Added Row Number, label, alignment on filter report and view rights for Importer and Exporter
This commit is contained in:
@@ -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,
|
||||||
|
|||||||
Reference in New Issue
Block a user