mirror of
https://github.com/devcode-it/openstamanager.git
synced 2025-06-05 22:09:38 +02:00
Controlli su scheda anagrafica
Se l'anagrafica è stata eliminata disabilito anche i relativi utenti. Blocco tutti i campi e mostro messaggio eliminazione.
This commit is contained in:
@@ -265,8 +265,14 @@ switch (post('op')) {
|
|||||||
if (!str_contains($records[0]['idtipianagrafica'], $id_azienda)) {
|
if (!str_contains($records[0]['idtipianagrafica'], $id_azienda)) {
|
||||||
$dbo->query('UPDATE an_anagrafiche SET deleted = 1 WHERE idanagrafica = '.prepare($id_record).Modules::getAdditionalsQuery($id_module));
|
$dbo->query('UPDATE an_anagrafiche SET deleted = 1 WHERE idanagrafica = '.prepare($id_record).Modules::getAdditionalsQuery($id_module));
|
||||||
|
|
||||||
|
// Se l'anagrafica è collegata ad un utente lo disabilito
|
||||||
|
$dbo->query('UPDATE zz_users SET enabled = 0 WHERE idanagrafica = '.prepare($id_record).Modules::getAdditionalsQuery($id_module));
|
||||||
|
|
||||||
|
|
||||||
$_SESSION['infos'][] = tr('Anagrafica eliminata!');
|
$_SESSION['infos'][] = tr('Anagrafica eliminata!');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@@ -24,7 +24,9 @@ if (!$cliente) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
?>
|
?>
|
||||||
<form action="" method="post" id="edit-form">
|
|
||||||
|
<form action="" method="post" id="edit-form" >
|
||||||
|
<fieldset <?php echo (!$records[0]['deleted']) ? '' : 'disabled'; ?> >
|
||||||
<input type="hidden" name="backto" value="record-edit">
|
<input type="hidden" name="backto" value="record-edit">
|
||||||
<input type="hidden" name="op" value="update">
|
<input type="hidden" name="op" value="update">
|
||||||
|
|
||||||
@@ -152,9 +154,9 @@ if (!$cliente) {
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
if ($cliente || $fornitore) {
|
if ($cliente || $fornitore) {
|
||||||
?>
|
?>
|
||||||
|
|
||||||
|
|
||||||
@@ -236,9 +238,9 @@ if ($cliente || $fornitore) {
|
|||||||
</div>
|
</div>
|
||||||
<div class="clearfix" ></div>
|
<div class="clearfix" ></div>
|
||||||
|
|
||||||
<?php
|
<?php
|
||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
|
|
||||||
<div class="panel panel-primary">
|
<div class="panel panel-primary">
|
||||||
<div class="panel-heading">
|
<div class="panel-heading">
|
||||||
@@ -419,31 +421,37 @@ if (!empty($google)) {
|
|||||||
?>
|
?>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
</fieldset>
|
||||||
</form>
|
</form>
|
||||||
|
|
||||||
{( "name": "filelist_and_upload", "id_module": "<?php echo $id_module; ?>", "id_record": "<?php echo $id_record; ?>" )}
|
{( "name": "filelist_and_upload", "id_module": "<?php echo $id_module; ?>", "id_record": "<?php echo $id_record; ?>" )}
|
||||||
|
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
//fatture, ddt, preventivi, contratti, ordini, interventi collegati a questa anagrafica
|
if (!$records[0]['deleted']){
|
||||||
$elementi = $dbo->fetchArray('SELECT `co_documenti`.`id`, `co_documenti`.`data`, `co_documenti`.`numero`, `co_documenti`.`numero_esterno`, `co_tipidocumento`.`descrizione` AS tipo_documento, `co_tipidocumento`.`dir` FROM `co_documenti` JOIN `co_tipidocumento` ON `co_tipidocumento`.`id` = `co_documenti`.`idtipodocumento` WHERE `co_documenti`.`id` IN (SELECT `iddocumento` FROM `co_righe_documenti` WHERE `idanagrafica` = '.prepare($id_record).')
|
|
||||||
|
//fatture, ddt, preventivi, contratti, ordini, interventi, utenti collegati a questa anagrafica
|
||||||
|
$elementi = $dbo->fetchArray('SELECT `co_documenti`.`id`, `co_documenti`.`data`, `co_documenti`.`numero`, `co_documenti`.`numero_esterno`, `co_tipidocumento`.`descrizione` AS tipo_documento, `co_tipidocumento`.`dir` FROM `co_documenti` JOIN `co_tipidocumento` ON `co_tipidocumento`.`id` = `co_documenti`.`idtipodocumento` WHERE `co_documenti`.`id` IN (SELECT `iddocumento` FROM `co_righe_documenti` WHERE `idanagrafica` = '.prepare($id_record).')
|
||||||
|
|
||||||
UNION
|
UNION
|
||||||
SELECT `or_ordini`.`id`, `or_ordini`.`data`, `or_ordini`.`numero`, `or_ordini`.`numero_esterno`, `or_tipiordine`.`descrizione` AS tipo_documento, `or_tipiordine`.`dir` FROM `or_ordini` JOIN `or_tipiordine` ON `or_tipiordine`.`id` = `or_ordini`.`idtipoordine` WHERE `or_ordini`.`idanagrafica` = '.prepare($id_record).'
|
SELECT `zz_users`.`id`, `zz_users`.`created_at` AS data, `zz_users`.`username` AS numero, 0 AS `numero_esterno`, "Utente" AS tipo_documento, 0 AS `dir` FROM `zz_users` WHERE `zz_users`.`idanagrafica` = '.prepare($id_record).'
|
||||||
|
|
||||||
UNION
|
UNION
|
||||||
SELECT `dt_ddt`.`id`, `dt_ddt`.`data`, `dt_ddt`.`numero`, `dt_ddt`.`numero_esterno`, `dt_tipiddt`.`descrizione` AS tipo_documento, `dt_tipiddt`.`dir` FROM `dt_ddt` JOIN `dt_tipiddt` ON `dt_tipiddt`.`id` = `dt_ddt`.`idtipoddt` WHERE `dt_ddt`.`idanagrafica` = '.prepare($id_record).'
|
SELECT `or_ordini`.`id`, `or_ordini`.`data`, `or_ordini`.`numero`, `or_ordini`.`numero_esterno`, `or_tipiordine`.`descrizione` AS tipo_documento, `or_tipiordine`.`dir` FROM `or_ordini` JOIN `or_tipiordine` ON `or_tipiordine`.`id` = `or_ordini`.`idtipoordine` WHERE `or_ordini`.`idanagrafica` = '.prepare($id_record).'
|
||||||
|
|
||||||
UNION
|
UNION
|
||||||
SELECT `in_interventi`.`id`, `in_interventi`.`data_richiesta`, `in_interventi`.`codice` AS numero, 0 AS numero_esterno, "Intervento" AS tipo_documento, 0 AS dir FROM `in_interventi` JOIN `in_interventi_tecnici` ON `in_interventi`.`id` = `in_interventi_tecnici`.`idintervento` WHERE `in_interventi`.`id` IN (SELECT `idintervento` FROM `in_interventi_tecnici` WHERE `idtecnico` = '.prepare($id_record).' OR `in_interventi`.`idanagrafica` = '.prepare($id_record).' )
|
SELECT `dt_ddt`.`id`, `dt_ddt`.`data`, `dt_ddt`.`numero`, `dt_ddt`.`numero_esterno`, `dt_tipiddt`.`descrizione` AS tipo_documento, `dt_tipiddt`.`dir` FROM `dt_ddt` JOIN `dt_tipiddt` ON `dt_tipiddt`.`id` = `dt_ddt`.`idtipoddt` WHERE `dt_ddt`.`idanagrafica` = '.prepare($id_record).'
|
||||||
|
|
||||||
UNION
|
UNION
|
||||||
SELECT `co_contratti`.`id`, `co_contratti`.`data_bozza`, `co_contratti`.`numero`, 0 AS numero_esterno , "Contratto" AS tipo_documento, 0 AS dir FROM `co_contratti` WHERE `co_contratti`.`id` IN (SELECT `idcontratto` FROM `co_righe_contratti` WHERE `idanagrafica` = '.prepare($id_record).')
|
SELECT `in_interventi`.`id`, `in_interventi`.`data_richiesta`, `in_interventi`.`codice` AS numero, 0 AS numero_esterno, "Intervento" AS tipo_documento, 0 AS dir FROM `in_interventi` JOIN `in_interventi_tecnici` ON `in_interventi`.`id` = `in_interventi_tecnici`.`idintervento` WHERE `in_interventi`.`id` IN (SELECT `idintervento` FROM `in_interventi_tecnici` WHERE `idtecnico` = '.prepare($id_record).' OR `in_interventi`.`idanagrafica` = '.prepare($id_record).' )
|
||||||
|
|
||||||
UNION
|
UNION
|
||||||
SELECT `co_preventivi`.`id`, `co_preventivi`.`data_bozza`, `co_preventivi`.`numero`, 0 AS numero_esterno , "Preventivo" AS tipo_documento, 0 AS dir FROM `co_preventivi` WHERE `co_preventivi`.`id` IN (SELECT `idpreventivo` FROM `co_righe_preventivi` WHERE `idanagrafica` = '.prepare($id_record).') ORDER BY `data`');
|
SELECT `co_contratti`.`id`, `co_contratti`.`data_bozza`, `co_contratti`.`numero`, 0 AS numero_esterno , "Contratto" AS tipo_documento, 0 AS dir FROM `co_contratti` WHERE `co_contratti`.`id` IN (SELECT `idcontratto` FROM `co_righe_contratti` WHERE `idanagrafica` = '.prepare($id_record).')
|
||||||
|
|
||||||
if (!empty($elementi)) {
|
UNION
|
||||||
|
SELECT `co_preventivi`.`id`, `co_preventivi`.`data_bozza`, `co_preventivi`.`numero`, 0 AS numero_esterno , "Preventivo" AS tipo_documento, 0 AS dir FROM `co_preventivi` WHERE `co_preventivi`.`id` IN (SELECT `idpreventivo` FROM `co_righe_preventivi` WHERE `idanagrafica` = '.prepare($id_record).') ORDER BY `data`');
|
||||||
|
|
||||||
|
if (!empty($elementi)) {
|
||||||
echo '
|
echo '
|
||||||
<div class="alert alert-warning">
|
<div class="alert alert-warning">
|
||||||
<p>'.tr('_NUM_ altr_I_ document_I_ collegat_I_', [
|
<p>'.tr('_NUM_ altr_I_ document_I_ collegat_I_', [
|
||||||
@@ -453,7 +461,7 @@ if (!empty($elementi)) {
|
|||||||
<ul>';
|
<ul>';
|
||||||
|
|
||||||
foreach ($elementi as $elemento) {
|
foreach ($elementi as $elemento) {
|
||||||
$descrizione = tr('_DOC_ num. _NUM_ del _DATE_', [
|
$descrizione = tr('_DOC_ _NUM_ del _DATE_', [
|
||||||
'_DOC_' => $elemento['tipo_documento'],
|
'_DOC_' => $elemento['tipo_documento'],
|
||||||
'_NUM_' => !empty($elemento['numero_esterno']) ? $elemento['numero_esterno'] : $elemento['numero'],
|
'_NUM_' => !empty($elemento['numero_esterno']) ? $elemento['numero_esterno'] : $elemento['numero'],
|
||||||
'_DATE_' => Translator::dateToLocale($elemento['data']),
|
'_DATE_' => Translator::dateToLocale($elemento['data']),
|
||||||
@@ -461,7 +469,10 @@ if (!empty($elementi)) {
|
|||||||
|
|
||||||
//se non è un preventivo è un ddt o una fattura
|
//se non è un preventivo è un ddt o una fattura
|
||||||
//se non è un ddt è una fattura.
|
//se non è un ddt è una fattura.
|
||||||
if (in_array($elemento['tipo_documento'], ['Intervento'])) {
|
if (in_array($elemento['tipo_documento'], ['Utente'])) {
|
||||||
|
$modulo = 'Utenti e permessi';
|
||||||
|
}
|
||||||
|
elseif (in_array($elemento['tipo_documento'], ['Intervento'])) {
|
||||||
$modulo = 'Interventi';
|
$modulo = 'Interventi';
|
||||||
}
|
}
|
||||||
elseif (in_array($elemento['tipo_documento'], ['Preventivo'])) {
|
elseif (in_array($elemento['tipo_documento'], ['Preventivo'])) {
|
||||||
@@ -490,19 +501,26 @@ if (!empty($elementi)) {
|
|||||||
</ul>
|
</ul>
|
||||||
<p>'.tr('Eliminando questo documento si potrebbero verificare problemi nelle altre sezioni del gestionale.').'</p>
|
<p>'.tr('Eliminando questo documento si potrebbero verificare problemi nelle altre sezioni del gestionale.').'</p>
|
||||||
</div>';
|
</div>';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (!str_contains($records[0]['idtipianagrafica'], $id_azienda)) {
|
if (!str_contains($records[0]['idtipianagrafica'], $id_azienda)) {
|
||||||
echo '
|
echo '
|
||||||
<a class="btn btn-danger ask" data-backto="record-list">
|
<a class="btn btn-danger ask" data-backto="record-list">
|
||||||
<i class="fa fa-trash"></i> '.tr('Elimina').'
|
<i class="fa fa-trash"></i> '.tr('Elimina').'
|
||||||
</a>';
|
</a>';
|
||||||
|
}else{
|
||||||
|
|
||||||
|
echo '
|
||||||
|
<div class=\'alert alert-warning\' >'.tr('Questa è l\'anagrafica "Azienda" e non è possibile eliminarla').'.</div>';
|
||||||
|
}
|
||||||
|
|
||||||
}else{
|
}else{
|
||||||
|
|
||||||
echo '
|
echo '
|
||||||
<div class=\'alert alert-warning\' >'.tr('Questa è l\'anagrafica "Azienda" e non è possibile eliminarla').'.</div>';
|
<div class=\'alert alert-danger\' >'.tr('Questa anagrafica è stata eliminata').'.</div>';
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
?>
|
?>
|
||||||
|
@@ -17,8 +17,14 @@ if ($self_edit) {
|
|||||||
$idgruppo = intval(filter('idgruppo'));
|
$idgruppo = intval(filter('idgruppo'));
|
||||||
$id_utente = filter('id_utente');
|
$id_utente = filter('id_utente');
|
||||||
|
|
||||||
|
//gruppo della selezione
|
||||||
$nome_gruppo = $dbo->fetchArray('SELECT nome FROM zz_groups WHERE id='.prepare($idgruppo))[0]['nome'];
|
$nome_gruppo = $dbo->fetchArray('SELECT nome FROM zz_groups WHERE id='.prepare($idgruppo))[0]['nome'];
|
||||||
$nome_gruppo = substr($nome_gruppo, 0, -1).'o';
|
$gruppi = [
|
||||||
|
'Clienti' => 'Cliente',
|
||||||
|
'Tecnici' => 'Tecnico',
|
||||||
|
'Agenti' => 'Agente',
|
||||||
|
];
|
||||||
|
$nome_gruppo = $gruppi[$nome_gruppo];
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user