| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104 | <?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');
            } 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),
        ];
    }
}
 |