28require_once DOL_DOCUMENT_ROOT.
'/core/class/commonobject.class.php';
38 public $module =
'asset';
43 public $element =
'asset';
48 public $table_element =
'asset';
53 public $picto =
'asset';
59 public $fk_element =
'fk_asset';
67 protected $childtablesoncascade = array(
68 '@AssetAccountancyCodes:/asset/class/assetaccountancycodes.class.php:fk_asset',
69 '@AssetAccountancyCodesFiscal:/asset/class/assetaccountancycodesfiscal.class.php:fk_asset'
73 const STATUS_DRAFT = 0;
74 const STATUS_VALIDATED = 1;
75 const STATUS_DISPOSED = 9;
108 public $fields = array(
109 'rowid' => array(
'type' =>
'integer',
'label' =>
'TechnicalID',
'enabled' => 1,
'position' => 1,
'notnull' => 1,
'visible' => 0,
'noteditable' => 1,
'index' => 1,
'css' =>
'left',
'comment' =>
"Id"),
110 'entity' => array(
'type' =>
'integer',
'label' =>
'Entity',
'enabled' => 1,
'visible' => 0,
'notnull' => 1,
'default' =>
'1',
'index' => 1,
'position' => 5),
111 'ref' => array(
'type' =>
'varchar(128)',
'label' =>
'Ref',
'enabled' => 1,
'position' => 20,
'notnull' => 1,
'visible' => 4,
'noteditable' => 0,
'default' =>
'(PROV)',
'index' => 1,
'searchall' => 1,
'showoncombobox' => 1,
'validate' => 1,
'comment' =>
"Reference of object",
"css" =>
"maxwidth150"),
112 'label' => array(
'type' =>
'varchar(255)',
'label' =>
'Label',
'enabled' => 1,
'position' => 30,
'notnull' => 1,
'visible' => 1,
'searchall' => 1,
'csslist' =>
'tdoverflowmax125',
'css' =>
'minwidth300',
'cssview' =>
'wordbreak',
'showoncombobox' => 2,
'validate' => 1,),
113 'fk_asset_model' => array(
'type' =>
'integer:AssetModel:asset/class/assetmodel.class.php:1:((status:=:1) and (entity:IN:__SHARED_ENTITIES__))',
'label' =>
'AssetModel',
'enabled' => 1,
'position' => 40,
'notnull' => 0,
'visible' => 1,
'index' => 1,
'validate' => 1,
'csslist' =>
'tdoverflowmax75',
'css' =>
'maxwidth300'),
114 'qty' => array(
'type' =>
'real',
'label' =>
'Qty',
'enabled' => 1,
'position' => 50,
'notnull' => 1,
'visible' => 0,
'default' =>
'1',
'isameasure' => 1,
'css' =>
'maxwidth75imp',
'validate' => 1,),
115 'acquisition_type' => array(
'type' =>
'smallint',
'label' =>
'AssetAcquisitionType',
'enabled' => 1,
'position' => 60,
'notnull' => 1,
'visible' => 1,
'arrayofkeyval' => array(0 =>
'AssetAcquisitionTypeNew', 1 =>
'AssetAcquisitionTypeOccasion'),
'validate' => 1,
'csslist' =>
'tdoverflowmax75'),
116 'asset_type' => array(
'type' =>
'smallint',
'label' =>
'AssetType',
'enabled' => 1,
'position' => 70,
'notnull' => 1,
'visible' => 1,
'arrayofkeyval' => array(0 =>
'AssetTypeIntangible', 1 =>
'AssetTypeTangible', 2 =>
'AssetTypeInProgress', 3 =>
'AssetTypeFinancial'),
'validate' => 1,
'csslist' =>
'tdoverflowmax75'),
117 'not_depreciated' => array(
'type' =>
'boolean',
'label' =>
'AssetNotDepreciated',
'enabled' => 1,
'position' => 80,
'notnull' => 0,
'default' =>
'0',
'visible' => 1,
'validate' => 1,
'csslist' =>
'maxwidth50 tdoverflowmax50',
'css' =>
'maxwidth50imp'),
118 'date_acquisition' => array(
'type' =>
'date',
'label' =>
'AssetDateAcquisition',
'enabled' => 1,
'position' => 90,
'notnull' => 1,
'visible' => 1,),
119 'date_start' => array(
'type' =>
'date',
'label' =>
'AssetDateStart',
'enabled' => 1,
'position' => 100,
'notnull' => 0,
'visible' => -1,),
120 'acquisition_value_ht' => array(
'type' =>
'price',
'label' =>
'AssetAcquisitionValueHT',
'enabled' => 1,
'position' => 110,
'notnull' => 1,
'visible' => 1,
'isameasure' => 1,
'validate' => 1,),
121 'recovered_vat' => array(
'type' =>
'price',
'label' =>
'AssetRecoveredVAT',
'enabled' => 1,
'position' => 120,
'notnull' => 0,
'visible' => 1,
'isameasure' => 1,
'validate' => 1,),
122 'reversal_date' => array(
'type' =>
'date',
'label' =>
'AssetReversalDate',
'enabled' => 1,
'position' => 130,
'notnull' => 0,
'visible' => 1,),
123 'reversal_amount_ht' => array(
'type' =>
'price',
'label' =>
'AssetReversalAmountHT',
'enabled' => 1,
'position' => 140,
'notnull' => 0,
'visible' => 1,
'isameasure' => 1,
'validate' => 1,
'csslist' =>
'maxwidth50'),
124 'disposal_date' => array(
'type' =>
'date',
'label' =>
'AssetDisposalDate',
'enabled' => 1,
'position' => 200,
'notnull' => 0,
'visible' => -2,),
125 'disposal_amount_ht' => array(
'type' =>
'price',
'label' =>
'AssetDisposalAmount',
'enabled' => 1,
'position' => 210,
'notnull' => 0,
'visible' => -2,
'default' =>
'0',
'isameasure' => 1,
'validate' => 1,),
126 'fk_disposal_type' => array(
'type' =>
'sellist:c_asset_disposal_type:label:rowid::active=1',
'label' =>
'AssetDisposalType',
'enabled' => 1,
'position' => 220,
'notnull' => 0,
'visible' => -2,
'index' => 1,
'validate' => 1,),
127 'disposal_depreciated' => array(
'type' =>
'boolean',
'label' =>
'AssetDisposalDepreciated',
'enabled' => 1,
'position' => 230,
'notnull' => 0,
'default' =>
'0',
'visible' => -2,
'validate' => 1,),
128 'disposal_subject_to_vat' => array(
'type' =>
'boolean',
'label' =>
'AssetDisposalSubjectToVat',
'enabled' => 1,
'position' => 240,
'notnull' => 0,
'default' =>
'0',
'visible' => -2,
'validate' => 1,),
129 'note_public' => array(
'type' =>
'html',
'label' =>
'NotePublic',
'enabled' => 1,
'position' => 300,
'notnull' => 0,
'visible' => 0,
'validate' => 1,),
130 'note_private' => array(
'type' =>
'html',
'label' =>
'NotePrivate',
'enabled' => 1,
'position' => 301,
'notnull' => 0,
'visible' => 0,
'validate' => 1,),
131 'date_creation' => array(
'type' =>
'datetime',
'label' =>
'DateCreation',
'enabled' => 1,
'position' => 500,
'notnull' => 1,
'visible' => -2,),
132 'tms' => array(
'type' =>
'timestamp',
'label' =>
'DateModification',
'enabled' => 1,
'position' => 501,
'notnull' => 0,
'visible' => -2,),
133 'date_valid' => array(
'type' =>
'datetime',
'label' =>
'DateValidation',
'enabled' => 1,
'visible' => -2,
'position' => 502,
'notnull' => 0,),
134 'fk_user_creat' => array(
'type' =>
'integer:User:user/class/user.class.php',
'label' =>
'UserAuthor',
'enabled' => 1,
'position' => 510,
'notnull' => 1,
'visible' => -2,
'foreignkey' =>
'user.rowid',),
135 'fk_user_modif' => array(
'type' =>
'integer:User:user/class/user.class.php',
'label' =>
'UserModif',
'enabled' => 1,
'position' => 511,
'notnull' => -1,
'visible' => -2,),
136 'fk_user_valid' => array(
'type' =>
'integer:User:user/class/user.class.php',
'label' =>
'UserValidation',
'picto' =>
'user',
'enabled' => 1,
'visible' => -2,
'position' => 512,
'notnull' => 0,
'csslist' =>
'tdoverflowmax100'),
137 'last_main_doc' => array(
'type' =>
'varchar(255)',
'label' =>
'LastMainDoc',
'enabled' => 1,
'position' => 600,
'notnull' => 0,
'visible' => 0,),
138 'import_key' => array(
'type' =>
'varchar(14)',
'label' =>
'ImportId',
'enabled' => 1,
'position' => 1000,
'notnull' => -1,
'visible' => -2,),
139 'model_pdf' => array(
'type' =>
'varchar(255)',
'label' =>
'Model pdf',
'enabled' => 1,
'position' => 1010,
'notnull' => -1,
'visible' => 0,),
140 'status' => array(
'type' =>
'smallint',
'label' =>
'Status',
'enabled' => 1,
'position' => 1000,
'notnull' => 1,
'default' =>
'0',
'visible' => 2,
'index' => 1,
'arrayofkeyval' => array(0 =>
'Draft', 1 =>
'Validated', 9 =>
'Canceled'),
'validate' => 1,),
158 public $fk_asset_model;
162 public $reversal_amount_ht;
166 public $acquisition_value_ht;
170 public $recovered_vat;
174 public $reversal_date;
178 public $date_acquisition;
190 public $acquisition_type;
198 public $not_depreciated;
202 public $disposal_date;
206 public $disposal_amount_ht;
210 public $fk_disposal_type;
214 public $disposal_depreciated;
218 public $disposal_subject_to_vat;
222 public $supplier_invoice_id;
230 public $note_private;
238 public $fk_user_creat;
242 public $fk_user_modif;
246 public $fk_user_valid;
250 public $last_main_doc;
269 public $asset_depreciation_options;
274 public $asset_accountancy_codes;
279 public $depreciation_lines = array();
293 $this->ismultientitymanaged = 1;
294 $this->isextrafieldmanaged = 1;
297 $this->fields[
'rowid'][
'visible'] = 0;
299 if (!
isModEnabled(
'multicompany') && isset($this->fields[
'entity'])) {
300 $this->fields[
'entity'][
'enabled'] = 0;
304 foreach ($this->fields as $key => $val) {
305 if (isset($val[
'enabled']) && empty($val[
'enabled'])) {
306 unset($this->fields[$key]);
311 if (is_object($langs)) {
312 foreach ($this->fields as $key => $val) {
313 if (!empty($val[
'arrayofkeyval']) && is_array($val[
'arrayofkeyval'])) {
314 foreach ($val[
'arrayofkeyval'] as $key2 => $val2) {
315 $this->fields[$key][
'arrayofkeyval'][$key2] = $langs->trans($val2);
331 if (!isset($this->date_start) || $this->date_start ===
"") {
332 $this->date_start = $this->date_acquisition;
337 $result = $result_create = $this->
createCommon($user, $notrigger);
338 if ($result > 0 && $this->fk_asset_model > 0) {
342 if ($this->supplier_invoice_id > 0) {
348 $this->db->rollback();
353 return $result > 0 ? $result_create : $result;
458 public function fetch($id, $ref =
null)
465 } elseif ($res > 0) {
466 $this->fields[
'date_acquisition'][
'noteditable'] = 1;
467 $this->fields[
'date_start'][
'noteditable'] = 1;
468 $this->fields[
'acquisition_value_ht'][
'noteditable'] = 1;
469 $this->fields[
'recovered_vat'][
'noteditable'] = 1;
470 $this->fields[
'reversal_date'][
'noteditable'] = 1;
471 $this->fields[
'reversal_amount_ht'][
'noteditable'] = 1;
491 public function fetchAll($sortorder =
'', $sortfield =
'', $limit = 0, $offset = 0, $filter =
'', $filtermode =
'AND')
499 $sql .=
" FROM ".MAIN_DB_PREFIX.$this->table_element.
" as t";
500 if (isset($this->ismultientitymanaged) && $this->ismultientitymanaged == 1) {
501 $sql .=
" WHERE t.entity IN (".getEntity($this->element).
")";
503 $sql .=
" WHERE 1 = 1";
508 $sql .= forgeSQLFromUniversalSearchCriteria($filter, $errormessage);
510 $this->errors[] = $errormessage;
511 dol_syslog(__METHOD__.
' '.implode(
',', $this->errors), LOG_ERR);
516 if (!empty($sortfield)) {
517 $sql .= $this->db->order($sortfield, $sortorder);
519 if (!empty($limit)) {
520 $sql .= $this->db->plimit($limit, $offset);
523 $resql = $this->db->query($sql);
525 $num = $this->db->num_rows($resql);
527 while ($i < ($limit ? min($limit, $num) : $num)) {
528 $obj = $this->db->fetch_object($resql);
530 $record =
new self($this->db);
531 $record->setVarsFromFetchObj($obj);
533 $records[$record->id] = $record;
537 $this->db->free($resql);
541 $this->errors[] =
'Error '.$this->db->lasterror();
542 dol_syslog(__METHOD__.
' '.implode(
',', $this->errors), LOG_ERR);
557 if (!isset($this->date_start) || $this->date_start ===
"") {
558 $this->date_start = $this->date_acquisition;
564 if ($result > 0 && $this->fk_asset_model > 0 && $this->fk_asset_model != $this->oldcopy->fk_asset_model) {
568 $this->date_start != $this->oldcopy->date_start ||
569 $this->acquisition_value_ht != $this->oldcopy->acquisition_value_ht ||
570 $this->reversal_date != $this->oldcopy->reversal_date ||
571 $this->reversal_amount_ht != $this->oldcopy->reversal_amount_ht ||
572 ($this->fk_asset_model > 0 && $this->fk_asset_model != $this->oldcopy->fk_asset_model)
579 $this->db->rollback();
594 public function delete(
User $user, $notrigger = 0)
596 $sql =
'DELETE FROM '.MAIN_DB_PREFIX.
'asset_depreciation_codes_economic WHERE fk_asset = '.((int) $this->
id);
597 $this->db->query($sql);
599 $sql =
'DELETE FROM '.MAIN_DB_PREFIX.
'asset_depreciation_codes_fiscal WHERE fk_asset = '.((int) $this->
id);
600 $this->db->query($sql);
602 $sql =
'DELETE FROM '.MAIN_DB_PREFIX.
'asset_depreciation_options_fiscal WHERE fk_asset = '.((int) $this->
id);
603 $this->db->query($sql);
605 $sql =
'DELETE FROM '.MAIN_DB_PREFIX.
'asset_depreciation_options_economic WHERE fk_asset = '.((int) $this->
id);
606 $this->db->query($sql);
608 $sql =
'DELETE FROM '.MAIN_DB_PREFIX.
'asset_depreciation WHERE fk_asset = '.((int) $this->
id);
609 $this->db->query($sql);
625 $langs->load(
'assets');
628 $this->
id = $this->
id > 0 ? $this->id : 0;
629 $this->fk_asset_model = $this->fk_asset_model > 0 ? $this->fk_asset_model : 0;
633 if (empty($this->
id)) {
634 $this->errors[] = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Asset") .
' (' . $langs->transnoentitiesnoconv(
"TechnicalID") .
')');
637 if (empty($this->fk_asset_model)) {
638 $this->errors[] = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"AssetModel") .
' (' . $langs->transnoentitiesnoconv(
"TechnicalID") .
')');
649 require_once DOL_DOCUMENT_ROOT .
'/asset/class/assetdepreciationoptions.class.php';
651 $result = $options_model->fetchDeprecationOptions(0, $this->fk_asset_model);
653 $this->error = $options_model->error;
654 $this->errors = $options_model->errors;
656 } elseif ($result > 0) {
658 $result = $options->fetchDeprecationOptions($this->
id);
660 $this->error = $options->error;
661 $this->errors = $options->errors;
666 foreach ($options_model->deprecation_options as $mode_key => $fields) {
667 foreach ($fields as $field_key => $value) {
668 $options->deprecation_options[$mode_key][$field_key] = $value;
672 $result = $options->updateDeprecationOptions($user, $this->
id, 0, $notrigger);
674 $this->error = $options->error;
675 $this->errors = $options->errors;
684 require_once DOL_DOCUMENT_ROOT .
'/asset/class/assetaccountancycodes.class.php';
686 $result = $accountancy_codes_model->fetchAccountancyCodes(0, $this->fk_asset_model);
688 $this->error = $accountancy_codes_model->error;
689 $this->errors = $accountancy_codes_model->errors;
691 } elseif ($result > 0) {
693 $result = $accountancy_codes->fetchAccountancyCodes($this->
id);
695 $this->error = $accountancy_codes->error;
696 $this->errors = $accountancy_codes->errors;
701 foreach ($accountancy_codes_model->accountancy_codes as $mode_key => $fields) {
702 foreach ($fields as $field_key => $value) {
703 $accountancy_codes->accountancy_codes[$mode_key][$field_key] = $value;
707 $result = $accountancy_codes->updateAccountancyCodes($user, $this->
id, 0, $notrigger);
709 $this->error = $accountancy_codes->error;
710 $this->errors = $accountancy_codes->errors;
718 $this->db->rollback();
734 $langs->load(
'assets');
735 $this->depreciation_lines = array();
738 $this->
id = $this->
id > 0 ? $this->id : 0;
742 if (empty($this->
id)) {
743 $this->errors[] = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Asset") .
' (' . $langs->transnoentitiesnoconv(
"TechnicalID") .
')');
750 $sql =
"SELECT ad.rowid, ad.depreciation_mode, ad.ref, ad.depreciation_date, ad.depreciation_ht, ad.cumulative_depreciation_ht,";
751 $sql .=
" " . $this->db->ifsql(
'EXISTS (SELECT fk_docdet FROM ' . MAIN_DB_PREFIX .
'accounting_bookkeeping as ab WHERE ab.doc_type = \'asset\' AND ab.fk_docdet = ad.rowid)',
'1',
'0') .
" AS bookkeeping";
752 $sql .=
" FROM " . MAIN_DB_PREFIX .
"asset_depreciation AS ad";
753 $sql .=
" WHERE ad.fk_asset = " . (int) $this->
id;
754 $sql .=
" ORDER BY ad.depreciation_date ASC";
756 $resql = $this->db->query($sql);
758 $this->errors[] = $langs->trans(
'AssetErrorFetchDepreciationLines') .
': ' . $this->db->lasterror();
762 while ($obj = $this->db->fetch_object($resql)) {
763 if (!isset($this->depreciation_lines[$obj->depreciation_mode])) {
764 $this->depreciation_lines[$obj->depreciation_mode] = array();
766 $this->depreciation_lines[$obj->depreciation_mode][] = array(
769 'depreciation_date' => $this->db->jdate($obj->depreciation_date),
770 'depreciation_ht' => $obj->depreciation_ht,
771 'cumulative_depreciation_ht' => $obj->cumulative_depreciation_ht,
772 'bookkeeping' => $obj->bookkeeping,
787 $langs->load(
'assets');
790 $this->
id = $this->
id > 0 ? $this->id : 0;
794 if (empty($this->
id)) {
795 $this->errors[] = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Asset") .
' (' . $langs->transnoentitiesnoconv(
"TechnicalID") .
')');
816 $sql =
"SELECT COUNT(*) AS has_bookkeeping";
817 $sql .=
" FROM " . MAIN_DB_PREFIX .
"asset_depreciation AS ad";
818 $sql .=
" LEFT JOIN (SELECT DISTINCT fk_docdet FROM " . MAIN_DB_PREFIX .
"accounting_bookkeeping WHERE doc_type = 'asset') AS iab ON iab.fk_docdet = ad.rowid";
819 $sql .=
" WHERE ad.fk_asset = " . (int) $this->
id;
820 $sql .=
" AND iab.fk_docdet IS NOT NULL";
822 $resql = $this->db->query($sql);
824 $this->errors[] = $langs->trans(
'AssetErrorFetchDepreciationLines') .
': ' . $this->db->lasterror();
828 if ($obj = $this->db->fetch_object($resql)) {
829 return $obj->has_bookkeeping > 0 ? 1 : 0;
847 public function addDepreciationLine($mode, $ref, $depreciation_date, $depreciation_ht, $cumulative_depreciation_ht, $accountancy_code_debit, $accountancy_code_credit)
850 $langs->load(
'assets');
853 $this->
id = $this->
id > 0 ? $this->id : 0;
854 $mode = strtolower(trim($mode));
856 $accountancy_code_debit = trim($accountancy_code_debit);
857 $accountancy_code_credit = trim($accountancy_code_credit);
861 if (empty($this->
id)) {
862 $this->errors[] = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Asset") .
' (' . $langs->transnoentitiesnoconv(
"TechnicalID") .
')');
869 $sql =
"INSERT INTO " . MAIN_DB_PREFIX .
"asset_depreciation(fk_asset, depreciation_mode, ref, depreciation_date, depreciation_ht, cumulative_depreciation_ht, accountancy_code_debit, accountancy_code_credit)";
870 $sql .=
" VALUES ( ";
871 $sql .=
" " . (int) $this->
id;
872 $sql .=
", '" . $this->db->escape($mode) .
"'";
873 $sql .=
", '" . $this->db->escape($ref) .
"'";
874 $sql .=
", '" . $this->db->idate($depreciation_date) .
"'";
875 $sql .=
", " . (float) $depreciation_ht;
876 $sql .=
", " . (float) $cumulative_depreciation_ht;
877 $sql .=
", '" . $this->db->escape($accountancy_code_debit) .
"'";
878 $sql .=
", '" . $this->db->escape($accountancy_code_credit) .
"'";
881 $resql = $this->db->query($sql);
883 $this->errors[] = $langs->trans(
'AssetErrorAddDepreciationLine') .
': ' . $this->db->lasterror();
897 global
$conf, $langs;
898 $langs->load(
'assets');
901 $this->
id = $this->
id > 0 ? $this->id : 0;
905 if (empty($this->
id)) {
906 $this->errors[] = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Asset") .
' (' . $langs->transnoentitiesnoconv(
"TechnicalID") .
')');
913 if (! empty($this->not_depreciated)) {
919 require_once DOL_DOCUMENT_ROOT .
'/asset/class/assetdepreciationoptions.class.php';
921 $result = $options->fetchDeprecationOptions($this->
id);
923 $this->error = $options->error;
924 $this->errors = $options->errors;
930 require_once DOL_DOCUMENT_ROOT .
'/asset/class/assetaccountancycodes.class.php';
932 $result = $accountancy_codes->fetchAccountancyCodes($this->
id);
934 $this->error = $accountancy_codes->error;
935 $this->errors = $accountancy_codes->errors;
943 foreach ($options->deprecation_options as $mode_key => $fields) {
944 $modes[$mode_key] = $this->db->escape($mode_key);
946 $sql =
"DELETE FROM " . MAIN_DB_PREFIX .
"asset_depreciation";
947 $sql .=
" WHERE fk_asset = " . (int) $this->
id;
948 $sql .=
" AND depreciation_mode NOT IN ('" . $this->db->sanitize(implode(
"', '", $modes)) .
"')";
950 $resql = $this->db->query($sql);
952 $this->errors[] = $langs->trans(
'AssetErrorClearDepreciationLines') .
': ' . $this->db->lasterror();
958 require_once DOL_DOCUMENT_ROOT .
'/core/lib/date.lib.php';
959 require_once DOL_DOCUMENT_ROOT .
'/core/lib/accounting.lib.php';
963 $init_fiscal_period_start = $dates[
'date_start'];
964 $init_fiscal_period_end = $dates[
'date_end'];
974 foreach ($options->deprecation_options as $mode_key => $fields) {
995 $sql =
"SELECT ad.depreciation_date, ad.cumulative_depreciation_ht";
996 $sql .=
" FROM " . MAIN_DB_PREFIX .
"asset_depreciation AS ad";
997 $sql .=
" LEFT JOIN (SELECT DISTINCT fk_docdet FROM " . MAIN_DB_PREFIX .
"accounting_bookkeeping WHERE doc_type = 'asset') AS iab ON iab.fk_docdet = ad.rowid";
998 $sql .=
" WHERE ad.fk_asset = " . (int) $this->
id;
999 $sql .=
" AND ad.depreciation_mode = '" . $this->db->escape($mode_key) .
"'";
1000 $sql .=
" AND iab.fk_docdet IS NOT NULL";
1001 $sql .=
" ORDER BY ad.depreciation_date DESC";
1004 $resql = $this->db->query($sql);
1006 $this->errors[] = $langs->trans(
'AssetErrorFetchMaxDepreciationDateForMode', $mode_key) .
': ' . $this->db->lasterror();
1010 $last_depreciation_date =
'';
1011 $last_cumulative_depreciation_ht = $this->reversal_amount_ht;
1012 if ($obj = $this->db->fetch_object($resql)) {
1013 $last_depreciation_date = $this->db->jdate($obj->depreciation_date);
1014 $last_cumulative_depreciation_ht = $obj->cumulative_depreciation_ht;
1018 $sql =
"UPDATE " . MAIN_DB_PREFIX . $this->db->sanitize($options->deprecation_options_fields[$mode_key][
'table']);
1019 $sql .=
" SET total_amount_last_depreciation_ht = " . ((float) (empty($last_cumulative_depreciation_ht) ? 0 : $last_cumulative_depreciation_ht));
1020 $sql .=
" WHERE fk_asset = " . (int) $this->
id;
1021 $resql = $this->db->query($sql);
1023 $this->errors[] = $langs->trans(
'AssetErrorSetLastCumulativeDepreciation') .
': ' . $this->db->lasterror();
1029 $sql =
"DELETE FROM " . MAIN_DB_PREFIX .
"asset_depreciation";
1030 $sql .=
" WHERE fk_asset = " . (int) $this->
id;
1031 $sql .=
" AND depreciation_mode = '" . $this->db->escape($mode_key) .
"'";
1032 $sql .=
" AND NOT EXISTS (SELECT fk_docdet FROM " . MAIN_DB_PREFIX .
"accounting_bookkeeping WHERE doc_type = 'asset' AND fk_docdet = " . MAIN_DB_PREFIX .
"asset_depreciation.rowid)";
1033 if ($last_depreciation_date !==
"") {
1034 $sql .=
" AND ref <> ''";
1036 $resql = $this->db->query($sql);
1038 $this->errors[] = $langs->trans(
'AssetErrorClearDepreciationLines') .
': ' . $this->db->lasterror();
1044 $depreciation_date_start = $this->date_start > $this->date_acquisition ? $this->date_start : $this->date_acquisition;
1045 $depreciation_date_end =
dol_time_plus_duree(
dol_time_plus_duree((
int) $depreciation_date_start, (
float) $fields[
'duration'], $fields[
'duration_type'] == 1 ?
'm' : ($fields[
'duration_type'] == 2 ?
'd' :
'y')), -1,
'd');
1046 $depreciation_amount = $fields[
'amount_base_depreciation_ht'];
1047 if ($fields[
'duration_type'] == 2) {
1048 $fiscal_period_start = $depreciation_date_start;
1049 $fiscal_period_end = $depreciation_date_start;
1050 } elseif ($fields[
'duration_type'] == 1) {
1051 $date_temp =
dol_getdate((
int) $depreciation_date_start);
1052 $fiscal_period_start =
dol_get_first_day($date_temp[
'year'], $date_temp[
'mon'],
false);
1053 $fiscal_period_end =
dol_get_last_day($date_temp[
'year'], $date_temp[
'mon'],
false);
1055 $fiscal_period_start = $init_fiscal_period_start;
1056 $fiscal_period_end = $init_fiscal_period_end;
1058 $cumulative_depreciation_ht = (float) $last_cumulative_depreciation_ht;
1059 $depreciation_period_amount = $depreciation_amount - (float) $this->reversal_amount_ht;
1060 $start_date = $depreciation_date_start;
1061 $disposal_date = isset($this->disposal_date) && $this->disposal_date !==
"" ? $this->disposal_date :
"";
1062 $finish_date = $disposal_date !==
"" ? $disposal_date : $depreciation_date_end;
1063 $accountancy_code_depreciation_debit_key = $accountancy_codes->accountancy_codes_fields[$mode_key][
'depreciation_debit'];
1064 $accountancy_code_depreciation_debit = $accountancy_codes->accountancy_codes[$mode_key][$accountancy_code_depreciation_debit_key];
1065 $accountancy_code_depreciation_credit_key = $accountancy_codes->accountancy_codes_fields[$mode_key][
'depreciation_credit'];
1066 $accountancy_code_credit = $accountancy_codes->accountancy_codes[$mode_key][$accountancy_code_depreciation_credit_key];
1070 if ($last_depreciation_date ===
"" && ($depreciation_date_start < $fiscal_period_start || is_numeric($this->reversal_date))) {
1071 if (is_numeric($this->reversal_date)) {
1072 if ($this->reversal_date < $fiscal_period_start) {
1073 $this->errors[] = $langs->trans(
'AssetErrorReversalDateNotGreaterThanCurrentBeginFiscalDateForMode', $mode_key);
1078 if (empty($this->reversal_amount_ht)) {
1079 $this->errors[] = $langs->trans(
'AssetErrorReversalAmountNotProvidedForMode', $mode_key);
1084 $start_date = $this->reversal_date;
1085 $result = $this->
addDepreciationLine($mode_key,
'', $start_date, (
float) $this->reversal_amount_ht, (
float) $this->reversal_amount_ht, $accountancy_code_depreciation_debit, $accountancy_code_credit);
1091 $this->errors[] = $langs->trans(
'AssetErrorReversalDateNotProvidedForMode', $mode_key);
1099 $nb_days_in_year =
getDolGlobalInt(
'ASSET_DEPRECIATION_DURATION_PER_YEAR', 360);
1100 $nb_days_in_month =
getDolGlobalInt(
'ASSET_DEPRECIATION_DURATION_PER_MONTH', 30);
1101 $period_amount = (float) ($fields[
'duration'] > 0 ?
price2num($depreciation_period_amount / $fields[
'duration'],
'MT') : 0);
1102 $first_period_found =
false;
1105 $first_period_date = $fiscal_period_start;
1107 $ref_date_format =
"%Y" . ($fields[
'duration_type'] == 1 || $fields[
'duration_type'] == 2 ?
'-%m' :
'') . ($fields[
'duration_type'] == 2 ?
'-%d' :
'');
1111 $max_loop = $fields[
'duration'] + 2;
1115 if ($idx_loop > $max_loop) {
1119 if ($last_depreciation_date < $fiscal_period_end && ($first_period_date <= $start_date || $first_period_found)) {
1121 if ($fiscal_period_start <= $disposal_date && $disposal_date <= $fiscal_period_end && empty($this->disposal_depreciated)) {
1125 $first_period_found =
true;
1127 $period_begin =
dol_print_date($fiscal_period_start, $ref_date_format);
1128 $period_end =
dol_print_date($fiscal_period_end, $ref_date_format);
1129 $ref = $period_begin . ($period_begin != $period_end ?
' - ' . $period_end :
'');
1130 if ($fiscal_period_start <= $disposal_date && $disposal_date <= $fiscal_period_end) {
1131 $ref .=
' - ' . $langs->transnoentitiesnoconv(
'AssetDisposal');
1134 $begin_date = $fiscal_period_start < $start_date && $start_date <= $fiscal_period_end ? $start_date : $fiscal_period_start;
1135 $end_date = $fiscal_period_start < $finish_date && $finish_date <= $fiscal_period_end ? $finish_date : $fiscal_period_end;
1136 if ($fields[
'duration_type'] == 2) {
1137 $depreciation_ht = $period_amount;
1138 } elseif ($fields[
'duration_type'] == 1) {
1139 $nb_days = min($nb_days_in_month,
num_between_day($begin_date, $end_date, 1));
1140 if ($nb_days >= 28) {
1142 if ($date_temp[
'mon'] == 2) {
1146 $depreciation_ht = (float)
price2num($period_amount * $nb_days / $nb_days_in_month,
'MT');
1149 if (($nb_days_real > 366) || (
num_between_day($fiscal_period_start, $fiscal_period_end, 1) < $nb_days_in_year)) {
1150 $nb_days = $nb_days_real;
1152 $nb_days = min($nb_days_in_year, $nb_days_real);
1154 $depreciation_ht = (float)
price2num($period_amount * $nb_days / $nb_days_in_year,
'MT');
1157 if ($idx_loop < $max_loop) {
1158 $depreciation_ht = ceil($depreciation_ht);
1162 if ($fiscal_period_start <= $depreciation_date_end && $depreciation_date_end <= $fiscal_period_end) {
1163 $depreciation_ht = (float)
price2num($depreciation_amount - (
float) $cumulative_depreciation_ht,
'MT');
1164 $cumulative_depreciation_ht = $depreciation_amount;
1166 $cumulative_depreciation_ht += $depreciation_ht;
1169 $result = $this->
addDepreciationLine($mode_key, $ref, $fiscal_period_end, $depreciation_ht, (
float) $cumulative_depreciation_ht, $accountancy_code_depreciation_debit, $accountancy_code_credit);
1179 if ($fields[
'duration_type'] == 0) {
1183 if ($next_fy !==
null) {
1185 $fiscal_period_start = $next_fy[
'date_start'];
1186 $fiscal_period_end = $next_fy[
'date_end'];
1190 $current_fy_start_parts =
dol_getdate($fiscal_period_start);
1198 } elseif ($fields[
'duration_type'] == 1) {
1201 $fiscal_period_end = $fiscal_period_start;
1203 $last_period_date = $disposal_date !==
"" && $disposal_date < $depreciation_date_end ? $disposal_date : $depreciation_date_end;
1204 }
while ($fiscal_period_start < $last_period_date);
1213 $this->db->rollback();
1216 $this->db->commit();
1230 $langs->load(
'assets');
1233 $asset_depreciation_id = $asset_depreciation_id > 0 ? $asset_depreciation_id : 0;
1237 if (empty($asset_depreciation_id)) {
1238 $this->errors[] = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"AssetDepreciation") .
' (' . $langs->transnoentitiesnoconv(
"TechnicalID") .
')');
1247 require_once DOL_DOCUMENT_ROOT .
'/asset/class/assetdepreciationoptions.class.php';
1252 $sql =
"SELECT fk_asset, depreciation_mode, cumulative_depreciation_ht";
1253 $sql .=
" FROM " . MAIN_DB_PREFIX .
"asset_depreciation";
1254 $sql .=
" WHERE rowid = " . (int) $asset_depreciation_id;
1255 $resql = $this->db->query($sql);
1257 $this->errors[] = $langs->trans(
'AssetErrorFetchCumulativeDepreciation') .
': ' . $this->db->lasterror();
1260 if ($obj = $this->db->fetch_object($resql)) {
1261 $mode_key = $obj->depreciation_mode;
1262 if (!empty($options->deprecation_options_fields[$mode_key])) {
1263 $sql =
"UPDATE " . MAIN_DB_PREFIX . $this->db->sanitize($options->deprecation_options_fields[$mode_key][
'table']);
1264 $sql .=
" SET total_amount_last_depreciation_ht = " . ((float) $obj->cumulative_depreciation_ht);
1265 $sql .=
" WHERE fk_asset = " . (int) $obj->fk_asset;
1266 $resql = $this->db->query($sql);
1268 $this->errors[] = $langs->trans(
'AssetErrorSetLastCumulativeDepreciation') .
': ' . $this->db->lasterror();
1276 $this->db->rollback();
1279 $this->db->commit();
1292 public function dispose($user, $disposal_invoice_id, $notrigger = 0)
1294 global
$conf, $langs;
1297 if ($this->
status == self::STATUS_DISPOSED) {
1303 $required_fields = array(
'disposal_date',
'disposal_date',
'fk_disposal_type');
1304 foreach ($required_fields as $field) {
1305 $this->fields[$field][
'notnull'] = 1;
1307 $result = $this->
update($user, 1);
1308 foreach ($required_fields as $field) {
1309 $this->fields[$field][
'notnull'] = 0;
1312 if ($disposal_invoice_id > 0) {
1315 $result = $this->
setStatusCommon($user, self::STATUS_DISPOSED, $notrigger,
'ASSET_DISPOSED');
1322 $this->db->rollback();
1324 $this->db->commit();
1329 if (method_exists($this,
'generateDocument')) {
1330 global $hidedetails, $hidedesc, $hideref;
1331 $outputlangs = $langs;
1334 $newlang =
GETPOST(
'lang_id',
'aZ09');
1337 $newlang = $this->thirdparty->default_lang;
1339 if (!empty($newlang)) {
1341 $outputlangs->setDefaultLang($newlang);
1343 $model = $this->model_pdf;
1344 $ret = $this->
fetch($this->
id);
1346 $this->generateDocument($model, $outputlangs, $hidedetails, $hidedesc, $hideref);
1360 public function reopen($user, $notrigger = 0)
1362 global
$conf, $langs;
1365 if ($this->
status != self::STATUS_DISPOSED) {
1372 $this->disposal_date =
null;
1373 $this->disposal_amount_ht =
null;
1374 $this->fk_disposal_type =
null;
1375 $this->disposal_depreciated = 0;
1376 $this->disposal_subject_to_vat = 0;
1377 $result = $this->
update($user, 1);
1380 $result = $this->
setStatusCommon($user, self::STATUS_VALIDATED, $notrigger,
'ASSET_REOPEN');
1387 $this->db->rollback();
1389 $this->db->commit();
1394 if (method_exists($this,
'generateDocument')) {
1395 global $hidedetails, $hidedesc, $hideref;
1396 $outputlangs = $langs;
1399 $newlang =
GETPOST(
'lang_id',
'aZ09');
1402 $newlang = $this->thirdparty->default_lang;
1404 if (!empty($newlang)) {
1406 $outputlangs->setDefaultLang($newlang);
1408 $model = $this->model_pdf;
1409 $ret = $this->
fetch($this->
id);
1411 $this->generateDocument($model, $outputlangs, $hidedetails, $hidedesc, $hideref);
1429 public function getNomUrl($withpicto = 0, $option =
'', $maxlen = 0, $notooltip = 0, $morecss =
'', $save_lastsearch_value = -1)
1431 global $db,
$conf, $langs, $hookmanager;
1432 global $dolibarr_main_authentication, $dolibarr_main_demo;
1433 global $menumanager;
1435 if (!empty(
$conf->dol_no_mouse_hover)) {
1441 $label =
img_picto(
'', $this->picto).
' <u>'.$langs->trans(
"Asset").
'</u>';
1442 if (isset($this->
status)) {
1443 $label .=
' '.$this->getLibStatut(5);
1446 $label .=
'<b>'.$langs->trans(
'Ref').
':</b> '.$this->ref;
1448 $url =
dol_buildpath(
'/asset/card.php', 1).
'?id='.$this->id;
1450 if ($option !=
'nolink') {
1452 $add_save_lastsearch_values = ($save_lastsearch_value == 1 ? 1 : 0);
1453 if ($save_lastsearch_value == -1 && isset($_SERVER[
"PHP_SELF"]) && preg_match(
'/list\.php/', $_SERVER[
"PHP_SELF"])) {
1454 $add_save_lastsearch_values = 1;
1456 if ($add_save_lastsearch_values) {
1457 $url .=
'&save_lastsearch_values=1';
1462 if (empty($notooltip)) {
1464 $label = $langs->trans(
"ShowAsset");
1465 $linkclose .=
' alt="'.dolPrintHTMLForAttribute($label).
'"';
1467 $linkclose .=
' title="'.dolPrintHTMLForAttribute($label).
'"';
1468 $linkclose .=
' class="classfortooltip'.($morecss ?
' '.$morecss :
'').
'"';
1470 $linkclose = ($morecss ?
' class="'.$morecss.
'"' :
'');
1473 if ($option ==
'nolink') {
1474 $linkstart =
'<span';
1476 $linkstart =
'<a href="'.$url.
'"';
1478 $linkstart .= $linkclose.
'>';
1479 if ($option ==
'nolink') {
1480 $linkend =
'</span>';
1485 $result .= $linkstart;
1487 if (empty($this->showphoto_on_popup)) {
1489 $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);
1493 require_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
1495 list($class, $module) = explode(
'@', $this->picto);
1498 $filename = $filearray[0][
'name'];
1499 if (!empty($filename)) {
1500 $pospoint = strpos($filearray[0][
'name'],
'.');
1502 $pathtophoto = $class.
'/'.$this->
ref.
'/thumbs/'.substr($filename, 0, $pospoint).
'_mini'.substr($filename, $pospoint);
1503 if (!
getDolGlobalString(strtoupper($module.
'_'.$class).
'_FORMATLISTPHOTOSASUSERS')) {
1504 $result .=
'<div class="floatleft inline-block valignmiddle divphotoref"><div class="photoref"><img class="photo'.$module.
'" alt="No photo" border="0" src="'.DOL_URL_ROOT.
'/viewimage.php?modulepart='.$module.
'&entity='.
$conf->entity.
'&file='.urlencode($pathtophoto).
'"></div></div>';
1506 $result .=
'<div class="floatleft inline-block valignmiddle divphotoref"><img class="photouserphoto userphoto" alt="No photo" border="0" src="'.DOL_URL_ROOT.
'/viewimage.php?modulepart='.$module.
'&entity='.
$conf->entity.
'&file='.urlencode($pathtophoto).
'"></div>';
1509 $result .=
'</div>';
1511 $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);
1516 if ($withpicto != 2) {
1518 if ($option ==
'label') {
1519 $name = $this->label;
1520 } elseif ($option ==
'with_label') {
1521 $name .=
' - ' . $this->label;
1526 $result .= $linkend;
1530 $hookmanager->initHooks(array($this->element .
'dao'));
1531 $parameters = array(
'id' => $this->
id,
'getnomurl' => &$result);
1532 $reshook = $hookmanager->executeHooks(
'getNomUrl', $parameters, $this, $action);
1534 $result = $hookmanager->resPrint;
1536 $result .= $hookmanager->resPrint;
1574 if (empty($this->labelStatus) || empty($this->labelStatusShort)) {
1577 $this->labelStatus[self::STATUS_DRAFT] = $langs->transnoentitiesnoconv(
'AssetInDraft');
1578 $this->labelStatus[self::STATUS_VALIDATED] = $langs->transnoentitiesnoconv(
'AssetInProgress');
1579 $this->labelStatus[self::STATUS_DISPOSED] = $langs->transnoentitiesnoconv(
'AssetDisposed');
1580 $this->labelStatusShort[self::STATUS_DRAFT] = $langs->transnoentitiesnoconv(
'AssetInDraft');
1581 $this->labelStatusShort[self::STATUS_VALIDATED] = $langs->transnoentitiesnoconv(
'AssetInProgress');
1582 $this->labelStatusShort[self::STATUS_DISPOSED] = $langs->transnoentitiesnoconv(
'AssetDisposed');
1585 $statusType =
'status'.$status;
1586 if ($status == self::STATUS_VALIDATED) {
1587 $statusType =
'status4';
1589 if ($status == self::STATUS_DISPOSED) {
1590 $statusType =
'status6';
1593 return dolGetStatus($this->labelStatus[$status], $this->labelStatusShort[$status],
'', $statusType, $mode);
1604 $sql =
"SELECT rowid, date_creation as datec, tms as datem, date_valid as datev,";
1605 $sql .=
" fk_user_creat, fk_user_modif, fk_user_valid";
1606 $sql .=
" FROM ".MAIN_DB_PREFIX.$this->table_element.
" as t";
1607 $sql .=
" WHERE t.rowid = ".((int) $id);
1609 $result = $this->db->query($sql);
1611 if ($this->db->num_rows($result)) {
1612 $obj = $this->db->fetch_object($result);
1613 $this->
id = $obj->rowid;
1615 $this->user_creation_id = $obj->fk_user_creat;
1616 $this->user_modification_id = $obj->fk_user_modif;
1617 $this->user_validation_id = $obj->fk_user_valid;
1618 $this->date_creation = $this->db->jdate($obj->datec);
1619 $this->date_modification = $this->db->jdate($obj->datem);
1620 $this->date_validation = $this->db->jdate($obj->datev);
1623 $this->db->free($result);
1649 public function getNextNumRef()
1651 global $langs,
$conf;
1652 $langs->load(
"assets");
1655 $conf->global->ASSET_ASSET_ADDON =
'mod_asset_standard';
1665 $dirmodels = array_merge(array(
'/'), (array)
$conf->modules_parts[
'models']);
1666 foreach ($dirmodels as $reldir) {
1670 $mybool = ((bool) @include_once $dir.$file) || $mybool;
1678 if (class_exists($classname)) {
1679 $obj =
new $classname();
1681 '@phan-var-force ModeleNumRefAsset $obj';
1684 $numref = $obj->getNextValue($this);
1686 if ($numref !=
'' && $numref !=
'-1') {
1689 $this->error = $obj->error;
1694 print $langs->trans(
"Error").
" ".$langs->trans(
"ClassNotFound").
' '.$classname;
1698 print $langs->trans(
"ErrorNumberingModuleNotSetup", $this->element);
1714 require_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
1719 if ($this->
status == self::STATUS_VALIDATED) {
1720 dol_syslog(get_class($this).
"::validate action abandoned: already validated", LOG_WARNING);
1729 if ( (preg_match(
'/^[\(]?PROV/i', $this->
ref) || empty($this->
ref))) {
1730 $num = $this->getNextNumRef();
1737 $sql =
"UPDATE ".MAIN_DB_PREFIX.$this->table_element;
1738 $sql .=
" SET ref = '".$this->db->escape($num).
"',";
1739 $sql .=
" status = ".self::STATUS_VALIDATED.
",";
1740 $sql .=
" date_valid='".$this->db->idate($now).
"',";
1741 $sql .=
" fk_user_valid = ".((int) $user->id);
1742 $sql .=
" WHERE rowid = ".((int) $this->
id);
1744 dol_syslog(get_class($this).
"::validate()", LOG_DEBUG);
1745 $resql = $this->db->query($sql);
1748 $this->error = $this->db->lasterror();
1752 if (!$error && !$notrigger) {
1754 $result = $this->call_trigger(
'ASSET_VALIDATE', $user);
1762 $this->oldref = $this->ref;
1765 if (preg_match(
'/^[\(]?PROV/i', $this->
ref)) {
1767 $sql =
'UPDATE '.MAIN_DB_PREFIX.
"ecm_files set filename = CONCAT('".$this->db->escape($this->newref).
"', SUBSTR(filename, ".(strlen($this->
ref) + 1).
")), filepath = 'asset/".$this->db->escape($this->newref).
"'";
1768 $sql .=
" WHERE filename LIKE '".$this->db->escape($this->
ref).
"%' AND filepath = 'bom/".$this->db->escape($this->
ref).
"' and entity = ".$conf->entity;
1769 $resql = $this->db->query($sql);
1772 $this->error = $this->db->lasterror();
1774 $sql =
'UPDATE '.MAIN_DB_PREFIX.
"ecm_files set filepath = 'asset/".$this->db->escape($this->newref).
"'";
1775 $sql .=
" WHERE filepath = 'asset/".$this->db->escape($this->
ref).
"' and entity = ".$conf->entity;
1776 $resql = $this->db->query($sql);
1779 $this->error = $this->db->lasterror();
1785 $dirsource =
$conf->asset->dir_output.
'/'.$oldref;
1786 $dirdest =
$conf->asset->dir_output.
'/'.$newref;
1787 if (!$error && file_exists($dirsource)) {
1788 dol_syslog(get_class($this).
"::validate() rename dir ".$dirsource.
" into ".$dirdest);
1790 if (@rename($dirsource, $dirdest)) {
1793 $listoffiles =
dol_dir_list(
$conf->asset->dir_output.
'/'.$newref,
'files', 1,
'^'.preg_quote($oldref,
'/'));
1794 foreach ($listoffiles as $fileentry) {
1795 $dirsource = $fileentry[
'name'];
1796 $dirdest = preg_replace(
'/^'.preg_quote($oldref,
'/').
'/', $newref, $dirsource);
1797 $dirsource = $fileentry[
'path'].
'/'.$dirsource;
1798 $dirdest = $fileentry[
'path'].
'/'.$dirdest;
1799 @rename($dirsource, $dirdest);
1809 $this->
status = self::STATUS_VALIDATED;
1813 $this->db->commit();
1816 $this->db->rollback();
1831 if ($this->
status <= self::STATUS_DRAFT) {
1835 return $this->
setStatusCommon($user, self::STATUS_DRAFT, $notrigger,
'ASSET_UNVALIDATE');
getCurrentPeriodOfFiscalYear($db, $conf, $from_time=null, $gm='tzserver', $withenddateonly=1)
Get current period of fiscal year?
getNextFiscalYear($db, $after_date, $gm='tzserver')
Get next fiscal year period after a given date.
Class for AssetAccountancyCodes.
Class for AssetDepreciationOptions.
getNomUrl($withpicto=0, $option='', $maxlen=0, $notooltip=0, $morecss='', $save_lastsearch_value=-1)
Return a link to the object card (with optionally the picto)
hasDepreciationLinesInBookkeeping()
If has depreciation lines in bookkeeping.
setDraft($user, $notrigger=0)
Set draft status.
dispose($user, $disposal_invoice_id, $notrigger=0)
Set dispose status.
validate($user, $notrigger=0)
Validate asset.
createFromClone(User $user, $fromid)
Clone an object into another one.
calculationDepreciation()
Calculation depreciation lines (reversal and future) for each mode.
__construct(DoliDB $db)
Constructor.
create(User $user, $notrigger=0)
Create object into database.
info($id)
Load the info information in the object.
getLabelStatus($mode=0)
Return the label of the status.
fetchAll($sortorder='', $sortfield='', $limit=0, $offset=0, $filter='', $filtermode='AND')
Load list of objects in memory from the database.
fetch($id, $ref=null)
Load object in memory from the database.
LibStatut($status, $mode=0)
Return the status.
reopen($user, $notrigger=0)
Set back to validated status if disposed status.
getLibStatut($mode=0)
Return the label of the status.
initAsSpecimen()
Initialise object with example values Id must be 0 if object instance is a specimen.
addDepreciationLine($mode, $ref, $depreciation_date, $depreciation_ht, $cumulative_depreciation_ht, $accountancy_code_debit, $accountancy_code_credit)
Add depreciation line for a mode.
fetchDepreciationLines()
Fetch depreciation lines for each mode in $this->depreciation_lines (sort by depreciation date)
setLastCumulativeDepreciation($asset_depreciation_id)
Set last cumulative depreciation for each mode.
update(User $user, $notrigger=0)
Update object into database.
setDataFromAssetModel(User $user, $notrigger=0)
Set asset model.
Parent class of all other business classes (invoices, contracts, proposals, orders,...
add_object_linked($origin=null, $origin_id=null, $f_user=null, $notrigger=0)
Add an object link into llx_element_element.
deleteObjectLinked($sourceid=null, $sourcetype='', $targetid=null, $targettype='', $rowid=0, $f_user=null, $notrigger=0)
Delete all links between an object $this.
createCommon(User $user, $notrigger=0)
Create object in the database.
getFieldList($alias='', $excludefields=array())
Function to concat keys of fields.
updateCommon(User $user, $notrigger=0)
Update object into database.
setStatusCommon($user, $status, $notrigger=0, $triggercode='')
Set to a status.
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.
Class to manage Dolibarr database access.
Class to manage translations.
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...
dol_get_first_day($year, $month=1, $gm=false)
Return GMT time for first day of a month or year.
num_between_day($timestampStart, $timestampEnd, $lastday=0)
Function to return number of days between two dates (date must be UTC date !) Example: 2012-01-01 201...
dol_time_plus_duree($time, $duration_value, $duration_unit, $ruleforendofmonth=0)
Add a delay to a date.
dol_get_last_day($year, $month=12, $gm=false)
Return GMT time for last day of a month or year.
dol_dir_list($utf8_path, $types="all", $recursive=0, $filter="", $excludefilter=null, $sortcriteria="name", $sortorder=SORT_ASC, $mode=0, $nohook=0, $relativename="", $donotfollowsymlinks=0, $nbsecondsold=0)
Scan a directory and return a list of files/directories.
dol_now($mode='gmt')
Return date for now.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2, $allowothertags=array())
Show picto whatever it's its name (generic function)
price2num($amount, $rounding='', $option=0)
Function that return a number with universal decimal format (decimal separator is '.
img_object($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $allowothertags=array())
Show a picto called object_picto (generic function)
dol_sanitizeFileName($str, $newstr='_', $unaccent=1, $includequotes=0, $allowdash=0)
Clean a string to use it as a file name.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_buildpath($path, $type=0, $returnemptyifnotfound=0)
Return path of url or filesystem.
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs=null, $encodetooutput=false, $decorate=0)
Output date in a string format according to outputlangs (or langs if not defined).
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.
isModEnabled($module)
Is Dolibarr module enabled.
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
dol_getdate($timestamp, $fast=false, $forcetimezone='')
Return an array with locale date info.
dol_escape_htmltag($stringtoescape, $keepb=0, $keepn=0, $noescapetags='', $escapeonlyhtmltags=0, $cleanalsojavascript=0)
Returns text escaped for inclusion in HTML alt or title or value tags, or into values of HTML input f...
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