25 require_once DOL_DOCUMENT_ROOT.
'/core/class/commonobject.class.php';
35 public $module =
'asset';
40 public $element =
'asset';
45 public $table_element =
'asset';
51 public $ismultientitymanaged = 1;
56 public $isextrafieldmanaged = 1;
61 public $picto =
'asset';
63 const STATUS_DRAFT = 0;
64 const STATUS_DISPOSED = 9;
98 'rowid' => array(
'type'=>
'integer',
'label'=>
'TechnicalID',
'enabled'=>
'1',
'position'=>1,
'notnull'=>1,
'visible'=>0,
'noteditable'=>
'1',
'index'=>1,
'css'=>
'left',
'comment'=>
"Id"),
99 'ref' => array(
'type'=>
'varchar(128)',
'label'=>
'Ref',
'enabled'=>
'1',
'position'=>20,
'notnull'=>1,
'visible'=>1,
'noteditable'=>
'0',
'index'=>1,
'searchall'=>1,
'showoncombobox'=>
'1',
'validate'=>
'1',
'comment'=>
"Reference of object"),
100 'label' => array(
'type'=>
'varchar(255)',
'label'=>
'Label',
'enabled'=>
'1',
'position'=>30,
'notnull'=>1,
'visible'=>1,
'searchall'=>1,
'css'=>
'minwidth300',
'cssview'=>
'wordbreak',
'showoncombobox'=>
'2',
'validate'=>
'1',),
101 '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',),
102 'qty' => array(
'type'=>
'real',
'label'=>
'Qty',
'enabled'=>
'1',
'position'=>50,
'notnull'=>1,
'visible'=>0,
'default'=>
'1',
'isameasure'=>
'1',
'css'=>
'maxwidth75imp',
'validate'=>
'1',),
103 'acquisition_type' => array(
'type'=>
'smallint',
'label'=>
'AssetAcquisitionType',
'enabled'=>
'1',
'position'=>60,
'notnull'=>1,
'visible'=>1,
'arrayofkeyval'=>array(
'0'=>
'AssetAcquisitionTypeNew',
'1'=>
'AssetAcquisitionTypeOccasion'),
'validate'=>
'1',),
104 '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',),
105 'not_depreciated' => array(
'type'=>
'boolean',
'label'=>
'AssetNotDepreciated',
'enabled'=>
'1',
'position'=>80,
'notnull'=>0,
'default'=>
'0',
'visible'=>1,
'validate'=>
'1',),
106 'date_acquisition' => array(
'type'=>
'date',
'label'=>
'AssetDateAcquisition',
'enabled'=>
'1',
'position'=>90,
'notnull'=>1,
'visible'=>1,),
107 'date_start' => array(
'type'=>
'date',
'label'=>
'AssetDateStart',
'enabled'=>
'1',
'position'=>100,
'notnull'=>0,
'visible'=>-1,),
108 'acquisition_value_ht' => array(
'type'=>
'price',
'label'=>
'AssetAcquisitionValueHT',
'enabled'=>
'1',
'position'=>110,
'notnull'=>1,
'visible'=>1,
'isameasure'=>
'1',
'validate'=>
'1',),
109 'recovered_vat' => array(
'type'=>
'price',
'label'=>
'AssetRecoveredVAT',
'enabled'=>
'1',
'position'=>120,
'notnull'=>0,
'visible'=>1,
'isameasure'=>
'1',
'validate'=>
'1',),
110 'reversal_date' => array(
'type'=>
'date',
'label'=>
'AssetReversalDate',
'enabled'=>
'1',
'position'=>130,
'notnull'=>0,
'visible'=>1,),
111 'reversal_amount_ht' => array(
'type'=>
'price',
'label'=>
'AssetReversalAmountHT',
'enabled'=>
'1',
'position'=>140,
'notnull'=>0,
'visible'=>1,
'isameasure'=>
'1',
'validate'=>
'1',),
112 'disposal_date' => array(
'type'=>
'date',
'label'=>
'AssetDisposalDate',
'enabled'=>
'1',
'position'=>200,
'notnull'=>0,
'visible'=>-2,),
113 'disposal_amount_ht' => array(
'type'=>
'price',
'label'=>
'AssetDisposalAmount',
'enabled'=>
'1',
'position'=>210,
'notnull'=>0,
'visible'=>-2,
'default'=>
'0',
'isameasure'=>
'1',
'validate'=>
'1',),
114 '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',),
115 'disposal_depreciated' => array(
'type'=>
'boolean',
'label'=>
'AssetDisposalDepreciated',
'enabled'=>
'1',
'position'=>230,
'notnull'=>0,
'default'=>
'0',
'visible'=>-2,
'validate'=>
'1',),
116 'disposal_subject_to_vat' => array(
'type'=>
'boolean',
'label'=>
'AssetDisposalSubjectToVat',
'enabled'=>
'1',
'position'=>240,
'notnull'=>0,
'default'=>
'0',
'visible'=>-2,
'validate'=>
'1',),
117 'note_public' => array(
'type'=>
'html',
'label'=>
'NotePublic',
'enabled'=>
'1',
'position'=>300,
'notnull'=>0,
'visible'=>0,
'validate'=>
'1',),
118 'note_private' => array(
'type'=>
'html',
'label'=>
'NotePrivate',
'enabled'=>
'1',
'position'=>301,
'notnull'=>0,
'visible'=>0,
'validate'=>
'1',),
119 'date_creation' => array(
'type'=>
'datetime',
'label'=>
'DateCreation',
'enabled'=>
'1',
'position'=>500,
'notnull'=>1,
'visible'=>-2,),
120 'tms' => array(
'type'=>
'timestamp',
'label'=>
'DateModification',
'enabled'=>
'1',
'position'=>501,
'notnull'=>0,
'visible'=>-2,),
121 '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',),
122 'fk_user_modif' => array(
'type'=>
'integer:User:user/class/user.class.php',
'label'=>
'UserModif',
'enabled'=>
'1',
'position'=>511,
'notnull'=>-1,
'visible'=>-2,),
123 'last_main_doc' => array(
'type'=>
'varchar(255)',
'label'=>
'LastMainDoc',
'enabled'=>
'1',
'position'=>600,
'notnull'=>0,
'visible'=>0,),
124 'import_key' => array(
'type'=>
'varchar(14)',
'label'=>
'ImportId',
'enabled'=>
'1',
'position'=>1000,
'notnull'=>-1,
'visible'=>-2,),
125 'model_pdf' => array(
'type'=>
'varchar(255)',
'label'=>
'Model pdf',
'enabled'=>
'1',
'position'=>1010,
'notnull'=>-1,
'visible'=>0,),
126 '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',),
131 public $fk_asset_model;
132 public $reversal_amount_ht;
133 public $acquisition_value_ht;
134 public $recovered_vat;
135 public $reversal_date;
136 public $date_acquisition;
139 public $acquisition_type;
141 public $not_depreciated;
142 public $disposal_date;
143 public $disposal_amount_ht;
144 public $fk_disposal_type;
145 public $disposal_depreciated;
146 public $disposal_subject_to_vat;
147 public $supplier_invoice_id;
149 public $note_private;
150 public $date_creation;
152 public $fk_user_creat;
153 public $fk_user_modif;
154 public $last_main_doc;
158 public $user_cloture_id;
169 public $asset_depreciation_options;
173 public $depreciation_lines = array();
182 global $conf, $langs;
186 if (empty($conf->global->MAIN_SHOW_TECHNICAL_ID) && isset($this->fields[
'rowid'])) {
187 $this->fields[
'rowid'][
'visible'] = 0;
189 if (!
isModEnabled(
'multicompany') && isset($this->fields[
'entity'])) {
190 $this->fields[
'entity'][
'enabled'] = 0;
194 foreach ($this->fields as $key => $val) {
195 if (isset($val[
'enabled']) && empty($val[
'enabled'])) {
196 unset($this->fields[$key]);
201 if (is_object($langs)) {
202 foreach ($this->fields as $key => $val) {
203 if (!empty($val[
'arrayofkeyval']) && is_array($val[
'arrayofkeyval'])) {
204 foreach ($val[
'arrayofkeyval'] as $key2 => $val2) {
205 $this->fields[$key][
'arrayofkeyval'][$key2] = $langs->trans($val2);
221 if (!isset($this->date_start) || $this->date_start ===
"") $this->date_start = $this->date_acquisition;
225 $result = $result_create = $this->
createCommon($user, $notrigger);
226 if ($result > 0 && $this->fk_asset_model > 0) $result = $this->
setDataFromAssetModel($user, $notrigger);
228 if ($this->supplier_invoice_id > 0) $this->
add_object_linked(
'invoice_supplier', $this->supplier_invoice_id);
232 $this->db->rollback();
237 return $result > 0 ? $result_create : $result;
249 global $langs, $extrafields;
347 public function fetch($id, $ref =
null)
351 if (!empty($this->table_element_line)) $this->
fetchLines();
356 } elseif ($res > 0) {
357 $this->fields[
'date_acquisition'][
'noteditable'] =
'1';
358 $this->fields[
'date_start'][
'noteditable'] =
'1';
359 $this->fields[
'acquisition_value_ht'][
'noteditable'] =
'1';
360 $this->fields[
'recovered_vat'][
'noteditable'] =
'1';
361 $this->fields[
'reversal_date'][
'noteditable'] =
'1';
362 $this->fields[
'reversal_amount_ht'][
'noteditable'] =
'1';
375 $this->lines = array();
392 public function fetchAll($sortorder =
'', $sortfield =
'', $limit = 0, $offset = 0, array $filter = array(), $filtermode =
'AND')
402 $sql .=
" FROM ".MAIN_DB_PREFIX.$this->table_element.
" as t";
403 if (isset($this->ismultientitymanaged) && $this->ismultientitymanaged == 1) {
404 $sql .=
" WHERE t.entity IN (".getEntity($this->element).
")";
406 $sql .=
" WHERE 1 = 1";
410 if (count($filter) > 0) {
411 foreach ($filter as $key => $value) {
412 if ($key ==
't.rowid') {
413 $sqlwhere[] = $key.
" = ".((int) $value);
414 } elseif (in_array($this->fields[$key][
'type'], array(
'date',
'datetime',
'timestamp'))) {
415 $sqlwhere[] = $key.
" = '".$this->db->idate($value).
"'";
416 } elseif ($key ==
'customsql') {
417 $sqlwhere[] = $value;
418 } elseif (strpos($value,
'%') ===
false) {
419 $sqlwhere[] = $key.
" IN (".$this->db->sanitize($this->db->escape($value)).
")";
421 $sqlwhere[] = $key.
" LIKE '%".$this->db->escape($value).
"%'";
425 if (count($sqlwhere) > 0) {
426 $sql .=
" AND (".implode(
" ".$filtermode.
" ", $sqlwhere).
")";
429 if (!empty($sortfield)) {
430 $sql .= $this->db->order($sortfield, $sortorder);
432 if (!empty($limit)) {
433 $sql .= $this->db->plimit($limit, $offset);
436 $resql = $this->db->query(
$sql);
438 $num = $this->db->num_rows($resql);
440 while ($i < ($limit ? min($limit, $num) : $num)) {
441 $obj = $this->db->fetch_object($resql);
443 $record =
new self($this->db);
444 $record->setVarsFromFetchObj($obj);
446 $records[$record->id] = $record;
450 $this->db->free($resql);
454 $this->errors[] =
'Error '.$this->db->lasterror();
455 dol_syslog(__METHOD__.
' '.join(
',', $this->errors), LOG_ERR);
470 if (!isset($this->date_start) || $this->date_start ===
"") $this->date_start = $this->date_acquisition;
475 if ($result > 0 && $this->fk_asset_model > 0 && $this->fk_asset_model != $this->oldcopy->fk_asset_model) {
479 $this->date_start != $this->oldcopy->date_start ||
480 $this->acquisition_value_ht != $this->oldcopy->acquisition_value_ht ||
481 $this->reversal_date != $this->oldcopy->reversal_date ||
482 $this->reversal_amount_ht != $this->oldcopy->reversal_amount_ht ||
483 ($this->fk_asset_model > 0 && $this->fk_asset_model != $this->oldcopy->fk_asset_model)
490 $this->db->rollback();
505 public function delete(
User $user, $notrigger =
false)
521 $langs->load(
'assets');
524 $this->
id = $this->
id > 0 ? $this->id : 0;
525 $this->fk_asset_model = $this->fk_asset_model > 0 ? $this->fk_asset_model : 0;
529 if (empty($this->
id)) {
530 $this->errors[] = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Asset") .
' (' . $langs->transnoentitiesnoconv(
"TechnicalID") .
')');
533 if (empty($this->fk_asset_model)) {
534 $this->errors[] = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"AssetModel") .
' (' . $langs->transnoentitiesnoconv(
"TechnicalID") .
')');
545 require_once DOL_DOCUMENT_ROOT .
'/asset/class/assetdepreciationoptions.class.php';
547 $result = $options_model->fetchDeprecationOptions(0, $this->fk_asset_model);
549 $this->error = $options_model->error;
550 $this->errors = $options_model->errors;
552 } elseif ($result > 0) {
554 $result = $options->fetchDeprecationOptions($this->
id);
556 $this->error = $options->error;
557 $this->errors = $options->errors;
562 foreach ($options_model->deprecation_options as $mode_key => $fields) {
563 foreach ($fields as $field_key => $value) {
564 $options->deprecation_options[$mode_key][$field_key] = $value;
568 $result = $options->updateDeprecationOptions($user, $this->
id, 0, $notrigger);
570 $this->error = $options->error;
571 $this->errors = $options->errors;
580 require_once DOL_DOCUMENT_ROOT .
'/asset/class/assetaccountancycodes.class.php';
582 $result = $accountancy_codes_model->fetchAccountancyCodes(0, $this->fk_asset_model);
584 $this->error = $accountancy_codes_model->error;
585 $this->errors = $accountancy_codes_model->errors;
587 } elseif ($result > 0) {
589 $result = $accountancy_codes->fetchAccountancyCodes($this->
id);
591 $this->error = $accountancy_codes->error;
592 $this->errors = $accountancy_codes->errors;
597 foreach ($accountancy_codes_model->accountancy_codes as $mode_key => $fields) {
598 foreach ($fields as $field_key => $value) {
599 $accountancy_codes->accountancy_codes[$mode_key][$field_key] = $value;
603 $result = $accountancy_codes->updateAccountancyCodes($user, $this->
id, 0, $notrigger);
605 $this->error = $accountancy_codes->error;
606 $this->errors = $accountancy_codes->errors;
614 $this->db->rollback();
630 $langs->load(
'assets');
631 $this->depreciation_lines = array();
634 $this->
id = $this->
id > 0 ? $this->id : 0;
638 if (empty($this->
id)) {
639 $this->errors[] = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Asset") .
' (' . $langs->transnoentitiesnoconv(
"TechnicalID") .
')');
661 $sql =
"SELECT ad.rowid, ad.depreciation_mode, ad.ref, ad.depreciation_date, ad.depreciation_ht, ad.cumulative_depreciation_ht";
662 $sql .=
", " . $this->db->ifsql(
'iab.fk_docdet IS NOT NULL', 1, 0) .
" AS bookkeeping";
663 $sql .=
" FROM " . MAIN_DB_PREFIX .
"asset_depreciation AS ad";
664 $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";
665 $sql .=
" WHERE ad.fk_asset = " . (int) $this->
id;
666 $sql .=
" ORDER BY ad.depreciation_date ASC";
668 $resql = $this->db->query(
$sql);
670 $this->errors[] = $langs->trans(
'AssetErrorFetchDepreciationLines') .
': ' . $this->db->lasterror();
674 while ($obj = $this->db->fetch_object($resql)) {
675 if (!isset($this->depreciation_lines[$obj->depreciation_mode])) $this->depreciation_lines[$obj->depreciation_mode] = array();
676 $this->depreciation_lines[$obj->depreciation_mode][] = array(
679 'depreciation_date' => $this->db->jdate($obj->depreciation_date),
680 'depreciation_ht' => $obj->depreciation_ht,
681 'cumulative_depreciation_ht' => $obj->cumulative_depreciation_ht,
682 'bookkeeping' => $obj->bookkeeping,
697 $langs->load(
'assets');
700 $this->
id = $this->
id > 0 ? $this->id : 0;
704 if (empty($this->
id)) {
705 $this->errors[] = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Asset") .
' (' . $langs->transnoentitiesnoconv(
"TechnicalID") .
')');
726 $sql =
"SELECT COUNT(*) AS has_bookkeeping";
727 $sql .=
" FROM " . MAIN_DB_PREFIX .
"asset_depreciation AS ad";
728 $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";
729 $sql .=
" WHERE ad.fk_asset = " . (int) $this->
id;
730 $sql .=
" AND iab.fk_docdet IS NOT NULL";
732 $resql = $this->db->query(
$sql);
734 $this->errors[] = $langs->trans(
'AssetErrorFetchDepreciationLines') .
': ' . $this->db->lasterror();
738 if ($obj = $this->db->fetch_object($resql)) {
739 return $obj->has_bookkeeping > 0 ? 1 : 0;
757 public function addDepreciationLine($mode, $ref, $depreciation_date, $depreciation_ht, $cumulative_depreciation_ht, $accountancy_code_debit, $accountancy_code_credit)
760 $langs->load(
'assets');
763 $this->
id = $this->
id > 0 ? $this->id : 0;
764 $mode = strtolower(trim($mode));
766 $accountancy_code_debit = trim($accountancy_code_debit);
767 $accountancy_code_credit = trim($accountancy_code_credit);
771 if (empty($this->
id)) {
772 $this->errors[] = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Asset") .
' (' . $langs->transnoentitiesnoconv(
"TechnicalID") .
')');
779 $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)";
780 $sql .=
" VALUES ( ";
781 $sql .=
" " . (int) $this->
id;
782 $sql .=
", '" . $this->db->escape($mode) .
"'";
783 $sql .=
", '" . $this->db->escape($ref) .
"'";
784 $sql .=
", '" . $this->db->idate($depreciation_date) .
"'";
785 $sql .=
", " . (double) $depreciation_ht;
786 $sql .=
", " . (double) $cumulative_depreciation_ht;
787 $sql .=
", '" . $this->db->escape($accountancy_code_debit) .
"'";
788 $sql .=
", '" . $this->db->escape($accountancy_code_credit) .
"'";
791 $resql = $this->db->query(
$sql);
793 $this->errors[] = $langs->trans(
'AssetErrorAddDepreciationLine') .
': ' . $this->db->lasterror();
807 global $conf, $langs;
808 $langs->load(
'assets');
811 $this->
id = $this->
id > 0 ? $this->id : 0;
815 if (empty($this->
id)) {
816 $this->errors[] = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Asset") .
' (' . $langs->transnoentitiesnoconv(
"TechnicalID") .
')');
825 require_once DOL_DOCUMENT_ROOT .
'/asset/class/assetdepreciationoptions.class.php';
827 $result = $options->fetchDeprecationOptions($this->
id);
829 $this->error = $options->error;
830 $this->errors = $options->errors;
836 require_once DOL_DOCUMENT_ROOT .
'/asset/class/assetaccountancycodes.class.php';
838 $result = $accountancy_codes->fetchAccountancyCodes($this->
id);
840 $this->error = $accountancy_codes->error;
841 $this->errors = $accountancy_codes->errors;
849 foreach ($options->deprecation_options as $mode_key => $fields) {
850 $modes[$mode_key] = $this->db->escape($mode_key);
852 $sql =
"DELETE FROM " . MAIN_DB_PREFIX .
"asset_depreciation";
853 $sql .=
" WHERE fk_asset = " . (int) $this->
id;
854 $sql .=
" AND depreciation_mode NOT IN ('" . $this->db->sanitize(implode(
"', '", $modes)) .
"')";
856 $resql = $this->db->query(
$sql);
858 $this->errors[] = $langs->trans(
'AssetErrorClearDepreciationLines') .
': ' . $this->db->lasterror();
864 require_once DOL_DOCUMENT_ROOT .
'/core/lib/date.lib.php';
865 require_once DOL_DOCUMENT_ROOT .
'/core/lib/accounting.lib.php';
867 $init_fiscal_period_start = $dates[
'date_start'];
868 $init_fiscal_period_end = $dates[
'date_end'];
869 if (empty($init_fiscal_period_start) || empty($init_fiscal_period_end)) {
870 $pastmonthyear = $dates[
'pastmonthyear'];
871 $pastmonth = $dates[
'pastmonth'];
872 $init_fiscal_period_start =
dol_get_first_day($pastmonthyear, $pastmonth,
false);
873 $init_fiscal_period_end =
dol_get_last_day($pastmonthyear, $pastmonth,
false);
876 foreach ($options->deprecation_options as $mode_key => $fields) {
897 $sql =
"SELECT ad.depreciation_date, ad.cumulative_depreciation_ht";
898 $sql .=
" FROM " . MAIN_DB_PREFIX .
"asset_depreciation AS ad";
899 $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";
900 $sql .=
" WHERE ad.fk_asset = " . (int) $this->
id;
901 $sql .=
" AND ad.depreciation_mode = '" . $this->db->escape($mode_key) .
"'";
902 $sql .=
" AND iab.fk_docdet IS NOT NULL";
903 $sql .=
" ORDER BY ad.depreciation_date DESC";
906 $resql = $this->db->query(
$sql);
908 $this->errors[] = $langs->trans(
'AssetErrorFetchMaxDepreciationDateForMode', $mode_key) .
': ' . $this->db->lasterror();
912 $last_depreciation_date =
'';
913 $last_cumulative_depreciation_ht = $this->reversal_amount_ht;
914 if ($obj = $this->db->fetch_object($resql)) {
915 $last_depreciation_date = $this->db->jdate($obj->depreciation_date);
916 $last_cumulative_depreciation_ht = $obj->cumulative_depreciation_ht;
920 $sql =
"UPDATE " . MAIN_DB_PREFIX . $options->deprecation_options_fields[$mode_key][
'table'];
921 $sql .=
" SET total_amount_last_depreciation_ht = " . (empty($last_cumulative_depreciation_ht) ? 0 : $last_cumulative_depreciation_ht);
922 $sql .=
" WHERE fk_asset = " . (int) $this->
id;
923 $resql = $this->db->query(
$sql);
925 $this->errors[] = $langs->trans(
'AssetErrorSetLastCumulativeDepreciation') .
': ' . $this->db->lasterror();
931 $sql =
"DELETE " . MAIN_DB_PREFIX .
"asset_depreciation FROM " . MAIN_DB_PREFIX .
"asset_depreciation";
932 $sql .=
" LEFT JOIN " . MAIN_DB_PREFIX .
"accounting_bookkeeping as ab ON ab.doc_type = 'asset' AND ab.fk_docdet = " . MAIN_DB_PREFIX .
"asset_depreciation.rowid";
933 $sql .=
" WHERE " . MAIN_DB_PREFIX .
"asset_depreciation.fk_asset = " . (int) $this->
id;
934 $sql .=
" AND " . MAIN_DB_PREFIX .
"asset_depreciation.depreciation_mode = '" . $this->db->escape($mode_key) .
"'";
935 $sql .=
" AND ab.fk_docdet IS NULL";
936 if ($last_depreciation_date !==
"")
$sql .=
" AND " . MAIN_DB_PREFIX .
"asset_depreciation.ref != ''";
937 $resql = $this->db->query(
$sql);
939 $this->errors[] = $langs->trans(
'AssetErrorClearDepreciationLines') .
': ' . $this->db->lasterror();
945 $depreciation_date_start = $this->date_start > $this->date_acquisition ? $this->date_start : $this->date_acquisition;
946 $depreciation_date_end =
dol_time_plus_duree($depreciation_date_start, $fields[
'duration'], $fields[
'duration_type'] == 1 ?
'm' : ($fields[
'duration_type'] == 2 ?
'd' :
'y'));
947 $depreciation_amount = $fields[
'amount_base_depreciation_ht'];
948 if ($fields[
'duration_type'] == 2) {
949 $fiscal_period_start = $depreciation_date_start;
950 $fiscal_period_end = $depreciation_date_start;
951 } elseif ($fields[
'duration_type'] == 1) {
952 $date_temp =
dol_getdate($depreciation_date_start);
953 $fiscal_period_start =
dol_get_first_day($date_temp[
'year'], $date_temp[
'mon'],
false);
954 $fiscal_period_end =
dol_get_last_day($date_temp[
'year'], $date_temp[
'mon'],
false);
956 $fiscal_period_start = $init_fiscal_period_start;
957 $fiscal_period_end = $init_fiscal_period_end;
959 $cumulative_depreciation_ht = $last_cumulative_depreciation_ht;
960 $depreciation_period_amount = $depreciation_amount - $this->reversal_amount_ht;
961 $start_date = $depreciation_date_start;
962 $disposal_date = isset($this->disposal_date) && $this->disposal_date !==
"" ? $this->disposal_date :
"";
963 $finish_date = $disposal_date !==
"" ? $disposal_date : $depreciation_date_end;
964 $accountancy_code_depreciation_debit_key = $accountancy_codes->accountancy_codes_fields[$mode_key][
'depreciation_debit'];
965 $accountancy_code_depreciation_debit = $accountancy_codes->accountancy_codes[$mode_key][$accountancy_code_depreciation_debit_key];
966 $accountancy_code_depreciation_credit_key = $accountancy_codes->accountancy_codes_fields[$mode_key][
'depreciation_credit'];
967 $accountancy_code_credit = $accountancy_codes->accountancy_codes[$mode_key][$accountancy_code_depreciation_credit_key];
971 if ($last_depreciation_date ===
"" && ($depreciation_date_start < $fiscal_period_start || is_numeric($this->reversal_date))) {
972 if (is_numeric($this->reversal_date)) {
973 if ($this->reversal_date < $fiscal_period_start) {
974 $this->errors[] = $langs->trans(
'AssetErrorReversalDateNotGreaterThanCurrentBeginFiscalDateForMode', $mode_key);
979 if (empty($this->reversal_amount_ht)) {
980 $this->errors[] = $langs->trans(
'AssetErrorReversalAmountNotProvidedForMode', $mode_key);
985 $start_date = $this->reversal_date;
986 $result = $this->
addDepreciationLine($mode_key,
'', $start_date, $this->reversal_amount_ht, $this->reversal_amount_ht, $accountancy_code_depreciation_debit, $accountancy_code_credit);
992 $this->errors[] = $langs->trans(
'AssetErrorReversalDateNotProvidedForMode', $mode_key);
1000 $nb_days_in_year = !empty($conf->global->ASSET_DEPRECIATION_DURATION_PER_YEAR) ? $conf->global->ASSET_DEPRECIATION_DURATION_PER_YEAR : 365;
1001 $nb_days_in_month = !empty($conf->global->ASSET_DEPRECIATION_DURATION_PER_MONTH) ? $conf->global->ASSET_DEPRECIATION_DURATION_PER_MONTH : 30;
1002 $period_amount = (double)
price2num($depreciation_period_amount / $fields[
'duration'],
'MT');
1003 $first_period_found =
false;
1004 $first_period_date = isset($begin_period) && $begin_period > $fiscal_period_start ? $begin_period : $fiscal_period_start;
1006 $ref_date_format =
"%Y" . ($fields[
'duration_type'] == 1 || $fields[
'duration_type'] == 2 ?
'-%m' :
'') . ($fields[
'duration_type'] == 2 ?
'-%d' :
'');
1010 $max_loop = $fields[
'duration'] + 2;
1014 if ($idx_loop > $max_loop)
break;
1016 if ($last_depreciation_date < $fiscal_period_end && ($first_period_date <= $start_date || $first_period_found)) {
1018 if ($fiscal_period_start <= $disposal_date && $disposal_date <= $fiscal_period_end && empty($this->disposal_depreciated)) {
1022 $first_period_found =
true;
1024 $period_begin =
dol_print_date($fiscal_period_start, $ref_date_format);
1025 $period_end =
dol_print_date($fiscal_period_end, $ref_date_format);
1026 $ref = $period_begin . ($period_begin != $period_end ?
' - ' . $period_end :
'');
1027 if ($fiscal_period_start <= $disposal_date && $disposal_date <= $fiscal_period_end) {
1028 $ref .=
' - ' . $langs->transnoentitiesnoconv(
'AssetDisposal');
1031 $begin_date = $fiscal_period_start < $start_date && $start_date <= $fiscal_period_end ? $start_date : $fiscal_period_start;
1032 $end_date = $fiscal_period_start < $finish_date && $finish_date <= $fiscal_period_end ? $finish_date : $fiscal_period_end;
1033 if ($fields[
'duration_type'] == 2) {
1034 $depreciation_ht = $period_amount;
1035 } elseif ($fields[
'duration_type'] == 1) {
1036 $nb_days = min($nb_days_in_month,
num_between_day($begin_date, $end_date, 1));
1037 if ($nb_days >= 28) {
1039 if ($date_temp[
'mon'] == 2) {
1043 $depreciation_ht = (double)
price2num($period_amount * $nb_days / $nb_days_in_month,
'MT');
1045 $nb_days = min($nb_days_in_year,
num_between_day($begin_date, $end_date, 1));
1046 $depreciation_ht = (double)
price2num($period_amount * $nb_days / $nb_days_in_year,
'MT');
1049 if ($fiscal_period_start <= $depreciation_date_end && $depreciation_date_end <= $fiscal_period_end) {
1050 $depreciation_ht = (double)
price2num($depreciation_amount - $cumulative_depreciation_ht,
'MT');
1051 $cumulative_depreciation_ht = $depreciation_amount;
1053 $cumulative_depreciation_ht += $depreciation_ht;
1056 $result = $this->
addDepreciationLine($mode_key, $ref, $fiscal_period_end, $depreciation_ht, $cumulative_depreciation_ht, $accountancy_code_depreciation_debit, $accountancy_code_credit);
1065 if ($fields[
'duration_type'] == 2) {
1066 $fiscal_period_end = $fiscal_period_start;
1067 } elseif ($fields[
'duration_type'] == 1) {
1072 $last_period_date = $disposal_date !==
"" && $disposal_date < $depreciation_date_end ? $disposal_date : $depreciation_date_end;
1073 }
while ($fiscal_period_start < $last_period_date);
1082 $this->db->rollback();
1085 $this->db->commit();
1099 $langs->load(
'assets');
1102 $asset_depreciation_id = $asset_depreciation_id > 0 ? $asset_depreciation_id : 0;
1106 if (empty($asset_depreciation_id)) {
1107 $this->errors[] = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"AssetDepreciation") .
' (' . $langs->transnoentitiesnoconv(
"TechnicalID") .
')');
1116 require_once DOL_DOCUMENT_ROOT .
'/asset/class/assetdepreciationoptions.class.php';
1121 $sql =
"SELECT fk_asset, depreciation_mode, cumulative_depreciation_ht";
1122 $sql .=
" FROM " . MAIN_DB_PREFIX .
"asset_depreciation";
1123 $sql .=
" WHERE rowid = " . (int) $asset_depreciation_id;
1124 $resql = $this->db->query(
$sql);
1126 $this->errors[] = $langs->trans(
'AssetErrorFetchCumulativeDepreciation') .
': ' . $this->db->lasterror();
1129 if ($obj = $this->db->fetch_object($resql)) {
1130 $mode_key = $obj->depreciation_mode;
1131 if (!empty($options->deprecation_options_fields[$mode_key])) {
1132 $sql =
"UPDATE " . MAIN_DB_PREFIX . $options->deprecation_options_fields[$mode_key][
'table'];
1133 $sql .=
" SET total_amount_last_depreciation_ht = " . $obj->cumulative_depreciation_ht;
1134 $sql .=
" WHERE fk_asset = " . (int) $obj->fk_asset;
1135 $resql = $this->db->query(
$sql);
1137 $this->errors[] = $langs->trans(
'AssetErrorSetLastCumulativeDepreciation') .
': ' . $this->db->lasterror();
1145 $this->db->rollback();
1148 $this->db->commit();
1161 public function dispose($user, $disposal_invoice_id, $notrigger = 0)
1163 global $conf, $langs;
1166 if ($this->status != self::STATUS_DRAFT || $this->status == self::STATUS_DISPOSED) {
1172 $required_fields = array(
'disposal_date',
'disposal_date',
'fk_disposal_type');
1173 foreach ($required_fields as $field) {
1174 $this->fields[$field][
'notnull'] = 1;
1176 $result = $this->
update($user, 1);
1177 foreach ($required_fields as $field) {
1178 $this->fields[$field][
'notnull'] = 0;
1181 if ($disposal_invoice_id > 0) $this->
add_object_linked(
'facture', $disposal_invoice_id);
1182 $result = $this->
setStatusCommon($user, self::STATUS_DISPOSED, $notrigger,
'ASSET_DISPOSED');
1187 $this->db->rollback();
1189 $this->db->commit();
1193 if ($result > 0 && empty($conf->global->MAIN_DISABLE_PDF_AUTOUPDATE)) {
1194 if (method_exists($this,
'generateDocument')) {
1195 global $hidedetails, $hidedesc, $hideref;
1196 $outputlangs = $langs;
1199 $newlang =
GETPOST(
'lang_id',
'aZ09');
1202 $newlang = $this->thirdparty->default_lang;
1204 if (!empty($newlang)) {
1205 $outputlangs =
new Translate(
"", $conf);
1206 $outputlangs->setDefaultLang($newlang);
1208 $model = $this->model_pdf;
1209 $ret = $this->
fetch($this->
id);
1211 $this->generateDocument($model, $outputlangs, $hidedetails, $hidedesc, $hideref);
1225 public function reopen($user, $notrigger = 0)
1227 global $conf, $langs;
1230 if ($this->status != self::STATUS_DISPOSED || $this->status == self::STATUS_DRAFT) {
1237 $this->disposal_date =
null;
1238 $this->disposal_amount_ht =
null;
1239 $this->fk_disposal_type =
null;
1240 $this->disposal_depreciated =
null;
1241 $this->disposal_subject_to_vat =
null;
1242 $result = $this->
update($user, 1);
1245 $result = $this->
setStatusCommon($user, self::STATUS_DRAFT, $notrigger,
'ASSET_REOPEN');
1250 $this->db->rollback();
1252 $this->db->commit();
1256 if ($result > 0 && empty($conf->global->MAIN_DISABLE_PDF_AUTOUPDATE)) {
1257 if (method_exists($this,
'generateDocument')) {
1258 global $hidedetails, $hidedesc, $hideref;
1259 $outputlangs = $langs;
1262 $newlang =
GETPOST(
'lang_id',
'aZ09');
1265 $newlang = $this->thirdparty->default_lang;
1267 if (!empty($newlang)) {
1268 $outputlangs =
new Translate(
"", $conf);
1269 $outputlangs->setDefaultLang($newlang);
1271 $model = $this->model_pdf;
1272 $ret = $this->
fetch($this->
id);
1274 $this->generateDocument($model, $outputlangs, $hidedetails, $hidedesc, $hideref);
1292 public function getNomUrl($withpicto = 0, $option =
'', $maxlen = 0, $notooltip = 0, $morecss =
'', $save_lastsearch_value = -1)
1294 global $db, $conf, $langs, $hookmanager;
1295 global $dolibarr_main_authentication, $dolibarr_main_demo;
1296 global $menumanager;
1298 if (!empty($conf->dol_no_mouse_hover)) {
1304 $label =
img_picto(
'', $this->picto).
' <u>'.$langs->trans(
"Asset").
'</u>';
1305 if (isset($this->status)) {
1306 $label .=
' '.$this->getLibStatut(5);
1309 $label .=
'<b>'.$langs->trans(
'Ref').
':</b> '.$this->ref;
1311 $url =
dol_buildpath(
'/asset/card.php', 1).
'?id='.$this->id;
1313 if ($option !=
'nolink') {
1315 $add_save_lastsearch_values = ($save_lastsearch_value == 1 ? 1 : 0);
1316 if ($save_lastsearch_value == -1 && preg_match(
'/list\.php/', $_SERVER[
"PHP_SELF"])) {
1317 $add_save_lastsearch_values = 1;
1319 if ($add_save_lastsearch_values) {
1320 $url .=
'&save_lastsearch_values=1';
1325 if (empty($notooltip)) {
1326 if (!empty($conf->global->MAIN_OPTIMIZEFORTEXTBROWSER)) {
1327 $label = $langs->trans(
"ShowAsset");
1328 $linkclose .=
' alt="'.dol_escape_htmltag($label, 1).
'"';
1330 $linkclose .=
' title="'.dol_escape_htmltag($label, 1).
'"';
1331 $linkclose .=
' class="classfortooltip'.($morecss ?
' '.$morecss :
'').
'"';
1333 $linkclose = ($morecss ?
' class="'.$morecss.
'"' :
'');
1336 if ($option ==
'nolink') {
1337 $linkstart =
'<span';
1339 $linkstart =
'<a href="'.$url.
'"';
1341 $linkstart .= $linkclose.
'>';
1342 if ($option ==
'nolink') {
1343 $linkend =
'</span>';
1348 $result .= $linkstart;
1350 if (empty($this->showphoto_on_popup)) {
1352 $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);
1356 require_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
1358 list($class, $module) = explode(
'@', $this->picto);
1361 $filename = $filearray[0][
'name'];
1362 if (!empty($filename)) {
1363 $pospoint = strpos($filearray[0][
'name'],
'.');
1365 $pathtophoto = $class.
'/'.$this->
ref.
'/thumbs/'.substr($filename, 0, $pospoint).
'_mini'.substr($filename, $pospoint);
1366 if (empty($conf->global->{strtoupper($module.
'_'.$class).
'_FORMATLISTPHOTOSASUSERS'})) {
1367 $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>';
1369 $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>';
1372 $result .=
'</div>';
1374 $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);
1379 if ($withpicto != 2) {
1381 if ($option ==
'label') $name = $this->label;
1382 elseif ($option ==
'with_label') $name .= ' - ' . $this->label;
1386 $result .= $linkend;
1390 $hookmanager->initHooks(array($this->element . 'dao'));
1391 $parameters = array('
id'=>$this->
id, 'getnomurl' => &$result);
1392 $reshook = $hookmanager->executeHooks('
getNomUrl', $parameters, $this, $action);
1394 $result = $hookmanager->resPrint;
1396 $result .= $hookmanager->resPrint;
1409 return $this->
LibStatut($this->status, $mode);
1420 return $this->
LibStatut($this->status, $mode);
1434 if (empty($this->labelStatus) || empty($this->labelStatusShort)) {
1437 $this->labelStatus[self::STATUS_DRAFT] = $langs->transnoentitiesnoconv(
'AssetInProgress');
1438 $this->labelStatus[self::STATUS_DISPOSED] = $langs->transnoentitiesnoconv(
'AssetDisposed');
1439 $this->labelStatusShort[self::STATUS_DRAFT] = $langs->transnoentitiesnoconv(
'AssetInProgress');
1440 $this->labelStatusShort[self::STATUS_DISPOSED] = $langs->transnoentitiesnoconv(
'AssetDisposed');
1443 $statusType =
'status4';
1444 if ($status == self::STATUS_DISPOSED) {
1445 $statusType =
'status6';
1448 return dolGetStatus($this->labelStatus[$status], $this->labelStatusShort[$status],
'', $statusType, $mode);
1459 $sql =
"SELECT rowid, date_creation as datec, tms as datem,";
1460 $sql .=
" fk_user_creat, fk_user_modif";
1461 $sql .=
" FROM ".MAIN_DB_PREFIX.$this->table_element.
" as t";
1462 $sql .=
" WHERE t.rowid = ".((int) $id);
1464 $result = $this->db->query(
$sql);
1466 if ($this->db->num_rows($result)) {
1467 $obj = $this->db->fetch_object($result);
1468 $this->
id = $obj->rowid;
1470 $this->user_creation_id = $obj->fk_user_author;
1471 $this->user_validation_id = $obj->fk_user_valid;
1472 $this->user_cloture_id = $obj->fk_user_cloture;
1473 $this->date_creation = $this->db->jdate($obj->datec);
1474 $this->date_modification = $this->db->jdate($obj->datem);
1475 $this->date_validation = $this->db->jdate($obj->datev);
1478 $this->db->free($result);
1506 $this->lines = array();
1508 return $this->lines;
1518 global $langs, $conf;
1519 $langs->load(
"asset@asset");
1521 if (empty($conf->global->ASSET_ASSET_ADDON)) {
1522 $conf->global->ASSET_ASSET_ADDON =
'mod_asset_standard';
1525 if (!empty($conf->global->ASSET_ASSET_ADDON)) {
1528 $file = $conf->global->ASSET_ASSET_ADDON.
".php";
1529 $classname = $conf->global->ASSET_ASSET_ADDON;
1532 $dirmodels = array_merge(array(
'/'), (array) $conf->modules_parts[
'models']);
1533 foreach ($dirmodels as $reldir) {
1537 $mybool |= @include_once $dir.$file;
1540 if ($mybool ===
false) {
1545 if (class_exists($classname)) {
1546 $obj =
new $classname();
1547 $numref = $obj->getNextValue($this);
1549 if ($numref !=
'' && $numref !=
'-1') {
1552 $this->error = $obj->error;
1557 print $langs->trans(
"Error").
" ".$langs->trans(
"ClassNotFound").
' '.$classname;
1561 print $langs->trans(
"ErrorNumberingModuleNotSetup", $this->element);