diff --git a/app/Filament/Resources/DeviceMasterResource.php b/app/Filament/Resources/DeviceMasterResource.php new file mode 100644 index 000000000..50c65d198 --- /dev/null +++ b/app/Filament/Resources/DeviceMasterResource.php @@ -0,0 +1,131 @@ +schema([ + Section::make('') + ->schema([ + Forms\Components\Select::make('plant_id') + ->label('Plant') + ->relationship('plant', 'name') + ->required(), + Forms\Components\TextInput::make('name') + ->label('Device Name') + ->required(), + Forms\Components\TextInput::make('mac_address') + ->label('MAC Address'), + Forms\Components\TextInput::make('ip_address') + ->label('IP Address'), + Forms\Components\Hidden::make('created_by') + ->default(Filament::auth()->user()?->name), + ]) + ->columns(4), + ]); + } + + public static function table(Table $table): Table + { + return $table + ->columns([ + Tables\Columns\TextColumn::make('id') + ->label('ID') + ->numeric() + ->sortable(), + Tables\Columns\TextColumn::make('plant.name') + ->label('Plant') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('name') + ->label('Device Name') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('mac_address') + ->label('MAC Address') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('ip_address') + ->label('IP Address') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('created_at') + ->label('Created At') + ->alignCenter() + ->dateTime() + ->sortable() + ->toggleable(isToggledHiddenByDefault: true), + Tables\Columns\TextColumn::make('updated_at') + ->label('Updated At') + ->alignCenter() + ->dateTime() + ->sortable() + ->toggleable(isToggledHiddenByDefault: true), + Tables\Columns\TextColumn::make('deleted_at') + ->dateTime() + ->alignCenter() + ->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(), + ]), + ]); + } + + public static function getRelations(): array + { + return [ + // + ]; + } + + public static function getPages(): array + { + return [ + 'index' => Pages\ListDeviceMasters::route('/'), + 'create' => Pages\CreateDeviceMaster::route('/create'), + 'view' => Pages\ViewDeviceMaster::route('/{record}'), + 'edit' => Pages\EditDeviceMaster::route('/{record}/edit'), + ]; + } + + public static function getEloquentQuery(): Builder + { + return parent::getEloquentQuery() + ->withoutGlobalScopes([ + SoftDeletingScope::class, + ]); + } +} diff --git a/app/Filament/Resources/DeviceMasterResource/Pages/CreateDeviceMaster.php b/app/Filament/Resources/DeviceMasterResource/Pages/CreateDeviceMaster.php new file mode 100644 index 000000000..75d4aac60 --- /dev/null +++ b/app/Filament/Resources/DeviceMasterResource/Pages/CreateDeviceMaster.php @@ -0,0 +1,12 @@ +