| 
									
										
										
										
											2019-12-28 19:27:50 +01:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2020-06-30 19:05:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-28 19:27:50 +01:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Location.php | 
					
						
							| 
									
										
										
										
											2020-06-30 19:05:35 +02:00
										 |  |  |  * Copyright (c) 2020 james@firefly-iii.org | 
					
						
							| 
									
										
										
										
											2019-12-28 19:27:50 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  * This file is part of Firefly III (https://github.com/firefly-iii). | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU Affero General Public License as | 
					
						
							|  |  |  |  * published by the Free Software Foundation, either version 3 of the | 
					
						
							|  |  |  |  * License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU Affero General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  |  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-30 19:05:35 +02:00
										 |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-28 19:27:50 +01:00
										 |  |  | namespace FireflyIII\Models; | 
					
						
							| 
									
										
										
										
											2021-08-28 15:47:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-25 06:58:29 +01:00
										 |  |  | use Eloquent; | 
					
						
							|  |  |  | use Illuminate\Database\Eloquent\Builder; | 
					
						
							|  |  |  | use Illuminate\Database\Eloquent\Collection; | 
					
						
							| 
									
										
										
										
											2019-12-28 19:27:50 +01:00
										 |  |  | use Illuminate\Database\Eloquent\Model; | 
					
						
							|  |  |  | use Illuminate\Database\Eloquent\Relations\MorphMany; | 
					
						
							|  |  |  | use Illuminate\Database\Eloquent\Relations\MorphTo; | 
					
						
							| 
									
										
										
										
											2020-03-25 06:58:29 +01:00
										 |  |  | use Illuminate\Support\Carbon; | 
					
						
							| 
									
										
										
										
											2021-08-28 15:47:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-28 19:27:50 +01:00
										 |  |  | /** | 
					
						
							| 
									
										
										
										
											2020-12-04 06:20:44 +01:00
										 |  |  |  * FireflyIII\Models\Location | 
					
						
							| 
									
										
										
										
											2020-03-25 06:58:29 +01:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |  * @property int                       $id | 
					
						
							|  |  |  |  * @property Carbon|null               $created_at | 
					
						
							|  |  |  |  * @property Carbon|null               $updated_at | 
					
						
							|  |  |  |  * @property Carbon|null               $deleted_at | 
					
						
							|  |  |  |  * @property int                       $locatable_id | 
					
						
							|  |  |  |  * @property string                    $locatable_type | 
					
						
							|  |  |  |  * @property float|null                $latitude | 
					
						
							|  |  |  |  * @property float|null                $longitude | 
					
						
							|  |  |  |  * @property int|null                  $zoom_level | 
					
						
							| 
									
										
										
										
											2021-05-24 08:50:17 +02:00
										 |  |  |  * @property-read Collection|Account[] $accounts | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |  * @property-read int|null             $accounts_count | 
					
						
							|  |  |  |  * @property-read Model|Eloquent       $locatable | 
					
						
							| 
									
										
										
										
											2020-03-25 06:58:29 +01:00
										 |  |  |  * @method static Builder|Location newModelQuery() | 
					
						
							|  |  |  |  * @method static Builder|Location newQuery() | 
					
						
							|  |  |  |  * @method static Builder|Location query() | 
					
						
							|  |  |  |  * @method static Builder|Location whereCreatedAt($value) | 
					
						
							|  |  |  |  * @method static Builder|Location whereDeletedAt($value) | 
					
						
							|  |  |  |  * @method static Builder|Location whereId($value) | 
					
						
							|  |  |  |  * @method static Builder|Location whereLatitude($value) | 
					
						
							|  |  |  |  * @method static Builder|Location whereLocatableId($value) | 
					
						
							|  |  |  |  * @method static Builder|Location whereLocatableType($value) | 
					
						
							|  |  |  |  * @method static Builder|Location whereLongitude($value) | 
					
						
							|  |  |  |  * @method static Builder|Location whereUpdatedAt($value) | 
					
						
							|  |  |  |  * @method static Builder|Location whereZoomLevel($value) | 
					
						
							|  |  |  |  * @mixin Eloquent | 
					
						
							| 
									
										
										
										
											2019-12-28 19:27:50 +01:00
										 |  |  |  */ | 
					
						
							|  |  |  | class Location extends Model | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * The attributes that should be casted to native types. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @var array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected $casts | 
					
						
							|  |  |  |         = [ | 
					
						
							|  |  |  |             'created_at' => 'datetime', | 
					
						
							|  |  |  |             'updated_at' => 'datetime', | 
					
						
							|  |  |  |             'deleted_at' => 'datetime', | 
					
						
							|  |  |  |             'zoomLevel'  => 'int', | 
					
						
							|  |  |  |             'latitude'   => 'float', | 
					
						
							|  |  |  |             'longitude'  => 'float', | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |     /** @var array Fields that can be filled */ | 
					
						
							|  |  |  |     protected $fillable = ['locatable_id', 'locatable_type', 'latitude', 'longitude', 'zoom_level']; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-17 16:46:00 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Add rules for locations. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |      * @param array $rules | 
					
						
							| 
									
										
										
										
											2020-03-17 16:46:00 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public static function requestRules(array $rules): array | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $rules['latitude']   = 'numeric|min:-90|max:90|nullable|required_with:longitude'; | 
					
						
							|  |  |  |         $rules['longitude']  = 'numeric|min:-180|max:180|nullable|required_with:latitude'; | 
					
						
							|  |  |  |         $rules['zoom_level'] = 'numeric|min:0|max:80|nullable|required_with:latitude'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $rules; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-28 19:27:50 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Get all of the accounts. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function accounts(): MorphMany | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->morphMany(Account::class, 'noteable'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Get all of the owning attachable models. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return MorphTo | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function locatable(): MorphTo | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->morphTo(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |