.
*
* ------------------------------------------------------------------------
*
* This file is used to display elements in the plugin.
*
* ------------------------------------------------------------------------
*
* @package FusionInventory
* @author Kevin Roy
* @author David Durieux
* @copyright Copyright (c) 2010-2016 FusionInventory team
* @license AGPL License 3.0 or (at your option) any later version
* http://www.gnu.org/licenses/agpl-3.0-standalone.html
* @link http://www.fusioninventory.org/
* @link https://github.com/fusioninventory/fusioninventory-for-glpi
*
*/
if (!defined('GLPI_ROOT')) {
die("Sorry. You can't access directly to this file");
}
/**
* It's a common code for display information in GLPI.
*/
class PluginFusioninventoryCommonView extends CommonDBTM {
/**
* Define the number for the message information constant
*
* @var interger
*/
const MSG_INFO = 0;
/**
* Define the number for the message warning constant
*
* @var interger
*/
const MSG_WARNING = 1;
/**
* Define the number for the message error constant
*
* @var interger
*/
const MSG_ERROR = 2;
/**
* Define default value for the base URLs
*
* @var array
*/
public $base_urls = [];
/**
* __contruct function and the different base URLs
*
* @global array $CFG_GLPI
*/
public function __construct() {
global $CFG_GLPI;
parent::__construct();
$fi_path = Plugin::getWebDir('fusioninventory');
$this->base_urls = [
'fi.base' => $fi_path,
'fi.ajax' => $fi_path . "/ajax",
'fi.front' => $fi_path . "/front",
'fi.pics' => $fi_path . "/pics",
'glpi.pics' => $CFG_GLPI['root_doc'] . "/pics",
];
}
/**
* Get a specific url root by type name
*
* @param string $name the type of url requested (can be used for ajax call
* or pictures location)
* @return string the requested url if found otherwise empty string
*/
function getBaseUrlFor($name) {
if (array_key_exists($name, $this->base_urls)) {
return $this->base_urls[$name];
}
trigger_error(
"The requested url type '$name' doesn't exists. ".
"Maybe the developper have forgotten to register it in the 'base_urls' variable.");
return "";
}
/**
* Show Search list for this itemtype
*/
public function showList() {
Search::show(get_class($this));
}
/**
* Display input form element
*
* @param string $title
* @param string $varname
*/
public function showTextField($title, $varname) {
echo "";
echo "
";
}
/**
* Display dropdown form element for itemtype
*
* @param string $title
* @param string $itemtype a glpi/plugin itemtype
* @param array $options
* @return string the rand number can be used with ajax to update something
*/
public function showDropdownForItemtype($title, $itemtype, $options = []) {
echo "";
echo "
";
return $rand;
}
/**
* Display dropdown form element with array data
*
* @param string $title
* @param string $varname
* @param array $values
* @param array $options
* @return string the rand number can be used with ajax to update something
*/
public function showDropdownFromArray($title, $varname, $values = [], $options = []) {
echo "";
echo "
";
return $rand;
}
/**
* Display date time select form element
*
* @param string $title
* @param string $varname
* @param array $options
*/
public function showDateTimeField($title, $varname, $options = []) {
// Get datetime value if the object is defined
if ($this->fields['id'] > 0) {
$value = $this->fields[$varname];
} else {
// Else set default value to current date and time
if (array_key_exists('maybeempty', $options)
and $options['maybeempty']) {
$value = "";
} else {
$value = date("Y-m-d H:i:s");
}
}
$options['value'] = $value;
echo "";
echo "
";
}
/**
* Display a text area form element
*
* @param string $title
* @param string $varname
*/
public function showTextArea($title, $varname) {
echo "";
echo "
";
echo
"";
echo "
";
echo Html::scriptBlock("$('.autogrow').autogrow();");
}
/**
* Get a HTML message
*
* @param string $msg
* @param integer $type
* @return string
*/
public function getMessage($msg, $type = self::MSG_INFO) {
switch ($type) {
case self::MSG_WARNING:
$msg = __('Warning:', 'fusioninventory') . " $msg";
$class_msg = 'warning';
break;
case self::MSG_ERROR:
$msg = __('Error:', 'fusioninventory') . " $msg";
$class_msg = 'error';
break;
case self::MSG_INFO:
default:
$class_msg = '';
break;
}
return "