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.

InvoiceOverview.php 2.9KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. <?php
  2. namespace App\Filament\Company\Resources\Sales\InvoiceResource\Widgets;
  3. use App\Enums\Accounting\InvoiceStatus;
  4. use App\Filament\Company\Resources\Sales\InvoiceResource\Pages\ListInvoices;
  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 InvoiceOverview extends EnhancedStatsOverviewWidget
  11. {
  12. use InteractsWithPageTable;
  13. protected function getTablePage(): string
  14. {
  15. return ListInvoices::class;
  16. }
  17. protected function getStats(): array
  18. {
  19. $unpaidInvoices = $this->getPageTableQuery()->unpaid();
  20. $amountUnpaid = $unpaidInvoices->get()->sumMoneyInDefaultCurrency('amount_due');
  21. $amountOverdue = $unpaidInvoices
  22. ->clone()
  23. ->where('status', InvoiceStatus::Overdue)
  24. ->get()
  25. ->sumMoneyInDefaultCurrency('amount_due');
  26. $amountDueWithin30Days = $unpaidInvoices
  27. ->clone()
  28. ->whereBetween('due_date', [today(), today()->addMonth()])
  29. ->get()
  30. ->sumMoneyInDefaultCurrency('amount_due');
  31. $validInvoices = $this->getPageTableQuery()
  32. ->whereNotIn('status', [
  33. InvoiceStatus::Void,
  34. InvoiceStatus::Draft,
  35. ]);
  36. $totalValidInvoiceAmount = $validInvoices->get()->sumMoneyInDefaultCurrency('total');
  37. $totalValidInvoiceCount = $validInvoices->count();
  38. $averageInvoiceTotal = $totalValidInvoiceCount > 0
  39. ? (int) round($totalValidInvoiceAmount / $totalValidInvoiceCount)
  40. : 0;
  41. $averagePaymentTime = $this->getPageTableQuery()
  42. ->whereNotNull('paid_at')
  43. ->selectRaw('AVG(TIMESTAMPDIFF(DAY, approved_at, paid_at)) as avg_days')
  44. ->value('avg_days');
  45. $averagePaymentTimeFormatted = Number::format($averagePaymentTime ?? 0, maxPrecision: 1);
  46. return [
  47. EnhancedStatsOverviewWidget\EnhancedStat::make('Total Unpaid', CurrencyConverter::formatCentsToMoney($amountUnpaid))
  48. ->suffix(CurrencyAccessor::getDefaultCurrency())
  49. ->description('Includes ' . CurrencyConverter::formatCentsToMoney($amountOverdue) . ' overdue'),
  50. EnhancedStatsOverviewWidget\EnhancedStat::make('Due Within 30 Days', CurrencyConverter::formatCentsToMoney($amountDueWithin30Days))
  51. ->suffix(CurrencyAccessor::getDefaultCurrency()),
  52. EnhancedStatsOverviewWidget\EnhancedStat::make('Average Payment Time', $averagePaymentTimeFormatted)
  53. ->suffix('days'),
  54. EnhancedStatsOverviewWidget\EnhancedStat::make('Average Invoice Total', CurrencyConverter::formatCentsToMoney($averageInvoiceTotal))
  55. ->suffix(CurrencyAccessor::getDefaultCurrency()),
  56. ];
  57. }
  58. }