Subversion Repositories oidplus

Rev

Rev 1206 | Rev 1266 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed

  1. <?php
  2.  
  3. /*
  4.  * OIDplus 2.0
  5.  * Copyright 2019 - 2023 Daniel Marschall, ViaThinkSoft
  6.  *
  7.  * Licensed under the Apache License, Version 2.0 (the "License");
  8.  * you may not use this file except in compliance with the License.
  9.  * You may obtain a copy of the License at
  10.  *
  11.  *     http://www.apache.org/licenses/LICENSE-2.0
  12.  *
  13.  * Unless required by applicable law or agreed to in writing, software
  14.  * distributed under the License is distributed on an "AS IS" BASIS,
  15.  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  16.  * See the License for the specific language governing permissions and
  17.  * limitations under the License.
  18.  */
  19.  
  20. namespace ViaThinkSoft\OIDplus;
  21.  
  22. // phpcs:disable PSR1.Files.SideEffects
  23. \defined('INSIDE_OIDPLUS') or die;
  24. // phpcs:enable PSR1.Files.SideEffects
  25.  
  26. class OIDplusPageAdminColors extends OIDplusPagePluginAdmin
  27.         implements INTF_OID_1_3_6_1_4_1_37476_2_5_2_3_1 /* oobeEntry, oobeRequested */
  28. {
  29.  
  30.         /**
  31.          * @param array $head_elems
  32.          * @return void
  33.          * @throws OIDplusException
  34.          */
  35.         public function htmlHeaderUpdate(array &$head_elems) {
  36.                 foreach ($head_elems as &$line) {
  37.                         if (strpos($line,'oidplus.min.css.php') !== false) {
  38.                                 $add_css_args = array();
  39.                                 $add_css_args[] = 'theme='.urlencode(OIDplus::config()->getValue('design','default'));
  40.                                 $add_css_args[] = 'invert='.urlencode(OIDplus::config()->getValue('color_invert',0));
  41.                                 $add_css_args[] = 'h_shift='.urlencode(number_format(OIDplus::config()->getValue('color_hue_shift',0)/360,5,'.',''));
  42.                                 $add_css_args[] = 's_shift='.urlencode(number_format(OIDplus::config()->getValue('color_sat_shift',0)/100,5,'.',''));
  43.                                 $add_css_args[] = 'v_shift='.urlencode(number_format(OIDplus::config()->getValue('color_val_shift',0)/100,5,'.',''));
  44.                                 if (count($add_css_args) > 0) {
  45.                                         $line = str_replace('oidplus.min.css.php?', 'oidplus.min.css.php&', $line);
  46.                                         $line = str_replace('oidplus.min.css.php', 'oidplus.min.css.php?'.htmlentities(implode('&',$add_css_args)), $line);
  47.                                 }
  48.                         }
  49.  
  50.                         if ((stripos($line,'<meta') !== false) && (stripos($line,'name="theme-color"') !== false)) {
  51.                                 if (preg_match('@content="(.+)"@ismU', $line, $m)) {
  52.                                         $theme_color = $m[1];
  53.                                         $hs = OIDplus::config()->getValue('color_hue_shift',0)/360;
  54.                                         $ss = OIDplus::config()->getValue('color_sat_shift',0)/100;
  55.                                         $vs = OIDplus::config()->getValue('color_val_shift',0)/100;
  56.                                         $theme_color = changeHueOfCSS($theme_color, $hs, $ss, $vs); // "changeHueOfCSS" can also change a single color value if it has the form #xxyyzz or #xyz
  57.                                         if (OIDplus::config()->getValue('color_invert',0)) {
  58.                                                 $theme_color = invertColorsOfCSS($theme_color);
  59.                                         }
  60.                                         $line = preg_replace('@content="(.+)"@ismU', 'content="'.$theme_color.'"', $line);
  61.  
  62.                                 }
  63.                         }
  64.                 }
  65.         }
  66.  
  67.         /**
  68.          * @param string $actionID
  69.          * @param array $params
  70.          * @return array
  71.          * @throws OIDplusException
  72.          */
  73.         public function action(string $actionID, array $params): array {
  74.                 if ($actionID == 'color_update') {
  75.                         if (!OIDplus::authUtils()->isAdminLoggedIn()) {
  76.                                 throw new OIDplusHtmlException(_L('You need to <a %1>log in</a> as administrator.',OIDplus::gui()->link('oidplus:login$admin')));
  77.                         }
  78.  
  79.                         _CheckParamExists($params, 'hue_shift');
  80.                         _CheckParamExists($params, 'sat_shift');
  81.                         _CheckParamExists($params, 'val_shift');
  82.                         _CheckParamExists($params, 'invcolors');
  83.                         _CheckParamExists($params, 'theme');
  84.  
  85.                         OIDplus::config()->setValue('color_hue_shift', $params['hue_shift']);
  86.                         OIDplus::config()->setValue('color_sat_shift', $params['sat_shift']);
  87.                         OIDplus::config()->setValue('color_val_shift', $params['val_shift']);
  88.                         OIDplus::config()->setValue('color_invert',    $params['invcolors']);
  89.                         OIDplus::config()->setValue('design',          $params['theme']);
  90.  
  91.                         OIDplus::logger()->log("[OK]A?", "Changed system color theme");
  92.  
  93.                         return array("status" => 0);
  94.                 } else {
  95.                         return parent::action($actionID, $params);
  96.                 }
  97.         }
  98.  
  99.         /**
  100.          * @param bool $html
  101.          * @return void
  102.          * @throws OIDplusException
  103.          */
  104.         public function init(bool $html=true) {
  105.                 OIDplus::config()->prepareConfigKey('color_hue_shift', 'HSV Hue shift of CSS colors (-360..360)', '0', OIDplusConfig::PROTECTION_EDITABLE, function($value) {
  106.                         if (!is_numeric($value) || ($value < -360) || ($value > 360)) {
  107.                                 throw new OIDplusException(_L('Please enter a valid value.'));
  108.                         }
  109.                 });
  110.                 OIDplus::config()->prepareConfigKey('color_sat_shift', 'HSV Saturation shift of CSS colors (-100..100)', '0', OIDplusConfig::PROTECTION_EDITABLE, function($value) {
  111.                         if (!is_numeric($value) || ($value < -100) || ($value > 100)) {
  112.                                 throw new OIDplusException(_L('Please enter a valid value.'));
  113.                         }
  114.                 });
  115.                 OIDplus::config()->prepareConfigKey('color_val_shift', 'HSV Value shift of CSS colors (-100..100)', '0', OIDplusConfig::PROTECTION_EDITABLE, function($value) {
  116.                         if (!is_numeric($value) || ($value < -100) || ($value > 100)) {
  117.                                 throw new OIDplusException(_L('Please enter a valid value.'));
  118.                         }
  119.                 });
  120.                 OIDplus::config()->prepareConfigKey('color_invert', 'Invert colors? (0=no, 1=yes)', '0', OIDplusConfig::PROTECTION_EDITABLE, function($value) {
  121.                         if (!is_numeric($value) || ($value < 0) || ($value > 1)) {
  122.                                 throw new OIDplusException(_L('Please enter a valid value (0=no, 1=yes).'));
  123.                         }
  124.                 });
  125.                 OIDplus::config()->prepareConfigKey('design', 'Which design to use (must exist in plugins/[vendorname]/design/)?', 'default', OIDplusConfig::PROTECTION_EDITABLE, function($value) {
  126.                         $good = true;
  127.                         if (strpos($value,'/') !== false) $good = false;
  128.                         if (strpos($value,'\\') !== false) $good = false;
  129.                         if (strpos($value,'..') !== false) $good = false;
  130.                         if (!$good) {
  131.                                 throw new OIDplusException(_L('Invalid design folder name. Do only enter a folder name, not an absolute or relative path'));
  132.                         }
  133.  
  134.                         if (!wildcard_is_dir(OIDplus::localpath().'plugins/'.'*'.'/design/'.$value)) {
  135.                                 throw new OIDplusException(_L('The design "%1" does not exist in plugin directory %2',$value,'plugins/[vendorname]/design/'));
  136.                         }
  137.                 });
  138.                 OIDplus::config()->prepareConfigKey('oobe_colors_done', '"Out Of Box Experience" wizard for OIDplusPageAdminColors done once?', '0', OIDplusConfig::PROTECTION_HIDDEN, function($value) {});
  139.         }
  140.  
  141.         /**
  142.          * @param string $id
  143.          * @param array $out
  144.          * @param bool $handled
  145.          * @return void
  146.          * @throws OIDplusException
  147.          */
  148.         public function gui(string $id, array &$out, bool &$handled) {
  149.                 if ($id === 'oidplus:colors') {
  150.                         $handled = true;
  151.                         $out['title'] = _L('Design');
  152.                         $out['icon']  = OIDplus::webpath(__DIR__,OIDplus::PATH_RELATIVE).'img/main_icon.png';
  153.  
  154.                         if (!OIDplus::authUtils()->isAdminLoggedIn()) {
  155.                                 throw new OIDplusHtmlException(_L('You need to <a %1>log in</a> as administrator.',OIDplus::gui()->link('oidplus:login$admin')), $out['title']);
  156.                         }
  157.  
  158.                         $out['text']  = '<br><p>';
  159.                         $out['text'] .= '  <label for="theme">'._L('Design').':</label>';
  160.                         $out['text'] .= '  <select name="theme" id="theme">';
  161.                         foreach (OIDplus::getDesignPlugins() as $plugin) {
  162.                                 $plugin_id = $plugin->id();
  163.                                 $selected = $plugin_id == OIDplus::config()->getValue('design') ? ' selected="true"' : '';
  164.                                 $out['text'] .= '<option value="'.htmlentities($plugin_id).'"'.$selected.'>'.htmlentities($plugin->getManifest()->getName()).'</option>';
  165.                         }
  166.                         $out['text'] .= '  </select>';
  167.                         $out['text'] .= '</p>';
  168.  
  169.                         $out['text'] .= '<br><p>';
  170.                         $out['text'] .= '  <label for="amount">'._L('Hue shift').':</label>';
  171.                         $out['text'] .= '  <input type="text" id="hshift" readonly style="border:0; background:transparent; font-weight:bold;">';
  172.                         $out['text'] .= '</p>';
  173.                         $out['text'] .= '<div id="slider-hshift"></div>';
  174.  
  175.                         $out['text'] .= '<br><p>';
  176.                         $out['text'] .= '  <label for="amount">'._L('Saturation shift').':</label>';
  177.                         $out['text'] .= '  <input type="text" id="sshift" readonly style="border:0; background:transparent; font-weight:bold;">';
  178.                         $out['text'] .= '</p>';
  179.                         $out['text'] .= '<div id="slider-sshift"></div>';
  180.  
  181.                         $out['text'] .= '<br><p>';
  182.                         $out['text'] .= '  <label for="amount">'._L('Value shift').':</label>';
  183.                         $out['text'] .= '  <input type="text" id="vshift" readonly style="border:0; background:transparent; font-weight:bold;">';
  184.                         $out['text'] .= '</p>';
  185.                         $out['text'] .= '<div id="slider-vshift"></div>';
  186.  
  187.                         $out['text'] .= '<p><div><input type="checkbox" id="icolor"> <label for="icolor">'._L('Invert colors').'</label></div></p>';
  188.  
  189.                         $out['text'] .= '<script>';
  190.                         $out['text'] .= 'if (OIDplusPageAdminColors.hue_shift == null) OIDplusPageAdminColors.hue_shift = OIDplusPageAdminColors.hue_shift_saved = '.OIDplus::config()->getValue('color_hue_shift').";\n";
  191.                         $out['text'] .= 'if (OIDplusPageAdminColors.sat_shift == null) OIDplusPageAdminColors.sat_shift = OIDplusPageAdminColors.sat_shift_saved = '.OIDplus::config()->getValue('color_sat_shift').";\n";
  192.                         $out['text'] .= 'if (OIDplusPageAdminColors.val_shift == null) OIDplusPageAdminColors.val_shift = OIDplusPageAdminColors.val_shift_saved = '.OIDplus::config()->getValue('color_val_shift').";\n";
  193.                         $out['text'] .= 'if (OIDplusPageAdminColors.invcolors == null) OIDplusPageAdminColors.invcolors = OIDplusPageAdminColors.invcolors_saved = '.OIDplus::config()->getValue('color_invert').";\n";
  194.                         $out['text'] .= 'if (OIDplusPageAdminColors.activetheme == null) OIDplusPageAdminColors.activetheme_saved = '.js_escape(OIDplus::config()->getValue('design')).";\n";
  195.                         $out['text'] .= 'OIDplusPageAdminColors.setup_color_sliders();';
  196.                         $out['text'] .= '</script>';
  197.  
  198.                         $out['text'] .= '<br>';
  199.                         $out['text'] .= '<input type="button" onclick="OIDplusPageAdminColors.color_reset_sliders_cfg()" value="'._L('Reset to last saved config').'">'.str_repeat('&nbsp;',5);
  200.                         $out['text'] .= '<input type="button" onclick="OIDplusPageAdminColors.color_reset_sliders_factory()" value="'._L('Reset default setting').'">'.str_repeat('&nbsp;',5);
  201.                         $out['text'] .= '<input type="button" onclick="OIDplusPageAdminColors.test_color_theme()" value="'._L('Test').'">'.str_repeat('&nbsp;',5);
  202.                         $out['text'] .= '<input type="button" onclick="OIDplusPageAdminColors.crudActionColorUpdate()" value="'._L('Set permanently').'">';
  203.                 }
  204.         }
  205.  
  206.         /**
  207.          * @param array $json
  208.          * @param string|null $ra_email
  209.          * @param bool $nonjs
  210.          * @param string $req_goto
  211.          * @return bool
  212.          * @throws OIDplusException
  213.          */
  214.         public function tree(array &$json, string $ra_email=null, bool $nonjs=false, string $req_goto=''): bool {
  215.                 if (!OIDplus::authUtils()->isAdminLoggedIn()) return false;
  216.  
  217.                 if (file_exists(__DIR__.'/img/main_icon16.png')) {
  218.                         $tree_icon = OIDplus::webpath(__DIR__,OIDplus::PATH_RELATIVE).'img/main_icon16.png';
  219.                 } else {
  220.                         $tree_icon = null; // default icon (folder)
  221.                 }
  222.  
  223.                 $json[] = array(
  224.                         'id' => 'oidplus:colors',
  225.                         'icon' => $tree_icon,
  226.                         'text' => _L('Design')
  227.                 );
  228.  
  229.                 return true;
  230.         }
  231.  
  232.         /**
  233.          * @param string $request
  234.          * @return array|false
  235.          */
  236.         public function tree_search(string $request) {
  237.                 return false;
  238.         }
  239.  
  240.         /**
  241.          * Implements interface INTF_OID_1_3_6_1_4_1_37476_2_5_2_3_1
  242.          * @return bool
  243.          * @throws OIDplusException
  244.          */
  245.         public function oobeRequested(): bool {
  246.                 return OIDplus::config()->getValue('oobe_colors_done') == '0';
  247.         }
  248.  
  249.         /**
  250.          * Implements interface INTF_OID_1_3_6_1_4_1_37476_2_5_2_3_1
  251.          * @param int $step
  252.          * @param bool $do_edits
  253.          * @param bool $errors_happened
  254.          * @return void
  255.          * @throws OIDplusException
  256.          */
  257.         public function oobeEntry(int $step, bool $do_edits, bool &$errors_happened)/*: void*/ {
  258.                 echo '<h2>'._L('Step %1: Color Theme',$step).'</h2>';
  259.  
  260.                 echo '<input type="checkbox" name="color_invert" id="color_invert"';
  261.                 if (isset($_POST['sent'])) {
  262.                         if ($set_value = isset($_POST['color_invert'])) {
  263.                                 echo ' checked';
  264.                         }
  265.                 } else {
  266.                         if ($set_value = (OIDplus::config()->getValue('color_invert') == 1)) {
  267.                                 echo ' checked';
  268.                         }
  269.                 }
  270.                 echo '> <label for="color_invert">'._L('Dark Theme (inverted colors)').'</label><br>';
  271.  
  272.                 $htmlmsg = '';
  273.                 if ($do_edits) {
  274.                         try {
  275.                                 OIDplus::config()->setValue('color_invert', $set_value ? 1 : 0);
  276.                                 OIDplus::config()->setValue('oobe_colors_done', '1');
  277.                         } catch (\Exception $e) {
  278.                                 $htmlmsg = $e instanceof OIDplusException ? $e->getHtmlMessage() : htmlentities($e->getMessage());
  279.                                 $errors_happened = true;
  280.                         }
  281.                 }
  282.  
  283.                 echo ' <font color="red"><b>'.$htmlmsg.'</b></font>';
  284.         }
  285.  
  286. }
  287.