32require_once DOL_DOCUMENT_ROOT.
'/core/class/commonobject.class.php';
33require_once DOL_DOCUMENT_ROOT.
'/fichinter/class/fichinterligne.class.php';
34require_once DOL_DOCUMENT_ROOT.
'/core/class/commonsignedobject.class.php';
35require_once DOL_DOCUMENT_ROOT.
'/subtotals/class/commonsubtotal.class.php';
45 use CommonSignedObject, CommonSubtotal;
51 public $TRIGGER_PREFIX =
'FICHINTER';
53 public $fields = array(
54 'rowid' => array(
'type' =>
'integer',
'label' =>
'TechnicalID',
'enabled' => 1,
'visible' => -1,
'notnull' => 1,
'position' => 10),
55 'fk_soc' => array(
'type' =>
'integer:Societe:societe/class/societe.class.php',
'label' =>
'ThirdParty',
'enabled' =>
'isModEnabled("societe")',
'visible' => -1,
'notnull' => 1,
'position' => 15),
56 'fk_projet' => array(
'type' =>
'integer:Project:projet/class/project.class.php:1:(fk_statut:=:1)',
'label' =>
'Project',
'enabled' =>
'isModEnabled("project")',
'visible' => -1,
'position' => 20),
57 'fk_contrat' => array(
'type' =>
'integer:Contrat:contrat/class/contrat.class.php',
'label' =>
'Contract',
'enabled' =>
'isModEnabled("contract")',
'visible' => -1,
'position' => 25),
58 'ref' => array(
'type' =>
'varchar(30)',
'label' =>
'Ref',
'enabled' => 1,
'visible' => -1,
'notnull' => 1,
'showoncombobox' => 1,
'position' => 30),
59 'ref_ext' => array(
'type' =>
'varchar(255)',
'label' =>
'RefExt',
'enabled' => 1,
'visible' => 0,
'position' => 35),
60 'ref_client' => array(
'type' =>
'varchar(255)',
'label' =>
'RefCustomer',
'enabled' => 1,
'visible' => -1,
'position' => 36),
61 'entity' => array(
'type' =>
'integer',
'label' =>
'Entity',
'default' =>
'1',
'enabled' => 1,
'visible' => -2,
'notnull' => 1,
'position' => 40,
'index' => 1),
62 'tms' => array(
'type' =>
'timestamp',
'label' =>
'DateModification',
'enabled' => 1,
'visible' => -1,
'notnull' => 1,
'position' => 45),
63 'datec' => array(
'type' =>
'datetime',
'label' =>
'DateCreation',
'enabled' => 1,
'visible' => -1,
'position' => 50),
64 'date_valid' => array(
'type' =>
'datetime',
'label' =>
'DateValidation',
'enabled' => 1,
'visible' => -1,
'position' => 55),
65 'datei' => array(
'type' =>
'date',
'label' =>
'Datei',
'enabled' => 1,
'visible' => -1,
'position' => 60),
66 'fk_user_author' => array(
'type' =>
'integer:User:user/class/user.class.php',
'label' =>
'UserAuthor',
'enabled' => 1,
'visible' => -1,
'position' => 65),
67 'fk_user_modif' => array(
'type' =>
'integer:User:user/class/user.class.php',
'label' =>
'UserModif',
'enabled' => 1,
'visible' => -2,
'notnull' => -1,
'position' => 70),
68 'fk_user_valid' => array(
'type' =>
'integer:User:user/class/user.class.php',
'label' =>
'UserValidation',
'enabled' => 1,
'visible' => -1,
'position' => 75),
69 'dateo' => array(
'type' =>
'date',
'label' =>
'Dateo',
'enabled' => 1,
'visible' => -1,
'position' => 85),
70 'datee' => array(
'type' =>
'date',
'label' =>
'Datee',
'enabled' => 1,
'visible' => -1,
'position' => 90),
71 'datet' => array(
'type' =>
'date',
'label' =>
'Datet',
'enabled' => 1,
'visible' => -1,
'position' => 95),
72 'duree' => array(
'type' =>
'integer',
'label' =>
'Duree',
'enabled' => 1,
'visible' => -1,
'position' => 100),
73 'signed_status' => array(
'type' =>
'smallint(6)',
'label' =>
'SignedStatus',
'enabled' => 1,
'visible' => -1,
'position' => 101,
'arrayofkeyval' => array(0 =>
'NoSignature', 1 =>
'SignedSender', 2 =>
'SignedReceiver', 3 =>
'SignedReceiverOnline', 9 =>
'SignedAll')),
74 'description' => array(
'type' =>
'html',
'label' =>
'Description',
'enabled' => 1,
'visible' => -1,
'position' => 105,
'showoncombobox' => 2),
75 'note_private' => array(
'type' =>
'html',
'label' =>
'NotePrivate',
'enabled' => 1,
'visible' => 0,
'position' => 110),
76 'note_public' => array(
'type' =>
'html',
'label' =>
'NotePublic',
'enabled' => 1,
'visible' => 0,
'position' => 115),
77 'model_pdf' => array(
'type' =>
'varchar(255)',
'label' =>
'PDFTemplate',
'enabled' => 1,
'visible' => 0,
'position' => 120),
78 'last_main_doc' => array(
'type' =>
'varchar(255)',
'label' =>
'LastMainDoc',
'enabled' => 1,
'visible' => -1,
'position' => 125),
79 'import_key' => array(
'type' =>
'varchar(14)',
'label' =>
'ImportId',
'enabled' => 1,
'visible' => -2,
'position' => 130),
80 'extraparams' => array(
'type' =>
'varchar(255)',
'label' =>
'Extraparams',
'enabled' => 1,
'visible' => -1,
'position' => 135),
81 'fk_statut' => array(
'type' =>
'integer',
'label' =>
'Status',
'enabled' => 1,
'visible' => -1,
'position' => 500),
87 public $element =
'fichinter';
92 public $fk_element =
'fk_fichinter';
97 public $table_element =
'fichinter';
102 public $table_element_line =
'fichinterdet';
107 public $class_element_line =
'FichinterLigne';
112 public $picto =
'intervention';
183 public $fk_contrat = 0;
199 public $extraparams = array();
204 public $lines = array();
231 public $date_delivery;
237 public $delivery_date_receipt;
243 public $user_author_id;
268 $sql =
"SELECT count(fi.rowid) as nb";
269 $sql .=
" FROM ".MAIN_DB_PREFIX.
"fichinter as fi";
270 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"societe as s ON fi.fk_soc = s.rowid";
271 if (!$user->hasRight(
'societe',
'client',
'voir')) {
272 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"societe_commerciaux as sc ON s.rowid = sc.fk_soc";
273 $sql .=
" WHERE sc.fk_user = ".((int) $user->id);
276 $sql .=
" ".$clause.
" fi.entity IN (".
getEntity(
'intervention').
")";
278 $resql = $this->db->query($sql);
280 while ($obj = $this->db->fetch_object($resql)) {
281 $this->nb[
"interventions"] = $obj->nb;
283 $this->db->free($resql);
287 $this->error = $this->db->error();
299 public function create($user, $notrigger = 0)
306 if (!empty($this->ref)) {
309 $this->error =
'ErrorRefAlreadyExists';
310 dol_syslog(get_class($this).
"::create ".$this->error, LOG_WARNING);
311 $this->db->rollback();
315 if (!is_numeric($this->duration)) {
318 if (!empty($this->ref_client)) {
319 $this->ref_client = trim($this->ref_client);
322 if ($this->socid <= 0) {
323 $this->error =
'ErrorFicheinterCompanyDoesNotExist';
324 dol_syslog(get_class($this).
"::create ".$this->error, LOG_ERR);
330 $result = $soc->fetch($this->socid);
336 $sql =
"INSERT INTO ".MAIN_DB_PREFIX.
"fichinter (";
340 $sql .=
", ref_client";
342 $sql .=
", fk_user_author";
343 $sql .=
", fk_user_modif";
344 $sql .=
", description";
345 $sql .=
", model_pdf";
346 $sql .=
", fk_projet";
347 $sql .=
", fk_contrat";
348 $sql .=
", fk_statut";
349 $sql .=
", signed_status";
350 $sql .=
", note_private";
351 $sql .=
", note_public";
354 $sql .= $this->socid;
355 $sql .=
", '".$this->db->idate($now).
"'";
356 $sql .=
", '".$this->db->escape($this->ref).
"'";
357 $sql .=
", ".($this->ref_client ?
"'".$this->db->escape($this->ref_client).
"'" :
"null");
358 $sql .=
", ".((int) $this->entity);
359 $sql .=
", ".((int) $user->id);
360 $sql .=
", ".((int) $user->id);
361 $sql .=
", ".($this->description ?
"'".$this->db->escape($this->
description).
"'" :
"null");
362 $sql .=
", '".$this->db->escape($this->model_pdf).
"'";
363 $sql .=
", ".((int) $this->fk_project > 0 ? ((
int) $this->fk_project) : 0);
364 $sql .=
", ".((int) $this->fk_contrat > 0 ? ((
int) $this->fk_contrat) : 0);
365 $sql .=
", ".((int) $this->
status);
366 $sql .=
", ".((int) $this->signed_status);
367 $sql .=
", ".($this->note_private ?
"'".$this->db->escape($this->note_private).
"'" :
"null");
368 $sql .=
", ".($this->note_public ?
"'".$this->db->escape($this->note_public).
"'" :
"null");
371 dol_syslog(get_class($this).
"::create", LOG_DEBUG);
372 $result = $this->db->query($sql);
374 $this->
id = $this->db->last_insert_id(MAIN_DB_PREFIX.
"fichinter");
377 $this->ref =
'(PROV'.$this->id.
')';
378 $sql =
'UPDATE '.MAIN_DB_PREFIX.
"fichinter SET ref='".$this->db->escape($this->ref).
"' WHERE rowid=".((int) $this->
id);
380 dol_syslog(get_class($this).
"::create", LOG_DEBUG);
381 $resql = $this->db->query($sql);
395 if (!$error && $this->origin && $this->origin_id) {
403 if (!$error && !$notrigger) {
405 $result = $this->call_trigger(
'FICHINTER_CREATE', $user);
416 $this->db->rollback();
417 $this->error = implode(
',', $this->errors);
418 dol_syslog(get_class($this).
"::create ".$this->error, LOG_ERR);
422 $this->error = $this->db->error();
423 $this->db->rollback();
435 public function update($user, $notrigger = 0)
439 if (!is_numeric($this->duration)) {
442 if (!
dol_strlen((
string) $this->fk_project)) {
443 $this->fk_project = 0;
445 if (!empty($this->ref_client)) {
446 $this->ref_client = trim($this->ref_client);
453 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"fichinter SET ";
454 $sql .=
"description = '".$this->db->escape($this->
description).
"'";
455 $sql .=
", duree = ".((int) $this->duration);
456 $sql .=
", ref_client = ".($this->ref_client ?
"'".$this->db->escape($this->ref_client).
"'" :
"null");
457 if ((
int) $this->fk_project > 0) {
458 $sql .=
", fk_projet = ".((int) $this->fk_project);
460 if (isset($this->datec)) {
461 $sql .=
", datec = ".($this->datec ?
"'".$this->db->idate($this->datec).
"'" :
"null");
463 if (isset($this->datev)) {
464 $sql .=
", date_valid = ".($this->datev ?
"'".$this->db->idate($this->datev).
"'" :
"null");
466 if (isset($this->datet)) {
467 $sql .=
", datet = ".($this->datet ?
"'".$this->db->idate($this->datet).
"'" :
"null");
469 $sql .=
", note_private = ".($this->note_private ?
"'".$this->db->escape($this->note_private).
"'" :
"null");
470 $sql .=
", note_public = ".($this->note_public ?
"'".$this->db->escape($this->note_public).
"'" :
"null");
471 $sql .=
", fk_user_modif = ".((int) $user->id);
472 $sql .=
" WHERE rowid = ".((int) $this->
id);
474 dol_syslog(get_class($this).
"::update", LOG_DEBUG);
475 if ($this->db->query($sql)) {
481 if (!$error && !$notrigger) {
483 $result = $this->call_trigger(
'FICHINTER_MODIFY', $user);
486 $this->db->rollback();
495 $this->error = $this->db->error();
496 $this->db->rollback();
509 public function fetch($rowid, $ref =
'', $ref_ext =
'')
511 $sql =
"SELECT f.rowid, f.ref, f.ref_client, f.description, f.fk_soc, f.fk_statut as status, f.signed_status,";
512 $sql .=
" f.datec, f.dateo, f.datee, f.datet,";
513 $sql .=
" f.date_valid as datev,";
514 $sql .=
" f.tms as datem,";
515 $sql .=
" f.fk_user_author, f.fk_user_modif,";
516 $sql .=
" f.duree, f.fk_projet as fk_project, f.note_public, f.note_private, f.model_pdf, f.last_main_doc, f.extraparams, fk_contrat, f.entity as entity";
517 $sql .=
" FROM ".MAIN_DB_PREFIX.
"fichinter as f";
518 $sql .=
" WHERE f.entity IN (".getEntity(
'intervention').
")";
520 $sql .=
" AND f.ref = '".$this->db->escape($ref).
"'";
521 } elseif ($ref_ext) {
522 $sql .=
" AND f.ref_ext = '".$this->db->escape($ref_ext).
"'";
524 $sql .=
" AND f.rowid = ".((int) $rowid);
527 $resql = $this->db->query($sql);
529 if ($this->db->num_rows($resql)) {
530 $obj = $this->db->fetch_object($resql);
532 $this->
id = $obj->rowid;
533 $this->
ref = $obj->ref;
534 $this->ref_client = $obj->ref_client;
536 $this->socid = $obj->fk_soc;
537 $this->
status = $obj->status;
538 $this->statut = $obj->status;
539 $this->signed_status = $obj->signed_status;
540 $this->duration = $obj->duree;
541 $this->datec = $this->db->jdate($obj->datec);
542 $this->dateo = $this->db->jdate($obj->dateo);
543 $this->datee = $this->db->jdate($obj->datee);
544 $this->datet = $this->db->jdate($obj->datet);
545 $this->datev = $this->db->jdate($obj->datev);
546 $this->datem = $this->db->jdate($obj->datem);
547 $this->fk_project = $obj->fk_project;
548 $this->note_public = $obj->note_public;
549 $this->note_private = $obj->note_private;
550 $this->model_pdf = $obj->model_pdf;
551 $this->fk_contrat = $obj->fk_contrat;
552 $this->entity = $obj->entity;
554 $this->user_author_id = $this->user_creation_id = $obj->fk_user_author;
555 $this->user_modification_id = $obj->fk_user_modif;
557 $this->extraparams = is_null($obj->extraparams) ? [] : (array) json_decode($obj->extraparams,
true);
559 $this->last_main_doc = $obj->last_main_doc;
571 $this->db->free($resql);
577 $this->error = $this->db->lasterror();
593 if ($this->
status <= self::STATUS_DRAFT) {
597 dol_syslog(get_class($this).
"::setDraft", LOG_DEBUG);
603 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"fichinter";
604 $sql .=
" SET fk_statut = ".self::STATUS_DRAFT;
605 $sql .=
" WHERE rowid = ".((int) $this->
id);
607 $resql = $this->db->query($sql);
610 $result = $this->call_trigger(
'FICHINTER_UNVALIDATE', $user);
621 $this->db->rollback();
625 $this->db->rollback();
626 $this->error = $this->db->lasterror();
641 require_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
645 if ($this->
status != self::STATUS_VALIDATED) {
651 if ((preg_match(
'/^[\(]?PROV/i', $this->
ref) || empty($this->
ref))) {
658 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"fichinter";
659 $sql .=
" SET fk_statut = 1";
660 $sql .=
", ref = '".$this->db->escape($num).
"'";
661 $sql .=
", date_valid = '".$this->db->idate($now).
"'";
662 $sql .=
", fk_user_valid = ".($user->id > 0 ? (int) $user->id :
"null");
663 $sql .=
" WHERE rowid = ".((int) $this->
id);
664 $sql .=
" AND entity = ".((int) $this->entity);
666 $sql .=
" AND fk_statut = 0";
668 dol_syslog(get_class($this).
"::setValid", LOG_DEBUG);
669 $resql = $this->db->query($sql);
675 if (!$error && !$notrigger) {
677 $result = $this->call_trigger(
'FICHINTER_VALIDATE', $user);
685 $this->oldref = $this->ref;
688 if (preg_match(
'/^[\(]?PROV/i', $this->
ref)) {
689 require_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
692 $sql =
'UPDATE '.MAIN_DB_PREFIX.
"ecm_files set filename = CONCAT('".$this->db->escape($this->newref).
"', SUBSTR(filename, ".(strlen($this->
ref) + 1).
")), filepath = 'ficheinter/".$this->db->escape($this->newref).
"'";
693 $sql .=
" WHERE filename LIKE '".$this->db->escape($this->
ref).
"%' AND filepath = 'ficheinter/".$this->db->escape($this->
ref).
"' and entity = ".((int) $this->entity);
694 $resql = $this->db->query($sql);
697 $this->error = $this->db->lasterror();
699 $sql =
'UPDATE '.MAIN_DB_PREFIX.
"ecm_files set filepath = 'ficheinter/".$this->db->escape($this->newref).
"'";
700 $sql .=
" WHERE filepath = 'ficheinter/".$this->db->escape($this->
ref).
"' and entity = ".$conf->entity;
701 $resql = $this->db->query($sql);
704 $this->error = $this->db->lasterror();
710 $dirsource =
$conf->ficheinter->dir_output.
'/'.$oldref;
711 $dirdest =
$conf->ficheinter->dir_output.
'/'.$newref;
712 if (!$error && file_exists($dirsource)) {
713 dol_syslog(get_class($this).
"::setValid rename dir ".$dirsource.
" into ".$dirdest);
715 if (@rename($dirsource, $dirdest)) {
718 $listoffiles =
dol_dir_list(
$conf->ficheinter->dir_output.
'/'.$newref,
'files', 1,
'^'.preg_quote($oldref,
'/'));
719 foreach ($listoffiles as $fileentry) {
720 $dirsource = $fileentry[
'name'];
721 $dirdest = preg_replace(
'/^'.preg_quote($oldref,
'/').
'/', $newref, $dirsource);
722 $dirsource = $fileentry[
'path'].
'/'.$dirsource;
723 $dirdest = $fileentry[
'path'].
'/'.$dirdest;
724 @rename($dirsource, $dirdest);
736 $this->date_validation = $now;
740 $this->db->rollback();
741 dol_syslog(get_class($this).
"::setValid ".$this->error, LOG_ERR);
762 if ($this->
status == self::STATUS_CLOSED) {
769 $sql =
'UPDATE ' . MAIN_DB_PREFIX . $this->table_element;
770 $sql .=
' SET fk_statut = ' . self::STATUS_CLOSED .
',';
771 $sql .=
" datet = '" . $this->db->idate($now) .
"',";
772 $sql .=
" fk_user_modif = " . ((int) $user->id);
773 $sql .=
" WHERE rowid = " . ((int) $this->
id);
775 $sql .=
" AND entity = " . ((int)
$conf->entity);
777 if ($this->db->query($sql)) {
780 $result = $this->call_trigger(
'FICHINTER_CLOSE', $user);
793 $this->db->rollback();
797 $this->error = $this->db->lasterror();
798 $this->db->rollback();
813 $this->author =
new User($this->db);
814 $this->author->fetch($this->user_creation_id);
816 $thm = $this->author->thm;
818 foreach ($this->lines as $line) {
819 $amount += ($line->duration / 60 / 60 * (float) $thm);
837 public function generateDocument($modele, $outputlangs, $hidedetails = 0, $hidedesc = 0, $hideref = 0, $moreparams =
null)
841 $outputlangs->load(
"interventions");
846 if (!empty($this->model_pdf)) {
847 $modele = $this->model_pdf;
853 $modelpath =
"core/modules/fichinter/doc/";
855 return $this->
commonGenerateDocument($modelpath, $modele, $outputlangs, $hidedetails, $hidedesc, $hideref, $moreparams);
866 return $this->
LibStatut((isset($this->statut) ? $this->statut : $this->status), $mode);
882 if (empty($this->labelStatus) || empty($this->labelStatusShort)) {
883 $langs->load(
"interventions");
884 $langs->load(
"propal");
888 $this->labelStatus[
self::STATUS_BILLED] = $langs->transnoentitiesnoconv(
'StatusInterInvoiced');
892 $this->labelStatusShort[
self::STATUS_BILLED] = $langs->transnoentitiesnoconv(
'StatusInterInvoiced');
896 $statuscode =
'status'.$status;
897 if ($status == self::STATUS_BILLED || $status == self::STATUS_CLOSED) {
898 $statuscode =
'status6';
902 $status_label = $this->signed_status ? $this->labelStatus[$status] . $signed_label : $this->labelStatus[$status];
903 $status_label_short = $this->signed_status ? $this->labelStatusShort[$status] . $signed_label : $this->labelStatusShort[$status];
905 return dolGetStatus($status_label, $status_label_short,
'', $statuscode, $mode);
918 $langs->load(
'interventions');
921 $datas[
'picto'] =
img_picto(
'', $this->picto).
' <u class="paddingrightonly">'.$langs->trans(
"ShowIntervention").
'</u>';
922 $datas[
'picto'] .=
' '.$this->getLibStatut(5);
923 $datas[
'ref'] =
'<br><b>'.$langs->trans(
'Ref').
':</b> '.$this->ref;
938 public function getNomUrl($withpicto = 0, $option =
'', $notooltip = 0, $save_lastsearch_value = -1, $morecss =
'')
940 global
$conf, $langs, $hookmanager;
942 if (!empty(
$conf->dol_no_mouse_hover)) {
949 'objecttype' => $this->element,
952 $classfortooltip =
'classfortooltip';
955 $classfortooltip =
'classforajaxtooltip';
956 $dataparams =
' data-params="'.dol_escape_htmltag(json_encode($params)).
'"';
962 $url = DOL_URL_ROOT.
'/fichinter/card.php?id='.$this->id;
964 if ($option !==
'nolink') {
966 $add_save_lastsearch_values = ($save_lastsearch_value == 1 ? 1 : 0);
967 if ($save_lastsearch_value == -1 && isset($_SERVER[
"PHP_SELF"]) && preg_match(
'/list\.php/', $_SERVER[
"PHP_SELF"])) {
968 $add_save_lastsearch_values = 1;
970 if ($add_save_lastsearch_values) {
971 $url .=
'&save_lastsearch_values=1';
976 if (empty($notooltip)) {
978 $label = $langs->trans(
"ShowIntervention");
979 $linkclose .=
' alt="'.dolPrintHTMLForAttribute($label).
'"';
981 $linkclose .= ($label ?
' title="'.dolPrintHTMLForAttribute($label).
'"' :
' title="tocomplete"');
982 $linkclose .= $dataparams.
' class="'.$classfortooltip.($morecss ?
' '.$morecss :
'').
'"';
984 $linkclose = ($morecss ?
' class="'.$morecss.
'"' :
'');
987 if ($option ==
'nolink') {
988 $linkstart =
'<span';
990 $linkstart =
'<a href="'.$url.
'"';
992 $linkstart .= $linkclose.
'>';
993 if ($option ==
'nolink') {
994 $linkend =
'</span>';
999 $result .= $linkstart;
1001 $result .=
img_object(($notooltip ?
'' : $label), ($this->picto ? $this->picto :
'generic'), ($notooltip ? (($withpicto != 2) ?
'class="paddingright"' :
'') :
'class="'.(($withpicto != 2) ?
'paddingright ' :
'').
'"'), 0, 0, $notooltip ? 0 : 1);
1004 if ($withpicto != 2) {
1005 $result .= $this->ref;
1008 $result .= $linkend;
1011 $hookmanager->initHooks(array(
'interventiondao'));
1012 $parameters = array(
'id' => $this->
id,
'getnomurl' => &$result);
1013 $reshook = $hookmanager->executeHooks(
'getNomUrl', $parameters, $this, $action);
1015 $result = $hookmanager->resPrint;
1017 $result .= $hookmanager->resPrint;
1033 global
$conf, $db, $langs;
1034 $langs->load(
"interventions");
1043 $dirmodels = array_merge(array(
'/'), (array)
$conf->modules_parts[
'models']);
1045 foreach ($dirmodels as $reldir) {
1049 $mybool = ((bool) @include_once $dir.$file) || $mybool;
1057 $obj =
new $classname();
1058 '@phan-var-force ModeleNumRefFicheinter $obj';
1060 $numref = $obj->getNextValue($soc, $this);
1062 if ($numref !=
"") {
1069 $langs->load(
"errors");
1070 print $langs->trans(
"Error").
" ".$langs->trans(
"Error_FICHEINTER_ADDON_NotDefined");
1083 $sql =
"SELECT f.rowid,";
1084 $sql .=
" f.datec,";
1085 $sql .=
" f.tms as date_modification,";
1086 $sql .=
" f.date_valid as datev,";
1087 $sql .=
" f.fk_user_author,";
1088 $sql .=
" f.fk_user_modif as fk_user_modification,";
1089 $sql .=
" f.fk_user_valid";
1090 $sql .=
" FROM ".MAIN_DB_PREFIX.
"fichinter as f";
1091 $sql .=
" WHERE f.rowid = ".((int) $id);
1093 $resql = $this->db->query($sql);
1095 if ($this->db->num_rows($resql)) {
1096 $obj = $this->db->fetch_object($resql);
1098 $this->
id = $obj->rowid;
1100 $this->date_creation = $this->db->jdate($obj->datec);
1101 $this->date_modification = $this->db->jdate($obj->date_modification);
1102 $this->date_validation = $this->db->jdate($obj->datev);
1104 $this->user_creation_id = $obj->fk_user_author;
1105 $this->user_validation_id = $obj->fk_user_valid;
1106 $this->user_modification_id = $obj->fk_user_modification;
1108 $this->db->free($resql);
1121 public function delete(
User $user, $notrigger = 0)
1123 global
$conf, $langs;
1124 require_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
1132 $result = $this->call_trigger(
'FICHINTER_DELETE', $user);
1135 $this->db->rollback();
1151 $this->error =
'ErrorFailToDeleteLinkedContact';
1157 $main = MAIN_DB_PREFIX.
'fichinterdet';
1158 $ef = $main.
"_extrafields";
1159 $sql =
"DELETE FROM ".$this->db->sanitize($ef).
" WHERE fk_object IN (SELECT rowid FROM ".$this->db->sanitize($main).
" WHERE fk_fichinter = ".((int) $this->
id).
")";
1161 $resql = $this->db->query($sql);
1168 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.
"fichinterdet";
1169 $sql .=
" WHERE fk_fichinter = ".((int) $this->
id);
1171 $resql = $this->db->query($sql);
1187 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.
"fichinter";
1188 $sql .=
" WHERE rowid = ".((int) $this->
id);
1191 $resql = $this->db->query($sql);
1204 if ($conf->ficheinter->dir_output) {
1205 $dir =
$conf->ficheinter->dir_output.
"/".$fichinterref;
1206 $file =
$conf->ficheinter->dir_output.
"/".$fichinterref.
"/".$fichinterref.
".pdf";
1207 if (file_exists($file)) {
1211 $langs->load(
"errors");
1212 $this->error = $langs->trans(
"ErrorFailToDeleteFile", $file);
1216 if (file_exists($dir)) {
1218 $langs->load(
"errors");
1219 $this->error = $langs->trans(
"ErrorFailToDeleteDir", $dir);
1227 $this->db->commit();
1230 $this->db->rollback();
1246 if ($user->hasRight(
'ficheinter',
'creer')) {
1247 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"fichinter";
1248 $sql .=
" SET datei = '".$this->db->idate($delivery_date_receipt).
"'";
1249 $sql .=
" WHERE rowid = ".((int) $this->
id);
1250 $sql .=
" AND fk_statut = 0";
1252 if ($this->db->query($sql)) {
1253 $this->date_delivery = $delivery_date_receipt;
1254 $this->delivery_date_receipt = $delivery_date_receipt;
1257 $this->error = $this->db->error();
1258 dol_syslog(
"Fichinter::set_date_delivery Erreur SQL");
1277 if ($user->hasRight(
'ficheinter',
'creer')) {
1278 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"fichinter ";
1279 $sql .=
" SET description = '".$this->db->escape($description).
"',";
1280 $sql .=
" fk_user_modif = ".((int) $user->id);
1281 $sql .=
" WHERE rowid = ".((int) $this->
id);
1283 if ($this->db->query($sql)) {
1287 $this->error = $this->db->error();
1288 dol_syslog(
"Fichinter::set_description Erreur SQL");
1308 if ($user->hasRight(
'ficheinter',
'creer')) {
1309 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"fichinter ";
1310 $sql .=
" SET fk_contrat = ".((int) $contractid);
1311 $sql .=
" WHERE rowid = ".((int) $this->
id);
1313 if ($this->db->query($sql)) {
1314 $this->fk_contrat = $contractid;
1317 $this->error = $this->db->error();
1338 global $hookmanager, $langs;
1339 $langs->load(
"errors");
1346 foreach ($this->lines as $line) {
1347 $line->fetch_optionals();
1351 $objFrom = clone $this;
1354 if (!empty($socid) && $socid != $this->socid) {
1355 $objsoc =
new Societe($this->db);
1357 if ($objsoc->fetch($socid) > 0) {
1358 $this->socid = $objsoc->id;
1361 $this->fk_project = 0;
1362 $this->fk_delivery_address = 0;
1374 $this->user_author_id = $user->id;
1375 $this->user_validation_id = 0;
1376 $this->date_creation =
'';
1377 $this->date_validation =
'';
1378 $this->signed_status = 0;
1380 $this->ref_client =
'';
1382 if (!$clone_notes) {
1383 $this->note_private =
'';
1384 $this->note_public =
'';
1388 $this->context[
'createfromclone'] =
'createfromclone';
1389 $result = $this->
create($user);
1396 foreach ($this->lines as $line) {
1397 $this->
addline($user, $this->
id, $line->desc, $line->datei, $line->duration, $line->array_options);
1401 if (is_object($hookmanager)) {
1402 $parameters = array(
'objFrom' => $objFrom);
1404 $reshook = $hookmanager->executeHooks(
'createFrom', $parameters, $this, $action);
1413 if ($clone_contacts) {
1414 foreach (array(
'internal',
'external') as $source) {
1415 $tab = $objFrom->liste_contact(-1, $source);
1416 if (is_array($tab) && count($tab) > 0) {
1417 foreach ($tab as $contacttoadd) {
1419 $contacttoadd[
'id'],
1420 $contacttoadd[
'code'],
1421 $contacttoadd[
'source']
1423 if ($this->error ==
'DB_ERROR_RECORD_ALREADY_EXISTS') {
1424 $this->error .= $langs->trans(
"ErrorThisContactIsAlreadyDefinedAsThisType");
1426 } elseif ($retAddContact < 0) {
1430 } elseif ($tab < 0) {
1431 $this->error .= $objFrom->error;
1437 unset($this->context[
'createfromclone']);
1441 $this->db->commit();
1444 $this->db->rollback();
1464 public function addline($user, $fichinterid, $desc, $date_intervention, $duration, $array_options = [], $type = 0, $rang = -1, $special_code = 0)
1466 dol_syslog(get_class($this).
"::addline $fichinterid, $desc, $date_intervention, $duration, $type, $rang, $special_code");
1468 if ($this->
status == self::STATUS_DRAFT) {
1474 $line->fk_fichinter = $fichinterid;
1475 $line->desc = $desc;
1476 $line->date = $date_intervention;
1477 $line->datei = $date_intervention;
1478 $line->duration = $duration;
1479 $line->product_type = $type;
1480 $line->rang = $rang;
1481 $line->special_code = $special_code;
1484 if (is_array($array_options) && count($array_options) > 0) {
1485 $line->array_options = $array_options;
1488 $result = $line->insert($user);
1491 $this->db->commit();
1494 $this->error = $this->db->error();
1495 $this->db->rollback();
1519 $this->
ref =
'SPECIMEN';
1520 $this->ref_client =
'SPECIMEN CLIENT';
1521 $this->specimen = 1;
1523 $this->datec = $now;
1524 $this->note_private =
'Private note';
1525 $this->note_public =
'SPECIMEN';
1526 $this->duration = 0;
1527 $this->user_creation_id = 1;
1530 while ($xnbp < $nbp) {
1532 $line->desc = $langs->trans(
"Description").
" ".$xnbp;
1533 $line->date = ($now - 3600 * (1 + $xnbp));
1534 $line->datei = ($now - 3600 * (1 + $xnbp));
1535 $line->duration = 600;
1536 $line->fk_fichinter = 0;
1537 $this->lines[$xnbp] = $line;
1540 $this->duration += $line->duration;
1555 $this->lines = array();
1557 $sql =
"SELECT rowid, fk_fichinter, description, duree, date, rang, extraparams";
1558 $sql .=
" FROM ".MAIN_DB_PREFIX.
"fichinterdet";
1559 $sql .=
" WHERE fk_fichinter = ".((int) $this->
id);
1560 $sql .=
" ORDER BY rang ASC, date ASC";
1562 dol_syslog(get_class($this).
"::fetch_lines", LOG_DEBUG);
1564 $resql = $this->db->query($sql);
1566 $num = $this->db->num_rows($resql);
1569 $objp = $this->db->fetch_object($resql);
1572 $line->id = $objp->rowid;
1573 $line->fk_fichinter = $objp->fk_fichinter;
1574 $line->desc = $objp->description;
1575 $line->duration = $objp->duree;
1577 $line->qty = round($objp->duree / 3600, 2);
1578 $line->date = $this->db->jdate($objp->date);
1579 $line->datei = $this->db->jdate($objp->date);
1580 $line->rang = $objp->rang;
1581 $line->product_type = 1;
1582 $line->fetch_optionals();
1584 $line->extraparams = !empty($objp->extraparams) ? (array) json_decode($objp->extraparams,
true) : array();
1586 $this->lines[$i] = $line;
1589 $this->db->free($resql);
1593 $this->error = $this->db->error();
1627 require_once DOL_DOCUMENT_ROOT.
'/categories/class/categorie.class.php';
1628 return parent::setCategoriesCommon($categories, Categorie::TYPE_FICHINTER);
1642 if ($user->hasRight(
'ficheinter',
'creer')) {
1649 $sql =
"UPDATE ".MAIN_DB_PREFIX.$this->table_element.
" SET ref_client = ".(empty($ref_client) ?
'NULL' :
"'".$this->db->escape($ref_client).
"'");
1650 $sql .=
" WHERE rowid = ".((int) $this->
id);
1652 dol_syslog(__METHOD__.
' $this->id='.$this->id.
', ref_client='.$ref_client, LOG_DEBUG);
1653 $resql = $this->db->query($sql);
1655 $this->errors[] = $this->db->error();
1660 $this->ref_client = $ref_client;
1663 if (!$notrigger && empty($error)) {
1665 $result = $this->call_trigger(
'FICHINTER_MODIFY', $user);
1673 $this->db->commit();
1676 foreach ($this->errors as $errmsg) {
1677 dol_syslog(__METHOD__.
' Error: '.$errmsg, LOG_ERR);
1678 $this->error .= ($this->error ?
', '.$errmsg : $errmsg);
1680 $this->db->rollback();
1695 public function getKanbanView($option =
'', $arraydata =
null)
1699 $selected = (empty($arraydata[
'selected']) ? 0 : $arraydata[
'selected']);
1701 $return =
'<div class="box-flex-item box-flex-grow-zero">';
1702 $return .=
'<div class="info-box info-box-sm">';
1703 $return .=
'<span class="info-box-icon bg-infobox-action">';
1705 $return .=
'</span>';
1706 $return .=
'<div class="info-box-content">';
1707 $return .=
'<span class="info-box-ref inline-block tdoverflowmax150 valignmiddle">' . $this->
getNomUrl() .
'</span>';
1708 if ($selected >= 0) {
1709 $return .=
'<input id="cb'.$this->id.
'" class="flat checkforselect fright" type="checkbox" name="toselect[]" value="'.$this->
id.
'"'.($selected ?
' checked="checked"' :
'').
'>';
1711 if (!empty($arraydata[
'thirdparty'])) {
1712 $tmpthirdparty = $arraydata[
'thirdparty'];
1713 '@phan-var-force Societe $tmpthirdparty';
1715 $return .=
'<br><span class="info-box-label">'.$tmpthirdparty->getNomUrl(1).
'</span>';
1717 if (!empty($this->duration)) {
1718 $return .=
'<br><span class="info-box-label ">'.$langs->trans(
"Duration").
' : '.
convertSecondToTime($this->duration,
'allhourmin').
'</span>';
1720 $return .=
'<br><div class="info-box-status">'.$this->getLibStatut(3).
'</div>';
1721 $return .=
'</div>';
1722 $return .=
'</div>';
1723 $return .=
'</div>';
Parent class of all other business classes (invoices, contracts, proposals, orders,...
fetch_optionals($rowid=null, $optionsArray=null)
Function to get extra fields of an object into $this->array_options This method is in most cases call...
deleteEcmFiles($mode=0)
Delete related files of object in database.
add_object_linked($origin=null, $origin_id=null, $f_user=null, $notrigger=0)
Add an object link into llx_element_element.
commonGenerateDocument($modelspath, $modele, $outputlangs, $hidedetails, $hidedesc, $hideref, $moreparams=null)
Common function for all objects extending CommonObject for generating documents.
deleteObjectLinked($sourceid=null, $sourcetype='', $targetid=null, $targettype='', $rowid=0, $f_user=null, $notrigger=0)
Delete all links between an object $this.
setErrorsFromObject($object)
setErrorsFromObject
static isExistingObject($element, $id, $ref='', $ref_ext='')
Check if an object id or ref exists If you don't need or want to instantiate the object and just need...
deleteExtraFields()
Delete all extra fields values for the current object.
static commonReplaceThirdparty(DoliDB $dbs, $origin_id, $dest_id, array $tables, $ignoreerrors=0)
Function used to replace a thirdparty id with another one.
insertExtraFields($trigger='', $userused=null)
Add/Update all extra fields values for the current object.
delete_linked_contact($source='', $code='')
Delete all links between an object $this and all its contacts in llx_element_contact.
add_contact($fk_socpeople, $type_contact, $source='external', $notrigger=0)
Add a link between element $this->element and a contact.
Class to manage Dolibarr database access.
const STATUS_BILLED
Billed.
initAsSpecimen()
Initialise an instance with random values.
createFromClone(User $user, $socid=0, $clone_contacts=false, $clone_notes=false)
Load an object from its id and create a new one in database.
getLibStatut($mode=0)
Returns the label status.
update($user, $notrigger=0)
Update an intervention.
static replaceThirdparty(DoliDB $dbs, $origin_id, $dest_id)
Function used to replace a thirdparty id with another one.
setClose($user, $notrigger=0)
Close intervention.
const STATUS_DRAFT
Draft status.
create($user, $notrigger=0)
Create an intervention into data base.
setCategories($categories)
Sets object to given categories.
set_description($user, $description)
Define the label of the intervention.
getTooltipContentArray($params)
getTooltipContentArray
set_date_delivery($user, $delivery_date_receipt)
Defines a delivery date of the receipt of intervention.
const STATUS_VALIDATED
Validated status.
fetch($rowid, $ref='', $ref_ext='')
Fetch a intervention.
const STATUS_CLOSED
Closed.
setDraft($user)
Set status to draft.
getNextNumRef($soc)
Returns the next non used reference of intervention depending on the module numbering assets within F...
getAmount()
Returns amount based on user thm.
addline($user, $fichinterid, $desc, $date_intervention, $duration, $array_options=[], $type=0, $rang=-1, $special_code=0)
Adding a line of intervention into data base.
setRefClient($user, $ref_client, $notrigger=0)
Set customer reference number.
set_contrat($user, $contractid)
Link intervention to a contract.
LibStatut($status, $mode=0)
Returns the label of a status.
setValid($user, $notrigger=0)
Validate a intervention.
loadStateBoard()
Load indicators into this->nb for board.
getNomUrl($withpicto=0, $option='', $notooltip=0, $save_lastsearch_value=-1, $morecss='')
Return clickable name (with picto eventually)
__construct($db)
Constructor.
generateDocument($modele, $outputlangs, $hidedetails=0, $hidedesc=0, $hideref=0, $moreparams=null)
Create a document onto disk according to template module.
info($id)
Load information on object.
fetch_lines()
Load array lines ->lines.
Class to manage intervention lines.
Class to manage third parties objects (customers, suppliers, prospects...)
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...
getLibSignedStatus(int $mode=0)
Returns the label for signed status.
convertSecondToTime($iSecond, $format='all', $lengthOfDay=86400, $lengthOfWeek=7)
Return, in clear text, value of a number of seconds in days, hours and minutes.
print $script_file $mode $langs defaultlang(is_numeric($duration_value) ? " delay=". $duration_value :"").(is_numeric($duration_value2) ? " after cd cd cd description as description
Only used if Module[ID]Desc translation string is not found.
dol_delete_file($file, $disableglob=0, $nophperrors=0, $nohook=0, $object=null, $allowdotdot=false, $indexdatabase=1, $nolog=0)
Remove a file or several files with a mask.
dol_delete_dir_recursive($dir, $count=0, $nophperrors=0, $onlysub=0, &$countdeleted=0, $indexdatabase=1, $nolog=0, $level=0)
Remove a directory $dir and its subdirectories (or only files and subdirectories)
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_delete_preview($object)
Delete all preview files linked to object instance.
dol_now($mode='gmt')
Return date for now.
setEntity($currentobject)
Set entity id to use when to create an object.
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.
dol_strlen($string, $stringencoding='UTF-8')
Make a strlen call.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
dol_buildpath($path, $type=0, $returnemptyifnotfound=0)
Return path of url or filesystem.
dol_clone($srcobject, $native=2)
Create a clone of instance of object (new instance with same value for each properties) With native =...
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
getEntity($element, $shared=1, $currentobject=null)
Get list of entity id to use.
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