3973 lines
121 KiB
PHP
3973 lines
121 KiB
PHP
<?php
|
|
|
|
// Pandora FMS - http://pandorafms.com
|
|
// ==================================================
|
|
// Copyright (c) 2005-2011 Artica Soluciones Tecnologicas
|
|
// Please see http://pandorafms.org for full contribution list
|
|
// This program is free software; you can redistribute it and/or
|
|
// modify it under the terms of the GNU Lesser General Public License
|
|
// as published by the Free Software Foundation; version 2
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
/**
|
|
* @package Include
|
|
* @subpackage HTML
|
|
*/
|
|
|
|
if (!isset($config)) {
|
|
$working_dir = getcwd();
|
|
$working_dir = str_replace('\\', '/', $working_dir);
|
|
// Windows compatibility.
|
|
$levels = substr_count($working_dir, '/');
|
|
|
|
for ($i = 0; $i < $levels; $i++) {
|
|
if (file_exists(str_repeat('../', $i).'config.php')) {
|
|
include_once str_repeat('../', $i).'config.php';
|
|
break;
|
|
// Skip config.php loading after load the first one.
|
|
} else if (file_exists(str_repeat('../', $i).'include/config.php')) {
|
|
// For path from the enterprise structure dirs.
|
|
include_once str_repeat('../', $i).'include/config.php';
|
|
break;
|
|
// Skip config.php loading after load the first one.
|
|
}
|
|
}
|
|
} else {
|
|
include_once $config['homedir'].'/include/functions.php';
|
|
include_once $config['homedir'].'/include/functions_users.php';
|
|
include_once $config['homedir'].'/include/functions_groups.php';
|
|
include_once $config['homedir'].'/include/functions_ui.php';
|
|
}
|
|
|
|
|
|
/**
|
|
* Prints the print_r with < pre > tags
|
|
*/
|
|
function html_debug_print($var, $file='', $oneline=false)
|
|
{
|
|
$more_info = '';
|
|
if (is_string($var)) {
|
|
$more_info = 'size: '.strlen($var);
|
|
} else if (is_bool($var)) {
|
|
$more_info = 'val: '.($var ? 'true' : 'false');
|
|
} else if (is_null($var)) {
|
|
$more_info = 'is null';
|
|
} else if (is_array($var)) {
|
|
$more_info = count($var);
|
|
}
|
|
|
|
if ($file === true) {
|
|
$file = '/tmp/logDebug';
|
|
}
|
|
|
|
if ($oneline && is_string($var)) {
|
|
$var = preg_replace("/[\t|\n| ]+/", ' ', $var);
|
|
}
|
|
|
|
if (strlen($file) > 0) {
|
|
$f = fopen($file, 'a');
|
|
ob_start();
|
|
echo date('Y/m/d H:i:s').' ('.gettype($var).') '.$more_info."\n";
|
|
print_r($var);
|
|
echo "\n\n";
|
|
$output = ob_get_clean();
|
|
fprintf($f, '%s', $output);
|
|
fclose($f);
|
|
} else {
|
|
echo '<pre style="z-index: 10000; background: #fff; padding: 1em;">'.date('Y/m/d H:i:s').' ('.gettype($var).') '.$more_info."\n";
|
|
print_r($var);
|
|
echo '</pre>';
|
|
}
|
|
}
|
|
|
|
|
|
// Alias for "html_debug_print"
|
|
function html_debug($var, $file='', $oneline=false)
|
|
{
|
|
html_debug_print($var, $file, $oneline);
|
|
}
|
|
|
|
|
|
// Alias for "html_debug_print"
|
|
function hd($var, $file='', $oneline=false)
|
|
{
|
|
html_debug_print($var, $file, $oneline);
|
|
}
|
|
|
|
|
|
/**
|
|
* Encapsulation (ob) for debug print function.
|
|
*
|
|
* @param mixed $var Variable to be dumped.
|
|
* @param string $file Target file path.
|
|
* @param boolean $oneline Show in oneline.
|
|
*
|
|
* @return string Dump string.
|
|
*/
|
|
function obhd($var, $file='', $oneline=false)
|
|
{
|
|
ob_start();
|
|
hd($var, $file, $oneline);
|
|
return ob_get_clean();
|
|
}
|
|
|
|
|
|
function debug()
|
|
{
|
|
$args_num = func_num_args();
|
|
$arg_list = func_get_args();
|
|
|
|
for ($i = 0; $i < $args_num; $i++) {
|
|
html_debug_print($arg_list[$i], true);
|
|
}
|
|
}
|
|
|
|
|
|
function html_f2str($function, $params)
|
|
{
|
|
ob_start();
|
|
|
|
call_user_func_array($function, $params);
|
|
|
|
return ob_get_clean();
|
|
}
|
|
|
|
|
|
/**
|
|
* Print side layer
|
|
*
|
|
* @params mixed Hash with all the params:
|
|
*
|
|
* position: left or right
|
|
* width: width of the layer
|
|
* height: height of the layer
|
|
* icon_closed: icon showed when layer is hidden
|
|
* icon_open: icon showed when layer is showed
|
|
* top_text: text over the content
|
|
* body_text: content of layer
|
|
* bottom_text: text under the contet
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
|
|
|
|
function html_print_side_layer($params)
|
|
{
|
|
global $config;
|
|
|
|
// Check mandatory values, if any of them is missed, return ''
|
|
$mandatory = [
|
|
'icon_closed',
|
|
'body_text',
|
|
];
|
|
|
|
foreach ($mandatory as $man) {
|
|
if (!isset($params[$man])) {
|
|
return '';
|
|
}
|
|
}
|
|
|
|
// Set default values if not setted
|
|
$defaults = [
|
|
'position' => 'left',
|
|
'width' => '400',
|
|
'height' => '97%',
|
|
'top_text' => '',
|
|
'bottom_text' => '',
|
|
'top' => '0',
|
|
'autotop' => '',
|
|
'right' => '0',
|
|
'autoright' => '',
|
|
'vertical_mode' => 'out',
|
|
'icon_width' => 50,
|
|
'icon_height' => 50,
|
|
'icon_open' => $params['icon_closed'],
|
|
];
|
|
|
|
foreach ($defaults as $token => $value) {
|
|
if (!isset($params[$token])) {
|
|
$params[$token] = $value;
|
|
}
|
|
}
|
|
|
|
// z-index is 1 because 2 made the calendar show under the side_layer
|
|
switch ($params['position']) {
|
|
case 'left':
|
|
$round_class = 'menu_sidebar_radius_right';
|
|
$body_float = 'left';
|
|
$button_float = 'right';
|
|
break;
|
|
|
|
case 'right':
|
|
$round_class = 'menu_sidebar_radius_left';
|
|
$body_float = 'right';
|
|
$button_float = 'left';
|
|
break;
|
|
|
|
case 'bottom':
|
|
$round_class = 'menu_sidebar_radius_left menu_sidebar_radius_right';
|
|
$body_float = 'right';
|
|
$button_float = 'left';
|
|
break;
|
|
}
|
|
|
|
$out_html = '<div id="side_layer" class="menu_sidebar '.$round_class.'" style="display:none; z-index:1; overflow: hidden; height: '.$params['height'].'; width: '.$params['width'].';">';
|
|
|
|
$table = new stdClass();
|
|
$table->id = 'side_layer_layout';
|
|
$table->width = $params['width'].'px';
|
|
$table->cellspacing = 2;
|
|
$table->cellpadding = 2;
|
|
$table->class = 'none';
|
|
|
|
$top = '<div id="side_top_text" style="width: 100%";">'.$params['top_text'].'</div>';
|
|
|
|
$button = '<div id="show_menu" style="vertical-align: middle; position: relative; width: '.$params['icon_width'].'px; padding-right: 17px; text-align: right; height: '.$params['icon_height'].'px;">';
|
|
// Use the no_meta parameter because this image is only in the base console
|
|
$button .= html_print_image(
|
|
$params['position'] == 'left' ? $params['icon_open'] : $params['icon_closed'],
|
|
true,
|
|
['id' => 'graph_menu_arrow'],
|
|
false,
|
|
false,
|
|
true
|
|
);
|
|
$button .= '</div>';
|
|
|
|
$body = '<div id="side_body_text" style="width: 100%;">'.$params['body_text'].'</div>';
|
|
|
|
$bottom = '<div id="side_bottom_text" style="text-align: '.$params['position'].';">'.$params['bottom_text'].'</div>';
|
|
|
|
switch ($params['position']) {
|
|
case 'left':
|
|
$table->size[1] = '15%';
|
|
|
|
$table->data[0][0] = $top;
|
|
$table->data[0][1] = '';
|
|
$table->rowclass[0] = '';
|
|
|
|
$table->data[1][0] = $body;
|
|
|
|
$table->data[1][1] = $button;
|
|
$table->rowclass[1] = '';
|
|
|
|
$table->data[2][0] = $bottom;
|
|
$table->data[2][1] = '';
|
|
$table->rowclass[2] = '';
|
|
break;
|
|
|
|
case 'right':
|
|
$table->size[0] = '15%';
|
|
|
|
$table->data[0][0] = '';
|
|
$table->data[0][1] = $top;
|
|
$table->rowclass[0] = '';
|
|
|
|
$table->data[1][0] = $button;
|
|
|
|
$table->data[1][1] = $body;
|
|
$table->rowclass[1] = '';
|
|
|
|
$table->data[2][0] = '';
|
|
$table->data[2][1] = $bottom;
|
|
$table->rowclass[2] = '';
|
|
break;
|
|
|
|
case 'bottom':
|
|
$table->data[0][0] = $button;
|
|
$table->cellstyle[0][0] = 'text-align: center;';
|
|
$table->rowclass[0] = '';
|
|
|
|
$table->data[1][0] = $top;
|
|
$table->rowclass[1] = '';
|
|
|
|
$table->data[2][0] = $body;
|
|
$table->rowclass[2] = '';
|
|
|
|
$table->data[3][0] = $bottom;
|
|
$table->rowclass[3] = '';
|
|
break;
|
|
}
|
|
|
|
$out_html .= html_print_table($table, true);
|
|
|
|
$out_html .= '</div>';
|
|
|
|
$out_js = "<script type='text/javascript'>
|
|
<!--
|
|
hidded_sidebar('".$params['position']."', ".$params['width'].", '".$params['height']."', ".$params['icon_width'].",
|
|
'".$params['top']."', '".$params['autotop']."', '".$params['right']."',
|
|
'".$params['autoright']."', '".$params['icon_closed']."', '".$params['icon_open']."', '".$config['homeurl']."'
|
|
, '".$params['vertical_mode']."');
|
|
//-->
|
|
</script>";
|
|
|
|
echo $out_html.$out_js;
|
|
}
|
|
|
|
|
|
/**
|
|
* Prints an array of fields in a popup menu of a form.
|
|
*
|
|
* Based on choose_from_menu() from Moodle
|
|
*
|
|
* @param array Array with dropdown values. Example: $fields["value"] = "label"
|
|
* @param string Select form name
|
|
* @param variant Current selected value. Can be a single value or an
|
|
* array of selected values (in combination with multiple)
|
|
* @param string Javascript onChange code.
|
|
* @param string Label when nothing is selected.
|
|
* @param variant Value when nothing is selected
|
|
* @param bool Whether to return an output string or echo now (optional, echo by default).
|
|
* @param bool Set the input to allow multiple selections (optional, single selection by default).
|
|
* @param bool Whether to sort the options or not (optional, unsorted by default).
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_select_style($fields, $name, $selected='', $style='', $script='', $nothing='', $nothing_value=0, $return=false, $multiple=false, $sort=true, $class='', $disabled=false)
|
|
{
|
|
$output = "\n";
|
|
|
|
static $idcounter = [];
|
|
|
|
// If duplicate names exist, it will start numbering. Otherwise it won't
|
|
if (isset($idcounter[$name])) {
|
|
$idcounter[$name]++;
|
|
} else {
|
|
$idcounter[$name] = 0;
|
|
}
|
|
|
|
$id = preg_replace('/[^a-z0-9\:\;\-\_]/i', '', $name.($idcounter[$name] ? $idcounter[$name] : ''));
|
|
|
|
$attributes = '';
|
|
if (!empty($script)) {
|
|
$attributes .= ' onchange="'.$script.'"';
|
|
}
|
|
|
|
if (!empty($multiple)) {
|
|
$attributes .= ' multiple="multiple" size="10"';
|
|
}
|
|
|
|
if (!empty($class)) {
|
|
$attributes .= ' class="'.$class.'"';
|
|
}
|
|
|
|
if (!empty($disabled)) {
|
|
$attributes .= ' disabled="disabled"';
|
|
}
|
|
|
|
$output .= '<select style="'.$style.'" id="'.$id.'" name="'.$name.'"'.$attributes.'>';
|
|
|
|
if ($nothing != '' || empty($fields)) {
|
|
if ($nothing == '') {
|
|
$nothing = __('None');
|
|
}
|
|
|
|
$output .= '<option value="'.$nothing_value.'"';
|
|
if ($nothing_value == $selected) {
|
|
$output .= ' selected="selected"';
|
|
}
|
|
|
|
$output .= '>'.$nothing.'</option>';
|
|
}
|
|
|
|
if (!empty($fields)) {
|
|
if ($sort !== false) {
|
|
asort($fields);
|
|
}
|
|
|
|
foreach ($fields as $value => $label) {
|
|
$output .= '<option value="'.$value.'"';
|
|
if (is_array($selected) && in_array($value, $selected)) {
|
|
$output .= ' selected="selected"';
|
|
} else if (is_numeric($value) && is_numeric($selected) && $value == $selected) {
|
|
// This fixes string ($value) to int ($selected) comparisons
|
|
$output .= ' selected="selected"';
|
|
} else if ($value === $selected) {
|
|
// Needs type comparison otherwise if $selected = 0 and $value = "string" this would evaluate to true
|
|
$output .= ' selected="selected"';
|
|
}
|
|
|
|
if ($label === '') {
|
|
$output .= '>'.$value.'</option>';
|
|
} else {
|
|
$output .= '>'.$label.'</option>';
|
|
}
|
|
}
|
|
}
|
|
|
|
$output .= '</select>';
|
|
|
|
if ($return) {
|
|
return $output;
|
|
}
|
|
|
|
echo $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Prints the groups of user of fields in a popup menu of a form.
|
|
*
|
|
* @param string User id
|
|
* @param string The privilege to evaluate
|
|
* @param boolean $returnAllGroup Flag the return group, by default true.
|
|
* @param boolean $returnAllColumns Flag to return all columns of groups.
|
|
* @param array Array with dropdown values. Example: $fields["value"] = "label"
|
|
* @param string Select form name
|
|
* @param variant Current selected value. Can be a single value or an
|
|
* array of selected values (in combination with multiple)
|
|
* @param string Javascript onChange code.
|
|
* @param string Label when nothing is selected.
|
|
* @param variant Value when nothing is selected
|
|
* @param bool Whether to return an output string or echo now (optional, echo by default).
|
|
* @param bool Set the input to allow multiple selections (optional, single selection by default).
|
|
* @param bool Whether to sort the options or not (optional, unsorted by default).
|
|
* @param string $style The string of style.
|
|
* @param integer $id_group The id of node that must do not show the children and own.
|
|
* @param string $keys_field The field of the group used in the array keys. By default ID
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_select_groups(
|
|
$id_user=false,
|
|
$privilege='AR',
|
|
$returnAllGroup=true,
|
|
$name,
|
|
$selected='',
|
|
$script='',
|
|
$nothing='',
|
|
$nothing_value=0,
|
|
$return=false,
|
|
$multiple=false,
|
|
$sort=true,
|
|
$class='',
|
|
$disabled=false,
|
|
$style=false,
|
|
$option_style=false,
|
|
$id_group=false,
|
|
$keys_field='id_grupo',
|
|
$strict_user=false,
|
|
$delete_groups=false,
|
|
$include_groups=false,
|
|
$size=false,
|
|
$simple_multiple_options=false
|
|
) {
|
|
global $config;
|
|
|
|
$fields = users_get_groups_for_select(
|
|
$id_user,
|
|
$privilege,
|
|
$returnAllGroup,
|
|
true,
|
|
$id_group,
|
|
$keys_field
|
|
);
|
|
|
|
if ($delete_groups && is_array($delete_groups)) {
|
|
foreach ($delete_groups as $value) {
|
|
unset($fields[$value]);
|
|
}
|
|
}
|
|
|
|
if (is_array($include_groups)) {
|
|
$field = [];
|
|
foreach ($include_groups as $value) {
|
|
$field[$value] = $fields[$value];
|
|
}
|
|
|
|
$fields = array_intersect($fields, $field);
|
|
}
|
|
|
|
if ($strict_user) {
|
|
$fields = users_get_strict_mode_groups($config['id_user'], $returnAllGroup);
|
|
}
|
|
|
|
$output = html_print_select(
|
|
$fields,
|
|
$name,
|
|
$selected,
|
|
$script,
|
|
$nothing,
|
|
$nothing_value,
|
|
$return,
|
|
$multiple,
|
|
false,
|
|
$class,
|
|
$disabled,
|
|
$style,
|
|
$option_style,
|
|
$size,
|
|
false,
|
|
'',
|
|
false,
|
|
$simple_multiple_options
|
|
);
|
|
|
|
if ($return) {
|
|
return $output;
|
|
} else {
|
|
echo $output;
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Prints an array of fields in a popup menu of a form.
|
|
*
|
|
* Based on choose_from_menu() from Moodle
|
|
*
|
|
* @param array Array with dropdown values. Example: $fields["value"] = "label"
|
|
* @param string Select form name
|
|
* @param variant Current selected value. Can be a single value or an
|
|
* array of selected values (in combination with multiple)
|
|
* @param string Javascript onChange code.
|
|
* @param string Label when nothing is selected.
|
|
* @param variant Value when nothing is selected
|
|
* @param bool Whether to return an output string or echo now (optional, echo by default).
|
|
* @param bool Set the input to allow multiple selections (optional, single selection by default).
|
|
* @param bool Whether to sort the options or not (optional, unsorted by default).
|
|
* @param string $style The string of style.
|
|
* @param mixed $size Max elements showed in the select or default (size=10).
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_select(
|
|
$fields,
|
|
$name,
|
|
$selected='',
|
|
$script='',
|
|
$nothing='',
|
|
$nothing_value=0,
|
|
$return=false,
|
|
$multiple=false,
|
|
$sort=true,
|
|
$class='',
|
|
$disabled=false,
|
|
$style=false,
|
|
$option_style=false,
|
|
$size=false,
|
|
$modal=false,
|
|
$message='',
|
|
$select_all=false,
|
|
$simple_multiple_options=false
|
|
) {
|
|
$output = "\n";
|
|
|
|
static $idcounter = [];
|
|
|
|
// If duplicate names exist, it will start numbering. Otherwise it won't
|
|
if (isset($idcounter[$name])) {
|
|
$idcounter[$name]++;
|
|
} else {
|
|
$idcounter[$name] = 0;
|
|
}
|
|
|
|
$id = preg_replace('/[^a-z0-9\:\;\-\_]/i', '', $name.($idcounter[$name] ? $idcounter[$name] : ''));
|
|
|
|
$attributes = '';
|
|
if (!empty($script)) {
|
|
$attributes .= ' onchange="'.$script.'"';
|
|
}
|
|
|
|
if (!empty($multiple)) {
|
|
if ($size !== false) {
|
|
$attributes .= ' multiple="multiple" size="'.$size.'"';
|
|
} else {
|
|
$attributes .= ' multiple="multiple" size="10"';
|
|
}
|
|
}
|
|
|
|
if ($simple_multiple_options === true) {
|
|
if ($size !== false) {
|
|
$attributes .= ' size="'.$size.'"';
|
|
} else {
|
|
$attributes .= ' size="10"';
|
|
}
|
|
}
|
|
|
|
if (!empty($class)) {
|
|
$attributes .= ' class="'.$class.'"';
|
|
}
|
|
|
|
if (!empty($disabled)) {
|
|
$attributes .= ' disabled="disabled"';
|
|
}
|
|
|
|
if ($style === false) {
|
|
$styleText = 'style=""';
|
|
} else {
|
|
$styleText = 'style="'.$style.'"';
|
|
}
|
|
|
|
$output .= '<select id="'.$id.'" name="'.$name.'"'.$attributes.' '.$styleText.'>';
|
|
|
|
if ($nothing != '' || empty($fields)) {
|
|
if ($nothing == '') {
|
|
$nothing = __('None');
|
|
}
|
|
|
|
$output .= '<option value="'.$nothing_value.'"';
|
|
|
|
if ($nothing_value == $selected) {
|
|
$output .= ' selected="selected"';
|
|
} else if (is_array($selected)) {
|
|
if (in_array($nothing_value, $selected)) {
|
|
$output .= ' selected="selected"';
|
|
}
|
|
}
|
|
|
|
$output .= '>'.$nothing.'</option>';
|
|
}
|
|
|
|
if (is_array($fields) && !empty($fields)) {
|
|
if ($sort !== false) {
|
|
// Sorting the fields in natural way and case insensitive preserving keys
|
|
$first_elem = reset($fields);
|
|
if (!is_array($first_elem)) {
|
|
uasort($fields, 'strnatcasecmp');
|
|
}
|
|
}
|
|
|
|
$lastopttype = '';
|
|
foreach ($fields as $value => $label) {
|
|
$optlabel = $label;
|
|
if (is_array($label)) {
|
|
if (isset($label['optgroup'])) {
|
|
if ($label['optgroup'] != $lastopttype) {
|
|
if ($lastopttype != '') {
|
|
$output .= '</optgroup>';
|
|
}
|
|
|
|
$output .= '<optgroup label="'.$label['optgroup'].'">';
|
|
$lastopttype = $label['optgroup'];
|
|
}
|
|
}
|
|
|
|
$optlabel = $label['name'];
|
|
}
|
|
|
|
$output .= '<option ';
|
|
if ($select_all) {
|
|
$output .= 'selected ';
|
|
}
|
|
|
|
$output .= 'value="'.$value.'"';
|
|
|
|
if (is_array($selected) && in_array($value, $selected)) {
|
|
$output .= ' selected="selected"';
|
|
} else if (is_numeric($value) && is_numeric($selected)
|
|
&& $value == $selected
|
|
) {
|
|
// This fixes string ($value) to int ($selected) comparisons
|
|
$output .= ' selected="selected"';
|
|
} else if ($value === $selected) {
|
|
// Needs type comparison otherwise if $selected = 0 and $value = "string" this would evaluate to true
|
|
$output .= ' selected="selected"';
|
|
}
|
|
|
|
if (is_array($option_style)
|
|
&& in_array($value, array_keys($option_style))
|
|
) {
|
|
$output .= ' style="'.$option_style[$value].'"';
|
|
}
|
|
|
|
if ($optlabel === '') {
|
|
$output .= '>None</option>';
|
|
} else {
|
|
$output .= '>'.$optlabel.'</option>';
|
|
}
|
|
}
|
|
|
|
if (is_array($label)) {
|
|
$output .= '</optgroup>';
|
|
}
|
|
}
|
|
|
|
$output .= '</select>';
|
|
if ($modal && !enterprise_installed()) {
|
|
$output .= "
|
|
<div id='".$message."' class='publienterprise' title='Community version' style='display:inline;position:relative;top:10px;left:0px;margin-top: -2px !important; margin-left: 2px !important;'><img data-title='Enterprise version' class='img_help forced_title' data-use_title_for_force_title='1' src='images/alert_enterprise.png'></div>
|
|
";
|
|
}
|
|
|
|
if ($return) {
|
|
return $output;
|
|
}
|
|
|
|
echo $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Prints an array of fields in a popup menu of a form based on a SQL query.
|
|
* The first and second columns of the query will be used.
|
|
*
|
|
* The element will have an id like: "password-$value". Based on choose_from_menu() from Moodle.
|
|
*
|
|
* @param string $sql SQL sentence, the first field will be the identifier of the option.
|
|
* The second field will be the shown value in the dropdown.
|
|
* @param string $name Select form name
|
|
* @param string $selected Current selected value.
|
|
* @param string $script Javascript onChange code.
|
|
* @param string $nothing Label when nothing is selected.
|
|
* @param string $nothing_value Value when nothing is selected
|
|
* @param boolean $return Whether to return an output string or echo now (optional, echo by default).
|
|
* @param boolean $multiple Whether to allow multiple selections or not. Single by default
|
|
* @param boolean $sort Whether to sort the options or not. Sorted by default.
|
|
* @param boolean $disabled if it's true, disable the select.
|
|
* @param string $style The string of style.
|
|
* @param mixed $size Max elements showed in select or default (size=10)
|
|
* @param integer $truncante_size Truncate size of the element, by default is set to GENERIC_SIZE_TEXT constant
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_select_from_sql(
|
|
$sql,
|
|
$name,
|
|
$selected='',
|
|
$script='',
|
|
$nothing='',
|
|
$nothing_value='0',
|
|
$return=false,
|
|
$multiple=false,
|
|
$sort=true,
|
|
$disabled=false,
|
|
$style=false,
|
|
$size=false,
|
|
$trucate_size=GENERIC_SIZE_TEXT
|
|
) {
|
|
global $config;
|
|
|
|
$fields = [];
|
|
$result = db_get_all_rows_sql($sql);
|
|
if ($result === false) {
|
|
$result = [];
|
|
}
|
|
|
|
foreach ($result as $row) {
|
|
$id = array_shift($row);
|
|
$value = array_shift($row);
|
|
$fields[$id] = ui_print_truncate_text(
|
|
$value,
|
|
$trucate_size,
|
|
false,
|
|
true,
|
|
false
|
|
);
|
|
}
|
|
|
|
return html_print_select(
|
|
$fields,
|
|
$name,
|
|
$selected,
|
|
$script,
|
|
$nothing,
|
|
$nothing_value,
|
|
$return,
|
|
$multiple,
|
|
$sort,
|
|
'',
|
|
$disabled,
|
|
$style,
|
|
'',
|
|
$size
|
|
);
|
|
}
|
|
|
|
|
|
function html_print_extended_select_for_unit(
|
|
$name,
|
|
$selected='',
|
|
$script='',
|
|
$nothing='',
|
|
$nothing_value='0',
|
|
$size=false,
|
|
$return=false,
|
|
$select_style=false,
|
|
$unique_name=true,
|
|
$disabled=false,
|
|
$no_change=0
|
|
) {
|
|
global $config;
|
|
|
|
// $fields = post_process_get_custom_values();
|
|
$fields['_timeticks_'] = 'Timeticks';
|
|
$fields['none'] = __('none');
|
|
|
|
if ($no_change != 0) {
|
|
$fields[-1] = __('No change');
|
|
}
|
|
|
|
// $selected_float = (float)$selected;
|
|
// $found = false;
|
|
//
|
|
// if (array_key_exists($selected, $fields))
|
|
// $found = true;
|
|
//
|
|
// if (!$found) {
|
|
// $fields[$selected] = floatval($selected);
|
|
// }
|
|
if ($unique_name === true) {
|
|
$uniq_name = uniqid($name);
|
|
} else {
|
|
$uniq_name = $name;
|
|
}
|
|
|
|
ob_start();
|
|
|
|
echo '<div id="'.$uniq_name.'_default" style="width:100%;display:inline;">';
|
|
html_print_select(
|
|
$fields,
|
|
$uniq_name.'_select',
|
|
$selected,
|
|
''.$script,
|
|
$nothing,
|
|
$nothing_value,
|
|
false,
|
|
false,
|
|
false,
|
|
'',
|
|
$disabled,
|
|
'font-size: xx-small;'.$select_style
|
|
);
|
|
echo ' <a href="javascript:">'.html_print_image(
|
|
'images/pencil.png',
|
|
true,
|
|
[
|
|
'class' => $uniq_name.'_toggler',
|
|
'alt' => __('Custom'),
|
|
'title' => __('Custom'),
|
|
'style' => 'width: 18px;',
|
|
]
|
|
).'</a>';
|
|
echo '</div>';
|
|
|
|
echo '<div id="'.$uniq_name.'_manual" style="width:100%;display:inline;">';
|
|
html_print_input_text($uniq_name.'_text', $selected, '', 20);
|
|
|
|
html_print_input_hidden($name, $selected, false, $uniq_name);
|
|
echo ' <a href="javascript:">'.html_print_image(
|
|
'images/default_list.png',
|
|
true,
|
|
[
|
|
'class' => $uniq_name.'_toggler',
|
|
'alt' => __('List'),
|
|
'title' => __('List'),
|
|
'style' => 'width: 18px;',
|
|
]
|
|
).'</a>';
|
|
echo '</div>';
|
|
|
|
echo "<script type='text/javascript'>
|
|
$(document).ready (function () {
|
|
post_process_select_init_unit('$uniq_name','$selected');
|
|
post_process_select_events_unit('$uniq_name','$selected');
|
|
});
|
|
|
|
</script>";
|
|
|
|
$returnString = ob_get_clean();
|
|
|
|
if ($return) {
|
|
return $returnString;
|
|
} else {
|
|
echo $returnString;
|
|
}
|
|
}
|
|
|
|
|
|
function html_print_extended_select_for_post_process(
|
|
$name,
|
|
$selected='',
|
|
$script='',
|
|
$nothing='',
|
|
$nothing_value='0',
|
|
$size=false,
|
|
$return=false,
|
|
$select_style=false,
|
|
$unique_name=true,
|
|
$disabled=false,
|
|
$no_change=0
|
|
) {
|
|
global $config;
|
|
|
|
include_once $config['homedir'].'/include/functions_post_process.php';
|
|
|
|
$fields = post_process_get_custom_values();
|
|
|
|
if ($no_change != 0) {
|
|
$fields[-1] = __('No change');
|
|
}
|
|
|
|
$selected_float = (float) $selected;
|
|
$found = false;
|
|
|
|
if ($selected) {
|
|
if (array_key_exists(number_format($selected, 14, '.', ','), $fields)) {
|
|
$found = true;
|
|
}
|
|
}
|
|
|
|
if (!$found) {
|
|
$fields[$selected] = floatval($selected);
|
|
}
|
|
|
|
if ($unique_name === true) {
|
|
$uniq_name = uniqid($name);
|
|
} else {
|
|
$uniq_name = $name;
|
|
}
|
|
|
|
ob_start();
|
|
|
|
echo '<div id="'.$uniq_name.'_default" style="width:100%;display:inline;">';
|
|
html_print_select(
|
|
$fields,
|
|
$uniq_name.'_select',
|
|
$selected,
|
|
''.$script,
|
|
$nothing,
|
|
$nothing_value,
|
|
false,
|
|
false,
|
|
false,
|
|
'',
|
|
$disabled,
|
|
'font-size: xx-small;'.$select_style
|
|
);
|
|
echo ' <a href="javascript:">'.html_print_image(
|
|
'images/pencil.png',
|
|
true,
|
|
[
|
|
'class' => $uniq_name.'_toggler',
|
|
'alt' => __('Custom'),
|
|
'title' => __('Custom'),
|
|
'style' => 'width: 18px;',
|
|
]
|
|
).'</a>';
|
|
echo '</div>';
|
|
|
|
echo '<div id="'.$uniq_name.'_manual" style="width:100%;display:inline;">';
|
|
html_print_input_text($uniq_name.'_text', $selected, '', 20);
|
|
|
|
html_print_input_hidden($name, $selected, false, $uniq_name);
|
|
echo ' <a href="javascript:">'.html_print_image(
|
|
'images/default_list.png',
|
|
true,
|
|
[
|
|
'class' => $uniq_name.'_toggler',
|
|
'alt' => __('List'),
|
|
'title' => __('List'),
|
|
'style' => 'width: 18px;',
|
|
]
|
|
).'</a>';
|
|
echo '</div>';
|
|
|
|
echo "<script type='text/javascript'>
|
|
$(document).ready (function () {
|
|
post_process_select_init('$uniq_name');
|
|
post_process_select_events('$uniq_name');
|
|
});
|
|
|
|
</script>";
|
|
|
|
$returnString = ob_get_clean();
|
|
|
|
if ($return) {
|
|
return $returnString;
|
|
} else {
|
|
echo $returnString;
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Render a pair of select for times and text box for set the time more fine.
|
|
*
|
|
* @param string Select form name
|
|
* @param variant Current selected value. Can be a single value or an
|
|
* array of selected values (in combination with multiple)
|
|
* @param string Javascript onChange (select) code.
|
|
* @param string Label when nothing is selected.
|
|
* @param variant Value when nothing is selected
|
|
* @param integer $size Size of the input.
|
|
* @param bool Whether to return an output string or echo now (optional, echo by default).
|
|
* @param bool Wherter to assign to combo a unique name (to have more than one on same page, like dashboard)
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
|
|
|
|
function html_print_extended_select_for_time(
|
|
$name,
|
|
$selected='',
|
|
$script='',
|
|
$nothing='',
|
|
$nothing_value='0',
|
|
$size=false,
|
|
$return=false,
|
|
$select_style=false,
|
|
$unique_name=true,
|
|
$class='',
|
|
$readonly=false,
|
|
$custom_fields=false,
|
|
$style_icon='',
|
|
$no_change=false
|
|
) {
|
|
global $config;
|
|
$admin = is_user_admin($config['id_user']);
|
|
if ($custom_fields) {
|
|
$fields = $custom_fields;
|
|
} else {
|
|
$fields = get_periods();
|
|
}
|
|
|
|
if ($no_change) {
|
|
$fields['-2'] = __('No change');
|
|
}
|
|
|
|
if (! $selected) {
|
|
foreach ($fields as $t_key => $t_value) {
|
|
if ($t_key != -1) {
|
|
if ($nothing == '') {
|
|
// -1 means 'custom'
|
|
$selected = $t_key;
|
|
break;
|
|
} else {
|
|
$selected = $nothing;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if (($selected !== false) && (!isset($fields[$selected]) && $selected != 0)) {
|
|
$fields[$selected] = human_time_description_raw($selected, true);
|
|
}
|
|
|
|
$units = [
|
|
1 => __('seconds'),
|
|
SECONDS_1MINUTE => __('minutes'),
|
|
SECONDS_1HOUR => __('hours'),
|
|
SECONDS_1DAY => __('days'),
|
|
SECONDS_1WEEK => __('weeks'),
|
|
SECONDS_1MONTH => __('months'),
|
|
SECONDS_1YEAR => __('years'),
|
|
];
|
|
|
|
if ($unique_name === true) {
|
|
$uniq_name = uniqid($name);
|
|
} else {
|
|
$uniq_name = $name;
|
|
}
|
|
|
|
if ($readonly) {
|
|
$readonly = true;
|
|
}
|
|
|
|
ob_start();
|
|
// Use the no_meta parameter because this image is only in the base console
|
|
echo '<div id="'.$uniq_name.'_default" style="width:100%;display:inline;">';
|
|
html_print_select(
|
|
$fields,
|
|
$uniq_name.'_select',
|
|
$selected,
|
|
''.$script,
|
|
$nothing,
|
|
$nothing_value,
|
|
false,
|
|
false,
|
|
false,
|
|
$class,
|
|
$readonly,
|
|
'font-size: xx-small;'.$select_style
|
|
);
|
|
// The advanced control is only for admins
|
|
if ($admin) {
|
|
echo ' <a href="javascript:">'.html_print_image(
|
|
'images/pencil.png',
|
|
true,
|
|
[
|
|
'class' => $uniq_name.'_toggler '.$class,
|
|
'alt' => __('Custom'),
|
|
'title' => __('Custom'),
|
|
'style' => 'width: 18px; margin-bottom: -5px;'.$style_icon,
|
|
],
|
|
false,
|
|
false,
|
|
true
|
|
).'</a>';
|
|
}
|
|
|
|
echo '</div>';
|
|
|
|
echo '<div id="'.$uniq_name.'_manual" style="width:100%;display:inline;">';
|
|
html_print_input_text($uniq_name.'_text', $selected, '', $size, 255, false, $readonly, false, '', $class);
|
|
|
|
html_print_input_hidden($name, $selected, false, $uniq_name);
|
|
html_print_select(
|
|
$units,
|
|
$uniq_name.'_units',
|
|
1,
|
|
''.$script,
|
|
$nothing,
|
|
$nothing_value,
|
|
false,
|
|
false,
|
|
false,
|
|
$class,
|
|
$readonly,
|
|
'font-size: xx-small;'.$select_style
|
|
);
|
|
echo ' <a href="javascript:">'.html_print_image(
|
|
'images/default_list.png',
|
|
true,
|
|
[
|
|
'class' => $uniq_name.'_toggler',
|
|
'alt' => __('List'),
|
|
'title' => __('List'),
|
|
'style' => 'width: 18px;margin-bottom: -5px;'.$style_icon,
|
|
]
|
|
).'</a>';
|
|
echo '</div>';
|
|
echo "<script type='text/javascript'>
|
|
$(document).ready (function () {
|
|
period_select_init('$uniq_name');
|
|
period_select_events('$uniq_name');
|
|
});
|
|
function period_select_".$name."_update(seconds) {
|
|
$('#text-".$uniq_name."_text').val(seconds);
|
|
adjustTextUnits('".$uniq_name."');
|
|
calculateSeconds('".$uniq_name."');
|
|
$('#".$uniq_name."_manual').show();
|
|
$('#".$uniq_name."_default').hide();
|
|
}
|
|
</script>";
|
|
$returnString = ob_get_clean();
|
|
|
|
if ($return) {
|
|
return $returnString;
|
|
} else {
|
|
echo $returnString;
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Print selects to configure the cron of a module.
|
|
*
|
|
* @param string Run hour.
|
|
* @param string Run minute.
|
|
* @param string Run day of the month.
|
|
* @param string Run month.
|
|
* @param string Run day of the week.
|
|
* @param bool Whether to return an output string or echo now (optional, echo by default).
|
|
* @param bool Print cron grayed
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_extended_select_for_cron($hour='*', $minute='*', $mday='*', $month='*', $wday='*', $return=false, $disabled=false, $to=false)
|
|
{
|
|
// Hours
|
|
for ($i = 0; $i < 24; $i++) {
|
|
$hours[$i] = $i;
|
|
}
|
|
|
|
// Minutes
|
|
for ($i = 0; $i < 60; $i++) {
|
|
$minutes[$i] = $i;
|
|
|
|
// If minute is not a multiple of 5, then add style to option in order to hide it from minute select but still is a valid value that input can adopt. We want this in case a value that is not a multiple of 5 is entered in module's data configuration.
|
|
if (($i % 5) != 0) {
|
|
$minutes_hidden_options[$i] = 'display: none;';
|
|
}
|
|
}
|
|
|
|
// Month days
|
|
for ($i = 1; $i <= 31; $i++) {
|
|
$mdays[$i] = $i;
|
|
}
|
|
|
|
// Months
|
|
for ($i = 1; $i <= 12; $i++) {
|
|
$months[$i] = date('F', mktime(0, 0, 0, $i, 1));
|
|
}
|
|
|
|
// Days of the week
|
|
$wdays = [
|
|
__('Sunday'),
|
|
__('Monday'),
|
|
__('Tuesday'),
|
|
__('Wednesday'),
|
|
__('Thursday'),
|
|
__('Friday'),
|
|
__('Saturday'),
|
|
];
|
|
|
|
// Print selectors
|
|
$table = new stdClass();
|
|
$table->id = 'cron';
|
|
$table->width = '100%';
|
|
$table->class = 'databox data';
|
|
$table->head[0] = __('Hour');
|
|
$table->head[1] = __('Minute');
|
|
$table->head[2] = __('Month day');
|
|
$table->head[3] = __('Month');
|
|
$table->head[4] = __('Week day');
|
|
|
|
if ($to) {
|
|
$table->data[0][0] = html_print_select($hours, 'hour_to', $hour, '', __('Any'), '*', true, false, false, '', $disabled);
|
|
$table->data[0][1] = html_print_select($minutes, 'minute_to', $minute, '', __('Any'), '*', true, false, false, '', $disabled, false, $minutes_hidden_options);
|
|
$table->data[0][2] = html_print_select($mdays, 'mday_to', $mday, '', __('Any'), '*', true, false, false, '', $disabled);
|
|
$table->data[0][3] = html_print_select($months, 'month_to', $month, '', __('Any'), '*', true, false, false, '', $disabled);
|
|
$table->data[0][4] = html_print_select($wdays, 'wday_to', $wday, '', __('Any'), '*', true, false, false, '', $disabled);
|
|
} else {
|
|
$table->data[0][0] = html_print_select($hours, 'hour_from', $hour, '', __('Any'), '*', true, false, false, '', $disabled);
|
|
$table->data[0][1] = html_print_select($minutes, 'minute_from', $minute, '', __('Any'), '*', true, false, false, '', $disabled, false, $minutes_hidden_options);
|
|
$table->data[0][2] = html_print_select($mdays, 'mday_from', $mday, '', __('Any'), '*', true, false, false, '', $disabled);
|
|
$table->data[0][3] = html_print_select($months, 'month_from', $month, '', __('Any'), '*', true, false, false, '', $disabled);
|
|
$table->data[0][4] = html_print_select($wdays, 'wday_from', $wday, '', __('Any'), '*', true, false, false, '', $disabled);
|
|
}
|
|
|
|
return html_print_table($table, $return);
|
|
}
|
|
|
|
|
|
/**
|
|
* Render an input text element. Extended version, use html_print_input_text() to simplify.
|
|
*
|
|
* @param string $name Input name.
|
|
* @param string $value Input value.
|
|
* @param string $id Input HTML id.
|
|
* @param string $alt Do not use, invalid for text and password. Use html_print_input_image
|
|
* @param integer $size Size of the input.
|
|
* @param integer $maxlength Maximum length allowed.
|
|
* @param boolean $disabled Disable the button (optional, button enabled by default).
|
|
* @param mixed $script JavaScript to attach to this. It is array the index is event to set a script, it is only string for "onkeyup" event.
|
|
* @param mixed $attributes Attributes to add to this tag. Should be an array for correction.
|
|
* @param boolean $return Whether to return an output string or echo now (optional, echo by default).
|
|
* @param boolean $password Whether it is a password input or not. Not password by default.
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_input_text_extended($name, $value, $id, $alt, $size, $maxlength, $disabled, $script, $attributes, $return=false, $password=false, $function='', $autocomplete='off')
|
|
{
|
|
static $idcounter = 0;
|
|
|
|
if ($maxlength == 0) {
|
|
$maxlength = 255;
|
|
}
|
|
|
|
if ($size === false) {
|
|
$size = '';
|
|
} else if ($size == 0) {
|
|
$size = 10;
|
|
}
|
|
|
|
++$idcounter;
|
|
|
|
$valid_attrs = [
|
|
'accept',
|
|
'disabled',
|
|
'maxlength',
|
|
'name',
|
|
'readonly',
|
|
'placeholder',
|
|
'size',
|
|
'value',
|
|
'accesskey',
|
|
'class',
|
|
'dir',
|
|
'id',
|
|
'lang',
|
|
'style',
|
|
'tabindex',
|
|
'title',
|
|
'xml:lang',
|
|
'onfocus',
|
|
'onblur',
|
|
'onselect',
|
|
'onchange',
|
|
'onclick',
|
|
'ondblclick',
|
|
'onmousedown',
|
|
'onmouseup',
|
|
'onmouseover',
|
|
'onmousemove',
|
|
'onmouseout',
|
|
'onkeypress',
|
|
'onkeydown',
|
|
'onkeyup',
|
|
'required',
|
|
'autocomplete',
|
|
];
|
|
|
|
$output = '<input '.($password ? 'type="password" autocomplete="'.$autocomplete.'" ' : 'type="text" ');
|
|
|
|
if ($disabled && (!is_array($attributes) || !array_key_exists('disabled', $attributes))) {
|
|
$output .= 'readonly="readonly" ';
|
|
}
|
|
|
|
if (is_array($attributes)) {
|
|
foreach ($attributes as $attribute => $attr_value) {
|
|
if (! in_array($attribute, $valid_attrs)) {
|
|
continue;
|
|
}
|
|
|
|
$output .= $attribute.'="'.$attr_value.'" ';
|
|
}
|
|
} else {
|
|
$output .= trim($attributes).' ';
|
|
$attributes = [];
|
|
}
|
|
|
|
if (!empty($alt)) {
|
|
$output .= 'alt="'.$alt.'" ';
|
|
}
|
|
|
|
// Attributes specified by function call
|
|
$attrs = [
|
|
'name' => 'unnamed',
|
|
'value' => '',
|
|
'id' => 'text-'.sprintf('%04d', $idcounter),
|
|
'size' => '',
|
|
'maxlength' => '',
|
|
];
|
|
|
|
foreach ($attrs as $attribute => $default) {
|
|
if (array_key_exists($attribute, $attributes)) {
|
|
continue;
|
|
} //end if
|
|
|
|
/*
|
|
* Remember, this next code have a $$ that for example there is a var as
|
|
* $a = 'john' then $$a is a var $john .
|
|
*
|
|
* In this case is use for example for $name and $atribute = 'name' .
|
|
*
|
|
*/
|
|
|
|
// Exact operator because we want to show "0" on the value
|
|
if ($attribute !== '') {
|
|
$output .= $attribute.'="'.$$attribute.'" ';
|
|
} else if ($default != '') {
|
|
$output .= $attribute.'="'.$default.'" ';
|
|
}
|
|
}
|
|
|
|
if (!empty($script)) {
|
|
if (is_string($script)) {
|
|
$code = $script;
|
|
$script = [];
|
|
$script['onkeyup'] = $code;
|
|
}
|
|
|
|
foreach ($script as $event => $code) {
|
|
$output .= ' '.$event.'="'.$code.'" ';
|
|
}
|
|
}
|
|
|
|
$output .= $function.'/>';
|
|
|
|
if (!$return) {
|
|
echo $output;
|
|
}
|
|
|
|
return $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Render an input password element.
|
|
*
|
|
* The element will have an id like: "password-$name"
|
|
*
|
|
* @param mixed parameters:
|
|
* - id: string
|
|
* - style: string
|
|
* - hidden: boolean
|
|
* - content: string
|
|
* @param bool return or echo flag
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_div($options, $return=false)
|
|
{
|
|
$output = '<div';
|
|
|
|
// Valid attributes (invalid attributes get skipped)
|
|
$attrs = [
|
|
'id',
|
|
'style',
|
|
'class',
|
|
];
|
|
|
|
if (isset($options['hidden'])) {
|
|
if (isset($options['style'])) {
|
|
$options['style'] .= 'display:none;';
|
|
} else {
|
|
$options['style'] = 'display:none;';
|
|
}
|
|
}
|
|
|
|
foreach ($attrs as $attribute) {
|
|
if (isset($options[$attribute])) {
|
|
$output .= ' '.$attribute.'="'.io_safe_input_html($options[$attribute]).'"';
|
|
}
|
|
}
|
|
|
|
$output .= '>';
|
|
|
|
$output .= isset($options['content']) ? $options['content'] : '';
|
|
|
|
$output .= '</div>';
|
|
|
|
if ($return) {
|
|
return $output;
|
|
} else {
|
|
echo $output;
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Render an input password element.
|
|
*
|
|
* The element will have an id like: "password-$name"
|
|
*
|
|
* @param string $name Input name.
|
|
* @param string $value Input value.
|
|
* @param string $alt Alternative HTML string (optional).
|
|
* @param integer $size Size of the input (optional).
|
|
* @param integer $maxlength Maximum length allowed (optional).
|
|
* @param boolean $return Whether to return an output string or echo now (optional, echo by default).
|
|
* @param boolean $disabled Disable the button (optional, button enabled by default).
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_input_password(
|
|
$name,
|
|
$value,
|
|
$alt='',
|
|
$size=50,
|
|
$maxlength=255,
|
|
$return=false,
|
|
$disabled=false,
|
|
$required=false,
|
|
$class='',
|
|
$autocomplete='off'
|
|
) {
|
|
if ($maxlength == 0) {
|
|
$maxlength = 255;
|
|
}
|
|
|
|
if ($size === false) {
|
|
$size = false;
|
|
} else if ($size == 0) {
|
|
$size = 10;
|
|
}
|
|
|
|
$attr = [];
|
|
if ($required) {
|
|
$attr['required'] = 'required';
|
|
}
|
|
|
|
if ($class) {
|
|
$attr['class'] = $class;
|
|
}
|
|
|
|
if ($disabled === false) {
|
|
// Trick to avoid password completion on most browsers.
|
|
if ($autocomplete !== 'on') {
|
|
$disabled = true;
|
|
$attr['onfocus'] = "this.removeAttribute('readonly');";
|
|
}
|
|
}
|
|
|
|
return html_print_input_text_extended($name, $value, 'password-'.$name, $alt, $size, $maxlength, $disabled, '', $attr, $return, true, '', $autocomplete);
|
|
}
|
|
|
|
|
|
/**
|
|
* Render an input text element.
|
|
*
|
|
* The element will have an id like: "text-$name"
|
|
*
|
|
* @param string $name Input name.
|
|
* @param string $value Input value.
|
|
* @param string $alt Alternative HTML string (invalid - not used).
|
|
* @param integer $size Size of the input (optional).
|
|
* @param integer $maxlength Maximum length allowed (optional).
|
|
* @param boolean $return Whether to return an output string or echo now (optional, echo by default).
|
|
* @param boolean $disabled Disable the button (optional, button enabled by default).
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_input_text($name, $value, $alt='', $size=50, $maxlength=255, $return=false, $disabled=false, $required=false, $function='', $class='', $onChange='', $autocomplete='')
|
|
{
|
|
if ($maxlength == 0) {
|
|
$maxlength = 255;
|
|
}
|
|
|
|
if ($size === false) {
|
|
$size = false;
|
|
} else if ($size == 0) {
|
|
$size = 10;
|
|
}
|
|
|
|
$attr = [];
|
|
if ($required) {
|
|
$attr['required'] = 'required';
|
|
}
|
|
|
|
if ($class != '') {
|
|
$attr['class'] = $class;
|
|
}
|
|
|
|
if ($onChange != '') {
|
|
$attr['onchange'] = $onChange;
|
|
}
|
|
|
|
if ($autocomplete !== '') {
|
|
$attr['autocomplete'] = $autocomplete;
|
|
}
|
|
|
|
return html_print_input_text_extended($name, $value, 'text-'.$name, $alt, $size, $maxlength, $disabled, '', $attr, $return, false, $function);
|
|
}
|
|
|
|
|
|
/**
|
|
* Render an input email element.
|
|
*
|
|
* @param array $settings Array with attributes input.
|
|
* only name is necessary.
|
|
*
|
|
* @return string Html input.
|
|
*/
|
|
function html_print_input_email(array $settings):string
|
|
{
|
|
// TODO: const.
|
|
$valid_attrs = [
|
|
'accept',
|
|
'disabled',
|
|
'maxlength',
|
|
'name',
|
|
'readonly',
|
|
'placeholder',
|
|
'size',
|
|
'value',
|
|
'accesskey',
|
|
'class',
|
|
'dir',
|
|
'id',
|
|
'lang',
|
|
'style',
|
|
'tabindex',
|
|
'title',
|
|
'xml:lang',
|
|
'onfocus',
|
|
'onblur',
|
|
'onselect',
|
|
'onchange',
|
|
'onclick',
|
|
'ondblclick',
|
|
'onmousedown',
|
|
'onmouseup',
|
|
'onmouseover',
|
|
'onmousemove',
|
|
'onmouseout',
|
|
'onkeypress',
|
|
'onkeydown',
|
|
'onkeyup',
|
|
'required',
|
|
'pattern',
|
|
'autocomplete',
|
|
];
|
|
|
|
$output = '';
|
|
if (isset($settings) === true && is_array($settings) === true) {
|
|
// Check Name is necessary.
|
|
if (isset($settings['name']) === true) {
|
|
$output = '<input type="email" ';
|
|
|
|
// Check Max length.
|
|
if (isset($settings['maxlength']) === false) {
|
|
$settings['maxlength'] = 255;
|
|
}
|
|
|
|
// Check Size.
|
|
if (isset($settings['size']) === false
|
|
|| $settings['size'] === 0
|
|
) {
|
|
$settings['size'] = 255;
|
|
}
|
|
|
|
foreach ($settings as $attribute => $attr_value) {
|
|
// Check valid attribute.
|
|
if (in_array($attribute, $valid_attrs) === false) {
|
|
continue;
|
|
}
|
|
|
|
$output .= $attribute.'="'.$attr_value.'" ';
|
|
}
|
|
|
|
$output .= $function.'/>';
|
|
}
|
|
}
|
|
|
|
return $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Render an input number element.
|
|
*
|
|
* @param array $settings Array with attributes input.
|
|
* only name is necessary.
|
|
*
|
|
* @return string
|
|
*/
|
|
function html_print_input_number(array $settings):string
|
|
{
|
|
// TODO: const.
|
|
$valid_attrs = [
|
|
'accept',
|
|
'disabled',
|
|
'maxlength',
|
|
'name',
|
|
'readonly',
|
|
'placeholder',
|
|
'size',
|
|
'value',
|
|
'accesskey',
|
|
'class',
|
|
'dir',
|
|
'id',
|
|
'lang',
|
|
'style',
|
|
'tabindex',
|
|
'title',
|
|
'xml:lang',
|
|
'onfocus',
|
|
'onblur',
|
|
'onselect',
|
|
'onchange',
|
|
'onclick',
|
|
'ondblclick',
|
|
'onmousedown',
|
|
'onmouseup',
|
|
'onmouseover',
|
|
'onmousemove',
|
|
'onmouseout',
|
|
'onkeypress',
|
|
'onkeydown',
|
|
'onkeyup',
|
|
'required',
|
|
'pattern',
|
|
'autocomplete',
|
|
];
|
|
|
|
$output = '';
|
|
if (isset($settings) === true && is_array($settings) === true) {
|
|
// Check Name is necessary.
|
|
if (isset($settings['name']) === true) {
|
|
$output = '<input type="number" ';
|
|
|
|
// Check Max length.
|
|
if (isset($settings['maxlength']) === false) {
|
|
$settings['maxlength'] = 255;
|
|
}
|
|
|
|
// Check Size.
|
|
if (isset($settings['size']) === false
|
|
|| $settings['size'] === 0
|
|
) {
|
|
$settings['size'] = 255;
|
|
}
|
|
|
|
foreach ($settings as $attribute => $attr_value) {
|
|
// Check valid attribute.
|
|
if (in_array($attribute, $valid_attrs) === false) {
|
|
continue;
|
|
}
|
|
|
|
$output .= $attribute.'="'.$attr_value.'" ';
|
|
}
|
|
|
|
$output .= $function.'/>';
|
|
}
|
|
}
|
|
|
|
return $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Render an input image element.
|
|
*
|
|
* The element will have an id like: "image-$name"
|
|
*
|
|
* @param string $name Input name.
|
|
* @param string $src Image source.
|
|
* @param string $value Input value.
|
|
* @param string $style HTML style property.
|
|
* @param boolean $return Whether to return an output string or echo now (optional, echo by default).
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_input_image($name, $src, $value, $style='', $return=false, $options=false)
|
|
{
|
|
global $config;
|
|
static $idcounter = 0;
|
|
|
|
++$idcounter;
|
|
|
|
// Checks if user's skin is available
|
|
$isFunctionSkins = enterprise_include_once('include/functions_skins.php');
|
|
|
|
if ($isFunctionSkins !== ENTERPRISE_NOT_HOOK) {
|
|
$skin_path = enterprise_hook('skins_get_image_path', [$src]);
|
|
if ($skin_path) {
|
|
$src = $skin_path;
|
|
}
|
|
}
|
|
|
|
// If metaconsole is activated and image doesn't exists try to search on normal console
|
|
if (is_metaconsole()) {
|
|
if (false === @file_get_contents($src, 0, null, 0, 1)) {
|
|
$src = '../../'.$src;
|
|
}
|
|
}
|
|
|
|
// path to image
|
|
$src = ui_get_full_url($src);
|
|
|
|
$output = '<input id="image-'.$name.$idcounter.'" src="'.$src.'" style="'.$style.'" name="'.$name.'" type="image"';
|
|
|
|
// Valid attributes (invalid attributes get skipped)
|
|
$attrs = [
|
|
'alt',
|
|
'accesskey',
|
|
'lang',
|
|
'tabindex',
|
|
'title',
|
|
'xml:lang',
|
|
'onclick',
|
|
'ondblclick',
|
|
'onmousedown',
|
|
'onmouseup',
|
|
'onmouseover',
|
|
'onmousemove',
|
|
'onmouseout',
|
|
'onkeypress',
|
|
'onkeydown',
|
|
'onkeyup',
|
|
'class',
|
|
];
|
|
|
|
foreach ($attrs as $attribute) {
|
|
if (isset($options[$attribute])) {
|
|
$output .= ' '.$attribute.'="'.io_safe_input_html($options[$attribute]).'"';
|
|
}
|
|
}
|
|
|
|
$output .= ' value="'.$value.'" />';
|
|
|
|
if ($return) {
|
|
return $output;
|
|
}
|
|
|
|
echo $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Render an input hidden element.
|
|
*
|
|
* The element will have an id like: "hidden-$name"
|
|
*
|
|
* @param string $name Input name.
|
|
* @param string $value Input value.
|
|
* @param boolean $return Whether to return an output string or echo now (optional, echo by default).
|
|
* @param string $class Set the class of input.
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_input_hidden($name, $value, $return=false, $class=false)
|
|
{
|
|
if ($class !== false) {
|
|
$classText = 'class="'.$class.'"';
|
|
} else {
|
|
$classText = '';
|
|
}
|
|
|
|
$separator = '"';
|
|
|
|
if (is_string($value)) {
|
|
if (strstr($value, '"')) {
|
|
$separator = "'";
|
|
}
|
|
}
|
|
|
|
$output = '<input id="hidden-'.$name.'" '.'name="'.$name.'" '.'type="hidden" '.$classText.' '.'value='.$separator.$value.$separator.' />';
|
|
|
|
if ($return) {
|
|
return $output;
|
|
}
|
|
|
|
echo $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Render an input hidden element. Extended version, use html_print_input_hidden() to simplify.
|
|
*
|
|
* The element will have an id like: "hidden-$name"
|
|
*
|
|
* @param string $name Input name.
|
|
* @param string $value Input value.
|
|
* @param string $id Input value.
|
|
* @param boolean $return Whether to return an output string or echo now (optional, echo by default).
|
|
* @param string $class Set the class of input.
|
|
* @param boolean $quotes Use simple quotes or double quotes.
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_input_hidden_extended(
|
|
$name,
|
|
$value,
|
|
$id,
|
|
$return=false,
|
|
$class=false,
|
|
$quotes=false
|
|
) {
|
|
if ($class !== false) {
|
|
$classText = 'class="'.$class.'"';
|
|
} else {
|
|
$classText = '';
|
|
}
|
|
|
|
if (empty($id)) {
|
|
$ouput_id = 'hidden-'.$name;
|
|
} else {
|
|
$ouput_id = $id;
|
|
}
|
|
|
|
$quote = '"';
|
|
if ($quotes === true) {
|
|
$quote = "'";
|
|
}
|
|
|
|
$output = '<input id='.$quote.''.$ouput_id.''.$quote.' ';
|
|
$output .= ' name='.$quote.''.$name.''.$quote.' ';
|
|
$output .= ' type='.$quote.'hidden'.$quote.' '.$classText;
|
|
$output .= ' value='.$quote.''.$value.''.$quote.'';
|
|
$output .= ' />';
|
|
|
|
if ($return) {
|
|
return $output;
|
|
}
|
|
|
|
echo $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Render a color input element.
|
|
*
|
|
* The element will have an id like: "hidden-$name"
|
|
*
|
|
* @param string $name Input name.
|
|
* @param integer $value Input value. Decimal representation of the color's hexadecimal value.
|
|
* @param string $class Set the class of input.
|
|
* @param boolean $return Whether to return an output string or echo now (optional, echo by default).
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_input_color($name, $value, $class=false, $return=false)
|
|
{
|
|
$attr_type = 'type="color"';
|
|
$attr_id = 'id="color-'.htmlspecialchars($name, ENT_QUOTES).'"';
|
|
$attr_name = 'name="'.htmlspecialchars($name, ENT_QUOTES).'"';
|
|
$attr_value = 'value="'.htmlspecialchars($value, ENT_QUOTES).'"';
|
|
$attr_class = 'class="'.($class !== false ? htmlspecialchars($class, ENT_QUOTES) : '').'"';
|
|
|
|
$output = '<input '.$attr_type.' '.$attr_id.' '.$attr_name.' '.$attr_value.' '.$attr_class.' />';
|
|
|
|
if ($return) {
|
|
return $output;
|
|
}
|
|
|
|
echo $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Render an submit input button element.
|
|
*
|
|
* The element will have an id like: "submit-$name"
|
|
*
|
|
* @param string $label Input label.
|
|
* @param string $name Input name.
|
|
* @param boolean $disabled Whether to disable by default or not. Enabled by default.
|
|
* @param array $attributes Additional HTML attributes.
|
|
* @param boolean $return Whether to return an output string or echo now (optional, echo by default).
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_submit_button($label='OK', $name='', $disabled=false, $attributes='', $return=false)
|
|
{
|
|
if (!$name) {
|
|
$name = 'unnamed';
|
|
}
|
|
|
|
if (is_array($attributes)) {
|
|
$attr_array = $attributes;
|
|
$attributes = '';
|
|
foreach ($attr_array as $attribute => $value) {
|
|
$attributes .= $attribute.'="'.$value.'" ';
|
|
}
|
|
}
|
|
|
|
$output = '<input type="submit" id="submit-'.$name.'" name="'.$name.'" value="'.$label.'" '.$attributes;
|
|
if ($disabled) {
|
|
$output .= ' disabled="disabled"';
|
|
}
|
|
|
|
$output .= ' />';
|
|
if (!$return) {
|
|
echo $output;
|
|
}
|
|
|
|
return $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Render an submit input button element.
|
|
*
|
|
* The element will have an id like: "button-$name"
|
|
*
|
|
* @param string $label Input label.
|
|
* @param string $name Input name.
|
|
* @param boolean $disabled Whether to disable by default or not. Enabled by default.
|
|
* @param string $script JavaScript to attach
|
|
* @param string $attributes Additional HTML attributes.
|
|
* @param boolean $return Whether to return an output string or echo now (optional, echo by default).
|
|
* @param boolean $imageButton Set the button as a image button without text, by default is false.
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_button($label='OK', $name='', $disabled=false, $script='', $attributes='', $return=false, $imageButton=false, $modal=false, $message='')
|
|
{
|
|
$output = '';
|
|
|
|
$alt = $title = '';
|
|
if ($imageButton) {
|
|
$alt = $title = $label;
|
|
$label = '';
|
|
}
|
|
|
|
$output .= '<input title="'.$title.'" alt="'.$alt.'" type="button" id="button-'.$name.'" name="'.$name.'" value="'.$label.'" onClick="'.$script.'" '.$attributes;
|
|
if ($disabled) {
|
|
$output .= ' disabled';
|
|
}
|
|
|
|
$output .= ' />';
|
|
|
|
if ($modal && !enterprise_installed()) {
|
|
$output .= "
|
|
<div id='".$message."' class='publienterprise' title='Community version' style='display:inline;position:relative;top:10px;left:0px;margin-top: -2px !important; margin-left: 2px !important;'><img data-title='Enterprise version' class='img_help forced_title' data-use_title_for_force_title='1' src='images/alert_enterprise.png'></div>
|
|
";
|
|
}
|
|
|
|
if ($return) {
|
|
return $output;
|
|
}
|
|
|
|
echo $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Render an input textarea element.
|
|
*
|
|
* The element will have an id like: "textarea_$name"
|
|
*
|
|
* @param string $name Input name.
|
|
* @param integer $rows How many rows (height)
|
|
* @param integer $columns How many columns (width)
|
|
* @param string $value Text in the textarea
|
|
* @param string $attributes Additional attributes
|
|
* @param boolean $return Whether to return an output string or echo now (optional, echo by default). *
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_textarea($name, $rows, $columns, $value='', $attributes='', $return=false, $class='')
|
|
{
|
|
$output = '<textarea id="textarea_'.$name.'" name="'.$name.'" cols="'.$columns.'" rows="'.$rows.'" '.$attributes.' class="'.$class.'">';
|
|
// $output .= io_safe_input ($value);
|
|
$output .= ($value);
|
|
$output .= '</textarea>';
|
|
|
|
if ($return) {
|
|
return $output;
|
|
}
|
|
|
|
echo $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Return a table parameters predefined
|
|
*
|
|
* @param string model
|
|
* - Transparent: More basic template. No borders, all the columns with same width
|
|
* @param int number of columns
|
|
*
|
|
* @return object Table object
|
|
*/
|
|
function html_get_predefined_table($model='transparent', $columns=4)
|
|
{
|
|
$width_percent = (100 / $columns);
|
|
|
|
switch ($model) {
|
|
case 'transparent':
|
|
default:
|
|
$table = new stdClass();
|
|
|
|
$table->class = 'none';
|
|
$table->cellpadding = 0;
|
|
$table->cellspacing = 0;
|
|
$table->head = [];
|
|
$table->data = [];
|
|
$table->style = array_fill(0, 4, 'text-align:center; width: '.$width_percent.'%;');
|
|
$table->width = '100%';
|
|
}
|
|
|
|
return $table;
|
|
}
|
|
|
|
|
|
/**
|
|
* Print a nicely formatted table. Code taken from moodle.
|
|
*
|
|
* @param object Object with several properties:
|
|
* $table->head - An array of heading names.
|
|
* $table->head_colspan - An array of colspans of each head column.
|
|
* $table->headstyle - An array of styles of each head column.
|
|
* $table->align - An array of column alignments
|
|
* $table->valign - An array of column alignments
|
|
* $table->size - An array of column sizes
|
|
* $table->wrap - An array of "nowrap"s or nothing
|
|
* $table->style - An array of personalized style for each column.
|
|
* $table->rowid - An array of personalized ids of each row.
|
|
* $table->rowstyle - An array of personalized style of each row.
|
|
* $table->rowclass - An array of personalized classes of each row (odd-evens classes will be ignored).
|
|
* $table->colspan - An array of colspans of each column.
|
|
* $table->rowspan - An array of rowspans of each column.
|
|
* $table->data[] - An array of arrays containing the data.
|
|
* $table->width - A percentage of the page
|
|
* $table->border - Border of the table.
|
|
* $table->tablealign - Align the whole table (float left or right)
|
|
* $table->cellpadding - Padding on each cell
|
|
* $table->cellspacing - Spacing between cells
|
|
* $table->cellstyle - Style of a cell
|
|
* $table->cellclass - Class of a cell
|
|
* $table->class - CSS table class
|
|
* $table->id - Table ID (useful in JavaScript)
|
|
* $table->headclass[] - An array of classes for each heading
|
|
* $table->title - Title of the table is a single string that will be on top of the table in the head spanning the whole table
|
|
* $table->titlestyle - Title style
|
|
* $table->titleclass - Title class
|
|
* $table->styleTable - Table style
|
|
* $table->autosize - Autosize
|
|
* $table->caption - Table title
|
|
* @param bool Whether to return an output string or echo now
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_table(&$table, $return=false)
|
|
{
|
|
$output = '';
|
|
static $table_count = 0;
|
|
|
|
$table_count++;
|
|
if (isset($table->align)) {
|
|
foreach ($table->align as $key => $aa) {
|
|
if ($aa) {
|
|
$align[$key] = ' text-align:'.$aa.';';
|
|
} else {
|
|
$align[$key] = '';
|
|
}
|
|
}
|
|
}
|
|
|
|
if (isset($table->valign)) {
|
|
foreach ($table->valign as $key => $aa) {
|
|
if ($aa) {
|
|
$valign[$key] = ' vertical-align:'.$aa.';';
|
|
} else {
|
|
$valign[$key] = '';
|
|
}
|
|
}
|
|
}
|
|
|
|
if (isset($table->size)) {
|
|
foreach ($table->size as $key => $ss) {
|
|
if ($ss) {
|
|
$size[$key] = ' width:'.$ss.';';
|
|
} else {
|
|
$size[$key] = '';
|
|
}
|
|
}
|
|
}
|
|
|
|
if (isset($table->style)) {
|
|
foreach ($table->style as $key => $st) {
|
|
if ($st) {
|
|
$style[$key] = ' '.$st.';';
|
|
} else {
|
|
$style[$key] = '';
|
|
}
|
|
}
|
|
}
|
|
|
|
$styleTable = '';
|
|
if (isset($table->styleTable)) {
|
|
$styleTable = $table->styleTable;
|
|
}
|
|
|
|
if (isset($table->rowid)) {
|
|
foreach ($table->rowid as $key => $id) {
|
|
$rowid[$key] = $id;
|
|
}
|
|
}
|
|
|
|
if (isset($table->rowstyle)) {
|
|
foreach ($table->rowstyle as $key => $st) {
|
|
$rowstyle[$key] = ' '.$st.';';
|
|
}
|
|
}
|
|
|
|
if (isset($table->rowclass)) {
|
|
foreach ($table->rowclass as $key => $class) {
|
|
$rowclass[$key] = $class;
|
|
}
|
|
}
|
|
|
|
if (isset($table->colspan)) {
|
|
foreach ($table->colspan as $keyrow => $cspan) {
|
|
foreach ($cspan as $key => $span) {
|
|
$colspan[$keyrow][$key] = ' colspan="'.$span.'"';
|
|
}
|
|
}
|
|
}
|
|
|
|
if (isset($table->cellstyle)) {
|
|
foreach ($table->cellstyle as $keyrow => $cstyle) {
|
|
foreach ($cstyle as $key => $cst) {
|
|
$cellstyle[$keyrow][$key] = $cst;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (isset($table->cellclass)) {
|
|
foreach ($table->cellclass as $keyrow => $cclass) {
|
|
foreach ($cclass as $key => $ccl) {
|
|
$cellclass[$keyrow][$key] = $ccl;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (isset($table->rowspan)) {
|
|
foreach ($table->rowspan as $keyrow => $rspan) {
|
|
foreach ($rspan as $key => $span) {
|
|
$rowspan[$keyrow][$key] = ' rowspan="'.$span.'"';
|
|
}
|
|
}
|
|
}
|
|
|
|
if (empty($table->width)) {
|
|
// $table->width = '80%';
|
|
}
|
|
|
|
if (isset($table->autosize) === true) {
|
|
$table->autosize = 'autosize = "1"';
|
|
} else {
|
|
$table->autosize = '';
|
|
}
|
|
|
|
if (empty($table->border)) {
|
|
if (empty($table)) {
|
|
$table = new stdClass();
|
|
}
|
|
|
|
$table->border = '0';
|
|
}
|
|
|
|
if (empty($table->tablealign) || (($table->tablealign != 'left') && ($table->tablealign != 'right'))) {
|
|
$table->tablealign = '"';
|
|
} else {
|
|
$table->tablealign = 'float:'.$table->tablealign.';"';
|
|
// Align is deprecated. Use float instead
|
|
}
|
|
|
|
if (!isset($table->cellpadding)) {
|
|
$table->cellpadding = '4';
|
|
}
|
|
|
|
if (!isset($table->cellspacing)) {
|
|
$table->cellspacing = '4';
|
|
}
|
|
|
|
if (empty($table->class)) {
|
|
$table->class = 'databox';
|
|
}
|
|
|
|
if (empty($table->titlestyle)) {
|
|
$table->titlestyle = 'text-align:center;';
|
|
}
|
|
|
|
$tableid = empty($table->id) ? 'table'.$table_count : $table->id;
|
|
|
|
if (!empty($table->width)) {
|
|
$output .= '<table '.$table->autosize.' style="width:'.$table->width.'; '.$styleTable.' '.$table->tablealign;
|
|
} else {
|
|
$output .= '<table '.$table->autosize.' style="'.$styleTable.' '.$table->tablealign;
|
|
}
|
|
|
|
$output .= ' cellpadding="'.$table->cellpadding.'" cellspacing="'.$table->cellspacing.'"';
|
|
$output .= ' border="'.$table->border.'" class="'.$table->class.'" id="'.$tableid.'">';
|
|
|
|
$countcols = 0;
|
|
|
|
if (!empty($table->caption)) {
|
|
$output .= '<caption style="text-align: left"><h4>'.$table->caption.'</h4></caption>';
|
|
}
|
|
|
|
if (!empty($table->head)) {
|
|
$countcols = count($table->head);
|
|
$output .= '<thead><tr>';
|
|
|
|
if (isset($table->title)) {
|
|
$output .= '<th colspan="'.$countcols.'"';
|
|
if (isset($table->titlestyle)) {
|
|
$output .= ' style="'.$table->titlestyle.'"';
|
|
}
|
|
|
|
if (isset($table->titleclass)) {
|
|
$output .= ' class="'.$table->titleclass.'"';
|
|
}
|
|
|
|
$output .= '>'.$table->title.'</th></tr><tr>';
|
|
}
|
|
|
|
foreach ($table->head as $key => $heading) {
|
|
if (!isset($size[$key])) {
|
|
$size[$key] = '';
|
|
}
|
|
|
|
if (!isset($align[$key])) {
|
|
$align[$key] = '';
|
|
}
|
|
|
|
if (!isset($table->headclass[$key])) {
|
|
$table->headclass[$key] = 'header c'.$key;
|
|
}
|
|
|
|
if (isset($table->head_colspan[$key])) {
|
|
$headColspan = 'colspan = "'.$table->head_colspan[$key].'"';
|
|
} else {
|
|
$headColspan = '';
|
|
}
|
|
|
|
if (isset($table->headstyle[$key])) {
|
|
$headStyle = ' style = "'.$table->headstyle[$key].'" ';
|
|
} else {
|
|
$headStyle = '';
|
|
}
|
|
|
|
$output .= '<th class="'.$table->headclass[$key].'" '.$headColspan.$headStyle.' scope="col">'.$heading.'</th>';
|
|
}
|
|
|
|
$output .= '</tr></thead>'."\n";
|
|
}
|
|
|
|
$output .= '<tbody>'."\n";
|
|
if (!empty($table->data)) {
|
|
$oddeven = 1;
|
|
foreach ($table->data as $keyrow => $row) {
|
|
if (!isset($rowstyle[$keyrow])) {
|
|
$rowstyle[$keyrow] = '';
|
|
}
|
|
|
|
if (!isset($rowid[$keyrow])) {
|
|
$rowid[$keyrow] = $tableid.'-'.$keyrow;
|
|
}
|
|
|
|
$oddeven = $oddeven ? 0 : 1;
|
|
$class = 'datos'.($oddeven ? '' : '2');
|
|
if (isset($rowclass[$keyrow])) {
|
|
$class = $rowclass[$keyrow];
|
|
}
|
|
|
|
$output .= '<tr id="'.$rowid[$keyrow].'" style="'.$rowstyle[$keyrow].'" class="'.$class.'">'."\n";
|
|
// Special separator rows
|
|
if ($row == 'hr' and $countcols) {
|
|
$output .= '<td colspan="'.$countcols.'"><div class="tabledivider"></div></td>';
|
|
continue;
|
|
}
|
|
|
|
if (!is_array($row)) {
|
|
$row = (array) $row;
|
|
}
|
|
|
|
// It's a normal row
|
|
foreach ($row as $key => $item) {
|
|
if (!isset($size[$key])) {
|
|
$size[$key] = '';
|
|
}
|
|
|
|
if (!isset($cellstyle[$keyrow][$key])) {
|
|
$cellstyle[$keyrow][$key] = '';
|
|
}
|
|
|
|
if (!isset($cellclass[$keyrow][$key])) {
|
|
$cellclass[$keyrow][$key] = '';
|
|
}
|
|
|
|
if (!isset($colspan[$keyrow][$key])) {
|
|
$colspan[$keyrow][$key] = '';
|
|
}
|
|
|
|
if (!isset($rowspan[$keyrow][$key])) {
|
|
$rowspan[$keyrow][$key] = '';
|
|
}
|
|
|
|
if (!isset($align[$key])) {
|
|
$align[$key] = '';
|
|
}
|
|
|
|
if (!isset($valign[$key])) {
|
|
$valign[$key] = '';
|
|
}
|
|
|
|
if (!isset($wrap[$key])) {
|
|
$wrap[$key] = '';
|
|
}
|
|
|
|
if (!isset($style[$key])) {
|
|
$style[$key] = '';
|
|
}
|
|
|
|
$output .= '<td id="'.$tableid.'-'.$keyrow.'-'.$key.'" style="'.$cellstyle[$keyrow][$key].$style[$key].$valign[$key].$align[$key].$size[$key].$wrap[$key].'" '.$colspan[$keyrow][$key].' '.$rowspan[$keyrow][$key].' class="'.$class.' '.$cellclass[$keyrow][$key].'">'.$item.'</td>'."\n";
|
|
}
|
|
|
|
$output .= '</tr>'."\n";
|
|
}
|
|
}
|
|
|
|
$output .= '</tbody></table>'."\n";
|
|
|
|
if ($return) {
|
|
return $output;
|
|
}
|
|
|
|
echo $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Render a radio button input. Extended version, use html_print_input()
|
|
* to simplify.
|
|
*
|
|
* @param string $name Input name.
|
|
* @param string $value Input value.
|
|
* @param string $label Set the button to be marked (optional, unmarked by default).
|
|
* @param string $checkedvalue Checked value.
|
|
* @param string $disabled Disable the button (optional, button enabled by default).
|
|
* @param string $script Script to execute when onClick event is triggered (optional).
|
|
* @param string $attributes Optional HTML attributes. It's a free string which will be inserted tag, use it carefully (optional).
|
|
* @param string $returnparam Whether to return an output string or echo now (optional, echo by default).
|
|
* @param string $modalparam Modal param.
|
|
* @param string $message Message.
|
|
* @param string $id Use custom id.
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_radio_button_extended(
|
|
$name,
|
|
$value,
|
|
$label,
|
|
$checkedvalue,
|
|
$disabled,
|
|
$script,
|
|
$attributes,
|
|
$return=false,
|
|
$modal=false,
|
|
$message='visualmodal',
|
|
$id=null
|
|
) {
|
|
static $idcounter = 0;
|
|
|
|
$output = '';
|
|
|
|
$output = '<input type="radio" name="'.$name.'" value="'.$value.'"';
|
|
if (empty($id) === false) {
|
|
$htmlid = $id;
|
|
} else {
|
|
$htmlid = 'radiobtn'.sprintf('%04d', ++$idcounter);
|
|
}
|
|
|
|
$output .= ' id="'.$htmlid.'"';
|
|
|
|
if ($value == $checkedvalue) {
|
|
$output .= ' checked="checked"';
|
|
}
|
|
|
|
if ($disabled) {
|
|
$output .= ' disabled="disabled"';
|
|
}
|
|
|
|
if ($script != '') {
|
|
$output .= ' onClick="'.$script.'"';
|
|
}
|
|
|
|
$output .= ' '.$attributes;
|
|
$output .= ' />';
|
|
|
|
if ($label != '') {
|
|
$output .= '<label for="'.$htmlid.'">'.$label.'</label>'."\n";
|
|
}
|
|
|
|
if ($modal && !enterprise_installed()) {
|
|
$output .= "
|
|
<div id='".$message."' class='publienterprise' title='Community version' style='display:inline;position:relative;top:10px;left:0px;margin-top: -2px !important; margin-left: 2px !important;'><img data-title='Enterprise version' class='img_help forced_title' data-use_title_for_force_title='1' src='images/alert_enterprise.png'></div>
|
|
";
|
|
}
|
|
|
|
if ($return) {
|
|
return $output;
|
|
}
|
|
|
|
echo $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Render a radio button input.
|
|
*
|
|
* @param string Input name.
|
|
* @param string Input value.
|
|
* @param string Label to add after the radio button (optional).
|
|
* @param string Checked and selected value, the button will be selected if it matches $value (optional).
|
|
* @param bool Whether to return an output string or echo now (optional, echo by default).
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_radio_button($name, $value, $label='', $checkedvalue='', $return=false, $disabled=false)
|
|
{
|
|
$output = html_print_radio_button_extended($name, $value, $label, $checkedvalue, $disabled, '', '', true);
|
|
|
|
if ($return) {
|
|
return $output;
|
|
}
|
|
|
|
echo $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Render a checkbox button input. Extended version, use html_print_checkbox() to simplify.
|
|
*
|
|
* @param string $name Input name.
|
|
* @param string $value Input value.
|
|
* @param string $checked Set the button to be marked (optional, unmarked by default).
|
|
* @param boolean $disabled Disable the button (optional, button enabled by default).
|
|
* @param string $script Script to execute when onClick event is triggered (optional).
|
|
* @param string $attributes Optional HTML attributes. It's a free string which will be inserted into the HTML tag, use it carefully (optional).
|
|
* @param boolean $return Whether to return an output string or echo now (optional, echo by default).
|
|
* @param string $id Custom id.
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_checkbox_extended(
|
|
$name,
|
|
$value,
|
|
$checked,
|
|
$disabled,
|
|
$script,
|
|
$attributes,
|
|
$return=false,
|
|
$id=''
|
|
) {
|
|
static $idcounter = [];
|
|
|
|
// If duplicate names exist, it will start numbering. Otherwise it won't
|
|
if (isset($idcounter[$name])) {
|
|
$idcounter[$name]++;
|
|
} else {
|
|
$idcounter[$name] = 0;
|
|
}
|
|
|
|
$id_aux = preg_replace('/[^a-z0-9\:\;\-\_]/i', '', $name.($idcounter[$name] ? $idcounter[$name] : ''));
|
|
|
|
$output = '<input name="'.$name.'" type="checkbox" value="'.$value.'" '.($checked ? 'checked="checked"' : '');
|
|
if ($id == '') {
|
|
$output .= ' id="checkbox-'.$id_aux.'"';
|
|
} else {
|
|
$output .= ' id="'.$id.'"';
|
|
}
|
|
|
|
if ($script != '') {
|
|
$output .= ' onclick="'.$script.'"';
|
|
}
|
|
|
|
if ($disabled) {
|
|
$output .= ' disabled="disabled"';
|
|
}
|
|
|
|
$output .= ' '.$attributes;
|
|
$output .= ' />';
|
|
$output .= "\n";
|
|
|
|
if ($return === false) {
|
|
echo $output;
|
|
}
|
|
|
|
return $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Render a checkbox button input.
|
|
*
|
|
* @param string $name Input name.
|
|
* @param string $value Input value.
|
|
* @param string $checked Set the button to be marked (optional, unmarked by default).
|
|
* @param boolean $return Whether to return an output string or echo now (optional, echo by default).
|
|
* @param boolean $disabled Disable the button (optional, button enabled by default).
|
|
* @param string $script Script.
|
|
* @param string $disabled_hidden Disabled_hidden.
|
|
* @param string $attributes Extra attributes.
|
|
* @param string $id Custom ID.
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_checkbox(
|
|
$name,
|
|
$value,
|
|
$checked=false,
|
|
$return=false,
|
|
$disabled=false,
|
|
$script='',
|
|
$disabled_hidden=false,
|
|
$attributes='',
|
|
$id=''
|
|
) {
|
|
$output = html_print_checkbox_extended(
|
|
$name,
|
|
$value,
|
|
(bool) $checked,
|
|
$disabled,
|
|
$script,
|
|
$attributes,
|
|
true,
|
|
$id
|
|
);
|
|
if (!$disabled_hidden) {
|
|
$output .= html_print_input_hidden($name.'_sent', 1, true);
|
|
}
|
|
|
|
if ($return === false) {
|
|
echo $output;
|
|
}
|
|
|
|
return $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Render a checkbox button input switch type. Extended version, use html_print_checkbox_switch() to simplify.
|
|
*
|
|
* @param string Input name.
|
|
* @param string Input value.
|
|
* @param string Set the button to be marked (optional, unmarked by default).
|
|
* @param bool Disable the button (optional, button enabled by default).
|
|
* @param string Script to execute when onClick event is triggered (optional).
|
|
* @param string Optional HTML attributes. It's a free string which will be
|
|
* @param bool Whether to return an output string or echo now (optional, echo by default).
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
|
|
|
|
function html_print_checkbox_switch_extended($name, $value, $checked, $disabled, $script, $attributes, $return=false, $id='')
|
|
{
|
|
static $idcounter = [];
|
|
|
|
// If duplicate names exist, it will start numbering. Otherwise it won't
|
|
if (isset($idcounter[$name])) {
|
|
$idcounter[$name]++;
|
|
} else {
|
|
$idcounter[$name] = 0;
|
|
}
|
|
|
|
$id_aux = preg_replace('/[^a-z0-9\:\;\-\_]/i', '', $name.($idcounter[$name] ? $idcounter[$name] : ''));
|
|
|
|
$output = '<label class="p-switch"><input name="'.$name.'" type="checkbox" value="'.$value.'" '.($checked ? 'checked="checked"' : '');
|
|
if ($id == '') {
|
|
$output .= ' id="checkbox-'.$id_aux.'"';
|
|
} else {
|
|
$output .= ' '.$id.'"';
|
|
}
|
|
|
|
if ($script != '') {
|
|
$output .= ' onclick="'.$script.'"';
|
|
}
|
|
|
|
if ($disabled) {
|
|
$output .= ' disabled="disabled"';
|
|
}
|
|
|
|
$output .= ' '.$attributes;
|
|
$output .= ' /><span class="p-slider"></span></label>';
|
|
$output .= "\n";
|
|
|
|
if ($return === false) {
|
|
echo $output;
|
|
}
|
|
|
|
return $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Render a checkbox button input switch type.
|
|
*
|
|
* @param string Input name.
|
|
* @param string Input value.
|
|
* @param string Set the button to be marked (optional, unmarked by default).
|
|
* @param bool Whether to return an output string or echo now (optional, echo by default).
|
|
* @param boolean $disabled Disable the button (optional, button enabled by default).
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
|
|
|
|
function html_print_checkbox_switch($name, $value, $checked=false, $return=false, $disabled=false, $script='', $disabled_hidden=false)
|
|
{
|
|
$output = html_print_checkbox_switch_extended($name, $value, (bool) $checked, $disabled, $script, '', true);
|
|
if (!$disabled_hidden) {
|
|
$output .= html_print_input_hidden($name.'_sent', 1, true);
|
|
}
|
|
|
|
if ($return === false) {
|
|
echo $output;
|
|
}
|
|
|
|
return $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Prints an image HTML element.
|
|
*
|
|
* @param string $src Image source filename.
|
|
* @param boolean $return Whether to return or print.
|
|
* @param array $options Array with optional HTML options to set.
|
|
* At this moment, the following options are supported:
|
|
* align, border, hspace, ismap, vspace, style, title, height,
|
|
* longdesc, usemap, width, id, class, lang, xml:lang, onclick,
|
|
* ondblclick, onmousedown, onmouseup, onmouseover, onmousemove,
|
|
* onmouseout, onkeypress, onkeydown, onkeyup, pos_tree, alt.
|
|
* @param boolean $return_src Whether to return src field of image
|
|
* ('images/*.*') or complete html img tag ('<img src="..." alt="...">').
|
|
* @param boolean $relative Whether to use relative path to image or not
|
|
* (i.e. $relative= true : /pandora/<img_src>).
|
|
* @param boolean $no_in_meta Do not show on metaconsole folder at first. Go
|
|
* directly to the node.
|
|
* @param boolean $isExternalLink Do not shearch for images in Pandora.
|
|
*
|
|
* @return string HTML code if return parameter is true.
|
|
*/
|
|
function html_print_image(
|
|
$src,
|
|
$return=false,
|
|
$options=false,
|
|
$return_src=false,
|
|
$relative=false,
|
|
$no_in_meta=false,
|
|
$isExternalLink=false
|
|
) {
|
|
global $config;
|
|
|
|
// If metaconsole is in use then don't use skins.
|
|
if (!is_metaconsole()) {
|
|
// Checks if user's skin is available.
|
|
$isFunctionSkins = enterprise_include_once('include/functions_skins.php');
|
|
|
|
if ($isFunctionSkins !== ENTERPRISE_NOT_HOOK) {
|
|
$skin_path = enterprise_hook('skins_get_image_path', [$src]);
|
|
|
|
if ($skin_path) {
|
|
$src = $skin_path;
|
|
}
|
|
}
|
|
}
|
|
|
|
// If metaconsole is activated and image doesn't exists try to search on normal console.
|
|
if (is_metaconsole()) {
|
|
if (!$relative) {
|
|
$working_dir = str_replace('\\', '/', getcwd());
|
|
// Windows compatibility.
|
|
if ($no_in_meta) {
|
|
$src = '../../'.$src;
|
|
} else if (strstr($working_dir, 'enterprise/meta') === false) {
|
|
if ($src[0] !== '/') {
|
|
$src = '/'.$src;
|
|
}
|
|
|
|
if (!is_readable($working_dir.'/enterprise/meta'.$src)) {
|
|
if ($isExternalLink) {
|
|
$src = ui_get_full_url($src, false, false, false);
|
|
} else {
|
|
$src = ui_get_full_url('../..'.$src);
|
|
}
|
|
} else {
|
|
$src = ui_get_full_url($src);
|
|
}
|
|
} else {
|
|
if ($src[0] !== '/') {
|
|
$src = '/'.$src;
|
|
}
|
|
|
|
if (is_readable($working_dir.$src)) {
|
|
$src = ui_get_full_url($src);
|
|
} else if (!is_readable($src)) {
|
|
$src = ui_get_full_url('../../'.$src);
|
|
}
|
|
}
|
|
} else {
|
|
$src = '../../'.$src;
|
|
}
|
|
} else {
|
|
if (!$relative) {
|
|
$src_tmp = $src;
|
|
$src = ui_get_full_url($src);
|
|
}
|
|
}
|
|
|
|
// Only return src field of image.
|
|
if ($return_src) {
|
|
if (!$return) {
|
|
echo io_safe_input($src);
|
|
return null;
|
|
}
|
|
|
|
return io_safe_input($src);
|
|
}
|
|
|
|
$output = '<img src="'.$src.'" ';
|
|
// Dont use safe_input here or the performance will dead.
|
|
$style = '';
|
|
|
|
if (!empty($options)) {
|
|
// Deprecated or value-less attributes.
|
|
if (isset($options['align'])) {
|
|
$style .= 'align:'.$options['align'].';';
|
|
// Align is deprecated, use styles.
|
|
}
|
|
|
|
if (isset($options['border'])) {
|
|
$style .= 'border:'.$options['border'].'px;';
|
|
// Border is deprecated, use styles.
|
|
}
|
|
|
|
if (isset($options['hspace'])) {
|
|
$style .= 'margin-left:'.$options['hspace'].'px;';
|
|
// hspace is deprecated, use styles.
|
|
$style .= 'margin-right:'.$options['hspace'].'px;';
|
|
}
|
|
|
|
if (isset($options['ismap'])) {
|
|
$output .= 'ismap="ismap" ';
|
|
// Defines the image as a server-side image map.
|
|
}
|
|
|
|
if (isset($options['vspace'])) {
|
|
$style .= 'margin-top:'.$options['vspace'].'px;';
|
|
// hspace is deprecated, use styles.
|
|
$style .= 'margin-bottom:'.$options['vspace'].'px;';
|
|
}
|
|
|
|
if (isset($options['style'])) {
|
|
$style .= $options['style'];
|
|
}
|
|
|
|
// If title is provided activate forced title.
|
|
if (isset($options['title']) && $options['title'] != '') {
|
|
if (isset($options['class'])) {
|
|
$options['class'] .= ' forced_title';
|
|
} else {
|
|
$options['class'] = 'forced_title';
|
|
}
|
|
|
|
// New way to show the force_title (cleaner and better performance).
|
|
$output .= 'data-title="'.io_safe_input_html($options['title']).'" ';
|
|
$output .= 'data-use_title_for_force_title="1" ';
|
|
}
|
|
|
|
// Valid attributes (invalid attributes get skipped).
|
|
$attrs = [
|
|
'height',
|
|
'longdesc',
|
|
'usemap',
|
|
'width',
|
|
'id',
|
|
'class',
|
|
'lang',
|
|
'xml:lang',
|
|
'onclick',
|
|
'ondblclick',
|
|
'onmousedown',
|
|
'onmouseup',
|
|
'onmouseover',
|
|
'onmousemove',
|
|
'onmouseout',
|
|
'onkeypress',
|
|
'onkeydown',
|
|
'onkeyup',
|
|
'pos_tree',
|
|
];
|
|
|
|
foreach ($attrs as $attribute) {
|
|
if (isset($options[$attribute])) {
|
|
$output .= $attribute.'="'.io_safe_input_html($options[$attribute]).'" ';
|
|
}
|
|
}
|
|
} else {
|
|
$options = [];
|
|
}
|
|
|
|
if (!isset($options['alt']) && isset($options['title'])) {
|
|
$options['alt'] = io_safe_input_html($options['title']);
|
|
// Set alt to title if it's not set.
|
|
}
|
|
|
|
if (!empty($style)) {
|
|
$output .= 'style="'.$style.'" ';
|
|
}
|
|
|
|
if (isset($options['alt'])) {
|
|
$output .= 'alt="'.io_safe_input_html($options['alt']).'" />';
|
|
} else {
|
|
$output .= '/>';
|
|
}
|
|
|
|
if (!$return) {
|
|
echo $output;
|
|
}
|
|
|
|
return $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Render an input text element. Extended version, use html_print_input_text() to simplify.
|
|
*
|
|
* @param string Input name.
|
|
* @param bool Whether to return an output string or echo now (optional, echo by default).
|
|
* @param array An array with optional HTML parameters.
|
|
* Key size: HTML size attribute.
|
|
* Key disabled: Whether to disable the input or not.
|
|
* Key class: HTML class
|
|
*/
|
|
function html_print_input_file($name, $return=false, $options=false)
|
|
{
|
|
$output = '';
|
|
|
|
$output .= '<input type="file" value="" name="'.$name.'" id="file-'.$name.'" ';
|
|
|
|
if ($options) {
|
|
if (isset($options['size'])) {
|
|
$output .= 'size="'.$options['size'].'"';
|
|
}
|
|
|
|
if (isset($options['disabled'])) {
|
|
$output .= 'disabled="disabled"';
|
|
}
|
|
|
|
if (isset($options['class'])) {
|
|
$output .= 'class="'.$options['class'].'"';
|
|
}
|
|
}
|
|
|
|
$output .= ' />';
|
|
|
|
if ($return) {
|
|
return $output;
|
|
}
|
|
|
|
echo $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Render a label for a input elemennt.
|
|
*
|
|
* @param string Label text.
|
|
* @param string Input id to refer.
|
|
* @param bool Whether to return an output string or echo now (optional, echo by default).
|
|
* @param array An array with optional HTML parameters.
|
|
* Key html: Extra HTML to add after the label.
|
|
* Key class: HTML class
|
|
*/
|
|
function html_print_label($text, $id, $return=false, $options=false)
|
|
{
|
|
$output = '';
|
|
|
|
$output .= '<label id="label-'.$id.'" ';
|
|
|
|
if ($options) {
|
|
if (isset($options['class'])) {
|
|
$output .= 'class="'.$options['class'].'" ';
|
|
}
|
|
|
|
if (isset($options['style'])) {
|
|
$output .= 'style="'.$options['style'].'" ';
|
|
}
|
|
}
|
|
|
|
$output .= 'for="'.$id.'" >';
|
|
$output .= $text;
|
|
$output .= '</label>';
|
|
|
|
if ($options) {
|
|
if (isset($options['html'])) {
|
|
$output .= $options['html'];
|
|
}
|
|
}
|
|
|
|
if ($return) {
|
|
return $output;
|
|
}
|
|
|
|
echo $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Convert a html color like #FF00FF into the rgb values like (255,0,255).
|
|
*
|
|
* @param string color in format #FFFFFF, FFFFFF, #FFF or FFF
|
|
*/
|
|
function html_html2rgb($htmlcolor)
|
|
{
|
|
if ($htmlcolor[0] == '#') {
|
|
$htmlcolor = substr($htmlcolor, 1);
|
|
}
|
|
|
|
if (strlen($htmlcolor) == 6) {
|
|
$r = hexdec($htmlcolor[0].$htmlcolor[1]);
|
|
$g = hexdec($htmlcolor[2].$htmlcolor[3]);
|
|
$b = hexdec($htmlcolor[4].$htmlcolor[5]);
|
|
return [
|
|
$r,
|
|
$g,
|
|
$b,
|
|
];
|
|
} else if (strlen($htmlcolor) == 3) {
|
|
$r = hexdec($htmlcolor[0].$htmlcolor[0]);
|
|
$g = hexdec($htmlcolor[1].$htmlcolor[1]);
|
|
$b = hexdec($htmlcolor[2].$htmlcolor[2]);
|
|
return [
|
|
$r,
|
|
$g,
|
|
$b,
|
|
];
|
|
} else {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Print a magic-ajax control to select the module.
|
|
*
|
|
* @param string $name The name of ajax control, by default is "module".
|
|
* @param string $default The default value to show in the ajax control.
|
|
* @param array $id_agents The array list of id agents as array(1,2,3), by default is false and the function use all agents (if the ACL desactive).
|
|
* @param boolean $ACL Filter the agents by the ACL list of user.
|
|
* @param string $scriptResult The source code of script to call, by default is
|
|
* empty. And the example is:
|
|
* function (e, data, formatted) {
|
|
* ...
|
|
* }
|
|
*
|
|
* And the formatted is the select item as string.
|
|
*
|
|
* @param array $filter Other filter of modules.
|
|
* @param boolean $return If it is true return a string with the output instead to echo the output.
|
|
* @param integer $id_agent_module Id agent module.
|
|
* @param string $size Size.
|
|
*
|
|
* @return mixed If the $return is true, return the output as string.
|
|
*/
|
|
function html_print_autocomplete_modules(
|
|
$name='module',
|
|
$default='',
|
|
$id_agents=false,
|
|
$ACL=true,
|
|
$scriptResult='',
|
|
$filter=[],
|
|
$return=false,
|
|
$id_agent_module=0,
|
|
$size='30'
|
|
) {
|
|
global $config;
|
|
|
|
if ($id_agents === false) {
|
|
$agents = agents_get_agents();
|
|
|
|
if ($agents === false) {
|
|
$agents = [];
|
|
}
|
|
|
|
$id_agents = [];
|
|
foreach ($agents as $agent) {
|
|
$id_agents[] = $agent['id_agente'];
|
|
}
|
|
} else {
|
|
if ($ACL) {
|
|
$agents = agents_get_agents();
|
|
|
|
if ($agents === false) {
|
|
$agents = [];
|
|
}
|
|
|
|
$id_agentsACL = [];
|
|
foreach ($agents as $agent) {
|
|
if (array_search($agent['id_agente'], $id_agents) !== false) {
|
|
$id_agentsACL[] = $agent['id_agente'];
|
|
}
|
|
}
|
|
|
|
$id_agents = $id_agentsACL;
|
|
}
|
|
}
|
|
|
|
ob_start();
|
|
|
|
html_print_input_text_extended(
|
|
$name,
|
|
$default,
|
|
'text-'.$name,
|
|
'',
|
|
$size,
|
|
100,
|
|
false,
|
|
'',
|
|
['style' => 'background: url(images/search_module.png) no-repeat right;']
|
|
);
|
|
html_print_input_hidden($name.'_hidden', $id_agent_module);
|
|
|
|
if (!is_metaconsole()) {
|
|
ui_print_help_tip(__('Type at least two characters to search the module.'), false);
|
|
}
|
|
|
|
$javascript_ajax_page = ui_get_full_url('ajax.php', false, false, false);
|
|
?>
|
|
<script type="text/javascript">
|
|
function escapeHTML (str)
|
|
{
|
|
var div = document.createElement('div');
|
|
var text = document.createTextNode(str);
|
|
div.appendChild(text);
|
|
return div.innerHTML;
|
|
}
|
|
|
|
$(document).ready (function () {
|
|
$("#text-<?php echo $name; ?>").autocomplete({
|
|
minLength: 2,
|
|
source: function( request, response ) {
|
|
var term = request.term; //Word to search
|
|
|
|
data_params = {
|
|
page: "include/ajax/module",
|
|
q: term,
|
|
search_modules: 1,
|
|
id_agents: '<?php echo json_encode($id_agents); ?>',
|
|
other_filter: '<?php echo json_encode($filter); ?>'
|
|
};
|
|
|
|
jQuery.ajax ({
|
|
data: data_params,
|
|
async: false,
|
|
type: "POST",
|
|
url: action="<?php echo $javascript_ajax_page; ?>",
|
|
timeout: 10000,
|
|
dataType: "json",
|
|
success: function (data) {
|
|
temp = [];
|
|
$.each(data, function (id, module) {
|
|
temp.push({
|
|
'value' : id,
|
|
'label' : module});
|
|
});
|
|
|
|
response(temp);
|
|
}
|
|
});
|
|
},
|
|
change: function( event, ui ) {
|
|
if (!ui.item)
|
|
$("input[name='<?php echo $name; ?>_hidden']")
|
|
.val(0);
|
|
return false;
|
|
},
|
|
select: function( event, ui ) {
|
|
$("input[name='<?php echo $name; ?>_hidden']")
|
|
.val(ui.item.value);
|
|
|
|
$("#text-<?php echo $name; ?>").val( ui.item.label );
|
|
return false;
|
|
}
|
|
}
|
|
);
|
|
});
|
|
</script>
|
|
<?php
|
|
$output = ob_get_clean();
|
|
|
|
if ($return) {
|
|
return $output;
|
|
} else {
|
|
echo $output;
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* @param string Select form name
|
|
* @param string Current selected value
|
|
*
|
|
* @return string HTML code
|
|
*/
|
|
function html_print_timezone_select($name, $selected='')
|
|
{
|
|
$timezones_index = timezone_identifiers_list();
|
|
$timezones = timezone_identifiers_list();
|
|
$timezones = array_combine($timezones_index, $timezones);
|
|
return html_print_select($timezones, $name, $selected, '', __('None'), '', true, false, false);
|
|
}
|
|
|
|
|
|
/**
|
|
* Enclose a text into a result_div
|
|
*
|
|
* @param string Text to enclose
|
|
*
|
|
* @return string Text inside the result_div
|
|
*/
|
|
function html_print_result_div($text)
|
|
{
|
|
$text = preg_replace('/</', '<', $text);
|
|
$text = preg_replace('/>/', '>', $text);
|
|
$text = preg_replace('/\n/i', '<br>', $text);
|
|
$text = preg_replace('/\s/i', ' ', $text);
|
|
|
|
$enclose = "<div id='result_div' style='width: 100%; height: 100%; overflow: auto; padding: 10px; font-size: 14px; line-height: 16px; font-family: mono,monospace; text-align: left'>";
|
|
$enclose .= $text;
|
|
$enclose .= '</div>';
|
|
return $enclose;
|
|
}
|
|
|
|
|
|
/**
|
|
* Print order arrows links
|
|
*
|
|
* @param array Base tags to build url
|
|
* @param string Order key to add to URL
|
|
* @param string Value to sort ascendent
|
|
* @param string Value to sort descendent
|
|
*
|
|
* @return string HTML code to display both arrows.
|
|
*/
|
|
function html_print_sort_arrows($params, $order_tag, $up='up', $down='down')
|
|
{
|
|
// Build the queries
|
|
$params[$order_tag] = $up;
|
|
$url_up = 'index.php?'.http_build_query($params, '', '&');
|
|
$params[$order_tag] = $down;
|
|
$url_down = 'index.php?'.http_build_query($params, '', '&');
|
|
|
|
// Build the links
|
|
$out = ' <a href="'.$url_up.'">';
|
|
$out .= html_print_image('images/sort_up_black.png', true);
|
|
$out .= '</a><a href="'.$url_down.'">';
|
|
$out .= html_print_image('images/sort_down_black.png', true).'</a>';
|
|
}
|
|
|
|
|
|
/**
|
|
* Print an input hidden with a new csrf token generated
|
|
*/
|
|
function html_print_csrf_hidden()
|
|
{
|
|
html_print_input_hidden('csrf_code', generate_csrf_code());
|
|
}
|
|
|
|
|
|
/**
|
|
* Print an error if csrf is incorrect
|
|
*/
|
|
function html_print_csrf_error()
|
|
{
|
|
if (validate_csrf_code()) {
|
|
return false;
|
|
}
|
|
|
|
ui_print_error_message(
|
|
__(
|
|
'%s cannot verify the origin of the request. Try again, please.',
|
|
get_product_name()
|
|
)
|
|
);
|
|
return true;
|
|
}
|
|
|
|
|
|
/**
|
|
* Print an swith button.
|
|
*
|
|
* @param array $attributes Valid params.
|
|
* name: Usefull to handle in forms.
|
|
* value: If is checked or not.
|
|
* disabled: Disabled. Cannot be pressed.
|
|
* id: Optional id for the switch.
|
|
* class: Additional classes (string).
|
|
*
|
|
* @return string with HTML of button.
|
|
*/
|
|
function html_print_switch($attributes=[])
|
|
{
|
|
$html_expand = '';
|
|
|
|
// Check the load values on status.
|
|
$html_expand .= (bool) ($attributes['value']) ? ' checked' : '';
|
|
$html_expand .= (bool) ($attributes['disabled']) ? ' disabled' : '';
|
|
|
|
// Only load the valid attributes.
|
|
$valid_attrs = [
|
|
'id',
|
|
'class',
|
|
'name',
|
|
'onclick',
|
|
'onchange',
|
|
];
|
|
foreach ($valid_attrs as $va) {
|
|
if (!isset($attributes[$va])) {
|
|
continue;
|
|
}
|
|
|
|
$html_expand .= ' '.$va.'="'.$attributes[$va].'"';
|
|
}
|
|
|
|
if (!isset($attributes['style'])) {
|
|
$attributes['style'] = '';
|
|
}
|
|
|
|
return "<label class='p-switch' style='".$attributes['style']."'>
|
|
<input type='checkbox' ".$html_expand.">
|
|
<span class='p-slider'></span>
|
|
</label>";
|
|
}
|
|
|
|
|
|
/**
|
|
* Print a link with post params.The component is really a form with a button
|
|
* with some inputs hidden.
|
|
*
|
|
* @param string $text Text to show.
|
|
* @param array $params Params to be written like inputs hidden.
|
|
* @param string $text Text of image.
|
|
* @param string $style Additional style for the element.
|
|
*
|
|
* @return string With HTML code.
|
|
*/
|
|
function html_print_link_with_params($text, $params=[], $type='text', $style='')
|
|
{
|
|
$html = '<form method=post>';
|
|
switch ($type) {
|
|
case 'image':
|
|
$html .= html_print_input_image($text, $text, $text, $style, true);
|
|
break;
|
|
|
|
case 'text':
|
|
default:
|
|
if (!empty($style)) {
|
|
$style = ' style="'.$style.'"';
|
|
}
|
|
|
|
$html .= html_print_submit_button(
|
|
$text,
|
|
$text,
|
|
false,
|
|
'class="button-as-link"'.$style,
|
|
true
|
|
);
|
|
break;
|
|
}
|
|
|
|
foreach ($params as $param => $value) {
|
|
$html .= html_print_input_hidden($param, $value, true);
|
|
}
|
|
|
|
$html .= '</form>';
|
|
|
|
return $html;
|
|
}
|
|
|
|
|
|
/**
|
|
* Print input using functions html lib.
|
|
*
|
|
* @param array $data Input definition.
|
|
* @param string $wrapper Wrapper 'div' or 'li'.
|
|
* @param boolean $input_only Return or print only input or also label.
|
|
*
|
|
* @return string HTML code for desired input.
|
|
*/
|
|
function html_print_input($data, $wrapper='div', $input_only=false)
|
|
{
|
|
if (is_array($data) === false) {
|
|
return '';
|
|
}
|
|
|
|
$output = '';
|
|
|
|
if ($data['label'] && $input_only === false) {
|
|
$output = '<'.$wrapper.' id="'.$wrapper.'-'.$data['name'].'" ';
|
|
$output .= ' class="'.$data['input_class'].'">';
|
|
$output .= '<label class="'.$data['label_class'].'">';
|
|
$output .= $data['label'];
|
|
$output .= '</label>';
|
|
|
|
if (!$data['return']) {
|
|
echo $output;
|
|
}
|
|
}
|
|
|
|
if (isset($data['wrapper']) === true) {
|
|
$output = '<'.$data['wrapper'].' id="wr_'.$data['name'].'" ';
|
|
$output .= ' class="'.$data['input_class'].'">';
|
|
}
|
|
|
|
switch ($data['type']) {
|
|
case 'text':
|
|
$output .= html_print_input_text(
|
|
$data['name'],
|
|
$data['value'],
|
|
((isset($data['alt']) === true) ? $data['alt'] : ''),
|
|
((isset($data['size']) === true) ? $data['size'] : 50),
|
|
((isset($data['maxlength']) === true) ? $data['maxlength'] : 255),
|
|
((isset($data['return']) === true) ? $data['return'] : true),
|
|
((isset($data['disabled']) === true) ? $data['disabled'] : false),
|
|
((isset($data['required']) === true) ? $data['required'] : false),
|
|
((isset($data['function']) === true) ? $data['function'] : ''),
|
|
((isset($data['class']) === true) ? $data['class'] : ''),
|
|
((isset($data['onChange']) === true) ? $data['onChange'] : ''),
|
|
((isset($data['autocomplete']) === true) ? $data['autocomplete'] : '')
|
|
);
|
|
break;
|
|
|
|
case 'image':
|
|
$output .= html_print_input_image(
|
|
$data['name'],
|
|
$data['src'],
|
|
$data['value'],
|
|
((isset($data['style']) === true) ? $data['style'] : ''),
|
|
((isset($data['return']) === true) ? $data['return'] : false),
|
|
((isset($data['options']) === true) ? $data['options'] : false)
|
|
);
|
|
break;
|
|
|
|
case 'text_extended':
|
|
$output .= html_print_input_text_extended(
|
|
$data['name'],
|
|
$data['value'],
|
|
$data['id'],
|
|
$data['alt'],
|
|
$data['size'],
|
|
$data['maxlength'],
|
|
$data['disabled'],
|
|
$data['script'],
|
|
$data['attributes'],
|
|
((isset($data['return']) === true) ? $data['return'] : false),
|
|
((isset($data['password']) === true) ? $data['password'] : false),
|
|
((isset($data['function']) === true) ? $data['function'] : '')
|
|
);
|
|
break;
|
|
|
|
case 'password':
|
|
$output .= html_print_input_password(
|
|
$data['name'],
|
|
$data['value'],
|
|
((isset($data['alt']) === true) ? $data['alt'] : ''),
|
|
((isset($data['size']) === true) ? $data['size'] : 50),
|
|
((isset($data['maxlength']) === true) ? $data['maxlength'] : 255),
|
|
((isset($data['return']) === true) ? $data['return'] : false),
|
|
((isset($data['disabled']) === true) ? $data['disabled'] : false),
|
|
((isset($data['required']) === true) ? $data['required'] : false),
|
|
((isset($data['class']) === true) ? $data['class'] : ''),
|
|
((isset($data['autocomplete']) === true) ? $data['autocomplete'] : 'off')
|
|
);
|
|
break;
|
|
|
|
case 'text':
|
|
$output .= html_print_input_text(
|
|
$data['name'],
|
|
$data['value'],
|
|
((isset($data['alt']) === true) ? $data['alt'] : ''),
|
|
((isset($data['size']) === true) ? $data['size'] : 50),
|
|
((isset($data['maxlength']) === true) ? $data['maxlength'] : 255),
|
|
((isset($data['return']) === true) ? $data['return'] : false),
|
|
((isset($data['disabled']) === true) ? $data['disabled'] : false),
|
|
((isset($data['required']) === true) ? $data['required'] : false),
|
|
((isset($data['function']) === true) ? $data['function'] : ''),
|
|
((isset($data['class']) === true) ? $data['class'] : ''),
|
|
((isset($data['onChange']) === true) ? $data['onChange'] : ''),
|
|
((isset($data['autocomplete']) === true) ? $data['autocomplete'] : '')
|
|
);
|
|
break;
|
|
|
|
case 'email':
|
|
$output .= html_print_input_email($data);
|
|
break;
|
|
|
|
case 'number':
|
|
$output .= html_print_input_number($data);
|
|
break;
|
|
|
|
case 'hidden':
|
|
$output .= html_print_input_hidden(
|
|
$data['name'],
|
|
$data['value'],
|
|
((isset($data['return']) === true) ? $data['return'] : false),
|
|
((isset($data['class']) === true) ? $data['class'] : false)
|
|
);
|
|
break;
|
|
|
|
case 'hidden_extended':
|
|
$output .= html_print_input_hidden_extended(
|
|
$data['name'],
|
|
$data['value'],
|
|
$data['id'],
|
|
((isset($data['return']) === true) ? $data['return'] : false),
|
|
((isset($data['class']) === true) ? $data['class'] : false),
|
|
((isset($data['quotes']) === true) ? $data['quotes'] : false)
|
|
);
|
|
break;
|
|
|
|
case 'color':
|
|
$output .= html_print_input_color(
|
|
$data['name'],
|
|
$data['value'],
|
|
((isset($data['class']) === true) ? $data['class'] : false),
|
|
((isset($data['return']) === true) ? $data['return'] : false)
|
|
);
|
|
break;
|
|
|
|
case 'file':
|
|
$output .= html_print_input_file(
|
|
$data['name'],
|
|
((isset($data['return']) === true) ? $data['return'] : false),
|
|
((isset($data['options']) === true) ? $data['options'] : false)
|
|
);
|
|
break;
|
|
|
|
case 'select':
|
|
$output .= html_print_select(
|
|
$data['fields'],
|
|
$data['name'],
|
|
((isset($data['selected']) === true) ? $data['selected'] : ''),
|
|
((isset($data['script']) === true) ? $data['script'] : ''),
|
|
((isset($data['nothing']) === true) ? $data['nothing'] : ''),
|
|
((isset($data['nothing_value']) === true) ? $data['nothing_value'] : 0),
|
|
((isset($data['return']) === true) ? $data['return'] : false),
|
|
((isset($data['multiple']) === true) ? $data['multiple'] : false),
|
|
((isset($data['sort']) === true) ? $data['sort'] : true),
|
|
((isset($data['class']) === true) ? $data['class'] : ''),
|
|
((isset($data['disabled']) === true) ? $data['disabled'] : false),
|
|
((isset($data['style']) === true) ? $data['style'] : false),
|
|
((isset($data['option_style']) === true) ? $data['option_style'] : false),
|
|
((isset($data['size']) === true) ? $data['size'] : false),
|
|
((isset($data['modal']) === true) ? $data['modal'] : false),
|
|
((isset($data['message']) === true) ? $data['message'] : ''),
|
|
((isset($data['select_all']) === true) ? $data['select_all'] : false)
|
|
);
|
|
break;
|
|
|
|
case 'select_from_sql':
|
|
$output .= html_print_select_from_sql(
|
|
$data['sql'],
|
|
$data['name'],
|
|
((isset($data['selected']) === true) ? $data['selected'] : ''),
|
|
((isset($data['script']) === true) ? $data['script'] : ''),
|
|
((isset($data['nothing']) === true) ? $data['nothing'] : ''),
|
|
((isset($data['nothing_value']) === true) ? $data['nothing_value'] : '0'),
|
|
((isset($data['return']) === true) ? $data['return'] : false),
|
|
((isset($data['multiple']) === true) ? $data['multiple'] : false),
|
|
((isset($data['sort']) === true) ? $data['sort'] : true),
|
|
((isset($data['disabled']) === true) ? $data['disabled'] : false),
|
|
((isset($data['style']) === true) ? $data['style'] : false),
|
|
((isset($data['size']) === true) ? $data['size'] : false),
|
|
((isset($data['trucate_size']) === true) ? $data['trucate_size'] : GENERIC_SIZE_TEXT)
|
|
);
|
|
break;
|
|
|
|
case 'select_groups':
|
|
$output .= html_print_select_groups(
|
|
((isset($data['id_user']) === true) ? $data['id_user'] : false),
|
|
((isset($data['privilege']) === true) ? $data['privilege'] : 'AR'),
|
|
((isset($data['returnAllGroup']) === true) ? $data['returnAllGroup'] : true),
|
|
$data['name'],
|
|
((isset($data['selected']) === true) ? $data['selected'] : ''),
|
|
((isset($data['script']) === true) ? $data['script'] : ''),
|
|
((isset($data['nothing']) === true) ? $data['nothing'] : ''),
|
|
((isset($data['nothing_value']) === true) ? $data['nothing_value'] : 0),
|
|
((isset($data['return']) === true) ? $data['return'] : false),
|
|
((isset($data['multiple']) === true) ? $data['multiple'] : false),
|
|
((isset($data['sort']) === true) ? $data['sort'] : true),
|
|
((isset($data['class']) === true) ? $data['class'] : ''),
|
|
((isset($data['disabled']) === true) ? $data['disabled'] : false),
|
|
((isset($data['style']) === true) ? $data['style'] : false),
|
|
((isset($data['option_style']) === true) ? $data['option_style'] : false),
|
|
((isset($data['id_group']) === true) ? $data['id_group'] : false),
|
|
((isset($data['keys_field']) === true) ? $data['keys_field'] : 'id_grupo'),
|
|
((isset($data['strict_user']) === true) ? $data['strict_user'] : false),
|
|
((isset($data['delete_groups']) === true) ? $data['delete_groups'] : false),
|
|
((isset($data['include_groups']) === true) ? $data['include_groups'] : false),
|
|
((isset($data['size']) === true) ? $data['size'] : false),
|
|
((isset($data['simple_multiple_options']) === true) ? $data['simple_multiple_options'] : false)
|
|
);
|
|
break;
|
|
|
|
case 'submit':
|
|
$width = (isset($data['width']) === true) ? 'width: '.$data['width'] : 'width: 100%';
|
|
$output .= '<'.$wrapper.' class="action-buttons" style="'.$width.'">'.html_print_submit_button(
|
|
((isset($data['label']) === true) ? $data['label'] : 'OK'),
|
|
((isset($data['name']) === true) ? $data['name'] : ''),
|
|
((isset($data['disabled']) === true) ? $data['disabled'] : false),
|
|
((isset($data['attributes']) === true) ? $data['attributes'] : ''),
|
|
((isset($data['return']) === true) ? $data['return'] : false)
|
|
).'</'.$wrapper.'>';
|
|
break;
|
|
|
|
case 'checkbox':
|
|
$output .= html_print_checkbox(
|
|
$data['name'],
|
|
$data['value'],
|
|
((isset($data['checked']) === true) ? $data['checked'] : false),
|
|
((isset($data['return']) === true) ? $data['return'] : false),
|
|
((isset($data['disabled']) === true) ? $data['disabled'] : false),
|
|
((isset($data['script']) === true) ? $data['script'] : ''),
|
|
((isset($data['disabled_hidden']) === true) ? $data['disabled_hidden'] : false),
|
|
((isset($data['attributes']) === true) ? $data['attributes'] : ''),
|
|
((isset($data['id']) === true) ? $data['id'] : '')
|
|
);
|
|
break;
|
|
|
|
case 'switch':
|
|
$output .= html_print_switch($data);
|
|
break;
|
|
|
|
case 'interval':
|
|
$output .= html_print_extended_select_for_time(
|
|
$data['name'],
|
|
$data['value'],
|
|
((isset($data['script']) === true) ? $data['script'] : ''),
|
|
((isset($data['nothing']) === true) ? $data['nothing'] : ''),
|
|
((isset($data['nothing_value']) === true) ? $data['nothing_value'] : 0),
|
|
((isset($data['size']) === true) ? $data['size'] : false),
|
|
((isset($data['return']) === true) ? $data['return'] : false),
|
|
((isset($data['style']) === true) ? $data['selected'] : false),
|
|
((isset($data['unique']) === true) ? $data['unique'] : false)
|
|
);
|
|
break;
|
|
|
|
case 'textarea':
|
|
$output .= html_print_textarea(
|
|
$data['name'],
|
|
$data['rows'],
|
|
$data['columns'],
|
|
((isset($data['value']) === true) ? $data['value'] : ''),
|
|
((isset($data['attributes']) === true) ? $data['attributes'] : ''),
|
|
((isset($data['return']) === true) ? $data['return'] : false),
|
|
((isset($data['class']) === true) ? $data['class'] : '')
|
|
);
|
|
break;
|
|
|
|
case 'button':
|
|
$output .= html_print_button(
|
|
((isset($data['label']) === true) ? $data['label'] : 'OK'),
|
|
((isset($data['name']) === true) ? $data['name'] : ''),
|
|
((isset($data['disabled']) === true) ? $data['disabled'] : false),
|
|
((isset($data['script']) === true) ? $data['script'] : ''),
|
|
((isset($data['attributes']) === true) ? $data['attributes'] : ''),
|
|
((isset($data['return']) === true) ? $data['return'] : false),
|
|
((isset($data['imageButton']) === true) ? $data['imageButton'] : false),
|
|
((isset($data['modal']) === true) ? $data['modal'] : false),
|
|
((isset($data['message']) === true) ? $data['message'] : '')
|
|
);
|
|
break;
|
|
|
|
case 'radio_button':
|
|
$output .= html_print_radio_button_extended(
|
|
$data['name'],
|
|
$data['value'],
|
|
$data['label'],
|
|
((isset($data['checkedvalue']) === true) ? $data['checkedvalue'] : 1),
|
|
((isset($data['disabled']) === true) ? $data['disabled'] : ''),
|
|
((isset($data['script']) === true) ? $data['script'] : ''),
|
|
((isset($data['attributes']) === true) ? $data['attributes'] : true),
|
|
((isset($data['return']) === true) ? $data['return'] : false),
|
|
((isset($data['modal']) === true) ? $data['modal'] : false),
|
|
((isset($data['message']) === true) ? $data['message'] : 'visualmodal'),
|
|
((isset($data['id']) === true) ? $data['id'] : null)
|
|
);
|
|
break;
|
|
|
|
case 'email':
|
|
$output .= html_print_input_email($data);
|
|
break;
|
|
|
|
case 'multicheck':
|
|
$output .= html_print_input_multicheck($data);
|
|
break;
|
|
|
|
case 'autocomplete_agent':
|
|
$agent_name = '';
|
|
if (isset($data['id_agent_hidden']) === true
|
|
&& empty($data['id_agent_hidden']) === false
|
|
) {
|
|
if (is_metaconsole() === true) {
|
|
$connection = metaconsole_get_connection_by_id(
|
|
$data['server_id_hidden']
|
|
);
|
|
$agent_name = '';
|
|
|
|
if (metaconsole_load_external_db($connection) == NOERR) {
|
|
$agent_name = db_get_value_filter(
|
|
'alias',
|
|
'tagente',
|
|
['id_agente' => $data['id_agent_hidden']]
|
|
);
|
|
}
|
|
|
|
// Append server name.
|
|
if (!empty($agent_name)) {
|
|
$agent_name .= ' ('.$connection['server_name'].')';
|
|
}
|
|
|
|
// Restore db connection.
|
|
metaconsole_restore_db();
|
|
} else {
|
|
$agent_name = agents_get_alias($data['id_agent_hidden']);
|
|
}
|
|
}
|
|
|
|
$params = [];
|
|
$params['return'] = $data['return'];
|
|
$params['show_helptip'] = false;
|
|
$params['input_name'] = $data['name'];
|
|
$params['value'] = $agent_name;
|
|
$params['javascript_is_function_select'] = true;
|
|
|
|
if (isset($data['module_input']) === true
|
|
&& $data['module_input'] === true
|
|
) {
|
|
$params['selectbox_id'] = $data['module_name'];
|
|
$params['add_none_module'] = $data['module_none'];
|
|
}
|
|
|
|
$params['use_hidden_input_idagent'] = true;
|
|
$params['hidden_input_idagent_id'] = 'hidden-'.$data['name_agent_hidden'];
|
|
if (is_metaconsole()) {
|
|
$params['use_input_id_server'] = true;
|
|
$params['input_id_server_id'] = 'hidden-'.$data['name_server_hidden'];
|
|
$params['metaconsole_enabled'] = true;
|
|
}
|
|
|
|
$output .= html_print_input_hidden(
|
|
$data['name_agent_hidden'],
|
|
$data['id_agent_hidden'],
|
|
$data['return']
|
|
);
|
|
|
|
$output .= html_print_input_hidden(
|
|
$data['name_server_hidden'],
|
|
$data['server_id_hidden'],
|
|
$data['return']
|
|
);
|
|
|
|
$output .= ui_print_agent_autocomplete_input($params);
|
|
break;
|
|
|
|
case 'autocomplete_module':
|
|
// Module.
|
|
if (isset($data['selected']) === false || $data['selected'] === 0) {
|
|
$fields = [
|
|
0 => __('Select an Agent first'),
|
|
];
|
|
} else {
|
|
$sql = sprintf(
|
|
'SELECT id_agente_modulo, nombre
|
|
FROM tagente_modulo
|
|
WHERE id_agente = %d
|
|
AND delete_pending = 0',
|
|
$data['agent_id']
|
|
);
|
|
|
|
if (is_metaconsole() === true) {
|
|
$connection = metaconsole_get_connection_id(
|
|
$data['metaconsole_id']
|
|
);
|
|
|
|
if (metaconsole_load_external_db($connection) == NOERR) {
|
|
$modules_agent = db_get_all_rows_sql($sql);
|
|
|
|
if ($modules_agent === false) {
|
|
$modules_agent = [];
|
|
}
|
|
}
|
|
|
|
// Restore db connection.
|
|
metaconsole_restore_db();
|
|
} else {
|
|
$modules_agent = db_get_all_rows_sql($sql);
|
|
}
|
|
|
|
$fields = [];
|
|
if (isset($modules_agent) === true
|
|
&& is_array($modules_agent) === true
|
|
) {
|
|
$fields = array_reduce(
|
|
$modules_agent,
|
|
function ($carry, $item) {
|
|
$carry[$item['id_agente_modulo']] = $item['nombre'];
|
|
return $carry;
|
|
},
|
|
[]
|
|
);
|
|
}
|
|
}
|
|
|
|
$output .= html_print_select(
|
|
$fields,
|
|
$data['name'],
|
|
((isset($data['selected']) === true) ? $data['selected'] : ''),
|
|
((isset($data['script']) === true) ? $data['script'] : ''),
|
|
((isset($data['nothing']) === true) ? $data['nothing'] : ''),
|
|
((isset($data['nothing_value']) === true) ? $data['nothing_value'] : 0),
|
|
((isset($data['return']) === true) ? $data['return'] : false),
|
|
((isset($data['multiple']) === true) ? $data['multiple'] : false),
|
|
((isset($data['sort']) === true) ? $data['sort'] : true),
|
|
((isset($data['class']) === true) ? $data['class'] : ''),
|
|
((isset($data['disabled']) === true) ? $data['disabled'] : false),
|
|
((isset($data['style']) === true) ? $data['style'] : false),
|
|
((isset($data['option_style']) === true) ? $data['option_style'] : false),
|
|
((isset($data['size']) === true) ? $data['size'] : false),
|
|
((isset($data['modal']) === true) ? $data['modal'] : false),
|
|
((isset($data['message']) === true) ? $data['message'] : ''),
|
|
((isset($data['select_all']) === true) ? $data['select_all'] : false)
|
|
);
|
|
break;
|
|
|
|
default:
|
|
// Ignore.
|
|
break;
|
|
}
|
|
|
|
if (isset($data['wrapper']) === true) {
|
|
$output .= '</'.$data['wrapper'].'>';
|
|
}
|
|
|
|
if ($data['label'] && $input_only === false) {
|
|
$output .= '</'.$wrapper.'>';
|
|
if (!$data['return']) {
|
|
echo '</'.$wrapper.'>';
|
|
}
|
|
}
|
|
|
|
return $output;
|
|
}
|
|
|
|
|
|
/**
|
|
* Print all checkbox in the same row.
|
|
*
|
|
* @param array $data Array with attributes input.
|
|
* only name is necessary.
|
|
*
|
|
* @return string
|
|
*/
|
|
function html_print_input_multicheck(array $data):string
|
|
{
|
|
$html = '';
|
|
if (isset($data['data']) === true && is_array($data['data']) === true) {
|
|
foreach ($data['data'] as $key => $value) {
|
|
$html .= $value;
|
|
$html .= html_print_checkbox(
|
|
'days_week_'.$key,
|
|
1,
|
|
$data['checked'][$key],
|
|
true
|
|
);
|
|
}
|
|
}
|
|
|
|
return $html;
|
|
}
|
|
|
|
|
|
/**
|
|
* Print an autocomplete input filled out with Integria IMS users.
|
|
*
|
|
* @param string $name The name of ajax control, by default is "users".
|
|
* @param string $default The default value to show in the ajax control.
|
|
* @param boolean $return If it is true return a string with the output instead to echo the output.
|
|
* @param string $size Size.
|
|
*
|
|
* @return mixed If the $return is true, return the output as string.
|
|
*/
|
|
function html_print_autocomplete_users_from_integria(
|
|
$name='users',
|
|
$default='',
|
|
$return=false,
|
|
$size='30',
|
|
$disable=false,
|
|
$required=false
|
|
) {
|
|
global $config;
|
|
|
|
ob_start();
|
|
|
|
$attrs = ['style' => 'background: url(images/user_green.png) no-repeat right;'];
|
|
|
|
if ($required) {
|
|
$attrs['required'] = 'required';
|
|
}
|
|
|
|
html_print_input_text_extended(
|
|
$name,
|
|
$default,
|
|
'text-'.$name,
|
|
'',
|
|
$size,
|
|
100,
|
|
$disable,
|
|
'',
|
|
$attrs
|
|
);
|
|
html_print_input_hidden($name.'_hidden', $id_agent_module);
|
|
|
|
ui_print_help_tip(__('Type at least two characters to search the user.'), false);
|
|
|
|
$javascript_ajax_page = ui_get_full_url('ajax.php', false, false, false, false);
|
|
?>
|
|
<script type="text/javascript">
|
|
function escapeHTML (str)
|
|
{
|
|
var div = document.createElement('div');
|
|
var text = document.createTextNode(str);
|
|
div.appendChild(text);
|
|
return div.innerHTML;
|
|
}
|
|
|
|
$(document).ready (function () {
|
|
$("#text-<?php echo $name; ?>").autocomplete({
|
|
minLength: 2,
|
|
source: function( request, response ) {
|
|
var term = request.term; //Word to search
|
|
|
|
data_params = {
|
|
page: "include/ajax/integria_incidents.ajax",
|
|
search_term: term,
|
|
get_users: 1,
|
|
};
|
|
|
|
jQuery.ajax ({
|
|
data: data_params,
|
|
async: false,
|
|
type: "POST",
|
|
url: action="<?php echo $javascript_ajax_page; ?>",
|
|
timeout: 10000,
|
|
dataType: "json",
|
|
success: function (data) {
|
|
temp = [];
|
|
$.each(data, function (id, module) {
|
|
temp.push({
|
|
'value' : id,
|
|
'label' : module});
|
|
});
|
|
|
|
response(temp);
|
|
}
|
|
});
|
|
},
|
|
change: function( event, ui ) {
|
|
if (!ui.item)
|
|
$("input[name='<?php echo $name; ?>_hidden']")
|
|
.val(0);
|
|
return false;
|
|
},
|
|
select: function( event, ui ) {
|
|
$("input[name='<?php echo $name; ?>_hidden']")
|
|
.val(ui.item.value);
|
|
|
|
$("#text-<?php echo $name; ?>").val( ui.item.label );
|
|
return false;
|
|
}
|
|
}
|
|
);
|
|
});
|
|
</script>
|
|
<?php
|
|
$output = ob_get_clean();
|
|
|
|
if ($return) {
|
|
return $output;
|
|
} else {
|
|
echo $output;
|
|
}
|
|
}
|
|
|
|
|
|
function html_print_tabs(array $tabs)
|
|
{
|
|
$result = '<div id="html-tabs">';
|
|
$result .= '<ul class="">';
|
|
foreach ($tabs as $key => $value) {
|
|
$result .= "<li><a href='".$value['href']."' id='".$value['id']."'>";
|
|
$result .= html_print_image(
|
|
'images/'.$value['img'],
|
|
true
|
|
);
|
|
$result .= '<span>'.$value['name'].'</span>';
|
|
$result .= '</a></li>';
|
|
}
|
|
|
|
$result .= '</ul>';
|
|
|
|
$result .= '</div>';
|
|
|
|
return $result;
|
|
}
|