middleware('check.permission:due-reports.read')->only(['index']); } public function index(Request $request) { $user = auth()->user(); $activeBranch = $user->active_branch; $business_id = $user->business_id; $query = Party::where('business_id', $business_id) ->where('type', '!=', 'Supplier') ->when($request->search, function ($q) use ($request) { $q->where(function ($q2) use ($request) { $q2->where('type', 'like', '%' . $request->search . '%') ->orWhere('name', 'like', '%' . $request->search . '%') ->orWhere('phone', 'like', '%' . $request->search . '%') ->orWhere('credit_limit', 'like', '%' . $request->search . '%'); }); }) ->when(request('type'), function ($q) use ($request) { $q->where(function ($q) use ($request) { $q->where('type', $request->type); }); }) ->with('sales_dues') ->latest(); if ($activeBranch) { $query->whereHas('sales_dues', function ($q) use ($activeBranch) { $q->where('branch_id', $activeBranch->id) ->where('dueAmount', '>', 0); }); } else { $query->where('due', '>', 0); } $parties = $query->paginate($request->per_page ?? 20); if ($activeBranch) { $parties->setCollection( $parties->getCollection() ->transform(function ($customer) use ($activeBranch) { $customer->due = $customer->sales_dues ->where('branch_id', $activeBranch->id) ->sum('dueAmount'); return $customer; }) ->filter(fn($customer) => $customer->due > 0) ->values() ); } $total_due = $parties->sum(fn($customer) => $customer->due); if ($request->ajax()) { return response()->json([ 'data' => view('business::reports.due.datas', compact('parties', 'total_due'))->render() ]); } if ($activeBranch) { // Filter customers that have branch-specific due > 0 $query->whereHas('sales_dues', function ($q) use ($activeBranch) { $q->where('branch_id', $activeBranch->id) ->where('dueAmount', '>', 0); }); } else { // global due > 0 $query->where('due', '>', 0); } $parties = $query->paginate(20)->appends($request->query()); // Replace customer due with branch-specific due if active branch exists if ($activeBranch) { $parties->setCollection( $parties->getCollection() ->transform(function ($customer) use ($activeBranch) { $customer->due = $customer->sales_dues ->where('branch_id', $activeBranch->id) ->sum('dueAmount'); return $customer; }) ->filter(fn($customer) => $customer->due > 0) ->values() ); } // Calculate total_due $total_due = $parties->sum(fn($customer) => $customer->due); return view('business::reports.due.due-reports', compact('parties', 'total_due')); } public function exportExcel() { return Excel::download(new ExportDue, 'customer-due.xlsx'); } public function exportCsv() { return Excel::download(new ExportDue, 'customer-due.csv'); } public function exportPdf() { $user = auth()->user(); $businessId = $user->business_id; $activeBranch = $user->active_branch; $query = Party::where('business_id', $businessId) ->where('type', '!=', 'Supplier') ->with('sales_dues') ->latest(); if ($activeBranch) { $query->whereHas('sales_dues', function ($q) use ($activeBranch) { $q->where('branch_id', $activeBranch->id) ->where('dueAmount', '>', 0); }); } else { $query->where('due', '>', 0); } $parties = $query->get(); if ($activeBranch) { $parties->transform(function ($supplier) use ($activeBranch) { $supplier->due = $supplier->sales_dues ->where('branch_id', $activeBranch->id) ->sum('dueAmount'); return $supplier; })->filter(fn($supplier) => $supplier->due > 0); } return PdfService::render('business::reports.due.pdf', compact('parties'),'customer-due-report.pdf'); } }