. */ include_once __DIR__.'/../../core.php'; use Carbon\Carbon; use Modules\Articoli\Articolo as ArticoloOriginale; use Modules\Contratti\Contratto; use Modules\Contratti\Stato as StatoContratto; use Modules\Fatture\Fattura; use Modules\Fatture\Stato; use Modules\Fatture\Tipo; use Plugins\PianificazioneInterventi\Promemoria; $module_fatture = 'Fatture di vendita'; // Segmenti $id_fatture = Modules::get($module_fatture)['id']; if (!isset($_SESSION['module_'.$id_fatture]['id_segment'])) { $segments = Modules::getSegments($id_fatture); $_SESSION['module_'.$id_fatture]['id_segment'] = isset($segments[0]['id']) ? $segments[0]['id'] : null; } $id_segment = $_SESSION['module_'.$id_fatture]['id_segment']; $idconto = setting('Conto predefinito fatture di vendita'); $idtipodocumento = $dbo->selectOne('co_tipidocumento', ['id'], [ 'predefined' => 1, 'dir' => 'entrata', ])['id']; $stati_completati = $dbo->fetchOne('SELECT GROUP_CONCAT(`name` SEPARATOR ", ") AS stati_completati FROM `co_staticontratti` LEFT JOIN `co_staticontratti_lang` ON (`co_staticontratti`.`id` = `co_staticontratti_lang`.`id_record` AND `co_staticontratti_lang`.`id_lang` = '.prepare(setting('Lingua')).') WHERE `is_completato` = 1')['stati_completati']; switch (post('op')) { case 'crea_fattura': $documenti = collect(); $numero_totale = 0; // Informazioni della fattura $tipo_documento = Tipo::where('id', post('idtipodocumento'))->first(); $stato_documenti_accodabili = (new Stato())->getByName('Bozza'->id_record); $accodare = post('accodare'); $data = date('Y-m-d'); $id_segment = post('id_segment'); $raggruppamento = post('raggruppamento'); // Lettura righe selezionate foreach ($id_records as $id) { $documento_import = Contratto::find($id); $anagrafica = $documento_import->anagrafica; $id_anagrafica = $anagrafica->id; if (!$documento_import->stato->is_fatturabile) { break; } // Proseguo solo se i documenti scelti sono fatturabili $righe = $documento_import->getRighe(); if (!empty($righe)) { ++$numero_totale; // Ricerca fattura per anagrafica tra le registrate $id_sede = $raggruppamento == 'sede' ? $documento_import->idsede : 0; if ($raggruppamento == 'sede') { $fattura = $documenti->first(function ($item, $key) use ($id_anagrafica, $id_sede) { return $item->anagrafica->id == $id_anagrafica && $item->idsede_destinazione == $id_sede; }); } else { $fattura = $documenti->first(function ($item, $key) use ($id_anagrafica) { return $item->anagrafica->id == $id_anagrafica; }); } // Ricerca fattura per anagrafica se l'impostazione di accodamento è selezionata if (!empty($accodare) && empty($fattura)) { if ($raggruppamento == 'sede') { $fattura = Fattura::where('idanagrafica', $id_anagrafica) ->where('idstatodocumento', $stato_documenti_accodabili->id) ->where('idtipodocumento', $tipo_documento->id) ->first(); } else { $fattura = Fattura::where('idanagrafica', $id_anagrafica) ->where('idstatodocumento', $stato_documenti_accodabili->id) ->where('idtipodocumento', $tipo_standard->id) ->where('idsede', $id_sede) ->first(); } if (!empty($fattura)) { $documenti->push($fattura); } } // Creazione fattura per anagrafica if (empty($fattura)) { $fattura = Fattura::build($anagrafica, $tipo_documento, $data, $id_segment); $fattura->idsede_destinazione = $id_sede; $fattura->save(); $documenti->push($fattura); } // Inserimento righe foreach ($righe as $riga) { $qta = $riga->qta_rimanente; if ($qta > 0) { $copia = $riga->copiaIn($fattura, $qta); // Fix per idconto righe fattura $articolo = ArticoloOriginale::find($copia->idarticolo); $copia->id_conto = ($articolo->idconto_vendita ? $articolo->idconto_vendita : $idconto); // Aggiornamento seriali dalla riga dell'ordine if ($copia->isArticolo()) { $copia->serials = $riga->serials; } $copia->save(); } } } } if ($numero_totale > 0) { flash()->info(tr('_NUM_ contratti fatturati!', [ '_NUM_' => $numero_totale, ])); } else { flash()->warning(tr('Nessun contratto fatturato!')); } break; case 'renew_contratto': $numero_totale = 0; // Lettura righe selezionate foreach ($id_records as $id) { $contratto = Contratto::find($id); $rinnova = !empty($contratto->data_accettazione) && !empty($contratto->data_conclusione) && $contratto->data_accettazione != '0000-00-00' && $contratto->data_conclusione != '0000-00-00' && $contratto->stato->is_completato && $contratto->rinnovabile; if ($rinnova) { $diff = $contratto->data_conclusione->diffAsCarbonInterval($contratto->data_accettazione); $new_contratto = $contratto->replicate(); $new_contratto->numero = Contratto::getNextNumero($contratto->data_conclusione->copy()->addDays(1), $contratto->id_segment); $new_contratto->idcontratto_prev = $contratto->id; $new_contratto->data_accettazione = $contratto->data_conclusione->copy()->addDays(1); $new_contratto->data_conclusione = $new_contratto->data_accettazione->copy()->add($diff); $new_contratto->data_bozza = Carbon::now(); $stato = StatoContratto::where('descrizione', '=', 'Bozza')->first(); $new_contratto->stato()->associate($stato); $new_contratto->save(); $new_idcontratto = $new_contratto->id; // Correzioni dei prezzi per gli interventi $dbo->query('DELETE FROM co_contratti_tipiintervento WHERE idcontratto='.prepare($new_idcontratto)); $dbo->query('INSERT INTO co_contratti_tipiintervento(idcontratto, idtipointervento, costo_ore, costo_km, costo_dirittochiamata, costo_ore_tecnico, costo_km_tecnico, costo_dirittochiamata_tecnico) SELECT '.prepare($new_idcontratto).', idtipointervento, costo_ore, costo_km, costo_dirittochiamata, costo_ore_tecnico, costo_km_tecnico, costo_dirittochiamata_tecnico FROM co_contratti_tipiintervento AS z WHERE idcontratto='.prepare($contratto->id)); $new_contratto->save(); // Replico le righe del contratto $righe = $contratto->getRighe(); foreach ($righe as $riga) { $new_riga = $riga->replicate(); $new_riga->qta_evasa = 0; $new_riga->idcontratto = $new_contratto->id; $new_riga->save(); } // Replicazione degli impianti $impianti = $dbo->fetchArray('SELECT idimpianto FROM my_impianti_contratti WHERE idcontratto='.prepare($contratto->id)); $dbo->sync('my_impianti_contratti', ['idcontratto' => $new_idcontratto], ['idimpianto' => array_column($impianti, 'idimpianto')]); // Replicazione dei promemoria $promemoria = $dbo->fetchArray('SELECT * FROM co_promemoria WHERE idcontratto='.prepare($contratto->id)); $giorni = $contratto->data_conclusione->diffInDays($contratto->data_accettazione); foreach ($promemoria as $p) { $dbo->insert('co_promemoria', [ 'idcontratto' => $new_idcontratto, 'data_richiesta' => date('Y-m-d', strtotime($p['data_richiesta'].' +'.$giorni.' day')), 'idtipointervento' => $p['idtipointervento'], 'richiesta' => $p['richiesta'], 'idimpianti' => $p['idimpianti'], ]); $id_promemoria = $dbo->lastInsertedID(); $promemoria = Promemoria::find($p['id']); $righe = $promemoria->getRighe(); foreach ($righe as $riga) { $new_riga = $riga->replicate(); $new_riga->id_promemoria = $id_promemoria; $new_riga->save(); } // Copia degli allegati $allegati = $promemoria->uploads(); foreach ($allegati as $allegato) { $allegato->copia([ 'id_module' => $id_module, 'id_plugin' => Plugins::get('Pianificazione interventi')['id'], 'id_record' => $id_promemoria, ]); } } // Cambio stato precedente contratto in concluso (non più pianificabile) $dbo->query('UPDATE `co_contratti` SET `rinnovabile`= 0, `idstato`= (SELECT `co_staticontratti`.`id` FROM `co_staticontratti` LEFT JOIN `co_staticontratti_lang` ON (`co_staticontratti`.`id` = `co_staticontratti_lang`.`id_record` AND `co_staticontratti_lang`.`id_lang` = '.prepare(setting('Lingua')).') WHERE `name` = \'Concluso\') WHERE `co_staticontratti`.`id` = '.prepare($contratto->id)); ++$numero_totale; } } if ($numero_totale > 0) { flash()->info(tr('_NUM_ contratti rinnovati!', [ '_NUM_' => $numero_totale, ])); } else { flash()->warning(tr('Nessun contratto rinnovato!')); } break; case 'cambia_stato': $id_stato = post('id_stato'); $n_contratti = 0; $stato = StatoContratto::find($id_stato); // Lettura righe selezionate foreach ($id_records as $id) { $contratto = Contratto::find($id); $contratto->stato()->associate($stato); $contratto->save(); ++$n_contratti; } if ($n_contratti > 0) { flash()->info(tr('Stato aggiornato a _NUM_ contratti!', [ '_NUM_' => $n_contratti, ])); } else { flash()->warning(tr('Nessuno stato aggiornato!')); } break; } $operations['crea_fattura'] = [ 'text' => ' '.tr('Fattura _TYPE_', ['_TYPE_' => strtolower($module['name'])]), 'data' => [ 'title' => tr('Fatturare i _TYPE_ selezionati?', ['_TYPE_' => strtolower($module['name'])]), 'msg' => '{[ "type": "checkbox", "label": "'.tr('Aggiungere alle fatture di vendita non ancora emesse?').'", "placeholder": "'.tr('Aggiungere alle fatture esistenti non ancora emesse?').'", "name": "accodare" ]}
{[ "type": "select", "label": "'.tr('Sezionale').'", "name": "id_segment", "required": 1, "ajax-source": "segmenti", "select-options": '.json_encode(['id_module' => $id_fatture, 'is_sezionale' => 1]).', "value": "'.$id_segment.'", "select-options-escape": true ]}
{[ "type": "select", "label": "'.tr('Tipo documento').'", "name": "idtipodocumento", "required": 1, "values": "query=SELECT id, CONCAT(codice_tipo_documento_fe, \' - \', descrizione) AS descrizione FROM co_tipidocumento WHERE enabled = 1 AND dir =\'entrata\' ORDER BY codice_tipo_documento_fe", "value": "'.$idtipodocumento.'" ]}
{[ "type": "select", "label": "'.tr('Raggruppa per').'", "name": "raggruppamento", "required": 1, "values": "list=\"cliente\":\"Cliente\",\"sede\":\"Sede\"" ]}', 'button' => tr('Procedi'), 'class' => 'btn btn-lg btn-warning', 'blank' => false, ], ]; $operations['renew_contratto'] = [ 'text' => ' '.tr('Rinnova contratti').'', 'data' => [ 'title' => tr('Rinnovare i contratti selezionati?').'
', 'msg' => ''.tr('Un contratto è rinnovabile se presenta una data di accettazione e conclusione, se il rinnovo è abilitato dal plugin Rinnovi e se si trova in uno di questi stati: _STATE_LIST_', ['_STATE_LIST_' => $stati_completati]), 'button' => tr('Procedi'), 'class' => 'btn btn-lg btn-warning', 'blank' => false, ], ]; $operations['cambia_stato'] = [ 'text' => ' '.tr('Cambia stato'), 'data' => [ 'title' => tr('Vuoi davvero aggiornare lo stato di questi contratti?'), 'msg' => '
{[ "type": "select", "label": "'.tr('Stato').'", "name": "id_stato", "required": 1, "values": "query=SELECT `co_staticontratti`.`id`, `name` AS descrizione, `colore` as _bgcolor_ FROM `co_staticontratti` LEFT JOIN `co_staticontratti_lang ON (`co_staticontratti`.`id` = `co_staticontratti_lang`.`id_record` AND `co_staticontratti_lang`.`id_lang` = '.prepare(setting('Lingua')).') ORDER BY `name`" ]}', 'button' => tr('Procedi'), 'class' => 'btn btn-lg btn-warning', 'blank' => false, ], ]; return $operations;