12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- <?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\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') {
- $averagePaymentTime = $this->getPageTableQuery()
- ->whereNotNull('paid_at')
- ->selectRaw('AVG(TIMESTAMPDIFF(DAY, date, paid_at)) as avg_days')
- ->groupBy('company_id')
- ->reorder()
- ->value('avg_days');
-
- $averagePaymentTimeFormatted = Number::format($averagePaymentTime ?? 0, maxPrecision: 1);
- $averagePaymentTimeSuffix = 'days';
-
- $lastMonthPaid = $this->getPageTableQuery()
- ->whereBetween('date', [
- today()->subMonth()->startOfMonth(),
- 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', [today(), 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),
- ];
- }
- }
|