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.

TransactionExporter.php 2.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. <?php
  2. namespace App\Filament\Exports\Accounting;
  3. use App\Enums\Accounting\PaymentMethod;
  4. use App\Enums\Accounting\TransactionType;
  5. use App\Models\Accounting\Transaction;
  6. use Filament\Actions\Exports\ExportColumn;
  7. use Filament\Actions\Exports\Exporter;
  8. use Filament\Actions\Exports\Models\Export;
  9. class TransactionExporter extends Exporter
  10. {
  11. protected static ?string $model = Transaction::class;
  12. public static function getColumns(): array
  13. {
  14. return [
  15. ExportColumn::make('posted_at')
  16. ->date(),
  17. ExportColumn::make('description'),
  18. ExportColumn::make('amount')
  19. ->money(),
  20. ExportColumn::make('account.name')
  21. ->label('Category'),
  22. ExportColumn::make('bankAccount.account.name')
  23. ->label('Account'),
  24. ExportColumn::make('type')
  25. ->formatStateUsing(function (?TransactionType $state) {
  26. return $state?->getLabel();
  27. }),
  28. ExportColumn::make('payeeable.name')
  29. ->label('Payee'),
  30. ExportColumn::make('payment_method')
  31. ->formatStateUsing(function (?PaymentMethod $state) {
  32. return $state?->getLabel();
  33. }),
  34. ExportColumn::make('notes')
  35. ->enabledByDefault(false),
  36. ExportColumn::make('transactionable_type')
  37. ->label('Source type')
  38. ->formatStateUsing(static function ($state) {
  39. return class_basename($state);
  40. })
  41. ->enabledByDefault(false),
  42. ExportColumn::make('payeeable_type')
  43. ->label('Payee type')
  44. ->formatStateUsing(static function ($state) {
  45. return class_basename($state);
  46. })
  47. ->enabledByDefault(false),
  48. ExportColumn::make('is_payment')
  49. ->enabledByDefault(false),
  50. ExportColumn::make('reviewed')
  51. ->enabledByDefault(false),
  52. ];
  53. }
  54. public static function getCompletedNotificationBody(Export $export): string
  55. {
  56. $body = 'Your transaction export has completed and ' . number_format($export->successful_rows) . ' ' . str('row')->plural($export->successful_rows) . ' exported.';
  57. if ($failedRowsCount = $export->getFailedRowsCount()) {
  58. $body .= ' ' . number_format($failedRowsCount) . ' ' . str('row')->plural($failedRowsCount) . ' failed to export.';
  59. }
  60. return $body;
  61. }
  62. }