feat(transmittal): replace PDF export with Excel export and add logo

- Remove PDF export functionality from TransmittalResource and CreateTransmittal page
- Add new TransmittalExcelExport class for formatted Excel exports with company logo
- Update export jobs to generate unique filenames per user and refresh user data
- Replace PDF export action with Excel export in table actions
- Comment out logo in PDF view template as it's no longer used
- Fix import alias for Excel export action in GeneralLedger
This commit is contained in:
Jp
2026-02-19 03:11:17 +08:00
parent b95f23f223
commit 6eeedbeeb0
7 changed files with 176 additions and 78 deletions

View File

@@ -4,6 +4,7 @@ namespace App\Jobs;
use Filament\Actions\Action;
use App\Models\Transmittal;
use App\Models\User;
use Barryvdh\DomPDF\Facade\Pdf;
use Filament\Notifications\Notification;
use Illuminate\Contracts\Queue\ShouldQueue;
@@ -20,12 +21,14 @@ class ExportCompleteJob implements ShouldQueue
use Queueable;
use SerializesModels;
public function __construct(private $user, private array $ids)
public function __construct(private User $user, private array $ids)
{
}
public function handle(): void
{
$this->user->refresh();
$transmittals = Transmittal::query()
->with(['client', 'branch', 'files.notes', 'files.remarks'])
->whereIn('id', $this->ids)
@@ -35,15 +38,17 @@ class ExportCompleteJob implements ShouldQueue
'transmittals' => $transmittals,
]);
Storage::disk('public')->put('transmittal-export.pdf', $pdf->output());
$filename = 'transmittal-export-'.$this->user->id.'-'.now()->format('YmdHis').'.pdf';
Storage::disk('public')->put($filename, $pdf->output());
Notification::make()
->success()
->title('Export Completed')
->actions([
Action::make('download_transmittal-export.pdf')
Action::make('download_transmittal_export')
->label('Download PDF File')
->url(Storage::url('transmittal-export.pdf'), true)
->url(Storage::url($filename), true)
->markAsRead(),
])
->sendToDatabase($this->user);

View File

@@ -4,6 +4,7 @@ namespace App\Jobs;
use Filament\Actions\Action;
use App\Models\Transmittal;
use App\Models\User;
use Barryvdh\DomPDF\Facade\Pdf;
use Filament\Notifications\Notification;
use Illuminate\Contracts\Queue\ShouldQueue;
@@ -20,7 +21,7 @@ class TransmittalPDFExportJob implements ShouldQueue
/**
* Create a new job instance.
*/
public function __construct(private $user, private array $ids)
public function __construct(private User $user, private array $ids)
{}
/**
@@ -28,6 +29,8 @@ class TransmittalPDFExportJob implements ShouldQueue
*/
public function handle(): void
{
$this->user->refresh();
$transmittals = Transmittal::query()
->with(['client', 'branch', 'files.notes', 'files.remarks'])
->whereIn('id', $this->ids)
@@ -37,15 +40,17 @@ class TransmittalPDFExportJob implements ShouldQueue
'transmittals' => $transmittals,
]);
Storage::disk('public')->put('transmittal-export.pdf', $pdf->output());
$filename = 'transmittal-export-'.$this->user->id.'-'.now()->format('YmdHis').'.pdf';
Storage::disk('public')->put($filename, $pdf->output());
Notification::make()
->success()
->title('Export Completed')
->actions([
Action::make('download_transmittal-export.pdf')
Action::make('download_transmittal_export')
->label('Download PDF File')
->url(Storage::url('transmittal-export.pdf'), true)
->url(Storage::url($filename), true)
->markAsRead(),
])
->sendToDatabase($this->user);