1123bc813SAndreas Gohr<?php 2*90fb952cSAndreas Gohr 38553d24dSAndreas Gohruse dokuwiki\Extension\AdminPlugin; 454cc7aa4SAndreas Gohruse dokuwiki\StyleUtils; 5*90fb952cSAndreas Gohr 6123bc813SAndreas Gohr/** 7123bc813SAndreas Gohr * DokuWiki Plugin styling (Admin Component) 8123bc813SAndreas Gohr * 9123bc813SAndreas Gohr * @license GPL 2 http://www.gnu.org/licenses/gpl-2.0.html 10123bc813SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org> 11123bc813SAndreas Gohr */ 128553d24dSAndreas Gohrclass admin_plugin_styling extends AdminPlugin 1371a75f04SAndreas Gohr{ 146667cd87SAndreas Gohr public $ispopup = false; 156667cd87SAndreas Gohr 16123bc813SAndreas Gohr /** 17123bc813SAndreas Gohr * @return int sort number in admin menu 18123bc813SAndreas Gohr */ 1971a75f04SAndreas Gohr public function getMenuSort() 2071a75f04SAndreas Gohr { 21123bc813SAndreas Gohr return 1000; 22123bc813SAndreas Gohr } 23123bc813SAndreas Gohr 24123bc813SAndreas Gohr /** 25123bc813SAndreas Gohr * @return bool true if only access for superuser, false is for superusers and moderators 26123bc813SAndreas Gohr */ 2771a75f04SAndreas Gohr public function forAdminOnly() 2871a75f04SAndreas Gohr { 29123bc813SAndreas Gohr return true; 30123bc813SAndreas Gohr } 31123bc813SAndreas Gohr 32123bc813SAndreas Gohr /** 33123bc813SAndreas Gohr * handle the different actions (also called from ajax) 34123bc813SAndreas Gohr */ 3571a75f04SAndreas Gohr public function handle() 3671a75f04SAndreas Gohr { 37123bc813SAndreas Gohr global $INPUT; 38123bc813SAndreas Gohr $run = $INPUT->extract('run')->str('run'); 39123bc813SAndreas Gohr if (!$run) return; 4054bcc3a6SAndreas Gohr if (!checkSecurityToken()) return; 4171a75f04SAndreas Gohr $run = 'run' . ucfirst($run); 42123bc813SAndreas Gohr $this->$run(); 43123bc813SAndreas Gohr } 44123bc813SAndreas Gohr 45123bc813SAndreas Gohr /** 46123bc813SAndreas Gohr * Render HTML output, e.g. helpful text and a form 47123bc813SAndreas Gohr */ 4871a75f04SAndreas Gohr public function html() 4971a75f04SAndreas Gohr { 506667cd87SAndreas Gohr $class = 'nopopup'; 51d634152eSAnika Henke if ($this->ispopup) $class = 'ispopup page'; 526667cd87SAndreas Gohr 536667cd87SAndreas Gohr echo '<div id="plugin__styling" class="' . $class . '">'; 54a664aabaSAndreas Gohr echo '<h1>' . $this->getLang('menu') . '</h1>'; 556667cd87SAndreas Gohr $this->form(); 56123bc813SAndreas Gohr echo '</div>'; 57123bc813SAndreas Gohr } 58123bc813SAndreas Gohr 59123bc813SAndreas Gohr /** 60123bc813SAndreas Gohr * Create the actual editing form 61123bc813SAndreas Gohr */ 6271a75f04SAndreas Gohr public function form() 6371a75f04SAndreas Gohr { 64123bc813SAndreas Gohr global $conf; 65123bc813SAndreas Gohr global $ID; 66fb1f9089SMichael Große 6754cc7aa4SAndreas Gohr $styleUtil = new StyleUtils($conf['template'], true, true); 684593dbd2SAnna Dabrowska $styleini = $styleUtil->cssStyleini(); 69123bc813SAndreas Gohr $replacements = $styleini['replacements']; 70123bc813SAndreas Gohr 716667cd87SAndreas Gohr if ($this->ispopup) { 726667cd87SAndreas Gohr $target = DOKU_BASE . 'lib/plugins/styling/popup.php'; 73123bc813SAndreas Gohr } else { 7454cc7aa4SAndreas Gohr $target = wl($ID, ['do' => 'admin', 'page' => 'styling']); 75123bc813SAndreas Gohr } 76123bc813SAndreas Gohr 77123bc813SAndreas Gohr if (empty($replacements)) { 78123bc813SAndreas Gohr echo '<p class="error">' . $this->getLang('error') . '</p>'; 79123bc813SAndreas Gohr } else { 80123bc813SAndreas Gohr echo $this->locale_xhtml('intro'); 81123bc813SAndreas Gohr 82123bc813SAndreas Gohr echo '<form class="styling" method="post" action="' . $target . '">'; 8354bcc3a6SAndreas Gohr formSecurityToken(); 84123bc813SAndreas Gohr 85d634152eSAnika Henke echo '<table><tbody>'; 86123bc813SAndreas Gohr foreach ($replacements as $key => $value) { 87123bc813SAndreas Gohr $name = tpl_getLang($key); 88123bc813SAndreas Gohr if (empty($name)) $name = $this->getLang($key); 89123bc813SAndreas Gohr if (empty($name)) $name = $key; 90123bc813SAndreas Gohr 91123bc813SAndreas Gohr echo '<tr>'; 92147d8f48SAnika Henke echo '<td><label for="tpl__' . hsc($key) . '">' . $name . '</label></td>'; 93*90fb952cSAndreas Gohr echo '<td><input type="' . $this->colorType($value) . '" name="tpl[' . hsc($key) . ']" ' . 94*90fb952cSAndreas Gohr 'id="tpl__' . hsc($key) . '" value="' . hsc($this->colorValue($value)) . '" ' . 95*90fb952cSAndreas Gohr 'dir="ltr" required="required"/></td>'; 96123bc813SAndreas Gohr echo '</tr>'; 97123bc813SAndreas Gohr } 98d634152eSAnika Henke echo '</tbody></table>'; 99123bc813SAndreas Gohr 100418cb617SAndreas Gohr echo '<p>'; 10164159a61SAndreas Gohr echo '<button type="submit" name="run[preview]" class="btn_preview primary">' . 10264159a61SAndreas Gohr $this->getLang('btn_preview') . '</button> '; 10364159a61SAndreas Gohr #FIXME only if preview.ini exists: 10464159a61SAndreas Gohr echo '<button type="submit" name="run[reset]">' . $this->getLang('btn_reset') . '</button>'; 105123bc813SAndreas Gohr echo '</p>'; 106123bc813SAndreas Gohr 107418cb617SAndreas Gohr echo '<p>'; 108cf2c8e75SAnika Henke echo '<button type="submit" name="run[save]" class="primary">' . $this->getLang('btn_save') . '</button>'; 109123bc813SAndreas Gohr echo '</p>'; 110123bc813SAndreas Gohr 111418cb617SAndreas Gohr echo '<p>'; 11264159a61SAndreas Gohr #FIXME only if local.ini exists: 11364159a61SAndreas Gohr echo '<button type="submit" name="run[revert]">' . $this->getLang('btn_revert') . '</button>'; 114123bc813SAndreas Gohr echo '</p>'; 115123bc813SAndreas Gohr 116123bc813SAndreas Gohr echo '</form>'; 117123bc813SAndreas Gohr 118123bc813SAndreas Gohr echo tpl_locale_xhtml('style'); 119123bc813SAndreas Gohr } 120123bc813SAndreas Gohr } 121123bc813SAndreas Gohr 122123bc813SAndreas Gohr /** 1237ef28ec1SAndreas Gohr * Adjust three char color codes to the 6 char one supported by browser's color input 1247ef28ec1SAndreas Gohr * 1257ef28ec1SAndreas Gohr * @param string $value 1267ef28ec1SAndreas Gohr * @return string 1277ef28ec1SAndreas Gohr */ 1287ef28ec1SAndreas Gohr protected function colorValue($value) 1297ef28ec1SAndreas Gohr { 1307ef28ec1SAndreas Gohr if (preg_match('/^#([0-9a-fA-F])([0-9a-fA-F])([0-9a-fA-F])$/', $value, $match)) { 1317ef28ec1SAndreas Gohr return '#' . $match[1] . $match[1] . $match[2] . $match[2] . $match[3] . $match[3]; 1327ef28ec1SAndreas Gohr } 1337ef28ec1SAndreas Gohr return $value; 1347ef28ec1SAndreas Gohr } 1357ef28ec1SAndreas Gohr 1367ef28ec1SAndreas Gohr /** 13788c52daaSAndreas Gohr * Decide the input type based on the value 1383465db0cSAndreas Gohr * 13988c52daaSAndreas Gohr * @param string $value 1403465db0cSAndreas Gohr * @return string color|text 141123bc813SAndreas Gohr */ 14288c52daaSAndreas Gohr protected function colorType($value) 14371a75f04SAndreas Gohr { 14488c52daaSAndreas Gohr if (preg_match('/^#([0-9a-fA-F]{3}){1,2}$/', $value)) { 1453465db0cSAndreas Gohr return 'color'; 146123bc813SAndreas Gohr } else { 1473465db0cSAndreas Gohr return 'text'; 148123bc813SAndreas Gohr } 149123bc813SAndreas Gohr } 150123bc813SAndreas Gohr 151123bc813SAndreas Gohr /** 152123bc813SAndreas Gohr * saves the preview.ini (alos called from ajax directly) 153123bc813SAndreas Gohr */ 15471a75f04SAndreas Gohr public function runPreview() 15571a75f04SAndreas Gohr { 156123bc813SAndreas Gohr global $conf; 157123bc813SAndreas Gohr $ini = $conf['cachedir'] . '/preview.ini'; 158123bc813SAndreas Gohr io_saveFile($ini, $this->makeini()); 159123bc813SAndreas Gohr } 160123bc813SAndreas Gohr 161123bc813SAndreas Gohr /** 162123bc813SAndreas Gohr * deletes the preview.ini 163123bc813SAndreas Gohr */ 16471a75f04SAndreas Gohr protected function runReset() 16571a75f04SAndreas Gohr { 166123bc813SAndreas Gohr global $conf; 167123bc813SAndreas Gohr $ini = $conf['cachedir'] . '/preview.ini'; 168123bc813SAndreas Gohr io_saveFile($ini, ''); 169123bc813SAndreas Gohr } 170123bc813SAndreas Gohr 171123bc813SAndreas Gohr /** 172123bc813SAndreas Gohr * deletes the local style.ini replacements 173123bc813SAndreas Gohr */ 17471a75f04SAndreas Gohr protected function runRevert() 17571a75f04SAndreas Gohr { 17671a75f04SAndreas Gohr $this->replaceIni(''); 17771a75f04SAndreas Gohr $this->runReset(); 178123bc813SAndreas Gohr } 179123bc813SAndreas Gohr 180123bc813SAndreas Gohr /** 181123bc813SAndreas Gohr * save the local style.ini replacements 182123bc813SAndreas Gohr */ 18371a75f04SAndreas Gohr protected function runSave() 18471a75f04SAndreas Gohr { 18571a75f04SAndreas Gohr $this->replaceIni($this->makeini()); 18671a75f04SAndreas Gohr $this->runReset(); 187123bc813SAndreas Gohr } 188123bc813SAndreas Gohr 189123bc813SAndreas Gohr /** 190123bc813SAndreas Gohr * create the replacement part of a style.ini from submitted data 191123bc813SAndreas Gohr * 192123bc813SAndreas Gohr * @return string 193123bc813SAndreas Gohr */ 19471a75f04SAndreas Gohr protected function makeini() 19571a75f04SAndreas Gohr { 196123bc813SAndreas Gohr global $INPUT; 197123bc813SAndreas Gohr 198123bc813SAndreas Gohr $ini = "[replacements]\n"; 199123bc813SAndreas Gohr $ini .= ";These overwrites have been generated from the Template styling Admin interface\n"; 200123bc813SAndreas Gohr $ini .= ";Any values in this section will be overwritten by that tool again\n"; 201123bc813SAndreas Gohr foreach ($INPUT->arr('tpl') as $key => $val) { 202123bc813SAndreas Gohr $ini .= $key . ' = "' . addslashes($val) . '"' . "\n"; 203123bc813SAndreas Gohr } 204123bc813SAndreas Gohr 205123bc813SAndreas Gohr return $ini; 206123bc813SAndreas Gohr } 207123bc813SAndreas Gohr 208123bc813SAndreas Gohr /** 209123bc813SAndreas Gohr * replaces the replacement parts in the local ini 210123bc813SAndreas Gohr * 211123bc813SAndreas Gohr * @param string $new the new ini contents 212123bc813SAndreas Gohr */ 21371a75f04SAndreas Gohr protected function replaceIni($new) 21471a75f04SAndreas Gohr { 215123bc813SAndreas Gohr global $conf; 216123bc813SAndreas Gohr $ini = DOKU_CONF . "tpl/" . $conf['template'] . "/style.ini"; 217123bc813SAndreas Gohr if (file_exists($ini)) { 218123bc813SAndreas Gohr $old = io_readFile($ini); 219123bc813SAndreas Gohr $old = preg_replace('/\[replacements\]\n.*?(\n\[.*]|$)/s', '\\1', $old); 220123bc813SAndreas Gohr $old = trim($old); 221123bc813SAndreas Gohr } else { 222123bc813SAndreas Gohr $old = ''; 223123bc813SAndreas Gohr } 224123bc813SAndreas Gohr 225123bc813SAndreas Gohr io_makeFileDir($ini); 226123bc813SAndreas Gohr io_saveFile($ini, "$old\n\n$new"); 227123bc813SAndreas Gohr } 228123bc813SAndreas Gohr} 229123bc813SAndreas Gohr 230123bc813SAndreas Gohr// vim:ts=4:sw=4:et: 231