diff --git a/assets/src/js/functions/input.js b/assets/src/js/functions/input.js old mode 100755 new mode 100644 index 1dced6cba..668125d0c --- a/assets/src/js/functions/input.js +++ b/assets/src/js/functions/input.js @@ -1,79 +1,94 @@ -// Inputmask -function start_inputmask(element) { - if (element == undefined) { - element = ''; - } else { - element = element + ' '; +function input(name) { + return new Input(name); +} + +function Input(name) { + this.element = $("[name=" + name + "]").last(); + + // Fix per select multipli + if (this.element.length === 0) { + this.element = $("[name='" + name + "[]']").last(); } - var date = dateFormatMoment(globals.date_format).toLowerCase(); - - $(element + ".date-mask").not('.bound').inputmask(date, { - placeholder: date - }).addClass('bound'); - - $(element + '.email-mask').not('.bound').inputmask('Regex', { - regex: "^[a-zA-Z0-9_!#$%&'*+/=?`{|}~^-]+(?:\\.[a-zA-Z0-9_!#$%&'*+/=?`{|}~^-]+)*@[a-zA-Z0-9-]+(?:\\.[a-zA-Z0-9-]+)*$", - }).addClass('bound'); - - $(element + '.rea-mask').not('.bound').inputmask( { - mask: "AA-999999{1,15}", - casing: "upper", - }).addClass('bound'); - - $(element + '.provincia-mask').not('.bound').inputmask( { - mask: "AA", - casing: "upper", - }).addClass('bound'); - - $(element + '.alphanumeric-mask').not('.bound').inputmask('Regex', { - regex: "[A-Za-z0-9#_|\/\\-.]*", - }).addClass('bound'); - - $(element + '.math-mask').not('.bound').inputmask('Regex', { - regex: "[0-9,.+\-]*", - }).addClass('bound'); - - if (globals.is_mobile) { - $(element + '.inputmask-decimal, ' + element + '.date-mask, ' + element + '.timestamp-mask').each(function () { - $(this).attr('type', 'tel'); - }).addClass('bound'); - } else { - $(element + '.inputmask-decimal').not('.bound').each(function () { - var $this = $(this); - - var min = $this.attr('min-value'); - if (min == 'undefined') { - min = false; - } - - var max = $this.attr('max-value'); - if (max == 'undefined') { - max = false; - } - - $this.inputmask("decimal", { - min: min ? min : undefined, - allowMinus: !min || min < 0 ? true : false, - max: max ? max : undefined, - allowPlus: !max || max < 0 ? true : false, - digits: $this.attr('decimals') ? $this.attr('decimals') : globals.cifre_decimali, - digitsOptional: true, // Necessario per un problema di inputmask con i numeri negativi durante l'init - enforceDigitsOnBlur: true, - rightAlign: true, - autoGroup: true, - radixPoint: globals.decimals, - groupSeparator: globals.thousands, - onUnMask: function (maskedValue, unmaskedValue) { - return maskedValue.toEnglish(); - }, - }); - - $this.on('keyup', function () { - if (min && $(this).val().toEnglish() < min) { - $(this).val(min); - } - }); - }).addClass('bound'); + // Controllo sulla gestione precedente + if (!this.element.data("input-set")) { + this.element.data("input-set", 1); + this.element.data("required", this.element.attr("required")); } } + +Input.prototype.getElement = function () { + return this.element; +} + +Input.prototype.setDisabled = function (value) { + if (value) { + return this.disable(); + } else { + return this.enable(); + } +} + +Input.prototype.disable = function () { + this.element.addClass("disabled") + .attr("disabled", true) + .attr("required", false); + + // Disabilitazione eventuali pulsanti relativi + this.element.closest(".form-group").find("button") + .addClass("disabled"); + + return this; +} + +Input.prototype.enable = function () { + this.element.removeClass("disabled") + .attr("disabled", false) + .attr("required", this.element.data("required")); + + // Abilitazione eventuali pulsanti relativi + this.element.closest(".form-group").find("button") + .removeClass("disabled"); + + return this; +} + +Input.prototype.getData = function () { + if (this.element.is('select')) { + return this.element.selectData(); + } + + return { + value: this.element.val() + }; +} + +Input.prototype.get = function () { + return this.element.val(); +} + +Input.prototype.set = function (value) { + this.element.val(value).trigger("change"); + + return this; +} + +Input.prototype.setRequired = function (value) { + this.element.attr("required", value) + .data("required", value); + + return this; +} + +// Eventi permessi +Input.prototype.change = function (event) { + return this.element.change(event); +} + +Input.prototype.on = function (event, action) { + return this.element.on(event, action(event)); +} + +Input.prototype.off = function (event) { + return this.element.off(event); +} diff --git a/assets/src/js/functions/inputmask.js b/assets/src/js/functions/inputmask.js new file mode 100644 index 000000000..1dced6cba --- /dev/null +++ b/assets/src/js/functions/inputmask.js @@ -0,0 +1,79 @@ +// Inputmask +function start_inputmask(element) { + if (element == undefined) { + element = ''; + } else { + element = element + ' '; + } + + var date = dateFormatMoment(globals.date_format).toLowerCase(); + + $(element + ".date-mask").not('.bound').inputmask(date, { + placeholder: date + }).addClass('bound'); + + $(element + '.email-mask').not('.bound').inputmask('Regex', { + regex: "^[a-zA-Z0-9_!#$%&'*+/=?`{|}~^-]+(?:\\.[a-zA-Z0-9_!#$%&'*+/=?`{|}~^-]+)*@[a-zA-Z0-9-]+(?:\\.[a-zA-Z0-9-]+)*$", + }).addClass('bound'); + + $(element + '.rea-mask').not('.bound').inputmask( { + mask: "AA-999999{1,15}", + casing: "upper", + }).addClass('bound'); + + $(element + '.provincia-mask').not('.bound').inputmask( { + mask: "AA", + casing: "upper", + }).addClass('bound'); + + $(element + '.alphanumeric-mask').not('.bound').inputmask('Regex', { + regex: "[A-Za-z0-9#_|\/\\-.]*", + }).addClass('bound'); + + $(element + '.math-mask').not('.bound').inputmask('Regex', { + regex: "[0-9,.+\-]*", + }).addClass('bound'); + + if (globals.is_mobile) { + $(element + '.inputmask-decimal, ' + element + '.date-mask, ' + element + '.timestamp-mask').each(function () { + $(this).attr('type', 'tel'); + }).addClass('bound'); + } else { + $(element + '.inputmask-decimal').not('.bound').each(function () { + var $this = $(this); + + var min = $this.attr('min-value'); + if (min == 'undefined') { + min = false; + } + + var max = $this.attr('max-value'); + if (max == 'undefined') { + max = false; + } + + $this.inputmask("decimal", { + min: min ? min : undefined, + allowMinus: !min || min < 0 ? true : false, + max: max ? max : undefined, + allowPlus: !max || max < 0 ? true : false, + digits: $this.attr('decimals') ? $this.attr('decimals') : globals.cifre_decimali, + digitsOptional: true, // Necessario per un problema di inputmask con i numeri negativi durante l'init + enforceDigitsOnBlur: true, + rightAlign: true, + autoGroup: true, + radixPoint: globals.decimals, + groupSeparator: globals.thousands, + onUnMask: function (maskedValue, unmaskedValue) { + return maskedValue.toEnglish(); + }, + }); + + $this.on('keyup', function () { + if (min && $(this).val().toEnglish() < min) { + $(this).val(min); + } + }); + }).addClass('bound'); + } +} diff --git a/modules/interventi/add.php b/modules/interventi/add.php index 49ad44fa9..c8af0c3d1 100755 --- a/modules/interventi/add.php +++ b/modules/interventi/add.php @@ -1,205 +1,197 @@ fetchArray('SELECT idtipointervento_default, idzona FROM an_anagrafiche WHERE idanagrafica='.prepare($idanagrafica)); - $idtipointervento = $rs[0]['idtipointervento_default']; - $idzona = $rs[0]['idzona']; - - $stato = $dbo->fetchArray("SELECT * FROM in_statiintervento WHERE descrizione = 'In programmazione'"); - $idstatointervento = $stato['idstatointervento']; - - $richiesta = filter('richiesta'); -} - -// Calcolo orario di inizio e fine di default -if (null !== filter('orario_inizio') && '00:00:00' != filter('orario_inizio')) { - $orario_inizio = filter('orario_inizio'); - $orario_fine = filter('orario_fine'); -} else { +// Calcolo dell'orario di inizio e di fine sulla base delle informazioni fornite +$orario_inizio = filter('orario_inizio'); +$orario_fine = filter('orario_fine'); +if (null == $orario_inizio || '00:00:00' == $orario_inizio) { $orario_inizio = date('H').':00:00'; $orario_fine = date('H', time() + 60 * 60).':00:00'; } +// Un utente del gruppo Tecnici può aprire attività solo a proprio nome +$id_tecnico = null; +if ($user['gruppo'] == 'Tecnici' && !empty($user['idanagrafica'])) { + $id_tecnico = $user['idanagrafica']; +} + +// Stato di default associato all'attivitò +$stato = $dbo->fetchArray("SELECT * FROM in_statiintervento WHERE descrizione = 'In programmazione'"); +$id_stato = $stato['idstatointervento']; + +// Se è indicata un'anagrafica relativa, si carica il tipo di intervento di default impostato +if (!empty($id_anagrafica)) { + $anagrafica = $dbo->fetchOne('SELECT idtipointervento_default, idzona FROM an_anagrafiche WHERE idanagrafica='.prepare($id_anagrafica)); + $id_tipo = $anagrafica['idtipointervento_default']; + $id_zona = $anagrafica['idzona']; +} + +// Gestione dell'impostazione dei Contratti $id_intervento = filter('id_intervento'); -$idcontratto = filter('idcontratto'); -$idcontratto_riga = filter('idcontratto_riga'); +$id_contratto = filter('idcontratto'); +$id_promemoria_contratto = filter('idcontratto_riga'); -// Se sto pianificando un contratto, leggo tutti i dati del contratto per predisporre l'aggiunta intervento -if (!empty($idcontratto) && !empty($idcontratto_riga)) { - $rs = $dbo->fetchArray('SELECT *, (SELECT idzona FROM an_anagrafiche WHERE idanagrafica = co_contratti.idanagrafica) AS idzona FROM co_contratti WHERE id='.prepare($idcontratto)); - $idanagrafica = $rs[0]['idanagrafica']; - $idzona = $rs[0]['idzona']; +// Trasformazione di un Promemoria dei Contratti in Intervento +if (!empty($id_contratto) && !empty($id_promemoria_contratto)) { + $contratto = $dbo->fetchOne('SELECT *, (SELECT idzona FROM an_anagrafiche WHERE idanagrafica = co_contratti.idanagrafica) AS idzona FROM co_contratti WHERE id = '.prepare($id_contratto)); + $id_anagrafica = $contratto['idanagrafica']; + $id_zona = $contratto['idzona']; - // Info riga pianificata - $rs = $dbo->fetchArray('SELECT *, (SELECT tempo_standard FROM in_tipiintervento WHERE idtipointervento = co_promemoria.idtipointervento) AS tempo_standard FROM co_promemoria WHERE idcontratto='.prepare($idcontratto).' AND id='.prepare($idcontratto_riga)); - $idtipointervento = $rs[0]['idtipointervento']; - $data = (null !== filter('data')) ? filter('data') : $rs[0]['data_richiesta']; - $richiesta = $rs[0]['richiesta']; - $idsede = $rs[0]['idsede']; - $idimpianti = $rs[0]['idimpianti']; + // Informazioni del Promemoria + $promemoria = $dbo->fetchOne('SELECT *, (SELECT tempo_standard FROM in_tipiintervento WHERE idtipointervento = co_promemoria.idtipointervento) AS tempo_standard FROM co_promemoria WHERE idcontratto='.prepare($id_contratto).' AND id = '.prepare($id_promemoria_contratto)); + $id_tipo = $promemoria['idtipointervento']; + $data = (null !== filter('data')) ? filter('data') : $promemoria['data_richiesta']; + $richiesta = $promemoria['richiesta']; + $id_sede = $promemoria['idsede']; + $impianti_collegati = $promemoria['idimpianti']; - // aumento orario inizio del tempo standard definito dalla tipologia dell'intervento (PRESO DAL PROMEMORIA) - if (!empty($rs[0]['tempo_standard'])) { - $orario_fine = date('H:i:s', strtotime($orario_inizio) + ((60 * 60) * $rs[0]['tempo_standard'])); + // Generazione dell'orario di fine sulla base del tempo standard definito dal Promemoria + if (!empty($promemoria['tempo_standard'])) { + $orario_fine = date('H:i:s', strtotime($orario_inizio) + ((60 * 60) * $promemoria['tempo_standard'])); } - // se gli impianti non sono stati definiti nel promemoria, carico tutti gli impianti a contratto - if (empty($idimpianti)) { - $rs = $dbo->fetchArray('SELECT idimpianto FROM my_impianti_contratti WHERE idcontratto='.prepare($idcontratto)); - $idimpianto = implode(',', array_column($rs, 'idimpianto')); - } else { - $idimpianto = $idimpianti; - // Spunto il tecnico di default assegnato all'impianto - $rs = $dbo->fetchArray('SELECT idtecnico FROM my_impianti WHERE id='.prepare($idimpianto)); - $idtecnico = $rs[0]['idtecnico'] ?: ''; + // Caricamento degli impianti a Contratto se non definiti in Promemoria + if (empty($impianti_collegati)) { + $rs = $dbo->fetchArray('SELECT idimpianto FROM my_impianti_contratti WHERE idcontratto = '.prepare($id_contratto)); + $impianti_collegati = implode(',', array_column($rs, 'idimpianto')); } - - // Seleziono "In programmazione" come stato - $rs = $dbo->fetchArray("SELECT * FROM in_statiintervento WHERE descrizione = 'In programmazione'"); - $idstatointervento = $rs[0]['idstatointervento']; } -// Intervento senza sessioni +// Gestione dell'aggiunta di una sessione a un Intervento senza sessioni (Promemoria intervento) da Dashboard elseif (!empty($id_intervento)) { - // Info riga pianificata - $rs = $dbo->fetchArray('SELECT *, (SELECT idcontratto FROM co_promemoria WHERE idintervento=in_interventi.id LIMIT 0,1) AS idcontratto, in_interventi.id_preventivo as idpreventivo, (SELECT tempo_standard FROM in_tipiintervento WHERE idtipointervento = in_interventi.idtipointervento) AS tempo_standard FROM in_interventi WHERE id='.prepare($id_intervento)); - $idtipointervento = $rs[0]['idtipointervento']; - $data = (null !== filter('data')) ? filter('data') : $rs[0]['data_richiesta']; - $data_richiesta = $rs[0]['data_richiesta']; - $data_scadenza = $rs[0]['data_scadenza']; - $richiesta = $rs[0]['richiesta']; - $idsede = $rs[0]['idsede']; - $idanagrafica = $rs[0]['idanagrafica']; - $idclientefinale = $rs[0]['idclientefinale']; - $idstatointervento = $rs[0]['idstatointervento']; - $idcontratto = $rs[0]['idcontratto']; - $idpreventivo = $rs[0]['idpreventivo']; - $idzona = $rs[0]['idzona']; + $intervento = $dbo->fetchOne('SELECT *, (SELECT idcontratto FROM co_promemoria WHERE idintervento = in_interventi.id LIMIT 0,1) AS idcontratto, in_interventi.id_preventivo as idpreventivo, (SELECT tempo_standard FROM in_tipiintervento WHERE idtipointervento = in_interventi.idtipointervento) AS tempo_standard FROM in_interventi WHERE id = '.prepare($id_intervento)); - // Aumento orario inizio del tempo standard definito dalla tipologia dell'intervento (PRESO DAL PROMEMORIA) - if (!empty($rs[0]['tempo_standard'])) { - $orario_fine = date('H:i:s', strtotime($orario_inizio) + ((60 * 60) * $rs[0]['tempo_standard'])); + $id_tipo = $intervento['idtipointervento']; + $data = (null !== filter('data')) ? filter('data') : $intervento['data_richiesta']; + $data_richiesta = $intervento['data_richiesta']; + $data_scadenza = $intervento['data_scadenza']; + $richiesta = $intervento['richiesta']; + $id_sede = $intervento['idsede']; + $id_anagrafica = $intervento['idanagrafica']; + $id_cliente_finale = $intervento['idclientefinale']; + $id_stato = $intervento['idstatointervento']; + $id_contratto = $intervento['idcontratto']; + $id_preventivo = $intervento['idpreventivo']; + $id_zona = $intervento['idzona']; + + // Generazione dell'orario di fine sulla base del tempo standard definito dall'Intervento + if (!empty($intervento['tempo_standard'])) { + $orario_fine = date('H:i:s', strtotime($orario_inizio) + ((60 * 60) * $intervento['tempo_standard'])); } - $rs = $dbo->fetchArray('SELECT idimpianto FROM my_impianti_interventi WHERE idintervento='.prepare($id_intervento)); - $idimpianto = implode(',', array_column($rs, 'idimpianto')); + $rs = $dbo->fetchArray('SELECT idimpianto FROM my_impianti_interventi WHERE idintervento = '.prepare($id_intervento)); + $impianti_collegati = implode(',', array_column($rs, 'idimpianto')); } -if (empty($data_fine)) { - if (null !== filter('data_fine')) { - $data_fine = filter('data_fine'); - } else { - $data_fine = date('Y-m-d'); - } +// Selezione dei tecnici assegnati agli impianti selezionati +if (!empty($impianti_collegati)) { + $tecnici_impianti = $dbo->fetchArray('SELECT idtecnico FROM my_impianti WHERE id IN ('.prepare($impianti_collegati).')'); + $id_tecnico = array_unique(array_column($tecnici_impianti, 'idtecnico')); } +// Impostazione della data se mancante if (empty($data)) { - if (null !== filter('data')) { - $data = filter('data'); - } else { + $data = filter('data'); + if (null == $data) { $data = date('Y-m-d'); } } +// Impostazione della data di fine da Dashboard +if (empty($data_fine)) { + $data_fine = filter('data_fine'); + if (null == $data_fine) { + $data_fine = date('Y-m-d'); + } +} $data_fine = $data_fine ?: $data; -$_SESSION['superselect']['idanagrafica'] = $idanagrafica; +$inizio_sessione = $data.' '.$orario_inizio; +$fine_sessione = $data_fine.' '.$orario_fine; -$orario_inizio = $data.' '.$orario_inizio; -$orario_fine = $data_fine.' '.$orario_fine; +// Calcolo del nuovo codice +$new_codice = Intervento::getNextCodice($data); -?> +$_SESSION['superselect']['idanagrafica'] = $id_anagrafica; -
+echo ' + - + - + '; -'; +if (!empty($id_promemoria_contratto)) { + echo ''; } if (!empty($id_intervento)) { echo ''; } -?> +echo '
-

+

'.tr('Dati cliente').'

-
- {[ "type": "select", "label": "", "name": "idanagrafica", "required": 1, "value": "", "ajax-source": "clienti", "icon-after": "add||tipoanagrafica=Cliente&readonly_tipo=1||", "data-heavy": 0, "readonly": "" ]} + {[ "type": "select", "label": "'.tr('Cliente').'", "name": "idanagrafica", "required": 1, "value": "'.$id_anagrafica.'", "ajax-source": "clienti", "icon-after": "add|'.$module_anagrafiche['id'].'|tipoanagrafica=Cliente&readonly_tipo=1", "readonly": "'.(empty($id_anagrafica) ? 0 : 1).'" ]}
- {[ "type": "select", "label": "", "name": "idsede_destinazione", "value": "", "placheholder": "...", "ajax-source": "sedi" ]} + {[ "type": "select", "label": "'.tr('Sede destinazione').'", "name": "idsede_destinazione", "value": "'.$id_sede.'", "ajax-source": "sedi" ]}
- {[ "type": "select", "label": "", "name": "idclientefinale", "value": "", "ajax-source": "clienti" ]} + {[ "type": "select", "label": "'.tr('Per conto di').'", "name": "idclientefinale", "value": "'.$id_cliente_finale.'", "ajax-source": "clienti" ]}
- {[ "type": "select", "label": "", "name": "idzona", "values": "query=SELECT id, CONCAT_WS( ' - ', nome, descrizione) AS descrizione FROM an_zone ORDER BY nome", "value": "", "placeholder": "", "help":".", "extra": "readonly", "value": "" ]} + {[ "type": "select", "label": "'.tr('Zona').'", "name": "idzona", "values": "query=SELECT id, CONCAT_WS(\' - \', nome, descrizione) AS descrizione FROM an_zone ORDER BY nome", "value": "'.$id_zona.'", "placeholder": "'.tr('Nessuna zona').'", "help":"'.tr('La zona viene definita automaticamente in base al cliente selezionato').'.", "extra": "readonly", "value": "'.$id_zona.'" ]}
- {[ "type": "select", "label": "", "name": "idpreventivo", "value": "", "ajax-source": "preventivi", "readonly": "" ]} + {[ "type": "select", "label": "'.tr('Preventivo').'", "name": "idpreventivo", "value": "'.$id_preventivo.'", "ajax-source": "preventivi", "readonly": "'.(empty($id_contratto) ? 0 : 1).'" ]}
- {[ "type": "select", "label": "", "name": "idcontratto", "value": "", "ajax-source": "contratti", "readonly": "" ]} + {[ "type": "select", "label": "'.tr('Contratto').'", "name": "idcontratto", "value": "'.$id_contratto.'", "ajax-source": "contratti", "readonly": "'.(empty($id_contratto) ? 0 : 1).'" ]}
-
- {[ "type": "select", "label": "", "multiple": 1, "name": "idimpianti[]", "value": "", "ajax-source": "impianti-cliente", "icon-after": "add||source=Attività||", "data-heavy": 0 ]} +
+ {[ "type": "select", "label": "'.tr('Impianto').'", "multiple": 1, "name": "idimpianti[]", "value": "'.$impianti_collegati.'", "ajax-source": "impianti-cliente", "icon-after": "add|'.Modules::get('Impianti')['id'].'|source=Attività" ]}
- {[ "type": "select", "label": "", "multiple": 1, "name": "componenti[]", "placeholder": "...", "ajax-source": "componenti" ]} + {[ "type": "select", "label": "'.tr('Componenti').'", "multiple": 1, "name": "componenti[]", "placeholder": "'.tr('Seleziona prima un impianto').'", "ajax-source": "componenti" ]}
@@ -208,45 +200,45 @@ if (!empty($id_intervento)) {
-

+

'.tr('Dati intervento').'

- {[ "type": "timestamp", "label": "", "name": "data_richiesta", "required": 1, "value": "" ]} + {[ "type": "timestamp", "label": "'.tr('Data/ora richiesta').'", "name": "data_richiesta", "required": 1, "value": "'.($data_richiesta ?: '-now-').'" ]}
- {[ "type": "timestamp", "label": "", "name": "data_scadenza", "required": 0, "value": "" ]} + {[ "type": "timestamp", "label": "'.tr('Data/ora scadenza').'", "name": "data_scadenza", "required": 0, "value": "'.$data_scadenza.'" ]}
- {[ "type": "select", "label": "", "name": "idtipointervento", "required": 1, "values": "query=SELECT idtipointervento AS id, descrizione FROM in_tipiintervento ORDER BY descrizione ASC", "value": "", "ajax-source": "tipiintervento" ]} + {[ "type": "select", "label": "'.tr('Tipo attività').'", "name": "idtipointervento", "required": 1, "values": "query=SELECT idtipointervento AS id, descrizione FROM in_tipiintervento ORDER BY descrizione ASC", "value": "'.$id_tipo.'", "ajax-source": "tipiintervento" ]}
- {[ "type": "select", "label": "", "name": "idstatointervento", "required": 1, "values": "query=SELECT idstatointervento AS id, descrizione, colore AS _bgcolor_ FROM in_statiintervento WHERE deleted_at IS NULL", "value": "" ]} + {[ "type": "select", "label": "'.tr('Stato').'", "name": "idstatointervento", "required": 1, "values": "query=SELECT idstatointervento AS id, descrizione, colore AS _bgcolor_ FROM in_statiintervento WHERE deleted_at IS NULL", "value": "'.$id_stato.'" ]}
- {[ "type": "textarea", "label": "", "name": "richiesta", "required": 1, "value": "", "extra": "style='max-height:80px; ' " ]} + {[ "type": "textarea", "label": "'.tr('Richiesta').'", "name": "richiesta", "required": 1, "value": "'.$richiesta.'", "extra": "style=\'max-height:80px;\'" ]}
-
+
-

+

'.tr('Ore di lavoro').'

@@ -254,227 +246,230 @@ if (!empty($id_intervento)) {
- {[ "type": "timestamp", "label": "", "name": "orario_inizio", "required": , "value": "" ]} + {[ "type": "timestamp", "label": "'.tr('Inizio attività').'", "name": "orario_inizio", "required": '.($origine_dashboard ? 1 : 0).', "value": "'.$inizio_sessione.'" ]}
- {[ "type": "timestamp", "label": "", "name": "orario_fine", "required": , "value": "" ]} + {[ "type": "timestamp", "label": "'.tr('Fine attività').'", "name": "orario_fine", "required": '.($origine_dashboard ? 1 : 0).', "value": "'.$fine_sessione.'" ]}
- {[ "type": "select", "label": "", "multiple": "1", "name": "idtecnico[]", "required": , "ajax-source": "tecnici", "value": "", "icon-after": "add||tipoanagrafica=Tecnico||" ]} + {[ "type": "select", "label": "'.tr('Tecnici').'", "multiple": "1", "name": "idtecnico[]", "required": '.($origine_dashboard ? 1 : 0).', "ajax-source": "tecnici", "value": "'.$id_tecnico.'", "icon-after": "add|'.$module_anagrafiche['id'].'|tipoanagrafica=Tecnico||'.(empty($id_tecnico) ? '' : 'disabled').'" ]}
-
- +
- - -'; if (!empty($id_intervento)) { echo ' - $("#modals > div #idsede_destinazione").prop("disabled", true); - $("#modals > div #idpreventivo").prop("disabled", true); - $("#modals > div #idcontratto").prop("disabled", true); - $("#modals > div #idimpianti").prop("disabled", true); - $("#modals > div #componenti").prop("disabled", true); - $("#modals > div #idanagrafica").prop("disabled", true); - $("#modals > div #idanagrafica").find("button").prop("disabled", true); - $("#modals > div #idclientefinale").prop("disabled", true); - $("#modals > div #idzona").prop("disabled", true); - $("#modals > div #idtipointervento").prop("disabled", true); - $("#modals > div #idstatointervento").prop("disabled", true); - $("#modals > div #richiesta").prop("disabled", true); - $("#modals > div #data_richiesta").prop("disabled", true); - $("#modals > div #impianti").find("button").prop("disabled", true); - '; +'; } -?> - // Quando modifico orario inizio, allineo anche l'orario fine - $("#modals > div #orario_inizio").on("dp.change", function (e) { - $("#modals > div #orario_fine").data("DateTimePicker").minDate(e.date); - $("#modals > div #orario_fine").change(); +// Disabilito i campi che non devono essere modificati per poter collegare l'Intervento al Promemoria del Contratto +if (!empty($id_contratto) && !empty($id_promemoria_contratto)) { + echo ' +'; +} + +echo ' + + + echo ' + var ref = "'.get('ref').'"; + + async function salva(button) { + // Submit attraverso ricaricamento della pagina + if (!ref) { + $("#add-form").submit(); + return; + } + + // Submit dinamico tramite AJAX + let valid = await salvaForm(button, "#add-form"); + if (!valid) return; + + // Se l\'aggiunta intervento proviene dalla scheda di pianificazione ordini di servizio della dashboard, la ricarico + if (ref == "dashboard") { + $("#modals > div").modal("hide"); + + // Aggiornamento elenco interventi da pianificare + $("#calendar").fullCalendar("refetchEvents"); + $("#calendar").fullCalendar("render"); + } + + // Se l\'aggiunta intervento proviene dai contratti, faccio il submit via ajax e ricarico la tabella dei contratti + else if (ref == "interventi_contratti") { + $("#modals > div").modal("hide"); + parent.window.location.reload(); + //TODO: da gestire via ajax + //$("#elenco_interventi > tbody").load(globals.rootdir + "/modules/contratti/plugins/contratti.pianificazioneinterventi.php?op=get_interventi_pianificati&idcontratto='.$id_contratto.'"); + } + } +'; diff --git a/plugins/exportFE/edit.php b/plugins/exportFE/edit.php index 50ec6da5b..e371c9357 100755 --- a/plugins/exportFE/edit.php +++ b/plugins/exportFE/edit.php @@ -240,42 +240,40 @@ echo ' }); } - $("#genera").click(function(event){ + $("#genera").click(function(event) { event.preventDefault(); - var form = $("#edit-form"); - form.find("*").prop("disabled", false); - valid = submitAjax(form); - - if (valid) {'; + salvaForm(this, "#edit-form").then(function(valid) { + if (valid) {'; if ($generated) { echo ' - swal({ - title: "'.tr('Sei sicuro di rigenerare la fattura?').'", - html: "

'.tr('Attenzione: sarà generato un nuovo progressivo invio').'.

'.tr('Se stai attendendo una ricevuta dal sistema SdI, rigenerando la fattura elettronica non sarà possibile corrispondere la ricevuta una volta emessa').'.

", - type: "warning", - showCancelButton: true, - confirmButtonColor: "#30d64b", - cancelButtonColor: "#d33", - confirmButtonText: "Genera" - }).then((result) => { - if (result) { - $("#form-xml").submit(); - } - });'; + swal({ + title: "'.tr('Sei sicuro di rigenerare la fattura?').'", + html: "

'.tr('Attenzione: sarà generato un nuovo progressivo invio').'.

'.tr('Se stai attendendo una ricevuta dal sistema SdI, rigenerando la fattura elettronica non sarà possibile corrispondere la ricevuta una volta emessa').'.

", + type: "warning", + showCancelButton: true, + confirmButtonColor: "#30d64b", + cancelButtonColor: "#d33", + confirmButtonText: "Genera" + }).then((result) => { + if (result) { + $("#form-xml").submit(); + } + });'; } else { echo ' - $("#form-xml").submit();'; + $("#form-xml").submit();'; } echo ' - } else { - swal({ - type: "error", - title: "'.tr('Errore').'", - text: "'.tr('Alcuni campi obbligatori non sono stati compilati correttamente').'.", - }); - } + } else { + swal({ + type: "error", + title: "'.tr('Errore').'", + text: "'.tr('Alcuni campi obbligatori non sono stati compilati correttamente').'.", + }); + } + }); }); '; diff --git a/plugins/pianificazione_interventi/edit.php b/plugins/pianificazione_interventi/edit.php index b92ea100b..f0ec12dd0 100755 --- a/plugins/pianificazione_interventi/edit.php +++ b/plugins/pianificazione_interventi/edit.php @@ -183,7 +183,7 @@ echo ' var restore = buttonLoading("#add_promemoria"); $.post(globals.rootdir + "/actions.php?id_plugin='.$structure['id'].'&id_parent='.$id_record.'", { op: "add-promemoria", - data_richiesta: "'.$contratto['data_accettazione'].'", + data_richiesta: "'.$contratto->data_accettazione.'", idtipointervento: id_tipo, }).done(function(data) { launch_modal("Nuovo promemoria", globals.rootdir + "/plugins/'.$structure['directory'].'/pianificazione.php?id_plugin='.$structure['id'].'&id_parent='.$id_record.'&id_record=" + data + "&add=1"); diff --git a/update/2_4_17.sql b/update/2_4_17.sql index f1a807983..bfa4c2596 100644 --- a/update/2_4_17.sql +++ b/update/2_4_17.sql @@ -177,3 +177,48 @@ ALTER TABLE `mg_causali_movimenti` DROP `movimento_carico`; INSERT INTO `mg_causali_movimenti` (`id`, `nome`, `descrizione`, `tipo_movimento`) VALUES (NULL, 'Spostamento', 'Spostamento manuale', 'spostamento'); + +-- Aggiunta tabella in_interventi_tecnici_assegnati per la gestione dei tecnici assegnati alle attività +CREATE TABLE IF NOT EXISTS `in_interventi_tecnici_assegnati` ( + `id_intervento` int(11) NOT NULL, + `id_tecnico` int(11) NOT NULL, + FOREIGN KEY (`id_intervento`) REFERENCES `in_interventi`(`id`) ON DELETE CASCADE, + FOREIGN KEY (`id_tecnico`) REFERENCES `an_anagrafiche`(`idanagrafica`) ON DELETE CASCADE +) ENGINE=InnoDB; + +-- Fix contenuti delle date (NULL al posto di 0000-00-00) +ALTER TABLE `mg_movimenti` CHANGE `data` `data` date; +ALTER TABLE `my_impianti` CHANGE `data` `data` date; +ALTER TABLE `an_anagrafiche` CHANGE `data_nascita` `data_nascita` date; +ALTER TABLE `in_interventi` CHANGE `data_richiesta` `data_richiesta` DATETIME; +ALTER TABLE `in_interventi` CHANGE `firma_data` `firma_data` DATETIME; + +UPDATE `mg_movimenti` SET `data` = NULL WHERE `data` = '0000-00-00' OR `data` = '0000-00-00 00:00:00'; +UPDATE `my_impianti` SET `data` = NULL WHERE `data` = '0000-00-00' OR `data` = '0000-00-00 00:00:00'; +UPDATE `an_anagrafiche` SET `data_nascita` = NULL WHERE `data_nascita` = '0000-00-00' OR `data_nascita` = '0000-00-00 00:00:00'; +UPDATE `in_interventi` SET `data_richiesta` = NULL WHERE `data_richiesta` = '0000-00-00' OR `data_richiesta` = '0000-00-00 00:00:00'; +UPDATE `in_interventi` SET `firma_data` = NULL WHERE `firma_data` = '0000-00-00' OR `firma_data` = '0000-00-00 00:00:00'; +UPDATE `updates` SET `id` = NULL WHERE `id` = '0000-00-00' OR `id` = '0000-00-00 00:00:00'; +UPDATE `in_interventi_tecnici` SET `orario_fine` = NULL WHERE `orario_fine` = '0000-00-00' OR `orario_fine` = '0000-00-00 00:00:00'; +UPDATE `in_interventi_tecnici` SET `orario_inizio` = NULL WHERE `orario_inizio` = '0000-00-00' OR `orario_inizio` = '0000-00-00 00:00:00'; +UPDATE `or_ordini` SET `data` = NULL WHERE `data` = '0000-00-00' OR `data` = '0000-00-00 00:00:00'; +UPDATE `co_documenti` SET `data` = NULL WHERE `data` = '0000-00-00' OR `data` = '0000-00-00 00:00:00'; +UPDATE `do_documenti` SET `data` = NULL WHERE `data` = '0000-00-00' OR `data` = '0000-00-00 00:00:00'; +UPDATE `co_movimenti` SET `data` = NULL WHERE `data` = '0000-00-00' OR `data` = '0000-00-00 00:00:00'; +UPDATE `my_impianto_componenti` SET `data` = NULL WHERE `data` = '0000-00-00' OR `data` = '0000-00-00 00:00:00'; +UPDATE `dt_ddt` SET `data` = NULL WHERE `data` = '0000-00-00' OR `data` = '0000-00-00 00:00:00'; +UPDATE `co_preventivi` SET `data_accettazione` = NULL WHERE `data_accettazione` = '0000-00-00' OR `data_accettazione` = '0000-00-00 00:00:00'; +UPDATE `co_contratti` SET `data_accettazione` = NULL WHERE `data_accettazione` = '0000-00-00' OR `data_accettazione` = '0000-00-00 00:00:00'; +UPDATE `co_contratti` SET `data_bozza` = NULL WHERE `data_bozza` = '0000-00-00' OR `data_bozza` = '0000-00-00 00:00:00'; +UPDATE `co_preventivi` SET `data_bozza` = NULL WHERE `data_bozza` = '0000-00-00' OR `data_bozza` = '0000-00-00 00:00:00'; +UPDATE `co_preventivi` SET `data_conclusione` = NULL WHERE `data_conclusione` = '0000-00-00' OR `data_conclusione` = '0000-00-00 00:00:00'; +UPDATE `co_contratti` SET `data_conclusione` = NULL WHERE `data_conclusione` = '0000-00-00' OR `data_conclusione` = '0000-00-00 00:00:00'; +UPDATE `co_scadenziario` SET `data_emissione` = NULL WHERE `data_emissione` = '0000-00-00' OR `data_emissione` = '0000-00-00 00:00:00'; +UPDATE `or_righe_ordini` SET `data_evasione` = NULL WHERE `data_evasione` = '0000-00-00' OR `data_evasione` = '0000-00-00 00:00:00'; +UPDATE `in_interventi` SET `data_invio` = NULL WHERE `data_invio` = '0000-00-00' OR `data_invio` = '0000-00-00 00:00:00'; +UPDATE `co_preventivi` SET `data_pagamento` = NULL WHERE `data_pagamento` = '0000-00-00' OR `data_pagamento` = '0000-00-00 00:00:00'; +UPDATE `co_scadenziario` SET `data_pagamento` = NULL WHERE `data_pagamento` = '0000-00-00' OR `data_pagamento` = '0000-00-00 00:00:00'; +UPDATE `co_promemoria` SET `data_richiesta` = NULL WHERE `data_richiesta` = '0000-00-00' OR `data_richiesta` = '0000-00-00 00:00:00'; +UPDATE `co_preventivi` SET `data_rifiuto` = NULL WHERE `data_rifiuto` = '0000-00-00' OR `data_rifiuto` = '0000-00-00 00:00:00'; +UPDATE `co_contratti` SET `data_rifiuto` = NULL WHERE `data_rifiuto` = '0000-00-00' OR `data_rifiuto` = '0000-00-00 00:00:00'; +UPDATE `my_impianto_componenti` SET `data_sostituzione` = NULL WHERE `data_sostituzione` = '0000-00-00' OR `data_sostituzione` = '0000-00-00 00:00:00';