2019-01-01 11:39:20 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Modules\Preventivi;
|
|
|
|
|
2019-01-10 18:41:25 +01:00
|
|
|
use Carbon\Carbon;
|
2019-07-22 18:35:13 +02:00
|
|
|
use Common\Components\Description;
|
2019-01-01 11:39:20 +01:00
|
|
|
use Common\Document;
|
|
|
|
use Modules\Anagrafiche\Anagrafica;
|
2019-02-14 17:49:58 +01:00
|
|
|
use Modules\Interventi\Intervento;
|
2019-07-22 18:35:13 +02:00
|
|
|
use Modules\Ordini\Ordine;
|
2019-07-08 12:24:59 +02:00
|
|
|
use Modules\TipiIntervento\Tipo as TipoSessione;
|
2019-01-01 11:39:20 +01:00
|
|
|
use Traits\RecordTrait;
|
|
|
|
use Util\Generator;
|
|
|
|
|
|
|
|
class Preventivo extends Document
|
|
|
|
{
|
|
|
|
use RecordTrait;
|
|
|
|
|
|
|
|
protected $table = 'co_preventivi';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Crea un nuovo preventivo.
|
|
|
|
*
|
2019-01-11 08:32:08 +01:00
|
|
|
* @param Anagrafica $anagrafica
|
|
|
|
* @param TipoSessione $tipo_sessione
|
|
|
|
* @param string $nome
|
2019-01-01 11:39:20 +01:00
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
2019-11-20 23:22:43 +01:00
|
|
|
public static function build(Anagrafica $anagrafica, TipoSessione $tipo_sessione, $nome, $data_bozza, $id_sede)
|
2019-01-01 11:39:20 +01:00
|
|
|
{
|
2019-01-02 14:15:16 +01:00
|
|
|
$model = parent::build();
|
2019-01-01 11:39:20 +01:00
|
|
|
|
|
|
|
$stato_documento = Stato::where('descrizione', 'Bozza')->first();
|
|
|
|
|
|
|
|
$id_anagrafica = $anagrafica->id;
|
|
|
|
$id_agente = $anagrafica->idagente;
|
|
|
|
$id_pagamento = $anagrafica->idpagamento_vendite;
|
|
|
|
|
2019-01-02 10:08:08 +01:00
|
|
|
$costo_orario = $tipo_sessione['costo_orario'];
|
|
|
|
$costo_diritto_chiamata = $tipo_sessione['costo_diritto_chiamata'];
|
2019-01-01 11:39:20 +01:00
|
|
|
|
|
|
|
$id_iva = setting('Iva predefinita');
|
|
|
|
if (empty($id_pagamento)) {
|
|
|
|
$id_pagamento = setting('Tipo di pagamento predefinito');
|
|
|
|
}
|
|
|
|
|
|
|
|
$model->anagrafica()->associate($anagrafica);
|
|
|
|
$model->stato()->associate($stato_documento);
|
2019-01-02 10:08:08 +01:00
|
|
|
$model->tipoSessione()->associate($tipo_sessione);
|
2019-01-01 11:39:20 +01:00
|
|
|
|
|
|
|
$model->numero = static::getNextNumero();
|
|
|
|
|
|
|
|
// Salvataggio delle informazioni
|
|
|
|
$model->nome = $nome;
|
2019-11-22 16:28:03 +01:00
|
|
|
if (empty($data_bozza)) {
|
2019-11-20 23:22:43 +01:00
|
|
|
$model->data_bozza = Carbon::now();
|
2019-11-22 16:28:03 +01:00
|
|
|
} else {
|
2019-11-20 23:22:43 +01:00
|
|
|
$model->data_bozza = $data_bozza;
|
2019-11-22 16:28:03 +01:00
|
|
|
}
|
2019-01-01 11:39:20 +01:00
|
|
|
$model->data_conclusione = Carbon::now()->addMonth();
|
2019-11-22 16:28:03 +01:00
|
|
|
|
2019-11-20 23:22:43 +01:00
|
|
|
if (!empty($id_sede)) {
|
|
|
|
$model->idsede = $id_sede;
|
|
|
|
}
|
2019-01-01 11:39:20 +01:00
|
|
|
|
|
|
|
if (!empty($id_agente)) {
|
|
|
|
$model->idagente = $id_agente;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!empty($id_iva)) {
|
|
|
|
$model->idiva = $id_iva;
|
|
|
|
}
|
|
|
|
if (!empty($id_pagamento)) {
|
|
|
|
$model->idpagamento = $id_pagamento;
|
|
|
|
}
|
|
|
|
|
|
|
|
$model->save();
|
|
|
|
|
|
|
|
// Gestione delle revisioni
|
|
|
|
$model->master_revision = $model->id;
|
|
|
|
$model->default_revision = 1;
|
|
|
|
|
|
|
|
$model->save();
|
|
|
|
|
|
|
|
return $model;
|
|
|
|
}
|
|
|
|
|
2019-09-10 09:44:16 +02:00
|
|
|
// Attributi Eloquent
|
|
|
|
|
2019-09-11 17:58:40 +02:00
|
|
|
public function getOreInterventiAttribute()
|
2019-09-10 09:44:16 +02:00
|
|
|
{
|
2019-09-11 17:58:40 +02:00
|
|
|
if (!isset($this->info['ore_interventi'])) {
|
2019-09-10 09:44:16 +02:00
|
|
|
$sessioni = collect();
|
|
|
|
|
2019-09-11 17:58:40 +02:00
|
|
|
$interventi = $this->interventi;
|
2019-09-10 09:44:16 +02:00
|
|
|
foreach ($interventi as $intervento) {
|
|
|
|
$sessioni = $sessioni->merge($intervento->sessioni);
|
|
|
|
}
|
|
|
|
|
2019-09-11 17:58:40 +02:00
|
|
|
$this->info['ore_interventi'] = $sessioni->sum('ore');
|
2019-09-10 09:44:16 +02:00
|
|
|
}
|
|
|
|
|
2019-09-11 17:58:40 +02:00
|
|
|
return $this->info['ore_interventi'];
|
2019-09-10 09:44:16 +02:00
|
|
|
}
|
|
|
|
|
2019-01-01 11:39:20 +01:00
|
|
|
/**
|
|
|
|
* Restituisce il nome del modulo a cui l'oggetto è collegato.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getModuleAttribute()
|
|
|
|
{
|
|
|
|
return 'Preventivi';
|
|
|
|
}
|
|
|
|
|
2019-03-29 12:46:17 +01:00
|
|
|
public function getDirezioneAttribute()
|
2019-01-01 11:39:20 +01:00
|
|
|
{
|
2019-03-29 12:46:17 +01:00
|
|
|
return 'entrata';
|
2019-01-01 11:39:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function anagrafica()
|
|
|
|
{
|
|
|
|
return $this->belongsTo(Anagrafica::class, 'idanagrafica');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function stato()
|
|
|
|
{
|
|
|
|
return $this->belongsTo(Stato::class, 'idstato');
|
|
|
|
}
|
|
|
|
|
2019-01-02 10:08:08 +01:00
|
|
|
public function tipoSessione()
|
|
|
|
{
|
|
|
|
return $this->belongsTo(TipoSessione::class, 'idtipointervento');
|
|
|
|
}
|
|
|
|
|
2019-01-01 11:39:20 +01:00
|
|
|
public function articoli()
|
|
|
|
{
|
|
|
|
return $this->hasMany(Components\Articolo::class, 'idpreventivo');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function righe()
|
|
|
|
{
|
|
|
|
return $this->hasMany(Components\Riga::class, 'idpreventivo');
|
|
|
|
}
|
|
|
|
|
2019-04-04 17:12:32 +02:00
|
|
|
public function sconti()
|
|
|
|
{
|
|
|
|
return $this->hasMany(Components\Sconto::class, 'idpreventivo');
|
|
|
|
}
|
|
|
|
|
2019-01-01 11:39:20 +01:00
|
|
|
public function descrizioni()
|
|
|
|
{
|
|
|
|
return $this->hasMany(Components\Descrizione::class, 'idpreventivo');
|
|
|
|
}
|
|
|
|
|
2019-02-14 17:49:58 +01:00
|
|
|
public function interventi()
|
|
|
|
{
|
|
|
|
return $this->hasMany(Intervento::class, 'id_preventivo');
|
|
|
|
}
|
|
|
|
|
2019-05-04 06:39:18 +02:00
|
|
|
public function fixBudget()
|
|
|
|
{
|
2019-09-05 18:40:39 +02:00
|
|
|
$this->budget = $this->totale_imponibile ?: 0;
|
2019-05-04 06:39:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function save(array $options = [])
|
|
|
|
{
|
|
|
|
$this->fixBudget();
|
|
|
|
|
|
|
|
return parent::save($options);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function delete()
|
|
|
|
{
|
|
|
|
$this->interventi()->update(['id_preventivo' => null]);
|
|
|
|
$revision = $this->master_revision;
|
|
|
|
|
2019-05-04 06:41:56 +02:00
|
|
|
$result = parent::delete();
|
2019-05-04 06:39:18 +02:00
|
|
|
|
|
|
|
self::where('master_revision', $revision)->delete();
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
2019-07-22 18:35:13 +02:00
|
|
|
/**
|
|
|
|
* Effettua un controllo sui campi del documento.
|
|
|
|
* Viene richiamatp dalle modifiche alle righe del documento.
|
|
|
|
*
|
|
|
|
* @param Description $trigger
|
|
|
|
*/
|
2019-09-13 10:07:54 +02:00
|
|
|
public function triggerEvasione(Description $trigger)
|
2019-07-22 18:35:13 +02:00
|
|
|
{
|
2019-09-13 10:07:54 +02:00
|
|
|
parent::triggerEvasione($trigger);
|
2019-07-22 18:35:13 +02:00
|
|
|
|
|
|
|
$righe = $this->getRighe();
|
|
|
|
|
|
|
|
$qta_evasa = $righe->sum('qta_evasa');
|
|
|
|
$qta = $righe->sum('qta');
|
|
|
|
$parziale = $qta != $qta_evasa;
|
|
|
|
|
2019-07-23 15:39:00 +02:00
|
|
|
$stato_attuale = $this->stato;
|
|
|
|
|
2019-07-22 18:35:13 +02:00
|
|
|
// Impostazione del nuovo stato
|
|
|
|
if ($qta_evasa == 0) {
|
|
|
|
$descrizione = 'In lavorazione';
|
|
|
|
$descrizione_intervento = 'Completato';
|
2019-07-23 15:39:00 +02:00
|
|
|
} elseif (!in_array($stato_attuale->descrizione, ['Parzialmente fatturato', 'Fatturato']) && $trigger->parent instanceof Ordine) {
|
2019-07-22 18:35:13 +02:00
|
|
|
$descrizione = $this->stato->descrizione;
|
|
|
|
$descrizione_intervento = 'Completato';
|
|
|
|
} else {
|
|
|
|
$descrizione = $parziale ? 'Parzialmente fatturato' : 'Fatturato';
|
|
|
|
$descrizione_intervento = 'Fatturato';
|
|
|
|
}
|
|
|
|
|
|
|
|
$stato = Stato::where('descrizione', $descrizione)->first();
|
|
|
|
$this->stato()->associate($stato);
|
|
|
|
$this->save();
|
|
|
|
|
|
|
|
// Trasferimento degli interventi collegati
|
|
|
|
$interventi = $this->interventi;
|
|
|
|
$stato_intervento = \Modules\Interventi\Stato::where('descrizione', $descrizione_intervento)->first();
|
|
|
|
foreach ($interventi as $intervento) {
|
|
|
|
$intervento->stato()->associate($stato_intervento);
|
|
|
|
$intervento->save();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-01-01 11:39:20 +01:00
|
|
|
// Metodi statici
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Calcola il nuovo numero di preventivo.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public static function getNextNumero()
|
|
|
|
{
|
|
|
|
$maschera = setting('Formato codice preventivi');
|
|
|
|
|
2019-01-10 20:10:47 +01:00
|
|
|
$ultimo = Generator::getPreviousFrom($maschera, 'co_preventivi', 'numero');
|
|
|
|
$numero = Generator::generate($maschera, $ultimo);
|
2019-01-01 11:39:20 +01:00
|
|
|
|
|
|
|
return $numero;
|
|
|
|
}
|
|
|
|
}
|