diff --git a/app/Filament/Resources/CustomerPoMasterResource.php b/app/Filament/Resources/CustomerPoMasterResource.php new file mode 100644 index 0000000..8b3de0c --- /dev/null +++ b/app/Filament/Resources/CustomerPoMasterResource.php @@ -0,0 +1,176 @@ +schema([ + Forms\Components\Select::make('plant_id') + ->label('Plant') + ->reactive() + ->relationship('plant', 'name') + ->options(function (callable $get) { + $userHas = Filament::auth()->user()->plant_id; + + return ($userHas && strlen($userHas) > 0) ? Plant::where('id', $userHas)->pluck('name', 'id')->toArray() : Plant::orderBy('code')->pluck('name', 'id')->toArray(); + }) + ->required(), + Forms\Components\Select::make('item_id') + ->label('Item Code') + ->reactive() + ->searchable() + ->options(function (callable $get) { + $plantId = $get('plant_id'); + if (empty($plantId)) { + return []; + } + + return Item::where('plant_id', $plantId)->pluck('code', 'id'); + }) + ->required(), + Forms\Components\TextInput::make('customer_po') + ->label('Customer PO'), + Forms\Components\TextInput::make('customer_name') + ->label('Customer Name'), + Forms\Components\TextInput::make('quantity') + ->label('Quantity'), + Forms\Components\Hidden::make('created_by') + ->label('Created By') + ->default(Filament::auth()->user()?->name), + Forms\Components\Hidden::make('updated_by') + ->default(Filament::auth()->user()?->name), + ]); + } + + public static function table(Table $table): Table + { + return $table + ->columns([ + 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('plant.name') + ->label('Plant') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('item.code') + ->label('Item Code') + ->searchable() + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('customer_po') + ->label('Customer PO') + ->searchable() + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('customer_name') + ->label('Customer Name') + ->searchable() + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('quantity') + ->label('Quantity') + ->searchable() + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('created_at') + ->dateTime() + ->sortable() + ->toggleable(isToggledHiddenByDefault: true), + Tables\Columns\TextColumn::make('updated_at') + ->dateTime() + ->sortable() + ->toggleable(isToggledHiddenByDefault: true), + Tables\Columns\TextColumn::make('deleted_at') + ->dateTime() + ->sortable() + ->toggleable(isToggledHiddenByDefault: true), + ]) + ->filters([ + Tables\Filters\TrashedFilter::make(), + ]) + ->actions([ + Tables\Actions\ViewAction::make(), + Tables\Actions\EditAction::make(), + ]) + ->bulkActions([ + Tables\Actions\BulkActionGroup::make([ + Tables\Actions\DeleteBulkAction::make(), + Tables\Actions\ForceDeleteBulkAction::make(), + Tables\Actions\RestoreBulkAction::make(), + ]), + ]) + ->headerActions([ + ImportAction::make() + ->label('Import Customer PO') + ->color('warning') + ->importer(CustomerPoMasterImporter::class) + ->visible(function () { + return Filament::auth()->user()->can('view import customer po master'); + }), + ExportAction::make() + ->label('Export Customer PO') + ->color('warning') + ->exporter(CustomerPoMasterExporter::class) + ->visible(function () { + return Filament::auth()->user()->can('view export customer po master'); + }), + ]); + } + + public static function getRelations(): array + { + return [ + // + ]; + } + + public static function getPages(): array + { + return [ + 'index' => Pages\ListCustomerPoMasters::route('/'), + 'create' => Pages\CreateCustomerPoMaster::route('/create'), + 'view' => Pages\ViewCustomerPoMaster::route('/{record}'), + 'edit' => Pages\EditCustomerPoMaster::route('/{record}/edit'), + ]; + } + + public static function getEloquentQuery(): Builder + { + return parent::getEloquentQuery() + ->withoutGlobalScopes([ + SoftDeletingScope::class, + ]); + } +} diff --git a/app/Filament/Resources/CustomerPoMasterResource/Pages/CreateCustomerPoMaster.php b/app/Filament/Resources/CustomerPoMasterResource/Pages/CreateCustomerPoMaster.php new file mode 100644 index 0000000..e52dcae --- /dev/null +++ b/app/Filament/Resources/CustomerPoMasterResource/Pages/CreateCustomerPoMaster.php @@ -0,0 +1,12 @@ +belongsTo(Plant::class); + } + + public function item(): BelongsTo + { + return $this->belongsTo(Item::class); + } +} diff --git a/app/Policies/CustomerPoMasterPolicy.php b/app/Policies/CustomerPoMasterPolicy.php new file mode 100644 index 0000000..e99c17f --- /dev/null +++ b/app/Policies/CustomerPoMasterPolicy.php @@ -0,0 +1,106 @@ +checkPermissionTo('view-any CustomerPoMaster'); + } + + /** + * Determine whether the user can view the model. + */ + public function view(User $user, CustomerPoMaster $customerpomaster): bool + { + return $user->checkPermissionTo('view CustomerPoMaster'); + } + + /** + * Determine whether the user can create models. + */ + public function create(User $user): bool + { + return $user->checkPermissionTo('create CustomerPoMaster'); + } + + /** + * Determine whether the user can update the model. + */ + public function update(User $user, CustomerPoMaster $customerpomaster): bool + { + return $user->checkPermissionTo('update CustomerPoMaster'); + } + + /** + * Determine whether the user can delete the model. + */ + public function delete(User $user, CustomerPoMaster $customerpomaster): bool + { + return $user->checkPermissionTo('delete CustomerPoMaster'); + } + + /** + * Determine whether the user can delete any models. + */ + public function deleteAny(User $user): bool + { + return $user->checkPermissionTo('delete-any CustomerPoMaster'); + } + + /** + * Determine whether the user can restore the model. + */ + public function restore(User $user, CustomerPoMaster $customerpomaster): bool + { + return $user->checkPermissionTo('restore CustomerPoMaster'); + } + + /** + * Determine whether the user can restore any models. + */ + public function restoreAny(User $user): bool + { + return $user->checkPermissionTo('restore-any CustomerPoMaster'); + } + + /** + * Determine whether the user can replicate the model. + */ + public function replicate(User $user, CustomerPoMaster $customerpomaster): bool + { + return $user->checkPermissionTo('replicate CustomerPoMaster'); + } + + /** + * Determine whether the user can reorder the models. + */ + public function reorder(User $user): bool + { + return $user->checkPermissionTo('reorder CustomerPoMaster'); + } + + /** + * Determine whether the user can permanently delete the model. + */ + public function forceDelete(User $user, CustomerPoMaster $customerpomaster): bool + { + return $user->checkPermissionTo('force-delete CustomerPoMaster'); + } + + /** + * Determine whether the user can permanently delete any models. + */ + public function forceDeleteAny(User $user): bool + { + return $user->checkPermissionTo('force-delete-any CustomerPoMaster'); + } +} diff --git a/database/migrations/2026_02_10_161202_create_customer_po_masters_table.php b/database/migrations/2026_02_10_161202_create_customer_po_masters_table.php new file mode 100644 index 0000000..fe139d0 --- /dev/null +++ b/database/migrations/2026_02_10_161202_create_customer_po_masters_table.php @@ -0,0 +1,45 @@ +