- {[ "type": "select", "label": "'.tr('Impianto su cui installare').'", "name": "idimpianto", "value": "'.$idimpianto.'", "ajax-source": "impianti-intervento", "select-options": '.json_encode($options['select-options']['impianti']).' ]}
+ {[ "type": "select", "label": "'.tr('Impianto su cui installare').'", "name": "id_impianto", "value": "", "ajax-source": "impianti-intervento", "select-options": '.json_encode($options['select-options']['impianti']).', "help": "'.tr("La selezione di un Impianto in questo campo provocherà l'installazione di un nuovo Componente basato sull'Articolo corrente").'" ]}
';
}
diff --git a/modules/gestione_componenti/ajax/select.php b/modules/gestione_componenti/ajax/select.php
deleted file mode 100755
index 28a3f15fe..000000000
--- a/modules/gestione_componenti/ajax/select.php
+++ /dev/null
@@ -1,62 +0,0 @@
-.
- */
-
-use Util\Ini;
-
-include_once __DIR__.'/../../../core.php';
-
-switch ($resource) {
- /*
- * Opzioni utilizzate:
- * - matricola
- */
- case 'componenti':
- if (isset($superselect['matricola'])) {
- $query = 'SELECT id, nome AS descrizione, contenuto FROM my_impianto_componenti |where| ORDER BY id';
-
- foreach ($elements as $element) {
- $filter[] = 'id='.prepare($element);
- }
-
- $temp = [];
- $impianti = explode(',', $superselect['matricola']);
- foreach ($impianti as $key => $idimpianto) {
- $temp[] = 'idimpianto='.prepare($idimpianto);
- }
- $where[] = '('.implode(' OR ', $temp).')';
-
- if (!empty($search)) {
- $search_fields[] = 'nome LIKE '.prepare('%'.$search.'%');
- }
-
- $results = AJAX::selectResults($query, $where, $filter, $search, $limit, $custom);
- $data = $results['results'];
- foreach ($data as $key => $value) {
- $matricola = Ini::getValue($value['contenuto'], 'Matricola');
-
- $data[$key]['text'] = (empty($matricola) ? '' : $matricola.' - ').$data[$key]['text'];
-
- unset($data[$key]['contenuto']);
- }
-
- $results['results'] = $data;
- }
-
- break;
-}
diff --git a/modules/impianti/ajax/select.php b/modules/impianti/ajax/select.php
index d3092fdf2..a86f28ccf 100755
--- a/modules/impianti/ajax/select.php
+++ b/modules/impianti/ajax/select.php
@@ -77,4 +77,36 @@ switch ($resource) {
}
}
break;
+
+ /*
+ * Opzioni utilizzate:
+ * - matricola
+ */
+ case 'componenti':
+ if (isset($superselect['matricola'])) {
+ $query = 'SELECT my_componenti.id, CONCAT("#", my_componenti.id, ": ", mg_articoli.codice, " - ", mg_articoli.descrizione) AS descrizione
+ FROM my_componenti
+ INNER JOIN mg_articoli ON mg_articoli.id = my_componenti.id_articolo
+ |where| ORDER BY my_componenti.id';
+
+ foreach ($elements as $element) {
+ $filter[] = 'my_componenti.id = '.prepare($element);
+ }
+
+ $where = [
+ 'my_componenti.data_sostituzione IS NULL',
+ 'my_componenti.data_rimozione IS NULL',
+ ];
+
+ $impianti = $superselect['matricola'];
+ if (!empty($impianti)){
+ $where[] = 'my_componenti.id_impianto IN ('.$impianti.')';
+ }
+
+ if (!empty($search)) {
+ $search[] = 'my_componenti.note LIKE '.prepare('%'.$search.'%');
+ }
+ }
+
+ break;
}
diff --git a/modules/impianti/plugins/my_impianti.componenti.php b/modules/impianti/plugins/my_impianti.componenti.php
deleted file mode 100755
index 2516c7fb8..000000000
--- a/modules/impianti/plugins/my_impianti.componenti.php
+++ /dev/null
@@ -1,340 +0,0 @@
-.
- */
-
-use Modules\Interventi\Intervento;
-use Util\Ini;
-
-include_once __DIR__.'/../../../core.php';
-
-switch (filter('op')) {
- case 'modifica_componente':
- $idcomponente = get('id');
- $data = post('data_componente');
-
- // Ricavo il valore di contenuto leggendolo dal db
- $query = 'SELECT * FROM my_impianto_componenti WHERE idimpianto='.prepare($id_record).' AND id='.prepare($idcomponente);
- $rs = $dbo->fetchArray($query);
- $contenuto = $rs[0]['contenuto'];
-
- $contenuto = Ini::write($contenuto, $post);
-
- $query = 'UPDATE my_impianto_componenti SET data='.prepare($data).', contenuto='.prepare($contenuto).' WHERE idimpianto='.prepare($id_record).' AND id='.prepare($idcomponente);
- $dbo->query($query);
-
- flash()->info(tr('Informazioni componente aggiornate correttamente!'));
-
- $_SESSION['idcomponente'] = $idcomponente;
- break;
-
- case 'aggiunta_componente':
- $filename = get('filename');
-
- if (!empty($filename)) {
- $contenuto = file_get_contents(base_dir().'/files/impianti/'.$filename);
- $nome = Ini::getValue(Ini::readFile(base_dir().'/files/impianti/'.$filename), 'Nome');
-
- $query = 'INSERT INTO my_impianto_componenti(filename, idimpianto, contenuto, nome, data) VALUES('.prepare($filename).', '.prepare($id_record).', '.prepare($contenuto).', '.prepare($nome).', NOW())';
- $dbo->query($query);
-
- $idcomponente = $dbo->lastInsertedID();
- $_SESSION['idcomponente'] = $idcomponente;
-
- flash()->info(tr("Aggiunto un nuovo componente all'impianto!"));
- }
- break;
-
- case 'sostituzione_componente':
- $filename = get('filename');
- $id = get('id');
-
- $nome = Ini::getValue(Ini::readFile(base_dir().'/files/impianti/'.$filename), 'Nome');
- $contenuto = file_get_contents(base_dir().'/files/impianti/'.$filename);
-
- // Verifico che questo componente non sia già stato sostituito
- $query = 'SELECT * FROM my_impianto_componenti WHERE idsostituto = '.prepare($id);
- $rs = $dbo->fetchArray($query);
-
- if (empty($rs)) {
- // Inserisco il nuovo componente in sostituzione
- $query = 'INSERT INTO my_impianto_componenti(idsostituto, filename, idimpianto, contenuto, nome, data) VALUES('.prepare($id).', '.prepare($filename).', '.prepare($id_record).', '.prepare($contenuto).', '.prepare($nome).', NOW())';
- $dbo->query($query);
-
- $idcomponente = $dbo->lastInsertedID();
- $_SESSION['idcomponente'] = $idcomponente;
-
- // Aggiorno la data di sostituzione del componente precedente
- $query = 'UPDATE my_impianto_componenti SET data_sostituzione = NOW() WHERE idimpianto = '.prepare($id_record).' AND id = '.prepare($id);
- $dbo->query($query);
-
- flash()->info(tr('Aggiunto un nuovo componente in sostituzione al precedente!'));
- } else {
- flash()->error(tr('Questo componente è già stato sostituito!').' '.('Nessuna modifica applicata'));
- }
- break;
-
- case 'unaggiunta_componente':
- $idcomponente = filter('id');
-
- $query = 'DELETE FROM my_impianto_componenti WHERE id='.prepare($idcomponente).' AND idimpianto='.prepare($id_record);
- $dbo->query($query);
-
- flash()->info(tr("Rimosso componente dall'impianto!"));
- break;
-}
-
-// Componenti non ancora collegati
-if (empty($id_list)) {
- $id_list = '0';
-}
-
-echo '
-
-
-
- ';
-
-// Mostro tutti i componenti utilizzati elencando quelli attualmente installati per primi.
-$q2 = 'SELECT * FROM my_impianto_componenti WHERE idimpianto = '.prepare($id_record).' ORDER by nome ASC, idsostituto DESC';
-$componenti_installati = $dbo->fetchArray($q2);
-
-if (!empty($componenti_installati)) {
- $prev_componente = '';
-
- echo '
-
';
-
- // Ciclo tra tutti i componenti
- foreach ($componenti_installati as $componente) {
- $contenuto = $componente['contenuto'];
-
- $nome_componente = $componente['nome'];
- $filename = $componente['filename'];
-
- if (empty($componente['data_sostituzione'])) {
- $stato_componente = tr('INSTALLATO in data _DATE_', [
- '_DATE_' => dateFormat($componente['data']),
- ]);
- } else {
- $stato_componente = tr('SOSTITUITO in data _DATE_', [
- '_DATE_' => dateFormat($componente['data_sostituzione']),
- ]);
- }
-
- // Per più "versioni" dello stesso componente mostro un riga meno evidente
- // per non confonderlo come componente in uso in questo momento
- $same = ($prev_componente == $nome_componente);
-
- if (get('id') == $componente['id']) {
- $collapsed = '';
- $icon = 'minus';
- } elseif ($_SESSION['idcomponente'] == $componente['id']) {
- unset($_SESSION['idcomponente']);
- $collapsed = '';
- $icon = 'minus';
- } else {
- $collapsed = 'collapsed-box';
- $icon = 'plus';
- }
-
- echo '
-
-
-';
diff --git a/modules/impianti/plugins/my_impianti.interventi.php b/modules/impianti/plugins/my_impianti.interventi.php
index 93aedaae5..89ca3a1d4 100644
--- a/modules/impianti/plugins/my_impianti.interventi.php
+++ b/modules/impianti/plugins/my_impianti.interventi.php
@@ -23,7 +23,7 @@ $matricole = (array) post('matricole');
// Salvo gli impianti selezionati
if (filter('op') == 'link_impianti') {
- $matricole_old = $dbo->fetchArray('SELECT * FROM my_impianti_interventi WHERE idintervento='.prepare($id_record));
+ $matricole_old = $dbo->fetchArray('SELECT * FROM my_impianti_interventi WHERE idintervento = '.prepare($id_record));
$matricole_old = array_column($matricole_old, 'idimpianto');
// Individuazione delle matricole mancanti
@@ -31,7 +31,7 @@ if (filter('op') == 'link_impianti') {
if (!in_array($matricola, $matricole)) {
$dbo->query('DELETE FROM my_impianti_interventi WHERE idintervento='.prepare($id_record).' AND idimpianto = '.prepare($matricola));
- $components = $dbo->fetchArray('SELECT * FROM my_impianto_componenti WHERE idimpianto = '.prepare($matricola));
+ $components = $dbo->fetchArray('SELECT * FROM my_componenti WHERE id_impianto = '.prepare($matricola));
if (!empty($components)) {
foreach ($components as $component) {
$dbo->query('DELETE FROM my_componenti_interventi WHERE id_componente = '.prepare($component['id']).' AND id_intervento = '.prepare($id_record));
@@ -51,7 +51,7 @@ if (filter('op') == 'link_impianti') {
$components = (array) post('componenti');
$id_impianto = post('id_impianto');
- $dbo->query('DELETE FROM my_componenti_interventi WHERE id_componente IN (SELECT id FROM my_impianto_componenti WHERE idimpianto = '.prepare($id_impianto).') AND id_intervento = '.prepare($id_record));
+ $dbo->query('DELETE FROM my_componenti_interventi WHERE id_componente IN (SELECT id FROM my_componenti WHERE id_impianto = '.prepare($id_impianto).') AND id_intervento = '.prepare($id_record));
foreach ($components as $component) {
$dbo->query('INSERT INTO my_componenti_interventi(id_componente, id_intervento) VALUES ('.prepare($component).', '.prepare($id_record).')');
@@ -87,13 +87,13 @@ echo '
';
foreach ($impianti_collegati as $impianto) {
echo '
-
+
';
// MATRICOLA
echo '
-
'.tr('Matricola').':
+
'.tr('Matricola').':
'.$impianto['matricola'].'
';
@@ -135,7 +135,9 @@ foreach ($impianti_collegati as $impianto) {
{[ "type": "select", "label": "'.tr('Componenti').'", "multiple": 1, "name": "componenti[]", "id": "componenti_'.$impianto['id'].'", "ajax-source": "componenti", "select-options": {"matricola": '.$impianto['id'].'}, "value": "'.implode(',', $ids).'", "readonly": "'.!empty($readonly).'", "disabled": "'.!empty($disabled).'" ]}
-
+
diff --git a/modules/interventi/actions.php b/modules/interventi/actions.php
index aca18cec5..829bac224 100644
--- a/modules/interventi/actions.php
+++ b/modules/interventi/actions.php
@@ -23,6 +23,7 @@ use Modules\Anagrafiche\Anagrafica;
use Modules\Articoli\Articolo as ArticoloOriginale;
use Modules\Emails\Mail;
use Modules\Emails\Template;
+use Modules\Impianti\Impianto;
use Modules\Interventi\Components\Articolo;
use Modules\Interventi\Components\Riga;
use Modules\Interventi\Components\Sconto;
@@ -30,6 +31,7 @@ use Modules\Interventi\Components\Sessione;
use Modules\Interventi\Intervento;
use Modules\Interventi\Stato;
use Modules\TipiIntervento\Tipo as TipoSessione;
+use Plugins\ComponentiImpianti\Componente;
use Plugins\PianificazioneInterventi\Promemoria;
switch (post('op')) {
@@ -228,7 +230,7 @@ switch (post('op')) {
$intervento->delete();
// Elimino il collegamento al componente
- $dbo->query('DELETE FROM my_impianto_componenti WHERE idintervento='.prepare($id_record));
+ $dbo->query('DELETE FROM my_componenti WHERE idintervento='.prepare($id_record));
// Eliminazione associazione tecnici collegati all'intervento
$dbo->query('DELETE FROM in_interventi_tecnici WHERE idintervento='.prepare($id_record));
@@ -331,8 +333,18 @@ switch (post('op')) {
flash()->info(tr('Articolo aggiunto!'));
}
- // Collegamento all'impianto
- link_componente_to_articolo($id_record, post('idimpianto'), $articolo->idarticolo, $qta);
+ // Collegamento all'Impianto tramite generazione Componente
+ $id_impianto = post('id_impianto');
+ $impianto = Impianto::find($id_impianto);
+ if (!empty($impianto)){
+ // Data di inizio dell'intervento (data_richiesta in caso di assenza di sessioni)
+ $data_registrazione = $intervento->inizio ?: $intervento->data_richiesta;
+
+ // Creazione in base alla quantità
+ for ($q = 0; $q < $articolo->qta; ++$q) {
+ $componente = Componente::build($impianto, $articolo->articolo, $data_registrazione);
+ }
+ }
break;
diff --git a/modules/interventi/modutil.php b/modules/interventi/modutil.php
index e6afbe9d8..288f9e802 100755
--- a/modules/interventi/modutil.php
+++ b/modules/interventi/modutil.php
@@ -52,6 +52,8 @@ function get_ore_intervento($id_intervento)
* @param int $id_impianto
* @param int $id_articolo
* @param int $qta
+ *
+ * @deprecated 2.4.25
*/
function link_componente_to_articolo($id_intervento, $id_impianto, $id_articolo, $qta)
{
diff --git a/modules/interventi/plugins/my_impianti.interventi.php b/modules/interventi/plugins/my_impianti.interventi.php
index 05160a8df..2f5b5300a 100755
--- a/modules/interventi/plugins/my_impianti.interventi.php
+++ b/modules/interventi/plugins/my_impianti.interventi.php
@@ -68,7 +68,9 @@ if (!empty($results)) {
';
} else {
echo '
-
'.tr('Nessun intervento su questo impianto').'.
';
+
+ '.tr('Nessun intervento su questo impianto').'.
+