openstamanager/plugins/listino_fornitori/edit.php

242 lines
8.6 KiB
PHP
Raw Normal View History

<?php
/*
* OpenSTAManager: il software gestionale open source per l'assistenza tecnica e la fatturazione
* Copyright (C) DevCode s.r.l.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
2024-03-22 15:52:24 +01:00
use Models\Module;
use Plugins\ListinoClienti\DettaglioPrezzo;
use Plugins\ListinoFornitori\DettaglioFornitore;
include_once __DIR__.'/../../core.php';
$id_articolo = $id_record;
echo '
2024-05-16 18:02:50 +02:00
<div class="card">
<div class="card-header">
<h3 class="card-title">'.tr('Informazioni specifiche per fornitore').'</h3>
</div>
2024-05-16 18:02:50 +02:00
<div class="card-body">
<div class="row">
<div class="col-md-9">
2024-04-18 17:44:05 +02:00
{[ "type": "select", "label": "'.tr('Fornitore').'", "name": "id_fornitore_informazioni", "required":"1", "ajax-source": "fornitori","icon-after": "add|'.(new Module())->getByField('title', 'Anagrafiche', Models\Locale::getPredefined()->id).'|tipoanagrafica=Fornitore&readonly_tipo=1" ]}
</div>
<div class="col-md-3">
<div class="btn-group btn-group-flex">
2023-03-24 12:06:58 +01:00
<button type="button" class="btn btn-info" style="margin-top:25px;" onclick="aggiungiFornitorePrezzi(this)">
2023-04-11 14:41:45 +02:00
<i class="fa fa-money"></i> '.tr('Aggiungi prezzi e fornitore').'
</button>
</div>
</div>
</div>
</div>
</div>
<h4>'.tr('Elenco fornitori').'</h4>';
$dettagli_fornitori = DettaglioFornitore::where('id_articolo', $id_record)->get()
2024-04-09 12:18:08 +02:00
->mapToGroups(fn ($item, $key) => [$item->id_fornitore => $item]);
$prezzi_fornitori = DettaglioPrezzo::where('id_articolo', $id_articolo)
->where('dir', 'uscita')
->get()
->groupBy('id_anagrafica');
$fornitori_disponibili = $dettagli_fornitori->keys()
->merge($prezzi_fornitori->keys())
->unique();
if (!$fornitori_disponibili->isEmpty()) {
echo '
<table class="table table-striped table-condensed table-bordered">
<tbody>';
foreach ($fornitori_disponibili as $id_fornitore) {
$dettaglio = $dettagli_fornitori[$id_fornitore] ? $dettagli_fornitori[$id_fornitore]->first() : null;
$prezzi = $prezzi_fornitori[$id_fornitore];
$anagrafica = $dettaglio ? $dettaglio->anagrafica : $prezzi->first()->anagrafica;
echo '
<tr>
<th>'.tr('Fornitore').'</th>
<th>'.tr('Descrizione').'</th>
<th width="150">'.tr('Codice').'</th>
<th width="150">'.tr('Barcode').'</th>
<th class="text-center" width="210">'.tr('Q. minima ordinabile').'</th>
<th class="text-center" width="150">'.tr('Tempi di consegna').'</th>
<th class="text-center" width="150">#</th>
</tr>
<tr data-id_anagrafica="'.$anagrafica->id.'" data-direzione="uscita" '.(($anagrafica->id == $articolo->id_fornitore) ? 'class="success"' : '').'>
<td>
'.Modules::link('Anagrafiche', $anagrafica->id, $anagrafica->ragione_sociale).'
</td>';
if (!empty($dettaglio)) {
echo '
<td>
'.$dettaglio['descrizione'].'
</td>
<td class="text-center">
'.$dettaglio['codice_fornitore'].'
</td>
<td class="text-center">
'.$dettaglio['barcode_fornitore'].'
</td>
<td class="text-right">
'.numberFormat($dettaglio['qta_minima']).' '.$articolo->um.'
</td>
<td class="text-right">
'.tr('_NUM_ gg', [
2024-03-22 15:52:24 +01:00
'_NUM_' => numberFormat($dettaglio['giorni_consegna'], 0),
]).'
</td>';
} else {
echo '
<td>-</td>
<td class="text-center">-</td>
<td class="text-center">-</td>
<td class="text-right">-</td>
<td class="text-right">-</td>';
}
echo '
<td class="text-center">
<button type="button" class="btn btn-xs btn-warning" onclick="modificaPrezzi(this)">
<i class="fa fa-money"></i>
</button>';
if (!empty($dettaglio)) {
echo '
<a class="btn btn-secondary btn-xs btn-warning" onclick="modificaFornitore('.$dettaglio['id'].', '.$anagrafica->id.')">
<i class="fa fa-edit"></i>
</a>
<a class="btn btn-secondary btn-xs btn-danger ask" data-op="delete_fornitore" data-id_riga="'.$dettaglio['id'].'" data-id_plugin="'.$id_plugin.'" data-backto="record-edit">
<i class="fa fa-trash-o"></i>
</a>';
}
echo '
</td>
</tr>';
/*
$dettaglio_predefinito = $prezzi->whereStrict('minimo', null)
->whereStrict('massimo', null)
->first();
$prezzi = $prezzi->reject(function ($item, $key) use ($dettaglio_predefinito) {
return $item->id == $dettaglio_predefinito->id;
});
*/
if (!empty($prezzi) && !$prezzi->isEmpty()) {
echo '
<tr>
<td colspan="2"></td>
<th class="text-center">'.tr('Q. minima').'</th>
<th class="text-center">'.tr('Q. massima').'</th>
<th class="text-center">'.tr('Prezzo unitario').'</th>
<th class="text-center">'.tr('Sconto').'</th>
<td></td>
</tr>';
foreach ($prezzi as $key => $dettaglio) {
echo '
<tr '.(($anagrafica->id == $articolo->id_fornitore) ? 'class="success"' : '').'>
<td colspan="2"></td>
<td class="text-right">
'.($dettaglio->minimo ? numberFormat($dettaglio->minimo) : '-').'
</td>
<td class="text-right">
'.($dettaglio->massimo ? numberFormat($dettaglio->massimo) : '-').'
</td>
<td class="text-right">
'.moneyFormat($dettaglio->prezzo_unitario).'
2024-05-16 18:02:50 +02:00
<p><span class="right badge badge-default tip" title="'.Translator::timestampToLocale($dettaglio['updated_at']).'"><i class="fa fa-clock-o"></i> '.$dettaglio->updated_at->diffForHumans().'</small></p>
</td>
<td class="text-right">
'.numberFormat($dettaglio->sconto_percentuale).'%
</td>
<td>';
if (!isset($dettaglio->minimo) && !isset($dettaglio->massimo)) {
echo '
<span class="badge badge-primary">'.tr('Prezzo predefinito').'</span>';
}
echo '
</td>
</tr>';
}
}
}
echo '
</tbody>
</table>';
} else {
echo '
<div class="alert alert-info">
<i class="fa fa-info-circle"></i> '.tr('Nessuna informazione disponibile').'...
</div>';
}
echo '
<script>
function modificaFornitore(id_riga, id_anagrafica) {
openModal("Modifica dati fornitore", "'.$structure->fileurl('dettaglio_fornitore.php').'?id_plugin='.$id_plugin.'&id_module='.$id_module.'&id_parent='.$id_record.'&id_articolo='.$id_record.'&id_riga=" + id_riga + "&id_anagrafica=" + id_anagrafica);
}
function aggiungiFornitore() {
let id_fornitore = $("#id_fornitore_informazioni").val();
if (id_fornitore) {
modificaFornitore("", id_fornitore);
} else {
swal("'.tr('Attenzione').'", "'.tr('Inserire un\'anagrafica').'", "warning");
}
}
2023-03-24 12:06:58 +01:00
function modificaFornitorePrezzi(id_anagrafica, direzione) {
openModal("'.tr('Gestisci prezzi specifici fornitore').'", "'.$structure->fileurl('dettaglio_prezzi_fornitore.php').'?id_plugin='.$id_plugin.'&id_module='.$id_module.'&id_parent='.$id_record.'&id_articolo='.$id_record.'&id_anagrafica=" + id_anagrafica + "&direzione=" + direzione);
}
function aggiungiFornitorePrezzi(button) {
2024-05-16 18:02:50 +02:00
let card = $(button).closest(".box");
2023-03-24 12:06:58 +01:00
let direzione = "uscita"
2024-05-16 18:02:50 +02:00
let id_anagrafica = card.find("select").val();
2023-03-24 12:06:58 +01:00
if (id_anagrafica) {
modificaFornitorePrezzi(id_anagrafica, direzione);
} else {
swal("'.tr('Attenzione').'", "'.tr('Inserire un\'anagrafica').'", "warning");
}
}
</script>';