1
0
mirror of https://github.com/devcode-it/openstamanager.git synced 2025-02-16 19:40:44 +01:00

Fix gestione righe

This commit is contained in:
Thomas Zilio 2020-01-17 17:31:07 +01:00
parent f288fb6940
commit 17abd0fc49
20 changed files with 222 additions and 198 deletions

View File

@ -18,6 +18,23 @@ abstract class Document extends Model
return $results->sortBy('order');
}
/**
* Restituisce la riga identificata dall'ID indicato.
*
* @param $type
* @param $id
*
* @return mixed
*/
public function getRiga($type, $id)
{
$righe = $this->getRighe();
return $righe->first(function ($item) use ($type, $id){
return $item instanceof $type && $item->id == $id ;
});
}
/**
* Restituisce la collezione di righe e articoli con valori rilevanti per i conti, raggruppate sulla base dei documenti di provenienza.
* La chiave è la serializzazione del documento di origine, oppure null in caso non esista.

View File

@ -219,11 +219,10 @@ switch (post('op')) {
// Eliminazione riga
case 'delete_riga':
$id_riga = post('idriga');
if ($id_riga !== null) {
$riga = Descrizione::find($id_riga) ?: Riga::find($id_riga);
$riga = $riga ? $riga : Articolo::find($id_riga);
$riga = $riga ? $riga : Sconto::find($id_riga);
$type = post('type');
$riga = $contratto->getRiga($type, $id_riga);
if (!empty($riga)) {
$riga->delete();
flash()->info(tr('Riga eliminata!'));

View File

@ -18,7 +18,8 @@ $options = [
// Dati della riga
$id_riga = get('idriga');
$riga = $documento->getRighe()->find($id_riga);
$type = get('type');
$riga = $documento->getRiga($type, $id_riga);
$result = $riga->toArray();
$result['prezzo'] = $riga->prezzo_unitario_vendita;

View File

@ -2,9 +2,6 @@
include_once __DIR__.'/../../core.php';
// Righe documento
$righe = $contratto->getRighe();
echo '
<table class="table table-striped table-hover table-condensed table-bordered">
<thead>
@ -20,6 +17,8 @@ echo '
</thead>
<tbody class="sortable">';
// Righe documento
$righe = $contratto->getRighe();
foreach ($righe as $riga) {
echo '
<tr data-id="'.$riga->id.'">';
@ -92,16 +91,15 @@ foreach ($righe as $riga) {
if (empty($record['is_completato'])) {
echo '
<form action="" method="post" id="delete-form-'.$riga->id.'" role="form">
<input type="hidden" name="backto" value="record-edit">
<input type="hidden" name="op" value="delete_riga">
<input type="hidden" name="idriga" value="'.$riga->id.'">
<div class="btn-group">
<a class="btn btn-xs btn-warning" onclick="editRow(\''.addslashes(get_class($riga)).'\', '.$riga->id.')">
<i class="fa fa-edit"></i>
</a>
<div class="btn-group">
<a class="btn btn-xs btn-warning" onclick="editRow('.$riga->id.')"><i class="fa fa-edit"></i></a>
<a class="btn btn-xs btn-danger" onclick="deleteRow('.$riga->id.')"><i class="fa fa-trash"></i></a>
</div>
</form>';
<a class="btn btn-xs btn-danger" onclick="deleteRow(\''.addslashes(get_class($riga)).'\', '.$riga->id.')">
<i class="fa fa-trash"></i>
</a>
</div>';
}
echo '
@ -116,13 +114,18 @@ foreach ($righe as $riga) {
echo '
<script>
function editRow(id){
launch_modal("'.tr('Modifica riga').'", "'.$module->fileurl('row-edit.php').'?id_module=" + globals.id_module + "&id_record=" + globals.id_record + "&idriga=" + id);
function editRow(type, id){
launch_modal("'.tr('Modifica riga').'", "'.$module->fileurl('row-edit.php').'?id_module=" + globals.id_module + "&id_record=" + globals.id_record + "&idriga=" + id + "&type=" + encodeURIComponent(type));
}
function deleteRow(id){
function deleteRow(type, id){
if(confirm("'.tr('Rimuovere questa riga dal documento?').'")){
$("#delete-form-" + id).submit();
redirect("", {
backto: "record-edit",
op: "delete_riga",
idriga: id,
type: type,
}, "post");
}
}
</script>';

View File

@ -282,10 +282,11 @@ switch (post('op')) {
// Scollegamento riga generica da ddt
case 'delete_riga':
$id_riga = post('idriga');
$type = post('type');
if (!empty($id_riga)) {
$riga = $ddt->getRighe()->find($id_riga);
$riga = $ddt->getRiga($type, $id_riga);
if (!empty($riga)) {
try {
$riga->delete();

View File

@ -18,7 +18,8 @@ $options = [
// Dati della riga
$id_riga = get('idriga');
$riga = $documento->getRighe()->find($id_riga);
$type = get('type');
$riga = $documento->getRiga($type, $id_riga);
$result = $riga->toArray();
$result['prezzo'] = $riga->prezzo_unitario_vendita;

View File

@ -16,28 +16,25 @@ echo '
<tbody class="sortable">';
/*
Articoli e righe generiche
*/
$q_art = 'SELECT *, round(sconto_unitario,'.setting('Cifre decimali per importi').') AS sconto_unitario, round(sconto,'.setting('Cifre decimali per importi').') AS sconto, round(subtotale,'.setting('Cifre decimali per importi').') AS subtotale, (SELECT codice FROM mg_articoli WHERE id=idarticolo) AS codice FROM `dt_righe_ddt` WHERE idddt='.prepare($id_record).' ORDER BY `order`';
$rs = $dbo->fetchArray($q_art);
// Righe documento
$righe = $ddt->getRighe();
foreach ($righe as $riga) {
$r = $riga->toArray();
if (!empty($rs)) {
foreach ($rs as $r) {
$extra = '';
$mancanti = 0;
$extra = '';
$mancanti = 0;
// Individuazione dei seriali
if (!empty($r['idarticolo']) && !empty($r['abilita_serial'])) {
$serials = array_column($dbo->fetchArray('SELECT serial FROM mg_prodotti WHERE serial IS NOT NULL AND id_riga_ddt='.prepare($r['id'])), 'serial');
$mancanti = $r['qta'] - count($serials);
// Individuazione dei seriali
if (!empty($r['idarticolo']) && !empty($r['abilita_serial'])) {
$serials = array_column($dbo->fetchArray('SELECT serial FROM mg_prodotti WHERE serial IS NOT NULL AND id_riga_ddt='.prepare($r['id'])), 'serial');
$mancanti = $r['qta'] - count($serials);
if ($mancanti > 0) {
$extra = 'class="warning"';
} else {
$mancanti = 0;
}
if ($mancanti > 0) {
$extra = 'class="warning"';
} else {
$mancanti = 0;
}
}
echo '
<tr data-id="'.$r['id'].'" '.$extra.'>
@ -45,7 +42,7 @@ if (!empty($rs)) {
if (!empty($r['idarticolo'])) {
echo '
'.Modules::link('Articoli', $r['idarticolo'], $r['codice'].' - '.$r['descrizione']);
'.Modules::link('Articoli', $r['idarticolo'], $riga->articolo->codice.' - '.$r['descrizione']);
if (!empty($r['abilita_serial'])) {
if (!empty($mancanti)) {
@ -138,13 +135,14 @@ if (!empty($rs)) {
// Possibilità di rimuovere una riga solo se il ddt non è evaso
echo '
<td class="text-center">';
if ($record['flag_completato'] == 0) {
echo "
<form action='".$rootdir.'/editor.php?id_module='.$id_module.'&id_record='.$id_record."' method='post' id='delete-form-".$r['id']."' role='form'>
<input type='hidden' name='backto' value='record-edit'>
<input type='hidden' name='id_record' value='".$id_record."'>
<input type='hidden' name='idriga' value='".$r['id']."'>
<input type='hidden' name='dir' value='".$dir."'>
<input type='hidden' name='type' value='".get_class($riga)."'>
<input type='hidden' name='op' value='delete_riga'>
<div class='input-group-btn'>";
@ -155,7 +153,7 @@ if (!empty($rs)) {
}
echo "
<a class='btn btn-xs btn-warning' title='Modifica questa riga...' onclick=\"launch_modal( 'Modifica riga', '".$rootdir.'/modules/ddt/row-edit.php?id_module='.$id_module.'&id_record='.$id_record.'&idriga='.$r['id']."');\">
<a class='btn btn-xs btn-warning' title='Modifica questa riga...' onclick=\"launch_modal('Modifica riga', '".$rootdir.'/modules/ddt/row-edit.php?id_module='.$id_module.'&id_record='.$id_record.'&idriga='.$r['id'].'&type='.urlencode(get_class($riga))."');\">
<i class='fa fa-edit'></i>
</a>
@ -174,7 +172,6 @@ if (!empty($rs)) {
echo '
</td>
</tr>';
}
}
echo '

View File

@ -500,10 +500,10 @@ switch (post('op')) {
// Scollegamento riga generica da documento
case 'delete_riga':
$id_riga = post('idriga');
$type = post('type');
$riga = $fattura->getRiga($type, $id_riga);
if (!empty($id_riga)) {
$riga = $fattura->getRighe()->find($id_riga);
if (!empty($riga)) {
try {
$riga->delete();

View File

@ -29,7 +29,8 @@ $documento = Fattura::find($id_record);
// Dati della riga
$id_riga = get('idriga');
$riga = $documento->getRighe()->find($id_riga);
$type = get('type');
$riga = $documento->getRiga($type, $id_riga);
$result = $riga->toArray();
$result = array_merge($result, $riga->dati_aggiuntivi_fe);
@ -120,12 +121,12 @@ echo '
var n = '.($key - 1).';
function add_altri_dati(btn){
cleanup_inputs();
var last = $(btn).closest("table").find("tr[id^=last-altri_dati]").parent().last();
n++;
var text = replaceAll($("#altri_dati-templace").html(), "-id-", "" + n);
last.after(text);
restart_inputs();
};

View File

@ -19,7 +19,8 @@ $options = [
// Dati della riga
$id_riga = get('idriga');
$riga = $documento->getRighe()->find($id_riga);
$type = get('type');
$riga = $documento->getRiga($type, $id_riga);
$result = $riga->toArray();
$result['prezzo'] = $riga->prezzo_unitario_vendita;

View File

@ -2,9 +2,6 @@
include_once __DIR__.'/../../core.php';
// Righe documento
$righe = $fattura->getRighe();
echo '
<table class="table table-striped table-hover table-condensed table-bordered">
<thead>
@ -20,19 +17,21 @@ echo '
</thead>
<tbody class="sortable">';
foreach ($righe as $row) {
$riga = $row->toArray();
// Righe documento
$righe = $fattura->getRighe();
foreach ($righe as $riga) {
$r = $riga->toArray();
// Valori assoluti
$riga['qta'] = abs($riga['qta']);
$riga['prezzo_unitario_acquisto'] = abs($riga['prezzo_unitario_acquisto']);
$riga['totale_imponibile'] = ($fattura->isNota() ? -$row->totale_imponibile : $row->totale_imponibile);
$riga['sconto_unitario'] = abs($riga['sconto_unitario']);
$riga['sconto'] = abs($riga['sconto']);
$riga['iva'] = abs($riga['iva']);
$r['qta'] = abs($r['qta']);
$r['prezzo_unitario_acquisto'] = abs($r['prezzo_unitario_acquisto']);
$r['totale_imponibile'] = ($fattura->isNota() ? -$riga->totale_imponibile : $riga->totale_imponibile);
$r['sconto_unitario'] = abs($r['sconto_unitario']);
$r['sconto'] = abs($r['sconto']);
$r['iva'] = abs($r['iva']);
if (empty($riga['is_descrizione'])) {
$riga['descrizione_conto'] = $dbo->fetchOne('SELECT descrizione FROM co_pianodeiconti3 WHERE id = '.prepare($riga['idconto']))['descrizione'];
if (empty($r['is_descrizione'])) {
$r['descrizione_conto'] = $dbo->fetchOne('SELECT descrizione FROM co_pianodeiconti3 WHERE id = '.prepare($r['idconto']))['descrizione'];
}
$extra = '';
@ -40,52 +39,52 @@ foreach ($righe as $row) {
$delete = 'delete_riga';
// Articoli
if ($row->isArticolo()) {
$riga['descrizione'] = (!empty($row->articolo) ? $row->articolo->codice.' - ' : '').$riga['descrizione'];
if ($riga->isArticolo()) {
$r['descrizione'] = (!empty($riga->articolo) ? $riga->articolo->codice.' - ' : '').$r['descrizione'];
$extra = '';
$mancanti = 0;
}
// Intervento
if (!empty($riga['idintervento'])) {
$intervento = $dbo->fetchOne('SELECT num_item,codice_cig,codice_cup,id_documento_fe FROM in_interventi WHERE id = '.prepare($riga['idintervento']));
$riga['num_item'] = $intervento['num_item'];
$riga['codice_cig'] = $intervento['codice_cig'];
$riga['codice_cup'] = $intervento['codice_cup'];
$riga['id_documento_fe'] = $intervento['id_documento_fe'];
if (!empty($r['idintervento'])) {
$intervento = $dbo->fetchOne('SELECT num_item,codice_cig,codice_cup,id_documento_fe FROM in_interventi WHERE id = '.prepare($r['idintervento']));
$r['num_item'] = $intervento['num_item'];
$r['codice_cig'] = $intervento['codice_cig'];
$r['codice_cup'] = $intervento['codice_cup'];
$r['id_documento_fe'] = $intervento['id_documento_fe'];
$delete = 'unlink_intervento';
}
// Preventivi
elseif (!empty($riga['idpreventivo'])) {
$preventivo = $dbo->fetchOne('SELECT num_item,codice_cig,codice_cup,id_documento_fe FROM co_preventivi WHERE id = '.prepare($riga['idpreventivo']));
$riga['num_item'] = $preventivo['num_item'];
$riga['codice_cig'] = $preventivo['codice_cig'];
$riga['codice_cup'] = $preventivo['codice_cup'];
$riga['id_documento_fe'] = $preventivo['id_documento_fe'];
elseif (!empty($r['idpreventivo'])) {
$preventivo = $dbo->fetchOne('SELECT num_item,codice_cig,codice_cup,id_documento_fe FROM co_preventivi WHERE id = '.prepare($r['idpreventivo']));
$r['num_item'] = $preventivo['num_item'];
$r['codice_cig'] = $preventivo['codice_cig'];
$r['codice_cup'] = $preventivo['codice_cup'];
$r['id_documento_fe'] = $preventivo['id_documento_fe'];
}
// Contratti
elseif (!empty($riga['idcontratto'])) {
$contratto = $dbo->fetchOne('SELECT num_item,codice_cig,codice_cup,id_documento_fe FROM co_contratti WHERE id = '.prepare($riga['idcontratto']));
$riga['num_item'] = $contratto['num_item'];
$riga['codice_cig'] = $contratto['codice_cig'];
$riga['codice_cup'] = $contratto['codice_cup'];
$riga['id_documento_fe'] = $contratto['id_documento_fe'];
elseif (!empty($r['idcontratto'])) {
$contratto = $dbo->fetchOne('SELECT num_item,codice_cig,codice_cup,id_documento_fe FROM co_contratti WHERE id = '.prepare($r['idcontratto']));
$r['num_item'] = $contratto['num_item'];
$r['codice_cig'] = $contratto['codice_cig'];
$r['codice_cup'] = $contratto['codice_cup'];
$r['id_documento_fe'] = $contratto['id_documento_fe'];
}
// Ordini (IDDOCUMENTO,CIG,CUP)
elseif (!empty($riga['idordine'])) {
$ordine = $dbo->fetchOne('SELECT num_item,codice_cig,codice_cup,id_documento_fe FROM or_ordini WHERE id = '.prepare($riga['idordine']));
$riga['num_item'] = $ordine['num_item'];
$riga['codice_cig'] = $ordine['codice_cig'];
$riga['codice_cup'] = $ordine['codice_cup'];
$riga['id_documento_fe'] = $ordine['id_documento_fe'];
elseif (!empty($r['idordine'])) {
$ordine = $dbo->fetchOne('SELECT num_item,codice_cig,codice_cup,id_documento_fe FROM or_ordini WHERE id = '.prepare($r['idordine']));
$r['num_item'] = $ordine['num_item'];
$r['codice_cig'] = $ordine['codice_cig'];
$r['codice_cup'] = $ordine['codice_cup'];
$r['id_documento_fe'] = $ordine['id_documento_fe'];
}
// Individuazione dei seriali
if (!empty($riga['abilita_serial'])) {
$serials = $row->serials;
$mancanti = $riga['qta'] - count($serials);
if (!empty($r['abilita_serial'])) {
$serials = $riga->serials;
$mancanti = $r['qta'] - count($serials);
if ($mancanti > 0) {
$extra = 'class="warning"';
@ -95,23 +94,23 @@ foreach ($righe as $row) {
}
$extra_riga = '';
if (!$riga['is_descrizione']) {
if (!$r['is_descrizione']) {
$extra_riga = tr('_DESCRIZIONE_CONTO__ID_DOCUMENTO__NUMERO_RIGA__CODICE_CIG__CODICE_CUP_', [
'_DESCRIZIONE_CONTO_' => $riga['descrizione_conto'] ?: null,
'_ID_DOCUMENTO_' => $riga['id_documento_fe'] ? ' - DOC: '.$riga['id_documento_fe'] : null,
'_NUMERO_RIGA_' => $riga['num_item'] ? ', NRI: '.$riga['num_item'] : null,
'_CODICE_CIG_' => $riga['codice_cig'] ? ', CIG: '.$riga['codice_cig'] : null,
'_CODICE_CUP_' => $riga['codice_cup'] ? ', CUP: '.$riga['codice_cup'] : null,
'_DESCRIZIONE_CONTO_' => $r['descrizione_conto'] ?: null,
'_ID_DOCUMENTO_' => $r['id_documento_fe'] ? ' - DOC: '.$r['id_documento_fe'] : null,
'_NUMERO_RIGA_' => $r['num_item'] ? ', NRI: '.$r['num_item'] : null,
'_CODICE_CIG_' => $r['codice_cig'] ? ', CIG: '.$r['codice_cig'] : null,
'_CODICE_CUP_' => $r['codice_cup'] ? ', CUP: '.$r['codice_cup'] : null,
]);
}
echo '
<tr data-id="'.$riga['id'].'" '.$extra.'>
<tr data-id="'.$r['id'].'" '.$extra.'>
<td>
'.Modules::link($row->isArticolo() ? Modules::get('Articoli')['id'] : null, $row->isArticolo() ? $riga['idarticolo'] : null, $riga['descrizione']).'
'.Modules::link($riga->isArticolo() ? Modules::get('Articoli')['id'] : null, $riga->isArticolo() ? $r['idarticolo'] : null, $r['descrizione']).'
<small class="pull-right text-muted">'.$extra_riga.'</small>';
if (!empty($riga['abilita_serial'])) {
if (!empty($r['abilita_serial'])) {
if (!empty($mancanti)) {
echo '
<br><b><small class="text-danger">'.tr('_NUM_ serial mancanti', [
@ -137,7 +136,7 @@ foreach ($righe as $row) {
<br>'.Modules::link($id_module, $record['ref_documento'], $text, $text);
}
$ref = doc_references($riga, $dir, ['iddocumento']);
$ref = doc_references($r, $dir, ['iddocumento']);
if (!empty($ref)) {
echo '
<br>'.Modules::link($ref['module'], $ref['id'], $ref['description'], $ref['description']);
@ -149,9 +148,9 @@ foreach ($righe as $row) {
echo '
<td class="text-center">';
if (!$row->isDescrizione()) {
if (!$riga->isDescrizione()) {
echo '
'.Translator::numberToLocale($riga['qta'], 'qta');
'.Translator::numberToLocale($r['qta'], 'qta');
}
echo '
@ -161,9 +160,9 @@ foreach ($righe as $row) {
echo '
<td class="text-center">';
if (!$row->isDescrizione()) {
if (!$riga->isDescrizione()) {
echo '
'.$riga['um'];
'.$r['um'];
}
echo '
@ -173,24 +172,24 @@ foreach ($righe as $row) {
echo '
<td class="text-right">';
if (!$row->isDescrizione()) {
if (!$riga->isDescrizione()) {
echo '
'.moneyFormat($row->prezzo_unitario_vendita);
'.moneyFormat($riga->prezzo_unitario_vendita);
if ($dir == 'entrata' && $row->prezzo_unitario_acquisto != 0) {
if ($dir == 'entrata' && $riga->prezzo_unitario_acquisto != 0) {
echo '
<br><small>
'.tr('Acquisto').': '.moneyFormat($row->prezzo_unitario_acquisto).'
'.tr('Acquisto').': '.moneyFormat($riga->prezzo_unitario_acquisto).'
</small>';
}
if (abs($row->sconto_unitario) > 0) {
$text = $row->sconto_unitario > 0 ? tr('sconto _TOT_ _TYPE_') : tr('maggiorazione _TOT_ _TYPE_');
if (abs($riga->sconto_unitario) > 0) {
$text = $riga->sconto_unitario > 0 ? tr('sconto _TOT_ _TYPE_') : tr('maggiorazione _TOT_ _TYPE_');
echo '
<br><small class="label label-danger">'.replace($text, [
'_TOT_' => Translator::numberToLocale(abs($row->sconto_unitario)),
'_TYPE_' => ($row->tipo_sconto == 'PRC' ? '%' : currency()),
'_TOT_' => Translator::numberToLocale(abs($riga->sconto_unitario)),
'_TYPE_' => ($riga->tipo_sconto == 'PRC' ? '%' : currency()),
]).'</small>';
}
}
@ -202,10 +201,10 @@ foreach ($righe as $row) {
echo '
<td class="text-right">';
if (!$row->isDescrizione()) {
if (!$riga->isDescrizione()) {
echo '
'.moneyFormat($riga['iva']).'
<br><small class="'.(($row->aliquota->deleted_at) ? 'text-red' : '').' help-block">'.$row->aliquota->descrizione.(($row->aliquota->esente) ? ' ('.$row->aliquota->codice_natura_fe.')' : null).'</small>';
'.moneyFormat($r['iva']).'
<br><small class="'.(($riga->aliquota->deleted_at) ? 'text-red' : '').' help-block">'.$riga->aliquota->descrizione.(($riga->aliquota->esente) ? ' ('.$riga->aliquota->codice_natura_fe.')' : null).'</small>';
}
echo '
@ -214,9 +213,9 @@ foreach ($righe as $row) {
// Importo
echo '
<td class="text-right">';
if (!$row->isDescrizione()) {
if (!$riga->isDescrizione()) {
echo '
'.moneyFormat($riga['totale_imponibile']);
'.moneyFormat($r['totale_imponibile']);
}
echo '
</td>';
@ -225,36 +224,37 @@ foreach ($righe as $row) {
echo '
<td class="text-center">';
if ($record['stato'] != 'Pagato' && $record['stato'] != 'Emessa' && $riga['id'] != $fattura->rigaBollo->id) {
if ($record['stato'] != 'Pagato' && $record['stato'] != 'Emessa' && $r['id'] != $fattura->rigaBollo->id) {
echo "
<form action='".$rootdir.'/editor.php?id_module='.$id_module.'&id_record='.$id_record."' method='post' id='delete-form-".$riga['id']."' role='form'>
<form action='".$rootdir.'/editor.php?id_module='.$id_module.'&id_record='.$id_record."' method='post' id='delete-form-".$r['id']."' role='form'>
<input type='hidden' name='backto' value='record-edit'>
<input type='hidden' name='idriga' value='".$riga['id']."'>
<input type='hidden' name='idriga' value='".$r['id']."'>
<input type='hidden' name='type' value='".get_class($riga)."'>
<input type='hidden' name='op' value='".$delete."'>";
if ($row->isArticolo()) {
if ($riga->isArticolo()) {
echo "
<input type='hidden' name='idarticolo' value='".$riga['idarticolo']."'>";
<input type='hidden' name='idarticolo' value='".$r['idarticolo']."'>";
}
echo "
<div class='input-group-btn'>";
if (!$fattura->isNota() && $row->isArticolo() && $riga['abilita_serial'] && (empty($riga['idddt']) || empty($riga['idintervento']))) {
if (!$fattura->isNota() && $riga->isArticolo() && $r['abilita_serial'] && (empty($r['idddt']) || empty($r['idintervento']))) {
echo "
<a class='btn btn-primary btn-xs'data-toggle='tooltip' title='Aggiorna SN...' onclick=\"launch_modal( 'Aggiorna SN', '".$structure->fileurl('add_serial.php').'?id_module='.$id_module.'&id_record='.$id_record.'&idriga='.$riga['id'].'&idarticolo='.$riga['idarticolo']."');\"><i class='fa fa-barcode' aria-hidden='true'></i></a>";
<a class='btn btn-primary btn-xs'data-toggle='tooltip' title='Aggiorna SN...' onclick=\"launch_modal( 'Aggiorna SN', '".$structure->fileurl('add_serial.php').'?id_module='.$id_module.'&id_record='.$id_record.'&idriga='.$r['id'].'&idarticolo='.$r['idarticolo']."');\"><i class='fa fa-barcode' aria-hidden='true'></i></a>";
}
echo "
<a class='btn btn-xs btn-info' title='".tr('Aggiungi informazioni FE per questa riga...')."' data-toggle='modal' data-title='".tr('Dati Fattura Elettronica')."' data-href='".$structure->fileurl('fe/row-fe.php').'?id_module='.$id_module.'&id_record='.$id_record.'&idriga='.$riga['id']."'>
<a class='btn btn-xs btn-info' title='".tr('Aggiungi informazioni FE per questa riga...')."' data-toggle='modal' data-title='".tr('Dati Fattura Elettronica')."' data-href='".$structure->fileurl('fe/row-fe.php').'?id_module='.$id_module.'&id_record='.$id_record.'&idriga='.$r['id'].'&type='.urlencode(get_class($riga))."'>
<i class='fa fa-file-code-o '></i>
</a>
<a class='btn btn-xs btn-warning' title='".tr('Modifica questa riga...')."' onclick=\"launch_modal( 'Modifica riga', '".$structure->fileurl('row-edit.php').'?id_module='.$id_module.'&id_record='.$id_record.'&idriga='.$riga['id']."');\">
<a class='btn btn-xs btn-warning' title='".tr('Modifica questa riga...')."' onclick=\"launch_modal( 'Modifica riga', '".$structure->fileurl('row-edit.php').'?id_module='.$id_module.'&id_record='.$id_record.'&idriga='.$r['id'].'&type='.urlencode(get_class($riga))."');\">
<i class='fa fa-edit'></i>
</a>
<a class='btn btn-xs btn-danger' title='".tr('Rimuovi questa riga...')."' onclick=\"if( confirm('".tr('Rimuovere questa riga dalla fattura?')."') ){ $('#delete-form-".$riga['id']."').submit(); }\">
<a class='btn btn-xs btn-danger' title='".tr('Rimuovi questa riga...')."' onclick=\"if( confirm('".tr('Rimuovere questa riga dalla fattura?')."') ){ $('#delete-form-".$r['id']."').submit(); }\">
<i class='fa fa-trash'></i>
</a>
</div>

View File

@ -293,10 +293,10 @@ switch (post('op')) {
case 'delete_riga':
$id_riga = post('idriga');
$type = post('type');
$riga = $intervento->getRiga($type, $id_riga);
if (!empty($id_riga)) {
$riga = $intervento->getRighe()->find($id_riga);
if (!empty($riga)) {
try {
$riga->delete();

View File

@ -128,11 +128,11 @@ if (!$righe->isEmpty()) {
}
echo '
<button type="button" class="btn btn-warning btn-xs" data-toggle="tooltip" onclick="launch_modal(\''.tr('Modifica').'\', \''.$link.'?id_module='.$id_module.'&id_record='.$id_record.'&idriga='.$r['id'].'\');">
<button type="button" class="btn btn-warning btn-xs" data-toggle="tooltip" onclick="launch_modal(\''.tr('Modifica').'\', \''.$link.'?id_module='.$id_module.'&id_record='.$id_record.'&idriga='.$r['id'].'&type='.urlencode(get_class($riga)).'\');">
<i class="fa fa-edit"></i>
</button>
<button type="button" class="btn btn-danger btn-xs" data-toggle="tooltip" onclick="if(confirm(\''.tr('Eliminare questa riga?').'\')){ elimina_riga( \''.$r['id'].'\' ); }">
<button type="button" class="btn btn-danger btn-xs" data-toggle="tooltip" onclick="elimina_riga(\''.addslashes(get_class($riga)).'\', \''.$riga->id.'\');">
<i class="fa fa-trash"></i>
</button>
</td>';
@ -152,23 +152,26 @@ if (!$righe->isEmpty()) {
?>
<script type="text/javascript">
function elimina_riga( id ){
$.post(globals.rootdir + '/actions.php', {
op: 'delete_riga',
id_module: globals.id_module,
id_record: globals.id_record,
idriga: id
}, function(data, result){
if(result == 'success'){
// Ricarico le righe
$('#righe').load('<?php echo $module->fileurl('ajax_righe.php'); ?>?id_module=<?php echo $id_module; ?>&id_record=<?php echo $id_record; ?>');
function elimina_riga(type, id){
if(confirm('<?php echo tr('Eliminare questa riga?'); ?>')) {
$.post(globals.rootdir + '/actions.php', {
op: 'delete_riga',
id_module: globals.id_module,
id_record: globals.id_record,
type: type,
idriga: id,
}, function (data, result) {
if (result == 'success') {
// Ricarico le righe
$('#righe').load('<?php echo $module->fileurl('ajax_righe.php'); ?>?id_module=<?php echo $id_module; ?>&id_record=<?php echo $id_record; ?>');
// Ricarico la tabella dei costi
$('#costi').load('<?php echo $module->fileurl('ajax_costi.php'); ?>?id_module=<?php echo $id_module; ?>&id_record=<?php echo $id_record; ?>');
// Ricarico la tabella dei costi
$('#costi').load('<?php echo $module->fileurl('ajax_costi.php'); ?>?id_module=<?php echo $id_module; ?>&id_record=<?php echo $id_record; ?>');
// Toast
alertPush();
}
});
// Toast
alertPush();
}
});
}
}
</script>

View File

@ -17,7 +17,8 @@ $options = [
// Dati della riga
$id_riga = get('idriga');
$riga = $documento->getRighe()->find($id_riga);
$type = get('type');
$riga = $documento->getRiga($type, $id_riga);
$result = $riga->toArray();
$result['prezzo'] = $riga->prezzo_unitario_vendita;

View File

@ -227,10 +227,10 @@ switch (post('op')) {
// Scollegamento riga generica da ordine
case 'delete_riga':
$id_riga = post('idriga');
$type = post('type');
$riga = $ordine->getRiga($type, $id_riga);
if (!empty($id_riga)) {
$riga = $ordine->getRighe()->find($id_riga);
if (!empty($riga)) {
try {
$riga->delete();

View File

@ -18,7 +18,8 @@ $options = [
// Dati della riga
$id_riga = get('idriga');
$riga = $documento->getRighe()->find($id_riga);
$type = get('type');
$riga = $documento->getRiga($type, $id_riga);
$result = $riga->toArray();
$result['prezzo'] = $riga->prezzo_unitario_vendita;

View File

@ -2,7 +2,6 @@
include_once __DIR__.'/../../core.php';
// Mostro le righe dell'ordine
echo '
<table class="table table-striped table-hover table-condensed table-bordered">
<thead>
@ -19,17 +18,17 @@ echo '
<tbody class="sortable">';
$q = 'SELECT *, round(sconto_unitario,'.setting('Cifre decimali per importi').') AS sconto_unitario, round(sconto,'.setting('Cifre decimali per importi').') AS sconto, round(subtotale,'.setting('Cifre decimali per importi').') AS subtotale, (SELECT codice FROM mg_articoli WHERE mg_articoli.id=`or_righe_ordini`.`idarticolo`) AS codice FROM `or_righe_ordini` WHERE idordine='.prepare($id_record).' ORDER BY `order`';
$rs = $dbo->fetchArray($q);
// Righe documento
$righe = $ordine->getRighe();
foreach ($righe as $riga) {
$r = $riga->toArray();
if (!empty($rs)) {
foreach ($rs as $r) {
$extra = '';
$mancanti = 0;
$extra = '';
$mancanti = 0;
// Individuazione dei seriali
if (!empty($r['idarticolo']) && !empty($r['abilita_serial'])) {
$serials = array_column($dbo->fetchArray('SELECT serial FROM mg_prodotti WHERE serial IS NOT NULL AND id_riga_ordine='.prepare($r['id'])), 'serial');
// Individuazione dei seriali
if (!empty($r['idarticolo']) && !empty($r['abilita_serial'])) {
$serials = array_column($dbo->fetchArray('SELECT serial FROM mg_prodotti WHERE serial IS NOT NULL AND id_riga_ordine='.prepare($r['id'])), 'serial');
$mancanti = $r['qta'] - count($serials);
if ($mancanti > 0) {
@ -45,7 +44,7 @@ if (!empty($rs)) {
if (!empty($r['idarticolo'])) {
echo '
'.Modules::link('Articoli', $r['idarticolo'], $r['codice'].' - '.$r['descrizione']);
'.Modules::link('Articoli', $r['idarticolo'], $riga->articolo->codice.' - '.$r['descrizione']);
if (!empty($r['abilita_serial'])) {
if (!empty($mancanti)) {
@ -145,14 +144,9 @@ if (!empty($rs)) {
<input type='hidden' name='backto' value='record-edit'>
<input type='hidden' name='id_record' value='".$id_record."'>
<input type='hidden' name='idriga' value='".$r['id']."'>
<input type='hidden' name='dir' value='".$dir."'>
<input type='hidden' name='type' value='".get_class($riga)."'>
<input type='hidden' name='op' value='delete_riga'>";
if (!empty($r['idarticolo'])) {
echo "
<input type='hidden' name='idarticolo' value='".$r['idarticolo']."'>";
}
echo "
<div class='input-group-btn'>";
@ -163,7 +157,7 @@ if (!empty($rs)) {
}
echo "
<a class='btn btn-xs btn-warning' title='Modifica questa riga...' onclick=\"launch_modal( 'Modifica riga', '".$rootdir.'/modules/ordini/row-edit.php?id_module='.$id_module.'&id_record='.$id_record.'&idriga='.$r['id'].'&dir='.$dir."');\"><i class='fa fa-edit'></i></a>
<a class='btn btn-xs btn-warning' title='Modifica questa riga...' onclick=\"launch_modal( 'Modifica riga', '".$rootdir.'/modules/ordini/row-edit.php?id_module='.$id_module.'&id_record='.$id_record.'&idriga='.$r['id'].'&type='.urlencode(get_class($riga))."');\"><i class='fa fa-edit'></i></a>
<a class='btn btn-xs btn-danger' title='Rimuovi questa riga...' onclick=\"if( confirm('Rimuovere questa riga dall\\'ordine?') ){ $('#delete-form-".$r['id']."').submit(); }\"><i class='fa fa-trash'></i></a>
</div>
@ -180,7 +174,7 @@ if (!empty($rs)) {
</tr>';
}
}
echo '
</tbody>';

View File

@ -250,11 +250,11 @@ switch (post('op')) {
// Eliminazione riga
case 'delete_riga':
$id_riga = post('idriga');
if ($id_riga !== null) {
$riga = Descrizione::find($id_riga) ?: Riga::find($id_riga);
$riga = $riga ? $riga : Articolo::find($id_riga);
$riga = $riga ? $riga : Sconto::find($id_riga);
$type = post('type');
$riga = $preventivo->getRiga($type, $id_riga);
if (!empty($riga)) {
$riga->delete();
flash()->info(tr('Riga eliminata!'));

View File

@ -18,7 +18,8 @@ $options = [
// Dati della riga
$id_riga = get('idriga');
$riga = $documento->getRighe()->find($id_riga);
$type = get('type');
$riga = $documento->getRiga($type, $id_riga);
$result = $riga->toArray();
$result['prezzo'] = $riga->prezzo_unitario_vendita;

View File

@ -2,9 +2,6 @@
include_once __DIR__.'/../../core.php';
// Righe documento
$righe = $preventivo->getRighe();
echo '
<table class="table table-striped table-hover table-condensed table-bordered">
<thead>
@ -20,6 +17,8 @@ echo '
</thead>
<tbody class="sortable">';
// Righe documento
$righe = $preventivo->getRighe();
foreach ($righe as $riga) {
echo '
<tr data-id="'.$riga->id.'">';
@ -92,16 +91,15 @@ foreach ($righe as $riga) {
if (empty($record['is_completato'])) {
echo '
<form action="" method="post" id="delete-form-'.$riga->id.'" role="form">
<input type="hidden" name="backto" value="record-edit">
<input type="hidden" name="op" value="delete_riga">
<input type="hidden" name="idriga" value="'.$riga->id.'">
<div class="btn-group">
<a class="btn btn-xs btn-warning" onclick="editRow(\''.addslashes(get_class($riga)).'\', '.$riga->id.')">
<i class="fa fa-edit"></i>
</a>
<div class="btn-group">
<a class="btn btn-xs btn-warning" onclick="editRow('.$riga->id.')"><i class="fa fa-edit"></i></a>
<a class="btn btn-xs btn-danger" onclick="deleteRow('.$riga->id.')"><i class="fa fa-trash"></i></a>
</div>
</form>';
<a class="btn btn-xs btn-danger" onclick="deleteRow(\''.addslashes(get_class($riga)).'\', '.$riga->id.')">
<i class="fa fa-trash"></i>
</a>
</div>';
}
echo '
@ -119,13 +117,18 @@ echo '
echo '
<script>
function editRow(id){
launch_modal("'.tr('Modifica riga').'", "'.$module->fileurl('row-edit.php').'?id_module=" + globals.id_module + "&id_record=" + globals.id_record + "&idriga=" + id);
function editRow(type, id){
launch_modal("'.tr('Modifica riga').'", "'.$module->fileurl('row-edit.php').'?id_module=" + globals.id_module + "&id_record=" + globals.id_record + "&idriga=" + id + "&type=" + encodeURIComponent(type));
}
function deleteRow(id){
function deleteRow(type, id){
if(confirm("'.tr('Rimuovere questa riga dal documento?').'")){
$("#delete-form-" + id).submit();
redirect("", {
backto: "record-edit",
op: "delete_riga",
idriga: id,
type: type,
}, "post");
}
}
</script>';