2022-02-11 15:48:06 +01:00

335 lines
8.8 KiB
PHP

<?php
/**
* FusionInventory
*
* Copyright (C) 2010-2016 by the FusionInventory Development Team.
*
* http://www.fusioninventory.org/
* https://github.com/fusioninventory/fusioninventory-for-glpi
* http://forge.fusioninventory.org/
*
* ------------------------------------------------------------------------
*
* LICENSE
*
* This file is part of FusionInventory project.
*
* FusionInventory is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* FusionInventory 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 Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with FusionInventory. If not, see <http://www.gnu.org/licenses/>.
*
* ------------------------------------------------------------------------
*
* 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 "<label>".$title."&nbsp;:</label>";
echo "<div class='input_wrap'>";
Html::autocompletionTextField ($this, $varname, $this->fields['name']);
echo "</div>";
}
/**
* Display input form element only with numbers
*
* @param string $title
* @param string $varname
* @param array $options
*/
public function showIntegerField($title, $varname, $options = []) {
echo "<label>".$title."&nbsp;:</label>";
echo "<div class='input_wrap'>";
Dropdown::showNumber($varname, $options);
echo "</div>";
}
/**
* Display checkbox form element
*
* @param string $title
* @param string $varname
* @param array $options
*/
public function showCheckboxField($title, $varname, $options = []) {
echo "<label>" . $title."&nbsp;:" . "</label>";
$options['name'] = $varname;
$options['checked'] = $this->fields[$varname];
$options['zero_on_empty']= true;
echo "<div class='input_wrap'>";
Html::showCheckbox($options);
echo "</div>";
}
/**
* 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 "<label>" . $title."&nbsp;:" . "</label>";
echo "<div class='input_wrap'>";
$dropdown_options = array_merge(
[
'width'=>'90%',
'display'=>true,
],
$options
);
$rand = Dropdown::show($itemtype, $dropdown_options);
echo "</div>";
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 "<label>" . $title."&nbsp;:" . "</label>";
echo "<div class='input_wrap'>";
if (!isset($options['width'])) {
$options['width'] = '100%';
}
if (!is_null($varname)) {
$options['value'] = $this->fields[$varname];
}
$rand = Dropdown::showFromArray(
$varname, $values,
$options
);
echo "</div>";
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 "<label>".$title."&nbsp;:</label>";
echo "<div class='input_wrap datetime'>";
Html::showDateTimeField(
$varname,
$options
);
echo "</div>";
}
/**
* Display a text area form element
*
* @param string $title
* @param string $varname
*/
public function showTextArea($title, $varname) {
echo "<label>".$title."&nbsp;:</label>";
echo "<div class='input_wrap'>";
echo
"<textarea class='autogrow' name='".$varname."' >".
$this->fields[$varname].
"</textarea>";
echo "</div>";
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 "<div class='box' style='margin-bottom:20px;'>
<div class='box-tleft'>
<div class='box-tright'>
<div class='box-tcenter'></div>
</div>
</div>
<div class='box-mleft'>
<div class='box-mright'>
<div class='box-mcenter'>
<span class='b $class_msg'>$msg</span>
</div>
</div>
</div>
<div class='box-bleft'>
<div class='box-bright'>
<div class='box-bcenter'></div>
</div>
</div>
</div>";
}
}