1
0
mirror of https://github.com/devcode-it/openstamanager.git synced 2024-12-25 23:33:02 +01:00
openstamanager/modules/pagamenti/actions.php
Thomas Zilio 9c5625c3bb Completo utilizzo delle funzionalità di Symfony Translator
Miglioramento nella gestione delle sostituzioni inline per le traduzioni, con aggiunta di alcune opzioni integrate per modificare l'output (tutto maiuscolo o tutto minuscolo).
Aggiunta della libreria danielstjules/stringy per migliorare la gestione delle stringhe con supporto completo alla codifica UTF-8.
2017-09-10 14:35:41 +02:00

94 lines
3.1 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,
];
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;
}