Update menu.php

This commit is contained in:
FusionPBX 2019-12-18 23:24:22 -07:00 committed by GitHub
parent a4854e3bb8
commit 9a41858dd5
1 changed files with 799 additions and 550 deletions

View File

@ -24,16 +24,253 @@
Mark J Crane <markjcrane@fusionpbx.com> Mark J Crane <markjcrane@fusionpbx.com>
*/ */
//define the menu class /**
* menu class
*
* @method null delete
* @method null toggle
* @method null copy
*/
if (!class_exists('menu')) { if (!class_exists('menu')) {
class menu { class menu {
//define the variables /**
* declare the variables
*/
private $app_name;
private $app_uuid;
private $name;
private $table;
private $toggle_field;
private $toggle_values;
private $description_field;
private $location;
public $menu_uuid; public $menu_uuid;
public $menu_language; public $menu_language;
//delete items in the menu that are not protected /**
public function delete() { * called when the object is created
*/
public function __construct() {
//assign the variables
$this->app_name = 'menus';
$this->app_uuid = 'f4b3b3d2-6287-489c-2a00-64529e46f2d7';
$this->name = 'menu';
$this->table = 'menus';
$this->toggle_field = '';
$this->toggle_values = ['true','false'];
$this->description_field = 'menu_description';
$this->location = 'menus.php';
}
/**
* called when there are no references to a particular object
* unset the variables used in the class
*/
public function __destruct() {
foreach ($this as $key => $value) {
unset($this->$key);
}
}
/**
* delete rows from the database
*/
public function delete($records) {
if (permission_exists($this->name.'_delete')) {
//add multi-lingual support
$language = new text;
$text = $language->get();
//validate the token
$token = new token;
if (!$token->validate($_SERVER['PHP_SELF'])) {
message::add($text['message-invalid_token'],'negative');
header('Location: '.$this->location);
exit;
}
//delete multiple records
if (is_array($records) && @sizeof($records) != 0) {
//build the delete array
$x = 0;
foreach ($records as $record) {
//add to the array
if ($record['checked'] == 'true' && is_uuid($record['uuid'])) {
//remove menu languages
$array['menu_languages'][$x][$this->name.'_uuid'] = $record['uuid'];
//remove menu item groups
$array['menu_item_groups'][$x][$this->name.'_uuid'] = $record['uuid'];
//remove menu items
$array['menu_items'][$x][$this->name.'_uuid'] = $record['uuid'];
//build array to remove the menu
$array['menus'][$x][$this->name.'_uuid'] = $record['uuid'];
}
//increment the id
$x++;
}
//delete the checked rows
if (is_array($array) && @sizeof($array) != 0) {
//execute delete
$database = new database;
$database->app_name = $this->app_name;
$database->app_uuid = $this->app_uuid;
$database->delete($array);
unset($array);
//set message
message::add($text['message-delete']);
}
unset($records);
}
}
}
/**
* toggle a field between two values
*/
public function toggle($records) {
if (permission_exists($this->name.'_edit')) {
//add multi-lingual support
$language = new text;
$text = $language->get();
//validate the token
$token = new token;
if (!$token->validate($_SERVER['PHP_SELF'])) {
message::add($text['message-invalid_token'],'negative');
header('Location: '.$this->location);
exit;
}
//toggle the checked records
if (is_array($records) && @sizeof($records) != 0) {
//get current toggle state
foreach($records as $record) {
if ($record['checked'] == 'true' && is_uuid($record['uuid'])) {
$uuids[] = "'".$record['uuid']."'";
}
}
if (is_array($uuids) && @sizeof($uuids) != 0) {
$sql = "select ".$this->name."_uuid as uuid, ".$this->toggle_field." as toggle from v_".$this->table." ";
$sql .= "where ".$this->name."_uuid in (".implode(', ', $uuids).") ";
$database = new database;
$rows = $database->select($sql, $parameters, 'all');
if (is_array($rows) && @sizeof($rows) != 0) {
foreach ($rows as $row) {
$states[$row['uuid']] = $row['toggle'];
}
}
unset($sql, $parameters, $rows, $row);
}
//build update array
$x = 0;
foreach($states as $uuid => $state) {
//create the array
$array[$this->table][$x][$this->name.'_uuid'] = $uuid;
$array[$this->table][$x][$this->toggle_field] = $state == $this->toggle_values[0] ? $this->toggle_values[1] : $this->toggle_values[0];
//increment the id
$x++;
}
//save the changes
if (is_array($array) && @sizeof($array) != 0) {
//save the array
$database = new database;
$database->app_name = $this->app_name;
$database->app_uuid = $this->app_uuid;
$database->save($array);
unset($array);
//set message
message::add($text['message-toggle']);
}
unset($records, $states);
}
}
}
/**
* copy rows from the database
*/
public function copy($records) {
if (permission_exists($this->name.'_add')) {
//add multi-lingual support
$language = new text;
$text = $language->get();
//validate the token
$token = new token;
if (!$token->validate($_SERVER['PHP_SELF'])) {
message::add($text['message-invalid_token'],'negative');
header('Location: '.$this->location);
exit;
}
//copy the checked records
if (is_array($records) && @sizeof($records) != 0) {
//get checked records
foreach($records as $record) {
if ($record['checked'] == 'true' && is_uuid($record['uuid'])) {
$uuids[] = "'".$record['uuid']."'";
}
}
//create the array from existing data
if (is_array($uuids) && @sizeof($uuids) != 0) {
$sql = "select * from v_".$this->table." ";
$sql .= "where ".$this->name."_uuid in (".implode(', ', $uuids).") ";
$database = new database;
$rows = $database->select($sql, $parameters, 'all');
if (is_array($rows) && @sizeof($rows) != 0) {
$x = 0;
foreach ($rows as $row) {
//copy data
$array[$this->table][$x] = $row;
//add copy to the description
$array[$this->table][$x][$this->name.'_uuid'] = uuid();
$array[$this->table][$x][$this->description_field] = trim($row[$this->description_field]).' ('.$text['label-copy'].')';
//increment the id
$x++;
}
}
unset($sql, $parameters, $rows, $row);
}
//save the changes and set the message
if (is_array($array) && @sizeof($array) != 0) {
//save the array
$database = new database;
$database->app_name = $this->app_name;
$database->app_uuid = $this->app_uuid;
$database->save($array);
unset($array);
//set message
message::add($text['message-copy']);
}
unset($records);
}
}
}
/**
* delete items in the menu that are not protected
*/
public function delete_unprotected() {
//remove existing menu languages //remove existing menu languages
$sql = "delete from v_menu_languages "; $sql = "delete from v_menu_languages ";
$sql .= "where menu_uuid = :menu_uuid "; $sql .= "where menu_uuid = :menu_uuid ";
@ -81,7 +318,9 @@ if (!class_exists('menu')) {
unset($sql, $parameters); unset($sql, $parameters);
} }
//restore the menu /**
* restore the menu
*/
public function restore() { public function restore() {
//get the $apps array from the installed apps from the core and mod directories //get the $apps array from the installed apps from the core and mod directories
@ -302,7 +541,9 @@ if (!class_exists('menu')) {
} }
//create the menu /**
* create the menu
*/
public function build_html($menu_item_level = 0) { public function build_html($menu_item_level = 0) {
$menu_html_full = ''; $menu_html_full = '';
@ -380,7 +621,9 @@ if (!class_exists('menu')) {
return $menu_html_full; return $menu_html_full;
} }
//create the sub menus /**
* create the sub menus
*/
private function build_child_html($menu_item_level, $submenu_array) { private function build_child_html($menu_item_level, $submenu_array) {
$db = $this->db; $db = $this->db;
@ -444,7 +687,9 @@ if (!class_exists('menu')) {
} }
} }
//create the menu array /**
* create the menu array
*/
public function menu_array($menu_item_level = 0) { public function menu_array($menu_item_level = 0) {
//if there are no groups then set the public group //if there are no groups then set the public group
@ -511,7 +756,9 @@ if (!class_exists('menu')) {
return $a; return $a;
} }
//create the sub menus /**
* create the sub menus
*/
private function menu_child_array($menu_item_level, $menu_item_uuid) { private function menu_child_array($menu_item_level, $menu_item_uuid) {
//set the level //set the level
@ -593,7 +840,9 @@ if (!class_exists('menu')) {
return $a; return $a;
} }
//add the default menu when no menu exists /**
* add the default menu when no menu exists
*/
public function menu_default() { public function menu_default() {
//set the default menu_uuid //set the default menu_uuid
$this->menu_uuid = 'b4750c3f-2a86-b00d-b7d0-345c14eca286'; $this->menu_uuid = 'b4750c3f-2a86-b00d-b7d0-345c14eca286';