mirror of
https://github.com/devcode-it/openstamanager.git
synced 2025-01-20 19:19:15 +01:00
93 lines
3.3 KiB
PHP
93 lines
3.3 KiB
PHP
<?php
|
|
|
|
include_once DOCROOT.'/modules/fatture/modutil.php';
|
|
include_once DOCROOT.'/modules/interventi/modutil.php';
|
|
|
|
// Fatture di vendita e acquisto
|
|
$results = $dbo->fetchArray("SELECT co_documenti.id, co_statidocumento.descrizione AS stato_fattura
|
|
FROM co_documenti
|
|
INNER JOIN co_statidocumento ON co_documenti.idstatodocumento=co_statidocumento.id
|
|
WHERE co_statidocumento.descrizione IN ('Emessa', 'Parzialmente pagato', 'Pagato', 'Bozza', 'Annullata')");
|
|
|
|
foreach ($results as $result) {
|
|
$scadenze = $dbo->fetchArray('SELECT id, da_pagare, pagato, scadenza FROM co_scadenziario WHERE iddocumento = '.prepare($result['id']));
|
|
|
|
// Se esiste la scadenza la elimino
|
|
if (!empty($scadenze)) {
|
|
elimina_scadenza($result['id']);
|
|
}
|
|
|
|
$is_pagato = null;
|
|
if ($result['stato_fattura'] == 'Pagato') {
|
|
$is_pagato = true;
|
|
} elseif (in_array($result['stato_fattura'], ['Emessa', 'Parzialmente pagato'])) {
|
|
$is_pagato = false;
|
|
}
|
|
|
|
// Aggiungo la scadenza e la segno eventualmente come pagata
|
|
if (isset($is_pagato)) {
|
|
aggiungi_scadenza($result['id'], null, $is_pagato);
|
|
}
|
|
|
|
if (!empty($scadenze) && $result['stato_fattura'] == 'Parzialmente pagato') {
|
|
foreach ($scadenze as $scadenza) {
|
|
$dbo->query('UPDATE co_scadenziario SET pagato = '.prepare($scadenza['pagato']).' WHERE scadenza = '.prepare($scadenza['scadenza']).' AND iddocumento = '.prepare($result['id']));
|
|
}
|
|
}
|
|
}
|
|
|
|
// Aggiornamento sconti incodizionati per Interventi
|
|
$id_iva = setting('Iva predefinita');
|
|
$iva = $dbo->fetchOne('SELECT * FROM co_iva WHERE id='.prepare($id_iva));
|
|
|
|
$interventi = $dbo->fetchArray('SELECT * FROM in_interventi WHERE sconto_globale != 0');
|
|
foreach ($interventi as $intervento) {
|
|
$costi = get_costi_intervento($intervento['id']);
|
|
$sconto_globale = $costi['sconto_globale'];
|
|
|
|
if ($intervento['tipo_sconto_globale'] == 'PRC') {
|
|
$descrizione = $sconto_globale >= 0 ? tr('Sconto percentuale') : tr('Maggiorazione percentuale');
|
|
$descrizione .= ' '.Translator::numberToLocale($intervento['sconto_globale']).'%';
|
|
} else {
|
|
$descrizione = $sconto_globale >= 0 ? tr('Sconto unitario') : tr('Maggiorazione unitaria');
|
|
}
|
|
|
|
$valore_iva = $sconto_globale * $iva['percentuale'] / 100;
|
|
|
|
$dbo->insert('in_righe_interventi', [
|
|
'idintervento' => $intervento['id'],
|
|
'descrizione' => $descrizione,
|
|
'qta' => 1,
|
|
'sconto' => $sconto_globale,
|
|
'sconto_unitario' => $sconto_globale,
|
|
'tipo_sconto' => 'UNT',
|
|
'is_sconto' => 1,
|
|
'idiva' => $id_iva['id'],
|
|
'desc_iva' => $iva['descrizione'],
|
|
'iva' => $valore_iva,
|
|
]);
|
|
}
|
|
|
|
$dbo->query('ALTER TABLE `in_interventi` DROP `sconto_globale`, DROP `tipo_sconto_globale`, DROP `tipo_sconto`');
|
|
|
|
// File e cartelle deprecate
|
|
$files = [
|
|
'plugins/xml/AT_v1.0.xml',
|
|
'plugins/xml/DT_v1.0.xml',
|
|
'plugins/xml/EC_v1.0.xml',
|
|
'plugins/xml/MC_v1.0.xml',
|
|
'plugins/xml/MT_v1.0.xml',
|
|
'plugins/xml/NE_v1.0.xml',
|
|
'plugins/xml/NS_v1.0.xml',
|
|
'plugins/xml/RC_v1.0.xml',
|
|
'plugins/xml/SE_v1.0.xml',
|
|
'plugins/exportFE/view.php',
|
|
'plugins/exportFE/src/stylesheet-1.2.1.xsl',
|
|
];
|
|
|
|
foreach ($files as $key => $value) {
|
|
$files[$key] = realpath(DOCROOT.'/'.$value);
|
|
}
|
|
|
|
delete($files);
|