. */ include_once __DIR__.'/../../../core.php'; $record['abilita_serial'] = ($record['serial'] > 0) ? 1 : $record['abilita_serial']; if (empty($record['abilita_serial'])) { echo ' '; } // Visualizzo, in base alle impostazioni scelte, se il magazzino verrà movimentato $message = setting("Movimenta il magazzino durante l'inserimento o eliminazione dei lotti/serial number") ? tr("L'inserimento e la rimozione dei seriali modificherà la quantità dell'articolo!") : tr("L'inserimento e la rimozione dei seriali non movimenterà la quantità dell'articolo!"); echo '
'.$message.'
'; // Inserimento seriali echo ' '; // Elenco if (empty(get('modal'))) { echo '

'.tr('Elenco seriali').'

'; // Conteggio totale prodotti $rs = $dbo->fetchArray('SELECT COUNT(id) AS tot FROM mg_prodotti WHERE id_articolo='.prepare($id_record)); $tot_prodotti = $rs[0]['tot']; // Visualizzazione di tutti i prodotti $search_serial = get('search_serial'); $query = 'SELECT id, serial, created_at FROM mg_prodotti WHERE serial IS NOT NULL AND id_articolo='.prepare($id_record).(!empty($search_serial) ? ' AND serial LIKE '.prepare('%'.$search_serial.'%') : '').' GROUP BY serial ORDER BY created_at DESC, serial DESC, lotto DESC, altro DESC'; $rs2 = $dbo->fetchArray($query); echo ' '; for ($i = 0; $i < count($rs2); ++$i) { echo ' '; echo ' '; // Ricerca acquisti $acquisti = $dbo->fetchArray('SELECT * FROM mg_prodotti WHERE dir=\'uscita\' AND id_articolo='.prepare($id_record).' AND (id_riga_documento IS NOT NULL OR id_riga_ordine IS NOT NULL OR id_riga_ddt IS NOT NULL) AND serial='.prepare($rs2[$i]['serial'])); if (!empty($acquisti)) { echo ' '; } // Non venduto else { echo ' '; } // Ricerca vendite $vendite = $dbo->fetchArray('SELECT * FROM mg_prodotti WHERE dir=\'entrata\' AND id_articolo='.prepare($id_record).' AND serial='.prepare($rs2[$i]['serial'])); if (!empty($vendite)) { echo ' '; } // Non venduto else { // Documento di vendita echo ' '; } echo ' '; } echo '
'.tr('Serial').' '.tr('Data di creazione').' '.tr('Documento di acquisto').' '.tr('Prezzo di acquisto').' '.tr('Documento di vendita').' '.tr('Prezzo di vendita').' #
'.$rs2[$i]['serial'].''.Translator::timestampToLocale($rs2[$i]['created_at']).''; $totali = []; foreach ($acquisti as $acquisto) { // Acquistato su fatture if (!empty($acquisto['id_riga_documento'])) { $module_id = Modules::get('Fatture di acquisto')['id']; // Ricerca vendite su fatture $query = 'SELECT *, `co_tipidocumento_lang`.`name` AS tipo_documento, `co_tipidocumento`.`dir`, `co_documenti`.`numero`, `co_documenti`.`numero_esterno`, `co_documenti`.`data` FROM `co_righe_documenti` INNER JOIN `co_documenti` ON `co_righe_documenti`.`iddocumento` = `co_documenti`.`id` INNER JOIN `co_tipidocumento` ON `co_documenti`.`idtipodocumento` = `co_tipidocumento`.`id` LEFT JOIN `co_tipidocumento_lang` ON (`co_tipidocumento`.`id` = `co_tipidocumento_lang`.`id_record` AND `co_tipidocumento_lang`.`id_lang` = '.prepare(setting('Lingua')).') WHERE `co_righe_documenti`.`id`='.prepare($acquisto['id_riga_documento']); $data = $dbo->fetchArray($query); $id = $data[0]['iddocumento']; } // Acquistato su ddt elseif (!empty($acquisto['id_riga_ddt'])) { $module_id = Modules::get('Ddt di acquisto')['id']; $query = 'SELECT *, ( SELECT descrizione FROM dt_tipiddt WHERE id=(SELECT idtipoddt FROM dt_ddt WHERE id=idddt) ) AS tipo_documento, ( SELECT `dir` FROM dt_tipiddt WHERE id=(SELECT idtipoddt FROM dt_ddt WHERE id=idddt) ) AS `dir`, ( SELECT numero FROM dt_ddt WHERE id=idddt ) AS numero, ( SELECT numero_esterno FROM dt_ddt WHERE id=idddt ) AS numero_esterno, ( SELECT data FROM dt_ddt WHERE id=idddt ) AS data FROM dt_righe_ddt WHERE dt_righe_ddt.id='.prepare($acquisto['id_riga_ddt']); $data = $dbo->fetchArray($query); $id = $data[0]['idddt']; } // Inserito su ordini elseif (!empty($acquisto['id_riga_ordine'])) { $module_id = Modules::get('Ordini cliente')['id']; // Ricerca inserimenti su ordini $query = 'SELECT *, ( SELECT descrizione FROM or_tipiordine WHERE id=(SELECT idtipoordine FROM or_ordini WHERE id=idordine) ) AS tipo_documento, ( SELECT `dir` FROM or_tipiordine WHERE id=(SELECT idtipoordine FROM or_ordini WHERE id=idordine) ) AS `dir`, ( SELECT numero FROM or_ordini WHERE id=idordine ) AS numero, ( SELECT numero_esterno FROM or_ordini WHERE id=idordine ) AS numero_esterno, ( SELECT data FROM or_ordini WHERE id=idordine ) AS data FROM or_righe_ordini WHERE or_righe_ordini.id='.prepare($acquisto['id_riga_ordine']); $data = $dbo->fetchArray($query); $id = $data[0]['idordine']; } $totali[] = [$data[0]['prezzo_unitario'] - $data[0]['sconto_unitario'], $data[0]['iva_unitaria']]; $numero = !empty($data[0]['numero_esterno']) ? $data[0]['numero_esterno'] : $data[0]['numero']; $text = tr('_DOC_ num. _NUM_ del _DATE_', [ '_DOC_' => $data[0]['tipo_documento'], '_NUM_' => $numero, '_DATE_' => Translator::dateToLocale($data[0]['data']), ]).(!empty($extra) ? ' '.$extra : ''); echo Modules::link($module_id, $id, $text).'
'; } echo '
'; foreach ($totali as $value) { $subtotale = $value[0]; $iva = $value[1]; echo ' '.moneyFormat($subtotale + $iva).''; if (!empty($subtotale) && !empty($iva)) { echo ' ('.Translator::numberToLocale($subtotale).' + '.Translator::numberToLocale($iva).')'; } echo '
'; } echo '
'; $totali = []; foreach ($vendite as $vendita) { // Venduto su fatture if (!empty($vendita['id_riga_documento'])) { $module_id = Modules::get('Fatture di vendita')['id']; // Ricerca vendite su fatture $query = 'SELECT *, `co_tipidocumento_lang`.`name` AS tipo_documento, `co_tipidocumento`.`dir`, `co_documenti`.`numero`, `co_documenti`.`numero_esterno`,`co_documenti`.`data` FROM `co_righe_documenti` INNER JOIN `co_documenti` ON `co_righe_documenti`.`iddocumento`=`co_documenti`.`id` INNER JOIN `co_tipidocumento` ON `co_documenti`.`idtipodocumento`=`co_tipidocumento`.`id` LEFT JOIN `co_tipidocumento_lang` ON (`co_tipidocumento`.`id`=`co_tipidocumento_lang`.`id_record` AND `co_tipidocumento_lang`.`id_lang`='.prepare(setting('Lingua')).') WHERE `co_righe_documenti`.`id`='.prepare($vendita['id_riga_documento']); $data = $dbo->fetchArray($query); $id = $data[0]['iddocumento']; } // Venduto su ddt elseif (!empty($vendita['id_riga_ddt'])) { $module_id = Modules::get('Ddt di vendita')['id']; $query = 'SELECT *, ( SELECT descrizione FROM dt_tipiddt WHERE id=(SELECT idtipoddt FROM dt_ddt WHERE id=idddt) ) AS tipo_documento, ( SELECT `dir` FROM dt_tipiddt WHERE id=(SELECT idtipoddt FROM dt_ddt WHERE id=idddt) ) AS `dir`, ( SELECT numero FROM dt_ddt WHERE id=idddt ) AS numero, ( SELECT numero_esterno FROM dt_ddt WHERE id=idddt ) AS numero_esterno, ( SELECT data FROM dt_ddt WHERE id=idddt ) AS data FROM dt_righe_ddt WHERE dt_righe_ddt.id='.prepare($vendita['id_riga_ddt']); $data = $dbo->fetchArray($query); $id = $data[0]['idddt']; } // Inserito su ordini elseif (!empty($vendita['id_riga_ordine'])) { $module_id = Modules::get('Ordini cliente')['id']; // Ricerca inserimenti su ordini $query = 'SELECT *, ( SELECT descrizione FROM or_tipiordine WHERE id=(SELECT idtipoordine FROM or_ordini WHERE id=idordine) ) AS tipo_documento, ( SELECT `dir` FROM or_tipiordine WHERE id=(SELECT idtipoordine FROM or_ordini WHERE id=idordine) ) AS `dir`, ( SELECT numero FROM or_ordini WHERE id=idordine ) AS numero, ( SELECT numero_esterno FROM or_ordini WHERE id=idordine ) AS numero_esterno, ( SELECT data FROM or_ordini WHERE id=idordine ) AS data FROM or_righe_ordini WHERE or_righe_ordini.id='.prepare($vendita['id_riga_ordine']); $data = $dbo->fetchArray($query); $id = $data[0]['idordine']; } // Inserito su intervento elseif (!empty($vendita['id_riga_intervento'])) { $module_id = Modules::get('Interventi')['id']; // Ricerca inserimenti su interventi $query = 'SELECT in_righe_interventi.*, in_interventi.codice, ( SELECT orario_inizio FROM in_interventi_tecnici WHERE idintervento=in_righe_interventi.idintervento LIMIT 0,1 ) AS data FROM in_righe_interventi JOIN in_interventi ON in_interventi.id = in_righe_interventi.idintervento WHERE in_righe_interventi.id='.prepare($vendita['id_riga_intervento']); $data = $dbo->fetchArray($query); $id = $data[0]['idintervento']; $data[0]['tipo_documento'] = tr('Intervento').' '.$data[0]['codice']; } // Inserito su contratto elseif (!empty($vendita['id_riga_contratto'])) { $module_id = Modules::get('Contratti')['id']; // Ricerca vendite su contratti $query = 'SELECT *, "Contratto" AS tipo_documento, ( SELECT data_bozza FROM co_contratti WHERE id=idcontratto ) AS data, ( SELECT numero FROM co_contratti WHERE id=idcontratto ) AS numero FROM co_righe_contratti WHERE co_righe_contratti.id='.prepare($vendita['id_riga_contratto']); $data = $dbo->fetchArray($query); $id = $data[0]['idcontratto']; } // Inserito su vendita banco elseif (!empty($vendita['id_riga_venditabanco'])) { $module_id = Modules::get('Vendita al banco')['id']; // Ricerca vendite su contratti $query = 'SELECT *, "Vendita al banco" AS tipo_documento, ( SELECT data FROM vb_venditabanco WHERE id=idvendita ) AS data, ( SELECT numero FROM vb_venditabanco WHERE id=idvendita ) AS numero FROM vb_righe_venditabanco WHERE vb_righe_venditabanco.id='.prepare($vendita['id_riga_venditabanco']); $data = $dbo->fetchArray($query); $id = $data[0]['idvendita']; } $totali[] = [$data[0]['prezzo_unitario'] - $data[0]['sconto_unitario'], $data[0]['iva_unitaria']]; $numero = !empty($data[0]['numero_esterno']) ? $data[0]['numero_esterno'] : $data[0]['numero']; $text = tr('_DOC_ num. _NUM_ del _DATE_', [ '_DOC_' => $data[0]['tipo_documento'], '_NUM_' => $numero, '_DATE_' => Translator::dateToLocale($data[0]['data']), ]); echo Modules::link($module_id, $id, $text).'
'; } echo '
'; foreach ($totali as $value) { $subtotale = $value[0]; $iva = $value[1]; echo ' '.moneyFormat($subtotale + $iva).''; if (!empty($subtotale) && !empty($iva)) { echo ' ('.Translator::numberToLocale($subtotale).' + '.Translator::numberToLocale($iva).')'; } echo '
'; } echo '
'; } echo ' ';