collect(); return $this->response('banking.accounts.index', compact('accounts')); } /** * Show the form for viewing the specified resource. * * @return Response */ public function show(Account $account) { $transactions = Transaction::with('category', 'contact', 'document')->where('account_id', $account->id)->collect(['paid_at'=> 'desc']); $transfers = Transfer::with('expense_transaction', 'expense_transaction.account', 'income_transaction', 'income_transaction.account') ->whereHas('expense_transaction', fn ($query) => $query->where('account_id', $account->id)) ->orWhereHas('income_transaction', fn ($query) => $query->where('account_id', $account->id)) ->collect(['expense_transaction.paid_at' => 'desc']); $incoming_amount = money($account->income_balance, $account->currency_code, true); $outgoing_amount = money($account->expense_balance, $account->currency_code, true); $current_amount = money($account->balance, $account->currency_code, true); $summary_amounts = [ 'incoming_exact' => $incoming_amount->format(), 'incoming_for_humans' => $incoming_amount->formatForHumans(), 'outgoing_exact' => $outgoing_amount->format(), 'outgoing_for_humans' => $outgoing_amount->formatForHumans(), 'current_exact' => $current_amount->format(), 'current_for_humans' => $current_amount->formatForHumans(), ]; return view('banking.accounts.show', compact('account', 'transactions', 'transfers', 'summary_amounts')); } /** * Show the form for creating a new resource. * * @return Response */ public function create() { $currency = Currency::where('code', '=', setting('default.currency'))->first(); return view('banking.accounts.create', compact('currency')); } /** * Store a newly created resource in storage. * * @param Request $request * * @return Response */ public function store(Request $request) { $response = $this->ajaxDispatch(new CreateAccount($request)); if ($response['success']) { $response['redirect'] = route('accounts.show', $response['data']->id); $message = trans('messages.success.added', ['type' => trans_choice('general.accounts', 1)]); flash($message)->success(); } else { $response['redirect'] = route('accounts.create'); $message = $response['message']; flash($message)->error()->important(); } return response()->json($response); } /** * Duplicate the specified resource. * * @param Account $account * * @return Response */ public function duplicate(Account $account) { $clone = $account->duplicate(); $message = trans('messages.success.duplicated', ['type' => trans_choice('general.accounts', 1)]); flash($message)->success(); return redirect()->route('accounts.edit', $clone->id); } /** * Show the form for editing the specified resource. * * @param Account $account * * @return Response */ public function edit(Account $account) { $account->default_account = ($account->id == setting('default.account')) ? 1 : 0; $currency = Currency::where('code', '=', $account->currency_code)->first(); return view('banking.accounts.edit', compact('account', 'currency')); } /** * Update the specified resource in storage. * * @param Account $account * @param Request $request * * @return Response */ public function update(Account $account, Request $request) { $response = $this->ajaxDispatch(new UpdateAccount($account, $request)); if ($response['success']) { $response['redirect'] = route('accounts.show', $account->id); $message = trans('messages.success.updated', ['type' => $account->name]); flash($message)->success(); } else { $response['redirect'] = route('accounts.edit', $account->id); $message = $response['message']; flash($message)->error()->important(); } return response()->json($response); } /** * Enable the specified resource. * * @param Account $account * * @return Response */ public function enable(Account $account) { $response = $this->ajaxDispatch(new UpdateAccount($account, request()->merge(['enabled' => 1]))); if ($response['success']) { $response['message'] = trans('messages.success.enabled', ['type' => $account->name]); } return response()->json($response); } /** * Disable the specified resource. * * @param Account $account * * @return Response */ public function disable(Account $account) { $response = $this->ajaxDispatch(new UpdateAccount($account, request()->merge(['enabled' => 0]))); if ($response['success']) { $response['message'] = trans('messages.success.disabled', ['type' => $account->name]); } return response()->json($response); } /** * Remove the specified resource from storage. * * @param Account $account * * @return Response */ public function destroy(Account $account) { $response = $this->ajaxDispatch(new DeleteAccount($account)); $response['redirect'] = route('accounts.index'); if ($response['success']) { $message = trans('messages.success.deleted', ['type' => $account->name]); flash($message)->success(); } else { $message = $response['message']; flash($message)->error()->important(); } return response()->json($response); } public function createIncome(Account $account) { $data['account_id'] = $account->id; return redirect()->route('transactions.create', ['type' => 'income'])->withInput($data); } public function createExpense(Account $account) { $data['account_id'] = $account->id; return redirect()->route('transactions.create', ['type' => 'expense'])->withInput($data); } public function createTransfer(Account $account) { $data['from_account_id'] = $account->id; return redirect()->route('transfers.create')->withInput($data); } public function seePerformance(Account $account) { $data = [ 'year' => Date::now()->year, 'basis' => 'accrual', 'account_id' => $account->id, ]; $report = Reports::getClassInstance('App\Reports\IncomeExpenseSummary'); if (empty($report) || empty($report->model)) { $message = trans('accounts.create_report'); flash($message)->warning()->important(); return redirect()->route('reports.create'); } return redirect()->route('reports.show', $report->model->id)->withInput($data); } public function currency() { $account_id = (int) request('account_id'); if (empty($account_id)) { return response()->json([]); } $account = Account::find($account_id); if (empty($account)) { return response()->json([]); } $currency_code = setting('default.currency'); if (isset($account->currency_code)) { $currencies = Currency::enabled()->pluck('name', 'code')->toArray(); if (array_key_exists($account->currency_code, $currencies)) { $currency_code = $account->currency_code; } } // Get currency object $currency = Currency::where('code', $currency_code)->first(); $account->currency_name = $currency->name; $account->currency_code = $currency_code; $account->currency_rate = $currency->rate; $account->thousands_separator = $currency->thousands_separator; $account->decimal_mark = $currency->decimal_mark; $account->precision = (int) $currency->precision; $account->symbol_first = $currency->symbol_first; $account->symbol = $currency->symbol; return response()->json($account); } }