openstamanager/modules/scadenzario/actions.php

33 lines
1.3 KiB
PHP

<?php
include_once __DIR__.'/../../core.php';
switch (post('op')) {
case 'update':
// Calcolo il totale da pagare
$rs = $dbo->fetchArray('SELECT SUM(da_pagare) AS totale_da_pagare FROM co_scadenziario GROUP BY iddocumento HAVING iddocumento=(SELECT iddocumento FROM co_scadenziario s WHERE id='.prepare($id_record).')');
$totale_da_pagare = $rs[0]['totale_da_pagare'];
$totale_utente = 0;
// Verifico se il totale sommato è uguale al totale da pagare
foreach (post('scadenza') as $idscadenza => $da_pagare) {
$totale_utente += floatval($da_pagare);
}
// Fix per problemi di comparazione tra float
$totale_utente = (string) $totale_utente;
if ($totale_utente == $totale_da_pagare) {
foreach (post('scadenza') as $idscadenza => $da_pagare) {
$dbo->query('UPDATE co_scadenziario SET da_pagare='.prepare($da_pagare).', pagato='.prepare(post('pagato')[$idscadenza]).', scadenza='.prepare(post('data')[$idscadenza]).' WHERE id='.prepare($idscadenza));
}
flash()->info(tr('Scadenze aggiornate!'));
} else {
flash()->error(tr('Il totale degli importi inseriti non corrisponde al totale da pagare!'));
}
break;
}