12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 |
- <?php
-
- namespace App\Filament\Exports\Common;
-
- use App\Enums\Accounting\BillStatus;
- use App\Models\Common\Vendor;
- use Filament\Actions\Exports\ExportColumn;
- use Filament\Actions\Exports\Exporter;
- use Filament\Actions\Exports\Models\Export;
-
- class VendorExporter extends Exporter
- {
- protected static ?string $model = Vendor::class;
-
- public static function getColumns(): array
- {
- return [
- ExportColumn::make('name'),
- ExportColumn::make('type')
- ->enum(),
- ExportColumn::make('contractor_type')
- ->enum(),
- ExportColumn::make('account_number'),
- ExportColumn::make('contact.full_name')
- ->label('Primary contact'),
- ExportColumn::make('contact.email')
- ->label('Email'),
- ExportColumn::make('contact.first_available_phone')
- ->label('Phone'),
- ExportColumn::make('currency_code'),
- ExportColumn::make('balance')
- ->state(function (Vendor $record) {
- return $record->bills()
- ->unpaid()
- ->get()
- ->sumMoneyInDefaultCurrency('amount_due');
- })
- ->money(),
- ExportColumn::make('overdue_amount')
- ->state(function (Vendor $record) {
- return $record->bills()
- ->where('status', BillStatus::Overdue)
- ->get()
- ->sumMoneyInDefaultCurrency('amount_due');
- })
- ->money(),
- ExportColumn::make('address.address_string')
- ->label('Address')
- ->enabledByDefault(false),
- ExportColumn::make('address.address_line_1')
- ->label('Address line 1'),
- ExportColumn::make('address.address_line_2')
- ->label('Address line 2'),
- ExportColumn::make('address.city')
- ->label('City'),
- ExportColumn::make('address.state.name')
- ->label('State'),
- ExportColumn::make('address.postal_code')
- ->label('Postal code'),
- ExportColumn::make('address.country.name')
- ->label('Country'),
- ExportColumn::make('ssn')
- ->label('SSN')
- ->enabledByDefault(false),
- ExportColumn::make('ein')
- ->label('EIN')
- ->enabledByDefault(false),
- ExportColumn::make('website')
- ->enabledByDefault(false),
- ExportColumn::make('notes')
- ->enabledByDefault(false),
- ];
- }
-
- public static function getCompletedNotificationBody(Export $export): string
- {
- $body = 'Your vendor export has completed and ' . number_format($export->successful_rows) . ' ' . str('row')->plural($export->successful_rows) . ' exported.';
-
- if ($failedRowsCount = $export->getFailedRowsCount()) {
- $body .= ' ' . number_format($failedRowsCount) . ' ' . str('row')->plural($failedRowsCount) . ' failed to export.';
- }
-
- return $body;
- }
- }
|