Save new folder
This commit is contained in:
239
inc/devicememory.class.php
Normal file
239
inc/devicememory.class.php
Normal file
@ -0,0 +1,239 @@
|
||||
<?php
|
||||
/**
|
||||
* ---------------------------------------------------------------------
|
||||
* GLPI - Gestionnaire Libre de Parc Informatique
|
||||
* Copyright (C) 2015-2020 Teclib' and contributors.
|
||||
*
|
||||
* http://glpi-project.org
|
||||
*
|
||||
* based on GLPI - Gestionnaire Libre de Parc Informatique
|
||||
* Copyright (C) 2003-2014 by the INDEPNET Development Team.
|
||||
*
|
||||
* ---------------------------------------------------------------------
|
||||
*
|
||||
* LICENSE
|
||||
*
|
||||
* This file is part of GLPI.
|
||||
*
|
||||
* GLPI is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* GLPI 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.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with GLPI. If not, see <http://www.gnu.org/licenses/>.
|
||||
* ---------------------------------------------------------------------
|
||||
*/
|
||||
|
||||
if (!defined('GLPI_ROOT')) {
|
||||
die("Sorry. You can't access this file directly");
|
||||
}
|
||||
|
||||
/// Class DeviceMemory
|
||||
class DeviceMemory extends CommonDevice {
|
||||
|
||||
static protected $forward_entity_to = ['Item_DeviceMemory', 'Infocom'];
|
||||
|
||||
static function getTypeName($nb = 0) {
|
||||
return _n('Memory', 'Memory', $nb);
|
||||
}
|
||||
|
||||
|
||||
function getAdditionalFields() {
|
||||
|
||||
return array_merge(parent::getAdditionalFields(),
|
||||
[['name' => 'size_default',
|
||||
'label' => __('Size by default'),
|
||||
'type' => 'text',
|
||||
'unit' => __('Mio')],
|
||||
['name' => 'frequence',
|
||||
'label' => __('Frequency'),
|
||||
'type' => 'text',
|
||||
'unit' => __('MHz')],
|
||||
['name' => 'devicememorytypes_id',
|
||||
'label' => _n('Type', 'Types', 1),
|
||||
'type' => 'dropdownValue'],
|
||||
['name' => 'devicememorymodels_id',
|
||||
'label' => _n('Model', 'Models', 1),
|
||||
'type' => 'dropdownValue']]);
|
||||
}
|
||||
|
||||
|
||||
function rawSearchOptions() {
|
||||
$tab = parent::rawSearchOptions();
|
||||
|
||||
$tab[] = [
|
||||
'id' => '11',
|
||||
'table' => $this->getTable(),
|
||||
'field' => 'size_default',
|
||||
'name' => __('Size by default'),
|
||||
'datatype' => 'string',
|
||||
'autocomplete' => true,
|
||||
];
|
||||
|
||||
$tab[] = [
|
||||
'id' => '12',
|
||||
'table' => $this->getTable(),
|
||||
'field' => 'frequence',
|
||||
'name' => __('Frequency'),
|
||||
'datatype' => 'string',
|
||||
'autocomplete' => true,
|
||||
];
|
||||
|
||||
$tab[] = [
|
||||
'id' => '13',
|
||||
'table' => 'glpi_devicememorytypes',
|
||||
'field' => 'name',
|
||||
'name' => _n('Type', 'Types', 1),
|
||||
'datatype' => 'dropdown'
|
||||
];
|
||||
|
||||
$tab[] = [
|
||||
'id' => '14',
|
||||
'table' => 'glpi_devicememorymodels',
|
||||
'field' => 'name',
|
||||
'name' => _n('Model', 'Models', 1),
|
||||
'datatype' => 'dropdown'
|
||||
];
|
||||
|
||||
return $tab;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @since 0.85
|
||||
* @param $input
|
||||
*
|
||||
* @return number
|
||||
**/
|
||||
function prepareInputForAddOrUpdate($input) {
|
||||
|
||||
foreach (['size_default'] as $field) {
|
||||
if (isset($input[$field]) && !is_numeric($input[$field])) {
|
||||
$input[$field] = 0;
|
||||
}
|
||||
}
|
||||
return $input;
|
||||
}
|
||||
|
||||
|
||||
function prepareInputForAdd($input) {
|
||||
return $this->prepareInputForAddOrUpdate($input);
|
||||
}
|
||||
|
||||
|
||||
function prepareInputForUpdate($input) {
|
||||
return $this->prepareInputForAddOrUpdate($input);
|
||||
}
|
||||
|
||||
|
||||
static function getHTMLTableHeader($itemtype, HTMLTableBase $base,
|
||||
HTMLTableSuperHeader $super = null,
|
||||
HTMLTableHeader $father = null, array $options = []) {
|
||||
|
||||
$column = parent::getHTMLTableHeader($itemtype, $base, $super, $father, $options);
|
||||
|
||||
if ($column == $father) {
|
||||
return $father;
|
||||
}
|
||||
|
||||
switch ($itemtype) {
|
||||
case 'Computer' :
|
||||
Manufacturer::getHTMLTableHeader(__CLASS__, $base, $super, $father, $options);
|
||||
$base->addHeader('devicememory_type', _n('Type', 'Types', 1), $super, $father);
|
||||
$base->addHeader('devicememory_frequency', __('Frequency'), $super, $father);
|
||||
break;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
function getHTMLTableCellForItem(HTMLTableRow $row = null, CommonDBTM $item = null,
|
||||
HTMLTableCell $father = null, array $options = []) {
|
||||
|
||||
$column = parent::getHTMLTableCellForItem($row, $item, $father, $options);
|
||||
|
||||
if ($column == $father) {
|
||||
return $father;
|
||||
}
|
||||
|
||||
switch ($item->getType()) {
|
||||
case 'Computer' :
|
||||
Manufacturer::getHTMLTableCellsForItem($row, $this, null, $options);
|
||||
if ($this->fields["devicememorytypes_id"]) {
|
||||
$row->addCell($row->getHeaderByName('devicememory_type'),
|
||||
Dropdown::getDropdownName("glpi_devicememorytypes",
|
||||
$this->fields["devicememorytypes_id"]),
|
||||
$father);
|
||||
}
|
||||
|
||||
if (!empty($this->fields["frequence"])) {
|
||||
$row->addCell($row->getHeaderByName('devicememory_frequency'),
|
||||
$this->fields["frequence"], $father);
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
function getImportCriteria() {
|
||||
|
||||
return ['designation' => 'equal',
|
||||
'devicememorytypes_id' => 'equal',
|
||||
'manufacturers_id' => 'equal',
|
||||
'frequence' => 'delta:10'];
|
||||
}
|
||||
|
||||
public static function rawSearchOptionsToAdd($class, $main_joinparams) {
|
||||
global $DB;
|
||||
|
||||
$tab = [];
|
||||
|
||||
$tab[] = [
|
||||
'id' => '110',
|
||||
'table' => 'glpi_devicememories',
|
||||
'field' => 'designation',
|
||||
'name' => DeviceMemoryType::getTypeName(1),
|
||||
'forcegroupby' => true,
|
||||
'usehaving' => true,
|
||||
'massiveaction' => false,
|
||||
'datatype' => 'string',
|
||||
'joinparams' => [
|
||||
'beforejoin' => [
|
||||
'table' => 'glpi_items_devicememories',
|
||||
'joinparams' => $main_joinparams
|
||||
]
|
||||
]
|
||||
];
|
||||
|
||||
$tab[] = [
|
||||
'id' => '111',
|
||||
'table' => 'glpi_items_devicememories',
|
||||
'field' => 'size',
|
||||
'unit' => 'auto',
|
||||
'name' => _n('Memory', 'Memories', 1),
|
||||
'forcegroupby' => true,
|
||||
'usehaving' => true,
|
||||
'datatype' => 'number',
|
||||
'width' => 100,
|
||||
'massiveaction' => false,
|
||||
'joinparams' => $main_joinparams,
|
||||
'computation' =>
|
||||
'(SUM(' . $DB->quoteName('TABLE.size') . ') / COUNT(' .
|
||||
$DB->quoteName('TABLE.id') . '))
|
||||
* COUNT(DISTINCT ' . $DB->quoteName('TABLE.id') . ')'
|
||||
];
|
||||
|
||||
return $tab;
|
||||
}
|
||||
|
||||
|
||||
static function getIcon() {
|
||||
return "fas fa-memory";
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user