%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /home/infra/fusioninventory/inc/
Upload File :
Create Path :
Current File : //home/infra/fusioninventory/inc/commonview.class.php

<?php

/**
 * FusionInventory
 *
 * Copyright (C) 2010-2023 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-2023 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'>";
      echo Html::input($varname, ['size' => 40, 'value' => $this->fields[$varname]]);
      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;

      Html::showCheckbox($options);
   }


   /**
    * 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>";
   }


}


Zerion Mini Shell 1.0