Files
pds/app/Filament/Exports/GuardPatrolEntryExporter.php
dhanabalan 3c4a09f571
All checks were successful
Scan for leaked secrets using Kingfisher / kingfisher-secrets-scan (push) Successful in 9s
Added view rights against plant on import and export
2026-01-13 16:02:45 +05:30

66 lines
2.3 KiB
PHP

<?php
namespace App\Filament\Exports;
use App\Models\GuardPatrolEntry;
use Filament\Actions\Exports\ExportColumn;
use Filament\Actions\Exports\Exporter;
use Filament\Actions\Exports\Models\Export;
class GuardPatrolEntryExporter extends Exporter
{
protected static ?string $model = GuardPatrolEntry::class;
public static function getColumns(): array
{
static $rowNumber = 0;
return [
ExportColumn::make('no')
->label('NO')
->state(function ($record) use (&$rowNumber) {
// Increment and return the row number
return ++$rowNumber;
}),
// ExportColumn::make('id')
// ->label('ID'),
ExportColumn::make('plant.code')
->label('PLANT CODE'),
ExportColumn::make('guardNames.name')
->label('GUARD NAME'),
ExportColumn::make('checkPointNames.name')
->label('CHECK POINT NAME'),
// ExportColumn::make('reader_code')
// ->label('READER CODE'),
ExportColumn::make('patrol_time')
->label('PATROL TIME'),
ExportColumn::make('created_at')
->enabledByDefault(false)
->label('CREATED AT'),
ExportColumn::make('created_by')
->enabledByDefault(false)
->label('CREATED BY'),
ExportColumn::make('updated_at')
->enabledByDefault(false)
->label('UPDATED AT'),
ExportColumn::make('Updated_by')
->enabledByDefault(false)
->label('UPDATED BY'),
ExportColumn::make('deleted_at')
->enabledByDefault(false)
->label('DELETED AT'),
];
}
public static function getCompletedNotificationBody(Export $export): string
{
$body = 'Your guard patrol entry 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;
}
}