You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

BillOverview.php 2.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. <?php
  2. namespace App\Filament\Company\Resources\Purchases\BillResource\Widgets;
  3. use App\Enums\Accounting\BillStatus;
  4. use App\Filament\Company\Resources\Purchases\BillResource\Pages\ListBills;
  5. use App\Filament\Widgets\EnhancedStatsOverviewWidget;
  6. use App\Utilities\Currency\CurrencyAccessor;
  7. use App\Utilities\Currency\CurrencyConverter;
  8. use Filament\Widgets\Concerns\InteractsWithPageTable;
  9. use Illuminate\Support\Number;
  10. class BillOverview extends EnhancedStatsOverviewWidget
  11. {
  12. use InteractsWithPageTable;
  13. protected function getTablePage(): string
  14. {
  15. return ListBills::class;
  16. }
  17. protected function getStats(): array
  18. {
  19. $unpaidBills = $this->getPageTableQuery()
  20. ->whereIn('status', [BillStatus::Open, BillStatus::Partial, BillStatus::Overdue]);
  21. $amountToPay = $unpaidBills->get()->sumMoneyInDefaultCurrency('amount_due');
  22. $amountOverdue = $unpaidBills
  23. ->clone()
  24. ->where('status', BillStatus::Overdue)
  25. ->get()
  26. ->sumMoneyInDefaultCurrency('amount_due');
  27. $amountDueWithin7Days = $unpaidBills
  28. ->clone()
  29. ->whereBetween('due_date', [today(), today()->addWeek()])
  30. ->get()
  31. ->sumMoneyInDefaultCurrency('amount_due');
  32. $averagePaymentTime = $this->getPageTableQuery()
  33. ->whereNotNull('paid_at')
  34. ->selectRaw('AVG(TIMESTAMPDIFF(DAY, date, paid_at)) as avg_days')
  35. ->value('avg_days');
  36. $averagePaymentTimeFormatted = Number::format($averagePaymentTime ?? 0, maxPrecision: 1);
  37. $lastMonthTotal = $this->getPageTableQuery()
  38. ->where('status', BillStatus::Paid)
  39. ->whereBetween('date', [
  40. today()->subMonth()->startOfMonth(),
  41. today()->subMonth()->endOfMonth(),
  42. ])
  43. ->get()
  44. ->sumMoneyInDefaultCurrency('amount_paid');
  45. return [
  46. EnhancedStatsOverviewWidget\EnhancedStat::make('Total To Pay', CurrencyConverter::formatCentsToMoney($amountToPay))
  47. ->suffix(CurrencyAccessor::getDefaultCurrency())
  48. ->description('Includes ' . CurrencyConverter::formatCentsToMoney($amountOverdue) . ' overdue'),
  49. EnhancedStatsOverviewWidget\EnhancedStat::make('Due Within 7 Days', CurrencyConverter::formatCentsToMoney($amountDueWithin7Days))
  50. ->suffix(CurrencyAccessor::getDefaultCurrency()),
  51. EnhancedStatsOverviewWidget\EnhancedStat::make('Average Payment Time', $averagePaymentTimeFormatted)
  52. ->suffix('days'),
  53. EnhancedStatsOverviewWidget\EnhancedStat::make('Paid Last Month', CurrencyConverter::formatCentsToMoney($lastMonthTotal))
  54. ->suffix(CurrencyAccessor::getDefaultCurrency()),
  55. ];
  56. }
  57. }