39require_once DOL_DOCUMENT_ROOT.
'/core/class/commonobject.class.php';
40require_once DOL_DOCUMENT_ROOT.
'/product/class/product.class.php';
41require_once DOL_DOCUMENT_ROOT.
'/ticket/class/ticket.class.php';
42require_once DOL_DOCUMENT_ROOT.
'/fourn/class/fournisseur.class.php';
43require_once DOL_DOCUMENT_ROOT.
'/contact/class/contact.class.php';
44require_once DOL_DOCUMENT_ROOT.
'/knowledgemanagement/class/knowledgerecord.class.php';
53 const TYPE_PRODUCT =
'product';
54 const TYPE_SUPPLIER =
'supplier';
55 const TYPE_CUSTOMER =
'customer';
56 const TYPE_MEMBER =
'member';
57 const TYPE_CONTACT =
'contact';
58 const TYPE_USER =
'user';
59 const TYPE_PROJECT =
'project';
60 const TYPE_ACCOUNT =
'bank_account';
61 const TYPE_BANK_LINE =
'bank_line';
62 const TYPE_WAREHOUSE =
'warehouse';
63 const TYPE_ACTIONCOMM =
'actioncomm';
64 const TYPE_WEBSITE_PAGE =
'website_page';
65 const TYPE_TICKET =
'ticket';
66 const TYPE_KNOWLEDGEMANAGEMENT =
'knowledgemanagement';
67 const TYPE_FICHINTER =
'fichinter';
68 const TYPE_ORDER =
'order';
69 const TYPE_INVOICE =
'invoice';
70 const TYPE_SUPPLIER_ORDER =
'supplier_order';
71 const TYPE_SUPPLIER_INVOICE =
'supplier_invoice';
72 const TYPE_SUPPLIER_PROPOSAL =
'supplier_proposal';
73 const TYPE_PROPOSAL =
'propal';
74 const TYPE_PROJECT_TASK =
'project_task';
81 public $picto =
'category';
87 public $MAP_ID = array(
100 'website_page' => 11,
102 'knowledgemanagement' => 13,
106 'supplier_order' => 20,
107 'supplier_invoice' => 21,
108 'supplier_proposal' => 22,
110 'project_task' => 24,
149 public $MAP_CAT_FK = array(
152 'contact' =>
'socpeople',
153 'bank_account' =>
'account',
159 public $MAP_CAT_TABLE = array(
160 'customer' =>
'societe',
161 'supplier' =>
'fournisseur',
162 'bank_account' =>
'account',
168 public $MAP_OBJ_CLASS = array(
169 'product' =>
'Product',
170 'service' =>
'Product',
171 'customer' =>
'Societe',
172 'supplier' =>
'Fournisseur',
173 'member' =>
'Adherent',
174 'contact' =>
'Contact',
176 'account' =>
'Account',
177 'bank_account' =>
'Account',
178 'project' =>
'Project',
179 'warehouse' =>
'Entrepot',
180 'actioncomm' =>
'ActionComm',
181 'website_page' =>
'WebsitePage',
182 'ticket' =>
'Ticket',
183 'knowledgemanagement' =>
'KnowledgeRecord',
184 'fichinter' =>
'Fichinter',
185 'order' =>
'Commande',
186 'invoice' =>
'Facture',
187 'supplier_order' =>
'CommandeFournisseur',
188 'supplier_invoice' =>
'FactureFournisseur',
189 'supplier_proposal' =>
'SupplierProposal',
190 'propal' =>
'Propal',
191 'project_task' =>
'Task',
198 public static $MAP_TYPE_TITLE_AREA = array(
199 'product' =>
'Products',
200 'service' =>
'Services',
201 'customer' =>
'ProspectsOrCustomers',
202 'supplier' =>
'Suppliers',
203 'member' =>
'Members',
204 'contact' =>
'Contacts',
206 'account' =>
'Accounts',
207 'bank_account' =>
'BankAccounts',
208 'bank_line' =>
'BankTransactions',
209 'project' =>
'Projects',
210 'warehouse' =>
'Warehouse',
211 'actioncomm' =>
'AgendaEvents',
212 'website_page' =>
'WebsitePages',
213 'ticket' =>
'Tickets',
214 'knowledgemanagement' =>
'KnowledgeRecords',
215 'fichinter' =>
'Interventions',
217 'invoice' =>
'Invoices',
218 'supplier_order' =>
'SuppliersOrders',
219 'supplier_invoice' =>
'SuppliersInvoices',
220 'propal' =>
'Proposals',
221 'supplier_proposal' =>
'SupplierProposals',
222 'project_task' =>
'Tasks',
230 public $MAP_OBJ_TABLE = array(
231 'customer' =>
'societe',
232 'supplier' =>
'societe',
233 'member' =>
'adherent',
234 'contact' =>
'socpeople',
235 'account' =>
'bank_account',
236 'project' =>
'projet',
237 'warehouse' =>
'entrepot',
238 'knowledgemanagement' =>
'knowledgemanagement_knowledgerecord',
239 'fichinter' =>
'fichinter',
240 'order' =>
'commande',
241 'invoice' =>
'facture',
242 'supplier_order' =>
'commande_fournisseur',
243 'supplier_invoice' =>
'facture_fourn',
244 'project_task' =>
'projet_task',
251 public $element =
'category';
256 public $table_element =
'categorie';
321 public $cats = array();
326 public $motherof = array();
331 public $childs = array();
336 public $multilangs = array();
373 'rowid' => array(
'type' =>
'integer',
'label' =>
'TechnicalID',
'enabled' => 1,
'position' => 10,
'notnull' => 1,
'visible' => 0,),
374 'entity' => array(
'type' =>
'integer',
'label' =>
'Entity',
'enabled' => 1,
'visible' => 0,
'default' =>
'1',
'notnull' => 1,
'index' => 1,
'position' => 5),
375 'fk_parent' => array(
'type' =>
'integer',
'label' =>
'ParentCategory',
'enabled' => 1,
'position' => 20,
'notnull' => 1,
'visible' => 0,
'css' =>
'maxwidth500 widthcentpercentminusxx',),
376 'label' => array(
'type' =>
'varchar(180)',
'label' =>
'Ref',
'enabled' => 1,
'position' => 25,
'notnull' => 1,
'visible' => 1,
'alwayseditable' => 1,
'css' =>
'minwidth300',
'cssview' =>
'wordbreak',
'csslist' =>
'tdoverflowmax150',
'showoncombobox' => 1),
377 'ref_ext' => array(
'type' =>
'varchar(255)',
'label' =>
'RefExt',
'enabled' => 1,
'position' => 30,
'notnull' => 0,
'visible' => 0,
'alwayseditable' => 1,),
378 'type' => array(
'type' =>
'integer',
'label' =>
'Type',
'enabled' => 1,
'position' => 35,
'notnull' => 1,
'visible' => 0,
'alwayseditable' => 1,),
379 'description' => array(
'type' =>
'text',
'label' =>
'Description',
'enabled' => 1,
'position' => 40,
'notnull' => 0,
'visible' => 1,
'alwayseditable' => 1,),
380 'color' => array(
'type' =>
'varchar(8)',
'label' =>
'Color',
'enabled' => 1,
'position' => 45,
'notnull' => 0,
'visible' => 1,
'alwayseditable' => 1,),
381 'position' => array(
'type' =>
'integer',
'label' =>
'Position',
'enabled' => 1,
'position' => 50,
'notnull' => 0,
'visible' => -1,
'alwayseditable' => 1,),
382 'fk_soc' => array(
'type' =>
'integer:Societe:societe/class/societe.class.php',
'label' =>
'ThirdParty',
'picto' =>
'company',
'enabled' => 1,
'position' => 55,
'notnull' => 0,
'visible' => 0,
'alwayseditable' => 1,
'css' =>
'maxwidth500 widthcentpercentminusxx',
'csslist' =>
'tdoverflowmax150',),
383 'visible' => array(
'type' =>
'integer',
'label' =>
'Visible',
'enabled' => 1,
'position' => 60,
'notnull' => 1,
'visible' => 0,
'alwayseditable' => 1,),
384 'import_key' => array(
'type' =>
'varchar(14)',
'label' =>
'ImportId',
'enabled' => 1,
'position' => 900,
'notnull' => 0,
'visible' => -2,
'alwayseditable' => 1,),
385 'date_creation' => array(
'type' =>
'datetime',
'label' =>
'DateCreation',
'enabled' => 1,
'position' => 70,
'notnull' => 0,
'visible' => -1,
'alwayseditable' => 1,),
386 'tms' => array(
'type' =>
'timestamp',
'label' =>
'DateModification',
'enabled' => 1,
'position' => 75,
'notnull' => 1,
'visible' => -1,
'alwayseditable' => 1,),
387 'fk_user_creat' => array(
'type' =>
'integer:User:user/class/user.class.php',
'label' =>
'UserAuthor',
'enabled' => 1,
'position' => 80,
'notnull' => 0,
'visible' => -2,
'alwayseditable' => 1,
'css' =>
'maxwidth500 widthcentpercentminusxx',
'csslist' =>
'tdoverflowmax150',),
388 'fk_user_modif' => array(
'type' =>
'integer:User:user/class/user.class.php',
'label' =>
'UserModif',
'enabled' => 1,
'position' => 85,
'notnull' => -1,
'visible' => -2,
'alwayseditable' => 1,
'css' =>
'maxwidth500 widthcentpercentminusxx',
'csslist' =>
'tdoverflowmax150',),
396 public function __construct($db)
402 $this->ismultientitymanaged = 1;
403 $this->isextrafieldmanaged = 1;
405 if (is_object($hookmanager)) {
406 $hookmanager->initHooks(array(
'category'));
407 $parameters = array();
408 $reshook = $hookmanager->executeHooks(
'constructCategory', $parameters, $this);
409 if ($reshook >= 0 && !empty($hookmanager->resArray)) {
410 foreach ($hookmanager->resArray as $mapList) {
412 $mapId = $mapList[
'id'];
413 $mapCode = $mapList[
'code'];
415 $this->MAP_ID[$mapCode] = $mapId;
416 $this->MAP_CAT_FK[$mapCode] = isset($mapList[
'cat_fk']) ? $mapList[
'cat_fk'] :
null;
417 $this->MAP_CAT_TABLE[$mapCode] = isset($mapList[
'cat_table']) ? $mapList[
'cat_table'] :
null;
418 $this->MAP_OBJ_CLASS[$mapCode] = $mapList[
'obj_class'];
419 $this->MAP_OBJ_TABLE[$mapCode] = $mapList[
'obj_table'];
420 self::$MAP_TYPE_TITLE_AREA[$mapCode] = isset($mapList[
'label']) ? $mapList[
'label'] :
null;
435 foreach ($this->MAP_ID as $mapCode => $mapId) {
439 'cat_fk' => (empty($this->MAP_CAT_FK[$mapCode]) ? $mapCode : $this->MAP_CAT_FK[$mapCode]),
440 'cat_table' => (empty($this->MAP_CAT_TABLE[$mapCode]) ? $mapCode : $this->MAP_CAT_TABLE[$mapCode]),
441 'obj_class' => (empty($this->MAP_OBJ_CLASS[$mapCode]) ? $mapCode : $this->MAP_OBJ_CLASS[$mapCode]),
442 'obj_table' => (empty($this->MAP_OBJ_TABLE[$mapCode]) ? $mapCode : $this->MAP_OBJ_TABLE[$mapCode]),
456 return $this->MAP_ID;
468 public function fetch($id, $label =
'', $type =
null, $ref_ext =
'')
471 if (empty($id) && empty($label) && empty($ref_ext)) {
472 $this->error =
"No category to search for";
475 if (!is_null($type) && !is_numeric($type)) {
476 $type = $this->MAP_ID[$type];
479 $sql =
"SELECT rowid, fk_parent, entity, label, description, color, position, fk_soc, visible, type, ref_ext";
480 $sql .=
", date_creation, tms, fk_user_creat, fk_user_modif, import_key";
481 $sql .=
" FROM ".MAIN_DB_PREFIX.
"categorie";
483 $sql .=
" WHERE rowid = ".((int) $id);
484 } elseif (!empty($ref_ext)) {
485 $sql .=
" WHERE ref_ext LIKE '".$this->db->escape($ref_ext).
"'";
487 $sql .=
" WHERE label = '".$this->db->escape($label).
"' AND entity IN (".
getEntity(
'category').
")";
488 if (!is_null($type)) {
489 $sql .=
" AND type = ".((int) $type);
493 dol_syslog(get_class($this).
"::fetch", LOG_DEBUG);
494 $resql = $this->db->query($sql);
496 if ($this->db->num_rows($resql) > 0 && $res = $this->db->fetch_array($resql)) {
497 $this->
id = $res[
'rowid'];
499 $this->fk_parent = (int) $res[
'fk_parent'];
500 $this->label = $res[
'label'];
502 $this->color = $res[
'color'];
504 $this->socid = (int) $res[
'fk_soc'];
505 $this->visible = (int) $res[
'visible'];
506 $this->
type = $res[
'type'];
507 $this->ref_ext = $res[
'ref_ext'];
508 $this->entity = (int) $res[
'entity'];
509 $this->date_creation = $this->db->jdate($res[
'date_creation']);
510 $this->date_modification = $this->db->jdate($res[
'tms']);
511 $this->user_creation_id = (int) $res[
'fk_user_creat'];
512 $this->user_modification_id = (int) $res[
'fk_user_modif'];
513 $this->import_key = $res[
'import_key'];
519 $this->db->free($resql);
528 $this->error =
"No category found";
533 $this->error = $this->db->lasterror;
534 $this->errors[] = $this->db->lasterror;
549 public function create($user, $notrigger = 0)
551 global
$conf, $langs;
552 $langs->load(
'categories');
556 if (!is_numeric($type)) {
557 $type = $this->MAP_ID[$type];
562 dol_syslog(get_class($this).
'::create', LOG_DEBUG);
565 $this->label = trim($this->label);
567 $this->color = trim($this->color);
569 if (isset($this->import_key)) {
570 $this->import_key = trim($this->import_key);
572 $this->ref_ext = trim($this->ref_ext);
573 if (empty($this->visible)) {
576 $this->fk_parent = ($this->fk_parent !=
"" ? intval($this->fk_parent) : 0);
579 $this->error = $langs->trans(
"ImpossibleAddCat", $this->label);
580 $this->error .=
" : ".$langs->trans(
"CategoryExistsAtSameLevel");
587 $sql =
"INSERT INTO ".MAIN_DB_PREFIX.
"categorie (";
588 $sql .=
"fk_parent,";
590 $sql .=
" description,";
592 $sql .=
" position,";
598 $sql .=
" import_key,";
601 $sql .=
" date_creation,";
602 $sql .=
" fk_user_creat";
603 $sql .=
") VALUES (";
604 $sql .= (int) $this->fk_parent.
",";
605 $sql .=
"'".$this->db->escape($this->label).
"', ";
606 $sql .=
"'".$this->db->escape($this->
description).
"', ";
607 $sql .=
"'".$this->db->escape($this->color).
"', ";
610 $sql .= ($this->socid > 0 ? $this->socid :
'null').
", ";
612 $sql .=
"'".$this->db->escape((
string) $this->visible).
"', ";
613 $sql .= ((int) $type).
", ";
614 $sql .= (!empty($this->import_key) ?
"'".$this->db->escape($this->import_key).
"'" :
'null').
", ";
615 $sql .= (!empty($this->ref_ext) ?
"'".$this->db->escape($this->ref_ext).
"'" :
'null').
", ";
616 $sql .= (int)
$conf->entity.
", ";
617 $sql .=
"'".$this->db->idate($now).
"', ";
618 $sql .= (int) $user->id;
621 $res = $this->db->query($sql);
623 $id = $this->db->last_insert_id(MAIN_DB_PREFIX.
"categorie");
636 if (!$error && !$notrigger) {
638 $result = $this->call_trigger(
'CATEGORY_CREATE', $user);
649 $this->db->rollback();
653 $this->db->rollback();
657 $this->error = $this->db->error();
658 $this->db->rollback();
679 $this->label = trim($this->label);
681 $this->ref_ext = trim($this->ref_ext);
682 $this->fk_parent = ($this->fk_parent !=
"" ? intval($this->fk_parent) : 0);
683 $this->visible = ($this->visible !=
"" ? intval($this->visible) : 0);
685 if ($this->fk_parent > 0 && $this->fk_parent == $this->
id) {
686 $langs->load(
'categories');
687 $this->error = $langs->trans(
"ErrorCategoryCannotBeItsOwnParent");
693 $this->error = $langs->trans(
"ImpossibleUpdateCat");
694 $this->error .=
" : ".$langs->trans(
"CategoryExistsAtSameLevel");
700 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"categorie";
701 $sql .=
" SET label = '".$this->db->escape($this->label).
"',";
702 $sql .=
" description = '".$this->db->escape($this->
description).
"',";
703 $sql .=
" ref_ext = '".$this->db->escape($this->ref_ext).
"',";
704 $sql .=
" color = '".$this->db->escape($this->color).
"'";
705 $sql .=
", position = ".(int) $this->
position;
707 $sql .=
", fk_soc = ".($this->socid > 0 ? $this->socid :
'null');
709 $sql .=
", visible = ".(int) $this->visible;
710 $sql .=
", fk_parent = ".(int) $this->fk_parent;
711 $sql .=
", fk_user_modif = ".(int) $user->id;
712 $sql .=
" WHERE rowid = ".((int) $this->
id);
714 dol_syslog(get_class($this).
"::update", LOG_DEBUG);
715 if ($this->db->query($sql)) {
719 $this->db->rollback();
732 if (!$error && !$notrigger) {
734 $result = $this->call_trigger(
'CATEGORY_MODIFY', $user);
745 $this->db->rollback();
749 $this->db->rollback();
762 public function delete($user, $notrigger = 0)
767 $this->fk_parent = ($this->fk_parent !=
"" ? intval($this->fk_parent) : 0);
775 $result = $this->call_trigger(
'CATEGORY_DELETE', $user);
784 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"categorie";
785 $sql .=
" SET fk_parent = ".((int) $this->fk_parent);
786 $sql .=
" WHERE fk_parent = ".((int) $this->
id);
788 if (!$this->db->query($sql)) {
789 $this->error = $this->db->lasterror();
794 $arraydelete = array(
795 'categorie_account' =>
'fk_categorie',
796 'categorie_actioncomm' =>
'fk_categorie',
797 'categorie_contact' =>
'fk_categorie',
798 'categorie_fournisseur' =>
'fk_categorie',
799 'categorie_knowledgemanagement' => array(
'field' =>
'fk_categorie',
'enabled' =>
isModEnabled(
'knowledgemanagement')),
800 'categorie_fichinter' => array(
'field' =>
'fk_categorie',
'enabled' =>
false ),
801 'categorie_member' =>
'fk_categorie',
802 'categorie_user' =>
'fk_categorie',
803 'categorie_product' =>
'fk_categorie',
804 'categorie_project' =>
'fk_categorie',
805 'categorie_project_task' => array(
'field' =>
'fk_categorie',
'enabled' =>
isModEnabled(
'project')),
806 'categorie_societe' =>
'fk_categorie',
807 'categorie_ticket' => array(
'field' =>
'fk_categorie',
'enabled' =>
isModEnabled(
'ticket')),
808 'categorie_warehouse' => array(
'field' =>
'fk_categorie',
'enabled' =>
isModEnabled(
'stock')),
809 'categorie_website_page' => array(
'field' =>
'fk_categorie',
'enabled' =>
isModEnabled(
'website')),
810 'category_bankline' =>
'fk_categ',
811 'categorie_lang' =>
'fk_category',
812 'categorie' =>
'rowid',
814 foreach ($arraydelete as $key => $value) {
815 $sanitizedvalue = $value;
816 if (is_array($value)) {
817 if (empty($value[
'enabled'])) {
820 $sanitizedvalue = $value[
'field'];
823 $sql =
"DELETE FROM ".$this->db->sanitize(MAIN_DB_PREFIX.$key);
824 $sql .=
" WHERE ".$this->db->sanitize($sanitizedvalue).
" = ".((int) $this->
id);
825 if (!$this->db->query($sql)) {
826 $this->errors[] = $this->db->lasterror();
827 dol_syslog(
"Error sql=".$sql.
" ".$this->error, LOG_ERR);
837 dol_syslog(get_class($this).
"::delete erreur ".$this->error, LOG_ERR);
845 $this->db->rollback();
866 if ($this->
id == -1) {
871 $type = $obj->element;
874 dol_syslog(get_class($this).
'::add_type', LOG_DEBUG);
878 $sql =
"INSERT INTO ".MAIN_DB_PREFIX.
"categorie_".(empty($this->MAP_CAT_TABLE[$type]) ? $type : $this->MAP_CAT_TABLE[$type]);
879 $sql .=
" (fk_categorie, fk_".(empty($this->MAP_CAT_FK[$type]) ? $type : $this->MAP_CAT_FK[$type]).
")";
880 $sql .=
" VALUES (".((int) $this->
id).
", ".((int) $obj->id).
")";
882 if ($this->db->query($sql)) {
884 $sql =
'SELECT fk_parent FROM '.MAIN_DB_PREFIX.
'categorie';
885 $sql .=
" WHERE rowid = ".((int) $this->
id);
887 dol_syslog(get_class($this).
"::add_type", LOG_DEBUG);
888 $resql = $this->db->query($sql);
890 if ($this->db->num_rows($resql) > 0) {
891 $objparent = $this->db->fetch_object($resql);
893 if (!empty($objparent->fk_parent)) {
895 $cat->id = $objparent->fk_parent;
896 if (!$cat->containsObject($type, $obj->id)) {
897 $result = $cat->add_type($obj, $type);
899 $this->error = $cat->error;
907 $this->error = $this->db->lasterror();
911 $this->db->rollback();
917 $this->context = array(
'linkto' => $obj);
918 $result = $this->call_trigger(
'CATEGORY_MODIFY', $user);
928 $this->db->rollback();
932 $this->db->rollback();
933 if ($this->db->lasterrno() ==
'DB_ERROR_RECORD_ALREADY_EXISTS') {
934 $this->error = $this->db->lasterrno();
937 $this->error = $this->db->lasterror();
960 if ($type ==
'societe') {
962 dol_syslog(get_class($this).
"::del_type(): type 'societe' is deprecated, please use 'customer' instead", LOG_WARNING);
963 } elseif ($type ==
'fournisseur') {
965 dol_syslog(get_class($this).
"::del_type(): type 'fournisseur' is deprecated, please use 'supplier' instead", LOG_WARNING);
970 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.
"categorie_".(empty($this->MAP_CAT_TABLE[$type]) ? $type : $this->MAP_CAT_TABLE[$type]);
971 $sql .=
" WHERE fk_categorie = ".((int) $this->
id);
972 $sql .=
" AND fk_".(empty($this->MAP_CAT_FK[$type]) ? $type : $this->MAP_CAT_FK[$type]).
" = ".((
int) $obj->id);
974 dol_syslog(get_class($this).
'::del_type', LOG_DEBUG);
975 if ($this->db->query($sql)) {
977 $this->context = array(
'unlinkoff' => $obj);
978 $result = $this->call_trigger(
'CATEGORY_MODIFY', $user);
988 $this->db->rollback();
992 $this->db->rollback();
993 $this->error = $this->db->lasterror();
1016 public function getObjectsInCateg($type, $onlyids = 0, $limit = 0, $offset = 0, $sortfield =
'', $sortorder =
'ASC', $filter =
'', $filtermode =
'AND', $filterlang =
'')
1020 if (empty($onlyids)) {
1021 dol_syslog(
"getObjectsInCateg: This method used with parameter onlyids=0 is deprecated. Try by using instead getListForItem().", LOG_WARNING);
1026 $classnameforobj = $this->MAP_OBJ_CLASS[$type];
1027 if (!empty($classnameforobj) && class_exists($classnameforobj)) {
1028 $tmpobj =
new $classnameforobj($this->db);
1031 $sql =
"SELECT c.fk_".(empty($this->MAP_CAT_FK[$type]) ? $type : $this->MAP_CAT_FK[$type]).
" as fk_object";
1032 $sql .=
" FROM ".MAIN_DB_PREFIX.
"categorie_".(empty($this->MAP_CAT_TABLE[$type]) ? $type : $this->MAP_CAT_TABLE[$type]).
" as c";
1033 $sql .=
", ".MAIN_DB_PREFIX.(empty($this->MAP_OBJ_TABLE[$type]) ? $type : $this->MAP_OBJ_TABLE[$type]).
" as o";
1034 if (!empty($filterlang)) {
1035 $sql .=
", ".MAIN_DB_PREFIX.(empty($this->MAP_OBJ_TABLE[$type]) ? $type : $this->MAP_OBJ_TABLE[$type]).
"_lang as ol";
1037 $sql .=
" WHERE o.entity IN (".getEntity($tmpobj->element).
")";
1038 $sql .=
" AND c.fk_categorie = ".((int) $this->
id);
1040 if ((array_key_exists($type, $this->MAP_OBJ_TABLE) && $this->MAP_OBJ_TABLE[$type] ==
"actioncomm") || $type ==
"actioncomm") {
1041 $sql .=
" AND c.fk_".(empty($this->MAP_CAT_FK[$type]) ? $type : $this->MAP_CAT_FK[$type]).
" = o.id";
1043 $sql .=
" AND c.fk_".(empty($this->MAP_CAT_FK[$type]) ? $type : $this->MAP_CAT_FK[$type]).
" = o.rowid";
1045 if (!empty($filterlang)) {
1046 $sql .=
" AND ol.fk_".(empty($this->MAP_OBJ_TABLE[$type]) ? $type : $this->MAP_OBJ_TABLE[$type]).
" = o.rowid";
1047 $sql .=
" AND ol.lang = '".$this->db->escape($filterlang).
"'";
1050 if (($type ==
'customer' || $type ==
'supplier') && $user->socid > 0) {
1051 $sql .=
" AND o.rowid = ".((int) $user->socid);
1055 $sql .= forgeSQLFromUniversalSearchCriteria($filter, $errormessage);
1056 if ($errormessage) {
1057 $this->errors[] = $errormessage;
1058 dol_syslog(__METHOD__.
' '.implode(
',', $this->errors), LOG_ERR);
1062 $sql .= $this->db->order($sortfield, $sortorder);
1063 if ($limit > 0 || $offset > 0) {
1064 $sql .= $this->db->plimit($limit + 1, $offset);
1067 dol_syslog(get_class($this).
"::getObjectsInCateg", LOG_DEBUG);
1069 $resql = $this->db->query($sql);
1071 while ($rec = $this->db->fetch_array($resql)) {
1073 $objs[] = $rec[
'fk_object'];
1075 $tmpobj =
new $classnameforobj($this->db);
1076 $tmpobj->fetch($rec[
'fk_object']);
1078 if ($tmpobj->id > 0) {
1084 $this->error = $this->db->error().
' sql='.$sql;
1102 $sql =
"SELECT COUNT(*) as nb FROM ".MAIN_DB_PREFIX.
"categorie_".(empty($this->MAP_CAT_TABLE[$type]) ? $type : $this->MAP_CAT_TABLE[$type]);
1103 $sql .=
" WHERE fk_categorie = ".((int) $this->
id).
" AND fk_".(empty($this->MAP_CAT_FK[$type]) ? $type : $this->MAP_CAT_FK[$type]).
" = ".((
int) $object_id);
1105 dol_syslog(get_class($this).
"::containsObject", LOG_DEBUG);
1107 $resql = $this->db->query($sql);
1109 return $this->db->fetch_object($resql)->nb;
1111 $this->error = $this->db->error();
1128 public function getListForItem($id, $type =
'customer', $sortfield =
"s.rowid", $sortorder =
'ASC', $limit = 0, $page = 0)
1130 $categories = array();
1135 $subcol_name =
"fk_".$type;
1136 if ($type ==
"customer") {
1137 $sub_type =
"societe";
1138 $subcol_name =
"fk_soc";
1140 if ($type ==
"supplier") {
1141 $sub_type =
"fournisseur";
1142 $subcol_name =
"fk_soc";
1144 if ($type ==
"contact") {
1145 $subcol_name =
"fk_socpeople";
1148 $idoftype = (int) (array_key_exists($type, $this->MAP_ID) ? $this->MAP_ID[$type] : -1);
1150 $sql =
"SELECT s.rowid";
1152 $sql .=
" FROM ".MAIN_DB_PREFIX.
"categorie as s, ".MAIN_DB_PREFIX.
"categorie_".$this->db->sanitize($sub_type).
" as sub";
1153 $sql .=
' WHERE s.entity IN ('.getEntity(
'category').
')';
1154 $sql .=
' AND s.type = '.((int) $idoftype);
1155 $sql .=
' AND s.rowid = sub.fk_categorie';
1156 $sql .=
" AND sub.".$this->db->sanitize($subcol_name).
" = ".((int) $id);
1159 $nbtotalofrecords =
'';
1161 $sqlforcount = preg_replace(
'/^'.preg_quote($sqlfields,
'/').
'/',
'SELECT COUNT(*) as nbtotalofrecords', $sql);
1162 $sqlforcount = preg_replace(
'/GROUP BY .*$/',
'', $sqlforcount);
1164 $resql = $this->db->query($sqlforcount);
1166 $objforcount = $this->db->fetch_object($resql);
1167 $nbtotalofrecords = $objforcount->nbtotalofrecords;
1172 if (($limit >= (
int) $nbtotalofrecords) && $page > 0) {
1176 if (($page * $limit) >= (
int) $nbtotalofrecords) {
1180 $this->db->free($resql);
1183 $sql .= $this->db->order($sortfield, $sortorder);
1188 $offset = $limit * $page;
1190 $sql .= $this->db->plimit($limit + 1, $offset);
1193 $result = $this->db->query($sql);
1196 $num = $this->db->num_rows($result);
1197 $min = min($num, ($limit <= 0 ? $num : $limit));
1199 $obj = $this->db->fetch_object($result);
1200 $category_static =
new Categorie($this->db);
1201 if ($category_static->fetch($obj->rowid)) {
1202 $categories[$i][
'id'] = $category_static->id;
1203 $categories[$i][
'fk_parent'] = $category_static->fk_parent;
1204 $categories[$i][
'label'] = $category_static->label;
1205 $categories[$i][
'description'] = $category_static->description;
1206 $categories[$i][
'color'] = $category_static->color;
1207 $categories[$i][
'position'] = $category_static->position;
1208 $categories[$i][
'socid'] = $category_static->socid;
1209 $categories[$i][
'ref_ext'] = $category_static->ref_ext;
1210 $categories[$i][
'visible'] = $category_static->visible;
1211 $categories[$i][
'type'] = $category_static->type;
1212 $categories[$i][
'entity'] = $category_static->entity;
1213 $categories[$i][
'array_options'] = $category_static->array_options;
1216 if (
getDolGlobalInt(
'MAIN_MULTILANGS') && isset($category_static->multilangs)) {
1217 $categories[$i][
'multilangs'] = $category_static->multilangs;
1223 $this->error = $this->db->lasterror();
1226 if (!count($categories)) {
1242 $sql =
"SELECT rowid FROM ".MAIN_DB_PREFIX.
"categorie";
1243 $sql .=
" WHERE fk_parent = ".((int) $this->
id);
1244 $sql .=
" AND entity IN (".getEntity(
'category').
")";
1246 $res = $this->db->query($sql);
1249 while ($rec = $this->db->fetch_array($res)) {
1251 $cat->fetch($rec[
'rowid']);
1271 $this->motherof = array();
1274 $sql =
"SELECT fk_parent as id_parent, rowid as id_son";
1275 $sql .=
" FROM ".MAIN_DB_PREFIX.
"categorie";
1276 $sql .=
" WHERE fk_parent <> 0";
1277 $sql .=
" AND entity IN (".getEntity(
'category').
")";
1279 dol_syslog(get_class($this).
"::load_motherof", LOG_DEBUG);
1280 $resql = $this->db->query($sql);
1282 while ($obj = $this->db->fetch_object($resql)) {
1283 $this->motherof[$obj->id_son] = $obj->id_parent;
1313 public function get_full_arbo($type, $fromid = 0, $include = 0, $forcelangcode =
'')
1318 if (!is_numeric($type)) {
1319 $type = $this->MAP_ID[$type];
1321 if (is_null($type)) {
1322 $this->error =
'BadValueForParameterType';
1326 if (is_string($fromid)) {
1327 $fromid = explode(
',', $fromid);
1328 } elseif (is_numeric($fromid)) {
1330 $fromid = array($fromid);
1334 } elseif (!is_array($fromid)) {
1338 $this->cats = array();
1344 if ($forcelangcode) {
1345 $current_lang = $forcelangcode;
1347 $current_lang = $langs->getDefaultLang();
1352 $sql =
"SELECT DISTINCT c.rowid, c.label, c.ref_ext, c.description, c.color, c.position, c.fk_parent, c.visible";
1354 $sql .=
", t.label as label_trans, t.description as description_trans";
1356 $sql .=
" FROM ".MAIN_DB_PREFIX.
"categorie as c";
1358 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"categorie_lang as t ON t.fk_category = c.rowid AND t.lang = '".$this->db->escape($current_lang).
"'";
1360 $sql .=
" WHERE c.entity IN (".getEntity(
'category').
")";
1361 $sql .=
" AND c.type = ".(int) $type;
1363 dol_syslog(get_class($this).
"::get_full_arbo get category list", LOG_DEBUG);
1365 $resql = $this->db->query($sql);
1368 $nbcateg = $this->db->num_rows($resql);
1370 while ($obj = $this->db->fetch_object($resql)) {
1371 $this->cats[(int) $obj->rowid]
1373 'rowid' => (
int) $obj->rowid,
1374 'id' => (int) $obj->rowid,
1375 'fk_parent' => (
int) $obj->fk_parent,
1376 'label' => !empty($obj->label_trans) ? (
string) $obj->label_trans : (
string) $obj->label,
1377 'description' => !empty($obj->description_trans) ? (
string) $obj->description_trans : (
string) $obj->description,
1378 'color' => (
string) $obj->color,
1379 'position' => (
string) $obj->position,
1380 'visible' => (
int) $obj->visible,
1381 'ref_ext' => (
string) $obj->ref_ext,
1382 'picto' =>
'category',
1396 dol_syslog(get_class($this).
"::get_full_arbo call to buildPathFromId", LOG_DEBUG);
1398 foreach ($this->cats as $key => $val) {
1404 if (count($fromid) > 0) {
1405 $keyfiltercatid =
'('.implode(
'|', $fromid).
')';
1408 $keyfilter1 =
'^'.$keyfiltercatid.
'$';
1409 $keyfilter2 =
'_'.$keyfiltercatid.
'$';
1410 $keyfilter3 =
'^'.$keyfiltercatid.
'_';
1411 $keyfilter4 =
'_'.$keyfiltercatid.
'_';
1412 foreach (array_keys($this->cats) as $key) {
1413 $fullpath = (
string) $this->cats[$key][
'fullpath'];
1414 $test = (preg_match(
'/'.$keyfilter1.
'/', $fullpath) || preg_match(
'/'.$keyfilter2.
'/', $fullpath)
1415 || preg_match(
'/'.$keyfilter3.
'/', $fullpath) || preg_match(
'/'.$keyfilter4.
'/', $fullpath));
1417 if (($test && !$include) || (!$test && $include)) {
1418 unset($this->cats[$key]);
1423 dol_syslog(get_class($this).
"::get_full_arbo dol_sort_array", LOG_DEBUG);
1425 $this->cats =
dol_sort_array($this->cats,
'fulllabel',
'asc', 1, 0, 1);
1444 if (!empty($this->cats[$id_categ][
'fullpath'])) {
1446 dol_syslog(get_class($this).
"::buildPathFromId fullpath and fulllabel already defined", LOG_WARNING);
1453 $this->cats[$id_categ][
'fullpath'] =
'_'.$id_categ;
1454 $this->cats[$id_categ][
'fulllabel'] = $this->cats[$id_categ][
'label'];
1456 $cursor_categ = $id_categ;
1458 while ((empty($protection) || $i < $protection) && !empty($this->motherof[$cursor_categ])) {
1460 $this->cats[$id_categ][
'fullpath'] =
'_'.$this->motherof[$cursor_categ].$this->cats[$id_categ][
'fullpath'];
1461 $this->cats[$id_categ][
'fulllabel'] = (empty($this->cats[$this->motherof[$cursor_categ]]) ?
'NotFound' : $this->cats[$this->motherof[$cursor_categ]][
'label']).
' > '.$this->cats[$id_categ][
'fulllabel'];
1464 $cursor_categ = $this->motherof[$cursor_categ];
1469 $nbunderscore = substr_count($this->cats[$id_categ][
'fullpath'],
'_');
1470 $this->cats[$id_categ][
'level'] = ($nbunderscore ? $nbunderscore :
null);
1487 if (!is_numeric($type) && !is_null($type)) {
1488 $type = $this->MAP_ID[$type];
1491 $sql =
"SELECT rowid FROM ".MAIN_DB_PREFIX.
"categorie";
1492 $sql .=
" WHERE entity IN (".getEntity(
'category').
")";
1493 if (!is_null($type)) {
1494 $sql .=
" AND type = ".(int) $type;
1497 $sql .=
" AND fk_parent = 0";
1500 $res = $this->db->query($sql);
1503 while ($rec = $this->db->fetch_array($res)) {
1505 $cat->fetch($rec[
'rowid']);
1506 $cats[$rec[
'rowid']] = $cat;
1537 $type = $this->type;
1539 if (!is_numeric($type)) {
1540 $type = $this->MAP_ID[$type];
1546 $sql =
"SELECT c.rowid";
1547 $sql .=
" FROM ".MAIN_DB_PREFIX.
"categorie as c ";
1548 $sql .=
" WHERE c.entity IN (".getEntity(
'category').
")";
1549 $sql .=
" AND c.type = ".((int) $type);
1550 $sql .=
" AND c.fk_parent = ".((int) $this->fk_parent);
1551 $sql .=
" AND c.label = '".$this->db->escape($this->label).
"'";
1553 dol_syslog(get_class($this).
"::already_exists", LOG_DEBUG);
1555 $resql = $this->db->query($sql);
1557 if ($this->db->num_rows($resql) > 0) {
1558 $obj = $this->db->fetch_object($resql);
1563 if (!empty($obj) && $obj->rowid > 0 && $obj->rowid != $this->id) {
1564 dol_syslog(get_class($this).
"::already_exists category with name=".$this->label.
" and parent ".$this->fk_parent.
" exists: rowid=".$obj->rowid.
" current_id=".$this->id, LOG_DEBUG);
1568 dol_syslog(get_class($this).
"::already_exists no category with same name=".$this->label.
" and same parent ".$this->fk_parent.
" than category id=".$this->id, LOG_DEBUG);
1571 $this->error = $this->db->error();
1589 public function print_all_ways($sep =
'auto', $url =
'', $nocolor = 0, $addpicto = 0, $notrunc = 0)
1594 if ($sep ==
'auto') {
1600 foreach ($all_ways as $way) {
1604 foreach ($way as $cat) {
1607 if (empty($nocolor)) {
1608 $forced_color =
'colortoreplace';
1609 if ($i == count($way)) {
1611 $forced_color =
'categtextwhite';
1612 if ($cat->color && colorIsLight($cat->color)) {
1613 $forced_color =
'categtextblack';
1619 if (($i < count($way) && empty($notrunc)) && $i > 1) {
1623 $link =
'<a href="'.DOL_URL_ROOT.
'/categories/viewcat.php?id='.((int) $cat->id).
'&type='.urlencode($cat->type).
'" class="'.(($i < count($way) && empty($notrunc)) ?
'small ' :
'').$forced_color.
'">';
1626 $s = $link.(($addpicto && $i == 1) ?
img_object(
'',
'category',
'class="paddingright"') :
'');
1627 $s .= (($i < count($way) && empty($notrunc)) ? ($i == 1 ?
dol_trunc($cat->label, 3) :
'') : $cat->label);
1630 } elseif ($url ==
'none') {
1631 if (($i < count($way) && empty($notrunc)) && $i > 1) {
1635 $link =
'<span class="valignmiddle '.($i < count($way) ?
'small ' :
'').$forced_color.
'">';
1636 $linkend =
'</span>';
1638 $s = $link.(($addpicto && $i == 1) ?
img_object(
'',
'category',
'class="paddingright"') :
'');
1639 $s .= (($i < count($way) && empty($notrunc)) ? ($i == 1 ?
dol_trunc($cat->label, 3) :
'') : $cat->label);
1643 $w[] =
'<a class="valignmiddle '.($i < count($way) ?
'small ' :
'').$forced_color.
'" href="'.DOL_URL_ROOT.
'/'.$url.
'?catid='.((
int) $cat->id).
'">'.($addpicto ?
img_object(
'',
'category') :
'').$cat->label.
'</a>';
1646 $newcategwithpath = preg_replace(
'/colortoreplace/', $forced_color, implode(
'<span class="inline-block valignmiddle paddingleft paddingright small '.$forced_color.
'">'.$sep.
'</span>', $w));
1648 $ways[] = $newcategwithpath;
1667 $sql =
"SELECT fk_parent FROM ".MAIN_DB_PREFIX.
"categorie";
1668 $sql .=
" WHERE rowid = ".((int) $this->
id);
1670 $res = $this->db->query($sql);
1673 while ($rec = $this->db->fetch_array($res)) {
1674 if ($rec[
'fk_parent'] > 0) {
1676 $cat->fetch($rec[
'fk_parent']);
1700 if (is_array($parents)) {
1701 foreach ($parents as $parent) {
1702 $all_ways = $parent->get_all_ways();
1703 foreach ($all_ways as $way) {
1711 if (count($ways) == 0) {
1712 $ways[0][0] = $this;
1732 if (is_numeric($type)) {
1733 $type = array_search($type, $this->MAP_ID);
1736 if ($type === Categorie::TYPE_BANK_LINE) {
1738 $sql =
"SELECT c.label, c.rowid";
1739 $sql .=
" FROM ".MAIN_DB_PREFIX.
"category_bankline as a, ".MAIN_DB_PREFIX.
"categorie as c";
1740 $sql .=
" WHERE a.lineid=".((int) $id).
" AND a.fk_categ = c.rowid";
1741 $sql .=
" AND c.entity IN (".getEntity(
'category').
")";
1742 $sql .=
" ORDER BY c.label";
1744 $res = $this->db->query($sql);
1746 while ($obj = $this->db->fetch_object($res)) {
1747 if ($mode ==
'id') {
1748 $cats[] = $obj->rowid;
1749 } elseif ($mode ==
'label') {
1750 $cats[] = $obj->label;
1753 $cat->id = $obj->rowid;
1754 $cat->label = $obj->label;
1763 $sql =
"SELECT ct.fk_categorie, c.label, c.rowid";
1764 $sql .=
" FROM ".MAIN_DB_PREFIX.
"categorie_".(empty($this->MAP_CAT_TABLE[$type]) ? $type : $this->MAP_CAT_TABLE[$type]).
" as ct, ".MAIN_DB_PREFIX.
"categorie as c";
1765 $sql .=
" WHERE ct.fk_categorie = c.rowid AND ct.fk_".(empty($this->MAP_CAT_FK[$type]) ? $type : $this->MAP_CAT_FK[$type]).
" = ".(
int) $id;
1769 $sql .=
" AND c.entity IN (".getEntity(
'category').
")";
1771 $res = $this->db->query($sql);
1773 while ($obj = $this->db->fetch_object($res)) {
1774 if ($mode ==
'id') {
1775 $cats[] = $obj->rowid;
1776 } elseif ($mode ==
'label') {
1777 $cats[] = $obj->label;
1780 $cat->fetch($obj->fk_categorie);
1804 public function rechercher($id, $nom, $type, $exact =
false, $case =
false)
1807 if (is_numeric($type)) {
1808 dol_syslog(__METHOD__.
': using numeric types is deprecated.', LOG_WARNING);
1814 if (is_numeric($type)) {
1816 $map_type = array_flip($this->MAP_ID);
1817 $type = $map_type[$type];
1818 dol_syslog(get_class($this).
"::rechercher(): numeric types are deprecated, please use string instead", LOG_WARNING);
1822 $sql =
"SELECT rowid FROM ".MAIN_DB_PREFIX.
"categorie";
1823 $sql .=
" WHERE type = ".((int) $this->MAP_ID[$type]);
1824 $sql .=
" AND entity IN (".getEntity(
'category').
")";
1827 $nom =
'%'.$this->db->escape(str_replace(
'*',
'%', $nom)).
'%';
1830 $sql .=
" AND label LIKE '".$this->db->escape($nom).
"'";
1832 $sql .=
" AND label LIKE BINARY '".$this->db->escape($nom).
"'";
1836 $sql .=
" AND rowid = ".((int) $id);
1839 $res = $this->db->query($sql);
1841 while ($rec = $this->db->fetch_array($res)) {
1843 $cat->fetch($rec[
'rowid']);
1849 $this->error = $this->db->error().
' sql='.$sql;
1862 include_once DOL_DOCUMENT_ROOT .
'/core/lib/files.lib.php';
1863 include_once DOL_DOCUMENT_ROOT .
'/core/lib/images.lib.php';
1865 $sdir .=
'/' .
get_exdir($this->
id, 2, 0, 0, $this,
'category') . $this->
id .
"/photos/";
1868 if (file_exists($dir_osencoded)) {
1869 $handle = opendir($dir_osencoded);
1870 if (is_resource($handle)) {
1871 while (($file = readdir($handle)) !==
false) {
1873 $file = mb_convert_encoding($file,
'UTF-8',
'ISO-8859-1');
1894 $langs->load(
'categories');
1898 $datas[
'label'] = $langs->trans(
"ShowCategory").
': '.($this->
ref ? $this->
ref : $this->label);
1916 public function getNomUrl($withpicto = 0, $option =
'', $maxlength = 0, $moreparam =
'', $notooltip = 0, $morecss =
'', $save_lastsearch_value = 0)
1918 global
$conf, $langs, $hookmanager;
1920 if (!empty(
$conf->dol_no_mouse_hover)) {
1927 'objecttype' => $this->element,
1928 'option' => $option,
1930 $classfortooltip =
'classfortooltip';
1933 $classfortooltip =
'classforajaxtooltip';
1934 $dataparams =
' data-params="'.dol_escape_htmltag(json_encode($params)).
'"';
1940 $url = DOL_URL_ROOT.
'/categories/viewcat.php?id='.$this->
id.
'&type='.$this->
type.$moreparam.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].($moreparam ?
'?'.$moreparam :
''));
1942 if ($option !==
'nolink') {
1944 $add_save_lastsearch_values = ($save_lastsearch_value == 1 ? 1 : 0);
1945 if ($save_lastsearch_value == -1 && isset($_SERVER[
"PHP_SELF"]) && preg_match(
'/list\.php/', $_SERVER[
"PHP_SELF"])) {
1946 $add_save_lastsearch_values = 1;
1948 if ( $add_save_lastsearch_values) {
1949 $url .=
'&save_lastsearch_values=1';
1954 $forced_color =
'categtextwhite';
1956 if (colorIsLight($this->color)) {
1957 $forced_color =
'categtextblack';
1962 if (empty($notooltip)) {
1964 $label = $langs->trans(
"ShowCategory");
1965 $linkclose .=
' alt="'.dolPrintHTMLForAttribute($label).
'"';
1967 $linkclose .= ($label ?
' title="'.dolPrintHTMLForAttribute($label).
'"' :
' title="tocomplete"');
1968 $linkclose .= $dataparams.
' class="'.$classfortooltip.
' '.$forced_color.($morecss ?
' '.$morecss :
'').
'"';
1970 $linkclose =
' class="'.$forced_color.($morecss ?
' '.$morecss :
'').
'"';
1973 if ($option ==
'nolink' ) {
1974 $linkstart =
'<span';
1976 $linkstart =
'<a href="'.$url.
'"';
1978 $linkstart .= $linkclose.
'>';
1979 if ($option ==
'nolink' ) {
1980 $linkend =
'</span>';
1985 $result .= $linkstart;
1988 $result .=
img_object(($notooltip ?
'' : $label), ($this->picto ? $this->picto :
'generic'), ($notooltip ? (($withpicto != 2) ?
'class="paddingright"' :
'') :
'class="'.(($withpicto != 2) ?
'paddingright ' :
'').
'"'), 0, 0, $notooltip ? 0 : 1);
1991 if ($withpicto != 2) {
1992 $result .=
dol_trunc(($this->
ref ? $this->
ref : $this->label), $maxlength);
1995 $result .= $linkend;
1998 $hookmanager->initHooks(array($this->element .
'dao'));
1999 $parameters = array(
'id' => $this->
id,
'getnomurl' => &$result);
2000 $reshook = $hookmanager->executeHooks(
'getNomUrl', $parameters, $this, $action);
2002 $result = $hookmanager->resPrint;
2004 $result .= $hookmanager->resPrint;
2021 require_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
2023 $dir = $sdir.
'/'.
get_exdir($this->
id, 2, 0, 0, $this,
'category').$this->id.
"/";
2026 if (!file_exists($dir)) {
2030 if (file_exists($dir)) {
2031 if (is_array($file[
'name'])) {
2032 $nbfile = count($file[
'name']);
2033 for ($i = 0; $i < $nbfile; $i++) {
2034 $originImage = $dir.$file[
'name'][$i];
2039 if (file_exists($originImage)) {
2045 $originImage = $dir.$file[
'name'];
2050 if (file_exists($originImage)) {
2069 include_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
2074 $dirthumb = $dir.
'thumbs/';
2076 if (file_exists($dir)) {
2077 $handle = opendir($dir);
2078 if (is_resource($handle)) {
2079 while (($file = readdir($handle)) !==
false) {
2080 if (
dol_is_file($dir.$file) && preg_match(
'/(\.jpeg|\.jpg|\.bmp|\.gif|\.png|\.tiff)$/i', $dir.$file)) {
2085 $photo_vignette =
'';
2087 if (preg_match(
'/(\.jpeg|\.jpg|\.bmp|\.gif|\.png|\.tiff)$/i', $photo, $regs)) {
2088 $photo_vignette = preg_replace(
'/'.$regs[0].
'/i',
'', $photo).
'_small'.$regs[0];
2093 $obj[
'photo'] = $photo;
2094 if ($photo_vignette && is_file($dirthumb.$photo_vignette)) {
2095 $obj[
'photo_vignette'] =
'thumbs/'.$photo_vignette;
2097 $obj[
'photo_vignette'] =
"";
2100 $tabobj[$nbphoto - 1] = $obj;
2103 if ($nbmax && $nbphoto >= $nbmax) {
2126 require_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
2128 $dir = dirname($file).
'/';
2129 $dirthumb = $dir.
'/thumbs/';
2130 $filename = preg_replace(
'/'.preg_quote($dir,
'/').
'/i',
'', $file);
2137 if (preg_match(
'/(\.jpeg|\.jpg|\.bmp|\.gif|\.png|\.tiff)$/i', $filename, $regs)) {
2138 $photo_vignette = preg_replace(
'/'.$regs[0].
'/i',
'', $filename).
'_small'.$regs[0];
2139 if (file_exists($dirthumb.$photo_vignette)) {
2155 $infoImg = getimagesize($file);
2156 $this->imgWidth = $infoImg[0];
2157 $this->imgHeight = $infoImg[1];
2172 $langs_available = $langs->get_available_languages();
2173 $current_lang = $langs->getDefaultLang();
2175 foreach ($langs_available as $key => $value) {
2176 $sql =
"SELECT rowid";
2177 $sql .=
" FROM ".MAIN_DB_PREFIX.
"categorie_lang";
2178 $sql .=
" WHERE fk_category=".((int) $this->
id);
2179 $sql .=
" AND lang = '".$this->db->escape($key).
"'";
2181 $result = $this->db->query($sql);
2183 if ($key == $current_lang) {
2185 if ($this->db->num_rows($result)) {
2186 $sql2 =
"UPDATE ".MAIN_DB_PREFIX.
"categorie_lang";
2187 $sql2 .=
" SET label = '".$this->db->escape($this->label).
"',";
2188 $sql2 .=
" description = '".$this->db->escape($this->
description).
"'";
2189 $sql2 .=
" WHERE fk_category = ".((int) $this->
id).
" AND lang = '".$this->db->escape($key).
"'";
2191 $sql2 =
"INSERT INTO ".MAIN_DB_PREFIX.
"categorie_lang (fk_category, lang, label, description)";
2192 $sql2 .=
" VALUES(".((int) $this->
id).
", '".$this->db->escape($key).
"', '".$this->db->escape($this->label).
"'";
2193 $sql2 .=
", '".$this->db->escape($this->
description).
"')";
2195 dol_syslog(get_class($this).
'::setMultiLangs', LOG_DEBUG);
2196 if (!$this->db->query($sql2)) {
2197 $this->error = $this->db->lasterror();
2200 $this->multilangs[$key][
"label"] = $this->label;
2201 $this->multilangs[$key][
"description"] = $this->description;
2202 } elseif (isset($this->multilangs[$key])) {
2203 if ($this->db->num_rows($result)) {
2204 $sql2 =
"UPDATE ".MAIN_DB_PREFIX.
"categorie_lang";
2205 $sql2 .=
" SET label='".$this->db->escape($this->multilangs[$key][
"label"]).
"',";
2206 $sql2 .=
" description='".$this->db->escape($this->multilangs[$key][
"description"]).
"'";
2207 $sql2 .=
" WHERE fk_category=".((int) $this->
id).
" AND lang='".$this->db->escape($key).
"'";
2209 $sql2 =
"INSERT INTO ".MAIN_DB_PREFIX.
"categorie_lang (fk_category, lang, label, description)";
2210 $sql2 .=
" VALUES(".((int) $this->
id).
", '".$this->db->escape($key).
"', '".$this->db->escape($this->multilangs[$key][
"label"]).
"'";
2211 $sql2 .=
",'".$this->db->escape($this->multilangs[$key][
"description"]).
"')";
2215 if ($this->multilangs[$key][
"label"] || $this->multilangs[$key][
"description"]) {
2216 dol_syslog(get_class($this).
'::setMultiLangs', LOG_DEBUG);
2218 if (!$this->db->query($sql2)) {
2219 $this->error = $this->db->lasterror();
2227 $result = $this->call_trigger(
'CATEGORY_SET_MULTILANGS', $user);
2229 $this->error = $this->db->lasterror();
2249 $sql =
"DELETE FROM ".$this->db->prefix().
"categorie_lang";
2250 $sql .=
" WHERE fk_category = ".((int) $this->
id).
" AND lang = '".$this->db->escape($langtodelete).
"'";
2252 dol_syslog(get_class($this).
'::delMultiLangs', LOG_DEBUG);
2253 $result = $this->db->query($sql);
2255 if (empty($notrigger)) {
2257 $result = $this->call_trigger(
'CATEGORY_DEL_MULTILANGS', $user);
2259 $this->error = $this->db->lasterror();
2260 dol_syslog(get_class($this).
'::delMultiLangs error='.$this->error, LOG_ERR);
2267 $this->error = $this->db->lasterror();
2268 dol_syslog(get_class($this).
'::delMultiLangs error='.$this->error, LOG_ERR);
2282 $current_lang = $langs->getDefaultLang();
2284 $sql =
"SELECT lang, label, description";
2285 $sql .=
" FROM ".MAIN_DB_PREFIX.
"categorie_lang";
2286 $sql .=
" WHERE fk_category=".((int) $this->
id);
2288 $result = $this->db->query($sql);
2290 while ($obj = $this->db->fetch_object($result)) {
2292 if ($obj->lang == $current_lang) {
2293 $this->label = $obj->label;
2296 $this->multilangs[$obj->lang][
"label"] = $obj->label;
2297 $this->multilangs[$obj->lang][
"description"] = $obj->description;
2301 $this->error = $langs->trans(
"Error").
" : ".$this->db->error().
" - ".$sql;
2327 dol_syslog(get_class($this).
"::initAsSpecimen");
2331 $this->fk_parent = 0;
2332 $this->label =
'SPECIMEN';
2333 $this->specimen = 1;
2336 $this->
type = self::TYPE_PRODUCT;
2368 if ($type ==
'bank_account') {
2372 return " LEFT JOIN ".MAIN_DB_PREFIX.
"categorie_".$type.
" as cp ON ".$rowIdName.
" = cp.fk_".$type;
2386 if ($type ==
'bank_account') {
2389 if ($type ==
'customer') {
2392 if ($type ==
'supplier') {
2393 $type =
'fournisseur';
2396 if (empty($searchList) && !is_array($searchList)) {
2400 $searchCategorySqlList = array();
2401 foreach ($searchList as $searchCategory) {
2402 if (intval($searchCategory) == -2) {
2403 $searchCategorySqlList[] =
" cp.fk_categorie IS NULL";
2404 } elseif (intval($searchCategory) > 0) {
2405 $searchCategorySqlList[] =
" ".$rowIdName.
" IN (SELECT fk_".$type.
" FROM ".MAIN_DB_PREFIX.
"categorie_".$type.
" WHERE fk_categorie = ".((int) $searchCategory).
")";
2409 if (!empty($searchCategorySqlList)) {
2410 return " AND (".implode(
' AND ', $searchCategorySqlList).
")";
2423 dol_syslog(get_class($this).
"::count_all_categories", LOG_DEBUG);
2424 $sql =
"SELECT COUNT(rowid) FROM ".MAIN_DB_PREFIX.
"categorie";
2425 $sql .=
" WHERE entity IN (".getEntity(
'category').
")";
2427 $res = $this->db->query($sql);
2429 $obj = $this->db->fetch_object($res);
Class to manage categories.
getListForItem($id, $type='customer', $sortfield="s.rowid", $sortorder='ASC', $limit=0, $page=0)
Return the list of the categories of a given element (a product, a customer, ...).
get_image_size($file)
Load size of image file.
load_motherof()
Load the array this->motherof that is array(id_son=>id_parent, ...), so array of all child categories...
getLibStatut($mode)
Return label of contact status.
delete_photo($file)
Efface la photo de la categorie et sa vignette.
containing($id, $type, $mode='object')
Return list of categories (object instances or labels) linked to a given object having id $id and typ...
getTooltipContentArray($params)
getTooltipContentArray
countNbOfCategories()
Count all categories.
del_type($obj, $type)
Delete object from category.
buildPathFromId($id_categ, $protection=1000)
For category id_categ and its children available in this->cats, define property fullpath and fulllabe...
static getFilterSelectQuery($type, $rowIdName, $searchList)
Return the additional SQL SELECT query for filtering a list by a category.
create($user, $notrigger=0)
Add category into database.
rechercher($id, $nom, $type, $exact=false, $case=false)
Returns categories whose id or name matches.
getMultiLangs()
Load array this->multilangs.
isAnyPhotoAvailable($sdir)
Return if at least one photo is available.
already_exists()
Check if a category with same label already exists for this cat's parent or root and for this cat's t...
get_filles()
Return direct children ids of a category into an array.
initAsSpecimen()
Initialise an instance with random values.
get_all_categories($type=null, $parent=false)
Returns all categories.
static getFilterJoinQuery($type, $rowIdName)
Return the additional SQL JOIN query for filtering a list by a category.
containsObject($type, $object_id)
Check for the presence of a given object in the current category.
get_main_categories($type=null)
Returns the first level categories (which are not child)
static replaceThirdparty(DoliDB $dbs, $origin_id, $dest_id)
Function used to replace a thirdparty id with another one.
setMultiLangs(User $user, $notrigger=0)
Create or Update translations of categories labels.
getMapList()
Get map list.
$fields
'type' if the field format ('integer', 'integer:ObjectClass:PathToClass[:AddCreateButtonOrNot[:Filter...
get_meres()
Returns an array containing the list of parent categories Note: A category can only have one parent b...
get_full_arbo($type, $fromid=0, $include=0, $forcelangcode='')
Rebuilding the category tree as an array Return an array of table('id','id_mere',....
add_type($obj, $type='')
Link an object to the category.
print_all_ways($sep='auto', $url='', $nocolor=0, $addpicto=0, $notrunc=0)
Returns the path of the category, with the names of the categories separated by $sep (" >> " by defau...
update(User $user, $notrigger=0)
Update category.
liste_photos($dir, $nbmax=0)
Return an array with all photos inside the directory.
get_all_ways()
Returns in a array all possible paths to go to the category starting with the major categories repres...
getNomUrl($withpicto=0, $option='', $maxlength=0, $moreparam='', $notooltip=0, $morecss='', $save_lastsearch_value=0)
Return name and link of category (with picto) Use ->id, ->ref, ->label, ->color.
delMultiLangs($langtodelete, $user, $notrigger=0)
Delete a language for this category.
add_photo($sdir, $file)
Add the image uploaded as $file to the directory $sdir/<category>-<id>/photos/.
fetch($id, $label='', $type=null, $ref_ext='')
Load category into memory from database.
Parent class of all other business classes (invoices, contracts, proposals, orders,...
fetch_optionals($rowid=null, $optionsArray=null)
Function to get extra fields of an object into $this->array_options This method is in most cases call...
deleteExtraFields()
Delete all extra fields values for the current object.
static commonReplaceThirdparty(DoliDB $dbs, $origin_id, $dest_id, array $tables, $ignoreerrors=0)
Function used to replace a thirdparty id with another one.
insertExtraFields($trigger='', $userused=null)
Add/Update all extra fields values for the current object.
addThumbs($file, $quality=50)
Build thumb.
Class to manage Dolibarr database access.
Class to manage Dolibarr users.
print $script_file $mode $langs defaultlang(is_numeric($duration_value) ? " delay=". $duration_value :"").(is_numeric($duration_value2) ? " after cd cd cd description as description
Only used if Module[ID]Desc translation string is not found.
dol_delete_file($file, $disableglob=0, $nophperrors=0, $nohook=0, $object=null, $allowdotdot=false, $indexdatabase=1, $nolog=0)
Remove a file or several files with a mask.
dol_is_file($pathoffile)
Return if path is a file.
dol_move_uploaded_file($src_file, $dest_file, $allowoverwrite, $disablevirusscan=0, $uploaderrorcode=0, $nohook=0, $keyforsourcefile='addedfile', $upload_dir='', $mode=0)
Check validity of a file upload from an GUI page, and move it to its final destination.
dol_now($mode='gmt')
Return date for now.
dol_osencode($str)
Return a string encoded into OS filesystem encoding.
img_object($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $allowothertags=array())
Show a picto called object_picto (generic function)
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
dol_sort_array(&$array, $index, $order='asc', $natsort=0, $case_sensitive=0, $keepindex=0)
Advanced sort array by the value of a given key, which produces ascending (default) or descending out...
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
dol_trunc($string, $size=40, $trunc='right', $stringencoding='UTF-8', $nodot=0, $display=0)
Truncate a string to a particular length adding '…' if string larger than length.
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
sanitizeVal($out='', $check='alphanohtml', $filter=null, $options=null)
Return a sanitized or empty value after checking value against a rule.
isModEnabled($module)
Is Dolibarr module enabled.
utf8_check($str)
Check if a string is in UTF8.
get_exdir($num, $level, $alpha, $withoutslash, $object, $modulepart='')
Return a path to have a the directory according to object where files are stored.
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
getEntity($element, $shared=1, $currentobject=null)
Get list of entity id to use.
dol_mkdir($dir, $dataroot='', $newmask='')
Creation of a directory (this can create recursive subdir)
image_format_supported($file, $acceptsvg=0)
Return if a filename is file name of a supported image format.
print $langs trans("Show") . '< td style="' . $timeColor . '" align="center"> s</td > badge status0 badge status4 badge status3 Error badge status8< td align="center">< span class="badge ' . $badge . '"></span ></td >< td align="center">< a href="#" class="button button-small" onclick="openLogModal(this)" data-req="' . dol_escape_htmltag($reqSafe) . '" data-res="' . dol_escape_htmltag($resSafe) . '" data-err="' . dol_escape_htmltag($errSafe) . '">< span class="fa fa-search-plus"></span ></a ></td ></tr >< tr >< td colspan="' . $colspan . '" class="opacitymedium"></td ></tr ></table ></div ></form > logModal none logModal none s a JSON string
buildzip.php
if(preg_match('/(crypted|dolcrypt):/i', $dolibarr_main_db_pass)||!empty($dolibarr_main_db_encrypted_pass)) $conf db type
'integer', 'integer:ObjectClass:PathToClass[:AddCreateButtonOrNot[:Filter[:Sortfield]]]',...