sedeLegale; $sede->indirizzo = post('indirizzo'); $sede->indirizzo2 = post('indirizzo2'); $sede->citta = post('citta'); $sede->cap = post('cap'); $sede->provincia = post('provincia'); $sede->km = post('km'); $sede->id_nazione = post('id_nazione') ?: null; $sede->gaddress = post('gaddress'); $sede->lat = post('lat'); $sede->lng = post('lng'); $sede->telefono = post('telefono'); $sede->cellulare = post('cellulare'); $sede->fax = post('fax'); $sede->idzona = post('idzona'); $sede->email = post('email'); $sede->save(); // Informazioni sull'anagrafica $anagrafica->codice = post('codice'); $anagrafica->tipo = post('tipo'); $anagrafica->codice_destinatario = post('codice_destinatario'); $anagrafica->ragione_sociale = post('ragione_sociale'); $anagrafica->nome = post('nome'); $anagrafica->cognome = post('cognome'); $anagrafica->tipo = post('tipo'); $anagrafica->data_nascita = post('data_nascita'); $anagrafica->luogo_nascita = post('luogo_nascita'); $anagrafica->sesso = post('sesso'); $anagrafica->capitale_sociale = post('capitale_sociale'); $anagrafica->pec = post('pec'); $anagrafica->idsede_fatturazione = post('idsede_fatturazione'); $anagrafica->note = post('note'); $anagrafica->codiceri = post('codiceri'); $anagrafica->codicerea = post('codicerea'); $anagrafica->appoggiobancario = post('appoggiobancario'); $anagrafica->filiale = post('filiale'); $anagrafica->codiceiban = post('codiceiban'); $anagrafica->bic = post('bic'); $anagrafica->diciturafissafattura = post('diciturafissafattura'); $anagrafica->idpagamento_acquisti = post('idpagamento_acquisti'); $anagrafica->idpagamento_vendite = post('idpagamento_vendite'); $anagrafica->idlistino_acquisti = post('idlistino_acquisti'); $anagrafica->idlistino_vendite = post('idlistino_vendite'); $anagrafica->idiva_acquisti = post('idiva_acquisti'); $anagrafica->idiva_vendite = post('idiva_vendite'); $anagrafica->idbanca_acquisti = post('idbanca_acquisti'); $anagrafica->idbanca_vendite = post('idbanca_vendite'); $anagrafica->settore = post('settore'); $anagrafica->marche = post('marche'); $anagrafica->dipendenti = post('dipendenti'); $anagrafica->macchine = post('macchine'); $anagrafica->idagente = post('idagente'); $anagrafica->idrelazione = post('idrelazione'); $anagrafica->sitoweb = post('sitoweb'); $anagrafica->iscrizione_tribunale = post('iscrizione_tribunale'); $anagrafica->cciaa = post('cciaa'); $anagrafica->cciaa_citta = post('cciaa_citta'); $anagrafica->n_alboartigiani = post('n_alboartigiani'); $anagrafica->foro_competenza = post('foro_competenza'); $anagrafica->colore = post('colore'); $anagrafica->idtipointervento_default = post('idtipointervento_default'); $anagrafica->id_ritenuta_acconto_acquisti = post('id_ritenuta_acconto_acquisti'); $anagrafica->id_ritenuta_acconto_vendite = post('id_ritenuta_acconto_vendite'); $anagrafica->split_payment = post('split_payment'); $anagrafica->tipologie = (array) post('idtipoanagrafica'); // Avviso durante il salvataggio del codice fiscale se già presente e informo l'utente delle schede presenti if (!empty(post('codice_fiscale'))) { $idanagrafica = $dbo->fetchOne('SELECT GROUP_CONCAT(idanagrafica) AS idanagrafica FROM an_anagrafiche WHERE codice_fiscale = '.prepare(post('codice_fiscale')).' AND idanagrafica != '.prepare($id_record))['idanagrafica']; if (!empty($idanagrafica)) { $array = explode(',', $idanagrafica); foreach ($array as $value) { flash()->warning(tr('Attenzione: il codice fiscale _COD_ è già stato censito _LINK_', [ '_COD_' => post('codice_fiscale'), '_LINK_' => Modules::link('Anagrafiche', $value, null, null, ''), ])); } } else { $anagrafica->codice_fiscale = strtoupper(post('codice_fiscale')); } } else { $anagrafica->codice_fiscale = strtoupper(post('codice_fiscale')); } // Avviso durante il salvataggio della partita iva se già presente e informo l'utente delle schede presenti if (!empty(post('piva'))) { $idanagrafica = $dbo->fetchOne('SELECT GROUP_CONCAT(idanagrafica) AS idanagrafica FROM an_anagrafiche WHERE piva = '.prepare(post('piva')).' AND idanagrafica != '.prepare($id_record))['idanagrafica']; if (!empty($idanagrafica)) { $array = explode(',', $idanagrafica); foreach ($array as $value) { flash()->warning(tr('Attenzione: la partita IVA _IVA_ è già stata censita _LINK_', [ '_IVA_' => post('piva'), '_LINK_' => Modules::link('Anagrafiche', $value, null, null, ''), ])); } } else { $anagrafica->partita_iva = post('piva'); } } else { $anagrafica->partita_iva = post('piva'); } $anagrafica->save(); flash()->info(str_replace('_NAME_', '"'.post('ragione_sociale').'"', "Informazioni per l'anagrafica _NAME_ salvate correttamente!")); // Validazione della Partita IVA $partita_iva = $anagrafica->partita_iva; $partita_iva = is_numeric($partita_iva) ? $anagrafica->nazione->iso2.$partita_iva : $partita_iva; $check_vat_number = Validate::isValidVatNumber($partita_iva); if (empty($check_vat_number)) { flash()->warning(tr('Attenzione: la partita IVA _IVA_ potrebbe non essere valida', [ '_IVA_' => $partita_iva, ])); } // Validazione del Codice Fiscale, solo per anagrafiche Private e Aziende, ignoro controllo se codice fiscale e settato uguale alla p.iva if ($anagrafica->tipo != 'Ente pubblico' and $anagrafica->codice_fiscale != $anagrafica->partita_iva) { $check_codice_fiscale = Validate::isValidTaxCode($anagrafica->codice_fiscale); if (empty($check_codice_fiscale)) { flash()->warning(tr('Attenzione: il codice fiscale _COD_ potrebbe non essere valido', [ '_COD_' => $anagrafica->codice_fiscale, ])); } } // Aggiorno il codice anagrafica se non è già presente, altrimenti lo ignoro if ($anagrafica->codice != post('codice')) { flash()->warning(tr('Attenzione: il codice anagrafica _COD_ esiste già', [ '_COD_' => $anagrafica->codice, ])); } // Aggiorno gli agenti collegati $dbo->sync('an_anagrafiche_agenti', ['idanagrafica' => $id_record], ['idagente' => (array) post('idagenti')]); // Se l'agente di default è stato elencato anche tra gli agenti secondari lo rimuovo if (!empty(post('idagente'))) { $dbo->query('DELETE FROM an_anagrafiche_agenti WHERE idanagrafica='.prepare($id_record).' AND idagente='.prepare(post('idagente'))); } break; case 'add': $idtipoanagrafica = post('idtipoanagrafica'); $ragione_sociale = post('ragione_sociale'); $anagrafica = Anagrafica::build($ragione_sociale, post('nome'), post('cognome'), $idtipoanagrafica); $id_record = $anagrafica->id; // Blocco il salvataggio del codice fiscale se già presente if (!empty(post('codice_fiscale'))) { $count_cf = $dbo->fetchNum('SELECT codice_fiscale FROM an_anagrafiche WHERE codice_fiscale = '.prepare(post('codice_fiscale')).' AND idanagrafica != '.prepare($id_record)); if ($count_cf > 0) { flash()->warning(tr('Attenzione: il codice fiscale _COD_ è già stato censito', [ '_COD_' => post('codice_fiscale'), ])); } else { $anagrafica->codice_fiscale = strtoupper(post('codice_fiscale')); } } else { $anagrafica->codice_fiscale = strtoupper(post('codice_fiscale')); } // Blocco il salvataggio della partita iva se già presente if (!empty(post('piva'))) { $count_piva = $dbo->fetchNum('SELECT piva FROM an_anagrafiche WHERE piva = '.prepare(post('piva')).' AND idanagrafica != '.prepare($id_record)); if ($count_piva > 0) { flash()->warning(tr('Attenzione: la partita IVA _IVA_ è già stata censita', [ '_IVA_' => post('piva'), ])); } else { $anagrafica->partita_iva = post('piva'); } } else { $anagrafica->partita_iva = post('piva'); } // Se ad aggiungere un cliente è un agente, lo imposto come agente di quel cliente // Lettura tipologia dell'utente loggato $agente_is_logged = false; $rs = $dbo->fetchArray('SELECT descrizione FROM an_tipianagrafiche INNER JOIN an_tipianagrafiche_anagrafiche ON an_tipianagrafiche.idtipoanagrafica = an_tipianagrafiche_anagrafiche.idtipoanagrafica WHERE idanagrafica = '.prepare($user['idanagrafica'])); for ($i = 0; $i < count($rs); ++$i) { if ($rs[$i]['descrizione'] == 'Agente') { $agente_is_logged = true; $i = count($rs); } } $idagente = ($agente_is_logged && in_array($id_cliente, $idtipoanagrafica)) ? $user['idanagrafica'] : 0; $anagrafica->indirizzo = post('indirizzo'); $anagrafica->citta = post('citta'); $anagrafica->cap = post('cap'); $anagrafica->provincia = post('provincia'); $anagrafica->telefono = post('telefono'); $anagrafica->cellulare = post('cellulare'); $anagrafica->email = post('email'); $anagrafica->idagente = $idagente; $anagrafica->pec = post('pec'); $anagrafica->tipo = post('tipo'); $anagrafica->codice_destinatario = post('codice_destinatario'); $anagrafica->id_nazione = post('id_nazione') ?: null; $anagrafica->save(); if ($anagrafica->isAzienda()) { flash()->info(tr('Anagrafica Azienda impostata come predefinita').'. '.tr('Per ulteriori informazionioni, visitare "Strumenti -> Impostazioni -> Generali"')); } // Lettura tipologia della nuova anagrafica $descrizioni_tipi = $anagrafica->tipi()->get()->pluck('descrizione')->toArray(); if (isAjaxRequest() && in_array(post('tipoanagrafica'), $descrizioni_tipi)) { echo json_encode(['id' => $id_record, 'text' => $anagrafica->ragione_sociale]); } flash()->info(tr('Aggiunta nuova anagrafica di tipo _TYPE_', [ '_TYPE_' => '"'.implode(', ', $descrizioni_tipi).'"', ])); break; case 'delete': // Se l'anagrafica non è l'azienda principale, la disattivo if (!in_array($id_azienda, $tipi_anagrafica)) { $interventi = $dbo->fetchOne('SELECT id FROM in_interventi WHERE idanagrafica='.prepare($id_record)); $preventivi = $dbo->fetchOne('SELECT id FROM co_preventivi WHERE idanagrafica='.prepare($id_record)); $contratti = $dbo->fetchOne('SELECT id FROM co_contratti WHERE idanagrafica='.prepare($id_record)); $ordini = $dbo->fetchOne('SELECT id FROM or_ordini WHERE idanagrafica='.prepare($id_record)); $ddt = $dbo->fetchOne('SELECT id FROM dt_ddt WHERE idanagrafica='.prepare($id_record)); $fatture = $dbo->fetchOne('SELECT id FROM co_documenti WHERE idanagrafica='.prepare($id_record)); // Se non ci sono documenti collegati, elimino l'anagrafica if (count($interventi) == 0 && count($preventivi) == 0 && count($contratti) == 0 && count($ordini) == 0 && count($ddt) == 0 && count($fatture) == 0) { $dbo->query('DELETE FROM an_anagrafiche WHERE idanagrafica = '.prepare($id_record)); } // altrimenti la disabilito solo else { $dbo->query('UPDATE an_anagrafiche SET deleted_at = NOW() WHERE idanagrafica = '.prepare($id_record)); // Se l'anagrafica è collegata ad un utente lo disabilito $dbo->query('UPDATE zz_users SET enabled = 0 WHERE idanagrafica = '.prepare($id_record)); } flash()->info(tr('Anagrafica eliminata!')); } break; } // Operazioni aggiuntive per il logo if (filter('op') == 'link_file') { $nome = 'Logo stampe'; if (setting('Azienda predefinita') == $id_record && filter('nome_allegato') == $nome) { Settings::setValue($nome, $upload); } }