user_setting_edit.php 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804
  1. <?php
  2. /*
  3. FusionPBX
  4. Version: MPL 1.1
  5. The contents of this file are subject to the Mozilla Public License Version
  6. 1.1 (the "License"); you may not use this file except in compliance with
  7. the License. You may obtain a copy of the License at
  8. http://www.mozilla.org/MPL/
  9. Software distributed under the License is distributed on an "AS IS" basis,
  10. WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
  11. for the specific language governing rights and limitations under the
  12. License.
  13. The Original Code is FusionPBX
  14. The Initial Developer of the Original Code is
  15. Mark J Crane <[email protected]>
  16. Portions created by the Initial Developer are Copyright (C) 2008-2023
  17. the Initial Developer. All Rights Reserved.
  18. Contributor(s):
  19. Mark J Crane <[email protected]>
  20. */
  21. //includes files
  22. require_once dirname(__DIR__, 2) . "/resources/require.php";
  23. require_once "resources/check_auth.php";
  24. //check permissions
  25. if (permission_exists('user_setting_add') || permission_exists('user_setting_edit')) {
  26. //access granted
  27. }
  28. else {
  29. echo "access denied";
  30. exit;
  31. }
  32. //add multi-lingual support
  33. $language = new text;
  34. $text = $language->get();
  35. //retrieve allowed setting categories
  36. if (!permission_exists('user_setting_category_edit')) {
  37. if (!empty($_SESSION['settings'])) {
  38. foreach ($_SESSION['groups'] as $index => $group) {
  39. $group_name = $group['group_name'];
  40. if (!empty($_SESSION['settings'][$group_name])) {
  41. foreach ($_SESSION['settings'][$group_name] as $category) {
  42. $categories[] = strtolower($category);
  43. }
  44. }
  45. }
  46. }
  47. if (!empty($categories)) {
  48. $allowed_categories = array_unique($categories);
  49. sort($allowed_categories, SORT_NATURAL);
  50. }
  51. unset($group, $group_name, $index, $category, $categories);
  52. }
  53. //action add or update
  54. if (!empty($_REQUEST["id"]) && is_uuid($_REQUEST["id"])) {
  55. $action = "update";
  56. $user_setting_uuid = $_REQUEST["id"];
  57. }
  58. else {
  59. $action = "add";
  60. }
  61. //set the user_uuid
  62. if (!empty($_GET["user_uuid"]) && is_uuid($_GET["user_uuid"])) {
  63. $user_uuid = $_GET["user_uuid"];
  64. }
  65. //get http post variables and set them to php variables
  66. if (!empty($_REQUEST)) {
  67. $user_setting_category = strtolower($_REQUEST["user_setting_category"] ?? '');
  68. $user_setting_subcategory = strtolower($_POST["user_setting_subcategory"] ?? '');
  69. $user_setting_name = strtolower($_POST["user_setting_name"] ?? '');
  70. $user_setting_value = $_POST["user_setting_value"] ?? '';
  71. $user_setting_order = $_POST["user_setting_order"] ?? '';
  72. $user_setting_enabled = strtolower($_POST["user_setting_enabled"] ?? 'false');
  73. $user_setting_description = $_POST["user_setting_description"] ?? '';
  74. }
  75. if (!empty($_POST) && empty($_POST["persistformvar"])) {
  76. $msg = '';
  77. if ($action == "update") {
  78. $user_setting_uuid = $_POST["user_setting_uuid"];
  79. }
  80. //validate the token
  81. $token = new token;
  82. if (!$token->validate($_SERVER['PHP_SELF'])) {
  83. message::add($text['message-invalid_token'],'negative');
  84. header('Location: ../users/user_edit.php?id='.$user_uuid);
  85. exit;
  86. }
  87. //check for all required/authorized data
  88. if (empty($user_setting_category) || (!empty($allowed_categories) && is_array($allowed_categories) && sizeof($allowed_categories) > 0 && !in_array(strtolower($user_setting_category), $allowed_categories))) { $msg .= $text['message-required'].$text['label-category']."<br>\n"; }
  89. if (empty($user_setting_subcategory)) { $msg .= $text['message-required'].$text['label-subcategory']."<br>\n"; }
  90. if (empty($user_setting_name)) { $msg .= $text['message-required'].$text['label-type']."<br>\n"; }
  91. //if (empty($user_setting_value)) { $msg .= $text['message-required'].$text['label-value']."<br>\n"; }
  92. if (empty($user_setting_order)) { $msg .= $text['message-required'].$text['label-order']."<br>\n"; }
  93. if (empty($user_setting_enabled)) { $msg .= $text['message-required'].$text['label-enabled']."<br>\n"; }
  94. //if (empty($user_setting_description)) { $msg .= $text['message-required'].$text['label-description']."<br>\n"; }
  95. if (!empty($msg) && empty($_POST["persistformvar"])) {
  96. require_once "resources/header.php";
  97. require_once "resources/persist_form_var.php";
  98. echo "<div align='center'>\n";
  99. echo "<table><tr><td>\n";
  100. echo $msg."<br />";
  101. echo "</td></tr></table>\n";
  102. persistformvar($_POST);
  103. echo "</div>\n";
  104. require_once "resources/footer.php";
  105. return;
  106. }
  107. //add or update the database
  108. if (empty($_POST["persistformvar"])) {
  109. // fix null
  110. $user_setting_order = ($user_setting_order != '') ? $user_setting_order : 'null';
  111. //update switch timezone variables
  112. if ($user_setting_category == "domain" && $user_setting_subcategory == "time_zone" && $user_setting_name == "name" ) {
  113. //get the dialplan_uuid
  114. $sql = "select dialplan_uuid from v_dialplans ";
  115. $sql .= "where domain_uuid = :domain_uuid ";
  116. $sql .= "and app_uuid = '9f356fe7-8cf8-4c14-8fe2-6daf89304458' ";
  117. $parameters['domain_uuid'] = $domain_uuid;
  118. $database = new database;
  119. $dialplan_uuid = $database->select($sql, $parameters, 'column');
  120. unset($sql, $parameters);
  121. //get the action
  122. $sql = "select dialplan_detail_uuid from v_dialplan_details ";
  123. $sql .= "where domain_uuid = :domain_uuid ";
  124. $sql .= "and dialplan_uuid = :dialplan_uuid ";
  125. $sql .= "and dialplan_detail_tag = 'action' ";
  126. $sql .= "and dialplan_detail_type = 'set' ";
  127. $sql .= "and dialplan_detail_data like 'timezone=%' ";
  128. $parameters['domain_uuid'] = $domain_uuid;
  129. $parameters['dialplan_uuid'] = $dialplan_uuid;
  130. $database = new database;
  131. $dialplan_detail_uuid = $database->select($sql, $parameters, 'column');
  132. if (is_uuid($dialplan_detail_uuid)) {
  133. $detail_action = "update";
  134. }
  135. unset($sql, $parameters);
  136. //update the timezone
  137. if ($detail_action == "update") {
  138. $p = new permissions;
  139. $p->add('dialplan_detail_edit', 'temp');
  140. $array['dialplan_details'][0]['dialplan_detail_uuid'] = $dialplan_detail_uuid;
  141. $array['dialplan_details'][0]['dialplan_detail_data'] = 'timezone='.$user_setting_value;
  142. }
  143. else {
  144. $p = new permissions;
  145. $p->add('dialplan_detail_add', 'temp');
  146. $array['dialplan_details'][0]['domain_uuid'] = $domain_uuid;
  147. $array['dialplan_details'][0]['dialplan_detail_uuid'] = uuid();
  148. $array['dialplan_details'][0]['dialplan_uuid'] = $dialplan_uuid;
  149. $array['dialplan_details'][0]['dialplan_detail_tag'] = 'action';
  150. $array['dialplan_details'][0]['dialplan_detail_type'] = 'set';
  151. $array['dialplan_details'][0]['dialplan_detail_data'] = 'timezone='.$user_setting_value;
  152. $array['dialplan_details'][0]['dialplan_detail_inline'] = 'true';
  153. $array['dialplan_details'][0]['dialplan_detail_group'] = 0;
  154. }
  155. if (is_array($array) && sizeof($array) != 0) {
  156. $database = new database;
  157. $database->app_name = 'user_settings';
  158. $database->app_uuid = '3a3337f7-78d1-23e3-0cfd-f14499b8ed97';
  159. $database->save($array);
  160. unset($array);
  161. $p->delete('dialplan_detail_edit', 'temp');
  162. $p->delete('dialplan_detail_add', 'temp');
  163. }
  164. }
  165. //add the user setting
  166. if ($action == "add" && permission_exists('user_setting_add')) {
  167. $array['user_settings'][0]['user_setting_uuid'] = uuid();
  168. }
  169. //update the user setting
  170. if ($action == "update" && permission_exists('user_setting_edit')) {
  171. $array['user_settings'][0]['user_setting_uuid'] = $user_setting_uuid;
  172. }
  173. //execute add or update
  174. if (is_array($array) && sizeof($array) != 0) {
  175. $array['user_settings'][0]['user_uuid'] = $user_uuid;
  176. $array['user_settings'][0]['domain_uuid'] = $domain_uuid;
  177. $array['user_settings'][0]['user_setting_category'] = $user_setting_category;
  178. $array['user_settings'][0]['user_setting_subcategory'] = $user_setting_subcategory;
  179. $array['user_settings'][0]['user_setting_name'] = $user_setting_name;
  180. $array['user_settings'][0]['user_setting_value'] = $user_setting_value;
  181. $array['user_settings'][0]['user_setting_order'] = $user_setting_order;
  182. $array['user_settings'][0]['user_setting_enabled'] = $user_setting_enabled;
  183. $array['user_settings'][0]['user_setting_description'] = $user_setting_description;
  184. $database = new database;
  185. $database->app_name = 'user_settings';
  186. $database->app_uuid = '3a3337f7-78d1-23e3-0cfd-f14499b8ed97';
  187. $database->save($array);
  188. unset($array);
  189. }
  190. //update time zone
  191. if ($user_setting_category == "domain" && $user_setting_subcategory == "time_zone" && $user_setting_name == "name" && !empty($user_setting_value) ) {
  192. $sql = "select * from v_dialplans ";
  193. $sql .= "where app_uuid = '34dd307b-fffe-4ead-990c-3d070e288126' ";
  194. $sql .= "and domain_uuid = :domain_uuid ";
  195. $parameters['domain_uuid'] = $_SESSION["domain_uuid"];
  196. $database = new database;
  197. $result = $database->select($sql, $parameters, 'all');
  198. unset($sql, $parameters);
  199. $time_zone_found = false;
  200. if (is_array($result) && sizeof($result) != 0) {
  201. foreach ($result as &$row) {
  202. //get the dialplan_uuid
  203. $dialplan_uuid = $row["dialplan_uuid"];
  204. //get the dialplan details
  205. $sql = "select * from v_dialplan_details ";
  206. $sql .= "where dialplan_uuid = :dialplan_uuid ";
  207. $sql .= "and domain_uuid = :domain_uuid ";
  208. $parameters['dialplan_uuid'] = $dialplan_uuid;
  209. $parameters['domain_uuid'] = $_SESSION["domain_uuid"];
  210. $database = new database;
  211. $sub_result = $database->select($sql, $parameters, 'all');
  212. if (is_array($sub_result) && sizeof($sub_result) != 0) {
  213. foreach ($sub_result as $sub_row) {
  214. $dialplan_detail_uuid = $sub_row["dialplan_detail_uuid"];
  215. $dialplan_detail_tag = $sub_row["dialplan_detail_tag"]; //action //condition
  216. $dialplan_detail_type = $sub_row["dialplan_detail_type"]; //set
  217. $dialplan_detail_data = $sub_row["dialplan_detail_data"];
  218. $dialplan_detail_group = $sub_row["dialplan_detail_group"];
  219. if ($dialplan_detail_tag == "action" && $dialplan_detail_type == "set") {
  220. $data_array = explode("=", $dialplan_detail_data);
  221. if ($data_array[0] == "timezone") {
  222. $time_zone_found = true;
  223. break;
  224. }
  225. }
  226. }
  227. }
  228. unset($sql, $parameters, $sub_result, $sub_row);
  229. //add the time zone
  230. if (!$time_zone_found) {
  231. $dialplan_detail_uuid = "eb3b3a4e-88ea-4306-b2a8-9f52d3c95f2f";
  232. $array['dialplan_details'][0]['domain_uuid'] = $_SESSION["domain_uuid"];
  233. $array['dialplan_details'][0]['dialplan_uuid'] = $dialplan_uuid;
  234. $array['dialplan_details'][0]['dialplan_detail_uuid'] = $dialplan_detail_uuid;
  235. $array['dialplan_details'][0]['dialplan_detail_tag'] = 'action';
  236. $array['dialplan_details'][0]['dialplan_detail_type'] = 'set';
  237. $array['dialplan_details'][0]['dialplan_detail_data'] = 'timezone='.$user_setting_value;
  238. $array['dialplan_details'][0]['dialplan_detail_group'] = !empty($dialplan_detail_group) ? $dialplan_detail_group : 'null';
  239. $array['dialplan_details'][0]['dialplan_detail_order'] = '15';
  240. $p = new permissions;
  241. $p->add('dialplan_detail_add', 'temp');
  242. $database = new database;
  243. $database->app_name = 'user_settings';
  244. $database->app_uuid = '3a3337f7-78d1-23e3-0cfd-f14499b8ed97';
  245. $database->save($array);
  246. unset($array);
  247. $p->delete('dialplan_detail_add', 'temp');
  248. }
  249. //update the time zone
  250. if ($time_zone_found) {
  251. $array['dialplan_details'][0]['dialplan_detail_uuid'] = $dialplan_detail_uuid;
  252. $array['dialplan_details'][0]['dialplan_detail_data'] = 'timezone='.$user_setting_value;
  253. $array['dialplan_details'][0]['domain_uuid'] = $_SESSION["domain_uuid"];
  254. $array['dialplan_details'][0]['dialplan_uuid'] = $dialplan_uuid;
  255. $p = new permissions;
  256. $p->add('dialplan_detail_edit', 'temp');
  257. $database = new database;
  258. $database->app_name = 'user_settings';
  259. $database->app_uuid = '3a3337f7-78d1-23e3-0cfd-f14499b8ed97';
  260. $database->save($array);
  261. unset($array);
  262. $p->delete('dialplan_detail_edit', 'temp');
  263. }
  264. }
  265. }
  266. }
  267. //redirect the browser
  268. if ($action == "update") {
  269. message::add($text['message-update']);
  270. }
  271. if ($action == "add") {
  272. message::add($text['message-add']);
  273. }
  274. header("Location: /core/users/user_edit.php?id=".$user_uuid);
  275. return;
  276. }
  277. }
  278. //pre-populate the form
  279. if (!empty($_GET["id"]) && empty($_POST["persistformvar"])) {
  280. $user_setting_uuid = $_GET["id"];
  281. $sql = "select user_setting_category, user_setting_subcategory, user_setting_name, user_setting_value, user_setting_order, cast(user_setting_enabled as text), user_setting_description ";
  282. $sql .= "from v_user_settings ";
  283. $sql .= "where user_setting_uuid = :user_setting_uuid ";
  284. $sql .= "and user_uuid = :user_uuid ";
  285. $parameters['user_setting_uuid'] = $user_setting_uuid;
  286. $parameters['user_uuid'] = $user_uuid;
  287. $database = new database;
  288. $row = $database->select($sql, $parameters, 'row');
  289. if (is_array($row) && sizeof($row) != 0) {
  290. $user_setting_category = $row["user_setting_category"];
  291. $user_setting_subcategory = $row["user_setting_subcategory"];
  292. $user_setting_name = $row["user_setting_name"];
  293. $user_setting_value = $row["user_setting_value"];
  294. $user_setting_order = $row["user_setting_order"];
  295. $user_setting_enabled = $row["user_setting_enabled"];
  296. $user_setting_description = $row["user_setting_description"];
  297. }
  298. unset($sql, $parameters, $row);
  299. }
  300. //create token
  301. $object = new token;
  302. $token = $object->create($_SERVER['PHP_SELF']);
  303. //show the header
  304. require_once "resources/header.php";
  305. if ($action == "update") {
  306. $document['title'] = $text['title-user_setting-edit'];
  307. }
  308. else if ($action == "add") {
  309. $document['title'] = $text['title-user_setting-add'];
  310. }
  311. //show the content
  312. echo "<form name='frm' id='frm' method='post'>\n";
  313. echo "<div class='action_bar' id='action_bar'>\n";
  314. echo " <div class='heading'>";
  315. if ($action == "update") {
  316. echo "<b>".$text['header-user_setting-edit']."</b>";
  317. }
  318. if ($action == "add") {
  319. echo "<b>".$text['header-user_setting-add']."</b>";
  320. }
  321. echo "</div>\n";
  322. echo " <div class='actions'>\n";
  323. echo button::create(['type'=>'button','label'=>$text['button-back'],'icon'=>$_SESSION['theme']['button_icon_back'],'style'=>'margin-right: 15px;','link'=>'/core/users/user_edit.php?id='.urlencode($user_uuid)]);
  324. echo button::create(['type'=>'submit','label'=>$text['button-save'],'icon'=>$_SESSION['theme']['button_icon_save'],'id'=>'btn_save']);
  325. echo " </div>\n";
  326. echo " <div style='clear: both;'></div>\n";
  327. echo "</div>\n";
  328. if ($action == "update") {
  329. echo $text['description-user_setting-edit']."\n";
  330. }
  331. if ($action == "add") {
  332. echo $text['description-user_setting-add']."\n";
  333. }
  334. echo "<br /><br />\n";
  335. echo "<table width='100%' border='0' cellpadding='0' cellspacing='0'>\n";
  336. echo "<tr>\n";
  337. echo "<td width='30%' class='vncellreq' valign='top' align='left' nowrap='nowrap'>\n";
  338. echo " ".$text['label-category']."\n";
  339. echo "</td>\n";
  340. echo "<td width='70%' class='vtable' align='left'>\n";
  341. if (permission_exists('user_setting_category_edit')) {
  342. echo " <input type='text' class='formfld' name='user_setting_category' id='user_setting_category' maxlength='255' value=\"".escape($user_setting_category)."\">\n";
  343. }
  344. else {
  345. echo " <select class='formfld' name='user_setting_category' id='user_setting_category' onchange=\"$('#user_setting_subcategory').trigger('focus');\">\n";
  346. echo " <option value=''></option>\n";
  347. if (is_array($allowed_categories) && sizeof($allowed_categories) > 0) {
  348. foreach ($allowed_categories as $category) {
  349. $selected = ($user_setting_category == $category) ? 'selected' : null;
  350. echo " <option value='".$category."' ".$selected.">".ucwords(str_replace('_',' ',$category))."</option>\n";
  351. }
  352. }
  353. echo " </select>";
  354. }
  355. echo "<br />\n";
  356. echo $text['description-category']."\n";
  357. echo "</td>\n";
  358. echo "</tr>\n";
  359. echo "<tr>\n";
  360. echo "<td class='vncellreq' valign='top' align='left' nowrap='nowrap'>\n";
  361. echo " ".$text['label-subcategory']."\n";
  362. echo "</td>\n";
  363. echo "<td class='vtable' align='left'>\n";
  364. echo " <input class='formfld lowercase' type='text' name='user_setting_subcategory' id='user_setting_subcategory' maxlength='255' value=\"".escape($user_setting_subcategory)."\">\n";
  365. echo "<br />\n";
  366. echo $text['description-subcategory']."\n";
  367. echo "</td>\n";
  368. echo "</tr>\n";
  369. echo "<tr>\n";
  370. echo "<td class='vncellreq' valign='top' align='left' nowrap='nowrap'>\n";
  371. echo " ".$text['label-type']."\n";
  372. echo "</td>\n";
  373. echo "<td class='vtable' align='left'>\n";
  374. $setting_types = ['Array','Boolean','Code','Dir','Name','Numeric','Text','UUID'];
  375. echo " <select class='formfld' id='user_setting_name' name='user_setting_name' required='required'>\n";
  376. echo " <option value=''></option>\n";
  377. foreach ($setting_types as $setting_type) {
  378. echo " <option value='".strtolower($setting_type)."' ".($user_setting_name == strtolower($setting_type) ? "selected='selected'" : null).">".$setting_type."</option>\n";
  379. }
  380. echo " </select>\n";
  381. unset($setting_types, $setting_type);
  382. echo "<br />\n";
  383. echo $text['description-type']."\n";
  384. echo "</td>\n";
  385. echo "</tr>\n";
  386. echo "<tr>\n";
  387. echo "<td class='vncell' valign='top' align='left' nowrap='nowrap'>\n";
  388. echo " ".$text['label-value']."\n";
  389. echo "</td>\n";
  390. echo "<td class='vtable' align='left'>\n";
  391. if ($user_setting_category == "domain" && $user_setting_subcategory == "menu" && $user_setting_name == "uuid" ) {
  392. echo " <select class='formfld' id='user_setting_value' name='user_setting_value' style=''>\n";
  393. echo " <option value=''></option>\n";
  394. $sql = "select * from v_menus ";
  395. $sql .= "order by menu_language, menu_name asc ";
  396. $database = new database;
  397. $result = $database->select($sql, null, 'all');
  398. if (is_array($result) && sizeof($result) != 0) {
  399. foreach ($result as $row) {
  400. if (strtolower($user_setting_value) == strtolower($row["menu_uuid"])) {
  401. echo " <option value='".strtolower($row["menu_uuid"])."' selected='selected'>".escape($row["menu_language"])." - ".escape($row["menu_name"])."\n";
  402. }
  403. else {
  404. echo " <option value='".strtolower($row["menu_uuid"])."'>".escape($row["menu_language"])." - ".escape($row["menu_name"])."</option>\n";
  405. }
  406. }
  407. }
  408. unset($sql, $result, $row);
  409. echo " </select>\n";
  410. }
  411. else if ($user_setting_category == "domain" && $user_setting_subcategory == "template" && $user_setting_name == "name" ) {
  412. echo " <select class='formfld' id='user_setting_value' name='user_setting_value' style=''>\n";
  413. echo " <option value=''></option>\n";
  414. //add all the themes to the list
  415. $theme_dir = $_SERVER["DOCUMENT_ROOT"].PROJECT_PATH.'/themes';
  416. if ($handle = opendir($_SERVER["DOCUMENT_ROOT"].PROJECT_PATH.'/themes')) {
  417. while (false !== ($dir_name = readdir($handle))) {
  418. if ($dir_name != "." && $dir_name != ".." && $dir_name != ".svn" && $dir_name != ".git" && is_dir($theme_dir.'/'.$dir_name)) {
  419. $dir_label = str_replace('_', ' ', $dir_name);
  420. $dir_label = str_replace('-', ' ', $dir_label);
  421. if ($dir_name == $user_setting_value) {
  422. echo " <option value='".escape($dir_name)."' selected='selected'>".ucwords($dir_label)."</option>\n";
  423. }
  424. else {
  425. echo " <option value='".escape($dir_name)."'>".ucwords($dir_label)."</option>\n";
  426. }
  427. }
  428. }
  429. closedir($handle);
  430. }
  431. echo " </select>\n";
  432. }
  433. else if ($user_setting_category == "domain" && $user_setting_subcategory == "language" && $user_setting_name == "code" ) {
  434. echo " <select class='formfld' id='user_setting_value' name='user_setting_value' style=''>\n";
  435. echo " <option value=''></option>\n";
  436. foreach ($_SESSION['app']['languages'] as $key => $value) {
  437. if ($user_setting_value == $key) {
  438. echo " <option value='$value' selected='selected'>$value</option>\n";
  439. }
  440. else {
  441. echo " <option value='$value'>$value</option>\n";
  442. }
  443. }
  444. echo " </select>\n";
  445. }
  446. else if ($user_setting_category == "domain" && $user_setting_subcategory == "time_zone" && $user_setting_name == "name" ) {
  447. echo " <select class='formfld' id='user_setting_value' name='user_setting_value' style=''>\n";
  448. echo " <option value=''></option>\n";
  449. //$list = DateTimeZone::listAbbreviations();
  450. $time_zone_identifiers = DateTimeZone::listIdentifiers();
  451. $previous_category = '';
  452. $x = 0;
  453. foreach ($time_zone_identifiers as $key => $val) {
  454. $time_zone = explode("/", $val);
  455. $category = $time_zone[0];
  456. if ($category != $previous_category) {
  457. if ($x > 0) {
  458. echo " </optgroup>\n";
  459. }
  460. echo " <optgroup label='".$category."'>\n";
  461. }
  462. if (!empty($val)) {
  463. $time_zone_offset = get_time_zone_offset($val)/3600;
  464. $time_zone_offset_hours = floor($time_zone_offset);
  465. $time_zone_offset_minutes = ($time_zone_offset - $time_zone_offset_hours) * 60;
  466. $time_zone_offset_minutes = number_pad($time_zone_offset_minutes, 2);
  467. if ($time_zone_offset > 0) {
  468. $time_zone_offset_hours = number_pad($time_zone_offset_hours, 2);
  469. $time_zone_offset_hours = "+".$time_zone_offset_hours;
  470. }
  471. else {
  472. $time_zone_offset_hours = str_replace("-", "", $time_zone_offset_hours);
  473. $time_zone_offset_hours = "-".number_pad($time_zone_offset_hours, 2);
  474. }
  475. }
  476. if ($val == $user_setting_value) {
  477. echo " <option value='".$val."' selected='selected'>(UTC ".$time_zone_offset_hours.":".$time_zone_offset_minutes.") ".$val."</option>\n";
  478. }
  479. else {
  480. echo " <option value='".$val."'>(UTC ".escape($time_zone_offset_hours).":".escape($time_zone_offset_minutes).") ".$val."</option>\n";
  481. }
  482. $previous_category = $category;
  483. $x++;
  484. }
  485. echo " </select>\n";
  486. }
  487. else if ($user_setting_category == "domain" && $user_setting_subcategory == "time_format" && $user_setting_name == "text" ) {
  488. echo " <select class='formfld' id='user_setting_value' name='user_setting_value'>\n";
  489. echo " <option value='24h' ".(($user_setting_value == "24h") ? "selected='selected'" : null).">".$text['label-24-hour']."</option>\n";
  490. echo " <option value='12h' ".(($user_setting_value == "12h") ? "selected='selected'" : null).">".$text['label-12-hour']."</option>\n";
  491. echo " </select>\n";
  492. }
  493. else if ($user_setting_subcategory == 'password' || substr_count($user_setting_subcategory, '_password') > 0 || $user_setting_category == "login" && $user_setting_subcategory == "password_reset_key" && $user_setting_name == "text") {
  494. echo " <input class='formfld' type='password' id='user_setting_value' name='user_setting_value' maxlength='255' onmouseover=\"this.type='text';\" onfocus=\"this.type='text';\" onmouseout=\"if (!$(this).is(':focus')) { this.type='password'; }\" onblur=\"this.type='password';\" value=\"".escape($user_setting_value)."\">\n";
  495. }
  496. else if ($user_setting_category == "theme" && substr_count($user_setting_subcategory, "_color") > 0 && ($user_setting_name == "text" || $user_setting_name == 'array')) {
  497. echo " <input type='text' class='formfld colorpicker' id='user_setting_value' name='user_setting_value' value=\"".$user_setting_value."\">\n";
  498. }
  499. else if ($user_setting_category == "theme" && substr_count($user_setting_subcategory, "_font") > 0 && $user_setting_name == "text") {
  500. $user_setting_value = str_replace('"', "'", $user_setting_value);
  501. if ($fonts = get_available_fonts('alpha')) {
  502. echo " <select class='formfld' id='sel_user_setting_value' onchange=\"if (this.selectedIndex == $('select#sel_user_setting_value option').length - 1) { $('#txt_user_setting_value').val('').fadeIn('fast'); $('#txt_user_setting_value').trigger('focus'); } else { $('#txt_user_setting_value').fadeOut('fast', function(){ $('#txt_user_setting_value').val($('#sel_user_setting_value').val()) }); } \">\n";
  503. echo " <option value=''></option>\n";
  504. echo " <optgroup label='".$text['label-web_fonts']."'>\n";
  505. $option_found = false;
  506. foreach ($fonts as $n => $font) {
  507. if ($user_setting_value == $font) {
  508. $selected = 'selected';
  509. $option_found = true;
  510. }
  511. else {
  512. unset($selected);
  513. }
  514. echo " <option value='".$font."' ".$selected.">".$font."</option>\n";
  515. }
  516. echo " </optgroup>\n";
  517. echo " <option value='' disabled='disabled'></option>\n";
  518. echo " <option value='' ".(($user_setting_value != '' && $option_found == false) ? 'selected' : null).">".$text['label-other']."...</option>\n";
  519. echo " </select>";
  520. echo " <input type='text' class='formfld' ".(($user_setting_value == '' || $option_found) ? "style='display: none;'" : null)." id='txt_user_setting_value' name='user_setting_value' value=\"".escape($user_setting_value)."\">\n";
  521. }
  522. else {
  523. echo " <input type='text' class='formfld' id='user_setting_value' name='user_setting_value' value=\"".escape($user_setting_value)."\">\n";
  524. }
  525. }
  526. else if ($user_setting_category == "fax" && $user_setting_subcategory == "page_size" && $user_setting_name == "text" ) {
  527. echo " <select class='formfld' id='user_setting_value' name='user_setting_value' style=''>\n";
  528. echo " <option value='letter' ".(($user_setting_value == 'letter') ? 'selected' : null).">Letter</option>";
  529. echo " <option value='legal' ".(($user_setting_value == 'legal') ? 'selected' : null).">Legal</option>";
  530. echo " <option value='a4' ".(($user_setting_value == 'a4') ? 'selected' : null).">A4</option>";
  531. echo " </select>";
  532. }
  533. else if ($user_setting_category == "fax" && $user_setting_subcategory == "resolution" && $user_setting_name == "text" ) {
  534. echo " <select class='formfld' id='user_setting_value' name='user_setting_value' style=''>\n";
  535. echo " <option value='normal' ".(($user_setting_value == 'normal') ? 'selected' : null).">".$text['label-normal']."</option>";
  536. echo " <option value='fine' ".(($user_setting_value == 'fine') ? 'selected' : null).">".$text['label-fine']."</option>";
  537. echo " <option value='superfine' ".(($user_setting_value == 'superfine') ? 'selected' : null).">".$text['label-superfine']."</option>";
  538. echo " </select>";
  539. }
  540. else if ($user_setting_category == "theme" && $user_setting_subcategory == "domain_visible" && $user_setting_name == "text" ) {
  541. echo " <select class='formfld' id='user_setting_value' name='user_setting_value'>\n";
  542. echo " <option value='false' ".(($user_setting_value == "false") ? "selected='selected'" : null).">".$text['label-false']."</option>\n";
  543. echo " <option value='true' ".(($user_setting_value == "true") ? "selected='selected'" : null).">".$text['label-true']."</option>\n";
  544. echo " </select>\n";
  545. }
  546. else if ($user_setting_category == "theme" && $user_setting_subcategory == "menu_brand_type" && $user_setting_name == "text" ) {
  547. echo " <select class='formfld' id='user_setting_value' name='user_setting_value'>\n";
  548. echo " <option value='image' ".(($user_setting_value == "image") ? "selected='selected'" : null).">".$text['label-image']."</option>\n";
  549. echo " <option value='text' ".(($user_setting_value == "text") ? "selected='selected'" : null).">".$text['label-text']."</option>\n";
  550. echo " <option value='image_text' ".(($user_setting_value == "image_text") ? "selected='selected'" : null).">".$text['label-image_text']."</option>\n";
  551. echo " <option value='none' ".(($user_setting_value == "none") ? "selected='selected'" : null).">".$text['label-none']."</option>\n";
  552. echo " </select>\n";
  553. }
  554. else if ($user_setting_category == "theme" && $user_setting_subcategory == "menu_style" && $user_setting_name == "text" ) {
  555. echo " <select class='formfld' id='user_setting_value' name='user_setting_value'>\n";
  556. echo " <option value='fixed' ".(($user_setting_value == "fixed") ? "selected='selected'" : null).">".$text['label-fixed']."</option>\n";
  557. echo " <option value='static' ".(($user_setting_value == "static") ? "selected='selected'" : null).">".$text['label-static']."</option>\n";
  558. echo " <option value='inline' ".(($user_setting_value == "inline") ? "selected='selected'" : null).">".$text['label-inline']."</option>\n";
  559. echo " </select>\n";
  560. }
  561. else if ($user_setting_category == "theme" && $user_setting_subcategory == "menu_position" && $user_setting_name == "text" ) {
  562. echo " <select class='formfld' id='user_setting_value' name='user_setting_value'>\n";
  563. echo " <option value='top' ".(($user_setting_value == "top") ? "selected='selected'" : null).">".$text['label-top']."</option>\n";
  564. echo " <option value='bottom' ".(($user_setting_value == "bottom") ? "selected='selected'" : null).">".$text['label-bottom']."</option>\n";
  565. echo " </select>\n";
  566. }
  567. else if ($user_setting_category == "theme" && $user_setting_subcategory == "logo_align" && $user_setting_name == "text" ) {
  568. echo " <select class='formfld' id='user_setting_value' name='user_setting_value'>\n";
  569. echo " <option value='left' ".(($user_setting_value == "left") ? "selected='selected'" : null).">".$text['label-left']."</option>\n";
  570. echo " <option value='center' ".(($user_setting_value == "center") ? "selected='selected'" : null).">".$text['label-center']."</option>\n";
  571. echo " <option value='right' ".(($user_setting_value == "right") ? "selected='selected'" : null).">".$text['label-right']."</option>\n";
  572. echo " </select>\n";
  573. }
  574. elseif ($user_setting_category == "theme" && $user_setting_subcategory == "menu_side_state" && $user_setting_name == "text" ) {
  575. echo " <select class='formfld' id='user_setting_value' name='user_setting_value'>\n";
  576. echo " <option value='expanded'>".$text['option-expanded']."</option>\n";
  577. echo " <option value='contracted' ".($user_setting_value == "contracted" ? "selected='selected'" : null).">".$text['option-contracted']."</option>\n";
  578. echo " <option value='hidden' ".($user_setting_value == "hidden" ? "selected='selected'" : null).">".$text['option-hidden']."</option>\n";
  579. echo " </select>\n";
  580. }
  581. elseif ($user_setting_category == "theme" && $user_setting_subcategory == "menu_side_toggle" && $user_setting_name == "text" ) {
  582. echo " <select class='formfld' id='user_setting_value' name='user_setting_value'>\n";
  583. echo " <option value='hover'>".$text['option-hover']."</option>\n";
  584. echo " <option value='click' ".($user_setting_value == "click" ? "selected='selected'" : null).">".$text['option-click']."</option>\n";
  585. echo " </select>\n";
  586. }
  587. elseif ($user_setting_category == "theme" && $user_setting_subcategory == "menu_side_toggle_body_width" && $user_setting_name == "text" ) {
  588. echo " <select class='formfld' id='user_setting_value' name='user_setting_value'>\n";
  589. echo " <option value='shrink'>".$text['option-shrink']."</option>\n";
  590. echo " <option value='fixed' ".($user_setting_value == "fixed" ? "selected='selected'" : null).">".$text['option-fixed']."</option>\n";
  591. echo " </select>\n";
  592. }
  593. elseif ($user_setting_category == "theme" && $user_setting_subcategory == "menu_side_item_main_sub_close" && $user_setting_name == "text" ) {
  594. echo " <select class='formfld' id='user_setting_value' name='user_setting_value'>\n";
  595. echo " <option value='automatic'>".$text['option-automatic']."</option>\n";
  596. echo " <option value='manual' ".($user_setting_value == "manual" ? "selected='selected'" : null).">".$text['option-manual']."</option>\n";
  597. echo " </select>\n";
  598. }
  599. else if ($user_setting_category == "theme" && $user_setting_subcategory == "body_header_brand_type" && $user_setting_name == "text" ) {
  600. echo " <select class='formfld' id='user_setting_value' name='user_setting_value'>\n";
  601. echo " <option value='image' ".(($user_setting_value == "image") ? "selected='selected'" : null).">".$text['label-image']."</option>\n";
  602. echo " <option value='text' ".(($user_setting_value == "text") ? "selected='selected'" : null).">".$text['label-text']."</option>\n";
  603. echo " <option value='image_text' ".(($user_setting_value == "image_text") ? "selected='selected'" : null).">".$text['label-image_text']."</option>\n";
  604. echo " <option value='none' ".(($user_setting_value == "none") ? "selected='selected'" : null).">".$text['label-none']."</option>\n";
  605. echo " </select>\n";
  606. }
  607. elseif ($user_setting_category == "theme" && $user_setting_subcategory == "input_toggle_style" && $user_setting_name == "text" ) {
  608. echo " <select class='formfld' id='user_setting_value' name='user_setting_value'>\n";
  609. echo " <option value='select'>".$text['option-select']."</option>\n";
  610. echo " <option value='switch_round' ".(($user_setting_value == "switch_round") ? "selected='selected'" : null).">".$text['option-switch_round']."</option>\n";
  611. echo " <option value='switch_square' ".(($user_setting_value == "switch_square") ? "selected='selected'" : null).">".$text['option-switch_square']."</option>\n";
  612. echo " </select>\n";
  613. }
  614. elseif ($user_setting_category == "users" && $user_setting_subcategory == "username_format" && $user_setting_name == "text" ) {
  615. echo " <select class='formfld' id='user_setting_value' name='user_setting_value'>\n";
  616. echo " <option value='any' ".($user_setting_value == 'any' ? "selected='selected'" : null).">".$text['option-username_format_any']."</option>\n";
  617. echo " <option value='email' ".($user_setting_value == 'email' ? "selected='selected'" : null).">".$text['option-username_format_email']."</option>\n";
  618. echo " <option value='no_email' ".($user_setting_value == 'no_email' ? "selected='selected'" : null).">".$text['option-username_format_no_email']."</option>\n";
  619. echo " </select>\n";
  620. }
  621. elseif ($user_setting_category == "destinations" && $user_setting_subcategory == "dialplan_mode" && $user_setting_name == "text" ) {
  622. echo " <select class='formfld' id='user_setting_value' name='user_setting_value'>\n";
  623. echo " <option value='multiple'>".$text['label-multiple']."</option>\n";
  624. echo " <option value='single' ".(($user_setting_value == "single") ? "selected='selected'" : null).">".$text['label-single']."</option>\n";
  625. echo " </select>\n";
  626. }
  627. elseif ($user_setting_category == "destinations" && $user_setting_subcategory == "select_mode" && $user_setting_name == "text" ) {
  628. echo " <select class='formfld' id='user_setting_value' name='user_setting_value'>\n";
  629. echo " <option value='default'>".$text['label-default']."</option>\n";
  630. echo " <option value='dynamic' ".(($user_setting_value == "dynamic") ? "selected='selected'" : null).">".$text['label-dynamic']."</option>\n";
  631. echo " </select>\n";
  632. }
  633. elseif (is_json($user_setting_value)) {
  634. echo " <textarea class='formfld' style='width: 100%; height: 80px; font-family: courier, monospace; overflow: auto;' id='user_setting_value' name='user_setting_value' wrap='off'>".$user_setting_value."</textarea>\n";
  635. }
  636. elseif ($user_setting_name == "boolean") {
  637. echo " <select class='formfld' id='user_setting_value' name='user_setting_value'>\n";
  638. if ($user_setting_category == "provision" && is_numeric($user_setting_value)) {
  639. echo " <option value='0'>".$text['label-false']."</option>\n";
  640. echo " <option value='1' ".(($user_setting_value == 1) ? "selected='selected'" : null).">".$text['label-true']."</option>\n";
  641. }
  642. else {
  643. echo " <option value='false'>".$text['label-false']."</option>\n";
  644. echo " <option value='true' ".((strtolower($user_setting_value) == "true") ? "selected='selected'" : null).">".$text['label-true']."</option>\n";
  645. }
  646. echo " </select>\n";
  647. }
  648. else {
  649. echo " <input class='formfld' type='text' id='user_setting_value' name='user_setting_value' maxlength='255' value=\"".escape($user_setting_value)."\">\n";
  650. }
  651. echo "<br />\n";
  652. echo $text['description-value']."\n";
  653. if ($user_setting_category == "theme" && substr_count($user_setting_subcategory, "_font") > 0 && $user_setting_name == "text") {
  654. echo "&nbsp;&nbsp;".$text['label-reference'].": <a href='https://www.google.com/fonts' target='_blank'>".$text['label-web_fonts']."</a>\n";
  655. }
  656. echo "</td>\n";
  657. echo "</tr>\n";
  658. echo "</table>\n";
  659. echo "<div id='tr_order' ".(($user_setting_name != 'array') ? "style='display: none;'" : null).">\n";
  660. echo "<table width='100%' border='0' cellpadding='0' cellspacing='0'>\n";
  661. echo "<tr>\n";
  662. echo "<td width='30%' class='vncellreq' valign='top' align='left' nowrap='nowrap'>\n";
  663. echo " ".$text['label-order']."\n";
  664. echo "</td>\n";
  665. echo "<td width='70%' class='vtable' align='left'>\n";
  666. echo " <select name='user_setting_order' class='formfld'>\n";
  667. $i=0;
  668. while($i<=999) {
  669. $selected = ($i == $user_setting_order) ? "selected" : null;
  670. if (strlen($i) == 1) {
  671. echo " <option value='00$i' ".$selected.">00$i</option>\n";
  672. }
  673. if (strlen($i) == 2) {
  674. echo " <option value='0$i' ".$selected.">0$i</option>\n";
  675. }
  676. if (strlen($i) == 3) {
  677. echo " <option value='$i' ".$selected.">$i</option>\n";
  678. }
  679. $i++;
  680. }
  681. echo " </select>\n";
  682. echo " <br />\n";
  683. echo $text['description-order'] ?? ''."\n";
  684. echo "</td>\n";
  685. echo "</tr>\n";
  686. echo "</table>\n";
  687. echo "</div>\n";
  688. echo "<table width='100%' border='0' cellpadding='0' cellspacing='0'>\n";
  689. echo "<tr>\n";
  690. echo "<td width='30%' class='vncellreq' valign='top' align='left' nowrap>\n";
  691. echo " ".$text['label-enabled']."\n";
  692. echo "</td>\n";
  693. echo "<td width='70%' class='vtable' align='left'>\n";
  694. if (substr($_SESSION['theme']['input_toggle_style']['text'], 0, 6) == 'switch') {
  695. echo " <label class='switch'>\n";
  696. echo " <input type='checkbox' id='user_setting_enabled' name='user_setting_enabled' value='true' ".($user_setting_enabled == 'true' ? "checked='checked'" : null).">\n";
  697. echo " <span class='slider'></span>\n";
  698. echo " </label>\n";
  699. }
  700. else {
  701. echo " <select class='formfld' id='user_setting_enabled' name='user_setting_enabled'>\n";
  702. echo " <option value='true' ".($user_setting_enabled == 'true' ? "selected='selected'" : null).">".$text['option-true']."</option>\n";
  703. echo " <option value='false' ".($user_setting_enabled == 'false' ? "selected='selected'" : null).">".$text['option-false']."</option>\n";
  704. echo " </select>\n";
  705. }
  706. echo "<br />\n";
  707. //echo $text['description-setting_enabled']."\n";
  708. echo "</td>\n";
  709. echo "</tr>\n";
  710. echo "<tr>\n";
  711. echo "<td class='vncell' valign='top' align='left' nowrap='nowrap'>\n";
  712. echo " ".$text['label-description']."\n";
  713. echo "</td>\n";
  714. echo "<td class='vtable' align='left'>\n";
  715. echo " <textarea class='formfld' style='width: 185px; height: 80px;' name='user_setting_description'>".escape($user_setting_description)."</textarea>\n";
  716. echo "<br />\n";
  717. echo $text['description-description']."\n";
  718. echo "</td>\n";
  719. echo "</tr>\n";
  720. echo " <tr>\n";
  721. echo " <td colspan='2' align='right'>\n";
  722. echo " <input type='hidden' name='user_uuid' value='".escape($user_uuid)."'>\n";
  723. if ($action == "update") {
  724. echo " <input type='hidden' name='user_setting_uuid' value='".escape($user_setting_uuid)."'>\n";
  725. }
  726. echo " <input type='hidden' name='".$token['name']."' value='".$token['hash']."'>\n";
  727. echo " </td>\n";
  728. echo " </tr>";
  729. echo "</table>";
  730. echo "<br />";
  731. echo "</form>";
  732. echo "<script>\n";
  733. //hide/convert password fields then submit form
  734. echo " function submit_form() {\n";
  735. echo " hide_password_fields();\n";
  736. echo " $('form#frm').submit();\n";
  737. echo " }\n";
  738. //define lowercase class
  739. echo " $('.lowercase').on('blur',function(){ this.value = this.value.toLowerCase(); });";
  740. //show order if array
  741. echo " $('#user_setting_name').on('keyup',function(){ \n";
  742. echo " (this.value.toLowerCase() == 'array') ? $('#tr_order').slideDown('fast') : $('#tr_order').slideUp('fast');\n";
  743. echo " });\n";
  744. echo "</script>\n";
  745. //include the footer
  746. require_once "resources/footer.php";
  747. ?>