wip
This commit is contained in:
@@ -2,6 +2,7 @@
|
||||
|
||||
namespace App\Filament\Resources\Users\Schemas;
|
||||
|
||||
use App\Modules\PhoneNumberVerification\Rules\PhoneNumberVerificationRule;
|
||||
use Filament\Forms\Components\Select;
|
||||
use Filament\Forms\Components\TextInput;
|
||||
use Filament\Schemas\Schema;
|
||||
@@ -13,50 +14,58 @@ class UserForm
|
||||
public static function configure(Schema $schema): Schema
|
||||
{
|
||||
return $schema
|
||||
->columns(2)
|
||||
->columns(6)
|
||||
->components([
|
||||
TextInput::make('first_name')
|
||||
->label(__('First name'))
|
||||
->required(),
|
||||
|
||||
TextInput::make('last_name')
|
||||
->label(__('Last name'))
|
||||
->required(),
|
||||
TextInput::make('name')
|
||||
->label(__('Full Name'))
|
||||
->required()
|
||||
->columnSpan(3),
|
||||
|
||||
TextInput::make('username')
|
||||
->label(__('Username'))
|
||||
->required()
|
||||
->unique(ignoreRecord: true),
|
||||
->unique(ignoreRecord: true)
|
||||
->columnSpan(3),
|
||||
|
||||
TextInput::make('phone')
|
||||
->label(__('Phone number'))
|
||||
->unique(ignoreRecord: true),
|
||||
->label(__('Phone'))
|
||||
->unique(ignoreRecord: true)
|
||||
->mask('99 99 99 99')
|
||||
->prefix('+993')
|
||||
->rules([
|
||||
new PhoneNumberVerificationRule,
|
||||
])
|
||||
->columnSpan(2),
|
||||
|
||||
TextInput::make('email')
|
||||
->label(__('Email'))
|
||||
->email()
|
||||
->unique(ignoreRecord: true),
|
||||
->unique(ignoreRecord: true)
|
||||
->columnSpan(2),
|
||||
|
||||
TextInput::make('password')
|
||||
->label(__('Password'))
|
||||
->password()
|
||||
->dehydrateStateUsing(fn ($state) => Hash::make($state))
|
||||
->dehydrated(fn ($state) => filled($state))
|
||||
->required(fn (string $context): bool => $context === 'create'),
|
||||
->required(fn (string $context): bool => $context === 'create')
|
||||
->columnSpan(2),
|
||||
|
||||
Select::make('roles')
|
||||
->label(__('Roles'))
|
||||
->relationship('roles', 'name')
|
||||
->multiple()
|
||||
->preload()
|
||||
->native(false),
|
||||
->native(false)
|
||||
->columnSpan(3),
|
||||
|
||||
Select::make('branches')
|
||||
->label(__('Branches'))
|
||||
->relationship('branches', 'name', fn (Builder $query) => $query->distinct('id')->orderBy('id'))
|
||||
->multiple()
|
||||
->preload()
|
||||
->native(false),
|
||||
->native(false)
|
||||
->columnSpan(3),
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,6 +2,7 @@
|
||||
|
||||
namespace App\Filament\Resources\Users;
|
||||
|
||||
use App\Filament\Clusters\Users\UsersCluster;
|
||||
use App\Filament\Resources\Users\Pages\CreateUser;
|
||||
use App\Filament\Resources\Users\Pages\EditUser;
|
||||
use App\Filament\Resources\Users\Pages\ListUsers;
|
||||
@@ -16,15 +17,15 @@ use Filament\Tables\Table;
|
||||
|
||||
class UserResource extends Resource
|
||||
{
|
||||
protected static ?int $navigationSort = 2;
|
||||
|
||||
protected static ?string $model = User::class;
|
||||
|
||||
protected static ?string $cluster = UsersCluster::class;
|
||||
|
||||
protected static string|BackedEnum|null $navigationIcon = Heroicon::OutlinedUsers;
|
||||
|
||||
protected static string|BackedEnum|null $activeNavigationIcon = Heroicon::Users;
|
||||
|
||||
protected static ?string $recordTitleAttribute = 'first_name';
|
||||
protected static ?string $recordTitleAttribute = 'phone';
|
||||
|
||||
public static function getNavigationLabel(): string
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user