1
0
mirror of https://github.com/devcode-it/openstamanager.git synced 2025-01-09 14:14:10 +01:00
openstamanager/modules/interventi/src/Intervento.php

115 lines
2.7 KiB
PHP
Raw Normal View History

2018-08-29 18:06:51 +02:00
<?php
namespace Modules\Interventi;
2018-12-14 09:46:35 +01:00
use Common\Document;
2018-08-29 18:06:51 +02:00
use Modules\Anagrafiche\Anagrafica;
2019-02-14 17:49:58 +01:00
use Modules\Contratti\Contratto;
2019-01-11 08:32:08 +01:00
use Modules\Preventivi\Preventivo;
use Util\Generator;
2018-08-29 18:06:51 +02:00
2018-12-14 09:46:35 +01:00
class Intervento extends Document
2018-08-29 18:06:51 +02:00
{
protected $table = 'in_interventi';
2019-01-11 08:32:08 +01:00
/**
* Crea un nuovo preventivo.
*
* @param Anagrafica $anagrafica
* @param TipoSessione $tipo_sessione
* @param Stato $stato
* @param string $data_richiesta
*
* @return self
*/
public static function build(Anagrafica $anagrafica, TipoSessione $tipo_sessione, Stato $stato, $data_richiesta)
{
$model = parent::build();
$model->anagrafica()->associate($anagrafica);
$model->stato()->associate($stato);
$model->tipoSessione()->associate($tipo_sessione);
$model->codice = static::getNextCodice($data_richiesta);
2019-01-11 08:32:08 +01:00
$model->data_richiesta = $data_richiesta;
$model->save();
return $model;
}
2018-08-29 18:06:51 +02:00
public function anagrafica()
{
return $this->belongsTo(Anagrafica::class, 'idanagrafica');
}
2019-01-11 08:32:08 +01:00
public function preventivo()
{
2019-02-14 17:49:58 +01:00
return $this->belongsTo(Preventivo::class, 'id_preventivo');
}
public function contratto()
{
return $this->belongsTo(Contratto::class, 'id_contratto');
2019-01-11 08:32:08 +01:00
}
2018-08-29 18:06:51 +02:00
public function stato()
{
return $this->belongsTo(Stato::class, 'idstatointervento');
}
2019-01-11 08:32:08 +01:00
public function tipoSessione()
{
return $this->belongsTo(TipoSessione::class, 'idtipointervento');
}
2018-08-29 18:06:51 +02:00
public function articoli()
{
return $this->hasMany(Components\Articolo::class, 'idintervento');
2018-08-29 18:06:51 +02:00
}
public function righe()
{
return $this->hasMany(Components\Riga::class, 'idintervento');
2018-08-29 18:06:51 +02:00
}
2018-12-25 11:32:19 +01:00
2019-04-04 17:12:32 +02:00
public function sconti()
{
return $this->hasMany(Components\Sconto::class, 'idintervento');
}
2018-12-25 11:33:15 +01:00
public function descrizioni()
{
2019-03-29 12:46:17 +01:00
return $this->righe()->where('prezzo_vendita', 0);
2018-12-25 11:32:19 +01:00
}
2019-01-11 08:32:08 +01:00
public function sessioni()
{
return $this->hasMany(Components\Sessione::class, 'idintervento');
}
2019-01-11 08:32:08 +01:00
// Metodi statici
/**
* Calcola il nuovo codice di intervento.
*
* @param string $data
*
2019-01-11 08:32:08 +01:00
* @return string
*/
public static function getNextCodice($data)
2019-01-11 08:32:08 +01:00
{
$maschera = setting('Formato codice intervento');
//$ultimo = Generator::getPreviousFrom($maschera, 'in_interventi', 'codice');
$ultimo = Generator::getPreviousFrom($maschera, 'in_interventi', 'codice', [
'YEAR(data_richiesta) = '.prepare(date('Y', strtotime($data))),
]);
2019-01-11 08:32:08 +01:00
$numero = Generator::generate($maschera, $ultimo);
return $numero;
}
2018-08-29 18:06:51 +02:00
}