1
0
mirror of https://github.com/devcode-it/openstamanager.git synced 2025-01-18 10:15:05 +01:00
openstamanager/modules/pagamenti/actions.php
Thomas Zilio d69a43860c Bugfix e miglioramenti
Miglioramento della gestione automatica dei conti relativi ai pagamenti.
Aggiunta possibilità di non specificare il nome tra gli allegati (se non impostato, viene preso il nome effettivo del file).
Aggiunta possibilità di testare la query principale nel modulo Viste.
Risoluzione di alcuni problemi nelle stampe dei contratti.
2017-09-13 13:05:35 +02:00

96 lines
3.2 KiB
PHP

<?php
include_once __DIR__.'/../../core.php';
switch (filter('op')) {
case 'update':
$descrizione = filter('descrizione');
if (isset($descrizione)) {
foreach ($post['id'] as $key => $id) {
// Data fatturazione
$giorno = 0;
// Data fatturazione fine mese
if ($post['scadenza'][$key] == 2) {
$giorno = -1;
}
// Data fatturazione giorno fisso
if ($post['scadenza'][$key] == 3) {
$giorno = $post['giorno'][$key];
}
// Data fatturazione fine mese (giorno fisso)
elseif ($post['scadenza'][$key] == 4) {
$giorno = -$post['giorno'][$key] - 1;
}
$array = [
'num_giorni' => $post['distanza'][$key],
'giorno' => $giorno,
'prc' => $post['percentuale'][$key],
'descrizione' => $descrizione,
'idconto_vendite' => $post['idconto_vendite'],
'idconto_acquisti' => $post['idconto_acquisti'],
];
if (!empty($id)) {
$dbo->update('co_pagamenti', $array, ['id' => $id]);
} else {
$dbo->INSERT('co_pagamenti', $array);
}
}
$_SESSION['infos'][] = tr('Salvataggio completato!');
} else {
$_SESSION['errors'][] = tr('Ci sono stati alcuni errori durante il salvataggio!');
}
break;
case 'add':
$descrizione = filter('descrizione');
if (isset($descrizione)) {
$dbo->query('INSERT INTO `co_pagamenti` (`descrizione`) VALUES ('.prepare($descrizione).')');
$id_record = $dbo->lastInsertedID();
$_SESSION['infos'][] = tr('Aggiunta nuova tipologia di _TYPE_', [
'_TYPE_' => 'pagamento',
]);
} else {
$_SESSION['errors'][] = tr('Ci sono stati alcuni errori durante il salvataggio!');
}
break;
case 'delete':
if (isset($id_record)) {
$dbo->query('DELETE FROM `co_pagamenti` WHERE `descrizione`='.prepare($records[0]['descrizione']));
$_SESSION['infos'][] = tr('Tipologia di _TYPE_ eliminata con successo!', [
'_TYPE_' => 'pagamento',
]);
}
break;
case 'delete_rata':
$id = filter('id');
if (isset($id)) {
$dbo->query('DELETE FROM `co_pagamenti` WHERE `id`='.prepare($id));
$_SESSION['infos'][] = tr('Elemento eliminato con successo!');
if ($id_record == $id) {
$res = $dbo->fetchArray('SELECT * FROM `co_pagamenti` WHERE `id`!='.prepare($id).' AND `descrizione`='.prepare($records[0]['descrizione']));
if (count($res) != 0) {
redirect($rootdir.'/editor.php?id_module='.$id_module.'&id_record='.$res[0]['id']);
} else {
// $_POST['backto'] = 'record-list';
redirect($rootdir.'/controller.php?id_module='.$id_module);
}
}
}
break;
}