25require_once DOL_DOCUMENT_ROOT.
'/core/class/commonobject.class.php';
35 public $table_element =
'';
70 public $fields = array();
76 public $deprecation_options_fields = array(
78 'label' =>
'AssetDepreciationOptionEconomic',
79 'table' =>
'asset_depreciation_options_economic',
81 'depreciation_type' => array(
'type' =>
'smallint',
'label' =>
'AssetDepreciationOptionDepreciationType',
'enabled' => 1,
'position' => 10,
'notnull' => 1,
'visible' => 1,
'default' =>
'0',
'arrayofkeyval' => array(0 =>
'AssetDepreciationOptionDepreciationTypeLinear', 1 =>
'AssetDepreciationOptionDepreciationTypeDegressive', 2 =>
'AssetDepreciationOptionDepreciationTypeExceptional'),
'validate' => 1,),
82 'degressive_coefficient' => array(
'type' =>
'double(24,8)',
'label' =>
'AssetDepreciationOptionDegressiveRate',
'enabled' => 1,
'position' => 20,
'notnull' => 1,
'visible' => 1,
'default' =>
'0',
'isameasure' => 1,
'validate' => 1,
'enabled_field' =>
'economic:depreciation_type:1'),
83 'duration' => array(
'type' =>
'integer',
'label' =>
'AssetDepreciationOptionDuration',
'enabled' => 1,
'position' => 30,
'notnull' => 1,
'visible' => 1,
'default' =>
'0',
'isameasure' => 1,
'validate' => 1,),
84 'duration_type' => array(
'type' =>
'smallint',
'label' =>
'AssetDepreciationOptionDurationType',
'enabled' => 1,
'position' => 40,
'notnull' => 1,
'visible' => 1,
'default' =>
'0',
'arrayofkeyval' => array(0 =>
'AssetDepreciationOptionDurationTypeAnnual', 1 =>
'AssetDepreciationOptionDurationTypeMonthly'),
'validate' => 1,),
85 'rate' => array(
'type' =>
'double(24,8)',
'label' =>
'AssetDepreciationOptionRate',
'enabled' => 1,
'position' => 50,
'visible' => 3,
'default' =>
'0',
'isameasure' => 1,
'validate' => 1,
'computed' =>
'$object->asset_depreciation_options->getRate("economic")',),
86 'accelerated_depreciation_option' => array(
'type' =>
'boolean',
'label' =>
'AssetDepreciationOptionAcceleratedDepreciation',
'enabled' => 1,
'position' => 60,
'column_break' =>
true,
'notnull' => 0,
'default' =>
'0',
'visible' => 1,
'validate' => 1,),
87 'amount_base_depreciation_ht' => array(
'type' =>
'price',
'label' =>
'AssetDepreciationOptionAmountBaseDepreciationHT',
'enabled' =>
'isset($object)&&get_class($object)=="Asset"',
'only_on_asset' => 1,
'position' => 90,
'notnull' => 0,
'required' => 1,
'visible' => 1,
'default' =>
'$object->reversal_amount_ht > 0 ? $object->reversal_amount_ht : $object->acquisition_value_ht',
'isameasure' => 1,
'validate' => 1,),
88 'amount_base_deductible_ht' => array(
'type' =>
'price',
'label' =>
'AssetDepreciationOptionAmountBaseDeductibleHT',
'enabled' =>
'isset($object)&&get_class($object)=="Asset"',
'only_on_asset' => 1,
'position' => 100,
'notnull' => 0,
'visible' => 1,
'default' =>
'0',
'isameasure' => 1,
'validate' => 1,),
89 'total_amount_last_depreciation_ht' => array(
'type' =>
'price',
'label' =>
'AssetDepreciationOptionTotalAmountLastDepreciationHT',
'enabled' =>
'isset($object)&&get_class($object)=="Asset"',
'only_on_asset' => 1,
'position' => 110,
'noteditable' => 1,
'notnull' => 0,
'visible' => 1,
'default' =>
'0',
'isameasure' => 1,
'validate' => 1,),
92 'accelerated_depreciation' => array(
93 'label' =>
'AssetDepreciationOptionAcceleratedDepreciation',
94 'table' =>
'asset_depreciation_options_fiscal',
95 'enabled_field' =>
'economic:accelerated_depreciation_option:1',
97 'depreciation_type' => array(
'type' =>
'smallint',
'label' =>
'AssetDepreciationOptionDepreciationType',
'enabled' => 1,
'position' => 10,
'notnull' => 1,
'visible' => 1,
'default' =>
'0',
'arrayofkeyval' => array(0 =>
'AssetDepreciationOptionDepreciationTypeLinear', 1 =>
'AssetDepreciationOptionDepreciationTypeDegressive', 2 =>
'AssetDepreciationOptionDepreciationTypeExceptional'),
'validate' => 1,),
98 'degressive_coefficient' => array(
'type' =>
'double(24,8)',
'label' =>
'AssetDepreciationOptionDegressiveRate',
'enabled' => 1,
'position' => 20,
'notnull' => 1,
'visible' => 1,
'default' =>
'0',
'isameasure' => 1,
'validate' => 1,
'enabled_field' =>
'accelerated_depreciation:depreciation_type:1'),
99 'duration' => array(
'type' =>
'integer',
'label' =>
'AssetDepreciationOptionDuration',
'enabled' => 1,
'position' => 30,
'notnull' => 1,
'visible' => 1,
'default' =>
'0',
'isameasure' => 1,
'validate' => 1,),
100 'duration_type' => array(
'type' =>
'smallint',
'label' =>
'AssetDepreciationOptionDurationType',
'enabled' => 1,
'position' => 40,
'notnull' => 1,
'visible' => 1,
'default' =>
'0',
'arrayofkeyval' => array(0 =>
'AssetDepreciationOptionDurationTypeAnnual', 1 =>
'AssetDepreciationOptionDurationTypeMonthly'),
'validate' => 1,),
101 'rate' => array(
'type' =>
'double(24,8)',
'label' =>
'AssetDepreciationOptionRate',
'enabled' => 1,
'position' => 50,
'visible' => 3,
'default' =>
'0',
'isameasure' => 1,
'validate' => 1,
'computed' =>
'$object->asset_depreciation_options->getRate("accelerated_depreciation")',),
102 'amount_base_depreciation_ht' => array(
'type' =>
'price',
'label' =>
'AssetDepreciationOptionAmountBaseDepreciationHT',
'enabled' =>
'isset($object)&&get_class($object)=="Asset"',
'only_on_asset' => 1,
'position' => 80,
'column_break' =>
true,
'notnull' => 0,
'required' => 1,
'visible' => 1,
'default' =>
'$object->reversal_amount_ht > 0 ? $object->reversal_amount_ht : $object->acquisition_value_ht',
'isameasure' => 1,
'validate' => 1,),
103 'amount_base_deductible_ht' => array(
'type' =>
'price',
'label' =>
'AssetDepreciationOptionAmountBaseDeductibleHT',
'enabled' =>
'isset($object)&&get_class($object)=="Asset"',
'only_on_asset' => 1,
'position' => 90,
'notnull' => 0,
'visible' => 1,
'default' =>
'0',
'isameasure' => 1,
'validate' => 1,),
104 'total_amount_last_depreciation_ht' => array(
'type' =>
'price',
'label' =>
'AssetDepreciationOptionTotalAmountLastDepreciationHT',
'enabled' =>
'isset($object)&&get_class($object)=="Asset"',
'only_on_asset' => 1,
'position' => 100,
'noteditable' => 1,
'notnull' => 0,
'visible' => 1,
'default' =>
'0',
'isameasure' => 1,
'validate' => 1,),
115 public $fk_asset_model;
119 public $fk_user_modif;
124 public $deprecation_options = array();
129 public $depreciation_type;
133 public $degressive_coefficient;
141 public $duration_type;
145 public $accelerated_depreciation_option;
158 if (is_object($langs)) {
159 foreach ($this->deprecation_options_fields as $mode_key => $mode_info) {
160 if (!empty($mode_info[
'fields']) && is_array($mode_info[
'fields'])) {
161 foreach ($mode_info[
'fields'] as $field_key => $field_info) {
162 if (!empty($field_info[
'arrayofkeyval']) && is_array($field_info[
'arrayofkeyval'])) {
163 foreach ($field_info[
'arrayofkeyval'] as $key => $val) {
164 $this->deprecation_options_fields[$mode_key][
'fields'][$field_key][
'arrayofkeyval'][$key] = $langs->trans($val);
184 $mode = strtolower(trim($mode));
186 if (!empty($this->deprecation_options_fields[$mode])) {
187 $this->table_element = $this->deprecation_options_fields[$mode][
'table'];
188 $this->fields = $this->deprecation_options_fields[$mode][
'fields'];
189 foreach ($this->fields as $field_key => $field_info) {
190 if ((!empty($field_info[
'computed']) && !$all_field) || (!empty($field_info[
'only_on_asset']) && !empty($class_type))) {
191 unset($this->fields[$field_key]);
196 if (!empty($field_info[
'enabled_field'])) {
197 $info = explode(
':', $field_info[
'enabled_field']);
198 if (!empty($this->deprecation_options[$info[0]][$info[1]]) && $this->deprecation_options[$info[0]][$info[1]] != $info[2] && isset($this->fields[$field_key][
'notnull'])) {
199 unset($this->fields[$field_key][
'notnull']);
203 $this->{$field_key} = $this->deprecation_options[$mode][$field_key] ??
null;
206 $this->fields[
'rowid'] = array(
'type' =>
'integer',
'label' =>
'TechnicalID',
'enabled' => 1,
'position' => 1,
'notnull' => 1,
'visible' => 0,
'noteditable' => 1,
'index' => 1,
'css' =>
'left',
'comment' =>
"Id");
207 if (empty($class_type)) {
208 $this->fields[
'fk_asset'] = array(
'type' =>
'integer:Asset:asset/class/asset.class.php:1:status=1 AND entity IN (__SHARED_ENTITIES__)',
'label' =>
'Asset',
'enabled' => 1,
'position' => 0,
'notnull' => 0,
'visible' => 0,
'index' => 1,
'validate' => 1,);
210 $this->fields[
'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' => 0,
'notnull' => 0,
'visible' => 0,
'index' => 1,
'validate' => 1,);
212 $this->fields[
'tms'] = array(
'type' =>
'timestamp',
'label' =>
'DateModification',
'enabled' => 1,
'position' => 501,
'notnull' => 0,
'visible' => 0,);
213 $this->fields[
'fk_user_modif'] = array(
'type' =>
'integer:User:user/class/user.class.php',
'label' =>
'UserModif',
'enabled' => 1,
'position' => 511,
'notnull' => -1,
'visible' => 0,);
227 global $conf, $langs;
231 $deprecation_options = array();
232 foreach ($this->deprecation_options_fields as $mode_key => $mode_info) {
235 foreach ($mode_info[
'fields'] as $field_key => $field_info) {
236 if (!empty($field_info[
'computed'])) {
240 $html_name = $mode_key .
'_' . $field_key;
241 if ($field_info[
'type'] ==
'duration') {
242 if (
GETPOST($html_name .
'hour') ==
'' &&
GETPOST($html_name .
'min') ==
'') {
246 if (!GETPOSTISSET($html_name)) {
251 if (in_array($field_key, array(
'rowid',
'entity',
'import_key'))) {
254 if (in_array($field_key, array(
'date_creation',
'tms',
'fk_user_creat',
'fk_user_modif'))) {
255 if (!in_array(abs($field_info[
'visible']), array(1, 3))) {
261 if (in_array($field_info[
'type'], array(
'text',
'html'))) {
262 $value =
GETPOST($html_name,
'restricthtml');
263 } elseif ($field_info[
'type'] ==
'date') {
265 } elseif ($field_info[
'type'] ==
'datetime') {
267 } elseif ($field_info[
'type'] ==
'duration') {
269 } elseif (preg_match(
'/^(integer|price|real|double)/', $field_info[
'type'])) {
271 } elseif ($field_info[
'type'] ==
'boolean') {
272 $value = ((
GETPOST($html_name) ==
'1' ||
GETPOST($html_name) ==
'on') ? 1 : 0);
273 } elseif ($field_info[
'type'] ==
'reference') {
275 $tmparraykey = array();
276 $value = $tmparraykey[
GETPOST($html_name)] .
',' .
GETPOST($html_name .
'2');
278 if ($field_key ==
'lang') {
279 $value =
GETPOST($html_name,
'aZ09') ?
GETPOST($html_name,
'aZ09') :
"";
281 $value =
GETPOST($html_name,
'alphanohtml');
284 if (preg_match(
'/^integer:/i', $field_info[
'type']) && $value ==
'-1') {
287 if (!empty($field_info[
'foreignkey']) && $value ==
'-1') {
292 $field_value = $value;
293 if ($field_info[
'notnull'] > 0 && $field_value ==
'' && !is_null($field_info[
'default']) && $field_info[
'default'] ==
'(PROV)') {
294 $field_value =
'(PROV)';
295 } elseif ((!empty($field_info[
'required']) || $field_info[
'notnull'] > 0) && $field_value ==
'' && !empty($field_info[
'default'])) {
296 $field_value = $field_info[
'default'];
298 if ($field_info[
'notnull'] > 0 && $field_value ==
'' && is_null($field_info[
'default'])) {
300 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv($field_info[
'label'])),
null,
'errors');
302 $deprecation_options[$mode_key][$field_key] = $field_value;
306 if (!$error && !empty($field_info[
'validate']) && is_callable(array($this,
'validateField'))) {
307 if (!$this->
validateField($mode_info[
'fields'], $field_key, $value)) {
315 foreach ($this->deprecation_options_fields as $mode_key => $mode_info) {
316 if (!empty($mode_info[
'enabled_field'])) {
317 $info = explode(
':', $mode_info[
'enabled_field']);
318 if ($deprecation_options[$info[0]][$info[1]] != $info[2]) {
319 unset($deprecation_options[$info[0]][$info[1]]);
323 $this->deprecation_options = $deprecation_options;
341 global $langs, $hookmanager;
342 dol_syslog(__METHOD__ .
" asset_id=$asset_id, asset_model_id=$asset_model_id");
345 $this->errors = array();
346 $this->deprecation_options = array();
349 $asset_id = $asset_id > 0 ? $asset_id : 0;
350 $asset_model_id = $asset_model_id > 0 ? $asset_model_id : 0;
352 $hookmanager->initHooks(array(
'assetdepreciationoptionsdao'));
353 $parameters = array(
'asset_id' => $asset_id,
'asset_model_id' => $asset_model_id);
354 $reshook = $hookmanager->executeHooks(
'fetchDepreciationOptions', $parameters, $this);
355 if (!empty($reshook)) {
360 if (empty($asset_id) && empty($asset_model_id)) {
361 $this->errors[] = $langs->trans(
'AssetErrorAssetOrAssetModelIDNotProvide');
369 $class_type = $asset_id > 0 ? 0 : 1;
370 $deprecation_options = array();
371 foreach ($this->deprecation_options_fields as $mode_key => $mode_info) {
374 $result = $this->
fetchCommon(0,
'',
" AND " . ($asset_id > 0 ?
" fk_asset = " . (
int) $asset_id :
" fk_asset_model = " . (int) $asset_model_id));
376 $this->errors = array_merge(array($langs->trans(
'AssetErrorFetchDepreciationOptionsForMode', $mode_key) .
':'), $this->errors);
378 } elseif ($result > 0) {
379 foreach ($this->fields as $field_key => $field_info) {
380 if (in_array($field_key, array(
'rowid',
'fk_asset',
'fk_asset_model',
'tms',
'fk_user_modif'))) {
383 $deprecation_options[$mode_key][$field_key] = $this->{$field_key};
388 foreach ($this->deprecation_options_fields as $mode_key => $mode_info) {
389 if (!empty($mode_info[
'enabled_field'])) {
390 $info = explode(
':', $mode_info[
'enabled_field']);
391 if (isset($deprecation_options[$info[0]][$info[1]]) && $deprecation_options[$info[0]][$info[1]] != $info[2]) {
392 unset($deprecation_options[$info[0]][$info[1]]);
401 $this->deprecation_options = $deprecation_options;
417 $this->errors = array();
420 $mode = strtolower(trim($mode));
422 $hookmanager->initHooks(array(
'assetdepreciationoptionsdao'));
423 $parameters = array(
'mode' => $mode);
424 $reshook = $hookmanager->executeHooks(
'getGeneralDepreciationInfoForMode', $parameters, $this);
427 } elseif ($reshook > 0) {
428 return $hookmanager->resArray;
431 $duration_type_list = $this->deprecation_options_fields[$mode][
'fields'][
'duration_type'][
'arrayofkeyval'];
434 'base_depreciation_ht' => $this->deprecation_options[$mode][
'amount_base_depreciation_ht'],
435 'duration' => $this->deprecation_options[$mode][
'duration'],
436 'duration_type' => $duration_type_list[$this->deprecation_options[$mode][
'duration_type']],
437 'rate' => $this->
getRate($mode),
452 global $langs, $hookmanager;
453 dol_syslog(__METHOD__ .
" user_id=".$user->id.
", asset_id=".$asset_id.
", asset_model_id=".$asset_model_id.
", notrigger=".$notrigger);
456 $this->errors = array();
459 $asset_id = $asset_id > 0 ? $asset_id : 0;
460 $asset_model_id = $asset_model_id > 0 ? $asset_model_id : 0;
462 $hookmanager->initHooks(array(
'assetdepreciationoptionsdao'));
463 $parameters = array(
'user' => $user,
'asset_id' => $asset_id,
'asset_model_id' => $asset_model_id);
464 $reshook = $hookmanager->executeHooks(
'updateDepreciationOptions', $parameters, $this);
465 if (!empty($reshook)) {
470 if (empty($asset_id) && empty($asset_model_id)) {
471 $this->errors[] = $langs->trans(
'AssetErrorAssetOrAssetModelIDNotProvide');
482 $this->fk_asset = $asset_id;
485 $this->fk_asset_model = $asset_model_id;
489 $this->fk_user_modif = $user->id;
491 foreach ($this->deprecation_options_fields as $mode_key => $mode_info) {
493 $sql =
"DELETE FROM " . MAIN_DB_PREFIX . $mode_info[
'table'];
494 $sql .=
" WHERE " . ($asset_id > 0 ?
" fk_asset = " . (int) $asset_id :
" fk_asset_model = " . (int) $asset_model_id);
495 $resql = $this->db->query($sql);
497 $this->errors[] = $langs->trans(
'AssetErrorDeleteDepreciationOptionsForMode', $mode_key) .
': ' . $this->db->lasterror();
501 if (!$error && !empty($this->deprecation_options[$mode_key])) {
502 if (!empty($mode_info[
'enabled_field'])) {
503 $info = explode(
':', $mode_info[
'enabled_field']);
504 if ($this->deprecation_options[$info[0]][$info[1]] != $info[2]) {
513 $this->errors = array_merge(array($langs->trans(
'AssetErrorInsertDepreciationOptionsForMode', $mode_key) .
':'), $this->errors);
519 if (!$error && $this->fk_asset > 0) {
521 require_once DOL_DOCUMENT_ROOT .
'/asset/class/asset.class.php';
522 $asset =
new Asset($this->db);
523 $result = $asset->fetch($this->fk_asset);
525 $result = $asset->calculationDepreciation();
528 $this->errors[] = $langs->trans(
'AssetErrorCalculationDepreciationLines');
529 $this->errors[] = $asset->errorsToString();
534 if (!$error && !$notrigger) {
536 $result = $this->
call_trigger(
'ASSET_DEPRECIATION_OPTIONS_MODIFY', $user);
544 $this->db->rollback();
560 $duration = (isset($this->deprecation_options[$mode][
"duration"]) && $this->deprecation_options[$mode][
"duration"] > 0) ? $this->deprecation_options[$mode][
"duration"] : 0;
561 $duration_type = (isset($this->deprecation_options[$mode][
"duration_type"]) && $this->deprecation_options[$mode][
"duration_type"] > 0) ? $this->deprecation_options[$mode][
"duration_type"] : 0;
563 return price(
price2num($duration > 0 ? (100 * ($duration_type == 1 ? 12 : 1) / $duration) : 0, 2));
Class for AssetDepreciationOptions.
__construct(DoliDB $db)
Constructor.
updateDeprecationOptions($user, $asset_id=0, $asset_model_id=0, $notrigger=0)
Update deprecation options of a asset or a asset model.
getGeneralDepreciationInfoForMode($mode)
get general depreciation info for a mode (used in depreciation card)
setDeprecationOptionsFromPost($class_type=0)
Fill deprecation_options property of object (using for data sent by forms)
setInfosForMode($mode, $class_type=0, $all_field=false)
Set object infos for a mode.
fetchDeprecationOptions($asset_id=0, $asset_model_id=0)
Load deprecation options of a asset or a asset model.
Parent class of all other business classes (invoices, contracts, proposals, orders,...
validateField($fields, $fieldKey, $fieldValue)
Return validation test result for a field.
createCommon(User $user, $notrigger=0)
Create object in the database.
errorsToString()
Method to output saved errors.
fetchCommon($id, $ref=null, $morewhere='', $noextrafields=0)
Load object in memory from the database.
call_trigger($triggerName, $user)
Call trigger based on this instance.
Class to manage Dolibarr database access.
dol_mktime($hour, $minute, $second, $month, $day, $year, $gm='auto', $check=1)
Return a timestamp date built from detailed information (by default a local PHP server timestamp) Rep...
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0, $attop=0)
Set event messages in dol_events session object.
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
price2num($amount, $rounding='', $option=0)
Function that return a number with universal decimal format (decimal separator is '.
price($amount, $form=0, $outlangs='', $trunc=1, $rounding=-1, $forcerounding=-1, $currency_code='')
Function to format a value into an amount for visual output Function used into PDF and HTML pages.
dol_now($mode='auto')
Return date for now.
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.
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.