Introduzione funzioni di utility per gli input
This commit is contained in:
parent
371ff09d93
commit
f605e61b0f
|
@ -1,79 +1,94 @@
|
||||||
// Inputmask
|
function input(name) {
|
||||||
function start_inputmask(element) {
|
return new Input(name);
|
||||||
if (element == undefined) {
|
}
|
||||||
element = '';
|
|
||||||
|
function Input(name) {
|
||||||
|
this.element = $("[name=" + name + "]").last();
|
||||||
|
|
||||||
|
// Fix per select multipli
|
||||||
|
if (this.element.length === 0) {
|
||||||
|
this.element = $("[name='" + name + "[]']").last();
|
||||||
|
}
|
||||||
|
|
||||||
|
// 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 {
|
} else {
|
||||||
element = element + ' ';
|
return this.enable();
|
||||||
}
|
|
||||||
|
|
||||||
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');
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
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);
|
||||||
|
}
|
||||||
|
|
|
@ -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');
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,205 +1,197 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
use Modules\Interventi\Intervento;
|
||||||
|
|
||||||
include_once __DIR__.'/../../core.php';
|
include_once __DIR__.'/../../core.php';
|
||||||
|
|
||||||
// Rimuovo session usate sui select combinati (sedi, preventivi, contratti, impianti)
|
// Rimuovo session usate sui select combinati (sedi, preventivi, contratti, impianti)
|
||||||
unset($_SESSION['superselect']['idanagrafica']);
|
unset($_SESSION['superselect']['idanagrafica']);
|
||||||
unset($_SESSION['superselect']['idsede']);
|
unset($_SESSION['superselect']['idsede']);
|
||||||
|
|
||||||
// Calcolo del nuovo codice
|
|
||||||
$new_codice = \Modules\Interventi\Intervento::getNextCodice($data);
|
|
||||||
|
|
||||||
// Se ho passato l'idanagrafica, carico il tipo di intervento di default
|
// Se ho passato l'idanagrafica, carico il tipo di intervento di default
|
||||||
$idanagrafica = filter('idanagrafica');
|
$id_anagrafica = filter('idanagrafica');
|
||||||
$idsede = filter('idsede');
|
$id_sede = filter('idsede');
|
||||||
|
$richiesta = filter('richiesta');
|
||||||
$idimpianto = null;
|
|
||||||
$idzona = null;
|
|
||||||
$idtipointervento = null;
|
|
||||||
$idstatointervento = null;
|
|
||||||
$richiesta = null;
|
|
||||||
$impianti = [];
|
$impianti = [];
|
||||||
|
|
||||||
// Come tecnico posso aprire attività solo a mio nome
|
$origine_dashboard = get('ref') !== null;
|
||||||
if ($user['gruppo'] == 'Tecnici' && !empty($user['idanagrafica'])) {
|
$module_anagrafiche = Modules::get('Anagrafiche');
|
||||||
$idtecnico = $user['idanagrafica'];
|
|
||||||
} else {
|
|
||||||
$idtecnico = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!empty($idanagrafica)) {
|
// Calcolo dell'orario di inizio e di fine sulla base delle informazioni fornite
|
||||||
$rs = $dbo->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_inizio = filter('orario_inizio');
|
||||||
$orario_fine = filter('orario_fine');
|
$orario_fine = filter('orario_fine');
|
||||||
} else {
|
if (null == $orario_inizio || '00:00:00' == $orario_inizio) {
|
||||||
$orario_inizio = date('H').':00:00';
|
$orario_inizio = date('H').':00:00';
|
||||||
$orario_fine = date('H', time() + 60 * 60).':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');
|
$id_intervento = filter('id_intervento');
|
||||||
$idcontratto = filter('idcontratto');
|
$id_contratto = filter('idcontratto');
|
||||||
$idcontratto_riga = filter('idcontratto_riga');
|
$id_promemoria_contratto = filter('idcontratto_riga');
|
||||||
|
|
||||||
// Se sto pianificando un contratto, leggo tutti i dati del contratto per predisporre l'aggiunta intervento
|
// Trasformazione di un Promemoria dei Contratti in Intervento
|
||||||
if (!empty($idcontratto) && !empty($idcontratto_riga)) {
|
if (!empty($id_contratto) && !empty($id_promemoria_contratto)) {
|
||||||
$rs = $dbo->fetchArray('SELECT *, (SELECT idzona FROM an_anagrafiche WHERE idanagrafica = co_contratti.idanagrafica) AS idzona FROM co_contratti WHERE id='.prepare($idcontratto));
|
$contratto = $dbo->fetchOne('SELECT *, (SELECT idzona FROM an_anagrafiche WHERE idanagrafica = co_contratti.idanagrafica) AS idzona FROM co_contratti WHERE id = '.prepare($id_contratto));
|
||||||
$idanagrafica = $rs[0]['idanagrafica'];
|
$id_anagrafica = $contratto['idanagrafica'];
|
||||||
$idzona = $rs[0]['idzona'];
|
$id_zona = $contratto['idzona'];
|
||||||
|
|
||||||
// Info riga pianificata
|
// Informazioni del Promemoria
|
||||||
$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));
|
$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));
|
||||||
$idtipointervento = $rs[0]['idtipointervento'];
|
$id_tipo = $promemoria['idtipointervento'];
|
||||||
$data = (null !== filter('data')) ? filter('data') : $rs[0]['data_richiesta'];
|
$data = (null !== filter('data')) ? filter('data') : $promemoria['data_richiesta'];
|
||||||
$richiesta = $rs[0]['richiesta'];
|
$richiesta = $promemoria['richiesta'];
|
||||||
$idsede = $rs[0]['idsede'];
|
$id_sede = $promemoria['idsede'];
|
||||||
$idimpianti = $rs[0]['idimpianti'];
|
$impianti_collegati = $promemoria['idimpianti'];
|
||||||
|
|
||||||
// aumento orario inizio del tempo standard definito dalla tipologia dell'intervento (PRESO DAL PROMEMORIA)
|
// Generazione dell'orario di fine sulla base del tempo standard definito dal Promemoria
|
||||||
if (!empty($rs[0]['tempo_standard'])) {
|
if (!empty($promemoria['tempo_standard'])) {
|
||||||
$orario_fine = date('H:i:s', strtotime($orario_inizio) + ((60 * 60) * $rs[0]['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
|
// Caricamento degli impianti a Contratto se non definiti in Promemoria
|
||||||
if (empty($idimpianti)) {
|
if (empty($impianti_collegati)) {
|
||||||
$rs = $dbo->fetchArray('SELECT idimpianto FROM my_impianti_contratti WHERE idcontratto='.prepare($idcontratto));
|
$rs = $dbo->fetchArray('SELECT idimpianto FROM my_impianti_contratti WHERE idcontratto = '.prepare($id_contratto));
|
||||||
$idimpianto = implode(',', array_column($rs, 'idimpianto'));
|
$impianti_collegati = 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'] ?: '';
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Seleziono "In programmazione" come stato
|
// Gestione dell'aggiunta di una sessione a un Intervento senza sessioni (Promemoria intervento) da Dashboard
|
||||||
$rs = $dbo->fetchArray("SELECT * FROM in_statiintervento WHERE descrizione = 'In programmazione'");
|
|
||||||
$idstatointervento = $rs[0]['idstatointervento'];
|
|
||||||
}
|
|
||||||
|
|
||||||
// Intervento senza sessioni
|
|
||||||
elseif (!empty($id_intervento)) {
|
elseif (!empty($id_intervento)) {
|
||||||
// Info riga pianificata
|
$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));
|
||||||
$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'];
|
|
||||||
|
|
||||||
// Aumento orario inizio del tempo standard definito dalla tipologia dell'intervento (PRESO DAL PROMEMORIA)
|
$id_tipo = $intervento['idtipointervento'];
|
||||||
if (!empty($rs[0]['tempo_standard'])) {
|
$data = (null !== filter('data')) ? filter('data') : $intervento['data_richiesta'];
|
||||||
$orario_fine = date('H:i:s', strtotime($orario_inizio) + ((60 * 60) * $rs[0]['tempo_standard']));
|
$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));
|
$rs = $dbo->fetchArray('SELECT idimpianto FROM my_impianti_interventi WHERE idintervento = '.prepare($id_intervento));
|
||||||
$idimpianto = implode(',', array_column($rs, 'idimpianto'));
|
$impianti_collegati = implode(',', array_column($rs, 'idimpianto'));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (empty($data_fine)) {
|
// Selezione dei tecnici assegnati agli impianti selezionati
|
||||||
if (null !== filter('data_fine')) {
|
if (!empty($impianti_collegati)) {
|
||||||
$data_fine = filter('data_fine');
|
$tecnici_impianti = $dbo->fetchArray('SELECT idtecnico FROM my_impianti WHERE id IN ('.prepare($impianti_collegati).')');
|
||||||
} else {
|
$id_tecnico = array_unique(array_column($tecnici_impianti, 'idtecnico'));
|
||||||
$data_fine = date('Y-m-d');
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Impostazione della data se mancante
|
||||||
if (empty($data)) {
|
if (empty($data)) {
|
||||||
if (null !== filter('data')) {
|
|
||||||
$data = filter('data');
|
$data = filter('data');
|
||||||
} else {
|
if (null == $data) {
|
||||||
$data = date('Y-m-d');
|
$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;
|
$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;
|
// Calcolo del nuovo codice
|
||||||
$orario_fine = $data_fine.' '.$orario_fine;
|
$new_codice = Intervento::getNextCodice($data);
|
||||||
|
|
||||||
?>
|
$_SESSION['superselect']['idanagrafica'] = $id_anagrafica;
|
||||||
|
|
||||||
<form action="" method="post" id="add-form" onsubmit="if($(this).parsley().validate()) { return add_intervento(); }">
|
echo '
|
||||||
|
<form action="" method="post" id="add-form">
|
||||||
<input type="hidden" name="op" value="add">
|
<input type="hidden" name="op" value="add">
|
||||||
<input type="hidden" name="ref" value="<?php echo get('ref'); ?>">
|
<input type="hidden" name="ref" value="'.get('ref').'">
|
||||||
<input type="hidden" name="backto" value="record-edit">
|
<input type="hidden" name="backto" value="record-edit">
|
||||||
|
|
||||||
<!-- Fix creazione da Anagrafica -->
|
<!-- Fix creazione da Anagrafica -->
|
||||||
<input type="hidden" name="id_record" value="">
|
<input type="hidden" name="id_record" value="">';
|
||||||
|
|
||||||
<?php
|
if (!empty($id_promemoria_contratto)) {
|
||||||
if (!empty($idcontratto_riga)) {
|
echo '<input type="hidden" name="idcontratto_riga" value="'.$id_promemoria_contratto.'">';
|
||||||
echo '<input type="hidden" name="idcontratto_riga" value="'.$idcontratto_riga.'">';
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!empty($id_intervento)) {
|
if (!empty($id_intervento)) {
|
||||||
echo '<input type="hidden" name="id_intervento" value="'.$id_intervento.'">';
|
echo '<input type="hidden" name="id_intervento" value="'.$id_intervento.'">';
|
||||||
}
|
}
|
||||||
?>
|
|
||||||
|
|
||||||
|
echo '
|
||||||
<!-- DATI CLIENTE -->
|
<!-- DATI CLIENTE -->
|
||||||
<div class="panel panel-primary">
|
<div class="panel panel-primary">
|
||||||
<div class="panel-heading">
|
<div class="panel-heading">
|
||||||
<h3 class="panel-title"><?php echo tr('Dati cliente'); ?></h3>
|
<h3 class="panel-title">'.tr('Dati cliente').'</h3>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
|
|
||||||
<!-- RIGA 1 -->
|
<!-- RIGA 1 -->
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-4">
|
<div class="col-md-4">
|
||||||
{[ "type": "select", "label": "<?php echo tr('Cliente'); ?>", "name": "idanagrafica", "required": 1, "value": "<?php echo $idanagrafica; ?>", "ajax-source": "clienti", "icon-after": "add|<?php echo Modules::get('Anagrafiche')['id']; ?>|tipoanagrafica=Cliente&readonly_tipo=1||<?php echo (empty($idanagrafica)) ? '' : 'disabled'; ?>", "data-heavy": 0, "readonly": "<?php echo (empty($idanagrafica)) ? 0 : 1; ?>" ]}
|
{[ "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).'" ]}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="col-md-4">
|
<div class="col-md-4">
|
||||||
{[ "type": "select", "label": "<?php echo tr('Sede destinazione'); ?>", "name": "idsede_destinazione", "value": "<?php echo $idsede; ?>", "placheholder": "<?php echo tr('Seleziona prima un cliente'); ?>...", "ajax-source": "sedi" ]}
|
{[ "type": "select", "label": "'.tr('Sede destinazione').'", "name": "idsede_destinazione", "value": "'.$id_sede.'", "ajax-source": "sedi" ]}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="col-md-4">
|
<div class="col-md-4">
|
||||||
{[ "type": "select", "label": "<?php echo tr('Per conto di'); ?>", "name": "idclientefinale", "value": "<?php echo $idclientefinale; ?>", "ajax-source": "clienti" ]}
|
{[ "type": "select", "label": "'.tr('Per conto di').'", "name": "idclientefinale", "value": "'.$id_cliente_finale.'", "ajax-source": "clienti" ]}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!-- RIGA 2 -->
|
<!-- RIGA 2 -->
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-4">
|
<div class="col-md-4">
|
||||||
{[ "type": "select", "label": "<?php echo tr('Zona'); ?>", "name": "idzona", "values": "query=SELECT id, CONCAT_WS( ' - ', nome, descrizione) AS descrizione FROM an_zone ORDER BY nome", "value": "<?php echo $idzona; ?>", "placeholder": "<?php echo tr('Nessuna zona'); ?>", "help":"<?php echo 'La zona viene definita automaticamente in base al cliente selezionato'; ?>.", "extra": "readonly", "value": "<?php echo $idzona; ?>" ]}
|
{[ "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.'" ]}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="col-md-4">
|
<div class="col-md-4">
|
||||||
{[ "type": "select", "label": "<?php echo tr('Preventivo'); ?>", "name": "idpreventivo", "value": "<?php echo $idpreventivo; ?>"<?php echo !empty($idanagrafica) ? '' : ', "placeholder": "'.tr('Seleziona prima un cliente').'..."'; ?>, "ajax-source": "preventivi", "readonly": "<?php echo (empty($idcontratto)) ? 0 : 1; ?>" ]}
|
{[ "type": "select", "label": "'.tr('Preventivo').'", "name": "idpreventivo", "value": "'.$id_preventivo.'", "ajax-source": "preventivi", "readonly": "'.(empty($id_contratto) ? 0 : 1).'" ]}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="col-md-4">
|
<div class="col-md-4">
|
||||||
{[ "type": "select", "label": "<?php echo tr('Contratto'); ?>", "name": "idcontratto", "value": "<?php echo $idcontratto; ?>"<?php echo !empty($idanagrafica) ? '' : ', "placeholder": "'.tr('Seleziona prima un cliente').'..."'; ?>, "ajax-source": "contratti", "readonly": "<?php echo (empty($idcontratto)) ? 0 : 1; ?>" ]}
|
{[ "type": "select", "label": "'.tr('Contratto').'", "name": "idcontratto", "value": "'.$id_contratto.'", "ajax-source": "contratti", "readonly": "'.(empty($id_contratto) ? 0 : 1).'" ]}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-6" id='impianti'>
|
<div class="col-md-6">
|
||||||
{[ "type": "select", "label": "<?php echo tr('Impianto'); ?>", "multiple": 1, "name": "idimpianti[]", "value": "<?php echo $idimpianto; ?>"<?php echo !empty($idanagrafica) ? '' : ', "placeholder": "'.tr('Seleziona prima un cliente').'..."'; ?>, "ajax-source": "impianti-cliente", "icon-after": "add|<?php echo Modules::get('Impianti')['id']; ?>|source=Attività||<?php echo (intval($idimpianto)) ? '' : 'disabled'; ?>", "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à" ]}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
{[ "type": "select", "label": "<?php echo tr('Componenti'); ?>", "multiple": 1, "name": "componenti[]", "placeholder": "<?php echo tr('Seleziona prima un impianto'); ?>...", "ajax-source": "componenti" ]}
|
{[ "type": "select", "label": "'.tr('Componenti').'", "multiple": 1, "name": "componenti[]", "placeholder": "'.tr('Seleziona prima un impianto').'", "ajax-source": "componenti" ]}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -208,45 +200,45 @@ if (!empty($id_intervento)) {
|
||||||
<!-- DATI INTERVENTO -->
|
<!-- DATI INTERVENTO -->
|
||||||
<div class="panel panel-primary">
|
<div class="panel panel-primary">
|
||||||
<div class="panel-heading">
|
<div class="panel-heading">
|
||||||
<h3 class="panel-title"><?php echo tr('Dati intervento'); ?></h3>
|
<h3 class="panel-title">'.tr('Dati intervento').'</h3>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
<!-- RIGA 3 -->
|
<!-- RIGA 3 -->
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-3">
|
<div class="col-md-3">
|
||||||
{[ "type": "timestamp", "label": "<?php echo tr('Data/ora richiesta'); ?>", "name": "data_richiesta", "required": 1, "value": "<?php echo $data_richiesta ?: '-now-'; ?>" ]}
|
{[ "type": "timestamp", "label": "'.tr('Data/ora richiesta').'", "name": "data_richiesta", "required": 1, "value": "'.($data_richiesta ?: '-now-').'" ]}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="col-md-3">
|
<div class="col-md-3">
|
||||||
{[ "type": "timestamp", "label": "<?php echo tr('Data/ora scadenza'); ?>", "name": "data_scadenza", "required": 0, "value": "<?php echo $data_scadenza; ?>" ]}
|
{[ "type": "timestamp", "label": "'.tr('Data/ora scadenza').'", "name": "data_scadenza", "required": 0, "value": "'.$data_scadenza.'" ]}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="col-md-3">
|
<div class="col-md-3">
|
||||||
{[ "type": "select", "label": "<?php echo tr('Tipo attività'); ?>", "name": "idtipointervento", "required": 1, "values": "query=SELECT idtipointervento AS id, descrizione FROM in_tipiintervento ORDER BY descrizione ASC", "value": "<?php echo $idtipointervento; ?>", "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" ]}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="col-md-3">
|
<div class="col-md-3">
|
||||||
{[ "type": "select", "label": "<?php echo 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": "<?php echo $idstatointervento; ?>" ]}
|
{[ "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.'" ]}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!-- RIGA 5 -->
|
<!-- RIGA 5 -->
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-12">
|
<div class="col-md-12">
|
||||||
{[ "type": "textarea", "label": "<?php echo tr('Richiesta'); ?>", "name": "richiesta", "required": 1, "value": "<?php echo $richiesta; ?>", "extra": "style='max-height:80px; ' " ]}
|
{[ "type": "textarea", "label": "'.tr('Richiesta').'", "name": "richiesta", "required": 1, "value": "'.$richiesta.'", "extra": "style=\'max-height:80px;\'" ]}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!-- DATI INTERVENTO -->
|
<!-- DATI INTERVENTO -->
|
||||||
<div class="box box-primary collapsable <?php echo get('ref') ? '' : 'collapsed-box'; ?>">
|
<div class="box box-primary collapsable '.($origine_dashboard ? '' : 'collapsed-box').'">
|
||||||
<div class="box-header with-border">
|
<div class="box-header with-border">
|
||||||
<h3 class="box-title"><?php echo tr('Ore di lavoro'); ?></h3>
|
<h3 class="box-title">'.tr('Ore di lavoro').'</h3>
|
||||||
<div class="box-tools pull-right">
|
<div class="box-tools pull-right">
|
||||||
<button type="button" class="btn btn-box-tool" data-widget="collapse">
|
<button type="button" class="btn btn-box-tool" data-widget="collapse">
|
||||||
<i class="fa fa-<?php echo get('ref') ? 'minus' : 'plus'; ?>"></i>
|
<i class="fa fa-'.($origine_dashboard ? 'minus' : 'plus').'"></i>
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -254,227 +246,230 @@ if (!empty($id_intervento)) {
|
||||||
<div class="box-body">
|
<div class="box-body">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
{[ "type": "timestamp", "label": "<?php echo tr('Inizio attività'); ?>", "name": "orario_inizio", "required": <?php echo get('ref') ? 1 : 0; ?>, "value": "<?php echo $orario_inizio; ?>" ]}
|
{[ "type": "timestamp", "label": "'.tr('Inizio attività').'", "name": "orario_inizio", "required": '.($origine_dashboard ? 1 : 0).', "value": "'.$inizio_sessione.'" ]}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
{[ "type": "timestamp", "label": "<?php echo tr('Fine attività'); ?>", "name": "orario_fine", "required": <?php echo get('ref') ? 1 : 0; ?>, "value": "<?php echo $orario_fine; ?>" ]}
|
{[ "type": "timestamp", "label": "'.tr('Fine attività').'", "name": "orario_fine", "required": '.($origine_dashboard ? 1 : 0).', "value": "'.$fine_sessione.'" ]}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-12">
|
<div class="col-md-12">
|
||||||
{[ "type": "select", "label": "<?php echo tr('Tecnici'); ?>", "multiple": "1", "name": "idtecnico[]", "required": <?php echo get('ref') ? 1 : 0; ?>, "ajax-source": "tecnici", "value": "<?php echo $idtecnico; ?>", "icon-after": "add|<?php echo Modules::get('Anagrafiche')['id']; ?>|tipoanagrafica=Tecnico||<?php echo (empty($idtecnico)) ? '' : 'disabled'; ?>" ]}
|
{[ "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').'" ]}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
<!-- PULSANTI -->
|
<!-- PULSANTI -->
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-12 text-right">
|
<div class="col-md-12 text-right">
|
||||||
<button type="submit" class="btn btn-primary"><i class="fa fa-plus"></i> <?php echo tr('Aggiungi'); ?></button>
|
<button type="button" class="btn btn-primary" onclick="salva(this)">
|
||||||
|
<i class="fa fa-plus"></i> '.tr('Aggiungi').'
|
||||||
|
</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
|
|
||||||
<script>$(document).ready(init)</script>
|
<script>$(document).ready(init)</script>';
|
||||||
|
|
||||||
<script type="text/javascript">
|
|
||||||
$(document).ready(function() {
|
|
||||||
if(!$("#modals > div #idanagrafica").val()){
|
|
||||||
$("#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);
|
|
||||||
|
|
||||||
<?php
|
|
||||||
if (!empty($idcontratto) && (!empty($idordineservizio) || !empty($idcontratto_riga))) {
|
|
||||||
// Disabilito i campi che non devono essere modificati per poter collegare l'intervento all'ordine di servizio
|
|
||||||
|
|
||||||
echo '
|
|
||||||
$("#modals > div #idanagrafica").prop("disabled", true);
|
|
||||||
$("#modals > div #idclientefinale").prop("disabled", true);
|
|
||||||
$("#modals > div #idzona").prop("disabled", true);
|
|
||||||
$("#modals > div #idtipointervento").prop("disabled", true);
|
|
||||||
$("#modals > div #impianti").find("button").prop("disabled", true);';
|
|
||||||
}
|
|
||||||
?>
|
|
||||||
}
|
|
||||||
|
|
||||||
<?php
|
|
||||||
|
|
||||||
if (!empty($id_intervento)) {
|
if (!empty($id_intervento)) {
|
||||||
echo '
|
echo '
|
||||||
$("#modals > div #idsede_destinazione").prop("disabled", true);
|
<script type="text/javascript">
|
||||||
$("#modals > div #idpreventivo").prop("disabled", true);
|
$(document).ready(function() {
|
||||||
$("#modals > div #idcontratto").prop("disabled", true);
|
input("idsede_destinazione").disable();
|
||||||
$("#modals > div #idimpianti").prop("disabled", true);
|
input("idpreventivo").disable();
|
||||||
$("#modals > div #componenti").prop("disabled", true);
|
input("idcontratto").disable();
|
||||||
$("#modals > div #idanagrafica").prop("disabled", true);
|
input("idimpianti").disable();
|
||||||
$("#modals > div #idanagrafica").find("button").prop("disabled", true);
|
input("componenti").disable();
|
||||||
$("#modals > div #idclientefinale").prop("disabled", true);
|
input("idanagrafica").disable();
|
||||||
$("#modals > div #idzona").prop("disabled", true);
|
input("idanagrafica").find("button").disable();
|
||||||
$("#modals > div #idtipointervento").prop("disabled", true);
|
input("idclientefinale").disable();
|
||||||
$("#modals > div #idstatointervento").prop("disabled", true);
|
input("idzona").disable();
|
||||||
$("#modals > div #richiesta").prop("disabled", true);
|
input("idtipointervento").disable();
|
||||||
$("#modals > div #data_richiesta").prop("disabled", true);
|
input("idstatointervento").disable();
|
||||||
$("#modals > div #impianti").find("button").prop("disabled", true);
|
input("richiesta").disable();
|
||||||
';
|
input("data_richiesta").disable();
|
||||||
|
input("impianti").find("button").disable();
|
||||||
|
});
|
||||||
|
</script>';
|
||||||
}
|
}
|
||||||
?>
|
|
||||||
|
|
||||||
// Quando modifico orario inizio, allineo anche l'orario fine
|
// Disabilito i campi che non devono essere modificati per poter collegare l'Intervento al Promemoria del Contratto
|
||||||
$("#modals > div #orario_inizio").on("dp.change", function (e) {
|
if (!empty($id_contratto) && !empty($id_promemoria_contratto)) {
|
||||||
$("#modals > div #orario_fine").data("DateTimePicker").minDate(e.date);
|
echo '
|
||||||
$("#modals > div #orario_fine").change();
|
<script type="text/javascript">
|
||||||
|
$(document).ready(function() {
|
||||||
|
input("idanagrafica").disable();
|
||||||
|
input("idclientefinale").disable();
|
||||||
|
input("idzona").disable();
|
||||||
|
input("idtipointervento").disable();
|
||||||
|
input("impianti").find("button").disable();
|
||||||
|
});
|
||||||
|
</script>';
|
||||||
|
}
|
||||||
|
|
||||||
|
echo '
|
||||||
|
<script type="text/javascript">
|
||||||
|
var anagrafica = input("idanagrafica");
|
||||||
|
var sede = input("idsede_destinazione");
|
||||||
|
var contratto = input("idcontratto");
|
||||||
|
var preventivo = input("idpreventivo");
|
||||||
|
|
||||||
|
$(document).ready(function() {
|
||||||
|
if(!anagrafica.get()){
|
||||||
|
sede.disable();
|
||||||
|
input("idpreventivo").disable();
|
||||||
|
input("idcontratto").disable();
|
||||||
|
input("idimpianti").disable();
|
||||||
|
input("componenti").disable();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Quando modifico orario inizio, allineo anche l\'orario fine
|
||||||
|
let orario_inizio = input("orario_inizio").getElement();
|
||||||
|
let orario_fine = input("orario_fine").getElement();
|
||||||
|
orario_inizio.on("dp.change", function (e) {
|
||||||
|
orario_fine.data("DateTimePicker").minDate(e.date);
|
||||||
|
orario_fine.change();
|
||||||
});
|
});
|
||||||
|
|
||||||
// Refresh modulo dopo la chiusura di una pianificazione attività derivante dalle attività
|
// Refresh modulo dopo la chiusura di una pianificazione attività derivante dalle attività
|
||||||
// da pianificare, altrimenti il promemoria non si vede più nella lista a destra
|
// da pianificare, altrimenti il promemoria non si vede più nella lista a destra
|
||||||
// TODO: da gestire via ajax
|
// TODO: da gestire via ajax
|
||||||
if( $('input[name=idcontratto_riga]').val() != undefined ){
|
if($("input[name=idcontratto_riga]").val()) {
|
||||||
$('#modals > div button.close').on('click', function() {
|
$("#modals > div button.close").on("click", function() {
|
||||||
location.reload();
|
location.reload();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
$('#modals > div #idanagrafica').change(function() {
|
// Gestione della modifica dell\'anagrafica
|
||||||
|
anagrafica.change(function() {
|
||||||
updateSelectOption("idanagrafica", $(this).val());
|
updateSelectOption("idanagrafica", $(this).val());
|
||||||
session_set('superselect,idanagrafica', $(this).val(), 0);
|
session_set("superselect,idanagrafica", $(this).val(), 0);
|
||||||
|
|
||||||
var value = !$(this).val() ? true : false;
|
var value = !$(this).val();
|
||||||
var placeholder = !$(this).val() ? "<?php echo tr('Seleziona prima un cliente...'); ?>" : "<?php echo tr("Seleziona un'opzione"); ?>";
|
var placeholder = value ? "'.tr('Seleziona prima un cliente').'" : "'.tr("Seleziona un'opzione").'";
|
||||||
|
|
||||||
$("#modals > div #idsede_destinazione").prop("disabled", value);
|
sede.setDisabled(value)
|
||||||
$("#modals > div #idsede_destinazione").selectReset(placeholder);
|
.getElement().selectReset(placeholder);
|
||||||
|
|
||||||
$("#modals > div #idpreventivo").prop("disabled", value);
|
input("idpreventivo").setDisabled(value)
|
||||||
$("#modals > div #idpreventivo").selectReset(placeholder);
|
.getElement().selectReset(placeholder);
|
||||||
|
|
||||||
$("#modals > div #idcontratto").prop("disabled", value);
|
input("idcontratto").setDisabled(value)
|
||||||
$("#modals > div #idcontratto").selectReset(placeholder);
|
.getElement().selectReset(placeholder);
|
||||||
|
|
||||||
$("#modals > div #idimpianti").prop("disabled", value);
|
input("idimpianti").setDisabled(value);
|
||||||
$("#modals > div #impianti").find("button").prop("disabled", value);
|
|
||||||
$("#modals > div #idimpianti").selectReset(placeholder);
|
|
||||||
|
|
||||||
if (($(this).val())) {
|
let data = anagrafica.getData();
|
||||||
if (($(this).selectData().idzona)){
|
if (data) {
|
||||||
$('#modals > div #idzona').val($(this).selectData().idzona).change();
|
input("idzona").set(data.idzona ? data.idzona : "");
|
||||||
|
// session_set("superselect,idzona", $(this).selectData().idzona, 0);
|
||||||
|
|
||||||
}else{
|
// Impostazione del tipo intervento da anagrafica
|
||||||
$('#modals > div #idzona').val('').change();
|
input("idtipointervento").getElement()
|
||||||
}
|
.selectSetNew($(this).selectData().idtipointervento, $(this).selectData().idtipointervento_descrizione);
|
||||||
// session_set('superselect,idzona', $(this).selectData().idzona, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Settaggio tipo intervento da anagrafica
|
|
||||||
$('#modals > div #idtipointervento').selectSetNew($(this).selectData().idtipointervento, $(this).selectData().idtipointervento_descrizione);
|
|
||||||
});
|
|
||||||
|
|
||||||
$('#modals > div #idsede_destinazione').change(function() {
|
|
||||||
session_set('superselect,idsede_destinazione', $(this).val(), 0);
|
|
||||||
$("#modals > div #idimpianti").selectReset();
|
|
||||||
|
|
||||||
if (($(this).val())) {
|
|
||||||
if (($(this).selectData().idzona)){
|
|
||||||
$('#modals > div #idzona').val($(this).selectData().idzona).change();
|
|
||||||
}else{
|
|
||||||
$('#modals > div #idzona').val('').change();
|
|
||||||
}
|
|
||||||
// session_set('superselect,idzona', $(this).selectData().idzona, 0);
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
$('#modals > div #idpreventivo').change(function() {
|
// Gestione della modifica della sede selezionato
|
||||||
if($('#modals > div #idcontratto').val() && $(this).val()){
|
sede.change(function() {
|
||||||
$("#modals > div #idcontratto").selectReset();
|
session_set("superselect,idsede_destinazione", $(this).val(), 0);
|
||||||
}
|
input("idimpianti").getElement().selectReset();
|
||||||
|
|
||||||
if($(this).val()){
|
let data = sede.getData();
|
||||||
$('#modals > div #idtipointervento').selectSetNew($(this).selectData().idtipointervento, $(this).selectData().idtipointervento_descrizione);
|
if (data) {
|
||||||
|
input("idzona").set(data.idzona ? data.idzona : "");
|
||||||
|
// session_set("superselect,idzona", $(this).selectData().idzona, 0);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
$('#modals > div #idcontratto').change(function() {
|
// Gestione della modifica del preventivo selezionato
|
||||||
if($('#modals > div #idpreventivo').val() && $(this).val()){
|
preventivo.change(function() {
|
||||||
$("#modals > div #idpreventivo").selectReset();
|
if (contratto.get() && preventivo.get()){
|
||||||
$('input[name=idcontratto_riga]').val('');
|
contratto.getElement().selectReset();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (preventivo.get()) {
|
||||||
|
input("idtipointervento").getElement()
|
||||||
|
.selectSetNew($(this).selectData().idtipointervento, $(this).selectData().idtipointervento_descrizione);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
$('#modals > div #idimpianti').change(function() {
|
// Gestione della modifica del contratto selezionato
|
||||||
session_set('superselect,marticola', $(this).val(), 0);
|
contratto.change(function() {
|
||||||
|
if (contratto.get() && preventivo.get()){
|
||||||
$("#modals > div #componenti").prop("disabled", !$(this).val() ? true : false);
|
preventivo.getElement().selectReset();
|
||||||
$("#modals > div #componenti").selectReset();
|
$("input[name=idcontratto_riga]").val("");
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
// tempo standard
|
// Gestione delle modifiche agli impianti selezionati
|
||||||
// TODO: tempo_standard da preventivo e contratto attraverso selectData() relativi
|
input("idimpianti").change(function() {
|
||||||
$('#modals > div #idtipointervento').change(function() {
|
session_set("superselect,marticola", $(this).val(), 0);
|
||||||
|
|
||||||
if ($(this).selectData() && (($(this).selectData().tempo_standard)>0) && ('<?php echo filter('orario_fine'); ?>' == '')){
|
input("componenti").setDisabled(!$(this).val())
|
||||||
|
.getElement().selectReset();
|
||||||
|
});';
|
||||||
|
|
||||||
orario_inizio = moment($('#modals > div #orario_inizio').val(), globals.timestamp_format, globals.locale).isValid() ? $('#modals > div #orario_inizio').val() : false;
|
if (filter('orario_fine') !== null) {
|
||||||
|
echo '
|
||||||
|
// Automatismo del tempo standard
|
||||||
|
input("idtipointervento").change(function() {
|
||||||
|
let data = $(this).selectData();
|
||||||
|
if (data && data.tempo_standard > 0) {
|
||||||
|
let orario_inizio = input("orario_inizio").get();
|
||||||
|
|
||||||
//da sistemare
|
if (moment(orario_inizio, globals.timestamp_format, globals.locale).isValid()) {
|
||||||
if (orario_inizio){
|
let tempo_standard = data.tempo_standard * 60;
|
||||||
tempo_standard = ($(this).selectData().tempo_standard)*60;
|
let nuovo_orario_fine = moment(orario_inizio).add(tempo_standard, "m");
|
||||||
orario_fine = moment(orario_inizio).add(tempo_standard, 'm');
|
input("orario_fine").set(moment(nuovo_orario_fine).format(globals.timestamp_format));
|
||||||
$('#modals > div #orario_fine').val(moment(orario_fine).format(globals.timestamp_format));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
});';
|
||||||
|
}
|
||||||
|
|
||||||
});
|
if (!$origine_dashboard) {
|
||||||
|
echo '
|
||||||
|
input("idtecnico").change(function() {
|
||||||
|
var value = $(this).val() > 0 ? true : false;
|
||||||
|
input("orario_inizio").setRequired(value);
|
||||||
|
input("orario_fine").setRequired(value);
|
||||||
|
input("data").setRequired(value);
|
||||||
|
});';
|
||||||
|
}
|
||||||
|
|
||||||
$('#modals > div #idtecnico').change(function() {
|
echo '
|
||||||
<?php if (!get('ref')) {
|
var ref = "'.get('ref').'";
|
||||||
?>
|
|
||||||
var value = ($(this).val()>0) ? true : false;
|
|
||||||
$('#modals > div #orario_inizio').prop("required", value);
|
|
||||||
$('#modals > div #orario_fine').prop("required", value);
|
|
||||||
$('#modals > div #data').prop("required", value);
|
|
||||||
<?php
|
|
||||||
} ?>
|
|
||||||
});
|
|
||||||
|
|
||||||
var ref = "<?php echo get('ref'); ?>";
|
async function salva(button) {
|
||||||
|
// Submit attraverso ricaricamento della pagina
|
||||||
|
if (!ref) {
|
||||||
|
$("#add-form").submit();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
function add_intervento(){
|
// Submit dinamico tramite AJAX
|
||||||
// Se l'aggiunta intervento proviene dal calendario, faccio il submit via ajax e ricarico gli eventi...
|
let valid = await salvaForm(button, "#add-form");
|
||||||
if(ref){
|
if (!valid) return;
|
||||||
$('#add-form').find('[type=submit]').prop("disabled", true).addClass("disabled");
|
|
||||||
$('#add-form').find('input:disabled, select:disabled, textarea:disabled').removeAttr('disabled');
|
|
||||||
|
|
||||||
$.post(globals.rootdir + '/actions.php?id_module=<?php echo Modules::get('Interventi')['id']; ?>', $('#add-form').serialize(), function(data,response){
|
// Se l\'aggiunta intervento proviene dalla scheda di pianificazione ordini di servizio della dashboard, la ricarico
|
||||||
if(response=="success"){
|
|
||||||
// Se l'aggiunta intervento proviene dalla scheda di pianificazione ordini di servizio della dashboard, la ricarico
|
|
||||||
if (ref == "dashboard") {
|
if (ref == "dashboard") {
|
||||||
$("#modals > div").modal('hide');
|
$("#modals > div").modal("hide");
|
||||||
|
|
||||||
// Aggiornamento elenco interventi da pianificare
|
// Aggiornamento elenco interventi da pianificare
|
||||||
$('#calendar').fullCalendar('refetchEvents');
|
$("#calendar").fullCalendar("refetchEvents");
|
||||||
$('#calendar').fullCalendar('render');
|
$("#calendar").fullCalendar("render");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Se l'aggiunta intervento proviene dai contratti, faccio il submit via ajax e ricarico la tabella dei contratti
|
// Se l\'aggiunta intervento proviene dai contratti, faccio il submit via ajax e ricarico la tabella dei contratti
|
||||||
else if (ref == "interventi_contratti") {
|
else if (ref == "interventi_contratti") {
|
||||||
|
$("#modals > div").modal("hide");
|
||||||
$("#modals > div").modal('hide');
|
|
||||||
parent.window.location.reload();
|
parent.window.location.reload();
|
||||||
//TODO: da gestire via ajax
|
//TODO: da gestire via ajax
|
||||||
//$('#elenco_interventi > tbody').load(globals.rootdir + '/modules/contratti/plugins/contratti.pianificazioneinterventi.php?op=get_interventi_pianificati&idcontratto=<?php echo $idcontratto; ?>');
|
//$("#elenco_interventi > tbody").load(globals.rootdir + "/modules/contratti/plugins/contratti.pianificazioneinterventi.php?op=get_interventi_pianificati&idcontratto='.$id_contratto.'");
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
</script>';
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
|
|
|
@ -243,10 +243,7 @@ echo '
|
||||||
$("#genera").click(function(event) {
|
$("#genera").click(function(event) {
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
|
|
||||||
var form = $("#edit-form");
|
salvaForm(this, "#edit-form").then(function(valid) {
|
||||||
form.find("*").prop("disabled", false);
|
|
||||||
valid = submitAjax(form);
|
|
||||||
|
|
||||||
if (valid) {';
|
if (valid) {';
|
||||||
|
|
||||||
if ($generated) {
|
if ($generated) {
|
||||||
|
@ -278,4 +275,5 @@ echo '
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
});
|
||||||
</script>';
|
</script>';
|
||||||
|
|
|
@ -183,7 +183,7 @@ echo '
|
||||||
var restore = buttonLoading("#add_promemoria");
|
var restore = buttonLoading("#add_promemoria");
|
||||||
$.post(globals.rootdir + "/actions.php?id_plugin='.$structure['id'].'&id_parent='.$id_record.'", {
|
$.post(globals.rootdir + "/actions.php?id_plugin='.$structure['id'].'&id_parent='.$id_record.'", {
|
||||||
op: "add-promemoria",
|
op: "add-promemoria",
|
||||||
data_richiesta: "'.$contratto['data_accettazione'].'",
|
data_richiesta: "'.$contratto->data_accettazione.'",
|
||||||
idtipointervento: id_tipo,
|
idtipointervento: id_tipo,
|
||||||
}).done(function(data) {
|
}).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");
|
launch_modal("Nuovo promemoria", globals.rootdir + "/plugins/'.$structure['directory'].'/pianificazione.php?id_plugin='.$structure['id'].'&id_parent='.$id_record.'&id_record=" + data + "&add=1");
|
||||||
|
|
|
@ -177,3 +177,48 @@ ALTER TABLE `mg_causali_movimenti` DROP `movimento_carico`;
|
||||||
|
|
||||||
INSERT INTO `mg_causali_movimenti` (`id`, `nome`, `descrizione`, `tipo_movimento`) VALUES
|
INSERT INTO `mg_causali_movimenti` (`id`, `nome`, `descrizione`, `tipo_movimento`) VALUES
|
||||||
(NULL, 'Spostamento', 'Spostamento manuale', 'spostamento');
|
(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';
|
||||||
|
|
Loading…
Reference in New Issue