| 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;
    }
}
 |