Report.php 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300
  1. <?php
  2. namespace App\Models;
  3. use Illuminate\Database\Eloquent\Factories\HasFactory;
  4. use Illuminate\Database\Eloquent\Model;
  5. class Report extends Model
  6. {
  7. use HasFactory;
  8. public $timestamps = false;
  9. protected $table = 'fcf_reports_reports';
  10. protected $fillable = [
  11. 'name',
  12. 'validated' ,
  13. 'necessita_nulla_osta' ,
  14. 'data_nulla_osta' ,
  15. 'protocollo_num' ,
  16. 'protocollo_ord' ,
  17. 'protocollo_anno' ,
  18. 'verificatosi_in_data' ,
  19. 'verificatosi_in_data_ora' ,
  20. 'verificatosi_in_data_minuti' ,
  21. 'utg' ,
  22. 'utg_data' ,
  23. 'utg_protocollo',
  24. 'ag' ,
  25. 'ag_data' ,
  26. 'ag_protocollo',
  27. 'incidente_con_danni_a_cose' ,
  28. 'incidente_con_feriti' ,
  29. 'incidente_con_feriti_lesioni_lievi' ,
  30. 'incidente_con_feriti_lesioni_gravi' ,
  31. 'incidente_mortale' ,
  32. 'localita_uno' ,
  33. 'localita_due' ,
  34. 'intersezione_con' ,
  35. 'prossimita_civico',
  36. 'prossimita_palo_luce',
  37. 'prossimita_chilometro',
  38. 'note_aggiuntive' ,
  39. 'accertatore_1' ,
  40. 'grado_accertatore_1' ,
  41. 'accertatore_2' ,
  42. 'grado_accertatore_2' ,
  43. 'accertatore_3' ,
  44. 'grado_accertatore_3' ,
  45. 'accertatore_4' ,
  46. 'grado_accertatore_4' ,
  47. 'accertatore_5' ,
  48. 'grado_accertatore_5' ,
  49. 'rilievi_id' ,
  50. 'parti_coinvolte_1_nome' ,
  51. 'parti_coinvolte_2_nome' ,
  52. 'parti_coinvolte_3_nome' ,
  53. 'parti_coinvolte_1_veicolo' ,
  54. 'parti_coinvolte_2_veicolo' ,
  55. 'parti_coinvolte_3_veicolo' ,
  56. 'tipo_urto_altro' ,
  57. 'segnalazione_data' ,
  58. 'segnalazione_ora',
  59. 'segnalazione_minuti',
  60. 'segnalazione_altro',
  61. 'ausilio_altri_enti_motivo',
  62. 'ausilio_altri_enti_ora_intervento',
  63. 'ausilio_altri_enti_minuti_intervento',
  64. 'ditta_intervenuta' ,
  65. 'ripristino_ora_chiamata' ,
  66. 'ripristino_minuti_chiamata' ,
  67. 'ripristino_ora_arrivo' ,
  68. 'ripristino_minuti_arrivo' ,
  69. 'danni_cose_diverse_da_veicoli',
  70. 'sinistro_ora' ,
  71. 'sinistro_minuti' ,
  72. 'localizzazione_incidente' ,
  73. 'localizzazione_incidente_altro',
  74. 'condizioni_atmosferiche' ,
  75. 'condizioni_atmosferiche_altro' ,
  76. 'nomenclatura_strada' ,
  77. 'nomenclatura_strada_numero' ,
  78. 'nomenclatura_strada_altro' ,
  79. 'pavimentazione' ,
  80. 'pavimentazione_altro' ,
  81. 'condizione_strada' ,
  82. 'condizione_strada_altro' ,
  83. 'fondo_stradale' ,
  84. 'fondo_stradale_specifica' ,
  85. 'visibilita' ,
  86. 'visibilita_specifica' ,
  87. 'particolarita_strada' ,
  88. 'particolarita_strada_specifica' ,
  89. 'tipo_strada' ,
  90. 'tipo_strada_altro' ,
  91. 'traffico' ,
  92. 'segnaletica' ,
  93. 'segnaletica_verticale_1_via' ,
  94. 'segnaletica_verticale_1_altro' ,
  95. 'segnaletica_verticale_1_limite_velocita' ,
  96. 'segnaletica_verticale_1_limite_direzione' ,
  97. 'segnaletica_verticale_1_pannello_integrativo' ,
  98. 'segnaletica_verticale_2_via' ,
  99. 'segnaletica_verticale_2_altro' ,
  100. 'segnaletica_verticale_2_limite_velocita' ,
  101. 'segnaletica_verticale_2_limite_direzione' ,
  102. 'segnaletica_verticale_2_pannello_integrativo' ,
  103. 'segnaletica_verticale_3_via' ,
  104. 'segnaletica_verticale_3_altro' ,
  105. 'segnaletica_verticale_3_limite_velocita' ,
  106. 'segnaletica_verticale_3_limite_direzione' ,
  107. 'segnaletica_verticale_3_pannello_integrativo' ,
  108. 'segnaletica_verticale_4_via' ,
  109. 'segnaletica_verticale_4_altro' ,
  110. 'segnaletica_verticale_4_limite_velocita' ,
  111. 'segnaletica_verticale_4_limite_direzione' ,
  112. 'segnaletica_verticale_4_pannello_integrativo' ,
  113. 'segnaletica_orizzontale_1_via' ,
  114. 'segnaletica_orizzontale_1_linea_margine' ,
  115. 'segnaletica_orizzontale_1_linea_margine_specifica' ,
  116. 'segnaletica_orizzontale_1_linea_mezzeria' ,
  117. 'segnaletica_orizzontale_1_linea_mezzeria_specifica' ,
  118. 'segnaletica_orizzontale_1_altro' ,
  119. 'segnaletica_orizzontale_1_direzione' ,
  120. 'segnaletica_orizzontale_2_via' ,
  121. 'segnaletica_orizzontale_2_linea_margine' ,
  122. 'segnaletica_orizzontale_2_linea_margine_specifica' ,
  123. 'segnaletica_orizzontale_2_linea_mezzeria' ,
  124. 'segnaletica_orizzontale_2_linea_mezzeria_specifica' ,
  125. 'segnaletica_orizzontale_2_altro' ,
  126. 'segnaletica_orizzontale_2_direzione' ,
  127. 'segnaletica_orizzontale_3_via' ,
  128. 'segnaletica_orizzontale_3_linea_margine' ,
  129. 'segnaletica_orizzontale_3_linea_margine_specifica' ,
  130. 'segnaletica_orizzontale_3_linea_mezzeria' ,
  131. 'segnaletica_orizzontale_3_linea_mezzeria_specifica' ,
  132. 'segnaletica_orizzontale_3_altro' ,
  133. 'segnaletica_orizzontale_3_direzione' ,
  134. 'segnaletica_orizzontale_4_via' ,
  135. 'segnaletica_orizzontale_4_linea_margine' ,
  136. 'segnaletica_orizzontale_4_linea_margine_specifica' ,
  137. 'segnaletica_orizzontale_4_linea_mezzeria' ,
  138. 'segnaletica_orizzontale_4_linea_mezzeria_specifica' ,
  139. 'segnaletica_orizzontale_4_altro' ,
  140. 'segnaletica_orizzontale_4_direzione' ,
  141. 'state' ,
  142. 'created',
  143. 'created_by' ,
  144. 'updated',
  145. 'updated_by' ,
  146. 'locked' ,
  147. 'locked_by' ,
  148. ];
  149. public function localita()
  150. {
  151. return $this->belongsTo(\App\Models\LocationTown::class, 'localita_uno');
  152. }
  153. public function indirizzo()
  154. {
  155. return $this->belongsTo(\App\Models\Stradario::class, 'localita_due');
  156. }
  157. public function rilievo()
  158. {
  159. return $this->belongsTo(\App\Models\Rilievi::class, 'rilievi_id');
  160. }
  161. public function nomenclatura()
  162. {
  163. return $this->belongsTo(\App\Models\NomenclaturaStrada::class, 'nomenclatura_strada');
  164. }
  165. public function condizioneatmosferiche()
  166. {
  167. return $this->belongsTo(\App\Models\CondizioniAtmosferiche::class, 'condizioni_atmosferiche');
  168. }
  169. public function pavimentazione_value()
  170. {
  171. return $this->belongsTo(\App\Models\PavimentazioneStrada::class, 'pavimentazione');
  172. }
  173. public function condizione_strada_value()
  174. {
  175. return $this->belongsTo(\App\Models\CondizioneStrada::class, 'condizione_strada');
  176. }
  177. public function fondo_stradale_value()
  178. {
  179. return $this->belongsTo(\App\Models\FondoStradale::class, 'fondo_stradale');
  180. }
  181. public function particolarita_strada_value()
  182. {
  183. return $this->belongsTo(\App\Models\ParticolaritaStrada::class, 'particolarita_strada');
  184. }
  185. public function segnaletica_verticale_1_via_value()
  186. {
  187. return $this->belongsTo(\App\Models\Stradario::class, 'segnaletica_verticale_1_via');
  188. }
  189. public function segnaletica_verticale_2_via_value()
  190. {
  191. return $this->belongsTo(\App\Models\Stradario::class, 'segnaletica_verticale_2_via');
  192. }
  193. public function segnaletica_verticale_3_via_value()
  194. {
  195. return $this->belongsTo(\App\Models\Stradario::class, 'segnaletica_verticale_3_via');
  196. }
  197. public function segnaletica_verticale_4_via_value()
  198. {
  199. return $this->belongsTo(\App\Models\Stradario::class, 'segnaletica_verticale_4_via');
  200. }
  201. public function segnaletica_orizzontale_1_via_value()
  202. {
  203. return $this->belongsTo(\App\Models\Stradario::class, 'segnaletica_orizzontale_1_via');
  204. }
  205. public function segnaletica_orizzontale_2_via_value()
  206. {
  207. return $this->belongsTo(\App\Models\Stradario::class, 'segnaletica_orizzontale_2_via');
  208. }
  209. public function segnaletica_orizzontale_3_via_value()
  210. {
  211. return $this->belongsTo(\App\Models\Stradario::class, 'segnaletica_orizzontale_3_via');
  212. }
  213. public function segnaletica_orizzontale_4_via_value()
  214. {
  215. return $this->belongsTo(\App\Models\Stradario::class, 'segnaletica_orizzontale_4_via');
  216. }
  217. public function accertatore_1_value()
  218. {
  219. return $this->belongsTo(\App\Models\User::class, 'accertatore_1');
  220. }
  221. public function grado_accertatore_1_value()
  222. {
  223. return $this->belongsTo(\App\Models\AccertatoreGrado::class, 'grado_accertatore_1');
  224. }
  225. public function accertatore_2_value()
  226. {
  227. return $this->belongsTo(\App\Models\User::class, 'accertatore_2');
  228. }
  229. public function grado_accertatore_2_value()
  230. {
  231. return $this->belongsTo(\App\Models\AccertatoreGrado::class, 'grado_accertatore_2');
  232. }
  233. public function accertatore_3_value()
  234. {
  235. return $this->belongsTo(\App\Models\User::class, 'accertatore_3');
  236. }
  237. public function grado_accertatore_3_value()
  238. {
  239. return $this->belongsTo(\App\Models\AccertatoreGrado::class, 'grado_accertatore_3');
  240. }
  241. public function accertatore_4_value()
  242. {
  243. return $this->belongsTo(\App\Models\User::class, 'accertatore_4');
  244. }
  245. public function grado_accertatore_4_value()
  246. {
  247. return $this->belongsTo(\App\Models\AccertatoreGrado::class, 'grado_accertatore_4');
  248. }
  249. public function accertatore_5_value()
  250. {
  251. return $this->belongsTo(\App\Models\User::class, 'accertatore_5');
  252. }
  253. public function grado_accertatore_5_value()
  254. {
  255. return $this->belongsTo(\App\Models\AccertatoreGrado::class, 'grado_accertatore_5');
  256. }
  257. public function reportDataPedoni()
  258. {
  259. return $this->belongsTo(\App\Models\ReportDataPedoni::class, 'report_id');
  260. }
  261. public function allegati()
  262. {
  263. return $this->hasMany(ReportAllegatiGallery::class);
  264. }
  265. }