tenant admin startseite schicker gestaltet und super-admin und tenant admin (filament) aufgesplittet.

Es gibt nun task collections und vordefinierte tasks für alle. Onboarding verfeinert und webseite-carousel gefixt (logging später entfernen!)
This commit is contained in:
Codex Agent
2025-10-14 15:17:52 +02:00
parent 64a5411fb9
commit 1a4bdb1fe1
92 changed files with 6027 additions and 515 deletions

View File

@@ -4,36 +4,30 @@ namespace App\Filament\Resources;
use App\Filament\Resources\UserResource\Pages;
use App\Models\User;
use Filament\Schemas\Schema;
use Filament\Forms\Form;
use Filament\Forms\Components\Section;
use Filament\Forms\Components\TextInput;
use Filament\Forms\Components\Textarea;
use Filament\Icons\Icon;
use Filament\Resources\Resource;
use Filament\Tables;
use BackedEnum;
use Filament\Actions\ActionGroup;
use Filament\Actions\BulkActionGroup;
use Filament\Actions\DeleteBulkAction;
use Filament\Actions\EditAction;
use Filament\Actions\ViewAction;
use Filament\Forms\Components\Section;
use Filament\Forms\Components\Textarea;
use Filament\Forms\Components\TextInput;
use Filament\Forms\Form;
use Filament\Resources\Resource;
use Filament\Schemas\Schema;
use Filament\Tables;
use Filament\Tables\Columns\IconColumn;
use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Table;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\SoftDeletingScope;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Facades\Request;
use BackedEnum;
use UnitEnum;
class UserResource extends Resource
{
protected static ?string $model = User::class;
protected static BackedEnum|string|null $navigationIcon = 'heroicon-o-user-circle';
protected static ?string $navigationLabel = 'Users';
protected static ?string $slug = 'users';
public static function form(Schema $form): Schema
@@ -76,8 +70,7 @@ class UserResource extends Resource
->required(fn (string $operation): bool => $operation === 'create')
->dehydrated(false),
])
->columns(1)
->visible(fn (): bool => Auth::user()?->id === Request::route('record')),
->columns(1),
]);
}
@@ -85,22 +78,18 @@ class UserResource extends Resource
{
return $table
->columns([
TextColumn::make('fullName')
->searchable(),
TextColumn::make('email')
->searchable(),
TextColumn::make('username')
->searchable(),
TextColumn::make('phone'),
TextColumn::make('fullName')->sortable()->searchable(),
TextColumn::make('email')->searchable(),
TextColumn::make('username')->searchable(),
TextColumn::make('tenant.name')
->label('Tenant'),
TextColumn::make('email_verified_at')
->dateTime()
->sortable(),
])
->filters([
//
->label(__('admin.common.tenant'))
->badge(),
TextColumn::make('phone'),
IconColumn::make('email_verified_at')
->label(__('admin.users.fields.verified'))
->boolean(),
])
->filters([])
->actions([
ActionGroup::make([
ViewAction::make(),
@@ -111,23 +100,20 @@ class UserResource extends Resource
BulkActionGroup::make([
DeleteBulkAction::make(),
]),
])
->modifyQueryUsing(fn (Builder $query) => $query->where('tenant_id', Auth::user()->tenant_id));
]);
}
public static function getRelations(): array
{
return [
//
];
return [];
}
public static function getPages(): array
{
return [
'index' => Pages\ListUsers::route('/'),
'create' => Pages\CreateUser::route('/create'),
'edit' => Pages\EditUser::route('/{record}/edit'),
];
}
}