mise à jour ansible glpi
This commit is contained in:
@@ -0,0 +1,334 @@
|
||||
<?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." :</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." :</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." :" . "</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." :" . "</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." :" . "</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." :</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." :</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>";
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user