0, 'open' => 0, 'overdue' => 0, ]; $counts = [ 'bills' => 0, 'payments' => 0, ]; // Handle bills $bills = Bill::with(['status', 'payments'])->where('vendor_id', $vendor->id)->get(); $counts['bills'] = $bills->count(); $bill_payments = []; $today = Date::today()->toDateString(); foreach ($bills as $item) { $payments = 0; foreach ($item->payments as $payment) { $payment->category = $item->category; $bill_payments[] = $payment; $amount = $payment->getConvertedAmount(); $amounts['paid'] += $amount; $payments += $amount; } if ($item->bill_status_code == 'paid') { continue; } // Check if it's open or overdue invoice if ($item->due_at > $today) { $amounts['open'] += $item->getConvertedAmount() - $payments; } else { $amounts['overdue'] += $item->getConvertedAmount() - $payments; } } // Handle payments $payments = Payment::with(['account', 'category'])->where('vendor_id', $vendor->id)->get(); $counts['payments'] = $payments->count(); // Prepare data $items = collect($payments)->each(function ($item) use (&$amounts) { $amounts['paid'] += $item->getConvertedAmount(); }); $limit = request('limit', setting('general.list_limit', '25')); $transactions = $this->paginate($items->merge($bill_payments)->sortByDesc('paid_at'), $limit); return view('expenses.vendors.show', compact('vendor', 'counts', 'amounts', 'transactions')); } /** * Show the form for creating a new resource. * * @return Response */ public function create() { $currencies = Currency::enabled()->pluck('name', 'code'); return view('expenses.vendors.create', compact('currencies')); } /** * Store a newly created resource in storage. * * @param Request $request * * @return Response */ public function store(Request $request) { if (empty($request['email'])) { $request['email'] = ''; } $vendor = Vendor::create($request->all()); // Upload logo if ($request->file('logo')) { $media = $this->getMedia($request->file('logo'), 'vendors'); $vendor->attachMedia($media, 'logo'); } $message = trans('messages.success.added', ['type' => trans_choice('general.vendors', 1)]); flash($message)->success(); return redirect('expenses/vendors'); } /** * Duplicate the specified resource. * * @param Vendor $vendor * * @return Response */ public function duplicate(Vendor $vendor) { $clone = $vendor->duplicate(); $message = trans('messages.success.duplicated', ['type' => trans_choice('general.vendors', 1)]); flash($message)->success(); return redirect('expenses/vendors/' . $clone->id . '/edit'); } /** * Import the specified resource. * * @param ImportFile $import * * @return Response */ public function import(ImportFile $import) { $rows = $import->all(); foreach ($rows as $row) { $data = $row->toArray(); if (empty($data['email'])) { $data['email'] = ''; } $data['company_id'] = session('company_id'); Vendor::create($data); } $message = trans('messages.success.imported', ['type' => trans_choice('general.vendors', 2)]); flash($message)->success(); return redirect('expenses/vendors'); } /** * Show the form for editing the specified resource. * * @param Vendor $vendor * * @return Response */ public function edit(Vendor $vendor) { $currencies = Currency::enabled()->pluck('name', 'code'); return view('expenses.vendors.edit', compact('vendor', 'currencies')); } /** * Update the specified resource in storage. * * @param Vendor $vendor * @param Request $request * * @return Response */ public function update(Vendor $vendor, Request $request) { if (empty($request['email'])) { $request['email'] = ''; } $vendor->update($request->all()); // Upload logo if ($request->file('logo')) { $media = $this->getMedia($request->file('logo'), 'vendors'); $vendor->attachMedia($media, 'logo'); } $message = trans('messages.success.updated', ['type' => trans_choice('general.vendors', 1)]); flash($message)->success(); return redirect('expenses/vendors'); } /** * Remove the specified resource from storage. * * @param Vendor $vendor * * @return Response */ public function destroy(Vendor $vendor) { $relationships = $this->countRelationships($vendor, [ 'bills' => 'bills', 'payments' => 'payments', ]); if (empty($relationships)) { $vendor->delete(); $message = trans('messages.success.deleted', ['type' => trans_choice('general.vendors', 1)]); flash($message)->success(); } else { $message = trans('messages.warning.deleted', ['name' => $vendor->name, 'text' => implode(', ', $relationships)]); flash($message)->warning(); } return redirect('expenses/vendors'); } public function currency() { $vendor_id = request('vendor_id'); $vendor = Vendor::find($vendor_id); return response()->json($vendor); } public function vendor(Request $request) { if (empty($request['email'])) { $request['email'] = ''; } $vendor = Vendor::create($request->all()); return response()->json($vendor); } /** * Generate a pagination collection. * * @param array|Collection $items * @param int $perPage * @param int $page * @param array $options * * @return LengthAwarePaginator */ public function paginate($items, $perPage = 15, $page = null, $options = []) { $page = $page ?: (Paginator::resolveCurrentPage() ?: 1); $items = $items instanceof Collection ? $items : Collection::make($items); return new LengthAwarePaginator($items->forPage($page, $perPage), $items->count(), $perPage, $page, $options); } }