openstamanager/modules/articoli/actions.php

247 lines
8.4 KiB
PHP
Raw Normal View History

<?php
include_once __DIR__.'/../../core.php';
switch (post('op')) {
// Aggiunta articolo
case 'add':
//Se non specifico il codice articolo lo imposto uguale all'id della riga
if (empty(post('codice'))) {
$codice = $dbo->fetchOne('SELECT (MAX(id)+1) as codice FROM mg_articoli')['codice'];
} else {
$codice = post('codice');
}
// Inserisco l'articolo e avviso se esiste un altro articolo con stesso codice.
2019-06-20 18:59:49 +02:00
if ($n = $dbo->fetchNum('SELECT * FROM mg_articoli WHERE codice='.prepare($codice)) > 0) {
flash()->warning(tr('Attenzione: il codice _CODICE_ è già stato utilizzato _N_ volta', [
'_CODICE_' => $codice,
'_N_' => $n,
]));
}
2018-07-19 17:48:02 +02:00
$dbo->insert('mg_articoli', [
'codice' => $codice,
'descrizione' => post('descrizione'),
'id_categoria' => post('categoria'),
'id_sottocategoria' => post('subcategoria'),
'attivo' => 1,
]);
$id_record = $dbo->lastInsertedID();
if (isAjaxRequest()) {
echo json_encode(['id' => $id_record, 'text' => post('descrizione')]);
}
2018-11-30 16:10:15 +01:00
2018-07-19 17:48:02 +02:00
flash()->info(tr('Aggiunto un nuovo articolo'));
break;
// Modifica articolo
case 'update':
$componente = post('componente_filename');
$qta = post('qta');
2019-06-20 18:59:49 +02:00
// Inserisco l'articolo e avviso se esiste un altro articolo con stesso codice.
if ($n = $dbo->fetchNum('SELECT * FROM mg_articoli WHERE codice='.prepare(post('codice')).' AND id != '.$id_record.'') > 0) {
flash()->warning(tr('Attenzione: il codice _CODICE_ è già stato utilizzato _N_ volta', [
'_CODICE_' => post('codice'),
'_N_' => $n,
]));
}
$dbo->update('mg_articoli', [
'codice' => post('codice'),
'descrizione' => post('descrizione'),
'um' => post('um'),
'id_categoria' => post('categoria'),
'id_sottocategoria' => post('subcategoria'),
'abilita_serial' => post('abilita_serial'),
'threshold_qta' => post('threshold_qta'),
'prezzo_vendita' => post('prezzo_vendita'),
'prezzo_acquisto' => post('prezzo_acquisto'),
2018-07-09 17:21:25 +02:00
'idconto_vendita' => post('idconto_vendita'),
'idconto_acquisto' => post('idconto_acquisto'),
'idiva_vendita' => post('idiva_vendita'),
'gg_garanzia' => post('gg_garanzia'),
'servizio' => post('servizio'),
'volume' => post('volume'),
'peso_lordo' => post('peso_lordo'),
'componente_filename' => $componente,
'attivo' => post('attivo'),
'note' => post('note'),
], ['id' => $id_record]);
// Leggo la quantità attuale per capire se l'ho modificata
2018-07-18 15:20:10 +02:00
$old_qta = $record['qta'];
$movimento = $qta - $old_qta;
if ($movimento != 0) {
2018-05-11 15:11:01 +02:00
$descrizione_movimento = post('descrizione_movimento');
$data_movimento = post('data_movimento');
add_movimento_magazzino($id_record, $movimento, [], $descrizione_movimento, $data_movimento);
}
// Salvataggio info componente (campo `contenuto`)
if (!empty($componente)) {
$contenuto = \Util\Ini::write(file_get_contents($docroot.'/files/my_impianti/'.$componente), $post);
$dbo->query('UPDATE mg_articoli SET contenuto='.prepare($contenuto).' WHERE id='.prepare($id_record));
}
// Upload file
2018-07-10 16:39:02 +02:00
if (!empty($_FILES) && !empty($_FILES['immagine']['name'])) {
$filename = Uploads::upload($_FILES['immagine'], [
'name' => 'Immagine',
'id_module' => $id_module,
'id_record' => $id_record,
], [
'thumbnails' => true,
]);
if (!empty($filename)) {
2018-07-10 16:39:02 +02:00
$dbo->update('mg_articoli', [
'immagine' => $filename,
], [
'id' => $id_record,
]);
} else {
2018-07-19 17:29:21 +02:00
flash()->warning(tr('Errore durante il caricamento del file in _DIR_!', [
'_DIR_' => $upload_dir,
]));
}
}
// Eliminazione file
2018-07-10 16:39:02 +02:00
if (post('delete_immagine') !== null) {
2018-07-18 15:20:10 +02:00
Uploads::delete($record['immagine'], [
'id_module' => $id_module,
'id_record' => $id_record,
]);
2018-07-10 16:39:02 +02:00
$dbo->update('mg_articoli', [
'immagine' => null,
], [
'id' => $id_record,
]);
}
2018-07-19 17:29:21 +02:00
flash()->info(tr('Informazioni salvate correttamente!'));
break;
2018-09-26 15:37:46 +02:00
// Duplica articolo
2018-07-19 17:48:02 +02:00
case 'copy':
2019-04-19 20:52:02 +02:00
$new = $articolo->replicate();
$new->qta = 0;
$new->save();
2018-09-26 15:37:46 +02:00
flash()->info(tr('Articolo duplicato correttamente!'));
2018-07-19 17:48:02 +02:00
break;
2019-08-28 11:52:04 +02:00
// Generazione seriali in sequenza
case 'generate_serials':
// Seriali
$serial_start = post('serial_start');
$serial_end = post('serial_end');
preg_match("/(.*?)([\d]*$)/", $serial_start, $m);
$numero_start = intval($m[2]);
preg_match("/(.*?)([\d]*$)/", $serial_end, $m);
$numero_end = intval($m[2]);
$totale = abs($numero_end - $numero_start) + 1;
$prefix = rtrim($serial_end, $numero_end);
$pad_length = strlen($serial_end) - strlen($prefix);
// Combinazione di seriali
$serials = [];
for ($s = 0; $s < $totale; ++$s) {
$serial = $prefix.(str_pad($numero_start + $s, $pad_length, '0', STR_PAD_LEFT));
$serials[] = $serial;
}
2019-08-28 11:52:04 +02:00
case 'add_serials':
$serials = $serials ?: filter('serials');
$count = $dbo->attach('mg_prodotti', ['id_articolo' => $id_record, 'dir' => 'uscita'], ['serial' => $serials]);
// Movimento il magazzino se l'ho specificato nelle impostazioni
if (setting("Movimenta il magazzino durante l'inserimento o eliminazione dei lotti/serial number")) {
add_movimento_magazzino($id_record, $count, [], tr('Carico magazzino con serial da _INIZIO_ a _FINE_', [
'_INIZIO_' => $serial_start,
'_FINE_' => $serial_end,
]));
}
2017-09-12 18:14:42 +02:00
2019-08-28 11:52:04 +02:00
flash()->info(tr('Aggiunti _NUM_ seriali!', [
'_NUM_' => $count,
]));
if ($count != $totale) {
flash()->warning(tr('Alcuni seriali erano già presenti') . '...');
2017-09-12 18:14:42 +02:00
}
break;
case 'delprodotto':
$idprodotto = post('idprodotto');
// Leggo info prodotto per descrizione mg_movimenti
$rs = $dbo->fetchArray('SELECT lotto, serial, altro FROM mg_prodotti WHERE id='.prepare($idprodotto));
$query = 'DELETE FROM mg_prodotti WHERE id='.prepare($idprodotto);
if ($dbo->query($query)) {
// Movimento il magazzino se l'ho specificato nelle impostazioni
2018-07-08 18:11:17 +02:00
if (setting("Movimenta il magazzino durante l'inserimento o eliminazione dei lotti/serial number")) {
add_movimento_magazzino($id_record, -1, [], tr('Eliminazione dal magazzino del prodotto con serial _SERIAL_', [
'_SERIAL_' => $rs[0]['serial'],
]));
}
2018-07-19 17:29:21 +02:00
flash()->info(tr('Prodotto rimosso!'));
}
break;
case 'delmovimento':
$idmovimento = post('idmovimento');
// Lettura qtà movimento
$rs = $dbo->fetchArray('SELECT idarticolo, qta FROM mg_movimenti WHERE id='.prepare($idmovimento));
$qta = $rs[0]['qta'];
$idarticolo = $rs[0]['idarticolo'];
// Aggiorno la quantità dell'articolo
$dbo->query('UPDATE mg_articoli SET qta=qta-'.$qta.' WHERE id='.prepare($idarticolo));
$query = 'DELETE FROM mg_movimenti WHERE id='.prepare($idmovimento);
if ($dbo->query($query)) {
2018-07-19 17:29:21 +02:00
flash()->info(tr('Movimento rimosso!'));
}
break;
case 'delete':
2019-08-26 11:10:59 +02:00
$articolo->delete();
2018-07-19 17:29:21 +02:00
flash()->info(tr('Articolo eliminato!'));
break;
}
// Operazioni aggiuntive per l'immagine
2018-07-18 15:20:10 +02:00
if (filter('op') == 'unlink_file' && filter('filename') == $record['immagine']) {
2018-07-04 12:57:53 +02:00
$dbo->update('mg_articoli', [
2018-07-10 16:39:02 +02:00
'immagine' => null,
2018-07-04 12:57:53 +02:00
], [
'id' => $id_record,
]);
} elseif (filter('op') == 'link_file' && filter('nome_allegato') == 'Immagine') {
$dbo->update('mg_articoli', [
2018-07-10 16:39:02 +02:00
'immagine' => $upload,
2018-07-04 12:57:53 +02:00
], [
'id' => $id_record,
]);
}