diff --git a/include/common/articolo.php b/include/common/articolo.php new file mode 100644 index 000000000..c027f105e --- /dev/null +++ b/include/common/articolo.php @@ -0,0 +1,78 @@ + +
'.tr('Contratto numero _NUM_', [ - '_NUM_' => $numero, -]).'
- -'; diff --git a/modules/contratti/add_riga.php b/modules/contratti/add_riga.php deleted file mode 100644 index 193cedb0a..000000000 --- a/modules/contratti/add_riga.php +++ /dev/null @@ -1,130 +0,0 @@ -fetchArray('SELECT * FROM co_contratti WHERE id='.prepare($id_record)); -$numero = $rs[0]['numero']; -$idanagrafica = $rs[0]['idanagrafica']; - -if (empty($idriga)) { - $op = 'addriga'; - $button = tr('Aggiungi'); - - // valori default - $descrizione = ''; - $qta = 1; - $um = ''; - $prezzo = 0; - $sconto = 0; - $tipo_sconto = ''; - - // Leggo l'iva predefinita per l'anagrafica e se non c'è leggo quella predefinita generica - $iva = $dbo->fetchArray('SELECT idiva_vendite AS idiva FROM an_anagrafiche WHERE idanagrafica='.prepare($idanagrafica)); - $idiva = $iva[0]['idiva'] ?: get_var('Iva predefinita'); - - // Sconto unitario - $rss = $dbo->fetchArray('SELECT prc_guadagno FROM mg_listini WHERE id=(SELECT idlistino_vendite FROM an_anagrafiche WHERE idanagrafica='.prepare($idanagrafica).')'); - if (!empty($rss)) { - $sconto = $rss[0]['prc_guadagno']; - $tipo_sconto = 'PRC'; - } -} else { - $op = 'editriga'; - $button = tr('Modifica'); - - $rsr = $dbo->fetchArray('SELECT * FROM co_righe2_contratti WHERE idcontratto='.prepare($id_record).' AND id='.prepare($idriga)); - - $idarticolo = $rsr[0]['idarticolo']; - $descrizione = $rsr[0]['descrizione']; - $qta = $rsr[0]['qta']; - $um = $rsr[0]['um']; - $idiva = $rsr[0]['idiva']; - $prezzo = $rsr[0]['subtotale'] / $rsr[0]['qta']; - $sconto = $rsr[0]['sconto_unitario']; - $tipo_sconto = $rsr[0]['tipo_sconto']; -} - -echo ' -'; - -echo ' - '; diff --git a/modules/contratti/edit.php b/modules/contratti/edit.php index cf91d023b..312090958 100644 --- a/modules/contratti/edit.php +++ b/modules/contratti/edit.php @@ -280,8 +280,11 @@ if (sizeof($rs) > 0) { - - + + + + + diff --git a/modules/contratti/row-add.php b/modules/contratti/row-add.php new file mode 100644 index 000000000..ec79a4347 --- /dev/null +++ b/modules/contratti/row-add.php @@ -0,0 +1,47 @@ +fetchArray('SELECT * FROM co_contratti WHERE id='.prepare($id_record)); +$idanagrafica = $rs[0]['idanagrafica']; + +// Impostazioni per la gestione +$options = [ + 'op' => 'addriga', + 'button' => tr('Aggiungi'), + 'dir' => 'entrata', + 'idanagrafica' => $idanagrafica, +]; + +// Dati di default +$result = [ + 'descrizione' => '', + 'qta' => 1, + 'um' => '', + 'prezzo' => 0, + 'sconto_unitario' => 0, + 'tipo_sconto' => '', + 'idiva' => '', +]; + +// Leggo l'iva predefinita per l'anagrafica e se non c'è leggo quella predefinita generica +$iva = $dbo->fetchArray('SELECT idiva_vendite AS idiva FROM an_anagrafiche WHERE idanagrafica='.prepare($idanagrafica)); +$result['idiva'] = $iva[0]['idiva'] ?: get_var('Iva predefinita'); + +// Sconto unitario +$rss = $dbo->fetchArray('SELECT prc_guadagno FROM mg_listini WHERE id=(SELECT idlistino_vendite FROM an_anagrafiche WHERE idanagrafica='.prepare($idanagrafica).')'); +if (!empty($rss)) { + $result['sconto_unitario'] = $rss[0]['prc_guadagno']; + $result['tipo_sconto'] = 'PRC'; +} + +// Importazione della gestione dedicata +$file = 'riga'; +if (isset($get['is_descrizione'])) { + $file = 'descrizione'; +} elseif (isset($get['is_articolo'])) { + $file = 'articolo'; +} + +echo App::load($file.'.php', $result, $options); diff --git a/modules/contratti/row-edit.php b/modules/contratti/row-edit.php new file mode 100644 index 000000000..292b0a8fd --- /dev/null +++ b/modules/contratti/row-edit.php @@ -0,0 +1,31 @@ +fetchArray('SELECT * FROM co_contratti WHERE id='.prepare($id_record)); +$idanagrafica = $rs[0]['idanagrafica']; + +// Impostazioni per la gestione +$options = [ + 'op' => 'editriga', + 'button' => tr('Modifica'), + 'dir' => 'entrata', + 'idanagrafica' => $idanagrafica, +]; + +// Dati della riga +$rsr = $dbo->fetchArray('SELECT * FROM co_righe2_contratti WHERE idcontratto='.prepare($id_record).' AND id='.prepare($get['idriga'])); + +$result = $rsr[0]; +$result['prezzo'] = $rsr[0]['subtotale'] / $rsr[0]['qta']; + +// Importazione della gestione dedicata +$file = 'riga'; +if (!empty($result['is_descrizione'])) { + $file = 'descrizione'; +} elseif (!empty($result['idarticolo'])) { + $file = 'articolo'; +} + +echo App::load($file.'.php', $result, $options); diff --git a/modules/contratti/row-list.php b/modules/contratti/row-list.php index 10c7a3907..1c83c0367 100644 --- a/modules/contratti/row-list.php +++ b/modules/contratti/row-list.php @@ -119,8 +119,10 @@ if (!empty($rs_art)) { diff --git a/src/App.php b/src/App.php index c61ffda0d..21164db66 100644 --- a/src/App.php +++ b/src/App.php @@ -333,4 +333,57 @@ class App return $query; } + + public static function load($file, $result, $options, $directory = null) + { + $module = self::getCurrentModule(); + + $id_module = filter('id_module'); + $id_record = filter('id_record'); + + $directory = empty($directory) ? 'include|custom|/common/' : $directory; + $directory = str_contains($directory, DOCROOT) ? $directory : DOCROOT.'/'.$directory; + + ob_start(); + + $original_file = str_replace('|custom|', '', $directory).'form.php'; + $custom_file = str_replace('|custom|', '/custom', $directory).'form.php'; + if (file_exists($custom_file)) { + require $custom_file; + } elseif (file_exists($original_file)) { + require $original_file; + } + + $form = ob_get_clean(); + + $response = self::internalLoad($file, $result, $options, $directory); + $form = str_replace('|response|', $response, $form); + + return $form; + } + + protected static function internalLoad($file, $result, $options, $directory = null) + { + $module = self::getCurrentModule(); + + $id_module = filter('id_module'); + $id_record = filter('id_record'); + + $directory = empty($directory) ? 'include|custom|/common/' : $directory; + $directory = str_contains($directory, DOCROOT) ? $directory : DOCROOT.'/'.$directory; + + ob_start(); + + $original_file = str_replace('|custom|', '', $directory).$file; + $custom_file = str_replace('|custom|', '/custom', $directory).$file; + if (file_exists($custom_file)) { + require $custom_file; + } elseif (file_exists($original_file)) { + require $original_file; + } + + $response = ob_get_clean(); + + return $response; + } }