mirror of
https://github.com/devcode-it/openstamanager.git
synced 2025-01-07 21:32:22 +01:00
300 lines
15 KiB
PHP
Executable File
300 lines
15 KiB
PHP
Executable File
<?php
|
|
/*
|
|
* OpenSTAManager: il software gestionale open source per l'assistenza tecnica e la fatturazione
|
|
* Copyright (C) DevCode s.n.c.
|
|
*
|
|
* 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/>.
|
|
*/
|
|
|
|
include_once __DIR__.'/../../../core.php';
|
|
|
|
switch ($resource) {
|
|
/*
|
|
* Opzioni utilizzate:
|
|
* - permetti_movimento_a_zero
|
|
* - idsede_partenza e idsede_destinazione
|
|
* - dir
|
|
* - idanagrafica
|
|
*/
|
|
case 'articoli':
|
|
$sedi_non_impostate = !isset($superselect['idsede_partenza']) && !isset($superselect['idsede_destinazione']);
|
|
$prezzi_ivati = setting('Utilizza prezzi di vendita comprensivi di IVA');
|
|
$usare_dettaglio_fornitore = $superselect['dir'] == 'uscita';
|
|
|
|
$query = 'SELECT
|
|
mg_articoli.id,
|
|
mg_articoli.barcode,
|
|
mg_articoli.'.($prezzi_ivati ? 'prezzo_vendita_ivato' : 'prezzo_vendita').' AS prezzo_vendita,
|
|
mg_articoli.prezzo_vendita_ivato AS prezzo_vendita_ivato,';
|
|
|
|
// Informazioni relative al fornitore specificato dal documenti di acquisto
|
|
if ($usare_dettaglio_fornitore) {
|
|
$query .= '
|
|
IFNULL(mg_fornitore_articolo.codice_fornitore, mg_articoli.codice) AS codice,
|
|
IFNULL(mg_fornitore_articolo.descrizione, mg_articoli.descrizione) AS descrizione,
|
|
IFNULL(mg_fornitore_articolo.prezzo_acquisto, mg_articoli.prezzo_acquisto) AS prezzo_acquisto,
|
|
IFNULL(mg_fornitore_articolo.qta_minima, 0) AS qta_minima,
|
|
mg_fornitore_articolo.id AS id_dettaglio_fornitore,';
|
|
}
|
|
// Informazioni dell'articolo per i documenti di vendita
|
|
else {
|
|
$query .= '
|
|
mg_articoli.codice AS codice,
|
|
mg_articoli.descrizione AS descrizione,
|
|
mg_articoli.prezzo_acquisto AS prezzo_acquisto,
|
|
0 AS qta_minima,
|
|
NULL AS id_dettaglio_fornitore,';
|
|
}
|
|
|
|
$query .= '
|
|
round(mg_articoli.qta,'.setting('Cifre decimali per quantità').') AS qta,
|
|
mg_articoli.um,
|
|
mg_articoli.servizio,
|
|
mg_articoli.idiva_vendita,
|
|
mg_articoli.idconto_vendita,
|
|
mg_articoli.idconto_acquisto,
|
|
categoria.`nome` AS categoria,
|
|
sottocategoria.`nome` AS sottocategoria,
|
|
co_iva.descrizione AS iva_vendita,
|
|
CONCAT(conto_vendita_categoria .numero, ".", conto_vendita_sottocategoria.numero, " ", conto_vendita_sottocategoria.descrizione) AS idconto_vendita_title,
|
|
CONCAT(conto_acquisto_categoria .numero, ".", conto_acquisto_sottocategoria.numero, " ", conto_acquisto_sottocategoria.descrizione) AS idconto_acquisto_title
|
|
FROM mg_articoli
|
|
LEFT JOIN co_iva ON mg_articoli.idiva_vendita = co_iva.id
|
|
LEFT JOIN `mg_categorie` AS categoria ON `categoria`.`id` = `mg_articoli`.`id_categoria`
|
|
LEFT JOIN `mg_categorie` AS sottocategoria ON `sottocategoria`.`id` = `mg_articoli`.`id_sottocategoria`
|
|
LEFT JOIN co_pianodeiconti3 AS conto_vendita_sottocategoria ON conto_vendita_sottocategoria.id=mg_articoli.idconto_vendita
|
|
LEFT JOIN co_pianodeiconti2 AS conto_vendita_categoria ON conto_vendita_sottocategoria.idpianodeiconti2=conto_vendita_categoria.id
|
|
LEFT JOIN co_pianodeiconti3 AS conto_acquisto_sottocategoria ON conto_acquisto_sottocategoria.id=mg_articoli.idconto_acquisto
|
|
LEFT JOIN co_pianodeiconti2 AS conto_acquisto_categoria ON conto_acquisto_sottocategoria.idpianodeiconti2=conto_acquisto_categoria.id
|
|
|
|
LEFT JOIN mg_fornitore_articolo ON mg_fornitore_articolo.id_articolo = mg_articoli.id AND mg_fornitore_articolo.deleted_at IS NULL AND mg_fornitore_articolo.id_fornitore = '.prepare($superselect['idanagrafica']);
|
|
|
|
// Se c'è una sede settata, carico tutti gli articoli presenti in quella sede
|
|
if (!$sedi_non_impostate) {
|
|
$query .= '
|
|
LEFT JOIN (SELECT idarticolo, idsede_azienda, idsede_controparte FROM mg_movimenti GROUP BY idarticolo) movimenti ON movimenti.idarticolo=mg_articoli.id
|
|
LEFT JOIN an_sedi ON an_sedi.id = movimenti.idsede_azienda';
|
|
}
|
|
|
|
$query .= '
|
|
|where|';
|
|
|
|
// Se c'è una sede settata, carico tutti gli articoli presenti in quella sede
|
|
if (!$sedi_non_impostate) {
|
|
$query .= '
|
|
GROUP BY
|
|
mg_articoli.id';
|
|
}
|
|
|
|
$query .= '
|
|
ORDER BY
|
|
mg_articoli.id_categoria ASC,
|
|
mg_articoli.id_sottocategoria ASC,
|
|
mg_articoli.codice ASC,
|
|
mg_articoli.descrizione ASC';
|
|
|
|
foreach ($elements as $element) {
|
|
$filter[] = 'mg_articoli.id='.prepare($element);
|
|
}
|
|
|
|
$where[] = 'mg_articoli.attivo = 1';
|
|
$where[] = 'mg_articoli.deleted_at IS NULL';
|
|
|
|
// Filtro articolo solo per documenti di vendita
|
|
if ($superselect['dir'] == 'entrata' && isset($superselect['idsede_partenza'])) {
|
|
$where[] = '((idsede_azienda='.prepare($superselect['idsede_partenza']).' OR idsede_azienda IS NULL) OR (idsede_controparte='.prepare($superselect['idsede_partenza']).' OR idsede_controparte IS NULL))';
|
|
}
|
|
|
|
if (!empty($search)) {
|
|
$search_fields[] = 'mg_articoli.descrizione LIKE '.prepare('%'.$search.'%');
|
|
$search_fields[] = 'mg_articoli.codice LIKE '.prepare('%'.$search.'%');
|
|
$search_fields[] = 'mg_articoli.barcode LIKE '.prepare('%'.$search.'%');
|
|
|
|
if ($usare_dettaglio_fornitore) {
|
|
$search_fields[] = 'mg_fornitore_articolo.descrizione LIKE '.prepare('%'.$search.'%');
|
|
$search_fields[] = 'mg_fornitore_articolo.codice_fornitore LIKE '.prepare('%'.$search.'%');
|
|
}
|
|
}
|
|
|
|
$data = AJAX::selectResults($query, $where, $filter, $search_fields, $limit, $custom);
|
|
$rs = $data['results'];
|
|
|
|
// Individuazione di eventuali listini
|
|
if (!empty($superselect['dir']) && !empty($superselect['idanagrafica'])) {
|
|
$listino = $dbo->fetchOne('SELECT prc_guadagno as percentuale FROM mg_listini WHERE id=(SELECT idlistino_'.($superselect['dir'] == 'uscita' ? 'acquisti' : 'vendite').' FROM an_anagrafiche WHERE idanagrafica='.prepare($superselect['idanagrafica']).')');
|
|
}
|
|
|
|
//per le vendite leggo iva predefinita da anagrafica, se settata
|
|
if (!empty($superselect['dir']) && $superselect['dir'] == 'entrata' && !empty($superselect['idanagrafica'])) {
|
|
$idiva_predefinita_anagrafica = $dbo->fetchOne('SELECT idiva_vendite FROM an_anagrafiche WHERE idanagrafica = '.prepare($superselect['idanagrafica']))['idiva_vendite'];
|
|
$iva_predefinita_anagrafica = $dbo->fetchOne('SELECT descrizione FROM co_iva WHERE id = '.prepare($idiva_predefinita_anagrafica))['descrizione'];
|
|
}
|
|
|
|
// IVA da impostazioni
|
|
$idiva_predefinita = setting('Iva predefinita');
|
|
$iva_predefinita = $dbo->fetchOne('SELECT descrizione FROM co_iva WHERE id='.prepare($idiva_predefinita))['descrizione'];
|
|
|
|
$previous_category = -1;
|
|
$previous_subcategory = -1;
|
|
foreach ($rs as $r) {
|
|
// Lettura movimenti delle mie sedi
|
|
$qta_azienda = $dbo->fetchOne("SELECT SUM(mg_movimenti.qta) AS qta, IF(mg_movimenti.idsede_azienda= 0,'Sede legale',(CONCAT_WS(' - ',an_sedi.nomesede,an_sedi.citta))) as sede FROM mg_movimenti LEFT JOIN an_sedi ON an_sedi.id = mg_movimenti.idsede_azienda WHERE mg_movimenti.idarticolo=".prepare($r['id']).' AND idsede_azienda='.prepare($superselect['idsede_partenza']).' GROUP BY idsede_azienda');
|
|
|
|
// Lettura eventuali movimenti ad una propria sede (nel caso di movimenti fra sedi della mia azienda) per il calcolo corretto delle quantità
|
|
if ($superselect['idsede_partenza'] != 0) {
|
|
$qta_controparte = $dbo->fetchOne("SELECT SUM(mg_movimenti.qta) AS qta, IF(mg_movimenti.idsede_controparte= 0,'Sede legale',(CONCAT_WS(' - ',an_sedi.nomesede,an_sedi.citta))) as sede FROM mg_movimenti LEFT JOIN an_sedi ON an_sedi.id = mg_movimenti.idsede_controparte WHERE mg_movimenti.idarticolo=".prepare($r['id']).' AND idsede_controparte='.prepare($superselect['idsede_partenza']).' GROUP BY idsede_controparte');
|
|
} else {
|
|
$qta_controparte = $dbo->fetchOne("SELECT SUM(mg_movimenti.qta) AS qta, IF(mg_movimenti.idsede_controparte= 0,'Sede legale',(CONCAT_WS(' - ',an_sedi.nomesede,an_sedi.citta))) as sede FROM ((( mg_movimenti LEFT JOIN an_sedi ON an_sedi.id = mg_movimenti.idsede_controparte ) LEFT JOIN dt_ddt ON mg_movimenti.idddt = dt_ddt.id ) LEFT JOIN co_documenti ON mg_movimenti.iddocumento = co_documenti.id ) WHERE mg_movimenti.idarticolo=".prepare($r['id']).' AND idsede_controparte='.prepare($superselect['idsede_partenza']).' AND IFNULL( dt_ddt.idanagrafica, co_documenti.idanagrafica ) = '.prepare(setting('Azienda predefinita')).' GROUP BY idsede_controparte');
|
|
}
|
|
|
|
$qta = $qta_azienda['qta'] - $qta_controparte['qta'];
|
|
|
|
if ($previous_category != $r['categoria'] || $previous_subcategory != $r['sottocategoria']) {
|
|
$previous_category = $r['categoria'];
|
|
$previous_subcategory = $r['sottocategoria'];
|
|
|
|
$text = '<i>'.tr('Nessuna categoria').'</i>';
|
|
if (!empty($r['categoria'])) {
|
|
$text = $r['categoria'].' ('.(!empty($r['sottocategoria']) ? $r['sottocategoria'] : '-').')';
|
|
}
|
|
|
|
$results[] = [
|
|
'text' => $text,
|
|
'children' => [],
|
|
];
|
|
}
|
|
|
|
// Iva dell'articolo
|
|
if (!empty($idiva_predefinita_anagrafica)) {
|
|
$idiva = $idiva_predefinita_anagrafica;
|
|
$iva = $iva_predefinita_anagrafica;
|
|
} elseif (empty($r['idiva_vendita'])) {
|
|
$idiva = $idiva_predefinita;
|
|
$iva = $iva_predefinita;
|
|
} else {
|
|
$idiva = $r['idiva_vendita'];
|
|
$iva = $r['iva_vendita'];
|
|
}
|
|
|
|
$prezzo_vendita = $r['prezzo_vendita'];
|
|
|
|
$results[count($results) - 1]['children'][] = [
|
|
'id' => $r['id'],
|
|
'text' => $r['codice'].' - '.$r['descrizione'].' '.(!$r['servizio'] ? '('.Translator::numberToLocale($qta).(!empty($r['um']) ? ' '.$r['um'] : '').')' : ''),
|
|
'codice' => $r['codice'],
|
|
'descrizione' => $r['descrizione'],
|
|
'qta_minima' => $r['qta_minima'],
|
|
'id_dettaglio_fornitore' => $r['id_dettaglio_fornitore'],
|
|
'barcode' => $r['barcode'],
|
|
'qta' => $r['qta'],
|
|
'um' => $r['um'],
|
|
'idiva_vendita' => $idiva,
|
|
'iva_vendita' => $iva,
|
|
'idconto_vendita' => $r['idconto_vendita'],
|
|
'idconto_vendita_title' => $r['idconto_vendita_title'],
|
|
'idconto_acquisto' => $r['idconto_acquisto'],
|
|
'idconto_acquisto_title' => $r['idconto_acquisto_title'],
|
|
'prezzo_acquisto' => $r['prezzo_acquisto'],
|
|
'prezzo_vendita' => $prezzo_vendita,
|
|
'prezzo_vendita_ivato' => $r['prezzo_vendita_ivato'],
|
|
'disabled' => $r['qta'] <= 0 && !$superselect['permetti_movimento_a_zero'] && !$r['servizio'],
|
|
];
|
|
}
|
|
|
|
$results = [
|
|
'results' => $results,
|
|
'recordsFiltered' => $data['recordsFiltered'],
|
|
];
|
|
|
|
break;
|
|
|
|
case 'categorie':
|
|
$query = 'SELECT id, nome AS descrizione FROM mg_categorie |where| ORDER BY nome';
|
|
|
|
foreach ($elements as $element) {
|
|
$filter[] = 'id='.prepare($element);
|
|
}
|
|
|
|
$where[] = '`parent` IS NULL';
|
|
|
|
if (!empty($search)) {
|
|
$search_fields[] = 'nome LIKE '.prepare('%'.$search.'%');
|
|
}
|
|
|
|
break;
|
|
|
|
/*
|
|
* Opzioni utilizzate:
|
|
* - id_categoria
|
|
*/
|
|
case 'sottocategorie':
|
|
if (isset($superselect['id_categoria'])) {
|
|
$query = 'SELECT id, nome AS descrizione FROM mg_categorie |where| ORDER BY nome';
|
|
|
|
foreach ($elements as $element) {
|
|
$filter[] = 'id='.prepare($element);
|
|
}
|
|
|
|
$where[] = '`parent`='.prepare($superselect['id_categoria']);
|
|
|
|
if (!empty($search)) {
|
|
$search_fields[] = 'nome LIKE '.prepare('%'.$search.'%');
|
|
}
|
|
}
|
|
break;
|
|
|
|
case 'misure':
|
|
$query = 'SELECT valore AS id, valore AS descrizione FROM mg_unitamisura |where| ORDER BY valore';
|
|
|
|
foreach ($elements as $element) {
|
|
$filter[] = 'valore='.prepare($element);
|
|
}
|
|
if (!empty($search)) {
|
|
$search_fields[] = 'valore LIKE '.prepare('%'.$search.'%');
|
|
}
|
|
|
|
break;
|
|
|
|
/*
|
|
* Opzioni utilizzate:
|
|
* - idanagrafica
|
|
*/
|
|
case 'articoli_barcode':
|
|
$id_anagrafica = filter('id_anagrafica'); // ID passato via URL in modo fisso
|
|
$prezzi_ivati = setting('Utilizza prezzi di vendita comprensivi di IVA');
|
|
|
|
$query = 'SELECT mg_articoli.*,
|
|
mg_articoli.id,
|
|
mg_articoli.qta,
|
|
mg_articoli.um,
|
|
mg_articoli.id,
|
|
mg_articoli.id,
|
|
IFNULL(mg_fornitore_articolo.codice_fornitore, mg_articoli.codice) AS codice,
|
|
IFNULL(mg_fornitore_articolo.descrizione, mg_articoli.descrizione) AS descrizione,
|
|
IFNULL(mg_fornitore_articolo.prezzo_acquisto, mg_articoli.prezzo_acquisto) AS prezzo_acquisto,
|
|
mg_articoli.'.($prezzi_ivati ? 'prezzo_vendita_ivato' : 'prezzo_vendita').' AS prezzo_vendita,
|
|
mg_articoli.prezzo_vendita_ivato AS prezzo_vendita_ivato,
|
|
IFNULL(mg_fornitore_articolo.qta_minima, 0) AS qta_minima,
|
|
mg_fornitore_articolo.id AS id_dettaglio_fornitore
|
|
FROM mg_articoli
|
|
LEFT JOIN mg_fornitore_articolo ON mg_fornitore_articolo.id_articolo = mg_articoli.id AND mg_fornitore_articolo.deleted_at IS NULL AND mg_fornitore_articolo.id_fornitore = '.prepare($id_anagrafica).'
|
|
|where|';
|
|
|
|
$where[] = 'barcode='.prepare(get('barcode'));
|
|
$where[] = 'mg_articoli.attivo = 1';
|
|
$where[] = 'mg_articoli.deleted_at IS NULL';
|
|
|
|
break;
|
|
}
|