mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-26 13:36:15 +00:00 
			
		
		
		
	Lots of new stuff.
This commit is contained in:
		| @@ -1,5 +1,6 @@ | |||||||
| <?php | <?php | ||||||
|  |  | ||||||
|  | use Carbon\Carbon; | ||||||
| use FireflyIII\Exception\FireflyException; | use FireflyIII\Exception\FireflyException; | ||||||
| use Illuminate\Support\MessageBag; | use Illuminate\Support\MessageBag; | ||||||
|  |  | ||||||
| @@ -35,58 +36,24 @@ class RepeatedExpenseController extends BaseController | |||||||
|         $repository = App::make('FireflyIII\Database\RepeatedExpense'); |         $repository = App::make('FireflyIII\Database\RepeatedExpense'); | ||||||
|  |  | ||||||
|         $expenses = $repository->get(); |         $expenses = $repository->get(); | ||||||
|  |  | ||||||
|         $expenses->each( |         $expenses->each( | ||||||
|             function (\Piggybank $piggyBank) { |             function (Piggybank $piggyBank) use ($repository) { | ||||||
|                 // do something with "parts". |                 $piggyBank->currentRelevantRep(); | ||||||
|                 $piggyBank->currentRep = $piggyBank->currentRelevantRep(); |                 $piggyBank->currentRep = $repository->calculateParts($piggyBank->currentRep); | ||||||
|                 if (!is_null($piggyBank->reminder)) { |  | ||||||
|                     switch ($piggyBank->reminder) { |  | ||||||
|                         default: |  | ||||||
|                             throw new FireflyException('Cannot handle "' . $piggyBank->reminder . '" reminders for repeated expenses'); |  | ||||||
|                             break; |  | ||||||
|                         case 'month': |  | ||||||
|                             $start = clone $piggyBank->currentRep->startdate; |  | ||||||
|                             $start->startOfMonth(); |  | ||||||
|                             $end = clone $piggyBank->currentRep->targetdate; |  | ||||||
|                             $end->endOfMonth(); |  | ||||||
|                             $piggyBank->parts = $start->diffInMonths($end); |  | ||||||
|                             unset($start, $end); |  | ||||||
|                             break; |  | ||||||
|             } |             } | ||||||
|  |  | ||||||
|                 } else { |  | ||||||
|                     $piggyBank->parts = 1; |  | ||||||
|                 } |  | ||||||
|  |  | ||||||
|                 // number of bars: |  | ||||||
|                 $piggyBank->barCount = floor(12 / $piggyBank->parts) == 0 ? 1 : floor(12 / $piggyBank->parts); |  | ||||||
|                 $amountPerBar        = floatval($piggyBank->targetamount) / $piggyBank->parts; |  | ||||||
|                 $currentAmount       = floatval($amountPerBar); |  | ||||||
|                 $bars                = []; |  | ||||||
|                 $currentDate         = clone $piggyBank->currentRep->startdate; |  | ||||||
|                 for ($i = 0; $i < $piggyBank->parts; $i++) { |  | ||||||
|                     // niet elke keer een andere dinges pakken? om target te redden? |  | ||||||
|                     if (!is_null($piggyBank->reminder)) { |  | ||||||
|                         $currentDate = \DateKit::addPeriod($currentDate, $piggyBank->reminder, 0); |  | ||||||
|                     } |  | ||||||
|                     $bars[] = [ |  | ||||||
|                         'amount' => $currentAmount, |  | ||||||
|                         'date'   => $currentDate |  | ||||||
|                     ]; |  | ||||||
|  |  | ||||||
|  |  | ||||||
|                     $currentAmount += $amountPerBar; |  | ||||||
|                 } |  | ||||||
|                 $piggyBank->bars = $bars; |  | ||||||
|  |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|         ); |         ); | ||||||
|  |  | ||||||
|         return View::make('repeatedexpense.index', compact('expenses', 'subTitle')); |         return View::make('repeatedexpense.index', compact('expenses', 'subTitle')); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public function show(Piggybank $piggyBank) | ||||||
|  |     { | ||||||
|  |         $subTitle = $piggyBank->name; | ||||||
|  |         $today    = Carbon::now(); | ||||||
|  |  | ||||||
|  |         return View::make('repeatedexpense.show', compact('piggyBank', 'today', 'subTitle')); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * |      * | ||||||
|      */ |      */ | ||||||
|   | |||||||
							
								
								
									
										135
									
								
								app/lib/FireflyIII/Collection/PiggybankPart.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										135
									
								
								app/lib/FireflyIII/Collection/PiggybankPart.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,135 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | namespace FireflyIII\Collection; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | use Carbon\Carbon; | ||||||
|  |  | ||||||
|  | class PiggybankPart | ||||||
|  | { | ||||||
|  |     /** @var  int */ | ||||||
|  |     public $amount; | ||||||
|  |     public $amountPerBar; | ||||||
|  |     /** @var  int */ | ||||||
|  |     public $currentamount; | ||||||
|  |     /** @var  \PiggybankRepetition */ | ||||||
|  |     public $repetition; | ||||||
|  |     /** @var  Carbon */ | ||||||
|  |     public $startdate; | ||||||
|  |     /** @var  Carbon */ | ||||||
|  |     public $targetdate; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @return \PiggybankRepetition | ||||||
|  |      */ | ||||||
|  |     public function getRepetition() | ||||||
|  |     { | ||||||
|  |         return $this->repetition; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @param \PiggybankRepetition $repetition | ||||||
|  |      */ | ||||||
|  |     public function setRepetition($repetition) | ||||||
|  |     { | ||||||
|  |         $this->repetition = $repetition; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @return Carbon | ||||||
|  |      */ | ||||||
|  |     public function getStartdate() | ||||||
|  |     { | ||||||
|  |         return $this->startdate; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @param Carbon $startdate | ||||||
|  |      */ | ||||||
|  |     public function setStartdate($startdate) | ||||||
|  |     { | ||||||
|  |         $this->startdate = $startdate; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @return Carbon | ||||||
|  |      */ | ||||||
|  |     public function getTargetdate() | ||||||
|  |     { | ||||||
|  |         return $this->targetdate; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @param Carbon $targetdate | ||||||
|  |      */ | ||||||
|  |     public function setTargetdate($targetdate) | ||||||
|  |     { | ||||||
|  |         $this->targetdate = $targetdate; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function percentage() | ||||||
|  |     { | ||||||
|  |         if ($this->getCurrentamount() < $this->getAmount()) { | ||||||
|  |             $pct = 0; | ||||||
|  |             // calculate halway point? | ||||||
|  |             if ($this->getAmount() - $this->getCurrentamount() < $this->getAmountPerBar()) { | ||||||
|  |                 $left = $this->getCurrentamount() % $this->getAmountPerBar(); | ||||||
|  |                 $pct  = round($left / $this->getAmountPerBar() * 100); | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             return $pct; | ||||||
|  |         } else { | ||||||
|  |             return 100; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @return int | ||||||
|  |      */ | ||||||
|  |     public function getCurrentamount() | ||||||
|  |     { | ||||||
|  |         return $this->currentamount; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @param int $currentamount | ||||||
|  |      */ | ||||||
|  |     public function setCurrentamount($currentamount) | ||||||
|  |     { | ||||||
|  |         $this->currentamount = $currentamount; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @return int | ||||||
|  |      */ | ||||||
|  |     public function getAmount() | ||||||
|  |     { | ||||||
|  |         return $this->amount; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @param int $amount | ||||||
|  |      */ | ||||||
|  |     public function setAmount($amount) | ||||||
|  |     { | ||||||
|  |         $this->amount = $amount; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @return mixed | ||||||
|  |      */ | ||||||
|  |     public function getAmountPerBar() | ||||||
|  |     { | ||||||
|  |         return $this->amountPerBar; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @param mixed $amountPerBar | ||||||
|  |      */ | ||||||
|  |     public function setAmountPerBar($amountPerBar) | ||||||
|  |     { | ||||||
|  |         $this->amountPerBar = $amountPerBar; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -4,9 +4,11 @@ namespace FireflyIII\Database; | |||||||
|  |  | ||||||
|  |  | ||||||
| use Carbon\Carbon; | use Carbon\Carbon; | ||||||
|  | use FireflyIII\Collection\PiggybankPart; | ||||||
| use FireflyIII\Database\Ifaces\CommonDatabaseCalls; | use FireflyIII\Database\Ifaces\CommonDatabaseCalls; | ||||||
| use FireflyIII\Database\Ifaces\CUD; | use FireflyIII\Database\Ifaces\CUD; | ||||||
| use FireflyIII\Database\Ifaces\PiggybankInterface; | use FireflyIII\Database\Ifaces\PiggybankInterface; | ||||||
|  | use FireflyIII\Exception\FireflyException; | ||||||
| use FireflyIII\Exception\NotImplementedException; | use FireflyIII\Exception\NotImplementedException; | ||||||
| use Illuminate\Support\Collection; | use Illuminate\Support\Collection; | ||||||
| use Illuminate\Support\MessageBag; | use Illuminate\Support\MessageBag; | ||||||
| @@ -24,6 +26,212 @@ class RepeatedExpense implements CUD, CommonDatabaseCalls, PiggybankInterface | |||||||
|         $this->setUser(\Auth::user()); |         $this->setUser(\Auth::user()); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Based on the piggy bank, the reminder-setting and | ||||||
|  |      * other variables this method tries to divide the piggy bank into equal parts. Each is | ||||||
|  |      * accommodated by a reminder (if everything goes to plan). | ||||||
|  |      * | ||||||
|  |      * @return \PiggybankRepetition | ||||||
|  |      */ | ||||||
|  |     public function calculateParts(\PiggybankRepetition $repetition) | ||||||
|  |     { | ||||||
|  |         \Log::debug('NOW in calculateParts()'); | ||||||
|  |         \Log::debug('Repetition id is ' . $repetition->id); | ||||||
|  |         /** @var \Piggybank $piggyBank */ | ||||||
|  |         $piggyBank = $repetition->piggybank()->first(); | ||||||
|  |         \Log::debug('connected piggy bank is: ' . $piggyBank->name . ' (#' . $piggyBank->id . ')'); | ||||||
|  |  | ||||||
|  |         /* | ||||||
|  |          * If no reminders are set, the repetition is split in exactly one part: | ||||||
|  |          */ | ||||||
|  |         if (is_null($piggyBank->reminder)) { | ||||||
|  |             $parts = 1; | ||||||
|  |         } else { | ||||||
|  |             /* | ||||||
|  |              * Number of parts is the number of [reminder period]s between | ||||||
|  |              * the start date and the target date | ||||||
|  |              */ | ||||||
|  |             /** @var Carbon $start */ | ||||||
|  |             $start  = clone $repetition->startdate; | ||||||
|  |             /** @var Carbon $target */ | ||||||
|  |             $target = clone $repetition->targetdate; | ||||||
|  |  | ||||||
|  |             switch ($piggyBank->reminder) { | ||||||
|  |                 default: | ||||||
|  |                     throw new FireflyException('Cannot handle "' . $piggyBank->reminder . '" reminders for repeated expenses (calculateParts)'); | ||||||
|  |                     break; | ||||||
|  |                 case 'week': | ||||||
|  |                     $parts = $start->diffInWeeks($target); | ||||||
|  |                     break; | ||||||
|  |                 case 'month': | ||||||
|  |                     $parts = $start->diffInMonths($target); | ||||||
|  |                     break; | ||||||
|  |                 case 'quarter': | ||||||
|  |                     $parts = ceil($start->diffInMonths($target) / 3); | ||||||
|  |                     break; | ||||||
|  |                 case 'year': | ||||||
|  |                     $parts = $start->diffInYears($target); | ||||||
|  |                     break; | ||||||
|  |             } | ||||||
|  |             $parts = $parts < 1 ? 1 : $parts; | ||||||
|  |             unset($start, $target); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |             //            /* | ||||||
|  |             //             * Otherwise, FF3 splits by the difference in time and the amount | ||||||
|  |             //             * of reminders the user wants. | ||||||
|  |             //             */ | ||||||
|  |             //            switch ($piggyBank->reminder) { | ||||||
|  |             //                default: | ||||||
|  |             //                    throw new FireflyException('Cannot handle "' . $piggyBank->reminder . '" reminders for repeated expenses (calculateParts)'); | ||||||
|  |             //                    break; | ||||||
|  |             //                case 'week': | ||||||
|  |             //                    $start = clone $repetition->startdate; | ||||||
|  |             //                    $start->startOfWeek(); | ||||||
|  |             //                    $end = clone $repetition->targetdate; | ||||||
|  |             //                    $end->endOfWeek(); | ||||||
|  |             //                    $parts = $start->diffInWeeks($end); | ||||||
|  |             //                    unset($start, $end); | ||||||
|  |             //                    break; | ||||||
|  |             //                case 'month': | ||||||
|  |             //                    $start = clone $repetition->startdate; | ||||||
|  |             //                    $start->startOfMonth(); | ||||||
|  |             //                    $end = clone $repetition->targetdate; | ||||||
|  |             //                    $end->endOfMonth(); | ||||||
|  |             //                    $parts = $start->diffInMonths($end); | ||||||
|  |             //                    unset($start, $end); | ||||||
|  |             //                    break; | ||||||
|  |             //            } | ||||||
|  |         } | ||||||
|  |         $amountPerBar  = floatval($piggyBank->targetamount) / $parts; | ||||||
|  |         $currentAmount = floatval($amountPerBar); | ||||||
|  |         $currentStart  = clone $repetition->startdate; | ||||||
|  |         $currentTarget = clone $repetition->targetdate; | ||||||
|  |         $bars          = new Collection; | ||||||
|  |  | ||||||
|  |         //        if($parts > 12) { | ||||||
|  |         //            $parts = 12; | ||||||
|  |         //            $currentStart = \DateKit::startOfPeriod(Carbon::now(), $piggyBank->reminder); | ||||||
|  |         //            $currentEnd = \DateKit::endOfPeriod($currentEnd, $piggyBank->reminder); | ||||||
|  |         //        } | ||||||
|  |  | ||||||
|  |         for ($i = 0; $i < $parts; $i++) { | ||||||
|  |             /* | ||||||
|  |              * Jump one month ahead after the first instance: | ||||||
|  |              */ | ||||||
|  |             //            if ($i > 0) { | ||||||
|  |             //                $currentStart = \DateKit::addPeriod($currentStart, $piggyBank->reminder, 0); | ||||||
|  |             //                /* | ||||||
|  |             //                 * Jump to the start of the period too: | ||||||
|  |             //                 */ | ||||||
|  |             //                $currentStart = \DateKit::startOfPeriod($currentStart, $piggyBank->reminder); | ||||||
|  |             // | ||||||
|  |             //            } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |             /* | ||||||
|  |              * Move the current start to the actual start of | ||||||
|  |              * the [period] once the first iteration has passed. | ||||||
|  |              */ | ||||||
|  |             //            if ($i != 0) { | ||||||
|  |             //                $currentStart = \DateKit::startOfPeriod($currentStart, $piggyBank->reminder); | ||||||
|  |             //            } | ||||||
|  |             //            if($i == 0 && !is_null($piggyBank->reminder)) { | ||||||
|  |             //                $currentEnd = \DateKit::startOfPeriod($currentStart, $piggyBank->reminder); | ||||||
|  |             //                $currentEnd = \DateKit::endOfPeriod($currentEnd, $piggyBank->reminder); | ||||||
|  |             //            } | ||||||
|  |  | ||||||
|  |             $part = new PiggybankPart; | ||||||
|  |             $part->setRepetition($repetition); | ||||||
|  |             $part->setAmount($currentAmount); | ||||||
|  |             $part->setAmountPerBar($amountPerBar); | ||||||
|  |             $part->setCurrentamount($repetition->currentamount); | ||||||
|  |             $part->setStartdate($currentStart); | ||||||
|  |             $part->setTargetdate($currentTarget); | ||||||
|  |  | ||||||
|  |             //            if (!is_null($piggyBank->reminder)) { | ||||||
|  |             //                $currentStart = \DateKit::addPeriod($currentStart, $piggyBank->reminder, 0); | ||||||
|  |             //                $currentEnd   = \DateKit::endOfPeriod($currentStart, $piggyBank->reminder); | ||||||
|  |             //            } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |             $bars->push($part); | ||||||
|  |             $currentAmount += $amountPerBar; | ||||||
|  |         } | ||||||
|  |         $repetition->bars = $bars; | ||||||
|  |  | ||||||
|  |         return $repetition; | ||||||
|  |         exit; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |         $repetition->hello = 'World!'; | ||||||
|  |  | ||||||
|  |         return $repetition; | ||||||
|  |  | ||||||
|  |         $return      = new Collection; | ||||||
|  |         $repetitions = $piggyBank->piggybankrepetitions()->get(); | ||||||
|  |         /** @var \PiggybankRepetition $repetition */ | ||||||
|  |         foreach ($repetitions as $repetition) { | ||||||
|  |  | ||||||
|  |  | ||||||
|  |             if (is_null($piggyBank->reminder)) { | ||||||
|  |                 // simple, one part "repetition". | ||||||
|  |                 $part = new PiggybankPart; | ||||||
|  |                 $part->setRepetition($repetition); | ||||||
|  |             } else { | ||||||
|  |                 $part = new PiggybankPart; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |             // end! | ||||||
|  |             $return->push($part); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         exit; | ||||||
|  |  | ||||||
|  |         return $return; | ||||||
|  |         $piggyBank->currentRelevantRep(); // get the current relevant repetition. | ||||||
|  |         if (!is_null($piggyBank->reminder)) { | ||||||
|  |             switch ($piggyBank->reminder) { | ||||||
|  |                 default: | ||||||
|  |                     throw new FireflyException('Cannot handle "' . $piggyBank->reminder . '" reminders for repeated expenses'); | ||||||
|  |                     break; | ||||||
|  |                 case 'month': | ||||||
|  |                     $start = clone $piggyBank->currentRep->startdate; | ||||||
|  |                     $start->startOfMonth(); | ||||||
|  |                     $end = clone $piggyBank->currentRep->targetdate; | ||||||
|  |                     $end->endOfMonth(); | ||||||
|  |                     $piggyBank->parts = $start->diffInMonths($end); | ||||||
|  |                     unset($start, $end); | ||||||
|  |                     break; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |         } else { | ||||||
|  |             $piggyBank->parts = 1; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // number of bars: | ||||||
|  |         $piggyBank->barCount = floor(12 / $piggyBank->parts) == 0 ? 1 : floor(12 / $piggyBank->parts); | ||||||
|  |         $amountPerBar        = floatval($piggyBank->targetamount) / $piggyBank->parts; | ||||||
|  |         $currentAmount       = floatval($amountPerBar); | ||||||
|  |         $bars                = []; | ||||||
|  |         $currentStart        = clone $piggyBank->currentRep->startdate; | ||||||
|  |         for ($i = 0; $i < $piggyBank->parts; $i++) { | ||||||
|  |             // niet elke keer een andere dinges pakken? om target te redden? | ||||||
|  |             if (!is_null($piggyBank->reminder)) { | ||||||
|  |                 $currentStart = \DateKit::addPeriod($currentStart, $piggyBank->reminder, 0); | ||||||
|  |             } | ||||||
|  |             $bars[] = [ | ||||||
|  |                 'amount' => $currentAmount, | ||||||
|  |                 'date'   => $currentStart | ||||||
|  |             ]; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |             $currentAmount += $amountPerBar; | ||||||
|  |         } | ||||||
|  |         $piggyBank->bars = $bars; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * @param Ardent $model |      * @param Ardent $model | ||||||
|      * |      * | ||||||
| @@ -119,6 +327,10 @@ class RepeatedExpense implements CUD, CommonDatabaseCalls, PiggybankInterface | |||||||
|             } catch (\Exception $e) { |             } catch (\Exception $e) { | ||||||
|                 $errors->add('targetdate', 'Invalid date.'); |                 $errors->add('targetdate', 'Invalid date.'); | ||||||
|             } |             } | ||||||
|  |             $diff = Carbon::now()->diff(new Carbon($model['targetdate'])); | ||||||
|  |             if ($diff->days > 365) { | ||||||
|  |                 $errors->add('targetdate', 'First target date should a a year or less from now.'); | ||||||
|  |             } | ||||||
|         } else { |         } else { | ||||||
|             $errors->add('targetdate', 'Invalid target date.'); |             $errors->add('targetdate', 'Invalid target date.'); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -82,12 +82,14 @@ class Date | |||||||
|             case 'monthly': |             case 'monthly': | ||||||
|                 $currentEnd->addMonth()->subDay(); |                 $currentEnd->addMonth()->subDay(); | ||||||
|                 break; |                 break; | ||||||
|  |             case 'quarter': | ||||||
|             case 'quarterly': |             case 'quarterly': | ||||||
|                 $currentEnd->addMonths(3)->subDay(); |                 $currentEnd->addMonths(3)->subDay(); | ||||||
|                 break; |                 break; | ||||||
|             case 'half-year': |             case 'half-year': | ||||||
|                 $currentEnd->addMonths(6)->subDay(); |                 $currentEnd->addMonths(6)->subDay(); | ||||||
|                 break; |                 break; | ||||||
|  |             case 'year': | ||||||
|             case 'yearly': |             case 'yearly': | ||||||
|                 $currentEnd->addYear()->subDay(); |                 $currentEnd->addYear()->subDay(); | ||||||
|                 break; |                 break; | ||||||
| @@ -154,6 +156,7 @@ class Date | |||||||
|                     $date->addMonths(6); |                     $date->addMonths(6); | ||||||
|                 } |                 } | ||||||
|                 break; |                 break; | ||||||
|  |             case 'year': | ||||||
|             case 'yearly': |             case 'yearly': | ||||||
|                 $date->startOfYear(); |                 $date->startOfYear(); | ||||||
|                 break; |                 break; | ||||||
|   | |||||||
| @@ -71,8 +71,13 @@ class Reminders | |||||||
|         /** @var \FireflyIII\Database\Piggybank $repository */ |         /** @var \FireflyIII\Database\Piggybank $repository */ | ||||||
|         $repository = \App::make('FireflyIII\Database\Piggybank'); |         $repository = \App::make('FireflyIII\Database\Piggybank'); | ||||||
|  |  | ||||||
|  |         /** @var \FireflyIII\Database\Piggybank $repeatedRepository */ | ||||||
|  |         $repeatedRepository = \App::make('FireflyIII\Database\RepeatedExpense'); | ||||||
|  |  | ||||||
|         /** @var Collection $piggybanks */ |         /** @var Collection $piggybanks */ | ||||||
|         $piggybanks = $repository->get(); |         $piggybanks = $repository->get()->merge($repeatedRepository->get()); | ||||||
|  |  | ||||||
|  |  | ||||||
|         $set        = $piggybanks->filter( |         $set        = $piggybanks->filter( | ||||||
|             function (\Piggybank $piggybank) { |             function (\Piggybank $piggybank) { | ||||||
|                 if (!is_null($piggybank->reminder)) { |                 if (!is_null($piggybank->reminder)) { | ||||||
|   | |||||||
| @@ -56,7 +56,7 @@ class Piggybank extends Ardent | |||||||
|            'rep_length'    => 'in:day,week,month,quarter,year', // how long is the period? |            'rep_length'    => 'in:day,week,month,quarter,year', // how long is the period? | ||||||
|            'rep_every'     => 'required|min:1|max:100', // how often does it repeat? every 3 years. |            'rep_every'     => 'required|min:1|max:100', // how often does it repeat? every 3 years. | ||||||
|            'rep_times'     => 'min:1|max:100', // how many times do you want to save this amount? eg. 3 times |            'rep_times'     => 'min:1|max:100', // how many times do you want to save this amount? eg. 3 times | ||||||
|            'reminder'      => 'in:day,week,month,year', // want a reminder to put money in this? |            'reminder'      => 'in:day,week,quarter,month,year', // want a reminder to put money in this? | ||||||
|            'reminder_skip' => 'required|min:0|max:100', // every week? every 2 months? |            'reminder_skip' => 'required|min:0|max:100', // every week? every 2 months? | ||||||
|            'remind_me'     => 'required|boolean', 'order' => 'required:min:1', // not yet used. |            'remind_me'     => 'required|boolean', 'order' => 'required:min:1', // not yet used. | ||||||
|         ]; |         ]; | ||||||
| @@ -77,16 +77,12 @@ class Piggybank extends Ardent | |||||||
|      * |      * | ||||||
|      * @return int |      * @return int | ||||||
|      */ |      */ | ||||||
|     public function amountPerReminder() { |     public function amountPerReminder() | ||||||
|  |     { | ||||||
|         return 0; |         return 0; | ||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public function reminders() |  | ||||||
|     { |  | ||||||
|         return $this->morphMany('Reminder', 'remindersable'); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * TODO remove this method in favour of something in the FireflyIII libraries. |      * TODO remove this method in favour of something in the FireflyIII libraries. | ||||||
|      * |      * | ||||||
| @@ -130,12 +126,14 @@ class Piggybank extends Ardent | |||||||
|             return $this->currentRep; |             return $this->currentRep; | ||||||
|         } |         } | ||||||
|         if ($this->repeats == 0) { |         if ($this->repeats == 0) { | ||||||
|             $rep              = $this->piggybankrepetitions()->first(); |             $rep = $this->piggybankrepetitions()->first(['piggybank_repetitions.*']); | ||||||
|             $this->currentRep = $rep; |             $this->currentRep = $rep; | ||||||
|  |  | ||||||
|             return $rep; |             return $rep; | ||||||
|         } else { |         } else { | ||||||
|             $query  = $this->piggybankrepetitions()->where( |             $query  = $this->piggybankrepetitions()->where( | ||||||
|  |                 function ($q) { | ||||||
|  |  | ||||||
|  |                     $q->where( | ||||||
|                         function ($q) { |                         function ($q) { | ||||||
|  |  | ||||||
|                             $q->where( |                             $q->where( | ||||||
| @@ -158,9 +156,14 @@ class Piggybank extends Ardent | |||||||
|                             $q->where('startdate', '>=', $today->format('Y-m-d')); |                             $q->where('startdate', '>=', $today->format('Y-m-d')); | ||||||
|                             $q->where('targetdate', '>=', $today->format('Y-m-d')); |                             $q->where('targetdate', '>=', $today->format('Y-m-d')); | ||||||
|                         } |                         } | ||||||
|             )->orderBy('startdate', 'ASC'); |                     ); | ||||||
|             $result           = $query->first(); |  | ||||||
|  |                 } | ||||||
|  |             ) | ||||||
|  |                            ->orderBy('startdate', 'ASC'); | ||||||
|  |             $result = $query->first(['piggybank_repetitions.*']); | ||||||
|             $this->currentRep = $result; |             $this->currentRep = $result; | ||||||
|  |             \Log::debug('Found relevant rep in currentRelevantRep(): ' . $result->id); | ||||||
|  |  | ||||||
|             return $result; |             return $result; | ||||||
|         } |         } | ||||||
| @@ -192,6 +195,11 @@ class Piggybank extends Ardent | |||||||
|         return $this->hasMany('PiggybankEvent'); |         return $this->hasMany('PiggybankEvent'); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public function reminders() | ||||||
|  |     { | ||||||
|  |         return $this->morphMany('Reminder', 'remindersable'); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * TODO remove this method in favour of something in the FireflyIII libraries. |      * TODO remove this method in favour of something in the FireflyIII libraries. | ||||||
|      * |      * | ||||||
|   | |||||||
| @@ -103,13 +103,27 @@ Route::bind( | |||||||
|     'piggybank', function ($value, $route) { |     'piggybank', function ($value, $route) { | ||||||
|         if (Auth::check()) { |         if (Auth::check()) { | ||||||
|             return Piggybank:: |             return Piggybank:: | ||||||
|             where('piggybanks.id', $value)->leftJoin('accounts', 'accounts.id', '=', 'piggybanks.account_id')->where('accounts.user_id', Auth::user()->id) |             where('piggybanks.id', $value) | ||||||
|                             ->first(['piggybanks.*']); |                 ->leftJoin('accounts', 'accounts.id', '=', 'piggybanks.account_id') | ||||||
|  |                 ->where('accounts.user_id', Auth::user()->id) | ||||||
|  |                 ->where('repeats',0)->first(['piggybanks.*']); | ||||||
|         } |         } | ||||||
|         return null; |         return null; | ||||||
|     } |     } | ||||||
| ); | ); | ||||||
|  |  | ||||||
|  | Route::bind( | ||||||
|  |     'repeated', function ($value, $route) { | ||||||
|  |         if (Auth::check()) { | ||||||
|  |             return Piggybank:: | ||||||
|  |             where('piggybanks.id', $value) | ||||||
|  |                             ->leftJoin('accounts', 'accounts.id', '=', 'piggybanks.account_id') | ||||||
|  |                             ->where('accounts.user_id', Auth::user()->id) | ||||||
|  |                             ->where('repeats',1)->first(['piggybanks.*']); | ||||||
|  |         } | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  | ); | ||||||
|  |  | ||||||
| // protected routes: | // protected routes: | ||||||
| Route::group( | Route::group( | ||||||
|   | |||||||
| @@ -21,11 +21,9 @@ | |||||||
|  |  | ||||||
|  |  | ||||||
|             </div> |             </div> | ||||||
|             <div class="panel-body"> |  | ||||||
|                 @include('list.accounts') |                 @include('list.accounts') | ||||||
|         </div> |         </div> | ||||||
|     </div> |     </div> | ||||||
|     </div> |  | ||||||
| </div> | </div> | ||||||
| @stop | @stop | ||||||
| @section('scripts') | @section('scripts') | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| <table class="table table-bordered table-striped"> | <table class="table table-striped"> | ||||||
|     <tr> |     <tr> | ||||||
|         <th> </th> |         <th> </th> | ||||||
|         <th>Name</th> |         <th>Name</th> | ||||||
|   | |||||||
| @@ -14,14 +14,36 @@ | |||||||
|     </div> |     </div> | ||||||
| </div> | </div> | ||||||
| @foreach($expenses as $entry) | @foreach($expenses as $entry) | ||||||
|  | <?php | ||||||
|  | $barSize = floor(12 / $entry->currentRep->bars->count()) == 0 ? 1 : floor(12 / $entry->currentRep->bars->count()); | ||||||
|  | ?> | ||||||
| <div class="row"> | <div class="row"> | ||||||
|     <div class="col-lg-12 col-sm-12 col-md-12"> |     <div class="col-lg-12 col-sm-12 col-md-12"> | ||||||
|         <div class="panel panel-default"> |         <div class="panel panel-default"> | ||||||
|             <div class="panel-heading"> |             <div class="panel-heading"> | ||||||
|                 <a href="{{route('repeated.show',$entry->id)}}" title="{{{$entry->name}}}">{{{$entry->name}}}</a> ({{mf($entry->currentRep->currentamount)}}) |                 <a href="{{route('repeated.show',$entry->id)}}" title="{{{$entry->name}}}">{{{$entry->name}}}</a> | ||||||
|             </div> |             </div> | ||||||
|             <div class="panel-body"> |             <div class="panel-body"> | ||||||
|                 <div class="row"> |                 <div class="row"> | ||||||
|  |                     <div class="col-lg-12 col-sm-12 col-md-12"> | ||||||
|  |                         <p> | ||||||
|  |                             Target amount: {{mf($entry->targetamount)}}. Currently saved: {{mf($entry->currentRep->currentamount)}}. Left to save: {{mf($entry->targetamount-$entry->currentRep->currentamount)}}<br /> | ||||||
|  |                             Runs from {{$entry->currentRep->startdate->format('j F Y')}} to {{$entry->currentRep->targetdate->format('j F Y')}} | ||||||
|  |                         </p> | ||||||
|  |                     </div> | ||||||
|  |                 </div> | ||||||
|  |                 <div class="row"> | ||||||
|  |                 @foreach($entry->currentRep->bars as $bar) | ||||||
|  |                     <div class="col-lg-{{$barSize}} col-md-{{$barSize}} col-sm-{{$barSize}}"> | ||||||
|  |                         <div class="progress"> | ||||||
|  |                             <!-- currentAmount:{{$bar->getCurrentAmount()}} getAmount:{{$bar->getAmount()}} --> | ||||||
|  |                                 <div class="progress-bar progress-bar-success" role="progressbar" aria-valuenow="{{$bar->percentage()}}" aria-valuemin="0" aria-valuemax="100" style="width: {{$bar->percentage()}}%;"></div> | ||||||
|  |                                 <div class="progress-bar progress-bar-info" role="progressbar" aria-valuenow="{{100-$bar->percentage()}}" aria-valuemin="0" aria-valuemax="100" style="width: {{100-$bar->percentage()}}%;"></div> | ||||||
|  |                         </div> | ||||||
|  |  | ||||||
|  |                     </div> | ||||||
|  |                 @endforeach | ||||||
|  |                 {{-- | ||||||
|                     @for($i=0;$i<$entry->parts;$i++) |                     @for($i=0;$i<$entry->parts;$i++) | ||||||
|                     <!-- {{$entry->currentRep->currentamount}} < {{$entry->bars[$i]['amount']}} --> |                     <!-- {{$entry->currentRep->currentamount}} < {{$entry->bars[$i]['amount']}} --> | ||||||
|                     <div class="col-lg-{{$entry->barCount}} col-md-{{$entry->barCount}} col-sm-{{$entry->barCount}}"> |                     <div class="col-lg-{{$entry->barCount}} col-md-{{$entry->barCount}} col-sm-{{$entry->barCount}}"> | ||||||
| @@ -37,13 +59,16 @@ | |||||||
|  |  | ||||||
|                     </div> |                     </div> | ||||||
|                     @endfor |                     @endfor | ||||||
|  |                     --}} | ||||||
|                 </div> |                 </div> | ||||||
|                 <div class="row"> |                 <div class="row"> | ||||||
|  |                 {{-- | ||||||
|                 @for($i=0;$i<$entry->parts;$i++) |                 @for($i=0;$i<$entry->parts;$i++) | ||||||
|                     <div class="col-lg-{{$entry->barCount}} col-md-{{$entry->barCount}} col-sm-{{$entry->barCount}}"> |                     <div class="col-lg-{{$entry->barCount}} col-md-{{$entry->barCount}} col-sm-{{$entry->barCount}}"> | ||||||
|                         <small>{{DateKit::periodShow($entry->bars[$i]['date'],$entry->reminder)}}</small> |                         <small>{{DateKit::periodShow($entry->bars[$i]['date'],$entry->reminder)}}</small> | ||||||
|                     </div> |                     </div> | ||||||
|                 @endfor |                 @endfor | ||||||
|  |                 --}} | ||||||
|                 </div> |                 </div> | ||||||
|             </div> |             </div> | ||||||
|         </div> |         </div> | ||||||
|   | |||||||
							
								
								
									
										23
									
								
								app/views/repeatedexpense/show.blade.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								app/views/repeatedexpense/show.blade.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | |||||||
|  | @extends('layouts.default') | ||||||
|  | @section('content') | ||||||
|  | <div class="row"> | ||||||
|  | <div class="col-lg-12 col-md-12 col-sm-12"> | ||||||
|  |     @foreach($piggyBank->piggybankrepetitions as $rep) | ||||||
|  |     <div class="panel | ||||||
|  |     @if($today > $rep->startdate && $today < $rep->targetdate) | ||||||
|  |     panel-primary | ||||||
|  |     @else | ||||||
|  |     panel-default | ||||||
|  |     @endif | ||||||
|  |     "> | ||||||
|  |         <div class="panel-heading"> | ||||||
|  |             Repetition from {{$rep->startdate->format('j F Y')}} to {{$rep->targetdate->format('j F Y')}} | ||||||
|  |         </div> | ||||||
|  |         <div class="panel-body"> | ||||||
|  |             {{$piggyBank->reminder}} | ||||||
|  |         </div> | ||||||
|  |     </div> | ||||||
|  |     @endforeach | ||||||
|  | </div> | ||||||
|  | </div> | ||||||
|  | @stop | ||||||
| @@ -6,11 +6,9 @@ | |||||||
|             <div class="panel-heading"> |             <div class="panel-heading"> | ||||||
|                 <i class="fa {{$subTitleIcon}}"></i> {{{$subTitle}}} |                 <i class="fa {{$subTitleIcon}}"></i> {{{$subTitle}}} | ||||||
|             </div> |             </div> | ||||||
|             <div class="panel-body"> |  | ||||||
|                 @include('list.journals-full') |                 @include('list.journals-full') | ||||||
|         </div> |         </div> | ||||||
|     </div> |     </div> | ||||||
|     </div> |  | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user