forked from Wavyzz/dolibarr
Clean code for better extrafields management
This commit is contained in:
@@ -153,7 +153,7 @@ if ($action == "update_extras" && ! empty($permissiontoadd))
|
|||||||
$attributekeylong = 'options_'.$attributekey;
|
$attributekeylong = 'options_'.$attributekey;
|
||||||
$object->array_options['options_'.$attributekey] = GETPOST($attributekeylong,' alpha');
|
$object->array_options['options_'.$attributekey] = GETPOST($attributekeylong,' alpha');
|
||||||
|
|
||||||
$result = $object->updateExtraField($attributekey, empty($triggermodname)?'':$triggermodname, $user);
|
$result = $object->insertExtraFields(empty($triggermodname)?'':$triggermodname, $user);
|
||||||
if ($result > 0)
|
if ($result > 0)
|
||||||
{
|
{
|
||||||
setEventMessages($langs->trans('RecordSaved'), null, 'mesgs');
|
setEventMessages($langs->trans('RecordSaved'), null, 'mesgs');
|
||||||
|
|||||||
@@ -4903,7 +4903,7 @@ abstract class CommonObject
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update an exta field value for the current object.
|
* Update an extra field value for the current object.
|
||||||
* Data to describe values to update are stored into $this->array_options=array('options_codeforfield1'=>'valueforfield1', 'options_codeforfield2'=>'valueforfield2', ...)
|
* Data to describe values to update are stored into $this->array_options=array('options_codeforfield1'=>'valueforfield1', 'options_codeforfield2'=>'valueforfield2', ...)
|
||||||
*
|
*
|
||||||
* @param string $key Key of the extrafield (without starting 'options_')
|
* @param string $key Key of the extrafield (without starting 'options_')
|
||||||
@@ -5054,7 +5054,6 @@ abstract class CommonObject
|
|||||||
if (is_array($val['arrayofkeyval'])) $type='select';
|
if (is_array($val['arrayofkeyval'])) $type='select';
|
||||||
if (preg_match('/^integer:(.*):(.*)/i', $val['type'], $reg)) $type='link';
|
if (preg_match('/^integer:(.*):(.*)/i', $val['type'], $reg)) $type='link';
|
||||||
|
|
||||||
//$elementtype=$this->attribute_elementtype[$key]; // seems to not be used
|
|
||||||
$default=$val['default'];
|
$default=$val['default'];
|
||||||
$computed=$val['computed'];
|
$computed=$val['computed'];
|
||||||
$unique=$val['unique'];
|
$unique=$val['unique'];
|
||||||
@@ -5597,7 +5596,6 @@ abstract class CommonObject
|
|||||||
if (is_array($val['arrayofkeyval'])) $type='select';
|
if (is_array($val['arrayofkeyval'])) $type='select';
|
||||||
if (preg_match('/^integer:(.*):(.*)/i', $val['type'], $reg)) $type='link';
|
if (preg_match('/^integer:(.*):(.*)/i', $val['type'], $reg)) $type='link';
|
||||||
|
|
||||||
//$elementtype=$this->attribute_elementtype[$key]; // seems to not be used
|
|
||||||
$default=$val['default'];
|
$default=$val['default'];
|
||||||
$computed=$val['computed'];
|
$computed=$val['computed'];
|
||||||
$unique=$val['unique'];
|
$unique=$val['unique'];
|
||||||
|
|||||||
@@ -1384,7 +1384,6 @@ class ExtraFields
|
|||||||
|
|
||||||
if (! empty($extrafieldsobjectkey))
|
if (! empty($extrafieldsobjectkey))
|
||||||
{
|
{
|
||||||
$elementtype=$this->attributes[$extrafieldsobjectkey]['elementtype'][$key]; // seems not used
|
|
||||||
$label=$this->attributes[$extrafieldsobjectkey]['label'][$key];
|
$label=$this->attributes[$extrafieldsobjectkey]['label'][$key];
|
||||||
$type=$this->attributes[$extrafieldsobjectkey]['type'][$key];
|
$type=$this->attributes[$extrafieldsobjectkey]['type'][$key];
|
||||||
$size=$this->attributes[$extrafieldsobjectkey]['size'][$key];
|
$size=$this->attributes[$extrafieldsobjectkey]['size'][$key];
|
||||||
@@ -1400,7 +1399,6 @@ class ExtraFields
|
|||||||
}
|
}
|
||||||
else // Old usage
|
else // Old usage
|
||||||
{
|
{
|
||||||
$elementtype=$this->attribute_elementtype[$key]; // seems not used
|
|
||||||
$label=$this->attribute_label[$key];
|
$label=$this->attribute_label[$key];
|
||||||
$type=$this->attribute_type[$key];
|
$type=$this->attribute_type[$key];
|
||||||
$size=$this->attribute_size[$key];
|
$size=$this->attribute_size[$key];
|
||||||
|
|||||||
@@ -1261,12 +1261,12 @@ class FormMail extends Form
|
|||||||
// Create dynamic tags for __PRODUCT_EXTRAFIELD_FIELD__
|
// Create dynamic tags for __PRODUCT_EXTRAFIELD_FIELD__
|
||||||
if (!empty($line->fk_product))
|
if (!empty($line->fk_product))
|
||||||
{
|
{
|
||||||
$extrafields = new ExtraFields($this->db);
|
if (! is_object($extrafields)) $extrafields = new ExtraFields($this->db);
|
||||||
$extralabels = $extrafields->fetch_name_optionals_label('product', true);
|
$extralabels = $extrafields->fetch_name_optionals_label('product', true);
|
||||||
$product = new Product($this->db);
|
$product = new Product($this->db);
|
||||||
$product->fetch($line->fk_product, '', '', 1);
|
$product->fetch($line->fk_product, '', '', 1);
|
||||||
$product->fetch_optionals();
|
$product->fetch_optionals();
|
||||||
foreach ($extrafields->attribute_label as $key => $label) {
|
foreach ($extrafields->attributes[$product->table_element]['label'] as $key => $label) {
|
||||||
$substit_line['__PRODUCT_EXTRAFIELD_' . strtoupper($key) . '__'] = $product->array_options['options_' . $key];
|
$substit_line['__PRODUCT_EXTRAFIELD_' . strtoupper($key) . '__'] = $product->array_options['options_' . $key];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5967,7 +5967,7 @@ function getCommonSubstitutionArray($outputlangs, $onlykey=0, $exclude=null, $ob
|
|||||||
$extrafieldstmp = new ExtraFields($db);
|
$extrafieldstmp = new ExtraFields($db);
|
||||||
$extralabels = $extrafieldstmp->fetch_name_optionals_label($object->table_element, true);
|
$extralabels = $extrafieldstmp->fetch_name_optionals_label($object->table_element, true);
|
||||||
$object->fetch_optionals();
|
$object->fetch_optionals();
|
||||||
foreach ($extrafieldstmp->attribute_label as $key => $label) {
|
foreach ($extrafieldstmp->attributes[$object->table_element]['label'] as $key => $label) {
|
||||||
$substitutionarray['__EXTRAFIELD_' . strtoupper($key) . '__'] = $object->array_options['options_' . $key];
|
$substitutionarray['__EXTRAFIELD_' . strtoupper($key) . '__'] = $object->array_options['options_' . $key];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -143,6 +143,7 @@ $langs->load("modulebuilder");
|
|||||||
<table summary="listofattributes" class="border centpercent">
|
<table summary="listofattributes" class="border centpercent">
|
||||||
|
|
||||||
<?php
|
<?php
|
||||||
|
$label=$extrafields->attributes[$elementtype]['label'][$attrname];
|
||||||
$type=$extrafields->attributes[$elementtype]['type'][$attrname];
|
$type=$extrafields->attributes[$elementtype]['type'][$attrname];
|
||||||
$size=$extrafields->attributes[$elementtype]['size'][$attrname];
|
$size=$extrafields->attributes[$elementtype]['size'][$attrname];
|
||||||
$computed=$extrafields->attributes[$elementtype]['computed'][$attrname];
|
$computed=$extrafields->attributes[$elementtype]['computed'][$attrname];
|
||||||
@@ -175,7 +176,7 @@ elseif (($type== 'sellist') || ($type == 'chkbxlst') || ($type == 'link') || ($t
|
|||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
<!-- Label -->
|
<!-- Label -->
|
||||||
<tr><td class="titlefield fieldrequired"><?php echo $langs->trans("Label"); ?></td><td class="valeur"><input type="text" name="label" size="40" value="<?php echo $extrafields->attribute_label[$attrname]; ?>"></td></tr>
|
<tr><td class="titlefield fieldrequired"><?php echo $langs->trans("Label"); ?></td><td class="valeur"><input type="text" name="label" size="40" value="<?php echo $label; ?>"></td></tr>
|
||||||
<!-- Code -->
|
<!-- Code -->
|
||||||
<tr><td class="fieldrequired"><?php echo $langs->trans("AttributeCode"); ?></td><td class="valeur"><?php echo $attrname; ?></td></tr>
|
<tr><td class="fieldrequired"><?php echo $langs->trans("AttributeCode"); ?></td><td class="valeur"><?php echo $attrname; ?></td></tr>
|
||||||
<!-- Type -->
|
<!-- Type -->
|
||||||
|
|||||||
@@ -7,8 +7,10 @@ if (empty($conf) || ! is_object($conf))
|
|||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (empty($extrafieldsobjectkey) && is_object($object)) $extrafieldsobjectkey=$object->table_element;
|
||||||
|
|
||||||
// Loop to show all columns of extrafields from $obj, $extrafields and $db
|
// Loop to show all columns of extrafields from $obj, $extrafields and $db
|
||||||
if (! empty($extrafieldsobjectkey)) // New method: $extrafieldsobject can be 'societe', 'socpeople', ...
|
if (! empty($extrafieldsobjectkey)) // $extrafieldsobject is the $object->table_element like 'societe', 'socpeople', ...
|
||||||
{
|
{
|
||||||
if (is_array($extrafields->attributes[$extrafieldsobjectkey]['label']) && count($extrafields->attributes[$extrafieldsobjectkey]['label']))
|
if (is_array($extrafields->attributes[$extrafieldsobjectkey]['label']) && count($extrafields->attributes[$extrafieldsobjectkey]['label']))
|
||||||
{
|
{
|
||||||
@@ -42,36 +44,3 @@ if (! empty($extrafieldsobjectkey)) // New method: $extrafieldsobject can be 'so
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else // Old method
|
|
||||||
{
|
|
||||||
if (is_array($extrafields->attribute_label) && count($extrafields->attribute_label))
|
|
||||||
{
|
|
||||||
foreach($extrafields->attribute_label as $key => $val)
|
|
||||||
{
|
|
||||||
if (! empty($arrayfields["ef.".$key]['checked']))
|
|
||||||
{
|
|
||||||
$align=$extrafields->getAlignFlag($key);
|
|
||||||
print '<td';
|
|
||||||
if ($align) print ' align="'.$align.'"';
|
|
||||||
print '>';
|
|
||||||
$tmpkey='options_'.$key;
|
|
||||||
if (in_array($extrafields->attribute_type[$key], array('date', 'datetime', 'timestamp')))
|
|
||||||
{
|
|
||||||
$value = $db->jdate($obj->$tmpkey);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$value = $obj->$tmpkey;
|
|
||||||
}
|
|
||||||
print $extrafields->showOutputField($key, $value, '');
|
|
||||||
print '</td>';
|
|
||||||
if (! $i) $totalarray['nbfield']++;
|
|
||||||
if (! empty($val['isameasure']))
|
|
||||||
{
|
|
||||||
if (! $i) $totalarray['pos'][$totalarray['nbfield']]='ef.'.$tmpkey;
|
|
||||||
$totalarray['val']['ef.'.$tmpkey] += $obj->$tmpkey;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -7,16 +7,18 @@ if (empty($conf) || ! is_object($conf))
|
|||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (empty($extrafieldsobjectkey) && is_object($object)) $extrafieldsobjectkey=$object->table_element;
|
||||||
|
|
||||||
// Loop to show all columns of extrafields for the search title line
|
// Loop to show all columns of extrafields for the search title line
|
||||||
if (is_array($extrafields->attribute_label) && count($extrafields->attribute_label))
|
if (is_array($extrafields->attributes[$extrafieldsobjectkey]['label']) && count($extrafields->attributes[$extrafieldsobjectkey]['label']))
|
||||||
{
|
{
|
||||||
foreach($extrafields->attribute_label as $key => $val)
|
foreach($extrafields->attributes[$extrafieldsobjectkey]['label'] as $key => $val)
|
||||||
{
|
{
|
||||||
if (! empty($arrayfields["ef.".$key]['checked'])) {
|
if (! empty($arrayfields["ef.".$key]['checked'])) {
|
||||||
$align=$extrafields->getAlignFlag($key);
|
$align=$extrafields->getAlignFlag($key);
|
||||||
$typeofextrafield=$extrafields->attribute_type[$key];
|
$typeofextrafield=$extrafields->attributes[$extrafieldsobjectkey]['type'][$key];
|
||||||
print '<td class="liste_titre'.($align?' '.$align:'').'">';
|
print '<td class="liste_titre'.($align?' '.$align:'').'">';
|
||||||
if (in_array($typeofextrafield, array('varchar', 'int', 'double', 'select')) && empty($extrafields->attribute_computed[$key]))
|
if (in_array($typeofextrafield, array('varchar', 'int', 'double', 'select')) && empty($extrafields->attributes[$extrafieldsobjectkey]['computed'][$key]))
|
||||||
{
|
{
|
||||||
$crit=$val;
|
$crit=$val;
|
||||||
$tmpkey=preg_replace('/search_options_/','',$key);
|
$tmpkey=preg_replace('/search_options_/','',$key);
|
||||||
|
|||||||
@@ -7,12 +7,17 @@ if (empty($conf) || ! is_object($conf))
|
|||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (empty($extrafieldsobjectkey) && is_object($object)) $extrafieldsobjectkey=$object->table_element;
|
||||||
|
|
||||||
// Loop to complete the sql search criterias from extrafields
|
// Loop to complete the sql search criterias from extrafields
|
||||||
|
if (! empty($extrafieldsobjectkey)) // $extrafieldsobject is the $object->table_element like 'societe', 'socpeople', ...
|
||||||
|
{
|
||||||
foreach ($search_array_options as $key => $val)
|
foreach ($search_array_options as $key => $val)
|
||||||
{
|
{
|
||||||
$crit=$val;
|
$crit=$val;
|
||||||
$tmpkey=preg_replace('/search_options_/','',$key);
|
$tmpkey=preg_replace('/search_options_/','',$key);
|
||||||
$typ=$extrafields->attribute_type[$tmpkey];
|
$typ=$extrafields->attributes[$extrafieldsobjectkey]['type'][$tmpkey];
|
||||||
|
|
||||||
$mode_search=0;
|
$mode_search=0;
|
||||||
if (in_array($typ, array('int','double','real'))) $mode_search=1; // Search on a numeric
|
if (in_array($typ, array('int','double','real'))) $mode_search=1; // Search on a numeric
|
||||||
if (in_array($typ, array('sellist','link')) && $crit != '0' && $crit != '-1') $mode_search=2; // Search on a foreign key int
|
if (in_array($typ, array('sellist','link')) && $crit != '0' && $crit != '-1') $mode_search=2; // Search on a foreign key int
|
||||||
@@ -22,3 +27,4 @@ foreach ($search_array_options as $key => $val)
|
|||||||
$sql .= natural_search('ef.'.$tmpkey, $crit, $mode_search);
|
$sql .= natural_search('ef.'.$tmpkey, $crit, $mode_search);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
@@ -267,7 +267,7 @@ if ($ok && GETPOST('standard', 'alpha'))
|
|||||||
if (! in_array($code,array_keys($arrayoffieldsfound)))
|
if (! in_array($code,array_keys($arrayoffieldsfound)))
|
||||||
{
|
{
|
||||||
print 'Found field '.$code.' declared into '.MAIN_DB_PREFIX.'extrafields table but not found into desc of table '.$tableextra." -> ";
|
print 'Found field '.$code.' declared into '.MAIN_DB_PREFIX.'extrafields table but not found into desc of table '.$tableextra." -> ";
|
||||||
$type=$extrafields->attribute_type[$code]; $length=$extrafields->attribute_size[$code]; $attribute=''; $default=''; $extra=''; $null='null';
|
$type=$extrafields->attributes[$elementtype]['type'][$code]; $length=$extrafields->attributes[$elementtype]['size'][$code]; $attribute=''; $default=''; $extra=''; $null='null';
|
||||||
|
|
||||||
if ($type=='boolean') {
|
if ($type=='boolean') {
|
||||||
$typedb='int';
|
$typedb='int';
|
||||||
|
|||||||
@@ -205,7 +205,6 @@ $help_url='';
|
|||||||
$title = $langs->trans('ListOf', $langs->transnoentitiesnoconv("MyObjects"));
|
$title = $langs->trans('ListOf', $langs->transnoentitiesnoconv("MyObjects"));
|
||||||
|
|
||||||
|
|
||||||
// TODO : move this SQL request into fetchAll class method
|
|
||||||
// Build and execute select
|
// Build and execute select
|
||||||
// --------------------------------------------------------------------
|
// --------------------------------------------------------------------
|
||||||
$sql = 'SELECT ';
|
$sql = 'SELECT ';
|
||||||
@@ -222,8 +221,8 @@ $reshook=$hookmanager->executeHooks('printFieldListSelect', $parameters, $object
|
|||||||
$sql.=$hookmanager->resPrint;
|
$sql.=$hookmanager->resPrint;
|
||||||
$sql=preg_replace('/, $/','', $sql);
|
$sql=preg_replace('/, $/','', $sql);
|
||||||
$sql.= " FROM ".MAIN_DB_PREFIX.$object->table_element." as t";
|
$sql.= " FROM ".MAIN_DB_PREFIX.$object->table_element." as t";
|
||||||
if (is_array($extrafields->attributes[$object->table_element]['label']) && count($extrafields->attributes[$object->table_element]['label'])) $sql.= " LEFT JOIN ".MAIN_DB_PREFIX."myobject_extrafields as ef on (t.rowid = ef.fk_object)";
|
if (is_array($extrafields->attributes[$object->table_element]['label']) && count($extrafields->attributes[$object->table_element]['label'])) $sql.= " LEFT JOIN ".MAIN_DB_PREFIX.$object->table_element."_extrafields as ef on (t.rowid = ef.fk_object)";
|
||||||
if ($object->ismultientitymanaged == 1) $sql.= " WHERE t.entity IN (".getEntity('myobject').")";
|
if ($object->ismultientitymanaged == 1) $sql.= " WHERE t.entity IN (".getEntity($object->element).")";
|
||||||
else $sql.=" WHERE 1 = 1";
|
else $sql.=" WHERE 1 = 1";
|
||||||
foreach($search as $key => $val)
|
foreach($search as $key => $val)
|
||||||
{
|
{
|
||||||
@@ -252,6 +251,7 @@ if (! empty($extrafields->attributes[$object->table_element]['label'])) {
|
|||||||
$parameters=array();
|
$parameters=array();
|
||||||
$reshook=$hookmanager->executeHooks('printFieldListGroupBy',$parameters); // Note that $action and $object may have been modified by hook
|
$reshook=$hookmanager->executeHooks('printFieldListGroupBy',$parameters); // Note that $action and $object may have been modified by hook
|
||||||
$sql.=$hookmanager->resPrint;
|
$sql.=$hookmanager->resPrint;
|
||||||
|
$sql=preg_replace('/, $/','', $sql);
|
||||||
*/
|
*/
|
||||||
|
|
||||||
$sql.=$db->order($sortfield,$sortorder);
|
$sql.=$db->order($sortfield,$sortorder);
|
||||||
@@ -272,7 +272,6 @@ if (($page * $limit) > $nbtotalofrecords)
|
|||||||
// if total resultset is smaller the limit, no need to do paging.
|
// if total resultset is smaller the limit, no need to do paging.
|
||||||
if (is_numeric($nbtotalofrecords) && $limit > $nbtotalofrecords)
|
if (is_numeric($nbtotalofrecords) && $limit > $nbtotalofrecords)
|
||||||
{
|
{
|
||||||
$resql = $result;
|
|
||||||
$num = $nbtotalofrecords;
|
$num = $nbtotalofrecords;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|||||||
@@ -157,7 +157,7 @@ class PriceParser
|
|||||||
$extrafields = new ExtraFields($this->db);
|
$extrafields = new ExtraFields($this->db);
|
||||||
$extralabels = $extrafields->fetch_name_optionals_label('product', true);
|
$extralabels = $extrafields->fetch_name_optionals_label('product', true);
|
||||||
$product->fetch_optionals();
|
$product->fetch_optionals();
|
||||||
foreach ($extrafields->attribute_label as $key=>$label)
|
foreach ($extrafields->attributes[$product->table_element]['label'] as $key=>$label)
|
||||||
{
|
{
|
||||||
$values["extrafield_".$key] = $product->array_options['options_'.$key];
|
$values["extrafield_".$key] = $product->array_options['options_'.$key];
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -107,7 +107,7 @@ if ($id > 0)
|
|||||||
print $form->showphoto('memberphoto', $object, 64);
|
print $form->showphoto('memberphoto', $object, 64);
|
||||||
print '</td></tr>'."\n";
|
print '</td></tr>'."\n";
|
||||||
}
|
}
|
||||||
// foreach($objecto->attribute_label as $key=>$value){
|
// foreach($extrafields->attributes[$object->table_element]['label'] as $key=>$value){
|
||||||
// print "<tr><td>$value</td><td>".$object->array_options["options_$key"]." </td></tr>\n";
|
// print "<tr><td>$value</td><td>".$object->array_options["options_$key"]." </td></tr>\n";
|
||||||
// }
|
// }
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
<?php
|
<?php
|
||||||
/* Copyright (C) 2013-2016 Jean-François FERRY <hello@librethic.io>
|
/* Copyright (C) 2013-2016 Jean-François FERRY <hello@librethic.io>
|
||||||
* Copyright (C) 2016 Christophe Battarel <christophe@altairis.fr>
|
* Copyright (C) 2016 Christophe Battarel <christophe@altairis.fr>
|
||||||
|
* Copyright (C) 2018 Laurent Destailleur <eldy@users.sourceforge.net>
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* This program is free software; you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License as published by
|
* it under the terms of the GNU General Public License as published by
|
||||||
@@ -76,25 +77,38 @@ if ($id || $track_id || $ref) {
|
|||||||
// Security check
|
// Security check
|
||||||
$result = restrictedArea($user, 'ticketsup', $object->id);
|
$result = restrictedArea($user, 'ticketsup', $object->id);
|
||||||
|
|
||||||
|
$triggermodname = 'TICKETSUP_MODIFY';
|
||||||
|
$permissiontoadd = $user->rights->ticketsup->write;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Actions
|
* Actions
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
if ($cancel)
|
||||||
|
{
|
||||||
|
if (! empty($backtopage))
|
||||||
|
{
|
||||||
|
header("Location: ".$backtopage);
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
$action='';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
$actionobject = new ActionsTicketsup($db);
|
$actionobject = new ActionsTicketsup($db);
|
||||||
$actionobject->doActions($action, $object);
|
$actionobject->doActions($action, $object);
|
||||||
|
|
||||||
if ($action == "update_extras" && $user->rights->ticketsup->write && !GETPOST('cancel','alpha'))
|
// Action to update one extrafield
|
||||||
|
if ($action == "update_extras" && ! empty($permissiontoadd))
|
||||||
{
|
{
|
||||||
$triggermodname = 'TICKETSUP_MODIFY';
|
$object->fetch(GETPOST('id','int'), '', GETPOST('track_id','alpha'));
|
||||||
|
|
||||||
$res = $object->fetch(GETPOST('id','int'), '', GETPOST('track_id','alpha'));
|
|
||||||
$attributekey = GETPOST('attribute','alpha');
|
$attributekey = GETPOST('attribute','alpha');
|
||||||
$attributekeylong = 'options_'.$attributekey;
|
$attributekeylong = 'options_'.$attributekey;
|
||||||
$object->array_options['options_'.$attributekey] = GETPOST($attributekeylong,' alpha');
|
$object->array_options['options_'.$attributekey] = GETPOST($attributekeylong,' alpha');
|
||||||
|
|
||||||
$result = $object->updateExtraField($attributekey, $triggermodname, $user);
|
$result = $object->insertExtraFields(empty($triggermodname)?'':$triggermodname, $user);
|
||||||
if ($result > 0)
|
if ($result > 0)
|
||||||
{
|
{
|
||||||
setEventMessages($langs->trans('RecordSaved'), null, 'mesgs');
|
setEventMessages($langs->trans('RecordSaved'), null, 'mesgs');
|
||||||
|
|||||||
@@ -586,8 +586,8 @@ class Ticketsup extends CommonObject
|
|||||||
$sql .= " t.tms";
|
$sql .= " t.tms";
|
||||||
$sql .= ", type.label as type_label, category.label as category_label, severity.label as severity_label";
|
$sql .= ", type.label as type_label, category.label as category_label, severity.label as severity_label";
|
||||||
// Add fields for extrafields
|
// Add fields for extrafields
|
||||||
foreach ($extrafields->attribute_list as $key => $val) {
|
foreach ($extrafields->attributes[$this->table_element]['label'] as $key => $val) {
|
||||||
$sql .= ($extrafields->attribute_type[$key] != 'separate' ? ",ef." . $key . ' as options_' . $key : '');
|
$sql .= ($extrafields->attributes[$this->table_element]['type'][$key] != 'separate' ? ",ef." . $key . ' as options_' . $key : '');
|
||||||
}
|
}
|
||||||
$sql .= " FROM " . MAIN_DB_PREFIX . "ticketsup as t";
|
$sql .= " FROM " . MAIN_DB_PREFIX . "ticketsup as t";
|
||||||
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . "c_ticketsup_type as type ON type.code=t.type_code";
|
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . "c_ticketsup_type as type ON type.code=t.type_code";
|
||||||
@@ -596,7 +596,7 @@ class Ticketsup extends CommonObject
|
|||||||
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . "societe as s ON s.rowid=t.fk_soc";
|
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . "societe as s ON s.rowid=t.fk_soc";
|
||||||
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . "user as uc ON uc.rowid=t.fk_user_create";
|
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . "user as uc ON uc.rowid=t.fk_user_create";
|
||||||
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . "user as ua ON ua.rowid=t.fk_user_assign";
|
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . "user as ua ON ua.rowid=t.fk_user_assign";
|
||||||
if (is_array($extrafields->attribute_label) && count($extrafields->attribute_label)) {
|
if (is_array($extrafields->attributes[$this->table_element]['label']) && count($extrafields->attributes[$this->table_element]['label'])) {
|
||||||
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . "ticketsup_extrafields as ef on (t.rowid = ef.fk_object)";
|
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . "ticketsup_extrafields as ef on (t.rowid = ef.fk_object)";
|
||||||
}
|
}
|
||||||
if (!$user->rights->societe->client->voir && !$user->socid) {
|
if (!$user->rights->societe->client->voir && !$user->socid) {
|
||||||
@@ -690,8 +690,8 @@ class Ticketsup extends CommonObject
|
|||||||
$line->date_close = $this->db->jdate($obj->date_close);
|
$line->date_close = $this->db->jdate($obj->date_close);
|
||||||
|
|
||||||
// Extra fields
|
// Extra fields
|
||||||
if (is_array($extrafields->attribute_label) && count($extrafields->attribute_label)) {
|
if (is_array($extrafields->attributes[$this->table_element]['label']) && count($extrafields->attributes[$this->table_element]['label'])) {
|
||||||
foreach ($extrafields->attribute_label as $key => $val) {
|
foreach ($extrafields->attributes[$this->table_element]['label'] as $key => $val) {
|
||||||
$tmpkey = 'options_' . $key;
|
$tmpkey = 'options_' . $key;
|
||||||
$line->{$tmpkey} = $obj->$tmpkey;
|
$line->{$tmpkey} = $obj->$tmpkey;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -105,11 +105,12 @@ foreach($object->fields as $key => $val)
|
|||||||
if (! empty($val['visible'])) $arrayfields['t.'.$key]=array('label'=>$val['label'], 'checked'=>(($val['visible']<0)?0:1), 'enabled'=>$val['enabled'], 'position'=>$val['position']);
|
if (! empty($val['visible'])) $arrayfields['t.'.$key]=array('label'=>$val['label'], 'checked'=>(($val['visible']<0)?0:1), 'enabled'=>$val['enabled'], 'position'=>$val['position']);
|
||||||
}
|
}
|
||||||
// Extra fields
|
// Extra fields
|
||||||
if (is_array($extrafields->attribute_label) && count($extrafields->attribute_label))
|
if (is_array($extrafields->attributes[$object->table_element]['label']) && count($extrafields->attributes[$object->table_element]['label']))
|
||||||
{
|
{
|
||||||
foreach($extrafields->attribute_label as $key => $val)
|
foreach($extrafields->attributes[$object->table_element]['label'] as $key => $val)
|
||||||
{
|
{
|
||||||
if (! empty($extrafields->attribute_list[$key])) $arrayfields["ef.".$key]=array('label'=>$extrafields->attribute_label[$key], 'checked'=>(($extrafields->attribute_list[$key]<0)?0:1), 'position'=>$extrafields->attribute_pos[$key], 'enabled'=>(abs($extrafields->attribute_list[$key])!=3 && $extrafields->attribute_perms[$key]));
|
if (! empty($extrafields->attributes[$object->table_element]['list'][$key]))
|
||||||
|
$arrayfields["ef.".$key]=array('label'=>$extrafields->attributes[$object->table_element]['label'][$key], 'checked'=>(($extrafields->attributes[$object->table_element]['list'][$key]<0)?0:1), 'position'=>$extrafields->attributes[$object->table_element]['pos'][$key], 'enabled'=>(abs($extrafields->attributes[$object->table_element]['list'][$key])!=3 && $extrafields->attributes[$object->table_element]['perms'][$key]));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$object->fields = dol_sort_array($object->fields, 'position');
|
$object->fields = dol_sort_array($object->fields, 'position');
|
||||||
@@ -202,7 +203,7 @@ $reshook=$hookmanager->executeHooks('printFieldListSelect', $parameters, $object
|
|||||||
$sql.=$hookmanager->resPrint;
|
$sql.=$hookmanager->resPrint;
|
||||||
$sql=preg_replace('/, $/','', $sql);
|
$sql=preg_replace('/, $/','', $sql);
|
||||||
$sql.= " FROM ".MAIN_DB_PREFIX.$object->table_element." as t";
|
$sql.= " FROM ".MAIN_DB_PREFIX.$object->table_element." as t";
|
||||||
if (is_array($extrafields->attribute_label) && count($extrafields->attribute_label)) $sql.= " LEFT JOIN ".MAIN_DB_PREFIX."ticketsup_extrafields as ef on (t.rowid = ef.fk_object)";
|
if (is_array($extrafields->attributes[$object->table_element]['label']) && count($extrafields->attributes[$object->table_element]['label'])) $sql.= " LEFT JOIN ".MAIN_DB_PREFIX."ticketsup_extrafields as ef on (t.rowid = ef.fk_object)";
|
||||||
if ($object->ismultientitymanaged == 1) $sql.= " WHERE t.entity IN (".getEntity('ticketsup').")";
|
if ($object->ismultientitymanaged == 1) $sql.= " WHERE t.entity IN (".getEntity('ticketsup').")";
|
||||||
else $sql.=" WHERE 1 = 1";
|
else $sql.=" WHERE 1 = 1";
|
||||||
foreach($search as $key => $val)
|
foreach($search as $key => $val)
|
||||||
@@ -237,7 +238,8 @@ $sql.=$hookmanager->resPrint;
|
|||||||
$sql.='t.'.$key.', ';
|
$sql.='t.'.$key.', ';
|
||||||
}
|
}
|
||||||
// Add fields from extrafields
|
// Add fields from extrafields
|
||||||
foreach ($extrafields->attribute_label as $key => $val) $sql.=($extrafields->attribute_type[$key] != 'separate' ? ",ef.".$key : '');
|
if (! empty($extrafields->attributes[$object->table_element]['label'])) {
|
||||||
|
foreach ($extrafields->attributes[$object->table_element]['label'] as $key => $val) $sql.=($extrafields->attributes[$object->table_element]['type'][$key] != 'separate' ? "ef.".$key.', ' : '');
|
||||||
// Add where from hooks
|
// Add where from hooks
|
||||||
$parameters=array();
|
$parameters=array();
|
||||||
$reshook=$hookmanager->executeHooks('printFieldListGroupBy',$parameters); // Note that $action and $object may have been modified by hook
|
$reshook=$hookmanager->executeHooks('printFieldListGroupBy',$parameters); // Note that $action and $object may have been modified by hook
|
||||||
@@ -535,7 +537,6 @@ print '<td class="liste_titre" align="right">';
|
|||||||
$searchpicto=$form->showFilterButtons();
|
$searchpicto=$form->showFilterButtons();
|
||||||
print $searchpicto;
|
print $searchpicto;
|
||||||
print '</td>';
|
print '</td>';
|
||||||
|
|
||||||
print '</tr>'."\n";
|
print '</tr>'."\n";
|
||||||
|
|
||||||
|
|
||||||
@@ -562,13 +563,12 @@ print '</tr>'."\n";
|
|||||||
|
|
||||||
// Detect if we need a fetch on each output line
|
// Detect if we need a fetch on each output line
|
||||||
$needToFetchEachLine=0;
|
$needToFetchEachLine=0;
|
||||||
foreach ($extrafields->attribute_computed as $key => $val)
|
foreach ($extrafields->attributes[$object->table_element]['computed'] as $key => $val)
|
||||||
{
|
{
|
||||||
if (preg_match('/\$object/',$val)) $needToFetchEachLine++; // There is at least one compute field that use $object
|
if (preg_match('/\$object/',$val)) $needToFetchEachLine++; // There is at least one compute field that use $object
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Loop on record
|
// Loop on record
|
||||||
// --------------------------------------------------------------------
|
// --------------------------------------------------------------------
|
||||||
$i=0;
|
$i=0;
|
||||||
@@ -672,8 +672,6 @@ print '</div>'."\n";
|
|||||||
|
|
||||||
print '</form>'."\n";
|
print '</form>'."\n";
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (in_array('builddoc',$arrayofmassactions) && ($nbtotalofrecords === '' || $nbtotalofrecords))
|
if (in_array('builddoc',$arrayofmassactions) && ($nbtotalofrecords === '' || $nbtotalofrecords))
|
||||||
{
|
{
|
||||||
$hidegeneratedfilelistifempty=1;
|
$hidegeneratedfilelistifempty=1;
|
||||||
@@ -694,5 +692,5 @@ if (in_array('builddoc',$arrayofmassactions) && ($nbtotalofrecords === '' || $nb
|
|||||||
}
|
}
|
||||||
|
|
||||||
// End of page
|
// End of page
|
||||||
llxFooter('');
|
llxFooter();
|
||||||
$db->close();
|
$db->close();
|
||||||
|
|||||||
Reference in New Issue
Block a user