diff --git a/app/Database/migrations/2017_12_20_005147_create_acars_tables.php b/app/Database/migrations/2017_12_20_005147_create_acars_tables.php index ee7a087b..14be0fd3 100644 --- a/app/Database/migrations/2017_12_20_005147_create_acars_tables.php +++ b/app/Database/migrations/2017_12_20_005147_create_acars_tables.php @@ -29,6 +29,7 @@ class CreateAcarsTables extends Migration $table->unsignedInteger('gs')->nullable(); $table->unsignedInteger('transponder')->nullable(); $table->string('autopilot')->nullable(); + $table->decimal('fuel')->nullable(); $table->decimal('fuel_flow')->nullable(); $table->string('sim_time')->nullable(); diff --git a/app/Database/seeds/in_progress.yml b/app/Database/seeds/in_progress.yml new file mode 100644 index 00000000..44490d83 --- /dev/null +++ b/app/Database/seeds/in_progress.yml @@ -0,0 +1,1075 @@ +acars: + - + id: aOYyrOopomBd + pirep_id: dNk9qNnojYKe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.934786422889' + lon: '-76.778003584686' + heading: '292' + altitude: '8.1515683516007' + vs: '0' + gs: '0' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-01 23:49:04' + updated_at: '2018-05-01 23:49:04' + - + id: bW67DZA551Ja + pirep_id: dNk9qNnojYKe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.934786432775' + lon: '-76.77800361008' + heading: '292' + altitude: '8.1583404581437' + vs: '0' + gs: '0.0074230431465574' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 00:28:36' + updated_at: '2018-05-02 00:28:36' + - + id: erkRwJWQnr4a + pirep_id: dNk9qNnojYKe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.934786689673' + lon: '-76.77800427491' + heading: '292' + altitude: '8.1583200798013' + vs: '0' + gs: '0.0063170024918172' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 00:28:58' + updated_at: '2018-05-02 00:28:58' + - + id: bmZQoAzRGYAd + pirep_id: dNk9qNnojYKe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.934786863364' + lon: '-76.778004724083' + heading: '292' + altitude: '8.1583258454302' + vs: '0' + gs: '0.0062211738290854' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 00:29:13' + updated_at: '2018-05-02 00:29:13' + - + id: mbk8EolwQOEd + pirep_id: dNk9qNnojYKe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.934787031837' + lon: '-76.778005160205' + heading: '292' + altitude: '8.1583950316794' + vs: '0' + gs: '0.0074284254152491' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 00:29:28' + updated_at: '2018-05-02 00:29:28' + - + id: bYEvG2JvOJAb + pirep_id: dNk9qNnojYKe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.934787200997' + lon: '-76.778005597894' + heading: '292' + altitude: '8.1583980328179' + vs: '0' + gs: '0.0056652719315407' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 00:29:43' + updated_at: '2018-05-02 00:29:43' + - + id: ejRqlxwJ5Ave + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.934787330613' + lon: '-76.778005933186' + heading: '292' + altitude: '8.1584579148505' + vs: '0' + gs: '0' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 00:31:21' + updated_at: '2018-05-02 00:31:21' + - + id: bkRZmyxPQwva + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.934787413408' + lon: '-76.778006147368' + heading: '292' + altitude: '8.1587934295896' + vs: '0' + gs: '0.0057051356580496' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 00:32:10' + updated_at: '2018-05-02 00:32:10' + - + id: lejZDnk5qMWe + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.934788873785' + lon: '-76.778009925791' + heading: '292' + altitude: '8.1591462785382' + vs: '0' + gs: '0.0087238823686628' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 00:35:15' + updated_at: '2018-05-02 00:35:15' + - + id: aM8QpMPDAMPe + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.934842509128' + lon: '-76.778532656292' + heading: '223' + altitude: '8.1607914299049' + vs: '0' + gs: '6.4202715128239' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 00:35:30' + updated_at: '2018-05-02 00:35:30' + - + id: aQW0wQl1jz7d + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.934617196721' + lon: '-76.778605526212' + heading: '194' + altitude: '8.1632128918151' + vs: '0' + gs: '0.78235724264669' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 00:35:45' + updated_at: '2018-05-02 00:35:45' + - + id: eVOPBYqAPWMa + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.934300718688' + lon: '-76.778703210335' + heading: '176' + altitude: '8.1666375744461' + vs: '0' + gs: '6.8945587994399' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 00:36:00' + updated_at: '2018-05-02 00:36:00' + - + id: epYQ0EpZyp1a + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.934118452794' + lon: '-76.77856797319' + heading: '124' + altitude: '8.166254969636' + vs: '0' + gs: '0.0063371483834717' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 00:36:15' + updated_at: '2018-05-02 00:36:15' + - + id: b2kv53PWlqKd + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.934118203036' + lon: '-76.778567591848' + heading: '124' + altitude: '8.1663702576785' + vs: '0' + gs: '0.0070555182089322' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 00:36:30' + updated_at: '2018-05-02 00:36:30' + - + id: aM8QpMPEB15e + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.934117958358' + lon: '-76.77856721815' + heading: '124' + altitude: '8.1663703232199' + vs: '0' + gs: '0.0064996252497234' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 00:36:45' + updated_at: '2018-05-02 00:36:45' + - + id: eZ6VJ3xj8vge + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.934117498661' + lon: '-76.778566516289' + heading: '124' + altitude: '8.1664622222087' + vs: '0' + gs: '0' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 00:40:16' + updated_at: '2018-05-02 00:40:16' + - + id: bo2QqDLl2lLa + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.933884143334' + lon: '-76.778210172233' + heading: '124' + altitude: '8.1707802663933' + vs: '0' + gs: '14.419195209695' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:22:25' + updated_at: '2018-05-02 01:22:25' + - + id: aM8QpM4qV2Be + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.933705349611' + lon: '-76.777936938059' + heading: '124' + altitude: '8.170089899507' + vs: '0' + gs: '15.392330039049' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:22:55' + updated_at: '2018-05-02 01:22:55' + - + id: dR6oxR9qjoOd + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.933130691906' + lon: '-76.777152737985' + heading: '158' + altitude: '8.1683570286331' + vs: '0' + gs: '10.450467475023' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:23:10' + updated_at: '2018-05-02 01:23:10' + - + id: erkRwJODRvEa + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.932580370289' + lon: '-76.777450200122' + heading: '221' + altitude: '8.1695896791822' + vs: '0' + gs: '12.932334300694' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:23:25' + updated_at: '2018-05-02 01:23:25' + - + id: b2kv53VMy7Ad + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.932012550651' + lon: '-76.778009113329' + heading: '296' + altitude: '8.1683852467213' + vs: '0' + gs: '10.502719192825' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:23:41' + updated_at: '2018-05-02 01:23:41' + - + id: eXDoE14JxAve + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.932052237309' + lon: '-76.778111495187' + heading: '290' + altitude: '8.1719753739837' + vs: '0' + gs: '12.643743277153' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:23:42' + updated_at: '2018-05-02 01:23:42' + - + id: b68R5gZ5YyOe + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.932664026837' + lon: '-76.779705339967' + heading: '293' + altitude: '8.2203963962548' + vs: '0' + gs: '64.870244840054' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:23:52' + updated_at: '2018-05-02 01:23:52' + - + id: bqxYvGNN5N0a + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.934300220408' + lon: '-76.783954914814' + heading: '293' + altitude: '8.3302468103811' + vs: '0' + gs: '122.78529244208' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:24:02' + updated_at: '2018-05-02 01:24:02' + - + id: en5rpBKw514d + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.935736496556' + lon: '-76.78765616448' + heading: '293' + altitude: '49.554739665916' + vs: '21' + gs: '146.79677958636' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:24:08' + updated_at: '2018-05-02 01:24:08' + - + id: erkRwJA29l2a + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '17.976972983585' + lon: '-76.896548114872' + heading: '297' + altitude: '6228.684012199' + vs: '62' + gs: '281.03976876098' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:26:08' + updated_at: '2018-05-02 01:26:08' + - + id: dR6oxR3r5nwd + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '18.061360208405' + lon: '-77.056156629983' + heading: '301' + altitude: '12522.331716891' + vs: '25' + gs: '371.70833265547' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:28:08' + updated_at: '2018-05-02 01:28:08' + - + id: e1wr82J877Zb + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '18.17373613295' + lon: '-77.260347185993' + heading: '301' + altitude: '16802.15636323' + vs: '43' + gs: '421.37353688139' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:30:08' + updated_at: '2018-05-02 01:30:08' + - + id: bqxYvGyExN2a + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '18.193907285814' + lon: '-77.29810465405' + heading: '297' + altitude: '17395.953175647' + vs: '40' + gs: '425.98105291451' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:35:21' + updated_at: '2018-05-02 01:35:21' + - + id: aQW0wQDQk5Md + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '18.648921231143' + lon: '-78.014696613517' + heading: '323' + altitude: '37108.124381987' + vs: '22' + gs: '438.52028383384' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:37:20' + updated_at: '2018-05-02 01:37:20' + - + id: e9rQ5lk3p63a + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '18.796585259338' + lon: '-78.194734005052' + heading: '260' + altitude: '39718.178225504' + vs: '19' + gs: '432.41969107334' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:39:20' + updated_at: '2018-05-02 01:39:20' + - + id: aQW0wQP8vZqd + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '18.660552760063' + lon: '-78.407597067994' + heading: '242' + altitude: '40998.775690971' + vs: '-25' + gs: '449.51695639627' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:41:20' + updated_at: '2018-05-02 01:41:20' + - + id: bqxYvGKgp32a + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '18.592775999582' + lon: '-78.638711340118' + heading: '298' + altitude: '41060.297106821' + vs: '0' + gs: '427.14806185954' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:43:20' + updated_at: '2018-05-02 01:43:20' + - + id: bqxYvGg2r02a + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '18.718367591656' + lon: '-78.840980459275' + heading: '284' + altitude: '41065.55293844' + vs: '1' + gs: '424.89060056552' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:45:20' + updated_at: '2018-05-02 01:45:20' + - + id: e0RV61wPj53b + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '18.77448809677' + lon: '-79.082727467209' + heading: '283' + altitude: '41069.809333539' + vs: '0' + gs: '425.02780492483' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:47:21' + updated_at: '2018-05-02 01:47:21' + - + id: dwpmBOo3wWwe + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '18.813031600863' + lon: '-79.249543355636' + heading: '283' + altitude: '41072.545805172' + vs: '0' + gs: '425.04687332464' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:48:46' + updated_at: '2018-05-02 01:48:46' + - + id: ejRqlxXoZPle + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '18.840653974635' + lon: '-79.370042672541' + heading: '283' + altitude: '40396.200981621' + vs: '-16' + gs: '428.08364925851' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:49:16' + updated_at: '2018-05-02 01:49:16' + - + id: eVOPBYw4q9Xa + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '18.868358744495' + lon: '-79.491434926253' + heading: '283' + altitude: '39399.093383161' + vs: '-16' + gs: '427.57826037174' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:49:46' + updated_at: '2018-05-02 01:49:46' + - + id: aOYyrOmVPzEd + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '18.896191929474' + lon: '-79.613169477385' + heading: '284' + altitude: '36491.730092364' + vs: '-55' + gs: '429.74732238829' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:50:16' + updated_at: '2018-05-02 01:50:16' + - + id: dL98oLQgyzje + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '18.9242378342' + lon: '-79.736368411294' + heading: '284' + altitude: '32998.644142986' + vs: '-61' + gs: '434.90864533098' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:50:46' + updated_at: '2018-05-02 01:50:46' + - + id: e9rQ5lqD2o8a + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '18.952608029755' + lon: '-79.861339775352' + heading: '284' + altitude: '29069.168636089' + vs: '-68' + gs: '441.90475491564' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:51:16' + updated_at: '2018-05-02 01:51:16' + - + id: av2oANWY1vma + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '18.981670375928' + lon: '-79.987960713131' + heading: '283' + altitude: '24954.890708875' + vs: '-56' + gs: '447.81957529674' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:51:46' + updated_at: '2018-05-02 01:51:46' + - + id: 9aAN4mxlK9zb + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '19.01074931075' + lon: '-80.116947122245' + heading: '283' + altitude: '21483.90439337' + vs: '-57' + gs: '450.05461228268' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:52:16' + updated_at: '2018-05-02 01:52:16' + - + id: e1wr82gp8zGb + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '19.039021032617' + lon: '-80.242584645189' + heading: '283' + altitude: '18000.954967422' + vs: '-58' + gs: '431.5690825604' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:52:46' + updated_at: '2018-05-02 01:52:46' + - + id: dG65jDL2gK0b + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '19.066116186076' + lon: '-80.36338355333' + heading: '284' + altitude: '14630.153058153' + vs: '-55' + gs: '414.70845758094' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:53:16' + updated_at: '2018-05-02 01:53:16' + - + id: epYQ0ENmyvXa + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '19.091238961633' + lon: '-80.475901417309' + heading: '284' + altitude: '11927.379697397' + vs: '-17' + gs: '381.57664353055' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:53:46' + updated_at: '2018-05-02 01:53:46' + - + id: erkRwJPrVoEa + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '19.10261633392' + lon: '-80.527021151647' + heading: '284' + altitude: '11424.525210898' + vs: '-17' + gs: '337.58307680654' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:54:16' + updated_at: '2018-05-02 01:54:16' + - + id: e1wr82gZXqZb + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '19.112886513796' + lon: '-80.57297038027' + heading: '284' + altitude: '10919.983208888' + vs: '-16' + gs: '307.28164751381' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:54:46' + updated_at: '2018-05-02 01:54:46' + - + id: eER95AJ4XLga + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '19.122449020305' + lon: '-80.615560002642' + heading: '284' + altitude: '10418.227268525' + vs: '-16' + gs: '292.97011599774' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:55:16' + updated_at: '2018-05-02 01:55:16' + - + id: dPNZvP0O0Gza + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '19.131746364354' + lon: '-80.657133675868' + heading: '284' + altitude: '9921.6695218175' + vs: '-16' + gs: '293.10586428433' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:55:46' + updated_at: '2018-05-02 01:55:46' + - + id: aQW0wQYVm2Yd + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '19.141074988147' + lon: '-80.698952940579' + heading: '284' + altitude: '9423.0799985721' + vs: '-16' + gs: '291.77956791503' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:56:16' + updated_at: '2018-05-02 01:56:16' + - + id: eXDoE11x32We + pirep_id: b68R5gwVzpVe + type: '0' + nav_type: null + order: '0' + name: null + log: null + lat: '19.150291803457' + lon: '-80.740363792336' + heading: '284' + altitude: '8921.7506913567' + vs: '-16' + gs: '289.03760297791' + transponder: null + autopilot: null + fuel_flow: null + sim_time: null + created_at: '2018-05-02 01:56:46' + updated_at: '2018-05-02 01:56:46' +pireps: + - + id: b68R5gwVzpVe + user_id: '1' + airline_id: '1' + aircraft_id: '1' + flight_number: '13' + route_code: null + route_leg: null + flight_type: J + dpt_airport_id: MKJP + arr_airport_id: MWCR + level: '320' + distance: '249.63' + planned_distance: '273.09' + block_time: null + flight_time: '0' + planned_flight_time: '0' + zfw: null + block_fuel: '21500.25390625' + fuel_used: null + landing_rate: '0' + score: '0' + route: '' + notes: null + source: '1' + source_name: vmsacars + state: '0' + status: APR + submitted_at: null + block_off_time: '2018-04-28T12:55:40Z' + block_on_time: null + created_at: '2018-05-02 00:31:21' + updated_at: '2018-05-02 01:56:46' diff --git a/app/Http/Controllers/Api/PirepController.php b/app/Http/Controllers/Api/PirepController.php index 4be491b5..da8db702 100644 --- a/app/Http/Controllers/Api/PirepController.php +++ b/app/Http/Controllers/Api/PirepController.php @@ -240,7 +240,8 @@ class PirepController extends Controller */ public function update($id, UpdateRequest $request) { - Log::info('PIREP Update, user '.Auth::id(), $request->post()); + Log::info('PIREP Update, user '.Auth::id()); + Log::info($request->getContent()); $user = Auth::user(); $pirep = Pirep::find($id); diff --git a/app/Http/Requests/Acars/PositionRequest.php b/app/Http/Requests/Acars/PositionRequest.php index 21ca418d..da800e7c 100644 --- a/app/Http/Requests/Acars/PositionRequest.php +++ b/app/Http/Requests/Acars/PositionRequest.php @@ -26,12 +26,13 @@ class PositionRequest extends FormRequest 'positions.*.lat' => 'required|numeric', 'positions.*.lon' => 'required|numeric', 'positions.*.altitude' => 'nullable|numeric', - 'positions.*.heading' => 'nullable|integer|between:0,360', + 'positions.*.heading' => 'nullable|numeric|between:0,360', 'positions.*.vs' => 'nullable', 'positions.*.gs' => 'nullable', 'positions.*.transponder' => 'nullable', 'positions.*.autopilot' => 'nullable', - 'positions.*.fuel_flow' => 'nullable', + 'positions.*.fuel' => 'nullable|numeric', + 'positions.*.fuel_flow' => 'nullable|numeric', 'positions.*.log' => 'nullable', 'positions.*.created_at' => 'nullable|date', ]; diff --git a/app/Http/Requests/Acars/UpdateRequest.php b/app/Http/Requests/Acars/UpdateRequest.php index 2941c3d1..49b86c35 100644 --- a/app/Http/Requests/Acars/UpdateRequest.php +++ b/app/Http/Requests/Acars/UpdateRequest.php @@ -43,9 +43,9 @@ class UpdateRequest extends FormRequest 'notes' => 'nullable', 'source_name' => 'nullable|max:25', 'landing_rate' => 'nullable|numeric', - 'block_off_time' => 'nullable|date', - 'block_on_time' => 'nullable|date', - 'created_at' => 'nullable|date', + 'block_off_time' => 'nullable', + 'block_on_time' => 'nullable', + 'created_at' => 'nullable', 'status' => 'nullable', 'score' => 'nullable|integer', diff --git a/app/Models/Pirep.php b/app/Models/Pirep.php index 375e64b5..d12f66b4 100644 --- a/app/Models/Pirep.php +++ b/app/Models/Pirep.php @@ -33,6 +33,8 @@ use PhpUnitsOfMeasure\Exception\NonStringUnitName; * @property integer block_time * @property integer flight_time In minutes * @property integer planned_flight_time + * @property mixed planned_distance + * @property mixed distance * @property integer score * @property User user * @property Flight|null flight @@ -105,11 +107,20 @@ class Pirep extends Model 'score' => 'integer', 'source' => 'integer', 'state' => 'integer', - 'block_off_time' => 'datetime', - 'block_on_time' => 'datetime', - 'submitted_at' => 'datetime', + #'block_off_time' => 'datetime', + #'block_on_time' => 'datetime', + #'submitted_at' => 'datetime', ]; + /*protected $dates = [ + 'block_off_time', + 'block_on_time', + 'submitted_at', + 'created_at', + 'updated_at', + 'deleted_at' + ];*/ + public static $rules = [ 'airline_id' => 'required|exists:airlines,id', 'aircraft_id' => 'required|exists:aircraft,id', @@ -140,6 +151,24 @@ class Pirep extends Model return $flight_id; } + /** + * Return the block off time in carbon format + * @return Carbon + */ + public function getBlockOffTimeAttribute() + { + return new Carbon($this->attributes['block_off_time']); + } + + /** + * Return the block on time + * @return Carbon + */ + public function getBlockOnTimeAttribute() + { + return new Carbon($this->attributes['block_on_time']); + } + /** * Return a new Length unit so conversions can be made * @return int|Distance @@ -236,16 +265,16 @@ class Pirep extends Model */ public function getProgressPercentAttribute() { - $upper_bound = $this->flight_time; - if($this->planned_flight_time) { - $upper_bound = $this->planned_flight_time; + $upper_bound = $this->distance['nmi']; + if($this->planned_distance) { + $upper_bound = $this->planned_distance['nmi']; } if(!$upper_bound) { $upper_bound = 1; } - return round(($this->flight_time / $upper_bound) * 100, 0); + return round(($this->distance['nmi'] / $upper_bound) * 100, 0); } /** diff --git a/app/Providers/AppServiceProvider.php b/app/Providers/AppServiceProvider.php index fbe0ef29..a01140f8 100755 --- a/app/Providers/AppServiceProvider.php +++ b/app/Providers/AppServiceProvider.php @@ -18,6 +18,7 @@ use App\Models\Setting; use App\Models\Subfleet; use App\Repositories\SettingRepository; use App\Services\ModuleService; +use Illuminate\Support\Carbon; use Illuminate\Support\Facades\Schema; use Illuminate\Support\ServiceProvider; use View; @@ -27,6 +28,11 @@ class AppServiceProvider extends ServiceProvider public function boot(): void { Schema::defaultStringLength(191); + + Carbon::serializeUsing(function ($carbon) { + return $carbon->format('U'); + }); + $this->app->bind('setting', SettingRepository::class); View::share('moduleSvc', app(ModuleService::class)); @@ -39,6 +45,7 @@ class AppServiceProvider extends ServiceProvider PirepField::observe(PirepFieldObserver::class); Setting::observe(SettingObserver::class); Subfleet::observe(SubfleetObserver::class); + } /** diff --git a/public/assets/admin/css/vendor.css b/public/assets/admin/css/vendor.css index 535bbe1f..36bf5cd2 100644 --- a/public/assets/admin/css/vendor.css +++ b/public/assets/admin/css/vendor.css @@ -10838,246 +10838,6 @@ button.close { .select2-container--classic.select2-container--open .select2-dropdown { border-color: #5897fb; } -@charset "UTF-8"; - -/*! - * Pikaday - * Copyright © 2014 David Bushell | BSD & MIT license | http://dbushell.com/ - */ - -.pika-single { - z-index: 9999; - display: block; - position: relative; - color: #333; - background: #fff; - border: 1px solid #ccc; - border-bottom-color: #bbb; - font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; -} - -/* -clear child float (pika-lendar), using the famous micro clearfix hack -http://nicolasgallagher.com/micro-clearfix-hack/ -*/ -.pika-single:before, -.pika-single:after { - content: " "; - display: table; -} -.pika-single:after { clear: both } -.pika-single { *zoom: 1 } - -.pika-single.is-hidden { - display: none; -} - -.pika-single.is-bound { - position: absolute; - box-shadow: 0 5px 15px -5px rgba(0,0,0,.5); -} - -.pika-lendar { - float: left; - width: 240px; - margin: 8px; -} - -.pika-title { - position: relative; - text-align: center; -} - -.pika-label { - display: inline-block; - *display: inline; - position: relative; - z-index: 9999; - overflow: hidden; - margin: 0; - padding: 5px 3px; - font-size: 14px; - line-height: 20px; - font-weight: bold; - background-color: #fff; -} -.pika-title select { - cursor: pointer; - position: absolute; - z-index: 9998; - margin: 0; - left: 0; - top: 5px; - filter: alpha(opacity=0); - opacity: 0; -} - -.pika-prev, -.pika-next { - display: block; - cursor: pointer; - position: relative; - outline: none; - border: 0; - padding: 0; - width: 20px; - height: 30px; - /* hide text using text-indent trick, using width value (it's enough) */ - text-indent: 20px; - white-space: nowrap; - overflow: hidden; - background-color: transparent; - background-position: center center; - background-repeat: no-repeat; - background-size: 75% 75%; - opacity: .5; - *position: absolute; - *top: 0; -} - -.pika-prev:hover, -.pika-next:hover { - opacity: 1; -} - -.pika-prev, -.is-rtl .pika-next { - float: left; - background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAeCAYAAAAsEj5rAAAAUklEQVR42u3VMQoAIBADQf8Pgj+OD9hG2CtONJB2ymQkKe0HbwAP0xucDiQWARITIDEBEnMgMQ8S8+AqBIl6kKgHiXqQqAeJepBo/z38J/U0uAHlaBkBl9I4GwAAAABJRU5ErkJggg=='); - *left: 0; -} - -.pika-next, -.is-rtl .pika-prev { - float: right; - background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAeCAYAAAAsEj5rAAAAU0lEQVR42u3VOwoAMAgE0dwfAnNjU26bYkBCFGwfiL9VVWoO+BJ4Gf3gtsEKKoFBNTCoCAYVwaAiGNQGMUHMkjGbgjk2mIONuXo0nC8XnCf1JXgArVIZAQh5TKYAAAAASUVORK5CYII='); - *right: 0; -} - -.pika-prev.is-disabled, -.pika-next.is-disabled { - cursor: default; - opacity: .2; -} - -.pika-select { - display: inline-block; - *display: inline; -} - -.pika-table { - width: 100%; - border-collapse: collapse; - border-spacing: 0; - border: 0; -} - -.pika-table th, -.pika-table td { - width: 14.285714285714286%; - padding: 0; -} - -.pika-table th { - color: #999; - font-size: 12px; - line-height: 25px; - font-weight: bold; - text-align: center; -} - -.pika-button { - cursor: pointer; - display: block; - box-sizing: border-box; - -moz-box-sizing: border-box; - outline: none; - border: 0; - margin: 0; - width: 100%; - padding: 5px; - color: #666; - font-size: 12px; - line-height: 15px; - text-align: right; - background: #f5f5f5; -} - -.pika-week { - font-size: 11px; - color: #999; -} - -.is-today .pika-button { - color: #33aaff; - font-weight: bold; -} - -.is-selected .pika-button, -.has-event .pika-button { - color: #fff; - font-weight: bold; - background: #33aaff; - box-shadow: inset 0 1px 3px #178fe5; - border-radius: 3px; -} - -.has-event .pika-button { - background: #005da9; - box-shadow: inset 0 1px 3px #0076c9; -} - -.is-disabled .pika-button, -.is-inrange .pika-button { - background: #D5E9F7; -} - -.is-startrange .pika-button { - color: #fff; - background: #6CB31D; - box-shadow: none; - border-radius: 3px; -} - -.is-endrange .pika-button { - color: #fff; - background: #33aaff; - box-shadow: none; - border-radius: 3px; -} - -.is-disabled .pika-button { - pointer-events: none; - cursor: default; - color: #999; - opacity: .3; -} - -.is-outside-current-month .pika-button { - color: #999; - opacity: .3; -} - -.is-selection-disabled { - pointer-events: none; - cursor: default; -} - -.pika-button:hover, -.pika-row.pick-whole-week:hover .pika-button { - color: #fff; - background: #ff8000; - box-shadow: none; - border-radius: 3px; -} - -/* styling for abbr */ -.pika-table abbr { - border-bottom: none; - cursor: help; -} - - /*! X-editable - v1.5.1 * In-place editing with Twitter Bootstrap, jQuery UI or pure jQuery * http://github.com/vitalets/x-editable diff --git a/public/assets/admin/js/app.js b/public/assets/admin/js/app.js index 42bf609d..c6c8d461 100644 --- a/public/assets/admin/js/app.js +++ b/public/assets/admin/js/app.js @@ -366,7 +366,7 @@ eval("/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__base_map__ = __webpa /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; -eval("/* unused harmony export onFeaturePointClick */\n/* unused harmony export pointToLayer */\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__base_map__ = __webpack_require__(\"./resources/js/maps/base_map.js\");\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__helpers__ = __webpack_require__(\"./resources/js/maps/helpers.js\");\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__config__ = __webpack_require__(\"./resources/js/maps/config.js\");\n\nvar leaflet = __webpack_require__(\"./node_modules/leaflet/dist/leaflet-src.js\");\n\n\n\n\n\n\n/**\n * Show some popup text when a feature is clicked on\n * @param feature\n * @param layer\n */\nvar onFeaturePointClick = function onFeaturePointClick(feature, layer) {\n var popup_html = '';\n if (feature.properties && feature.properties.popup) {\n popup_html += feature.properties.popup;\n }\n\n layer.bindPopup(popup_html);\n};\n\n/**\n * Show each point as a marker\n * @param feature\n * @param latlng\n * @returns {*}\n */\nvar pointToLayer = function pointToLayer(feature, latlng) {\n return leaflet.circleMarker(latlng, {\n radius: 5,\n fillColor: __WEBPACK_IMPORTED_MODULE_2__config__[\"b\" /* CIRCLE_COLOR */],\n color: '#000',\n weight: 1,\n opacity: 1,\n fillOpacity: 0.8\n });\n};\n\n/**\n *\n * @param opts\n * @private\n */\n/* harmony default export */ __webpack_exports__[\"a\"] = (function (opts) {\n\n opts = Object.assign({\n route_points: null,\n planned_route_line: null,\n actual_route_points: null,\n actual_route_line: null,\n render_elem: 'map',\n metar_wms: {\n url: '',\n params: {}\n }\n }, opts);\n\n console.log(opts);\n\n var map = Object(__WEBPACK_IMPORTED_MODULE_0__base_map__[\"a\" /* default */])(opts);\n\n if (opts.metar_wms.url !== '') {\n Object(__WEBPACK_IMPORTED_MODULE_1__helpers__[\"a\" /* addWMSLayer */])(map, opts.metar_wms);\n }\n\n var geodesicLayer = leaflet.geodesic([], {\n weight: 4,\n opacity: 0.9,\n color: __WEBPACK_IMPORTED_MODULE_2__config__[\"c\" /* PLAN_ROUTE_COLOR */],\n steps: 50,\n wrap: false\n }).addTo(map);\n\n geodesicLayer.geoJson(opts.planned_route_line);\n\n try {\n map.fitBounds(geodesicLayer.getBounds());\n } catch (e) {\n console.log(e);\n }\n\n // Draw the route points after\n if (opts.route_points !== null) {\n var route_points = leaflet.geoJSON(opts.route_points, {\n onEachFeature: onFeaturePointClick,\n pointToLayer: pointToLayer,\n style: {\n 'color': __WEBPACK_IMPORTED_MODULE_2__config__[\"c\" /* PLAN_ROUTE_COLOR */],\n 'weight': 3,\n 'opacity': 0.65\n }\n });\n\n route_points.addTo(map);\n }\n\n /**\n * draw the actual route\n */\n\n if (opts.actual_route_line !== null && opts.actual_route_line.features.length > 0) {\n var _geodesicLayer = leaflet.geodesic([], {\n weight: 3,\n opacity: 0.9,\n color: __WEBPACK_IMPORTED_MODULE_2__config__[\"a\" /* ACTUAL_ROUTE_COLOR */],\n steps: 50,\n wrap: false\n }).addTo(map);\n\n _geodesicLayer.geoJson(opts.actual_route_line);\n\n try {\n map.fitBounds(_geodesicLayer.getBounds());\n } catch (e) {\n console.log(e);\n }\n }\n\n if (opts.actual_route_points !== null && opts.actual_route_points.features.length > 0) {\n var _route_points = leaflet.geoJSON(opts.actual_route_points, {\n onEachFeature: onFeaturePointClick,\n pointToLayer: pointToLayer,\n style: {\n 'color': __WEBPACK_IMPORTED_MODULE_2__config__[\"a\" /* ACTUAL_ROUTE_COLOR */],\n 'weight': 3,\n 'opacity': 0.65\n }\n });\n\n _route_points.addTo(map);\n }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./resources/js/maps/route_map.js?a745"],"names":["leaflet","require","onFeaturePointClick","feature","layer","popup_html","properties","popup","bindPopup","pointToLayer","latlng","circleMarker","radius","fillColor","color","weight","opacity","fillOpacity","opts","Object","assign","route_points","planned_route_line","actual_route_points","actual_route_line","render_elem","metar_wms","url","params","console","log","map","draw_base_map","addWMSLayer","geodesicLayer","geodesic","steps","wrap","addTo","geoJson","fitBounds","getBounds","e","geoJSON","onEachFeature","style","features","length"],"mappings":"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","file":"./resources/js/maps/route_map.js.js","sourcesContent":["\nconst leaflet = require('leaflet');\n\nimport draw_base_map from './base_map'\nimport { addWMSLayer } from './helpers';\n\nimport {\n  ACTUAL_ROUTE_COLOR,\n  PLAN_ROUTE_COLOR,\n  CIRCLE_COLOR\n} from './config'\n\n/**\n * Show some popup text when a feature is clicked on\n * @param feature\n * @param layer\n */\nexport const onFeaturePointClick = (feature, layer) => {\n  let popup_html = '';\n  if (feature.properties && feature.properties.popup) {\n    popup_html += feature.properties.popup\n  }\n\n  layer.bindPopup(popup_html)\n};\n\n/**\n * Show each point as a marker\n * @param feature\n * @param latlng\n * @returns {*}\n */\nexport const pointToLayer = (feature, latlng) => {\n  return leaflet.circleMarker(latlng, {\n    radius: 5,\n    fillColor: CIRCLE_COLOR,\n    color: '#000',\n    weight: 1,\n    opacity: 1,\n    fillOpacity: 0.8\n  })\n}\n\n/**\n *\n * @param opts\n * @private\n */\nexport default (opts) => {\n\n  opts = Object.assign({\n    route_points: null,\n    planned_route_line: null,\n    actual_route_points: null,\n    actual_route_line: null,\n    render_elem: 'map',\n    metar_wms: {\n        url: '',\n        params: {}\n    },\n  }, opts);\n\n  console.log(opts);\n\n  let map = draw_base_map(opts);\n\n  if (opts.metar_wms.url !== '') {\n      addWMSLayer(map, opts.metar_wms);\n  }\n\n  let geodesicLayer = leaflet.geodesic([], {\n    weight: 4,\n    opacity: 0.9,\n    color: PLAN_ROUTE_COLOR,\n    steps: 50,\n    wrap: false,\n  }).addTo(map);\n\n  geodesicLayer.geoJson(opts.planned_route_line);\n\n  try {\n    map.fitBounds(geodesicLayer.getBounds())\n  } catch (e) {\n    console.log(e)\n  }\n\n  // Draw the route points after\n  if (opts.route_points !== null) {\n    let route_points = leaflet.geoJSON(opts.route_points, {\n      onEachFeature: onFeaturePointClick,\n      pointToLayer: pointToLayer,\n      style: {\n        'color': PLAN_ROUTE_COLOR,\n        'weight': 3,\n        'opacity': 0.65,\n      },\n    });\n\n    route_points.addTo(map);\n  }\n\n  /**\n   * draw the actual route\n   */\n\n  if (opts.actual_route_line !== null && opts.actual_route_line.features.length > 0) {\n    let geodesicLayer = leaflet.geodesic([], {\n      weight: 3,\n      opacity: 0.9,\n      color: ACTUAL_ROUTE_COLOR,\n      steps: 50,\n      wrap: false,\n    }).addTo(map);\n\n    geodesicLayer.geoJson(opts.actual_route_line);\n\n    try {\n      map.fitBounds(geodesicLayer.getBounds())\n    } catch (e) {\n      console.log(e)\n    }\n  }\n\n  if (opts.actual_route_points !== null && opts.actual_route_points.features.length > 0) {\n    let route_points = leaflet.geoJSON(opts.actual_route_points, {\n      onEachFeature: onFeaturePointClick,\n      pointToLayer: pointToLayer,\n      style: {\n        'color': ACTUAL_ROUTE_COLOR,\n        'weight': 3,\n        'opacity': 0.65,\n      },\n    });\n\n    route_points.addTo(map)\n  }\n};\n\n\n\n// WEBPACK FOOTER //\n// ./resources/js/maps/route_map.js"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./resources/js/maps/route_map.js\n"); +eval("/* unused harmony export onFeaturePointClick */\n/* unused harmony export pointToLayer */\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__base_map__ = __webpack_require__(\"./resources/js/maps/base_map.js\");\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__helpers__ = __webpack_require__(\"./resources/js/maps/helpers.js\");\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__config__ = __webpack_require__(\"./resources/js/maps/config.js\");\nvar leaflet = __webpack_require__(\"./node_modules/leaflet/dist/leaflet-src.js\");\n\n\n\n\n\n\n/**\n * Show some popup text when a feature is clicked on\n * @param feature\n * @param layer\n */\nvar onFeaturePointClick = function onFeaturePointClick(feature, layer) {\n var popup_html = '';\n if (feature.properties && feature.properties.popup) {\n popup_html += feature.properties.popup;\n }\n\n layer.bindPopup(popup_html);\n};\n\n/**\n * Show each point as a marker\n * @param feature\n * @param latlng\n * @returns {*}\n */\nvar pointToLayer = function pointToLayer(feature, latlng) {\n return leaflet.circleMarker(latlng, {\n radius: 5,\n fillColor: __WEBPACK_IMPORTED_MODULE_2__config__[\"b\" /* CIRCLE_COLOR */],\n color: '#000',\n weight: 1,\n opacity: 1,\n fillOpacity: 0.8\n });\n};\n\n/**\n *\n * @param opts\n * @private\n */\n/* harmony default export */ __webpack_exports__[\"a\"] = (function (opts) {\n\n opts = Object.assign({\n\n route_points: null,\n planned_route_line: null,\n actual_route_points: null,\n actual_route_line: null,\n render_elem: 'map',\n live_map: false,\n aircraft_icon: '/assets/img/acars/aircraft.png',\n metar_wms: {\n url: '',\n params: {}\n }\n }, opts);\n\n var aircraftIcon = leaflet.icon({\n iconUrl: opts.aircraft_icon,\n iconSize: [42, 42],\n iconAnchor: [21, 21]\n });\n\n var map = Object(__WEBPACK_IMPORTED_MODULE_0__base_map__[\"a\" /* default */])(opts);\n var layerLiveFlight = void 0;\n\n if (opts.metar_wms.url !== '') {\n Object(__WEBPACK_IMPORTED_MODULE_1__helpers__[\"a\" /* addWMSLayer */])(map, opts.metar_wms);\n }\n\n var geodesicLayer = leaflet.geodesic([], {\n weight: 4,\n opacity: 0.9,\n color: __WEBPACK_IMPORTED_MODULE_2__config__[\"c\" /* PLAN_ROUTE_COLOR */],\n steps: 50,\n wrap: false\n }).addTo(map);\n\n geodesicLayer.geoJson(opts.planned_route_line);\n\n try {\n map.fitBounds(geodesicLayer.getBounds());\n } catch (e) {\n console.log(e);\n }\n\n // Draw the route points after\n if (opts.route_points !== null) {\n var route_points = leaflet.geoJSON(opts.route_points, {\n onEachFeature: onFeaturePointClick,\n pointToLayer: pointToLayer,\n style: {\n 'color': __WEBPACK_IMPORTED_MODULE_2__config__[\"c\" /* PLAN_ROUTE_COLOR */],\n 'weight': 3,\n 'opacity': 0.65\n }\n });\n\n route_points.addTo(map);\n }\n\n /**\n * draw the actual route\n */\n\n if (opts.actual_route_line !== null && opts.actual_route_line.features.length > 0) {\n var _geodesicLayer = leaflet.geodesic([], {\n weight: 3,\n opacity: 0.9,\n color: __WEBPACK_IMPORTED_MODULE_2__config__[\"a\" /* ACTUAL_ROUTE_COLOR */],\n steps: 50,\n wrap: false\n }).addTo(map);\n\n _geodesicLayer.geoJson(opts.actual_route_line);\n\n try {\n map.fitBounds(_geodesicLayer.getBounds());\n } catch (e) {\n console.log(e);\n }\n }\n\n if (opts.actual_route_points !== null && opts.actual_route_points.features.length > 0) {\n var _route_points = leaflet.geoJSON(opts.actual_route_points, {\n onEachFeature: onFeaturePointClick,\n pointToLayer: pointToLayer,\n style: {\n 'color': __WEBPACK_IMPORTED_MODULE_2__config__[\"a\" /* ACTUAL_ROUTE_COLOR */],\n 'weight': 3,\n 'opacity': 0.65\n }\n });\n\n _route_points.addTo(map);\n }\n\n /**\n *\n */\n var liveFlight = function liveFlight() {\n var uri = opts.pirep_uri;\n var live_route = $.ajax({\n url: uri,\n dataType: 'json',\n error: console.log\n });\n\n $.when(live_route).done(function (routeJson) {\n layerLiveFlight = leaflet.geoJSON(routeJson, {\n pointToLayer: function pointToLayer(feature, latlon) {\n return leaflet.marker(latlon, {\n icon: aircraftIcon,\n rotationAngle: feature.properties.heading\n });\n }\n });\n\n layerLiveFlight.addTo(map);\n });\n };\n\n setInterval(liveFlight, 10000);\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./resources/js/maps/route_map.js?a745"],"names":["leaflet","require","onFeaturePointClick","feature","layer","popup_html","properties","popup","bindPopup","pointToLayer","latlng","circleMarker","radius","fillColor","color","weight","opacity","fillOpacity","opts","Object","assign","route_points","planned_route_line","actual_route_points","actual_route_line","render_elem","live_map","aircraft_icon","metar_wms","url","params","aircraftIcon","icon","iconUrl","iconSize","iconAnchor","map","draw_base_map","layerLiveFlight","addWMSLayer","geodesicLayer","geodesic","steps","wrap","addTo","geoJson","fitBounds","getBounds","e","console","log","geoJSON","onEachFeature","style","features","length","liveFlight","uri","pirep_uri","live_route","$","ajax","dataType","error","when","done","routeJson","latlon","marker","rotationAngle","heading","setInterval"],"mappings":"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","file":"./resources/js/maps/route_map.js.js","sourcesContent":["const leaflet = require('leaflet');\n\nimport draw_base_map from './base_map'\nimport {addWMSLayer} from './helpers';\n\nimport {ACTUAL_ROUTE_COLOR, CIRCLE_COLOR, PLAN_ROUTE_COLOR} from './config'\n\n/**\n * Show some popup text when a feature is clicked on\n * @param feature\n * @param layer\n */\nexport const onFeaturePointClick = (feature, layer) => {\n    let popup_html = '';\n    if (feature.properties && feature.properties.popup) {\n        popup_html += feature.properties.popup\n    }\n\n    layer.bindPopup(popup_html)\n};\n\n/**\n * Show each point as a marker\n * @param feature\n * @param latlng\n * @returns {*}\n */\nexport const pointToLayer = (feature, latlng) => {\n    return leaflet.circleMarker(latlng, {\n        radius: 5,\n        fillColor: CIRCLE_COLOR,\n        color: '#000',\n        weight: 1,\n        opacity: 1,\n        fillOpacity: 0.8\n    })\n}\n\n/**\n *\n * @param opts\n * @private\n */\nexport default (opts) => {\n\n    opts = Object.assign({\n\n        route_points: null,\n        planned_route_line: null,\n        actual_route_points: null,\n        actual_route_line: null,\n        render_elem: 'map',\n        live_map: false,\n        aircraft_icon: '/assets/img/acars/aircraft.png',\n        metar_wms: {\n            url: '',\n            params: {}\n        },\n    }, opts);\n\n    const aircraftIcon = leaflet.icon({\n        iconUrl: opts.aircraft_icon,\n        iconSize: [42, 42],\n        iconAnchor: [21, 21],\n    });\n\n    let map = draw_base_map(opts);\n    let layerLiveFlight;\n\n    if (opts.metar_wms.url !== '') {\n        addWMSLayer(map, opts.metar_wms);\n    }\n\n    let geodesicLayer = leaflet.geodesic([], {\n        weight: 4,\n        opacity: 0.9,\n        color: PLAN_ROUTE_COLOR,\n        steps: 50,\n        wrap: false,\n    }).addTo(map);\n\n    geodesicLayer.geoJson(opts.planned_route_line);\n\n    try {\n        map.fitBounds(geodesicLayer.getBounds())\n    } catch (e) {\n        console.log(e)\n    }\n\n    // Draw the route points after\n    if (opts.route_points !== null) {\n        let route_points = leaflet.geoJSON(opts.route_points, {\n            onEachFeature: onFeaturePointClick,\n            pointToLayer: pointToLayer,\n            style: {\n                'color': PLAN_ROUTE_COLOR,\n                'weight': 3,\n                'opacity': 0.65,\n            },\n        });\n\n        route_points.addTo(map);\n    }\n\n    /**\n     * draw the actual route\n     */\n\n    if (opts.actual_route_line !== null && opts.actual_route_line.features.length > 0) {\n        let geodesicLayer = leaflet.geodesic([], {\n            weight: 3,\n            opacity: 0.9,\n            color: ACTUAL_ROUTE_COLOR,\n            steps: 50,\n            wrap: false,\n        }).addTo(map);\n\n        geodesicLayer.geoJson(opts.actual_route_line);\n\n        try {\n            map.fitBounds(geodesicLayer.getBounds())\n        } catch (e) {\n            console.log(e)\n        }\n    }\n\n    if (opts.actual_route_points !== null && opts.actual_route_points.features.length > 0) {\n        let route_points = leaflet.geoJSON(opts.actual_route_points, {\n            onEachFeature: onFeaturePointClick,\n            pointToLayer: pointToLayer,\n            style: {\n                'color': ACTUAL_ROUTE_COLOR,\n                'weight': 3,\n                'opacity': 0.65,\n            },\n        });\n\n        route_points.addTo(map)\n    }\n\n    /**\n     *\n     */\n    const liveFlight = () => {\n        const uri = opts.pirep_uri;\n        const live_route = $.ajax({\n            url: uri,\n            dataType: 'json',\n            error: console.log\n        });\n\n        $.when(live_route).done((routeJson) => {\n            layerLiveFlight = leaflet.geoJSON(routeJson, {\n                pointToLayer: function (feature, latlon) {\n                    return leaflet.marker(latlon, {\n                        icon: aircraftIcon,\n                        rotationAngle: feature.properties.heading\n                    })\n                }\n            })\n\n            layerLiveFlight.addTo(map)\n        });\n    };\n\n    setInterval(liveFlight, 10000);\n};\n\n\n\n// WEBPACK FOOTER //\n// ./resources/js/maps/route_map.js"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./resources/js/maps/route_map.js\n"); /***/ }), diff --git a/public/assets/admin/js/vendor.js b/public/assets/admin/js/vendor.js index 1ee244d1..c42f0e17 100644 --- a/public/assets/admin/js/vendor.js +++ b/public/assets/admin/js/vendor.js @@ -44514,1252 +44514,6 @@ S2.define('jquery.select2',[ } })(window.jQuery || window.Zepto); -/*! - * Pikaday - * - * Copyright © 2014 David Bushell | BSD & MIT license | https://github.com/dbushell/Pikaday - */ - -(function (root, factory) -{ - 'use strict'; - - var moment; - if (typeof exports === 'object') { - // CommonJS module - // Load moment.js as an optional dependency - try { moment = require('moment'); } catch (e) {} - module.exports = factory(moment); - } else if (typeof define === 'function' && define.amd) { - // AMD. Register as an anonymous module. - define(function (req) - { - // Load moment.js as an optional dependency - var id = 'moment'; - try { moment = req(id); } catch (e) {} - return factory(moment); - }); - } else { - root.Pikaday = factory(root.moment); - } -}(this, function (moment) -{ - 'use strict'; - - /** - * feature detection and helper functions - */ - var hasMoment = typeof moment === 'function', - - hasEventListeners = !!window.addEventListener, - - document = window.document, - - sto = window.setTimeout, - - addEvent = function(el, e, callback, capture) - { - if (hasEventListeners) { - el.addEventListener(e, callback, !!capture); - } else { - el.attachEvent('on' + e, callback); - } - }, - - removeEvent = function(el, e, callback, capture) - { - if (hasEventListeners) { - el.removeEventListener(e, callback, !!capture); - } else { - el.detachEvent('on' + e, callback); - } - }, - - trim = function(str) - { - return str.trim ? str.trim() : str.replace(/^\s+|\s+$/g,''); - }, - - hasClass = function(el, cn) - { - return (' ' + el.className + ' ').indexOf(' ' + cn + ' ') !== -1; - }, - - addClass = function(el, cn) - { - if (!hasClass(el, cn)) { - el.className = (el.className === '') ? cn : el.className + ' ' + cn; - } - }, - - removeClass = function(el, cn) - { - el.className = trim((' ' + el.className + ' ').replace(' ' + cn + ' ', ' ')); - }, - - isArray = function(obj) - { - return (/Array/).test(Object.prototype.toString.call(obj)); - }, - - isDate = function(obj) - { - return (/Date/).test(Object.prototype.toString.call(obj)) && !isNaN(obj.getTime()); - }, - - isWeekend = function(date) - { - var day = date.getDay(); - return day === 0 || day === 6; - }, - - isLeapYear = function(year) - { - // solution by Matti Virkkunen: http://stackoverflow.com/a/4881951 - return year % 4 === 0 && year % 100 !== 0 || year % 400 === 0; - }, - - getDaysInMonth = function(year, month) - { - return [31, isLeapYear(year) ? 29 : 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31][month]; - }, - - setToStartOfDay = function(date) - { - if (isDate(date)) date.setHours(0,0,0,0); - }, - - compareDates = function(a,b) - { - // weak date comparison (use setToStartOfDay(date) to ensure correct result) - return a.getTime() === b.getTime(); - }, - - extend = function(to, from, overwrite) - { - var prop, hasProp; - for (prop in from) { - hasProp = to[prop] !== undefined; - if (hasProp && typeof from[prop] === 'object' && from[prop] !== null && from[prop].nodeName === undefined) { - if (isDate(from[prop])) { - if (overwrite) { - to[prop] = new Date(from[prop].getTime()); - } - } - else if (isArray(from[prop])) { - if (overwrite) { - to[prop] = from[prop].slice(0); - } - } else { - to[prop] = extend({}, from[prop], overwrite); - } - } else if (overwrite || !hasProp) { - to[prop] = from[prop]; - } - } - return to; - }, - - fireEvent = function(el, eventName, data) - { - var ev; - - if (document.createEvent) { - ev = document.createEvent('HTMLEvents'); - ev.initEvent(eventName, true, false); - ev = extend(ev, data); - el.dispatchEvent(ev); - } else if (document.createEventObject) { - ev = document.createEventObject(); - ev = extend(ev, data); - el.fireEvent('on' + eventName, ev); - } - }, - - adjustCalendar = function(calendar) { - if (calendar.month < 0) { - calendar.year -= Math.ceil(Math.abs(calendar.month)/12); - calendar.month += 12; - } - if (calendar.month > 11) { - calendar.year += Math.floor(Math.abs(calendar.month)/12); - calendar.month -= 12; - } - return calendar; - }, - - /** - * defaults and localisation - */ - defaults = { - - // bind the picker to a form field - field: null, - - // automatically show/hide the picker on `field` focus (default `true` if `field` is set) - bound: undefined, - - // position of the datepicker, relative to the field (default to bottom & left) - // ('bottom' & 'left' keywords are not used, 'top' & 'right' are modifier on the bottom/left position) - position: 'bottom left', - - // automatically fit in the viewport even if it means repositioning from the position option - reposition: true, - - // the default output format for `.toString()` and `field` value - format: 'YYYY-MM-DD', - - // the toString function which gets passed a current date object and format - // and returns a string - toString: null, - - // used to create date object from current input string - parse: null, - - // the initial date to view when first opened - defaultDate: null, - - // make the `defaultDate` the initial selected value - setDefaultDate: false, - - // first day of week (0: Sunday, 1: Monday etc) - firstDay: 0, - - // the default flag for moment's strict date parsing - formatStrict: false, - - // the minimum/earliest date that can be selected - minDate: null, - // the maximum/latest date that can be selected - maxDate: null, - - // number of years either side, or array of upper/lower range - yearRange: 10, - - // show week numbers at head of row - showWeekNumber: false, - - // Week picker mode - pickWholeWeek: false, - - // used internally (don't config outside) - minYear: 0, - maxYear: 9999, - minMonth: undefined, - maxMonth: undefined, - - startRange: null, - endRange: null, - - isRTL: false, - - // Additional text to append to the year in the calendar title - yearSuffix: '', - - // Render the month after year in the calendar title - showMonthAfterYear: false, - - // Render days of the calendar grid that fall in the next or previous month - showDaysInNextAndPreviousMonths: false, - - // Allows user to select days that fall in the next or previous month - enableSelectionDaysInNextAndPreviousMonths: false, - - // how many months are visible - numberOfMonths: 1, - - // when numberOfMonths is used, this will help you to choose where the main calendar will be (default `left`, can be set to `right`) - // only used for the first display or when a selected date is not visible - mainCalendar: 'left', - - // Specify a DOM element to render the calendar in - container: undefined, - - // Blur field when date is selected - blurFieldOnSelect : true, - - // internationalization - i18n: { - previousMonth : 'Previous Month', - nextMonth : 'Next Month', - months : ['January','February','March','April','May','June','July','August','September','October','November','December'], - weekdays : ['Sunday','Monday','Tuesday','Wednesday','Thursday','Friday','Saturday'], - weekdaysShort : ['Sun','Mon','Tue','Wed','Thu','Fri','Sat'] - }, - - // Theme Classname - theme: null, - - // events array - events: [], - - // callback function - onSelect: null, - onOpen: null, - onClose: null, - onDraw: null, - - // Enable keyboard input - keyboardInput: true - }, - - - /** - * templating functions to abstract HTML rendering - */ - renderDayName = function(opts, day, abbr) - { - day += opts.firstDay; - while (day >= 7) { - day -= 7; - } - return abbr ? opts.i18n.weekdaysShort[day] : opts.i18n.weekdays[day]; - }, - - renderDay = function(opts) - { - var arr = []; - var ariaSelected = 'false'; - if (opts.isEmpty) { - if (opts.showDaysInNextAndPreviousMonths) { - arr.push('is-outside-current-month'); - - if(!opts.enableSelectionDaysInNextAndPreviousMonths) { - arr.push('is-selection-disabled'); - } - - } else { - return '
Arrived {{$pirep->created_at->diffForHumans()}}
++ @if($pirep->state === PirepState::IN_PROGRESS) + + @else + Arrived {{$pirep->created_at->diffForHumans()}} + @endif +
Status | @php @@ -96,6 +104,15 @@ {{ PirepState::label($pirep->state) }} | +||||
State | +
+
+ {{ PirepStatus::label($pirep->status) }}
+
+ |
||||
{{ $pirep->ident }} | +{{ $pirep->airline->code }}{{ $pirep->ident }} | {{ $pirep->dpt_airport_id }} | {{ $pirep->arr_airport_id }} | +{{ $pirep->aircraft->name }} | {{ PirepStatus::label($pirep->status) }} | diff --git a/tests/UtilsTest.php b/tests/UtilsTest.php index f90931bb..350ac300 100644 --- a/tests/UtilsTest.php +++ b/tests/UtilsTest.php @@ -9,8 +9,8 @@ class UtilsTest extends TestCase public function testDates() { - $carbon = new \Carbon\Carbon('2018-03-18 00:20:43'); - //echo $carbon; + $carbon = new \Carbon\Carbon('2018-04-28T12:55:40Z'); + $this->assertNotNull($carbon); } public function testSecondsToTimeParts()