Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  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\Facades\DB;
  10. use Illuminate\Support\Number;
  11. class BillOverview extends EnhancedStatsOverviewWidget
  12. {
  13. use InteractsWithPageTable;
  14. protected function getTablePage(): string
  15. {
  16. return ListBills::class;
  17. }
  18. protected function getStats(): array
  19. {
  20. $activeTab = $this->activeTab;
  21. $averagePaymentTimeFormatted = '-';
  22. $averagePaymentTimeSuffix = null;
  23. $lastMonthTotal = '-';
  24. $lastMonthTotalSuffix = null;
  25. if ($activeTab !== 'unpaid') {
  26. $driver = DB::getDriverName();
  27. $query = $this->getPageTableQuery()
  28. ->whereNotNull('paid_at');
  29. if ($driver === 'pgsql') {
  30. $query->selectRaw('AVG(EXTRACT(EPOCH FROM (paid_at - date)) / 86400) as avg_days');
  31. } elseif ($driver === 'sqlite') {
  32. $query->selectRaw('AVG(julianday(paid_at) - julianday(date)) as avg_days');
  33. } else {
  34. $query->selectRaw('AVG(TIMESTAMPDIFF(DAY, date, paid_at)) as avg_days');
  35. }
  36. $averagePaymentTime = $query
  37. ->groupBy('company_id')
  38. ->reorder()
  39. ->value('avg_days');
  40. $averagePaymentTimeFormatted = Number::format($averagePaymentTime ?? 0, maxPrecision: 1);
  41. $averagePaymentTimeSuffix = 'days';
  42. $lastMonthPaid = $this->getPageTableQuery()
  43. ->whereBetween('date', [
  44. company_today()->subMonth()->startOfMonth(),
  45. company_today()->subMonth()->endOfMonth(),
  46. ])
  47. ->get()
  48. ->sumMoneyInDefaultCurrency('amount_paid');
  49. $lastMonthTotal = CurrencyConverter::formatCentsToMoney($lastMonthPaid);
  50. $lastMonthTotalSuffix = CurrencyAccessor::getDefaultCurrency();
  51. }
  52. if ($activeTab === 'paid') {
  53. return [
  54. EnhancedStatsOverviewWidget\EnhancedStat::make('Total To Pay', '-'),
  55. EnhancedStatsOverviewWidget\EnhancedStat::make('Due Within 7 Days', '-'),
  56. EnhancedStatsOverviewWidget\EnhancedStat::make('Average Payment Time', $averagePaymentTimeFormatted)
  57. ->suffix($averagePaymentTimeSuffix),
  58. EnhancedStatsOverviewWidget\EnhancedStat::make('Paid Last Month', $lastMonthTotal)
  59. ->suffix($lastMonthTotalSuffix),
  60. ];
  61. }
  62. $unpaidBills = $this->getPageTableQuery()
  63. ->unpaid();
  64. $amountToPay = $unpaidBills->get()->sumMoneyInDefaultCurrency('amount_due');
  65. $amountOverdue = $unpaidBills
  66. ->clone()
  67. ->where('status', BillStatus::Overdue)
  68. ->get()
  69. ->sumMoneyInDefaultCurrency('amount_due');
  70. $amountDueWithin7Days = $unpaidBills
  71. ->clone()
  72. ->whereBetween('due_date', [company_today(), company_today()->addWeek()])
  73. ->get()
  74. ->sumMoneyInDefaultCurrency('amount_due');
  75. return [
  76. EnhancedStatsOverviewWidget\EnhancedStat::make('Total To Pay', CurrencyConverter::formatCentsToMoney($amountToPay))
  77. ->suffix(CurrencyAccessor::getDefaultCurrency())
  78. ->description('Includes ' . CurrencyConverter::formatCentsToMoney($amountOverdue) . ' overdue'),
  79. EnhancedStatsOverviewWidget\EnhancedStat::make('Due Within 7 Days', CurrencyConverter::formatCentsToMoney($amountDueWithin7Days))
  80. ->suffix(CurrencyAccessor::getDefaultCurrency()),
  81. EnhancedStatsOverviewWidget\EnhancedStat::make('Average Payment Time', $averagePaymentTimeFormatted)
  82. ->suffix($averagePaymentTimeSuffix),
  83. EnhancedStatsOverviewWidget\EnhancedStat::make('Paid Last Month', $lastMonthTotal)
  84. ->suffix($lastMonthTotalSuffix),
  85. ];
  86. }
  87. }