2019-01-19 10:33:57 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Modules\Contratti;
|
|
|
|
|
|
|
|
use Carbon\Carbon;
|
|
|
|
use Common\Document;
|
|
|
|
use Modules\Anagrafiche\Anagrafica;
|
2019-02-14 17:49:58 +01:00
|
|
|
use Modules\Interventi\Intervento;
|
2019-07-08 12:24:59 +02:00
|
|
|
use Modules\TipiIntervento\Tipo as TipoSessione;
|
2019-01-19 10:33:57 +01:00
|
|
|
use Traits\RecordTrait;
|
|
|
|
use Util\Generator;
|
|
|
|
|
|
|
|
class Contratto extends Document
|
|
|
|
{
|
|
|
|
use RecordTrait;
|
|
|
|
|
|
|
|
protected $table = 'co_contratti';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Crea un nuovo contratto.
|
|
|
|
*
|
|
|
|
* @param Anagrafica $anagrafica
|
|
|
|
* @param string $nome
|
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
|
|
|
public static function build(Anagrafica $anagrafica, $nome)
|
|
|
|
{
|
|
|
|
$model = parent::build();
|
|
|
|
|
|
|
|
$stato_documento = Stato::where('descrizione', 'Bozza')->first();
|
|
|
|
|
|
|
|
$id_anagrafica = $anagrafica->id;
|
|
|
|
$id_agente = $anagrafica->idagente;
|
|
|
|
|
|
|
|
$id_pagamento = $anagrafica->idpagamento_vendite;
|
|
|
|
if (empty($id_pagamento)) {
|
|
|
|
$id_pagamento = setting('Tipo di pagamento predefinito');
|
|
|
|
}
|
|
|
|
|
|
|
|
$model->anagrafica()->associate($anagrafica);
|
|
|
|
$model->stato()->associate($stato_documento);
|
|
|
|
|
|
|
|
$model->numero = static::getNextNumero();
|
|
|
|
|
|
|
|
$model->nome = $nome;
|
|
|
|
$model->data_bozza = Carbon::now();
|
|
|
|
|
|
|
|
if (!empty($id_agente)) {
|
|
|
|
$model->idagente = $id_agente;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!empty($id_pagamento)) {
|
|
|
|
$model->idpagamento = $id_pagamento;
|
|
|
|
}
|
|
|
|
|
2019-07-08 12:24:59 +02:00
|
|
|
// Salvataggio delle informazioni
|
2019-01-19 10:33:57 +01:00
|
|
|
$model->save();
|
|
|
|
|
|
|
|
return $model;
|
|
|
|
}
|
|
|
|
|
2019-07-08 12:24:59 +02:00
|
|
|
public function save(array $options = [])
|
|
|
|
{
|
|
|
|
$result = parent::save($options);
|
|
|
|
|
|
|
|
$this->fixTipiSessioni();
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
2019-01-19 10:33:57 +01:00
|
|
|
public function fixTipiSessioni()
|
|
|
|
{
|
|
|
|
$database = database();
|
2019-07-08 12:24:59 +02:00
|
|
|
|
|
|
|
$presenti = $database->fetchArray('SELECT idtipointervento AS id FROM co_contratti_tipiintervento WHERE idcontratto = '.prepare($this->id));
|
2019-01-19 10:33:57 +01:00
|
|
|
|
|
|
|
// Aggiunta associazioni costi unitari al contratto
|
2019-07-08 12:24:59 +02:00
|
|
|
$tipi = TipoSessione::whereNotIn('idtipointervento', array_column($presenti, 'id'))->get();
|
2019-01-19 10:33:57 +01:00
|
|
|
|
|
|
|
foreach ($tipi as $tipo) {
|
|
|
|
$database->insert('co_contratti_tipiintervento', [
|
|
|
|
'idcontratto' => $this->id,
|
|
|
|
'idtipointervento' => $tipo->id,
|
|
|
|
'costo_ore' => $tipo->costo_orario,
|
|
|
|
'costo_km' => $tipo->costo_km,
|
|
|
|
'costo_dirittochiamata' => $tipo->costo_diritto_chiamata,
|
|
|
|
'costo_ore_tecnico' => $tipo->costo_orario_tecnico,
|
|
|
|
'costo_km_tecnico' => $tipo->costo_km_tecnico,
|
|
|
|
'costo_dirittochiamata_tecnico' => $tipo->costo_diritto_chiamata_tecnico,
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Restituisce il nome del modulo a cui l'oggetto è collegato.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getModuleAttribute()
|
|
|
|
{
|
|
|
|
return 'Contratti';
|
|
|
|
}
|
|
|
|
|
2019-03-29 12:46:17 +01:00
|
|
|
public function getDirezioneAttribute()
|
2019-01-19 10:33:57 +01:00
|
|
|
{
|
2019-03-29 12:46:17 +01:00
|
|
|
return 'entrata';
|
2019-01-19 10:33:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function anagrafica()
|
|
|
|
{
|
|
|
|
return $this->belongsTo(Anagrafica::class, 'idanagrafica');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function stato()
|
|
|
|
{
|
|
|
|
return $this->belongsTo(Stato::class, 'idstato');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function articoli()
|
|
|
|
{
|
|
|
|
return $this->hasMany(Components\Articolo::class, 'idcontratto');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function righe()
|
|
|
|
{
|
|
|
|
return $this->hasMany(Components\Riga::class, 'idcontratto');
|
|
|
|
}
|
|
|
|
|
2019-04-04 17:12:32 +02:00
|
|
|
public function sconti()
|
|
|
|
{
|
|
|
|
return $this->hasMany(Components\Sconto::class, 'idcontratto');
|
|
|
|
}
|
|
|
|
|
2019-01-19 10:33:57 +01:00
|
|
|
public function descrizioni()
|
|
|
|
{
|
|
|
|
return $this->hasMany(Components\Descrizione::class, 'idcontratto');
|
|
|
|
}
|
|
|
|
|
2019-02-14 17:49:58 +01:00
|
|
|
public function interventi()
|
|
|
|
{
|
|
|
|
return $this->hasMany(Intervento::class, 'id_contratto');
|
|
|
|
}
|
|
|
|
|
2019-01-19 10:33:57 +01:00
|
|
|
// Metodi statici
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Calcola il nuovo numero di contratto.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public static function getNextNumero()
|
|
|
|
{
|
|
|
|
$maschera = setting('Formato codice contratti');
|
|
|
|
|
|
|
|
$ultimo = Generator::getPreviousFrom($maschera, 'co_contratti', 'numero');
|
|
|
|
$numero = Generator::generate($maschera, $ultimo);
|
|
|
|
|
|
|
|
return $numero;
|
|
|
|
}
|
|
|
|
}
|