feat: update various Filament resources and models for enhanced functionality

This commit is contained in:
Remco
2026-01-24 21:24:49 +01:00
parent 9378fc16e5
commit 71a4c6677e
14 changed files with 159 additions and 25 deletions
@@ -7,7 +7,7 @@ use App\Filament\Resources\Atom\Teams\Pages\EditTeam;
use App\Filament\Resources\Atom\Teams\Pages\ListTeams;
use App\Filament\Tables\Columns\HabboBadgeColumn;
use App\Filament\Traits\TranslatableResource;
use App\Models\Community\Staff\WebsiteTeam;
use App\Models\Community\Staff\WebsiteStaffTeam;
use Filament\Actions\DeleteBulkAction;
use Filament\Actions\EditAction;
use Filament\Forms\Components\TextInput;
@@ -24,7 +24,7 @@ class TeamResource extends Resource
{
use TranslatableResource;
protected static ?string $model = WebsiteTeam::class;
protected static ?string $model = WebsiteStaffTeam::class;
protected static string|\BackedEnum|null $navigationIcon = 'heroicon-o-user-group';
@@ -82,7 +82,7 @@ class TeamResource extends Resource
IconColumn::make('hidden_rank')
->label(__('filament::resources.columns.is_hidden'))
->icon(fn (\App\Models\Community\Staff\WebsiteTeam $record) => $record->hidden_rank ? 'heroicon-o-check-circle' : 'heroicon-o-x-circle')
->icon(fn (\App\Models\Community\Staff\WebsiteStaffTeam $record) => $record->hidden_rank ? 'heroicon-o-check-circle' : 'heroicon-o-x-circle')
->colors([
'danger' => false,
'success' => true,
@@ -1,4 +1,4 @@
<?php
<?php
namespace App\Filament\Resources\Hotel\CatalogEditors;
@@ -1,4 +1,4 @@
<?php
<?php
namespace App\Filament\Resources\Hotel\CatalogEditors\Pages;
@@ -1,4 +1,4 @@
<?php
<?php
namespace App\Filament\Resources\Hotel\CatalogEditors\Pages;
@@ -1,4 +1,4 @@
<?php
<?php
namespace App\Filament\Resources\Hotel\CatalogEditors\Pages;
@@ -1,4 +1,4 @@
<?php
<?php
namespace App\Filament\Resources\Hotel\CatalogEditors\Pages;
@@ -1,4 +1,4 @@
<?php
<?php
namespace App\Filament\Resources\Hotel\CatalogEditors\Pages;
@@ -0,0 +1,121 @@
<?php
namespace App\Filament\Resources\Hotel\OpenPositions;
use App\Filament\Resources\Hotel\OpenPositions\Pages\CreateOpenPosition;
use App\Filament\Resources\Hotel\OpenPositions\Pages\EditOpenPosition;
use App\Filament\Resources\Hotel\OpenPositions\Pages\ListOpenPositions;
use App\Models\Community\Staff\WebsiteOpenPosition;
use Filament\Actions\DeleteAction;
use Filament\Actions\DeleteBulkAction;
use Filament\Actions\EditAction;
use Filament\Forms\Components\DateTimePicker;
use Filament\Forms\Components\Select;
use Filament\Forms\Components\Textarea;
use Filament\Notifications\Notification;
use Filament\Resources\Resource;
use Filament\Schemas\Schema;
use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Table;
class OpenPositionResource extends Resource
{
protected static ?string $model = WebsiteOpenPosition::class;
protected static string|\BackedEnum|null $navigationIcon = 'heroicon-o-briefcase';
protected static string|\UnitEnum|null $navigationGroup = 'Hotel';
#[\Override]
public static function form(Schema $schema): Schema
{
return $schema
->components([
Select::make('permission_id')
->label('Rank')
->relationship('permission', 'rank_name')
->required()
->searchable()
->preload()
->unique(ignoreRecord: true)
->placeholder('Select a rank'),
Textarea::make('description')
->label('Position Description')
->required()
->maxLength(65535)
->columnSpanFull(),
DateTimePicker::make('apply_from')
->label('Application Start Date')
->nullable(),
DateTimePicker::make('apply_to')
->label('Application End Date')
->nullable(),
]);
}
#[\Override]
public static function table(Table $table): Table
{
return $table
->columns([
TextColumn::make('permission.rank_name')
->label('Rank')
->sortable()
->searchable(),
TextColumn::make('description')
->label('Description')
->limit(50)
->searchable(),
TextColumn::make('apply_from')
->label('Apply From')
->dateTime()
->sortable(),
TextColumn::make('apply_to')
->label('Apply To')
->dateTime()
->sortable(),
TextColumn::make('created_at')
->label('Created')
->dateTime()
->sortable(),
])
->filters([
])
->recordActions([
EditAction::make(),
DeleteAction::make()
->requiresConfirmation()
->modalHeading('Delete Open Position')
->modalDescription('This will also delete all related staff applications. Are you sure?')
->modalSubmitActionLabel('Yes, delete')
->successNotification(
Notification::make()
->success()
->title('Open Position Deleted')
->body('The open position and its related staff applications have been deleted successfully.'),
),
])
->toolbarActions([
DeleteBulkAction::make()
->requiresConfirmation()
->modalHeading('Delete Open Positions')
->modalDescription('This will also delete all related staff applications for the selected positions. Are you sure?')
->modalSubmitActionLabel('Yes, delete')
->successNotification(
Notification::make()
->success()
->title('Open Positions Deleted')
->body('The selected open positions and their related staff applications have been deleted successfully.'),
),
]);
}
public static function getPages(): array
{
return [
'index' => ListOpenPositions::route('/'),
'create' => CreateOpenPosition::route('/create'),
'edit' => EditOpenPosition::route('/{record}/edit'),
];
}
}
@@ -92,8 +92,8 @@ class OpenPositionResource extends Resource
Notification::make()
->success()
->title('Open Position Deleted')
->body('The open position and its related staff applications have been deleted successfully.'),
),
->body('The open position and its related staff applications have been deleted successfully.')
)
])
->toolbarActions([
DeleteBulkAction::make()
@@ -105,8 +105,8 @@ class OpenPositionResource extends Resource
Notification::make()
->success()
->title('Open Positions Deleted')
->body('The selected open positions and their related staff applications have been deleted successfully.'),
),
->body('The selected open positions and their related staff applications have been deleted successfully.')
)
]);
}
@@ -118,4 +118,4 @@ class OpenPositionResource extends Resource
'edit' => EditOpenPosition::route('/{record}/edit'),
];
}
}
}
@@ -12,7 +12,7 @@ use App\Filament\Resources\User\Users\RelationManagers\ChatLogRelationManager;
use App\Filament\Resources\User\Users\RelationManagers\SettingsRelationManager;
use App\Filament\Tables\Columns\UserAvatarColumn;
use App\Filament\Traits\TranslatableResource;
use App\Models\Community\Staff\WebsiteTeam;
use App\Models\Community\Staff\WebsiteStaffTeam;
use App\Models\Game\Permission;
use App\Models\User;
use Filament\Actions\EditAction;
@@ -31,6 +31,7 @@ use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Table;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Hash;
class UserResource extends Resource
@@ -118,7 +119,7 @@ class UserResource extends Resource
Select::make('team_id')
->native(false)
->label(__('filament::resources.inputs.team_id'))
->options(fn () => WebsiteTeam::query()->pluck('rank_name', 'id')->all())
->options(fn () => WebsiteStaffTeam::query()->pluck('rank_name', 'id')->all())
->columnSpanFull(),
])->columns(['sm' => 2]),
@@ -190,14 +191,14 @@ class UserResource extends Resource
Select::make('rank')
->native(false)
->label(__('filament::resources.inputs.rank'))
->options(fn () => (function (): array {
$authUser = auth()->user();
->options(function (): array {
$authUser = Auth::user();
$rank = $authUser instanceof User ? $authUser->rank : 0;
return Permission::query()
->where('id', '<', $rank)
->pluck('rank_name', 'id')
->all();
})()),
}),
Toggle::make('is_hidden')
->label(__('filament::resources.inputs.is_hidden'))
@@ -6,7 +6,7 @@ use App\Models\User;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Relations\HasMany;
class WebsiteTeam extends Model
class WebsiteStaffTeam extends Model
{
protected $guarded = [];
+3 -3
View File
@@ -5,7 +5,7 @@ namespace App\Models;
use App\Models\Articles\WebsiteArticle;
use App\Models\Articles\WebsiteArticleComment;
use App\Models\Community\Staff\WebsiteStaffApplications;
use App\Models\Community\Staff\WebsiteTeam;
use App\Models\Community\Staff\WebsiteStaffTeam;
use App\Models\Game\Furniture\Item;
use App\Models\Game\Permission;
use App\Models\Game\Player\MessengerFriendship;
@@ -239,11 +239,11 @@ class User extends Authenticatable implements FilamentUser, HasName
}
/**
* @return BelongsTo<WebsiteTeam, $this>
* @return BelongsTo<WebsiteStaffTeam, $this>
*/
public function team(): BelongsTo
{
return $this->belongsTo(WebsiteTeam::class, 'team_id');
return $this->belongsTo(WebsiteStaffTeam::class, 'team_id');
}
/**