| 
									
										
										
										
											2015-02-27 16:48:33 +01:00
										 |  |  | <?php namespace FireflyIII\Models; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-02 20:05:28 +01:00
										 |  |  | use Carbon\Carbon; | 
					
						
							| 
									
										
										
										
											2015-03-29 08:18:15 +02:00
										 |  |  | use Illuminate\Database\Eloquent\Builder as EloquentBuilder; | 
					
						
							|  |  |  | use Illuminate\Database\Eloquent\Model; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-27 16:48:33 +01:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Class PiggyBankRepetition | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @package FireflyIII\Models | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class PiggyBankRepetition extends Model | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getDates() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return ['created_at', 'updated_at', 'startdate', 'targetdate']; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @return \Illuminate\Database\Eloquent\Relations\BelongsTo | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function piggyBank() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->belongsTo('FireflyIII\Models\PiggyBank'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-02 20:05:28 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param EloquentBuilder $query | 
					
						
							| 
									
										
										
										
											2015-03-29 08:18:15 +02:00
										 |  |  |      * @param Carbon          $start | 
					
						
							|  |  |  |      * @param Carbon          $target | 
					
						
							| 
									
										
										
										
											2015-03-02 20:05:28 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-03-29 08:18:15 +02:00
										 |  |  |      * @return $this | 
					
						
							| 
									
										
										
										
											2015-03-02 20:05:28 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-03-29 08:18:15 +02:00
										 |  |  |     public function scopeOnDates(EloquentBuilder $query, Carbon $start, Carbon $target) | 
					
						
							| 
									
										
										
										
											2015-03-02 20:05:28 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-03-29 08:18:15 +02:00
										 |  |  |         return $query->where('startdate', $start->format('Y-m-d'))->where('targetdate', $target->format('Y-m-d')); | 
					
						
							| 
									
										
										
										
											2015-03-02 20:05:28 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-21 21:33:52 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param EloquentBuilder $query | 
					
						
							| 
									
										
										
										
											2015-03-29 08:18:15 +02:00
										 |  |  |      * @param Carbon          $date | 
					
						
							| 
									
										
										
										
											2015-03-21 21:33:52 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-03-29 08:18:15 +02:00
										 |  |  |      * @return mixed | 
					
						
							| 
									
										
										
										
											2015-03-21 21:33:52 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-03-29 08:18:15 +02:00
										 |  |  |     public function scopeRelevantOnDate(EloquentBuilder $query, Carbon $date) | 
					
						
							| 
									
										
										
										
											2015-03-21 21:33:52 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-03-29 08:18:15 +02:00
										 |  |  |         return $query->where( | 
					
						
							|  |  |  |             function (EloquentBuilder $q) use ($date) { | 
					
						
							|  |  |  |                 $q->where('startdate', '<=', $date->format('Y-m-d 00:00:00')); | 
					
						
							|  |  |  |                 $q->orWhereNull('startdate'); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |                      ->where( | 
					
						
							|  |  |  |                          function (EloquentBuilder $q) use ($date) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                              $q->where('targetdate', '>=', $date->format('Y-m-d 00:00:00')); | 
					
						
							|  |  |  |                              $q->orWhereNull('targetdate'); | 
					
						
							|  |  |  |                          } | 
					
						
							|  |  |  |                      ); | 
					
						
							| 
									
										
										
										
											2015-03-21 21:33:52 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-27 16:48:33 +01:00
										 |  |  | } |