Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

BillOverview.php 3.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  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. $activeTab = $this->activeTab;
  20. $averagePaymentTimeFormatted = '-';
  21. $averagePaymentTimeSuffix = null;
  22. $lastMonthTotal = '-';
  23. $lastMonthTotalSuffix = null;
  24. if ($activeTab !== 'unpaid') {
  25. $averagePaymentTime = $this->getPageTableQuery()
  26. ->whereNotNull('paid_at')
  27. ->selectRaw('AVG(TIMESTAMPDIFF(DAY, date, paid_at)) as avg_days')
  28. ->groupBy('company_id')
  29. ->value('avg_days');
  30. $averagePaymentTimeFormatted = Number::format($averagePaymentTime ?? 0, maxPrecision: 1);
  31. $averagePaymentTimeSuffix = 'days';
  32. $lastMonthPaid = $this->getPageTableQuery()
  33. ->whereBetween('date', [
  34. today()->subMonth()->startOfMonth(),
  35. today()->subMonth()->endOfMonth(),
  36. ])
  37. ->get()
  38. ->sumMoneyInDefaultCurrency('amount_paid');
  39. $lastMonthTotal = CurrencyConverter::formatCentsToMoney($lastMonthPaid);
  40. $lastMonthTotalSuffix = CurrencyAccessor::getDefaultCurrency();
  41. }
  42. if ($activeTab === 'paid') {
  43. return [
  44. EnhancedStatsOverviewWidget\EnhancedStat::make('Total To Pay', '-'),
  45. EnhancedStatsOverviewWidget\EnhancedStat::make('Due Within 7 Days', '-'),
  46. EnhancedStatsOverviewWidget\EnhancedStat::make('Average Payment Time', $averagePaymentTimeFormatted)
  47. ->suffix($averagePaymentTimeSuffix),
  48. EnhancedStatsOverviewWidget\EnhancedStat::make('Paid Last Month', $lastMonthTotal)
  49. ->suffix($lastMonthTotalSuffix),
  50. ];
  51. }
  52. $unpaidBills = $this->getPageTableQuery()
  53. ->unpaid();
  54. $amountToPay = $unpaidBills->get()->sumMoneyInDefaultCurrency('amount_due');
  55. $amountOverdue = $unpaidBills
  56. ->clone()
  57. ->where('status', BillStatus::Overdue)
  58. ->get()
  59. ->sumMoneyInDefaultCurrency('amount_due');
  60. $amountDueWithin7Days = $unpaidBills
  61. ->clone()
  62. ->whereBetween('due_date', [today(), today()->addWeek()])
  63. ->get()
  64. ->sumMoneyInDefaultCurrency('amount_due');
  65. return [
  66. EnhancedStatsOverviewWidget\EnhancedStat::make('Total To Pay', CurrencyConverter::formatCentsToMoney($amountToPay))
  67. ->suffix(CurrencyAccessor::getDefaultCurrency())
  68. ->description('Includes ' . CurrencyConverter::formatCentsToMoney($amountOverdue) . ' overdue'),
  69. EnhancedStatsOverviewWidget\EnhancedStat::make('Due Within 7 Days', CurrencyConverter::formatCentsToMoney($amountDueWithin7Days))
  70. ->suffix(CurrencyAccessor::getDefaultCurrency()),
  71. EnhancedStatsOverviewWidget\EnhancedStat::make('Average Payment Time', $averagePaymentTimeFormatted)
  72. ->suffix($averagePaymentTimeSuffix),
  73. EnhancedStatsOverviewWidget\EnhancedStat::make('Paid Last Month', $lastMonthTotal)
  74. ->suffix($lastMonthTotalSuffix),
  75. ];
  76. }
  77. }