You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

InvoiceExporter.php 2.5KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. <?php
  2. namespace App\Filament\Exports\Accounting;
  3. use App\Enums\Accounting\InvoiceStatus;
  4. use App\Models\Accounting\Invoice;
  5. use Filament\Actions\Exports\ExportColumn;
  6. use Filament\Actions\Exports\Exporter;
  7. use Filament\Actions\Exports\Models\Export;
  8. class InvoiceExporter extends Exporter
  9. {
  10. protected static ?string $model = Invoice::class;
  11. public static function getColumns(): array
  12. {
  13. return [
  14. ExportColumn::make('invoice_number'),
  15. ExportColumn::make('date')
  16. ->date(),
  17. ExportColumn::make('due_date')
  18. ->date(),
  19. ExportColumn::make('client.name'),
  20. ExportColumn::make('status')
  21. ->formatStateUsing(function (?InvoiceStatus $state) {
  22. return $state?->getLabel();
  23. }),
  24. ExportColumn::make('total')
  25. ->money(),
  26. ExportColumn::make('amount_paid')
  27. ->money(),
  28. ExportColumn::make('amount_due')
  29. ->money(),
  30. ExportColumn::make('subtotal')
  31. ->money(),
  32. ExportColumn::make('tax_total')
  33. ->money(),
  34. ExportColumn::make('discount_total')
  35. ->money(),
  36. ExportColumn::make('discount_rate'),
  37. ExportColumn::make('currency_code'),
  38. ExportColumn::make('order_number'),
  39. ExportColumn::make('approved_at')
  40. ->dateTime(),
  41. ExportColumn::make('paid_at')
  42. ->dateTime(),
  43. ExportColumn::make('last_sent_at')
  44. ->dateTime(),
  45. ExportColumn::make('estimate.estimate_number')
  46. ->label('Estimate number')
  47. ->enabledByDefault(false),
  48. ExportColumn::make('recurringInvoice.order_number')
  49. ->label('Recurring invoice number')
  50. ->enabledByDefault(false),
  51. ExportColumn::make('discount_method')
  52. ->enabledByDefault(false),
  53. ];
  54. }
  55. public static function getCompletedNotificationBody(Export $export): string
  56. {
  57. $body = 'Your invoice export has completed and ' . number_format($export->successful_rows) . ' ' . str('row')->plural($export->successful_rows) . ' exported.';
  58. if ($failedRowsCount = $export->getFailedRowsCount()) {
  59. $body .= ' ' . number_format($failedRowsCount) . ' ' . str('row')->plural($failedRowsCount) . ' failed to export.';
  60. }
  61. return $body;
  62. }
  63. }