1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- <?php
-
- namespace App\Filament\Company\Resources\Purchases\VendorResource\Widgets;
-
- use App\Enums\Accounting\BillStatus;
- use App\Filament\Widgets\EnhancedStatsOverviewWidget;
- use App\Utilities\Currency\CurrencyAccessor;
- use App\Utilities\Currency\CurrencyConverter;
- use Illuminate\Database\Eloquent\Model;
- use Illuminate\Support\Facades\DB;
- use Illuminate\Support\Number;
-
- class BillOverview extends EnhancedStatsOverviewWidget
- {
- public ?Model $record = null;
-
- protected function getStats(): array
- {
- $unpaidBills = $this->record->bills()
- ->whereIn('status', [BillStatus::Open, BillStatus::Partial, BillStatus::Overdue]);
-
- $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');
-
- $driver = DB::getDriverName();
-
- $query = $this->record->bills()
- ->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);
-
- $lastMonthTotal = $this->record->bills()
- ->where('status', BillStatus::Paid)
- ->whereBetween('date', [
- company_today()->subMonth()->startOfMonth(),
- company_today()->subMonth()->endOfMonth(),
- ])
- ->get()
- ->sumMoneyInDefaultCurrency('amount_paid');
-
- 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('days'),
-
- EnhancedStatsOverviewWidget\EnhancedStat::make('Paid Last Month', CurrencyConverter::formatCentsToMoney($lastMonthTotal))
- ->suffix(CurrencyAccessor::getDefaultCurrency()),
- ];
- }
- }
|