$dati_anagrafica) { if (!empty($dati_anagrafica)) { $id_tipo_anagrafica = (array) $dati_anagrafica['tipologia']; unset($dati_anagrafica['tipologia']); // Separazione dei campi relativi alla sede legale $dati_sede = []; foreach ($sede_fields as $field) { if (isset($dati_anagrafica[$field])) { $dati_sede[$field] = $dati_anagrafica[$field]; unset($dati_anagrafica[$field]); } } // Ricerca di eventuale anagrafica corrispondente sulla base del campo definito come primary_key (es. codice) if (!empty($primary_key)) { $anagrafica = Anagrafica::where($primary_key, '=', $dati_anagrafica[$primary_key])->first(); } // Se non trovo nessuna anagrafica corrispondente, allora la creo if (empty($anagrafica)) { $anagrafica = Anagrafica::build($dati_anagrafica['ragione_sociale']); } // Impedisco di aggiornare la mia anagrafica azienda if ($dati_anagrafica[$primary_key] != $id_azienda) { //se non imposto nessun codice evito di resettare quello calcolato automaticamente o già presente if (empty($dati_anagrafica['codice'])){ unset($dati_anagrafica['codice']); } $anagrafica->fill($dati_anagrafica); $anagrafica->tipologie = $id_tipo_anagrafica; $anagrafica->save(); $sede = $anagrafica->sedeLegale; $sede->fill($dati_sede); $sede->save(); } } } break; } return [ [ 'field' => 'codice', 'label' => 'Codice', 'primary_key' => true, 'names' => [ 'Codice interno', 'Numero', ] ], [ 'field' => 'ragione_sociale', 'label' => 'Ragione sociale', 'names' => [ 'Nome', 'Denominazione', ] ], [ 'field' => 'codice_destinatario', 'label' => 'Codice destinatario', 'names' => [ 'Codice destinatario', 'Codice SDI', 'Codice univoco', 'Codice univoco ufficio', 'SDI', ] ], [ 'field' => 'provincia', 'label' => 'Provincia', ], [ 'field' => 'citta', 'label' => 'Città', 'names' => [ 'Citt_', 'Città', ] ], [ 'field' => 'telefono', 'label' => 'Telefono', ], [ 'field' => 'indirizzo', 'label' => 'Indirizzo', ], [ 'field' => 'indirizzo2', 'label' => 'Civico', ], [ 'field' => 'cap', 'label' => 'CAP', ], [ 'field' => 'cellulare', 'label' => 'Cellulare', ], [ 'field' => 'fax', 'label' => 'Fax', ], [ 'field' => 'email', 'label' => 'Email', 'names' => [ 'E-mail', 'Indirizzo email', 'Mail', ] ], [ 'field' => 'pec', 'label' => 'PEC', 'names' => [ 'E-mail PEC', 'Email certificata', 'Indirizzo email certificata', ] ], [ 'field' => 'codice_fiscale', 'label' => 'Codice Fiscale', ], [ 'field' => 'data_nascita', 'label' => 'Data di nascita', ], [ 'field' => 'luogo_nascita', 'label' => 'Luogo di nascita', ], [ 'field' => 'sesso', 'label' => 'Sesso', ], [ 'field' => 'piva', 'label' => 'Partita IVA', 'names' => [ 'P.IVA', 'P.IVA/TAX ID', 'TAX ID', ] ], [ 'field' => 'codiceiban', 'label' => 'IBAN', ], [ 'field' => 'note', 'label' => 'Note', 'names' => [ 'Note Extra', ] ], [ 'field' => 'id_nazione', 'label' => 'Nazione', 'names' => [ 'Nazione', 'Paese', 'id_nazione', 'idnazione', 'nazione', ], 'query' => 'SELECT id as result FROM an_nazioni WHERE LOWER(nome) = LOWER(|value|)', ], [ 'field' => 'idagente', 'label' => 'ID Agente', ], [ 'field' => 'idpagamento_vendite', 'label' => 'ID Pagamento', 'names' => [ 'Pagamento', 'ID Pagamento', 'id_pagamento', 'idpagamento_vendite', 'idpagamento', ], ], [ 'field' => 'tipologia', 'label' => 'Tipologia', 'names' => [ 'Tipologia', 'tipologia', 'idtipo', ], 'query' => 'SELECT idtipoanagrafica as result FROM an_tipianagrafiche WHERE descrizione = |value|', ], ];