piggyBank()->first(); $bars = new Collection; $currentStart = clone $repetition->startdate; if (is_null($piggyBank->reminder)) { $entry = ['repetition' => $repetition, 'amountPerBar' => floatval($piggyBank->targetamount), 'currentAmount' => floatval($repetition->currentamount), 'cumulativeAmount' => floatval($piggyBank->targetamount), 'startDate' => clone $repetition->startdate, 'targetDate' => clone $repetition->targetdate]; $bars->push($this->createPiggyBankPart($entry)); return $bars; } while ($currentStart < $repetition->targetdate) { $currentTarget = Navigation::endOfX($currentStart, $piggyBank->reminder, $repetition->targetdate); $entry = ['repetition' => $repetition, 'amountPerBar' => null, 'currentAmount' => floatval($repetition->currentamount), 'cumulativeAmount' => null, 'startDate' => $currentStart, 'targetDate' => $currentTarget]; $bars->push($this->createPiggyBankPart($entry)); $currentStart = clone $currentTarget; $currentStart->addDay(); } $amountPerBar = floatval($piggyBank->targetamount) / $bars->count(); $cumulative = $amountPerBar; /** @var PiggyBankPart $bar */ foreach ($bars as $index => $bar) { $bar->setAmountPerBar($amountPerBar); $bar->setCumulativeAmount($cumulative); if ($bars->count() - 1 == $index) { $bar->setCumulativeAmount($piggyBank->targetamount); } $cumulative += $amountPerBar; } return $bars; } /** * @param array $data * * @return PiggyBankPart */ public function createPiggyBankPart(array $data) { $part = new PiggyBankPart; $part->setRepetition($data['repetition']); $part->setAmountPerBar($data['amountPerBar']); $part->setCurrentamount($data['currentAmount']); $part->setCumulativeAmount($data['cumulativeAmount']); $part->setStartdate($data['startDate']); $part->setTargetdate($data['targetDate']); return $part; } /** * @param PiggyBank $piggyBank * * @return Collection */ public function getEventSummarySet(PiggyBank $piggyBank) { return DB::table('piggy_bank_events')->where('piggy_bank_id', $piggyBank->id)->groupBy('date')->get(['date', DB::Raw('SUM(`amount`) AS `sum`')]); } /** * Set all piggy banks to order 0. * * @return void */ public function reset() { DB::table('piggy_banks') ->leftJoin('accounts', 'accounts.id', '=', 'piggy_banks.id') ->where('accounts.user_id', Auth::user()->id) ->update(['order' => 0, 'piggy_banks.updated_at' => DB::Raw('NOW()')]); } /** * * set id of piggy bank. * * @param int $id * @param int $order * * @return void */ public function setOrder($id, $order) { $piggyBank = PiggyBank::leftJoin('accounts', 'accounts.id', '=', 'piggy_banks.account_id')->where('accounts.user_id', Auth::user()->id) ->where('piggy_banks.id', $id)->first(['piggy_banks.*']); if ($piggyBank) { $piggyBank->order = $order; $piggyBank->save(); } } /** * @param array $data * * @return PiggyBank */ public function store(array $data) { $data['remind_me'] = isset($data['remind_me']) && $data['remind_me'] == '1' ? true : false; $piggyBank = PiggyBank::create($data); return $piggyBank; } /** * @param PiggyBank $account * @param array $data * * @return PiggyBank */ public function update(PiggyBank $piggyBank, array $data) { /** * 'rep_length' => $request->get('rep_length'), * 'rep_every' => intval($request->get('rep_every')), * 'rep_times' => intval($request->get('rep_times')), * 'remind_me' => intval($request->get('remind_me')) == 1 ? true : false , * 'reminder' => $request->get('reminder'), */ $piggyBank->name = $data['name']; $piggyBank->account_id = intval($data['account_id']); $piggyBank->targetamount = floatval($data['targetamount']); $piggyBank->targetdate = $data['targetdate']; $piggyBank->reminder = $data['reminder']; $piggyBank->startdate = $data['startdate']; $piggyBank->remind_me = isset($data['remind_me']) && $data['remind_me'] == '1' ? 1 : 0; $piggyBank->save(); return $piggyBank; } }