diff --git a/app/ivr_menus/resources/classes/ivr_menu.php b/app/ivr_menus/resources/classes/ivr_menu.php
index f7783c86ee..abbcda9c60 100644
--- a/app/ivr_menus/resources/classes/ivr_menu.php
+++ b/app/ivr_menus/resources/classes/ivr_menu.php
@@ -166,7 +166,7 @@ if (!class_exists('ivr_menu')) {
//clear the cache
if (is_array($ivr_menu_contexts) && @sizeof($ivr_menu_contexts) != 0) {
- $ivr_menu_contexts = array_unique($ivr_menu_contexts, SORT_STRING);
+ $ivr_menu_contexts = array_unique($ivr_menu_contexts);
$cache = new cache;
foreach ($ivr_menu_contexts as $ivr_menu_context) {
$cache->delete("dialplan:".$dialplan_context);
diff --git a/app/modules/resources/classes/modules.php b/app/modules/resources/classes/modules.php
index 0a8756ee5d..4dd6908286 100644
--- a/app/modules/resources/classes/modules.php
+++ b/app/modules/resources/classes/modules.php
@@ -965,8 +965,8 @@ if (!class_exists('modules')) {
}
//build the delete array
- $x = 0;
if (is_array($modules) && @sizeof($modules) != 0) {
+ $x = 0;
foreach ($modules as $module_uuid => $module) {
$array[$this->table][$x][$this->uuid_prefix.'uuid'] = $module_uuid;
$x++;
diff --git a/app/number_translations/number_translations.php b/app/number_translations/number_translations.php
index e5850e82c9..840436399d 100644
--- a/app/number_translations/number_translations.php
+++ b/app/number_translations/number_translations.php
@@ -167,7 +167,7 @@
}
echo th_order_by('number_translation_name', $text['label-number_translation_name'], $order_by, $order);
echo th_order_by('number_translation_enabled', $text['label-number_translation_enabled'], $order_by, $order, null, "class='center'");
- echo th_order_by('number_translation_description', $text['label-number_translation_description'], $order_by, $order, null, "class='hide-sm-dn'");
+ echo th_order_by('number_translation_description', $text['label-number_translation_description'], $order_by, $order, null, "class='hide-sm-dn' style='min-width: 50%;'");
if (permission_exists('number_translation_edit') && $_SESSION['theme']['list_row_edit_button']['boolean'] == 'true') {
echo "
| \n";
}
@@ -203,7 +203,7 @@
echo $text['label-'.$row['number_translation_enabled']];
}
echo " \n";
- echo " ".escape($row['number_translation_description'])." | \n";
+ echo " ".escape($row['number_translation_description'])." | \n";
if (permission_exists('number_translation_edit') && $_SESSION['theme']['list_row_edit_button']['boolean'] == 'true') {
echo " ";
echo button::create(['type'=>'button','title'=>$text['button-edit'],'icon'=>$_SESSION['theme']['button_icon_edit'],'link'=>$list_row_url]);
diff --git a/app/phrases/phrases.php b/app/phrases/phrases.php
index f8d32701cc..1ee85a1bdc 100644
--- a/app/phrases/phrases.php
+++ b/app/phrases/phrases.php
@@ -17,7 +17,7 @@
The Initial Developer of the Original Code is
Mark J Crane
- Portions created by the Initial Developer are Copyright (C) 2008-2015
+ Portions created by the Initial Developer are Copyright (C) 2018 - 2019
the Initial Developer. All Rights Reserved.
Contributor(s):
@@ -28,6 +28,8 @@
include "root.php";
require_once "resources/require.php";
require_once "resources/check_auth.php";
+ require_once "resources/paging.php";
+ require_once "resources/functions/save_phrases_xml.php";
//check the permission
if (!permission_exists('phrase_view')) {
@@ -39,113 +41,205 @@
$language = new text;
$text = $language->get();
-//get the http get values and set them as php variables
+//get posted data
+ if (is_array($_POST['phrases'])) {
+ $action = $_POST['action'];
+ $search = $_POST['search'];
+ $phrases = $_POST['phrases'];
+ }
+
+//copy the phrases
+ if (permission_exists('phrase_add')) {
+ if ($action == 'copy' && is_array($phrases) && @sizeof($phrases) != 0) {
+ //copy
+ $obj = new phrases;
+ $obj->copy($phrases);
+ //save the xml
+ save_phrases_xml();
+ //redirect
+ header('Location: phrases.php'.($search != '' ? '?search='.urlencode($search) : null));
+ exit;
+ }
+ }
+
+//toggle the phrases
+ if (permission_exists('phrase_edit')) {
+ if ($action == 'toggle' && is_array($phrases) && @sizeof($phrases) != 0) {
+ //toggle
+ $obj = new phrases;
+ $obj->toggle($phrases);
+ //save the xml
+ save_phrases_xml();
+ //redirect
+ header('Location: phrases.php'.($search != '' ? '?search='.urlencode($search) : null));
+ exit;
+ }
+ }
+
+//delete the phrases
+ if (permission_exists('phrase_delete')) {
+ if ($action == 'delete' && is_array($phrases) && @sizeof($phrases) != 0) {
+ //delete
+ $obj = new phrases;
+ $obj->delete($phrases);
+ //save the xml
+ save_phrases_xml();
+ //redirect
+ header('Location: phrases.php'.($search != '' ? '?search='.urlencode($search) : null));
+ exit;
+ }
+ }
+
+//get order and order by
$order_by = $_GET["order_by"];
$order = $_GET["order"];
-//add paging
- require_once "resources/paging.php";
+//add the search term
+ $search = strtolower($_GET["search"]);
+ if (strlen($search) > 0) {
+ $sql_search = "and (";
+ $sql_search .= "lower(phrase_name) like :search ";
+ $sql_search .= "or lower(phrase_enabled) like :search ";
+ $sql_search .= "or lower(phrase_description) like :search ";
+ $sql_search .= ") ";
+ $parameters['search'] = '%'.$search.'%';
+ }
+
+//get phrases record count
+ $sql = "select count(*) from v_phrases ";
+ $sql .= "where (domain_uuid = :domain_uuid or domain_uuid is null) ";
+ $sql .= $sql_search;
+ $parameters['domain_uuid'] = $domain_uuid;
+ $database = new database;
+ $num_rows = $database->select($sql, $parameters, 'column');
+
+//prepare to page the results
+ $rows_per_page = ($_SESSION['domain']['paging']['numeric'] != '') ? $_SESSION['domain']['paging']['numeric'] : 50;
+ $param = "&search=".$search;
+ $page = is_numeric($_GET['page']) ? $_GET['page'] : 0;
+ list($paging_controls, $rows_per_page) = paging($num_rows, $param, $rows_per_page);
+ list($paging_controls_mini, $rows_per_page) = paging($num_rows, $param, $rows_per_page, true);
+ $offset = $rows_per_page * $page;
+
+//get the list
+ $sql = str_replace('count(*)', '*', $sql);
+ $sql .= order_by($order_by, $order, 'phrase_name', 'asc');
+ $sql .= limit_offset($rows_per_page, $offset);
+ $database = new database;
+ $phrases = $database->select($sql, $parameters, 'all');
+ unset($sql, $parameters);
+
+//create token
+ $object = new token;
+ $token = $object->create($_SERVER['PHP_SELF']);
//include the header
require_once "resources/header.php";
$document['title'] = $text['title-phrases'];
//begin the content
- echo "\n";
- echo " \n";
- echo " \n";
- echo " ".$text['header_phrases']."\n";
- echo "
\n";
- echo " ".$text['description-phrases']."\n";
- echo " | \n";
- echo " \n";
- echo " ";
- echo " \n";
+ echo "\n";
+ echo " ".$text['header_phrases']." (".$num_rows.") \n";
+ echo " \n";
+ if (permission_exists('phrase_add')) {
+ echo button::create(['type'=>'button','label'=>$text['button-add'],'icon'=>$_SESSION['theme']['button_icon_add'],'link'=>'phrase_edit.php']);
+ }
+ if (permission_exists('phrase_add') && $phrases) {
+ echo button::create(['type'=>'button','label'=>$text['button-copy'],'icon'=>$_SESSION['theme']['button_icon_copy'],'onclick'=>"if (confirm('".$text['confirm-copy']."')) { list_action_set('copy'); list_form_submit('form_list'); } else { this.blur(); return false; }"]);
+ }
+ if (permission_exists('phrase_edit') && $phrases) {
+ echo button::create(['type'=>'button','label'=>$text['button-toggle'],'icon'=>$_SESSION['theme']['button_icon_toggle'],'onclick'=>"if (confirm('".$text['confirm-toggle']."')) { list_action_set('toggle'); list_form_submit('form_list'); } else { this.blur(); return false; }"]);
+ }
+ if (permission_exists('phrase_delete') && $phrases) {
+ echo button::create(['type'=>'button','label'=>$text['button-delete'],'icon'=>$_SESSION['theme']['button_icon_delete'],'onclick'=>"if (confirm('".$text['confirm-delete']."')) { list_action_set('delete'); list_form_submit('form_list'); } else { this.blur(); return false; }"]);
+ }
+ echo "\n";
+ echo " \n";
+ echo " \n";
+ echo " \n";
- $sql = "select count(*) from v_phrases ";
- $sql .= "where domain_uuid = :domain_uuid ";
- $sql .= "or domain_uuid is null ";
- $parameters['domain_uuid'] = $domain_uuid;
- $database = new database;
- $num_rows = $database->select($sql, $parameters, 'column');
+ echo $text['description-phrases']."\n";
+ echo "
\n";
- $rows_per_page = ($_SESSION['domain']['paging']['numeric'] != '') ? $_SESSION['domain']['paging']['numeric'] : 50;
- $param = "";
- $page = $_GET['page'];
- if (strlen($page) == 0) { $page = 0; $_GET['page'] = 0; }
- list($paging_controls, $rows_per_page, $var_3) = paging($num_rows, $param, $rows_per_page);
- $offset = $rows_per_page * $page;
+ echo " |