mirror of
https://github.com/devcode-it/openstamanager.git
synced 2025-02-23 23:07:46 +01:00
Migliorato modulo per gestire i tipi delle scadenze
This commit is contained in:
parent
79abc7e6af
commit
8316fa72cc
@ -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');
|
||||
}
|
||||
|
@ -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',
|
||||
]));
|
||||
|
@ -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);
|
||||
|
@ -1,7 +1,17 @@
|
||||
<?php
|
||||
include_once __DIR__.'/../../core.php';
|
||||
|
||||
?><form action="" method="post" id="edit-form">
|
||||
// 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 '<div class="alert alert-warning">'.tr('Alcune impostazioni non possono essere modificate per questo tipo di scadenza.').'</div>';
|
||||
}
|
||||
?>
|
||||
<form action="" method="post" id="edit-form">
|
||||
<input type="hidden" name="backto" value="record-edit">
|
||||
<input type="hidden" name="op" value="update">
|
||||
|
||||
@ -15,16 +25,13 @@ include_once __DIR__.'/../../core.php';
|
||||
<div class="row">
|
||||
|
||||
<div class="col-md-3">
|
||||
{[ "type": "text", "label": "<?php echo tr('Nome'); ?>", "name": "nome", "required": 1, "value": "$nome$" ]}
|
||||
{[ "type": "text", "label": "<?php echo tr('Nome'); ?>", "name": "nome", "required": 1, "value": "$nome$", "extra": "<?php echo $attr; ?>" ]}
|
||||
</div>
|
||||
|
||||
<div class="col-md-6">
|
||||
{[ "type": "text", "label": "<?php echo tr('Descrizione'); ?>", "name": "descrizione", "required": 1, "value": "$descrizione$" ]}
|
||||
</div>
|
||||
|
||||
<div class="col-md-3">
|
||||
{[ "type": "checkbox", "label": "<?php echo tr('Causale predefinita'); ?>", "name": "predefined", "value": "$predefined$", "help":"<?php echo tr('Scadenza di sistema, impossibile modificare'); ?>." ]}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
@ -33,19 +40,23 @@ include_once __DIR__.'/../../core.php';
|
||||
|
||||
<?php
|
||||
|
||||
// Collegamenti diretti (numerici)
|
||||
$scadenze = $dbo->fetchNum('SELECT id FROM co_scadenziario WHERE tipo = '.prepare($record['nome']));
|
||||
if ($record['can_delete']){
|
||||
|
||||
if (!empty($scadenze)) {
|
||||
echo '
|
||||
<div class="alert alert-danger">
|
||||
'.tr('Ci sono _NUM_ scadenze collegate', [
|
||||
'_NUM_' => count($scadenze),
|
||||
]).'.
|
||||
</div>';
|
||||
|
||||
if (!empty($scadenze)) {
|
||||
echo '
|
||||
<div class="alert alert-danger">
|
||||
'.tr('Ci sono _NUM_ scadenze collegate', [
|
||||
'_NUM_' => count($scadenze),
|
||||
]).'.
|
||||
</div>';
|
||||
}
|
||||
?>
|
||||
|
||||
<a class="btn btn-danger ask" data-backto="record-list">
|
||||
<i class="fa fa-trash"></i> <?php echo tr('Elimina'); ?>
|
||||
</a>
|
||||
|
||||
<?php
|
||||
}
|
||||
?>
|
||||
|
||||
<a class="btn btn-danger ask" data-backto="record-list">
|
||||
<i class="fa fa-trash"></i> <?php echo tr('Elimina'); ?>
|
||||
</a>
|
||||
?>
|
@ -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));
|
||||
}
|
||||
|
@ -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);
|
Loading…
x
Reference in New Issue
Block a user