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:34:50 +05:30
parent 37d6c174c3
commit ce80f8e7e5

View File

@@ -2,11 +2,13 @@
namespace App\Filament\Resources; namespace App\Filament\Resources;
use App\Filament\Exports\CompanyExporter;
use App\Filament\Imports\CompanyImporter; use App\Filament\Imports\CompanyImporter;
use App\Filament\Resources\CompanyResource\Pages; use App\Filament\Resources\CompanyResource\Pages;
use App\Filament\Resources\CompanyResource\RelationManagers\PlantsRelationManager; use App\Filament\Resources\CompanyResource\RelationManagers\PlantsRelationManager;
use App\Models\Company; use App\Models\Company;
use Filament\Actions\Imports\Importer; use Filament\Actions\Imports\Importer;
use Filament\Facades\Filament;
use Filament\Forms; use Filament\Forms;
use Filament\Forms\Form; use Filament\Forms\Form;
use Filament\Resources\Resource; use Filament\Resources\Resource;
@@ -16,6 +18,7 @@ use Filament\Tables\Table;
use Illuminate\Database\Eloquent\Builder; use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\SoftDeletingScope; use Illuminate\Database\Eloquent\SoftDeletingScope;
use Filament\Forms\Components\Section; use Filament\Forms\Components\Section;
use Filament\Tables\Actions\ExportAction;
class CompanyResource extends Resource class CompanyResource extends Resource
{ {
@@ -67,22 +70,38 @@ class CompanyResource 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(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('name') Tables\Columns\TextColumn::make('name')
->label('Company')
->alignCenter()
->sortable() ->sortable()
->searchable(), ->searchable(),
Tables\Columns\TextColumn::make('created_at') Tables\Columns\TextColumn::make('created_at')
->label('Created At')
->dateTime() ->dateTime()
->alignCenter()
->sortable(), ->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),
]) ])
@@ -102,10 +121,17 @@ class CompanyResource extends Resource
]) ])
->headerActions([ ->headerActions([
ImportAction::make() ImportAction::make()
->importer(CompanyImporter::class) ->importer(CompanyImporter::class)
->visible(function() {
return Filament::auth()->user()->can('view import company');
}),
ExportAction::make()
->exporter(CompanyExporter::class)
->visible(function() {
return Filament::auth()->user()->can('view export company');
}),
]); ]);
} }
public static function getRelations(): array public static function getRelations(): array
{ {
return [ return [