30require_once DOL_DOCUMENT_ROOT.
'/core/class/commonobject.class.php';
 
   31require_once DOL_DOCUMENT_ROOT.
'/core/class/commonobjectline.class.php';
 
   44  public $element = 
'inventory';
 
   49  public $table_element = 
'inventory';
 
   54  public $picto = 
'inventory';
 
   56  const STATUS_DRAFT     = 0;   
 
   57  const STATUS_VALIDATED = 1;   
 
   58  const STATUS_RECORDED  = 2;   
 
   59  const STATUS_CANCELED  = 9;   
 
   91  public $fields = array(
 
   92    'rowid'              => array(
'type' => 
'integer', 
'label' => 
'TechnicalID', 
'visible' => -1, 
'enabled' => 1, 
'position' => 1, 
'notnull' => 1, 
'index' => 1, 
'comment' => 
'Id',),
 
   93    'ref'                => array(
'type' => 
'varchar(64)', 
'label' => 
'Ref', 
'visible' => 1, 
'enabled' => 1, 
'position' => 10, 
'notnull' => 1, 
'index' => 1, 
'searchall' => 1, 
'comment' => 
'Reference of object', 
'css' => 
'maxwidth150'),
 
   94    'entity'             => array(
'type' => 
'integer', 
'label' => 
'Entity', 
'visible' => 0, 
'enabled' => 1, 
'position' => 20, 
'notnull' => 1, 
'index' => 1,),
 
   95    'title'              => array(
'type' => 
'varchar(255)', 
'label' => 
'Label', 
'visible' => 1, 
'enabled' => 1, 
'position' => 25, 
'css' => 
'minwidth300', 
'csslist' => 
'tdoverflowmax150', 
'alwayseditable' => 1),
 
   96    'fk_warehouse'       => array(
'type' => 
'integer:Entrepot:product/stock/class/entrepot.class.php', 
'label' => 
'Warehouse', 
'visible' => 1, 
'enabled' => 1, 
'position' => 30, 
'index' => 1, 
'help' => 
'InventoryForASpecificWarehouse', 
'picto' => 
'stock', 
'css' => 
'minwidth300 maxwidth500 widthcentpercentminusx', 
'csslist' => 
'tdoverflowmax150'),
 
   97    'fk_product'         => array(
'type' => 
'integer:Product:product/class/product.class.php', 
'label' => 
'Product', 
'get_name_url_params' => 
'0::0:-1:0::1', 
'visible' => 1, 
'enabled' => 1, 
'position' => 32, 
'index' => 1, 
'help' => 
'InventoryForASpecificProduct', 
'picto' => 
'product', 
'css' => 
'minwidth300 maxwidth500 widthcentpercentminusx', 
'csslist' => 
'tdoverflowmax150'),
 
   98    'categories_product' => array(
'type' => 
'chkbxlst:categorie:label:rowid::type=0:0:', 
'label' => 
'OrProductsWithCategories', 
'visible' => 3, 
'enabled' => 1, 
'position' => 33, 
'help' => 
'', 
'picto' => 
'category', 
'css' => 
'minwidth300 maxwidth500 widthcentpercentminusx'),
 
   99    'date_inventory'     => array(
'type' => 
'date', 
'label' => 
'DateValue', 
'visible' => 1, 
'enabled' => 
'$conf->global->STOCK_INVENTORY_ADD_A_VALUE_DATE', 
'position' => 35, 
'csslist' => 
'nowraponall'),  
 
  100    'date_creation'      => array(
'type' => 
'datetime', 
'label' => 
'DateCreation', 
'enabled' => 1, 
'visible' => -2, 
'notnull' => 1, 
'position' => 500, 
'csslist' => 
'nowraponall'),
 
  101    'tms'                => array(
'type' => 
'timestamp', 
'label' => 
'DateModification', 
'enabled' => 1, 
'visible' => -2, 
'notnull' => 1, 
'position' => 501, 
'csslist' => 
'nowraponall'),
 
  102    'date_validation'    => array(
'type' => 
'datetime', 
'label' => 
'DateValidation', 
'visible' => -2, 
'enabled' => 1, 
'position' => 502, 
'csslist' => 
'nowraponall'),
 
  103    'fk_user_creat'      => array(
'type' => 
'integer:User:user/class/user.class.php', 
'label' => 
'UserAuthor', 
'enabled' => 1, 
'visible' => -2, 
'notnull' => 1, 
'position' => 510, 
'foreignkey' => 
'user.rowid', 
'csslist' => 
'tdoverflowmax150'),
 
  104    'fk_user_modif'      => array(
'type' => 
'integer:User:user/class/user.class.php', 
'label' => 
'UserModif', 
'enabled' => 1, 
'visible' => -2, 
'notnull' => -1, 
'position' => 511, 
'csslist' => 
'tdoverflowmax150'),
 
  105    'fk_user_valid'      => array(
'type' => 
'integer:User:user/class/user.class.php', 
'label' => 
'UserValidation', 
'visible' => -2, 
'enabled' => 1, 
'position' => 512, 
'csslist' => 
'tdoverflowmax150'),
 
  106    'import_key'         => array(
'type' => 
'varchar(14)', 
'label' => 
'ImportId', 
'enabled' => 1, 
'visible' => -2, 
'notnull' => -1, 
'index' => 0, 
'position' => 1000),
 
  107    'status'             => array(
'type' => 
'integer', 
'label' => 
'Status', 
'visible' => 4, 
'enabled' => 1, 
'position' => 1000, 
'notnull' => 1, 
'default' => 
'0', 
'index' => 1, 
'arrayofkeyval' => array(0 => 
'Draft', 1 => 
'Validated', 2 => 
'Closed', 9 => 
'Canceled'))
 
  128  public $fk_warehouse;
 
  138  public $categories_product;
 
  142  public $date_inventory;
 
  156  public $fk_user_creat;
 
  161  public $fk_user_modif;
 
  166  public $fk_user_valid;
 
  181  public $table_element_line = 
'inventorydet';
 
  186  public $fk_element = 
'fk_inventory';
 
  191  public $class_element_line = 
'Inventoryline';
 
  196  protected $childtables = array();
 
  200  protected $childtablesoncascade = array(
'inventorydet');
 
  205  public $lines = array();
 
  220    $this->ismultientitymanaged = 1;
 
  221    $this->isextrafieldmanaged = 0;
 
  224      $this->fields[
'rowid'][
'visible'] = 0;
 
  226    if (!isModEnabled(
'multicompany')) {
 
  227      $this->fields[
'entity'][
'enabled'] = 0;
 
 
  254  public function validate(
User $user, $notrigger = 0, $include_sub_warehouse = 0)
 
  260    if ($this->
status == self::STATUS_DRAFT) {
 
  262      $sql = 
'DELETE FROM '.$this->db->prefix().
'inventorydet WHERE fk_inventory = '.((int) $this->
id);
 
  263      $resql = $this->db->query($sql);
 
  265        $this->error = $this->db->lasterror();
 
  266        $this->db->rollback();
 
  271      $sql = 
"SELECT ps.rowid, ps.fk_entrepot as fk_warehouse, ps.fk_product, ps.reel,";
 
  272      if (isModEnabled(
'productbatch')) {
 
  273        $sql .= 
" pb.batch as batch, pb.qty as qty,";
 
  275        $sql .= 
" '' as batch, 0 as qty,";
 
  277      $sql .= 
" p.ref, p.tobatch";
 
  278      $sql .= 
" FROM ".$this->db->prefix().
"product_stock as ps";
 
  279      if (isModEnabled(
'productbatch')) {
 
  280        $sql .= 
" LEFT JOIN ".$this->db->prefix().
"product_batch as pb ON pb.fk_product_stock = ps.rowid";
 
  282      $sql .= 
", ".$this->db->prefix().
"product as p, ".$this->db->prefix().
"entrepot as e";
 
  283      $sql .= 
" WHERE p.entity IN (".getEntity(
'product').
")";
 
  284      $sql .= 
" AND ps.fk_product = p.rowid AND ps.fk_entrepot = e.rowid";
 
  286        $sql .= 
" AND p.fk_product_type = 0";
 
  288      if ($this->fk_product > 0) {
 
  289        $sql .= 
" AND ps.fk_product = ".((int) $this->fk_product);
 
  291      if ($this->fk_warehouse > 0) {
 
  292        $sql .= 
" AND (ps.fk_entrepot = ".((int) $this->fk_warehouse);
 
  293        if (!empty($include_sub_warehouse) && 
getDolGlobalInt(
'INVENTORY_INCLUDE_SUB_WAREHOUSE')) {
 
  294          $TChildWarehouses = array();
 
  296          $sql .= 
" OR ps.fk_entrepot IN (".$this->db->sanitize(implode(
',', $TChildWarehouses)).
")";
 
  300      if (!empty($this->categories_product)) {
 
  301        $sql .= 
" AND EXISTS (";
 
  302        $sql .= 
" SELECT cp.fk_product";
 
  303        $sql .= 
" FROM ".$this->db->prefix().
"categorie_product AS cp";
 
  304        $sql .= 
" WHERE cp.fk_product = ps.fk_product";
 
  305        $sql .= 
" AND cp.fk_categorie IN (".$this->db->sanitize($this->categories_product).
")";
 
  309        $sql .= 
" AND NOT EXISTS (";
 
  310        $sql .= 
" SELECT pa.rowid";
 
  311        $sql .= 
" FROM ".$this->db->prefix().
"product_association as pa";
 
  312        $sql .= 
" WHERE pa.fk_product_pere = ps.fk_product";
 
  315      $sql .= 
" ORDER BY p.rowid";
 
  319      $resql = $this->db->query($sql);
 
  321        $num = $this->db->num_rows($resql);
 
  325          $obj = $this->db->fetch_object($resql);
 
  327          $inventoryline->fk_inventory = $this->id;
 
  328          $inventoryline->fk_warehouse = $obj->fk_warehouse;
 
  329          $inventoryline->fk_product = $obj->fk_product;
 
  330          $inventoryline->batch = $obj->batch;
 
  331          $inventoryline->datec = 
dol_now();
 
  333          if (isModEnabled(
'productbatch')) {
 
  334            if ($obj->batch && empty($obj->tobatch)) {
 
  337              $this->error = 
'The product ID='.$obj->ref.
" has stock with lot/serial but is configured to not manage lot/serial. You must first fix this, this way: Set the product to have 'Management of Lot/Serial' to Yes, then set it back to 'Management of Lot/Serial to No";
 
  341            $inventoryline->qty_stock = ($obj->batch ? $obj->qty : $obj->reel); 
 
  343            $inventoryline->qty_stock = $obj->reel;
 
  347          $resultline = $inventoryline->create($user);
 
  348          if ($resultline <= 0) {
 
  349            $this->error = $inventoryline->error;
 
  350            $this->errors = $inventoryline->errors;
 
  359        $this->error = $this->db->lasterror();
 
  364      $result = $this->
setStatut($this::STATUS_VALIDATED, 
null, 
'', 
'INVENTORY_VALIDATED');
 
  370      $this->db->rollback();
 
 
  387    $sql = 
'DELETE FROM '.$this->db->prefix().
'inventorydet WHERE fk_inventory = '.((int) $this->
id);
 
  388    $resql = $this->db->query($sql);
 
  390      $this->error = $this->db->lasterror();
 
  391      $this->db->rollback();
 
  395    $result = $this->
setStatut($this::STATUS_DRAFT, 
null, 
'', 
'INVENTORY_DRAFT');
 
  400      $this->db->rollback();
 
 
  416    $result = $this->
setStatut($this::STATUS_RECORDED, 
null, 
'', 
'INVENTORY_RECORDED');
 
  421      $this->db->rollback();
 
 
  438    $result = $this->
setStatut($this::STATUS_CANCELED, 
null, 
'', 
'INVENTORY_CANCELED');
 
  443      $this->db->rollback();
 
 
  458    global $hookmanager, $langs;
 
  475    $object->ref = 
"copy_of_".$object->ref;
 
  480    $object->context[
'createfromclone'] = 
'createfromclone';
 
  481    $result = 
$object->createCommon($user);
 
  485      $this->errors = 
$object->errors;
 
  488    unset(
$object->context[
'createfromclone']);
 
  495      $this->db->rollback();
 
 
  507  public function fetch($id, $ref = 
null)
 
 
  547  public function delete(
User $user, $notrigger = 0)
 
 
  563      $this->error = 
'ErrorDeleteLineNotAllowedByObjectStatus';
 
 
  580  public function getNomUrl($withpicto = 0, $option = 
'', $notooltip = 0, $morecss = 
'', $save_lastsearch_value = -1)
 
  582    global $db, 
$conf, $langs;
 
  583    global $dolibarr_main_authentication, $dolibarr_main_demo;
 
  586    if (!empty(
$conf->dol_no_mouse_hover)) {
 
  593    $label = 
'<u>'.$langs->trans(
"Inventory").
'</u>';
 
  595    $label .= 
'<b>'.$langs->trans(
'Ref').
':</b> '.$this->ref;
 
  597    $url = 
dol_buildpath(
'/product/inventory/card.php', 1).
'?id='.$this->id;
 
  600    if (empty($notooltip)) {
 
  602        $label = $langs->trans(
"ShowInventory");
 
  603        $linkclose .= 
' alt="'.dol_escape_htmltag($label, 1).
'"';
 
  605      $linkclose .= 
' title="'.dol_escape_htmltag($label, 1).
'"';
 
  606      $linkclose .= 
' class="classfortooltip'.($morecss ? 
' '.$morecss : 
'').
'"';
 
  608      $linkclose = ($morecss ? 
' class="'.$morecss.
'"' : 
'');
 
  611    $linkstart = 
'<a href="'.$url.
'"';
 
  612    $linkstart .= $linkclose.
'>';
 
  615    $result .= $linkstart;
 
  617      $result .= 
img_object(($notooltip ? 
'' : $label), ($this->picto ? $this->picto : 
'generic'), ($notooltip ? (($withpicto != 2) ? 
'class="paddingright"' : 
'') : 
'class="'.(($withpicto != 2) ? 
'paddingright ' : 
'').
'classfortooltip"'), 0, 0, $notooltip ? 0 : 1);
 
  619    if ($withpicto != 2) {
 
  620      $result .= $this->ref;
 
 
  650    global $langs, $hookmanager;
 
  652    $labelStatus = array();
 
  653    $labelStatusShort = array();
 
  654    $labelStatus[self::STATUS_DRAFT] = $langs->transnoentitiesnoconv(
'Draft');
 
  655    $labelStatus[self::STATUS_VALIDATED] = $langs->transnoentitiesnoconv(
'Validated').
' ('.$langs->transnoentitiesnoconv(
'InventoryStartedShort').
')';
 
  656    $labelStatus[self::STATUS_CANCELED] = $langs->transnoentitiesnoconv(
'Canceled');
 
  657    $labelStatus[self::STATUS_RECORDED] = $langs->transnoentitiesnoconv(
'Closed');
 
  658    $labelStatusShort[self::STATUS_DRAFT] = $langs->transnoentitiesnoconv(
'Draft');
 
  659    $labelStatusShort[self::STATUS_VALIDATED] = $langs->transnoentitiesnoconv(
'InventoryStartedShort');
 
  660    $labelStatusShort[self::STATUS_CANCELED] = $langs->transnoentitiesnoconv(
'Canceled');
 
  661    $labelStatusShort[self::STATUS_RECORDED] = $langs->transnoentitiesnoconv(
'Closed');
 
  663    $statusType = 
'status'.$status;
 
  664    if ($status == self::STATUS_RECORDED) {
 
  665      $statusType = 
'status6';
 
  668    $parameters = array(
'status' => $status, 
'mode' => $mode);
 
  669    $reshook = $hookmanager->executeHooks(
'LibStatut', $parameters, $this); 
 
  671      return $hookmanager->resPrint;
 
  673    return dolGetStatus($labelStatus[$status], $labelStatusShort[$status], 
'', $statusType, $mode);
 
 
  685    global 
$conf, $langs;
 
  687    $selected = (empty($arraydata[
'selected']) ? 0 : $arraydata[
'selected']);
 
  689    $return = 
'<div class="box-flex-item box-flex-grow-zero">';
 
  690    $return .= 
'<div class="info-box info-box-sm">';
 
  691    $return .= 
'<span class="info-box-icon bg-infobox-action">';
 
  693    $return .= 
'</span>';
 
  694    $return .= 
'<div class="info-box-content">';
 
  695    $return .= 
'<span class="info-box-ref inline-block tdoverflowmax150 valignmiddle">'.(method_exists($this, 
'getNomUrl') ? $this->
getNomUrl() : $this->ref).
'</span>';
 
  696    if ($selected >= 0) {
 
  697      $return .= 
'<input id="cb'.$this->id.
'" class="flat checkforselect fright" type="checkbox" name="toselect[]" value="'.$this->
id.
'"'.($selected ? 
' checked="checked"' : 
'').
'>';
 
  699    if (property_exists($this, 
'label')) {
 
  700      $return .= 
' <div class="inline-block opacitymedium valignmiddle tdoverflowmax100">'.$this->label.
'</div>';
 
  702    if (property_exists($this, 
'amount')) {
 
  704      $return .= 
'<span class="info-box-label amount">'.price($this->amount, 0, $langs, 1, -1, -1, 
$conf->currency).
'</span>';
 
  706    if (method_exists($this, 
'getLibStatut')) {
 
  707      $return .= 
'<br><div class="info-box-status">'.$this->getLibStatut(3).
'</div>';
 
 
  724    $sql = 
"SELECT rowid, date_creation as datec, tms as datem, date_validation as datev,";
 
  725    $sql .= 
" fk_user_creat, fk_user_modif, fk_user_valid";
 
  726    $sql .= 
" FROM ".$this->db->prefix().$this->table_element.
" as t";
 
  727    $sql .= 
" WHERE t.rowid = ".((int) $id);
 
  728    $result = $this->db->query($sql);
 
  730      if ($this->db->num_rows($result)) {
 
  731        $obj = $this->db->fetch_object($result);
 
  733        $this->
id = $obj->rowid;
 
  735        $this->user_creation_id = $obj->fk_user_creat;
 
  736        $this->user_modification_id = $obj->fk_user_modif;
 
  737        $this->user_validation_id = $obj->fk_user_valid;
 
  739        $this->date_creation     = $this->db->jdate($obj->datec);
 
  740        $this->date_modification = $this->db->jdate($obj->datem);
 
  741        $this->date_validation   = $this->db->jdate($obj->datev);
 
  744      $this->db->free($result);
 
 
  773    $sql = 
'SELECT rowid FROM '.MAIN_DB_PREFIX.
'entrepot';
 
  774    $sql .= 
' WHERE fk_parent='.(int) $id;
 
  775    $sql .= 
' ORDER BY rowid';
 
  776    $resql = $this->db->query($sql);
 
  777    if ($resql && $this->db->num_rows($resql) > 0) {
 
  778      while ($obj = $this->db->fetch_object($resql)) {
 
  779        $TChildWarehouse[] = $obj->rowid;
 
 
 
  797  public $element = 
'inventoryline';
 
  802  public $table_element = 
'inventorydet';
 
  817  public $picto = 
'stock';
 
  840  public $fields = array(
 
  841    'rowid'         => array(
'type' => 
'integer', 
'label' => 
'TechnicalID', 
'visible' => -1, 
'enabled' => 1, 
'position' => 1, 
'notnull' => 1, 
'index' => 1, 
'comment' => 
'Id',),
 
  842    'fk_inventory'  => array(
'type' => 
'integer:Inventory:product/inventory/class/inventory.class.php', 
'label' => 
'Inventory', 
'visible' => 1, 
'enabled' => 1, 
'position' => 30, 
'index' => 1, 
'help' => 
'LinkToInventory'),
 
  843    'fk_warehouse'  => array(
'type' => 
'integer:Entrepot:product/stock/class/entrepot.class.php', 
'label' => 
'Warehouse', 
'visible' => 1, 
'enabled' => 1, 
'position' => 30, 
'index' => 1, 
'help' => 
'LinkToThirdparty'),
 
  844    'fk_product'    => array(
'type' => 
'integer:Product:product/class/product.class.php', 
'label' => 
'Product', 
'visible' => 1, 
'enabled' => 1, 
'position' => 32, 
'index' => 1, 
'help' => 
'LinkToProduct'),
 
  845    'batch'         => array(
'type' => 
'string', 
'label' => 
'Batch', 
'visible' => 1, 
'enabled' => 1, 
'position' => 32, 
'index' => 1, 
'help' => 
'LinkToProduct'),
 
  846    'datec'         => array(
'type' => 
'datetime', 
'label' => 
'DateCreation', 
'enabled' => 1, 
'visible' => -2, 
'notnull' => 1, 
'position' => 500),
 
  847    'tms'           => array(
'type' => 
'timestamp', 
'label' => 
'DateModification', 
'enabled' => 1, 
'visible' => -2, 
'notnull' => 1, 
'position' => 501),
 
  848    'qty_stock'     => array(
'type' => 
'double', 
'label' => 
'QtyFound', 
'visible' => 1, 
'enabled' => 1, 
'position' => 32, 
'index' => 1, 
'help' => 
'Qty we found/want (to define during draft edition)'),
 
  849    'qty_view'      => array(
'type' => 
'double', 
'label' => 
'QtyBefore', 
'visible' => 1, 
'enabled' => 1, 
'position' => 33, 
'index' => 1, 
'help' => 
'Qty before (filled once movements are validated)'),
 
  850    'qty_regulated' => array(
'type' => 
'double', 
'label' => 
'QtyDelta', 
'visible' => 1, 
'enabled' => 1, 
'position' => 34, 
'index' => 1, 
'help' => 
'Qty added or removed (filled once movements are validated)'),
 
  851    'pmp_real'      => array(
'type' => 
'double', 
'label' => 
'PMPReal', 
'visible' => 1, 
'enabled' => 1, 
'position' => 35),
 
  852    'pmp_expected'  => array(
'type' => 
'double', 
'label' => 
'PMPExpected', 
'visible' => 1, 
'enabled' => 1, 
'position' => 36),
 
  863  public $fk_inventory;
 
  867  public $fk_warehouse;
 
  894  public $qty_regulated;
 
  903  public $pmp_expected;
 
  913    $this->ismultientitymanaged = 0;
 
  915    $this->isextrafieldmanaged = 0;
 
 
  936  public function fetch($id, $ref = 
null)
 
 
  962  public function delete(
User $user, $notrigger = 0)
 
 
 
if( $user->socid > 0) if(! $user->hasRight('accounting', 'chartofaccount')) $object
Parent class of all other business classes (invoices, contracts, proposals, orders,...
deleteLineCommon(User $user, $idline, $notrigger=0)
Delete a line of object in database.
createCommon(User $user, $notrigger=0)
Create object in the database.
setStatut($status, $elementId=null, $elementType='', $trigkey='', $fieldstatus='fk_statut')
Set status of an object.
updateCommon(User $user, $notrigger=0)
Update object into database.
initAsSpecimenCommon()
Initialise object with example values Id must be 0 if object instance is a specimen.
fetchCommon($id, $ref=null, $morewhere='', $noextrafields=0)
Load object in memory from the database.
deleteCommon(User $user, $notrigger=0, $forcechilddeletion=0)
Delete object in database.
Parent class for class inheritance lines of business objects This class is useless for the moment so ...
Class to manage Dolibarr database access.
getNomUrl($withpicto=0, $option='', $notooltip=0, $morecss='', $save_lastsearch_value=-1)
Return a link to the object card (with optionally the picto)
create(User $user, $notrigger=0)
Create object into database.
setRecorded(User $user, $notrigger=0)
Set to inventory to status "Closed".
LibStatut($status, $mode=0)
Return the status.
getKanbanView($option='', $arraydata=null)
Return a thumb for kanban views.
__construct(DoliDB $db)
Constructor.
getLibStatut($mode=0)
Return the label of the status.
info($id)
Charge les information d'ordre info dans l'objet commande.
setDraft(User $user, $notrigger=0)
Go back to draft.
update(User $user, $notrigger=0)
Load object lines in memory from the database.
setCanceled(User $user, $notrigger=0)
Set to Canceled.
validate(User $user, $notrigger=0, $include_sub_warehouse=0)
Validate inventory (start it)
initAsSpecimen()
Initialise object with example values Id must be 0 if object instance is a specimen.
deleteLine(User $user, $idline, $notrigger=0)
Delete a line of object in database.
fetch($id, $ref=null)
Load object in memory from the database.
getChildWarehouse($id, &$TChildWarehouse)
Return the child warehouse of the current one.
createFromClone(User $user, $fromid)
Clone and object into another one.
update(User $user, $notrigger=0)
Update object into database.
__construct($db)
Constructor.
create(User $user, $notrigger=0)
Create object in database.
fetch($id, $ref=null)
Load object in memory from the database.
Class to manage Dolibarr users.
print $langs trans("Ref").' m titre as m m statut as status
Or an array listing all the potential status of the object: array: int of the status => translated la...
img_object($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0)
Show a picto called object_picto (generic function)
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2)
Show picto whatever it's its name (generic function)
dol_now($mode='auto')
Return date for now.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
dolGetStatus($statusLabel='', $statusLabelShort='', $html='', $statusType='status0', $displayMode=0, $url='', $params=array())
Output the badge of a status.
dol_buildpath($path, $type=0, $returnemptyifnotfound=0)
Return path of url or filesystem.
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
global $conf
The following vars must be defined: $type2label $form $conf, $lang, The following vars may also be de...