diff --git a/modules/anagrafiche/actions.php b/modules/anagrafiche/actions.php index c4ae36194..a122af858 100644 --- a/modules/anagrafiche/actions.php +++ b/modules/anagrafiche/actions.php @@ -76,14 +76,20 @@ switch (post('op')) { $anagrafica->tipologie = (array) post('idtipoanagrafica'); - // Blocco il salvataggio del codice fiscale se già presente + // Avviso durante il salvataggio del codice fiscale se già presente e informo l'utente delle schede presenti if (!empty(post('codice_fiscale'))) { - $count_cf = $dbo->fetchNum('SELECT codice_fiscale FROM an_anagrafiche WHERE codice_fiscale = '.prepare(post('codice_fiscale')).' AND idanagrafica != '.prepare($id_record)); + $idanagrafica = $dbo->fetchOne('SELECT GROUP_CONCAT(idanagrafica) AS idanagrafica FROM an_anagrafiche WHERE codice_fiscale = '.prepare(post('codice_fiscale')).' AND idanagrafica != '.prepare($id_record))['idanagrafica']; + + if (!empty($idanagrafica)) { + + $array = explode(',', $idanagrafica); + foreach($array as &$value) { + flash()->warning(tr('Attenzione: il codice fiscale _COD_ è già stato censito _LINK_', [ + '_COD_' => post('codice_fiscale'), + '_LINK_' => Modules::link('Anagrafiche', $value, null, null, ''), + ])); + } - if ($count_cf > 0) { - flash()->warning(tr('Attenzione: il codice fiscale _COD_ è già stato censito', [ - '_COD_' => post('codice_fiscale'), - ])); } else { $anagrafica->codice_fiscale = post('codice_fiscale'); } @@ -91,14 +97,19 @@ switch (post('op')) { $anagrafica->codice_fiscale = post('codice_fiscale'); } - // Blocco il salvataggio della partita iva se già presente + // Avviso durante il salvataggio della partita iva se già presente e informo l'utente delle schede presenti if (!empty(post('piva'))) { - $count_piva = $dbo->fetchNum('SELECT piva FROM an_anagrafiche WHERE piva = '.prepare(post('piva')).' AND idanagrafica != '.prepare($id_record)); + $idanagrafica = $dbo->fetchOne('SELECT GROUP_CONCAT(idanagrafica) AS idanagrafica FROM an_anagrafiche WHERE piva = '.prepare(post('piva')).' AND idanagrafica != '.prepare($id_record))['idanagrafica']; + + if (!empty($idanagrafica)) { + $array = explode(',', $idanagrafica); + foreach($array as &$value) { + flash()->warning(tr('Attenzione: la partita IVA _IVA_ è già stata censita _LINK_', [ + '_IVA_' => post('piva'), + '_LINK_' => Modules::link('Anagrafiche', $value, null, null, ''), + ])); + } - if ($count_piva > 0) { - flash()->warning(tr('Attenzione: la partita IVA _IVA_ è già stata censita', [ - '_IVA_' => post('piva'), - ])); } else { $anagrafica->partita_iva = post('piva'); } diff --git a/modules/tipi_scadenze/actions.php b/modules/tipi_scadenze/actions.php index d824d6ec8..5d01f62c9 100644 --- a/modules/tipi_scadenze/actions.php +++ b/modules/tipi_scadenze/actions.php @@ -8,22 +8,33 @@ switch (filter('op')) { $nome = filter('nome'); if (isset($nome)) { - if ($dbo->fetchNum('SELECT * FROM `co_tipiscadenze` WHERE `nome`='.prepare($nome).' AND `id`!='.prepare($id_record)) == 0) { - $predefined = post('predefined'); - if (!empty($predefined)) { - $dbo->query('UPDATE co_tipiscadenze SET predefined = 0'); - } - $dbo->update('co_tipiscadenze', [ + //Se non esiste già una tipo di scadenza con lo stesso nome + if ($dbo->fetchNum('SELECT * FROM `co_tipi_scadenze` WHERE `nome`='.prepare($nome).' AND `id`!='.prepare($id_record)) == 0) { + + //nome_prev + $nome_prev = $dbo->fetchOne('SELECT nome AS nome_prev FROM `co_tipi_scadenze` WHERE `id`='.prepare($id_record))['nome_prev']; + + $dbo->update('co_tipi_scadenze', [ 'nome' => $nome, 'descrizione' => $descrizione, - 'predefined' => $predefined, ], ['id' => $id_record]); + //aggiorno anche il segmento + $dbo->update('zz_segments', [ + 'clause' => 'co_scadenziario.tipo="'.$nome.'"', + 'name' => 'Scadenzario '.$nome, + ], [ + 'clause' => 'co_scadenziario.tipo="'.$nome_prev.'"', + 'name' => 'Scadenzario '.$nome_prev, + 'id_module' => Modules::get('Scadenzario')['id'], + ]); + flash()->info(tr('Salvataggio completato!')); } else { - flash()->error(tr("E' già presente una tipologia di _TYPE_ con lo stesso nome", [ + flash()->error(tr("E' già presente una tipologia di _TYPE_ con nome: _NOME_", [ '_TYPE_' => 'scadenza', + '_NOME_' => $nome, ])); } } else { @@ -36,13 +47,23 @@ switch (filter('op')) { $descrizione = filter('descrizione'); $nome = filter('nome'); - if (isset($descrizione)) { - if ($dbo->fetchNum('SELECT * FROM `co_tipiscadenze` WHERE `nome`='.prepare($nome)) == 0) { - $dbo->insert('co_tipiscadenze', [ + if (isset($nome)) { + //Se non esiste già un tipo di scadenza con lo stesso nome + if ($dbo->fetchNum('SELECT * FROM `co_tipi_scadenze` WHERE `nome`='.prepare($nome)) == 0) { + $dbo->insert('co_tipi_scadenze', [ 'nome' => $nome, 'descrizione' => $descrizione, ]); $id_record = $dbo->lastInsertedID(); + + //Aggiungo anche il segmento + $dbo->insert('zz_segments', [ + 'id_module' => Modules::get('Scadenzario')['id'], + 'name' => 'Scadenzario '.$nome, + 'clause' => 'co_scadenziario.tipo="'.$nome.'"', + 'position' => 'WHR' + ]); + if (isAjaxRequest()) { echo json_encode(['id' => $nome, 'text' => $descrizione]); @@ -52,8 +73,9 @@ switch (filter('op')) { '_TYPE_' => 'scadenza', ])); } else { - flash()->error(tr("E' già presente una tipologia di _TYPE_ con lo stesso nome", [ + flash()->error(tr("E' già presente una tipologia di _TYPE_ con nome: _NOME_", [ '_TYPE_' => 'scadenza', + '_NOME_' => $nome, ])); } } else { @@ -64,10 +86,10 @@ switch (filter('op')) { case 'delete': - $documenti = $dbo->fetchNum('SELECT id FROM co_scadenziario WHERE tipo = (SELECT nome FROM co_tipiscadenze WHERE id = '.prepare($id_record).')'); + $documenti = $dbo->fetchNum('SELECT id FROM co_scadenziario WHERE tipo = (SELECT nome FROM co_tipi_scadenze WHERE id = '.prepare($id_record).')'); if (isset($id_record) && empty($documenti)) { - $dbo->query('DELETE FROM `co_tipiscadenze` WHERE `id`='.prepare($id_record)); + $dbo->query('DELETE FROM `co_tipi_scadenze` WHERE `can_delete` = 1 AND `id`='.prepare($id_record)); flash()->info(tr('Tipologia di _TYPE_ eliminata con successo.', [ '_TYPE_' => 'scadenza', ])); diff --git a/modules/tipi_scadenze/ajax/select.php b/modules/tipi_scadenze/ajax/select.php index d70dfdd13..98b4917aa 100644 --- a/modules/tipi_scadenze/ajax/select.php +++ b/modules/tipi_scadenze/ajax/select.php @@ -4,7 +4,7 @@ include_once __DIR__.'/../../../core.php'; switch ($resource) { case 'tipi_scadenze': - $query = 'SELECT nome AS id, descrizione FROM co_tipiscadenze |where| ORDER BY nome ASC'; + $query = 'SELECT nome AS id, descrizione FROM co_tipi_scadenze |where| ORDER BY nome ASC'; foreach ($elements as $element) { $filter[] = 'id='.prepare($element); diff --git a/modules/tipi_scadenze/edit.php b/modules/tipi_scadenze/edit.php index ff2d5b5f2..d2feb177d 100644 --- a/modules/tipi_scadenze/edit.php +++ b/modules/tipi_scadenze/edit.php @@ -1,7 +1,17 @@
+// Collegamenti con scadenzaio (numerici) +$scadenze = $dbo->fetchNum('SELECT id FROM co_scadenziario WHERE tipo = '.prepare($record['nome'])); + +if ($record['can_delete'] and empty($scadenze)) { + $attr = ''; +} else { + $attr = 'readonly'; + echo '
'.tr('Alcune impostazioni non possono essere modificate per questo tipo di scadenza.').'
'; +} +?> + @@ -15,16 +25,13 @@ include_once __DIR__.'/../../core.php';
- {[ "type": "text", "label": "", "name": "nome", "required": 1, "value": "$nome$" ]} + {[ "type": "text", "label": "", "name": "nome", "required": 1, "value": "$nome$", "extra": "" ]}
{[ "type": "text", "label": "", "name": "descrizione", "required": 1, "value": "$descrizione$" ]}
-
- {[ "type": "checkbox", "label": "", "name": "predefined", "value": "$predefined$", "help":"." ]} -
@@ -33,19 +40,23 @@ include_once __DIR__.'/../../core.php'; fetchNum('SELECT id FROM co_scadenziario WHERE tipo = '.prepare($record['nome'])); +if ($record['can_delete']){ -if (!empty($scadenze)) { - echo ' -
- '.tr('Ci sono _NUM_ scadenze collegate', [ - '_NUM_' => count($scadenze), - ]).'. -
'; + + if (!empty($scadenze)) { + echo ' +
+ '.tr('Ci sono _NUM_ scadenze collegate', [ + '_NUM_' => count($scadenze), + ]).'. +
'; + } + ?> + + + + + + - - - - +?> \ No newline at end of file diff --git a/modules/tipi_scadenze/init.php b/modules/tipi_scadenze/init.php index fdf322df6..c0bdf6d32 100644 --- a/modules/tipi_scadenze/init.php +++ b/modules/tipi_scadenze/init.php @@ -3,5 +3,5 @@ include_once __DIR__.'/../../core.php'; if (isset($id_record)) { - $record = $dbo->fetchOne('SELECT * FROM `co_tipiscadenze` WHERE id='.prepare($id_record)); + $record = $dbo->fetchOne('SELECT * FROM `co_tipi_scadenze` WHERE id='.prepare($id_record)); } diff --git a/update/2_4_10.sql b/update/2_4_10.sql index e94ae6ccc..d4e7049e2 100644 --- a/update/2_4_10.sql +++ b/update/2_4_10.sql @@ -112,24 +112,23 @@ UPDATE `co_movimenti_modelli` SET `nome` = `descrizione` WHERE `nome` = ''; -- Rimuovo le interruzioni di riga per descrizioni vuote --UPDATE `in_interventi` SET `descrizione` = REPLACE(`descrizione`, '\n', '') where `descrizione` LIKE '%\n'; --- Aggiunto tabella co_tipiscadenze -CREATE TABLE `co_tipiscadenze` ( +-- Aggiunto tabella co_tipi_scadenze +CREATE TABLE `co_tipi_scadenze` ( `id` int(11) NOT NULL AUTO_INCREMENT, `nome` varchar(255) NOT NULL, `descrizione` varchar(255) NOT NULL, - `predefined` tinyint(1) NOT NULL DEFAULT '0', + `can_delete` tinyint(1) NOT NULL DEFAULT '1', PRIMARY KEY (`id`) ) ENGINE=InnoDB; -INSERT INTO `co_tipiscadenze` (`id`, `nome`, `descrizione`, `predefined`) VALUES -(1, 'f24', 'F24', 1), -(2, 'generico', 'Scadenze generiche', 1); +INSERT INTO `co_tipi_scadenze` (`id`, `nome`, `descrizione`, `can_delete`) VALUES +(1, 'f24', 'F24', 0), +(2, 'generico', 'Scadenze generiche', 0); -- Aggiunto modulo per gestire i tipi di scadenze -INSERT INTO `zz_modules` (`id`, `name`, `title`, `directory`, `options`, `options2`, `icon`, `version`, `compatibility`, `order`, `parent`, `default`, `enabled`) VALUES (NULL, 'Tipi scadenze', 'Tipi scadenze', 'tipi_scadenze', 'SELECT |select| FROM `co_tipiscadenze` WHERE 1=1 HAVING 2=2', '', 'fa fa-calendar', '2.4.10', '2.4.10', '1', (SELECT `id` FROM `zz_modules` t WHERE t.`name` = 'Tabelle'), '1', '1'; +INSERT INTO `zz_modules` (`id`, `name`, `title`, `directory`, `options`, `options2`, `icon`, `version`, `compatibility`, `order`, `parent`, `default`, `enabled`) VALUES (NULL, 'Tipi scadenze', 'Tipi scadenze', 'tipi_scadenze', 'SELECT |select| FROM `co_tipi_scadenze` WHERE 1=1 HAVING 2=2', '', 'fa fa-calendar', '2.4.10', '2.4.10', '1', (SELECT `id` FROM `zz_modules` t WHERE t.`name` = 'Tabelle'), '1', '1'; INSERT INTO `zz_views` (`id_module`, `name`, `query`, `order`, `search`, `slow`, `default`) VALUES -((SELECT `id` FROM `zz_modules` WHERE `name` = 'Tipi scadenze'), 'Predefinita', 'predefined', 4, 1, 0, 0), ((SELECT `id` FROM `zz_modules` WHERE `name` = 'Tipi scadenze'), 'Descrizione', 'descrizione', 3, 1, 0, 0), ((SELECT `id` FROM `zz_modules` WHERE `name` = 'Tipi scadenze'), 'Nome', 'nome', 2, 1, 0, 0), ((SELECT `id` FROM `zz_modules` WHERE `name` = 'Tipi scadenze'), 'id', 'id', 1, 1, 0, 0); \ No newline at end of file