1
0
forked from poc/pds

Added Row Number, label, alignment on filter report and view rights for Importer and Exporter

This commit is contained in:
dhanabalan
2025-05-31 10:38:32 +05:30
parent 58f98c7632
commit 2bd69214d6

View File

@@ -7,6 +7,7 @@ use App\Filament\Imports\ItemImporter;
use App\Filament\Resources\ItemResource\Pages; use App\Filament\Resources\ItemResource\Pages;
use App\Models\Item; use App\Models\Item;
use Filament\Actions\Exports\Enums\ExportFormat; use Filament\Actions\Exports\Enums\ExportFormat;
use Filament\Facades\Filament;
use Filament\Forms; use Filament\Forms;
use Filament\Forms\Components\TextInput; use Filament\Forms\Components\TextInput;
use Filament\Forms\Form; use Filament\Forms\Form;
@@ -159,38 +160,58 @@ class ItemResource extends Resource
{ {
return $table return $table
->columns([ ->columns([
Tables\Columns\TextColumn::make('id') // Tables\Columns\TextColumn::make('id')
->label('ID') // ->label('ID')
->numeric() // ->numeric()
->sortable(), // ->sortable(),
Tables\Columns\TextColumn::make('No.')
->label('No.')
// ->getStateUsing(fn ($record, $livewire, $column, $rowLoop) => $rowLoop->iteration),
->getStateUsing(function ($record, $livewire, $column, $rowLoop) {
$paginator = $livewire->getTableRecords();
$perPage = method_exists($paginator, 'perPage') ? $paginator->perPage() : 10;
$currentPage = method_exists($paginator, 'currentPage') ? $paginator->currentPage() : 1;
return ($currentPage - 1) * $perPage + $rowLoop->iteration;
}),
Tables\Columns\TextColumn::make('code') Tables\Columns\TextColumn::make('code')
->label('Item Code')
->alignCenter()
->sortable() ->sortable()
->searchable(), ->searchable(),
Tables\Columns\TextColumn::make('description') Tables\Columns\TextColumn::make('description')
->label('Description')
->alignCenter()
->sortable() ->sortable()
->searchable(), ->searchable(),
Tables\Columns\TextColumn::make('hourly_quantity') Tables\Columns\TextColumn::make('hourly_quantity')
->label('Hourly Quantity') ->label('Hourly Quantity')
->alignCenter()
->numeric() ->numeric()
->alignCenter()
->sortable(), ->sortable(),
Tables\Columns\TextColumn::make('uom') Tables\Columns\TextColumn::make('uom')
->label('Unit of Measure') ->label('Unit of Measure')
->alignCenter() ->alignCenter()
->sortable(), ->sortable(),
Tables\Columns\TextColumn::make('plant.name') Tables\Columns\TextColumn::make('plant.name')
->label('Plant')
->alignCenter()
->sortable() ->sortable()
->searchable(), ->searchable(),
Tables\Columns\TextColumn::make('created_at') Tables\Columns\TextColumn::make('created_at')
->label('Created At')
->dateTime() ->dateTime()
->sortable() ->alignCenter()
->toggleable(isToggledHiddenByDefault: true), ->sortable(),
Tables\Columns\TextColumn::make('updated_at') Tables\Columns\TextColumn::make('updated_at')
->label('Updated At')
->dateTime() ->dateTime()
->alignCenter()
->sortable() ->sortable()
->toggleable(isToggledHiddenByDefault: true), ->toggleable(isToggledHiddenByDefault: true),
Tables\Columns\TextColumn::make('deleted_at') Tables\Columns\TextColumn::make('deleted_at')
->label('Deleted At')
->dateTime() ->dateTime()
->alignCenter()
->sortable() ->sortable()
->toggleable(isToggledHiddenByDefault: true), ->toggleable(isToggledHiddenByDefault: true),
]) ])
@@ -210,13 +231,19 @@ class ItemResource extends Resource
]) ])
->headerActions([ ->headerActions([
ImportAction::make() ImportAction::make()
->importer(ItemImporter::class), ->importer(ItemImporter::class)
->visible(function() {
return Filament::auth()->user()->can('view import item');
}),
// ->maxRows(100000), // ->maxRows(100000),
ExportAction::make() ExportAction::make()
// ->columnMapping(true) // ->columnMapping(true)
// ->label('Export') // ->label('Export')
// ->fileName("items" . date('Y-m-d') . ".xlsx") // ->fileName("Items Report " . date('Y-m-d H:i:s'))
->exporter(ItemExporter::class), ->exporter(ItemExporter::class)
->visible(function() {
return Filament::auth()->user()->can('view export item');
}),
// ->formats([ // ->formats([
// ExportFormat::Xlsx, // ExportFormat::Xlsx,
// ExportFormat::Csv, // ExportFormat::Csv,