getPrecision(); $bcadd = function_exists('bcadd'); foreach ($array as $value) { $value = round($value, $decimals); if ($bcadd) { $result = bcadd($result, $value, $decimals); } else { $result += $value; } } return floatval($result); } /** * @param $field * @param $id_riga * @param $old_qta * @param $new_qta * @param $dir * * @throws Exception * * @return bool * * @deprecated */ function controlla_seriali($field, $id_riga, $old_qta, $new_qta, $dir) { $dbo = database(); $new_qta = abs($new_qta); $old_qta = abs($old_qta); if ($old_qta >= $new_qta) { // Controllo sulla possibilità di rimuovere i seriali (se non utilizzati da documenti di vendita) if ($dir == 'uscita' && $new_qta < count(seriali_non_rimuovibili($field, $id_riga, $dir))) { return false; } else { // Controllo sul numero di seriali effettivi da rimuovere $count = $dbo->fetchArray('SELECT COUNT(*) AS tot FROM mg_prodotti WHERE '.$field.'='.prepare($id_riga))[0]['tot']; if ($new_qta < $count) { $deletes = $dbo->fetchArray("SELECT id FROM mg_prodotti WHERE serial NOT IN (SELECT serial FROM mg_prodotti WHERE dir = 'entrata' AND ".$field.'!='.prepare($id_riga).') AND '.$field.'='.prepare($id_riga).' ORDER BY serial DESC LIMIT '.abs($count - $new_qta)); // Rimozione foreach ($deletes as $delete) { $dbo->query('DELETE FROM mg_prodotti WHERE id = '.prepare($delete['id'])); } } } } return true; } /** * Individua i seriali non rimuovibili poichè utilizzati in documenti rilasciati. * * @param string $field * @param int $id_riga * @param string $dir * * @return array * * @deprecated */ function seriali_non_rimuovibili($field, $id_riga, $dir) { $dbo = database(); $results = []; if ($dir == 'uscita') { $results = $dbo->fetchArray("SELECT serial FROM mg_prodotti WHERE serial IN (SELECT serial FROM mg_prodotti WHERE dir = 'entrata') AND ".$field.'='.prepare($id_riga)); } return $results; } /** * Calcola gli sconti in modo automatico. * * @param array $data * * @return float */ function calcola_sconto($data) { if ($data['tipo'] == 'PRC') { $result = 0; $price = floatval($data['prezzo']); $percentages = explode('+', $data['sconto']); foreach ($percentages as $percentage) { $discount = $price / 100 * floatval($percentage); $result += $discount; $price -= $discount; } } else { $result = floatval($data['sconto']); } if (!empty($data['qta'])) { $result = $result * $data['qta']; } return $result; } /** * Restistuisce le informazioni sull'eventuale riferimento ai documenti. * * @param $info * @param $dir * @param array $ignore * * @deprecated * * @throws Exception * * @return array */ function doc_references($info, $dir, $ignore = []) { $dbo = database(); // Rimozione valori da non controllare foreach ($ignore as $field) { if (isset($info[$field])) { unset($info[$field]); } } $module = null; $id = null; // DDT if (!empty($info['idddt'])) { $data = $dbo->fetchArray("SELECT IF(numero_esterno != '', numero_esterno, numero) AS numero, data FROM dt_ddt WHERE id=".prepare($info['idddt'])); $module = ($dir == 'entrata') ? 'Ddt di vendita' : 'Ddt di acquisto'; $id = $info['idddt']; $document = tr('Ddt'); } // Ordine elseif (!empty($info['idordine'])) { $data = $dbo->fetchArray("SELECT IF(numero_esterno != '', numero_esterno, numero) AS numero, data FROM or_ordini WHERE id=".prepare($info['idordine'])); $module = ($dir == 'entrata') ? 'Ordini cliente' : 'Ordini fornitore'; $id = $info['idordine']; $document = tr('Ordine'); } // Preventivo elseif (!empty($info['idpreventivo'])) { $data = $dbo->fetchArray('SELECT numero, data_bozza AS data FROM co_preventivi WHERE id='.prepare($info['idpreventivo'])); $module = 'Preventivi'; $id = $info['idpreventivo']; $document = tr('Preventivo'); } // Contratto elseif (!empty($info['idcontratto'])) { $data = $dbo->fetchArray('SELECT numero, data_bozza AS data FROM co_contratti WHERE id='.prepare($info['idcontratto'])); $module = 'Contratti'; $id = $info['idcontratto']; $document = tr('Contratto'); } // Intervento elseif (!empty($info['idintervento'])) { $data = $dbo->fetchArray('SELECT codice AS numero, IFNULL( (SELECT MIN(orario_inizio) FROM in_interventi_tecnici WHERE in_interventi_tecnici.idintervento=in_interventi.id), data_richiesta) AS data FROM in_interventi WHERE id='.prepare($info['idintervento'])); $module = 'Interventi'; $id = $info['idintervento']; $document = tr('Intervento'); } // Testo relativo if (!empty($module) && !empty($id)) { $document = Stringy\Stringy::create($document)->toLowerCase(); if (!empty($data)) { $description = tr('Rif. _DOC_ num. _NUM_ del _DATE_', [ '_DOC_' => $document, '_NUM_' => $data[0]['numero'], '_DATE_' => Translator::dateToLocale($data[0]['data']), ]); } else { $description = tr('_DOC_ di riferimento _ID_ eliminato', [ '_DOC_' => $document->upperCaseFirst(), '_ID_' => $id, ]); } return [ 'module' => $module, 'id' => $id, 'description' => $description, ]; } return []; } /** * Restituisce i mesi tradotti nella lingua corrente. * Da sostituire con il relativo corretto utilizzo delle date PHP. * * @deprecated * * @return array */ function months() { return [ 1 => tr('Gennaio'), 2 => tr('Febbraio'), 3 => tr('Marzo'), 4 => tr('Aprile'), 5 => tr('Maggio'), 6 => tr('Giugno'), 7 => tr('Luglio'), 8 => tr('Agosto'), 9 => tr('Settembre'), 10 => tr('Ottobre'), 11 => tr('Novembre'), 12 => tr('Dicembre'), ]; } /** * Individua il valore della colonna order per i nuovi elementi di una tabella. * * @param $table * @param $field * @param $id * * @return mixed */ function orderValue($table, $field, $id) { return database()->fetchOne('SELECT IFNULL(MAX(`order`) + 1, 0) AS value FROM '.$table.' WHERE '.$field.' = '.prepare($id))['value']; } /** * Visualizza le informazioni relative allo sconto presente su una riga. * * @param bool $mostra_maggiorazione * * @return string|null */ function discountInfo(\Common\Components\Row $riga, $mostra_maggiorazione = true) { if (empty($riga->sconto_unitario) || (!$mostra_maggiorazione && $riga->sconto_unitario < 0)) { return null; } $text = $riga->sconto_unitario > 0 ? tr('sconto _TOT_ _TYPE_') : tr('maggiorazione _TOT_ _TYPE_'); return replace($text, [ '_TOT_' => Translator::numberToLocale(!empty($riga->sconto_percentuale) ? $riga->sconto_percentuale : $riga->sconto_unitario), '_TYPE_' => (!empty($riga->sconto_percentuale) ? '%' : currency()), ]); } /** * Genera i riferimenti ai documenti del gestionale, attraverso l'interfaccia Common\ReferenceInterface. * * @param $document * * @return string */ function reference($document) { if (!empty($document) && !($document instanceof \Common\ReferenceInterface)) { return; } $extra = ''; $module_id = null; $document_id = null; if (empty($document)) { $description = tr('Documento di riferimento non disponibile'); $extra = 'class="disabled"'; } else { $module_id = $document->module; $document_id = $document->id; $description = $document->getReference(); } return Modules::link($module_id, $document_id, $description, $description, $extra); } /** * Funzione che gestisce il parsing di uno sconto combinato e la relativa trasformazione in sconto fisso. * Esempio: (40 + 10) % = 44 %. * * @param $combinato * * @return float|int */ function parseScontoCombinato($combinato) { $sign = substr($combinato, 0, 1); $original = $sign != '+' && $sign != '-' ? '+'.$combinato : $combinato; $pieces = preg_split('/[+,-]+/', $original); unset($pieces[0]); $result = 1; $text = $original; foreach ($pieces as $piece) { $sign = substr($text, 0, 1); $text = substr($text, 1 + strlen($piece)); $result *= 1 - floatval($sign.$piece) / 100; } return (1 - $result) * 100; }