| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 | 
							- <?php
 - 
 - namespace App\Filament\Company\Resources\Purchases\BillResource\Widgets;
 - 
 - use App\Enums\Accounting\BillStatus;
 - use App\Filament\Company\Resources\Purchases\BillResource\Pages\ListBills;
 - use App\Filament\Widgets\EnhancedStatsOverviewWidget;
 - use App\Utilities\Currency\CurrencyAccessor;
 - use App\Utilities\Currency\CurrencyConverter;
 - use Filament\Widgets\Concerns\InteractsWithPageTable;
 - use Illuminate\Support\Facades\DB;
 - use Illuminate\Support\Number;
 - 
 - class BillOverview extends EnhancedStatsOverviewWidget
 - {
 -     use InteractsWithPageTable;
 - 
 -     protected function getTablePage(): string
 -     {
 -         return ListBills::class;
 -     }
 - 
 -     protected function getStats(): array
 -     {
 -         $activeTab = $this->activeTab;
 - 
 -         $averagePaymentTimeFormatted = '-';
 -         $averagePaymentTimeSuffix = null;
 -         $lastMonthTotal = '-';
 -         $lastMonthTotalSuffix = null;
 - 
 -         if ($activeTab !== 'unpaid') {
 -             $driver = DB::getDriverName();
 - 
 -             $query = $this->getPageTableQuery()
 -                 ->whereNotNull('paid_at');
 - 
 -             if ($driver === 'pgsql') {
 -                 $query->selectRaw('AVG(EXTRACT(EPOCH FROM (paid_at - date)) / 86400) as avg_days');
 -             } elseif ($driver === 'sqlite') {
 -                 $query->selectRaw('AVG(julianday(paid_at) - julianday(date)) as avg_days');
 -             } else {
 -                 $query->selectRaw('AVG(TIMESTAMPDIFF(DAY, date, paid_at)) as avg_days');
 -             }
 - 
 -             $averagePaymentTime = $query
 -                 ->groupBy('company_id')
 -                 ->reorder()
 -                 ->value('avg_days');
 - 
 -             $averagePaymentTimeFormatted = Number::format($averagePaymentTime ?? 0, maxPrecision: 1);
 -             $averagePaymentTimeSuffix = 'days';
 - 
 -             $lastMonthPaid = $this->getPageTableQuery()
 -                 ->whereBetween('date', [
 -                     company_today()->subMonth()->startOfMonth(),
 -                     company_today()->subMonth()->endOfMonth(),
 -                 ])
 -                 ->get()
 -                 ->sumMoneyInDefaultCurrency('amount_paid');
 - 
 -             $lastMonthTotal = CurrencyConverter::formatCentsToMoney($lastMonthPaid);
 -             $lastMonthTotalSuffix = CurrencyAccessor::getDefaultCurrency();
 -         }
 - 
 -         if ($activeTab === 'paid') {
 -             return [
 -                 EnhancedStatsOverviewWidget\EnhancedStat::make('Total To Pay', '-'),
 -                 EnhancedStatsOverviewWidget\EnhancedStat::make('Due Within 7 Days', '-'),
 -                 EnhancedStatsOverviewWidget\EnhancedStat::make('Average Payment Time', $averagePaymentTimeFormatted)
 -                     ->suffix($averagePaymentTimeSuffix),
 -                 EnhancedStatsOverviewWidget\EnhancedStat::make('Paid Last Month', $lastMonthTotal)
 -                     ->suffix($lastMonthTotalSuffix),
 -             ];
 -         }
 - 
 -         $unpaidBills = $this->getPageTableQuery()
 -             ->unpaid();
 - 
 -         $amountToPay = $unpaidBills->get()->sumMoneyInDefaultCurrency('amount_due');
 - 
 -         $amountOverdue = $unpaidBills
 -             ->clone()
 -             ->where('status', BillStatus::Overdue)
 -             ->get()
 -             ->sumMoneyInDefaultCurrency('amount_due');
 - 
 -         $amountDueWithin7Days = $unpaidBills
 -             ->clone()
 -             ->whereBetween('due_date', [company_today(), company_today()->addWeek()])
 -             ->get()
 -             ->sumMoneyInDefaultCurrency('amount_due');
 - 
 -         return [
 -             EnhancedStatsOverviewWidget\EnhancedStat::make('Total To Pay', CurrencyConverter::formatCentsToMoney($amountToPay))
 -                 ->suffix(CurrencyAccessor::getDefaultCurrency())
 -                 ->description('Includes ' . CurrencyConverter::formatCentsToMoney($amountOverdue) . ' overdue'),
 -             EnhancedStatsOverviewWidget\EnhancedStat::make('Due Within 7 Days', CurrencyConverter::formatCentsToMoney($amountDueWithin7Days))
 -                 ->suffix(CurrencyAccessor::getDefaultCurrency()),
 -             EnhancedStatsOverviewWidget\EnhancedStat::make('Average Payment Time', $averagePaymentTimeFormatted)
 -                 ->suffix($averagePaymentTimeSuffix),
 -             EnhancedStatsOverviewWidget\EnhancedStat::make('Paid Last Month', $lastMonthTotal)
 -                 ->suffix($lastMonthTotalSuffix),
 -         ];
 -     }
 - }
 
 
  |