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 @@ + +
+ {[ "type": "select", "label": "'.tr('Articolo').'", "name": "idarticolo", "required": 1, "value": "'.$result['idarticolo'].'", "ajax-source": "articoli" ]} +
+ '; + +echo App::internalLoad('riga.php', $result, $options); + +// Informazioni aggiuntive +if ($module['name'] != 'Contratti' && $module['name'] != 'Preventivi') { + echo ' +
+
+ +
+
+ +
+ +
+
+ +
+ +
+
+
+
'; +} + +echo ' + '; diff --git a/include/common/descrizione.php b/include/common/descrizione.php new file mode 100644 index 000000000..1167b4557 --- /dev/null +++ b/include/common/descrizione.php @@ -0,0 +1,11 @@ + +
+ {[ "type": "textarea", "label": "'.tr('Descrizione').'", "name": "descrizione", "id": "descrizione_riga", "value": '.json_encode($result['descrizione']).', "required": 1 ]} +
+ '; diff --git a/include/common/form.php b/include/common/form.php new file mode 100644 index 000000000..19dfa228b --- /dev/null +++ b/include/common/form.php @@ -0,0 +1,29 @@ + + + + + '; + +echo ' + |response|'; + +echo ' + + +
+
+ +
+
+'; + +echo ' + '; diff --git a/include/common/riga.php b/include/common/riga.php new file mode 100644 index 000000000..1edd59f1f --- /dev/null +++ b/include/common/riga.php @@ -0,0 +1,74 @@ +'; + + // Rivalsa INPS + if (get_var('Percentuale rivalsa INPS') != '' || $options['dir'] == 'uscita') { + echo ' +
+ {[ "type": "select", "label": "'.tr('Rivalsa INPS').'", "name": "idrivalsainps", "value": "'.$result['idrivalsainps'].'", "values": "query=SELECT * FROM co_rivalsainps", "required": '.intval($options['dir'] != 'uscita').' ]} +
'; + } + + // Ritenuta d'acconto + if (get_var("Percentuale ritenuta d'acconto") != '' || $options['dir'] == 'uscita') { + echo ' +
+ {[ "type": "select", "label": "'.tr("Ritenuta d'acconto").'", "name": "idritenutaacconto", "value": "'.$result['idritenutaacconto'].'", "values": "query=SELECT * FROM co_ritenutaacconto", "required": '.intval($options['dir'] != 'uscita').' ]} +
'; + } + + echo ' + '; + } + + // Conto + echo ' +
+
+ {[ "type": "select", "label": "'.tr('Conto').'", "name": "idconto", "required": 1, "value": "'.$result['idconto'].'", "ajax-source": "'.$options['conti'].'" ]} +
+
'; +} + +// Iva +echo ' +
+
+ {[ "type": "select", "label": "'.tr('Iva').'", "name": "idiva", "required": 1, "value": "'.$result['idiva'].'", "values": "query=SELECT * FROM co_iva ORDER BY descrizione ASC" ]} +
'; + +// Quantità +echo ' +
+ {[ "type": "number", "label": "'.tr('Q.tà').'", "name": "qta", "required": 1, "value": "'.$result['qta'].'", "decimals": "qta" ]} +
'; + +// Unità di misura +echo ' +
+ {[ "type": "select", "label": "'.tr('Unità di misura').'", "icon-after": "add|'.Modules::get('Unità di misura')['id'].'", "name": "um", "value": "'.$result['um'].'", "ajax-source": "misure" ]} +
'; + +// Costo unitario +echo ' +
+ {[ "type": "number", "label": "'.tr('Costo unitario').'", "name": "prezzo", "value": "'.$result['prezzo'].'", "required": 1, "icon-after": "€" ]} +
'; + +// Sconto unitario +echo ' +
+ {[ "type": "number", "label": "'.tr('Sconto unitario').'", "name": "sconto", "value": "'.$result['sconto_unitario'].'", "icon-after": "choice|untprc|'.$result['tipo_sconto'].'" ]} +
+
'; diff --git a/modules/contratti/actions.php b/modules/contratti/actions.php index 91e79fef4..ec75576dd 100644 --- a/modules/contratti/actions.php +++ b/modules/contratti/actions.php @@ -160,21 +160,17 @@ switch (post('op')) { $iva_indetraibile = $iva / 100 * $rs2[0]['indetraibile']; $desc_iva = $rs2[0]['descrizione']; - $dbo->query('INSERT INTO co_righe2_contratti(idcontratto, idarticolo, idiva, desc_iva, iva, iva_indetraibile, descrizione, subtotale, um, qta, sconto, sconto_unitario, tipo_sconto, `order`) VALUES ('.prepare($id_record).', '.prepare($idarticolo).', '.prepare($idiva).', '.prepare($desc_iva).', '.prepare($iva).', '.prepare($iva_indetraibile).', '.prepare($descrizione).', '.prepare($subtot).', '.prepare($um).', '.prepare($qta).', '.prepare($sconto).', '.prepare($sconto_unitario).', '.prepare($tipo_sconto).', (SELECT IFNULL(MAX(`order`) + 1, 0) FROM co_righe2_contratti AS t WHERE idcontratto='.prepare($id_record).'))'); + $dbo->query('INSERT INTO co_righe2_contratti(idcontratto, idarticolo, idiva, desc_iva, iva, iva_indetraibile, descrizione, subtotale, um, qta, sconto, sconto_unitario, tipo_sconto, is_descrizione, `order`) VALUES ('.prepare($id_record).', '.prepare($idarticolo).', '.prepare($idiva).', '.prepare($desc_iva).', '.prepare($iva).', '.prepare($iva_indetraibile).', '.prepare($descrizione).', '.prepare($subtot).', '.prepare($um).', '.prepare($qta).', '.prepare($sconto).', '.prepare($sconto_unitario).', '.prepare($tipo_sconto).', '.prepare(empty($qta)).', (SELECT IFNULL(MAX(`order`) + 1, 0) FROM co_righe2_contratti AS t WHERE idcontratto='.prepare($id_record).'))'); - $_SESSION['infos'][] = tr('Articolo aggiunto!'); - - break; - - case 'adddescrizione': - if (!empty($id_record)) { - $descrizione = post('descrizione'); - $query = 'INSERT INTO co_righe2_contratti(idcontratto, descrizione, is_descrizione) VALUES('.prepare($id_record).', '.prepare($descrizione).', 1)'; - - if ($dbo->query($query)) { - $_SESSION['infos'][] = tr('Riga descrittiva aggiunta!'); - } + // Messaggi informativi + if (!empty($idarticolo)) { + $_SESSION['infos'][] = tr('Articolo aggiunto!'); + } elseif (!empty($qta)) { + $_SESSION['infos'][] = tr('Riga descrittiva aggiunta!'); + } else { + $_SESSION['infos'][] = tr('Riga aggiunta!'); } + break; case 'editriga': diff --git a/modules/contratti/add_descrizione.php b/modules/contratti/add_descrizione.php deleted file mode 100644 index 45ba8d053..000000000 --- a/modules/contratti/add_descrizione.php +++ /dev/null @@ -1,41 +0,0 @@ -fetchArray('SELECT * FROM co_contratti WHERE id='.prepare($id_record)); -$numero = $record[0]['numero']; -$idanagrafica = $record[0]['idanagrafica']; - -/* - Form di inserimento riga documento -*/ -echo ' -

'.tr('Contratto numero _NUM_', [ - '_NUM_' => $numero, -]).'

- -
- - - '; - -// Descrizione -echo ' -
-
- {[ "type": "textarea", "label": "'.tr('Descrizione').'", "name": "descrizione", "required": 1 ]} -
-
'; - -echo ' - - -
-
- -
-
-
'; 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 ' -
- - - '; - -// Elenco articoli raggruppati per gruppi e sottogruppi -if (empty($rsr[0]['is_descrizione'])) { - echo ' -
- {[ "type": "select", "label": "'.tr('Articolo').'", "name": "idarticolo", "value": "'.$idarticolo.'", "ajax-source": "articoli" ]} -
'; -} - -// Descrizione -echo ' -
- {[ "type": "textarea", "label": "'.tr('Descrizione').'", "name": "descrizione", "id": "descrizione_riga", "value": '.json_encode($descrizione).', "required": 1 ]} -
'; - -if (empty($rsr[0]['is_descrizione'])) { - // Iva - echo ' -
- {[ "type": "select", "label": "'.tr('Iva').'", "name": "idiva", "required": 1, "values": "query=SELECT id, descrizione FROM co_iva ORDER BY descrizione ASC", "value": "'.$idiva.'" ]} -
'; - - // Quantità - echo ' -
- {[ "type": "number", "label": "'.tr('Q.tà').'", "name": "qta", "value": "'.$qta.'", "required": 1, "decimals": "qta" ]} -
'; - - // Unità di misura - echo ' -
- {[ "type": "select", "label": "'.tr('Unità di misura').'", "icon-after": "add|'.Modules::get('Unità di misura')['id'].'", "name": "um", "value": "'.$um.'", "ajax-source": "misure" ]} -
'; - - // Costo unitario - echo ' -
- {[ "type": "number", "label": "'.tr('Costo unitario').'", "name": "prezzo", "required": 1, "value": "'.$prezzo.'", "icon-after": "€" ]} -
'; - - // Sconto unitario - echo ' -
- {[ "type": "number", "label": "'.tr('Sconto unitario').'", "name": "sconto", "value": "'.$sconto.'", "icon-after": "choice|untprc|'.$tipo_sconto.'" ]} -
'; -} - -echo ' - '; - -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)) {
'; + echo " - + + "; echo '
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; + } }