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

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