mirror of
https://github.com/lkddi/nexusphp.git
synced 2026-04-24 03:57:22 +08:00
migration script
# Conflicts: # app/Filament/Resources/Torrent/AnnounceLogResource.php
This commit is contained in:
@@ -2,13 +2,20 @@
|
||||
|
||||
namespace App\Filament\Resources\User;
|
||||
|
||||
use Filament\Schemas\Schema;
|
||||
use Filament\Tables\Columns\TextColumn;
|
||||
use Filament\Tables\Columns\IconColumn;
|
||||
use Filament\Tables\Filters\Filter;
|
||||
use Filament\Forms\Components\TextInput;
|
||||
use Filament\Tables\Filters\SelectFilter;
|
||||
use Filament\Forms\Components\DatePicker;
|
||||
use App\Filament\Resources\User\AttendanceLogResource\Pages\ManageAttendanceLogs;
|
||||
use App\Filament\OptionsTrait;
|
||||
use App\Filament\Resources\User\AttendanceLogResource\Pages;
|
||||
use App\Filament\Resources\User\AttendanceLogResource\RelationManagers;
|
||||
use App\Models\AttendanceLog;
|
||||
use Carbon\Carbon;
|
||||
use Filament\Forms;
|
||||
use Filament\Forms\Form;
|
||||
use Filament\Resources\Resource;
|
||||
use Filament\Tables\Table;
|
||||
use Filament\Tables;
|
||||
@@ -21,9 +28,9 @@ class AttendanceLogResource extends Resource
|
||||
|
||||
protected static ?string $model = AttendanceLog::class;
|
||||
|
||||
protected static ?string $navigationIcon = 'heroicon-o-pencil-square';
|
||||
protected static string | \BackedEnum | null $navigationIcon = 'heroicon-o-pencil-square';
|
||||
|
||||
protected static ?string $navigationGroup = 'User';
|
||||
protected static string | \UnitEnum | null $navigationGroup = 'User';
|
||||
|
||||
protected static ?int $navigationSort = 11;
|
||||
|
||||
@@ -37,10 +44,10 @@ class AttendanceLogResource extends Resource
|
||||
return self::getNavigationLabel();
|
||||
}
|
||||
|
||||
public static function form(Form $form): Form
|
||||
public static function form(Schema $schema): Schema
|
||||
{
|
||||
return $form
|
||||
->schema([
|
||||
return $schema
|
||||
->components([
|
||||
//
|
||||
]);
|
||||
}
|
||||
@@ -49,34 +56,34 @@ class AttendanceLogResource extends Resource
|
||||
{
|
||||
return $table
|
||||
->columns([
|
||||
Tables\Columns\TextColumn::make('id')->sortable(),
|
||||
Tables\Columns\TextColumn::make('uid')->formatStateUsing(fn ($state) => username_for_admin($state)),
|
||||
Tables\Columns\TextColumn::make('date')->label(__('attendance.fields.date'))->sortable(),
|
||||
Tables\Columns\TextColumn::make('points')->label(__('attendance.fields.points')),
|
||||
Tables\Columns\IconColumn::make('is_retroactive')
|
||||
TextColumn::make('id')->sortable(),
|
||||
TextColumn::make('uid')->formatStateUsing(fn ($state) => username_for_admin($state)),
|
||||
TextColumn::make('date')->label(__('attendance.fields.date'))->sortable(),
|
||||
TextColumn::make('points')->label(__('attendance.fields.points')),
|
||||
IconColumn::make('is_retroactive')
|
||||
->label(__('attendance.fields.is_retroactive'))
|
||||
->boolean(true)
|
||||
,
|
||||
Tables\Columns\TextColumn::make('created_at')->label(__('label.created_at')),
|
||||
TextColumn::make('created_at')->label(__('label.created_at')),
|
||||
])
|
||||
->defaultSort('id', 'desc')
|
||||
->filters([
|
||||
Tables\Filters\Filter::make('id')
|
||||
->form([
|
||||
Forms\Components\TextInput::make('id')
|
||||
Filter::make('id')
|
||||
->schema([
|
||||
TextInput::make('id')
|
||||
->placeholder('UID')
|
||||
,
|
||||
])->query(function (Builder $query, array $data) {
|
||||
return $query->when($data['id'], fn (Builder $query, $value) => $query->where("uid", $value));
|
||||
})
|
||||
,
|
||||
Tables\Filters\SelectFilter::make('is_retroactive')
|
||||
SelectFilter::make('is_retroactive')
|
||||
->options(self::getYesNoOptions())
|
||||
->label(__('attendance.fields.is_retroactive'))
|
||||
,
|
||||
Tables\Filters\Filter::make('date')
|
||||
->form([
|
||||
Forms\Components\DatePicker::make('date')
|
||||
Filter::make('date')
|
||||
->schema([
|
||||
DatePicker::make('date')
|
||||
->maxDate(now())
|
||||
->label(__('attendance.fields.date'))
|
||||
,
|
||||
@@ -84,9 +91,9 @@ class AttendanceLogResource extends Resource
|
||||
return $query->when($data['date'], fn (Builder $query, $value) => $query->where("date", $value));
|
||||
})
|
||||
,
|
||||
Tables\Filters\Filter::make('created_at')
|
||||
->form([
|
||||
Forms\Components\DatePicker::make('created_at')
|
||||
Filter::make('created_at')
|
||||
->schema([
|
||||
DatePicker::make('created_at')
|
||||
->label(__('label.created_at'))
|
||||
,
|
||||
])->query(function (Builder $query, array $data) {
|
||||
@@ -98,16 +105,16 @@ class AttendanceLogResource extends Resource
|
||||
})
|
||||
,
|
||||
])
|
||||
->actions([
|
||||
->recordActions([
|
||||
])
|
||||
->bulkActions([
|
||||
->toolbarActions([
|
||||
]);
|
||||
}
|
||||
|
||||
public static function getPages(): array
|
||||
{
|
||||
return [
|
||||
'index' => Pages\ManageAttendanceLogs::route('/'),
|
||||
'index' => ManageAttendanceLogs::route('/'),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,6 +2,7 @@
|
||||
|
||||
namespace App\Filament\Resources\User\AttendanceLogResource\Pages;
|
||||
|
||||
use Filament\Actions\CreateAction;
|
||||
use App\Filament\PageListSingle;
|
||||
use App\Filament\Resources\User\AttendanceLogResource;
|
||||
use Filament\Pages\Actions;
|
||||
@@ -14,7 +15,7 @@ class ManageAttendanceLogs extends PageListSingle
|
||||
protected function getHeaderActions(): array
|
||||
{
|
||||
return [
|
||||
Actions\CreateAction::make(),
|
||||
CreateAction::make(),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,11 +2,16 @@
|
||||
|
||||
namespace App\Filament\Resources\User;
|
||||
|
||||
use Filament\Schemas\Schema;
|
||||
use Filament\Tables\Columns\TextColumn;
|
||||
use Filament\Tables\Filters\Filter;
|
||||
use Filament\Forms\Components\TextInput;
|
||||
use Filament\Tables\Filters\SelectFilter;
|
||||
use App\Filament\Resources\User\BonusLogResource\Pages\ManageBonusLogs;
|
||||
use App\Filament\Resources\User\BonusLogResource\Pages;
|
||||
use App\Filament\Resources\User\BonusLogResource\RelationManagers;
|
||||
use App\Models\BonusLogs;
|
||||
use Filament\Forms;
|
||||
use Filament\Forms\Form;
|
||||
use Filament\Resources\Resource;
|
||||
use Filament\Tables\Table;
|
||||
use Filament\Tables;
|
||||
@@ -19,9 +24,9 @@ class BonusLogResource extends Resource
|
||||
{
|
||||
protected static ?string $model = BonusLogs::class;
|
||||
|
||||
protected static ?string $navigationIcon = 'heroicon-o-rectangle-stack';
|
||||
protected static string | \BackedEnum | null $navigationIcon = 'heroicon-o-rectangle-stack';
|
||||
|
||||
protected static ?string $navigationGroup = 'User';
|
||||
protected static string | \UnitEnum | null $navigationGroup = 'User';
|
||||
|
||||
protected static ?int $navigationSort = 10;
|
||||
|
||||
@@ -35,10 +40,10 @@ class BonusLogResource extends Resource
|
||||
return sprintf('%s(%s)', get_model_label(static::getModel()), __('bonus-log.exclude_seeding_bonus'));
|
||||
}
|
||||
|
||||
public static function form(Form $form): Form
|
||||
public static function form(Schema $schema): Schema
|
||||
{
|
||||
return $form
|
||||
->schema([
|
||||
return $schema
|
||||
->components([
|
||||
//
|
||||
]);
|
||||
}
|
||||
@@ -47,38 +52,38 @@ class BonusLogResource extends Resource
|
||||
{
|
||||
return $table
|
||||
->columns([
|
||||
Tables\Columns\TextColumn::make('id')->sortable(),
|
||||
Tables\Columns\TextColumn::make('uid')
|
||||
TextColumn::make('id')->sortable(),
|
||||
TextColumn::make('uid')
|
||||
->formatStateUsing(fn ($state) => username_for_admin($state))
|
||||
->label(__('label.username'))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('business_type_text')
|
||||
TextColumn::make('business_type_text')
|
||||
->label(__('bonus-log.fields.business_type'))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('old_total_value')
|
||||
TextColumn::make('old_total_value')
|
||||
->label(__('bonus-log.fields.old_total_value'))
|
||||
->formatStateUsing(fn ($state) => $state >= 0 ? number_format($state) : '-')
|
||||
,
|
||||
Tables\Columns\TextColumn::make('value')
|
||||
TextColumn::make('value')
|
||||
->formatStateUsing(fn ($record) => $record->old_total_value > $record->new_total_value ? "-" . number_format($record->value) : "+" . number_format($record->value))
|
||||
->label(__('bonus-log.fields.value'))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('new_total_value')
|
||||
TextColumn::make('new_total_value')
|
||||
->label(__('bonus-log.fields.new_total_value'))
|
||||
->formatStateUsing(fn ($state) => $state >= 0 ? number_format($state) : '-')
|
||||
,
|
||||
Tables\Columns\TextColumn::make('comment')
|
||||
TextColumn::make('comment')
|
||||
->label(__('label.comment'))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('created_at')
|
||||
TextColumn::make('created_at')
|
||||
->label(__('label.created_at'))
|
||||
,
|
||||
])
|
||||
->defaultSort('id', 'desc')
|
||||
->filters([
|
||||
Tables\Filters\Filter::make('uid')
|
||||
->form([
|
||||
Forms\Components\TextInput::make('uid')
|
||||
Filter::make('uid')
|
||||
->schema([
|
||||
TextInput::make('uid')
|
||||
->label(__('label.username'))
|
||||
->placeholder('UID')
|
||||
,
|
||||
@@ -86,7 +91,7 @@ class BonusLogResource extends Resource
|
||||
return $query->when($data['uid'], fn (Builder $query, $value) => $query->where("uid", $value));
|
||||
})
|
||||
,
|
||||
Tables\Filters\SelectFilter::make('business_type')
|
||||
SelectFilter::make('business_type')
|
||||
->options(BonusLogs::listStaticProps(Arr::except(BonusLogs::$businessTypes, BonusLogs::$businessTypeBonus), 'bonus-log.business_types', true))
|
||||
->label(__('bonus-log.fields.business_type'))
|
||||
,
|
||||
@@ -101,11 +106,11 @@ class BonusLogResource extends Resource
|
||||
// ->default()
|
||||
// ,
|
||||
])
|
||||
->actions([
|
||||
->recordActions([
|
||||
// Tables\Actions\EditAction::make(),
|
||||
// Tables\Actions\DeleteAction::make(),
|
||||
])
|
||||
->bulkActions([
|
||||
->toolbarActions([
|
||||
// Tables\Actions\DeleteBulkAction::make(),
|
||||
]);
|
||||
}
|
||||
@@ -113,7 +118,7 @@ class BonusLogResource extends Resource
|
||||
public static function getPages(): array
|
||||
{
|
||||
return [
|
||||
'index' => Pages\ManageBonusLogs::route('/'),
|
||||
'index' => ManageBonusLogs::route('/'),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,11 +2,18 @@
|
||||
|
||||
namespace App\Filament\Resources\User;
|
||||
|
||||
use Filament\Schemas\Schema;
|
||||
use Filament\Tables\Columns\TextColumn;
|
||||
use Filament\Tables\Columns\BooleanColumn;
|
||||
use Filament\Tables\Filters\Filter;
|
||||
use Filament\Forms\Components\TextInput;
|
||||
use App\Filament\Resources\User\ClaimResource\Pages\ListClaims;
|
||||
use App\Filament\Resources\User\ClaimResource\Pages\CreateClaim;
|
||||
use App\Filament\Resources\User\ClaimResource\Pages\EditClaim;
|
||||
use App\Filament\Resources\User\ClaimResource\Pages;
|
||||
use App\Filament\Resources\User\ClaimResource\RelationManagers;
|
||||
use App\Models\Claim;
|
||||
use Filament\Forms;
|
||||
use Filament\Forms\Form;
|
||||
use Filament\Resources\Resource;
|
||||
use Filament\Tables\Table;
|
||||
use Filament\Tables;
|
||||
@@ -19,9 +26,9 @@ class ClaimResource extends Resource
|
||||
{
|
||||
protected static ?string $model = Claim::class;
|
||||
|
||||
protected static ?string $navigationIcon = 'heroicon-o-rectangle-stack';
|
||||
protected static string | \BackedEnum | null $navigationIcon = 'heroicon-o-rectangle-stack';
|
||||
|
||||
protected static ?string $navigationGroup = 'User';
|
||||
protected static string | \UnitEnum | null $navigationGroup = 'User';
|
||||
|
||||
protected static ?int $navigationSort = 4;
|
||||
|
||||
@@ -35,10 +42,10 @@ class ClaimResource extends Resource
|
||||
return self::getNavigationLabel();
|
||||
}
|
||||
|
||||
public static function form(Form $form): Form
|
||||
public static function form(Schema $schema): Schema
|
||||
{
|
||||
return $form
|
||||
->schema([
|
||||
return $schema
|
||||
->components([
|
||||
//
|
||||
]);
|
||||
}
|
||||
@@ -47,27 +54,27 @@ class ClaimResource extends Resource
|
||||
{
|
||||
return $table
|
||||
->columns([
|
||||
Tables\Columns\TextColumn::make('id')->sortable(),
|
||||
Tables\Columns\TextColumn::make('uid')->searchable(),
|
||||
Tables\Columns\TextColumn::make('user.username')
|
||||
TextColumn::make('id')->sortable(),
|
||||
TextColumn::make('uid')->searchable(),
|
||||
TextColumn::make('user.username')
|
||||
->label(__('label.user.label'))
|
||||
->searchable()
|
||||
->formatStateUsing(fn ($record) => new HtmlString(get_username($record->uid, false, true, true, true)))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('torrent.name')->limit(40)->label(__('label.torrent.label'))->searchable(),
|
||||
Tables\Columns\TextColumn::make('torrent.size')->label(__('label.torrent.size'))->formatStateUsing(fn (Model $record) => mksize($record->torrent->size)),
|
||||
Tables\Columns\TextColumn::make('torrent.added')->label(__('label.torrent.ttl'))->formatStateUsing(fn (Model $record) => mkprettytime(abs($record->torrent->added->diffInSeconds()))),
|
||||
Tables\Columns\TextColumn::make('created_at')->label(__('label.created_at'))->dateTime(),
|
||||
Tables\Columns\TextColumn::make('last_settle_at')->label(__('label.claim.last_settle_at'))->dateTime(),
|
||||
Tables\Columns\TextColumn::make('seedTimeThisMonth')->label(__('label.claim.seed_time_this_month')),
|
||||
Tables\Columns\TextColumn::make('uploadedThisMonth')->label(__('label.claim.uploaded_this_month')),
|
||||
Tables\Columns\BooleanColumn::make('isReachedThisMonth')->label(__('label.claim.is_reached_this_month')),
|
||||
TextColumn::make('torrent.name')->limit(40)->label(__('label.torrent.label'))->searchable(),
|
||||
TextColumn::make('torrent.size')->label(__('label.torrent.size'))->formatStateUsing(fn (Model $record) => mksize($record->torrent->size)),
|
||||
TextColumn::make('torrent.added')->label(__('label.torrent.ttl'))->formatStateUsing(fn (Model $record) => mkprettytime(abs($record->torrent->added->diffInSeconds()))),
|
||||
TextColumn::make('created_at')->label(__('label.created_at'))->dateTime(),
|
||||
TextColumn::make('last_settle_at')->label(__('label.claim.last_settle_at'))->dateTime(),
|
||||
TextColumn::make('seedTimeThisMonth')->label(__('label.claim.seed_time_this_month')),
|
||||
TextColumn::make('uploadedThisMonth')->label(__('label.claim.uploaded_this_month')),
|
||||
BooleanColumn::make('isReachedThisMonth')->label(__('label.claim.is_reached_this_month')),
|
||||
])
|
||||
->defaultSort('id', 'desc')
|
||||
->filters([
|
||||
Tables\Filters\Filter::make('uid')
|
||||
->form([
|
||||
Forms\Components\TextInput::make('uid')
|
||||
Filter::make('uid')
|
||||
->schema([
|
||||
TextInput::make('uid')
|
||||
->label('UID')
|
||||
->placeholder('UID')
|
||||
,
|
||||
@@ -75,9 +82,9 @@ class ClaimResource extends Resource
|
||||
return $query->when($data['uid'], fn (Builder $query, $uid) => $query->where("uid", $uid));
|
||||
})
|
||||
,
|
||||
Tables\Filters\Filter::make('torrent_id')
|
||||
->form([
|
||||
Forms\Components\TextInput::make('torrent_id')
|
||||
Filter::make('torrent_id')
|
||||
->schema([
|
||||
TextInput::make('torrent_id')
|
||||
->label(__('claim.fields.torrent_id'))
|
||||
->placeholder(__('claim.fields.torrent_id'))
|
||||
,
|
||||
@@ -86,10 +93,10 @@ class ClaimResource extends Resource
|
||||
})
|
||||
,
|
||||
])
|
||||
->actions([
|
||||
->recordActions([
|
||||
// Tables\Actions\EditAction::make(),
|
||||
])
|
||||
->bulkActions([
|
||||
->toolbarActions([
|
||||
// Tables\Actions\DeleteBulkAction::make(),
|
||||
]);
|
||||
}
|
||||
@@ -109,9 +116,9 @@ class ClaimResource extends Resource
|
||||
public static function getPages(): array
|
||||
{
|
||||
return [
|
||||
'index' => Pages\ListClaims::route('/'),
|
||||
'create' => Pages\CreateClaim::route('/create'),
|
||||
'edit' => Pages\EditClaim::route('/{record}/edit'),
|
||||
'index' => ListClaims::route('/'),
|
||||
'create' => CreateClaim::route('/create'),
|
||||
'edit' => EditClaim::route('/{record}/edit'),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,6 +2,7 @@
|
||||
|
||||
namespace App\Filament\Resources\User\ClaimResource\Pages;
|
||||
|
||||
use Filament\Actions\DeleteAction;
|
||||
use App\Filament\Resources\User\ClaimResource;
|
||||
use Filament\Pages\Actions;
|
||||
use Filament\Resources\Pages\EditRecord;
|
||||
@@ -13,7 +14,7 @@ class EditClaim extends EditRecord
|
||||
protected function getHeaderActions(): array
|
||||
{
|
||||
return [
|
||||
Actions\DeleteAction::make(),
|
||||
DeleteAction::make(),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,6 +2,21 @@
|
||||
|
||||
namespace App\Filament\Resources\User;
|
||||
|
||||
use Filament\Schemas\Schema;
|
||||
use Filament\Tables\Columns\TextColumn;
|
||||
use Filament\Tables\Columns\BooleanColumn;
|
||||
use Filament\Tables\Filters\Filter;
|
||||
use Filament\Forms\Components\TextInput;
|
||||
use Filament\Tables\Filters\SelectFilter;
|
||||
use Filament\Actions\ViewAction;
|
||||
use Filament\Actions\BulkAction;
|
||||
use Filament\Forms\Components\DateTimePicker;
|
||||
use Filament\Forms\Components\Textarea;
|
||||
use Filament\Schemas\Components\Grid;
|
||||
use Filament\Schemas\Components\Group;
|
||||
use Filament\Infolists\Components\TextEntry;
|
||||
use App\Filament\Resources\User\ExamUserResource\Pages\ListExamUsers;
|
||||
use App\Filament\Resources\User\ExamUserResource\Pages\ViewExamUser;
|
||||
use App\Filament\Resources\User\ExamUserResource\Pages;
|
||||
use App\Filament\Resources\User\ExamUserResource\RelationManagers;
|
||||
use App\Models\Exam;
|
||||
@@ -10,9 +25,7 @@ use App\Repositories\ExamRepository;
|
||||
use App\Repositories\HitAndRunRepository;
|
||||
use Carbon\Carbon;
|
||||
use Filament\Forms;
|
||||
use Filament\Forms\Form;
|
||||
use Filament\Infolists\Components\ViewEntry;
|
||||
use Filament\Infolists\Infolist;
|
||||
use Filament\Resources\Resource;
|
||||
use Filament\Tables\Table;
|
||||
use Filament\Tables;
|
||||
@@ -28,9 +41,9 @@ class ExamUserResource extends Resource
|
||||
{
|
||||
protected static ?string $model = ExamUser::class;
|
||||
|
||||
protected static ?string $navigationIcon = 'heroicon-o-shield-check';
|
||||
protected static string | \BackedEnum | null $navigationIcon = 'heroicon-o-shield-check';
|
||||
|
||||
protected static ?string $navigationGroup = 'User';
|
||||
protected static string | \UnitEnum | null $navigationGroup = 'User';
|
||||
|
||||
protected static ?int $navigationSort = 2;
|
||||
|
||||
@@ -44,10 +57,10 @@ class ExamUserResource extends Resource
|
||||
return self::getNavigationLabel();
|
||||
}
|
||||
|
||||
public static function form(Form $form): Form
|
||||
public static function form(Schema $schema): Schema
|
||||
{
|
||||
return $form
|
||||
->schema([
|
||||
return $schema
|
||||
->components([
|
||||
|
||||
]);
|
||||
}
|
||||
@@ -56,26 +69,26 @@ class ExamUserResource extends Resource
|
||||
{
|
||||
return $table
|
||||
->columns([
|
||||
Tables\Columns\TextColumn::make('id')->sortable(),
|
||||
Tables\Columns\TextColumn::make('uid')->searchable(),
|
||||
Tables\Columns\TextColumn::make('user.username')
|
||||
TextColumn::make('id')->sortable(),
|
||||
TextColumn::make('uid')->searchable(),
|
||||
TextColumn::make('user.username')
|
||||
->label(__('label.username'))
|
||||
->searchable()
|
||||
->formatStateUsing(fn ($record) => new HtmlString(get_username($record->uid, false, true, true, true)))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('exam.name')->label(__('label.exam.label')),
|
||||
Tables\Columns\TextColumn::make('exam.typeText')->label(__('exam.type')),
|
||||
Tables\Columns\TextColumn::make('begin')->label(__('label.begin'))->dateTime(),
|
||||
Tables\Columns\TextColumn::make('end')->label(__('label.end'))->dateTime(),
|
||||
Tables\Columns\BooleanColumn::make('is_done')->label(__('label.exam_user.is_done')),
|
||||
Tables\Columns\TextColumn::make('statusText')->label(__('label.status')),
|
||||
Tables\Columns\TextColumn::make('created_at')->dateTime()->label(__('label.created_at')),
|
||||
TextColumn::make('exam.name')->label(__('label.exam.label')),
|
||||
TextColumn::make('exam.typeText')->label(__('exam.type')),
|
||||
TextColumn::make('begin')->label(__('label.begin'))->dateTime(),
|
||||
TextColumn::make('end')->label(__('label.end'))->dateTime(),
|
||||
BooleanColumn::make('is_done')->label(__('label.exam_user.is_done')),
|
||||
TextColumn::make('statusText')->label(__('label.status')),
|
||||
TextColumn::make('created_at')->dateTime()->label(__('label.created_at')),
|
||||
])
|
||||
->defaultSort('id', 'desc')
|
||||
->filters([
|
||||
Tables\Filters\Filter::make('uid')
|
||||
->form([
|
||||
Forms\Components\TextInput::make('uid')
|
||||
Filter::make('uid')
|
||||
->schema([
|
||||
TextInput::make('uid')
|
||||
->label('UID')
|
||||
->placeholder('UID')
|
||||
,
|
||||
@@ -83,7 +96,7 @@ class ExamUserResource extends Resource
|
||||
return $query->when($data['uid'], fn (Builder $query, $uid) => $query->where("uid", $uid));
|
||||
})
|
||||
,
|
||||
Tables\Filters\SelectFilter::make('exam_type')
|
||||
SelectFilter::make('exam_type')
|
||||
->options(Exam::listTypeOptions())
|
||||
->label(__('exam.type'))
|
||||
->query(function (Builder $query, array $data) {
|
||||
@@ -94,18 +107,18 @@ class ExamUserResource extends Resource
|
||||
});
|
||||
})
|
||||
,
|
||||
Tables\Filters\SelectFilter::make('exam_id')
|
||||
SelectFilter::make('exam_id')
|
||||
->options(Exam::query()->pluck('name', 'id')->toArray())
|
||||
->label(__('label.exam.label'))
|
||||
,
|
||||
Tables\Filters\SelectFilter::make('status')->options(ExamUser::listStatus(true))->label(__("label.status")),
|
||||
Tables\Filters\SelectFilter::make('is_done')->options(['0' => 'No', '1' => 'yes'])->label(__('label.exam_user.is_done')),
|
||||
SelectFilter::make('status')->options(ExamUser::listStatus(true))->label(__("label.status")),
|
||||
SelectFilter::make('is_done')->options(['0' => 'No', '1' => 'yes'])->label(__('label.exam_user.is_done')),
|
||||
])
|
||||
->actions([
|
||||
Tables\Actions\ViewAction::make(),
|
||||
->recordActions([
|
||||
ViewAction::make(),
|
||||
])
|
||||
->groupedBulkActions([
|
||||
Tables\Actions\BulkAction::make('Avoid')->action(function (Collection $records) {
|
||||
BulkAction::make('Avoid')->action(function (Collection $records) {
|
||||
$idArr = $records->pluck('id')->toArray();
|
||||
$rep = new ExamRepository();
|
||||
$rep->avoidExamUserBulk(['id' => $idArr], Auth::user());
|
||||
@@ -115,13 +128,13 @@ class ExamUserResource extends Resource
|
||||
->label(__('admin.resources.exam_user.bulk_action_avoid_label'))
|
||||
->icon('heroicon-o-x-mark'),
|
||||
|
||||
Tables\Actions\BulkAction::make('UpdateEnd')
|
||||
BulkAction::make('UpdateEnd')
|
||||
->form([
|
||||
Forms\Components\DateTimePicker::make('end')
|
||||
DateTimePicker::make('end')
|
||||
->required()
|
||||
->label(__('label.end'))
|
||||
,
|
||||
Forms\Components\Textarea::make('reason')
|
||||
Textarea::make('reason')
|
||||
->label(__('label.reason'))
|
||||
,
|
||||
])
|
||||
@@ -142,44 +155,44 @@ class ExamUserResource extends Resource
|
||||
]);
|
||||
}
|
||||
|
||||
public static function infolist(Infolist $infolist): Infolist
|
||||
public static function infolist(Schema $schema): Schema
|
||||
{
|
||||
return $infolist
|
||||
->schema([
|
||||
Components\Grid::make(2)->schema([
|
||||
Components\Group::make([
|
||||
Infolists\Components\TextEntry::make('id'),
|
||||
Infolists\Components\TextEntry::make('statusText')
|
||||
return $schema
|
||||
->components([
|
||||
Grid::make(2)->schema([
|
||||
Group::make([
|
||||
TextEntry::make('id'),
|
||||
TextEntry::make('statusText')
|
||||
->label(__("label.status"))
|
||||
,
|
||||
Infolists\Components\TextEntry::make('uid')
|
||||
TextEntry::make('uid')
|
||||
->formatStateUsing(fn ($record) => username_for_admin($record->uid))
|
||||
->label(__("label.username"))
|
||||
,
|
||||
Infolists\Components\TextEntry::make('exam.name')
|
||||
TextEntry::make('exam.name')
|
||||
// ->formatStateUsing(fn ($record) => $record->torrent->name)
|
||||
->label(__("label.exam.label"))
|
||||
,
|
||||
Infolists\Components\TextEntry::make('begin')
|
||||
TextEntry::make('begin')
|
||||
->label(__("label.begin"))
|
||||
,
|
||||
Infolists\Components\TextEntry::make('end')
|
||||
TextEntry::make('end')
|
||||
->label(__("label.end"))
|
||||
,
|
||||
Infolists\Components\TextEntry::make('isDoneText')
|
||||
TextEntry::make('isDoneText')
|
||||
->label(__("label.exam_user.is_done"))
|
||||
,
|
||||
Infolists\Components\TextEntry::make('created_at')
|
||||
TextEntry::make('created_at')
|
||||
->label(__("label.created_at"))
|
||||
,
|
||||
Infolists\Components\TextEntry::make('updated_at')
|
||||
TextEntry::make('updated_at')
|
||||
->label(__("label.updated_at"))
|
||||
,
|
||||
])
|
||||
->columnSpan(1)
|
||||
->columns(2)
|
||||
,
|
||||
Components\Group::make([
|
||||
Group::make([
|
||||
ViewEntry::make('progressFormatted')
|
||||
->label('进度')
|
||||
->view('filament.resources.user.exam-user-resource.pages.detail-v3')
|
||||
@@ -231,10 +244,10 @@ class ExamUserResource extends Resource
|
||||
public static function getPages(): array
|
||||
{
|
||||
return [
|
||||
'index' => Pages\ListExamUsers::route('/'),
|
||||
'index' => ListExamUsers::route('/'),
|
||||
// 'create' => Pages\CreateExamUser::route('/create'),
|
||||
// 'edit' => Pages\EditExamUser::route('/{record}/edit'),
|
||||
'view' => Pages\ViewExamUser::route('/{record}'),
|
||||
'view' => ViewExamUser::route('/{record}'),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,6 +2,7 @@
|
||||
|
||||
namespace App\Filament\Resources\User\ExamUserResource\Pages;
|
||||
|
||||
use Filament\Actions\DeleteAction;
|
||||
use App\Filament\Resources\User\ExamUserResource;
|
||||
use Filament\Pages\Actions;
|
||||
use Filament\Resources\Pages\EditRecord;
|
||||
@@ -13,7 +14,7 @@ class EditExamUser extends EditRecord
|
||||
protected function getHeaderActions(): array
|
||||
{
|
||||
return [
|
||||
Actions\DeleteAction::make(),
|
||||
DeleteAction::make(),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,6 +2,12 @@
|
||||
|
||||
namespace App\Filament\Resources\User\ExamUserResource\Pages;
|
||||
|
||||
use Filament\Actions\Action;
|
||||
use Exception;
|
||||
use Filament\Schemas\Schema;
|
||||
use Filament\Forms\Components\DateTimePicker;
|
||||
use Filament\Forms\Components\Textarea;
|
||||
use Filament\Actions\DeleteAction;
|
||||
use App\Filament\Resources\User\ExamUserResource;
|
||||
use App\Models\Exam;
|
||||
use App\Repositories\ExamRepository;
|
||||
@@ -75,7 +81,7 @@ class ViewExamUser extends ViewRecord
|
||||
protected function getHeaderActions(): array
|
||||
{
|
||||
return [
|
||||
Actions\Action::make('Avoid')
|
||||
Action::make('Avoid')
|
||||
->requiresConfirmation()
|
||||
->action(function () {
|
||||
$examRep = new ExamRepository();
|
||||
@@ -83,22 +89,22 @@ class ViewExamUser extends ViewRecord
|
||||
$examRep->avoidExamUser($this->record->id);
|
||||
send_admin_success_notification();
|
||||
$this->record = $this->resolveRecord($this->record->id);
|
||||
} catch (\Exception $exception) {
|
||||
} catch (Exception $exception) {
|
||||
send_admin_fail_notification($exception->getMessage());
|
||||
}
|
||||
})
|
||||
->label(__('admin.resources.exam_user.action_avoid')),
|
||||
|
||||
Actions\Action::make('UpdateEnd')
|
||||
->mountUsing(fn (Forms\ComponentContainer $form) => $form->fill([
|
||||
Action::make('UpdateEnd')
|
||||
->mountUsing(fn (Schema $schema) => $schema->fill([
|
||||
'end' => $this->record->end,
|
||||
]))
|
||||
->form([
|
||||
Forms\Components\DateTimePicker::make('end')
|
||||
->schema([
|
||||
DateTimePicker::make('end')
|
||||
->required()
|
||||
->label(__('label.end'))
|
||||
,
|
||||
Forms\Components\Textarea::make('reason')
|
||||
Textarea::make('reason')
|
||||
->label(__('label.reason'))
|
||||
,
|
||||
])
|
||||
@@ -108,13 +114,13 @@ class ViewExamUser extends ViewRecord
|
||||
$examRep->updateExamUserEnd($this->record, Carbon::parse($data['end']), $data['reason'] ?? "");
|
||||
send_admin_success_notification();
|
||||
$this->record = $this->resolveRecord($this->record->id);
|
||||
} catch (\Exception $exception) {
|
||||
} catch (Exception $exception) {
|
||||
send_admin_fail_notification($exception->getMessage());
|
||||
}
|
||||
})
|
||||
->label(__('admin.resources.exam_user.action_update_end')),
|
||||
|
||||
Actions\DeleteAction::make(),
|
||||
DeleteAction::make(),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,6 +2,18 @@
|
||||
|
||||
namespace App\Filament\Resources\User;
|
||||
|
||||
use Filament\Tables\Columns\TextColumn;
|
||||
use Filament\Tables\Filters\Filter;
|
||||
use Filament\Forms\Components\TextInput;
|
||||
use Filament\Tables\Filters\SelectFilter;
|
||||
use Filament\Forms\Components\DatePicker;
|
||||
use Filament\Actions\ViewAction;
|
||||
use Filament\Actions\BulkAction;
|
||||
use Filament\Actions\DeleteBulkAction;
|
||||
use Filament\Schemas\Schema;
|
||||
use Filament\Infolists\Components\TextEntry;
|
||||
use App\Filament\Resources\User\HitAndRunResource\Pages\ListHitAndRuns;
|
||||
use App\Filament\Resources\User\HitAndRunResource\Pages\ViewHitAndRun;
|
||||
use App\Filament\Resources\User\HitAndRunResource\Pages;
|
||||
use App\Filament\Resources\User\HitAndRunResource\RelationManagers;
|
||||
use App\Models\HitAndRun;
|
||||
@@ -9,7 +21,6 @@ use App\Models\User;
|
||||
use App\Repositories\HitAndRunRepository;
|
||||
use Filament\Forms;
|
||||
use Filament\Forms\Form;
|
||||
use Filament\Infolists\Infolist;
|
||||
use Filament\Resources\Resource;
|
||||
use Filament\Tables\Table;
|
||||
use Filament\Tables;
|
||||
@@ -26,9 +37,9 @@ class HitAndRunResource extends Resource
|
||||
{
|
||||
protected static ?string $model = HitAndRun::class;
|
||||
|
||||
protected static ?string $navigationIcon = 'heroicon-o-beaker';
|
||||
protected static string | \BackedEnum | null $navigationIcon = 'heroicon-o-beaker';
|
||||
|
||||
protected static ?string $navigationGroup = 'User';
|
||||
protected static string | \UnitEnum | null $navigationGroup = 'User';
|
||||
|
||||
protected static ?int $navigationSort = 3;
|
||||
|
||||
@@ -46,28 +57,28 @@ class HitAndRunResource extends Resource
|
||||
{
|
||||
return $table
|
||||
->columns([
|
||||
Tables\Columns\TextColumn::make('id')->sortable(),
|
||||
Tables\Columns\TextColumn::make('uid')->searchable(),
|
||||
Tables\Columns\TextColumn::make('user.username')
|
||||
TextColumn::make('id')->sortable(),
|
||||
TextColumn::make('uid')->searchable(),
|
||||
TextColumn::make('user.username')
|
||||
->searchable()
|
||||
->label(__('label.username'))
|
||||
->formatStateUsing(fn ($record) => new HtmlString(get_username($record->uid, false, true, true, true)))
|
||||
,
|
||||
|
||||
Tables\Columns\TextColumn::make('torrent.name')->limit(30)->label(__('label.torrent.label')),
|
||||
Tables\Columns\TextColumn::make('snatch.uploadText')->label(__('label.uploaded')),
|
||||
Tables\Columns\TextColumn::make('snatch.downloadText')->label(__('label.downloaded')),
|
||||
Tables\Columns\TextColumn::make('snatch.shareRatio')->label(__('label.ratio')),
|
||||
Tables\Columns\TextColumn::make('seedTimeRequired')->label(__('label.seed_time_required')),
|
||||
Tables\Columns\TextColumn::make('inspectTimeLeft')->label(__('label.inspect_time_left')),
|
||||
Tables\Columns\TextColumn::make('statusText')->label(__('label.status')),
|
||||
Tables\Columns\TextColumn::make('created_at')->label(__('label.created_at')),
|
||||
TextColumn::make('torrent.name')->limit(30)->label(__('label.torrent.label')),
|
||||
TextColumn::make('snatch.uploadText')->label(__('label.uploaded')),
|
||||
TextColumn::make('snatch.downloadText')->label(__('label.downloaded')),
|
||||
TextColumn::make('snatch.shareRatio')->label(__('label.ratio')),
|
||||
TextColumn::make('seedTimeRequired')->label(__('label.seed_time_required')),
|
||||
TextColumn::make('inspectTimeLeft')->label(__('label.inspect_time_left')),
|
||||
TextColumn::make('statusText')->label(__('label.status')),
|
||||
TextColumn::make('created_at')->label(__('label.created_at')),
|
||||
])
|
||||
->defaultSort('id', 'desc')
|
||||
->filters([
|
||||
Tables\Filters\Filter::make('uid')
|
||||
->form([
|
||||
Forms\Components\TextInput::make('uid')
|
||||
Filter::make('uid')
|
||||
->schema([
|
||||
TextInput::make('uid')
|
||||
->label('UID')
|
||||
->placeholder('UID')
|
||||
,
|
||||
@@ -76,10 +87,10 @@ class HitAndRunResource extends Resource
|
||||
return $query->when($data['uid'], fn (Builder $query, $uid) => $query->where("uid", $uid));
|
||||
})
|
||||
,
|
||||
Tables\Filters\SelectFilter::make('status')->options(HitAndRun::listStatus(true))->label(__('label.status')),
|
||||
Tables\Filters\Filter::make('created_at_begin')
|
||||
->form([
|
||||
Forms\Components\DatePicker::make('created_at_begin')
|
||||
SelectFilter::make('status')->options(HitAndRun::listStatus(true))->label(__('label.status')),
|
||||
Filter::make('created_at_begin')
|
||||
->schema([
|
||||
DatePicker::make('created_at_begin')
|
||||
->maxDate(now())
|
||||
->label(__('label.created_at_begin'))
|
||||
,
|
||||
@@ -87,9 +98,9 @@ class HitAndRunResource extends Resource
|
||||
return $query->when($data['created_at_begin'], fn (Builder $query, $value) => $query->where("created_at", '>=', $value));
|
||||
})
|
||||
,
|
||||
Tables\Filters\Filter::make('created_at_end')
|
||||
->form([
|
||||
Forms\Components\DatePicker::make('created_at_end')
|
||||
Filter::make('created_at_end')
|
||||
->schema([
|
||||
DatePicker::make('created_at_end')
|
||||
->maxDate(now())
|
||||
->label(__('label.created_at_end'))
|
||||
,
|
||||
@@ -98,11 +109,11 @@ class HitAndRunResource extends Resource
|
||||
})
|
||||
,
|
||||
])
|
||||
->actions([
|
||||
Tables\Actions\ViewAction::make(),
|
||||
->recordActions([
|
||||
ViewAction::make(),
|
||||
])
|
||||
->groupedBulkActions([
|
||||
Tables\Actions\BulkAction::make('Pardon')->action(function (Collection $records) {
|
||||
BulkAction::make('Pardon')->action(function (Collection $records) {
|
||||
$idArr = $records->pluck('id')->toArray();
|
||||
$rep = new HitAndRunRepository();
|
||||
$rep->bulkPardon(['id' => $idArr], Auth::user());
|
||||
@@ -111,49 +122,49 @@ class HitAndRunResource extends Resource
|
||||
->label(__('admin.resources.hit_and_run.bulk_action_pardon'))
|
||||
->icon('heroicon-o-x-mark')
|
||||
,
|
||||
Tables\Actions\DeleteBulkAction::make('bulkDelete')
|
||||
DeleteBulkAction::make('bulkDelete')
|
||||
]);
|
||||
}
|
||||
|
||||
public static function infolist(Infolist $infolist): Infolist
|
||||
public static function infolist(Schema $schema): Schema
|
||||
{
|
||||
return $infolist
|
||||
->schema([
|
||||
Infolists\Components\TextEntry::make('id'),
|
||||
Infolists\Components\TextEntry::make('statusText')
|
||||
return $schema
|
||||
->components([
|
||||
TextEntry::make('id'),
|
||||
TextEntry::make('statusText')
|
||||
->label(__("label.status"))
|
||||
,
|
||||
Infolists\Components\TextEntry::make('uid')
|
||||
TextEntry::make('uid')
|
||||
->formatStateUsing(fn ($record) => username_for_admin($record->uid))
|
||||
->label(__("label.username"))
|
||||
,
|
||||
Infolists\Components\TextEntry::make('torrent_id')
|
||||
TextEntry::make('torrent_id')
|
||||
->formatStateUsing(fn ($record) => $record->torrent->name)
|
||||
->label(__("label.torrent.label"))
|
||||
,
|
||||
Infolists\Components\TextEntry::make('snatch.uploadedText')
|
||||
TextEntry::make('snatch.uploadedText')
|
||||
->label(__("label.uploaded"))
|
||||
,
|
||||
Infolists\Components\TextEntry::make('snatch.downloadedText')
|
||||
TextEntry::make('snatch.downloadedText')
|
||||
->label(__("label.downloaded"))
|
||||
,
|
||||
Infolists\Components\TextEntry::make('snatch.shareRatio')
|
||||
TextEntry::make('snatch.shareRatio')
|
||||
->label(__("label.ratio"))
|
||||
,
|
||||
Infolists\Components\TextEntry::make('seedTimeRequired')
|
||||
TextEntry::make('seedTimeRequired')
|
||||
->label(__("label.seed_time_required"))
|
||||
,
|
||||
Infolists\Components\TextEntry::make('inspectTimeLeft')
|
||||
TextEntry::make('inspectTimeLeft')
|
||||
->label(__("label.inspect_time_left"))
|
||||
,
|
||||
Infolists\Components\TextEntry::make('comment')
|
||||
TextEntry::make('comment')
|
||||
->formatStateUsing(fn ($record) => new HtmlString(nl2br($record->comment)))
|
||||
->label(__("label.comment"))
|
||||
,
|
||||
Infolists\Components\TextEntry::make('created_at')
|
||||
TextEntry::make('created_at')
|
||||
->label(__("label.created_at"))
|
||||
,
|
||||
Infolists\Components\TextEntry::make('updated_at')
|
||||
TextEntry::make('updated_at')
|
||||
->label(__("label.updated_at"))
|
||||
,
|
||||
])->columns(4);
|
||||
@@ -175,10 +186,10 @@ class HitAndRunResource extends Resource
|
||||
public static function getPages(): array
|
||||
{
|
||||
return [
|
||||
'index' => Pages\ListHitAndRuns::route('/'),
|
||||
'index' => ListHitAndRuns::route('/'),
|
||||
// 'create' => Pages\CreateHitAndRun::route('/create'),
|
||||
// 'edit' => Pages\EditHitAndRun::route('/{record}/edit'),
|
||||
'view' => Pages\ViewHitAndRun::route('/{record}'),
|
||||
'view' => ViewHitAndRun::route('/{record}'),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,6 +2,7 @@
|
||||
|
||||
namespace App\Filament\Resources\User\HitAndRunResource\Pages;
|
||||
|
||||
use Filament\Actions\DeleteAction;
|
||||
use App\Filament\Resources\User\HitAndRunResource;
|
||||
use Filament\Pages\Actions;
|
||||
use Filament\Resources\Pages\EditRecord;
|
||||
@@ -13,7 +14,7 @@ class EditHitAndRun extends EditRecord
|
||||
protected function getHeaderActions(): array
|
||||
{
|
||||
return [
|
||||
Actions\DeleteAction::make(),
|
||||
DeleteAction::make(),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,6 +2,9 @@
|
||||
|
||||
namespace App\Filament\Resources\User\HitAndRunResource\Pages;
|
||||
|
||||
use Filament\Actions\Action;
|
||||
use Exception;
|
||||
use Filament\Actions\DeleteAction;
|
||||
use App\Filament\Resources\User\HitAndRunResource;
|
||||
use App\Models\HitAndRun;
|
||||
use App\Repositories\HitAndRunRepository;
|
||||
@@ -82,7 +85,7 @@ class ViewHitAndRun extends ViewRecord
|
||||
{
|
||||
$actions = [];
|
||||
if (in_array($this->record->status, HitAndRun::CAN_PARDON_STATUS)) {
|
||||
$actions[] = Actions\Action::make('Pardon')
|
||||
$actions[] = Action::make('Pardon')
|
||||
->requiresConfirmation()
|
||||
->action(function () {
|
||||
$hitAndRunRep = new HitAndRunRepository();
|
||||
@@ -90,14 +93,14 @@ class ViewHitAndRun extends ViewRecord
|
||||
$hitAndRunRep->pardon($this->record->id, Auth::user());
|
||||
send_admin_success_notification();
|
||||
$this->record = $this->resolveRecord($this->record->id);
|
||||
} catch (\Exception $exception) {
|
||||
} catch (Exception $exception) {
|
||||
send_admin_fail_notification($exception->getMessage());
|
||||
}
|
||||
})
|
||||
->label(__('admin.resources.hit_and_run.action_pardon'))
|
||||
;
|
||||
}
|
||||
$actions[] = Actions\DeleteAction::make();
|
||||
$actions[] = DeleteAction::make();
|
||||
|
||||
return $actions;
|
||||
}
|
||||
|
||||
@@ -2,12 +2,21 @@
|
||||
|
||||
namespace App\Filament\Resources\User;
|
||||
|
||||
use Filament\Schemas\Schema;
|
||||
use Filament\Tables\Columns\TextColumn;
|
||||
use Filament\Tables\Columns\IconColumn;
|
||||
use App\Filament\Resources\User\InviteResource\Pages\ListInvites;
|
||||
use App\Filament\Resources\User\InviteResource\Pages\CreateInvite;
|
||||
use App\Filament\Resources\User\InviteResource\Pages\EditInvite;
|
||||
use Filament\Tables\Filters\Filter;
|
||||
use Filament\Forms\Components\TextInput;
|
||||
use Filament\Tables\Filters\SelectFilter;
|
||||
use Filament\Forms\Components\DatePicker;
|
||||
use App\Filament\OptionsTrait;
|
||||
use App\Filament\Resources\User\InviteResource\Pages;
|
||||
use App\Filament\Resources\User\InviteResource\RelationManagers;
|
||||
use App\Models\Invite;
|
||||
use Filament\Forms;
|
||||
use Filament\Forms\Form;
|
||||
use Filament\Resources\Resource;
|
||||
use Filament\Tables\Table;
|
||||
use Filament\Tables;
|
||||
@@ -20,9 +29,9 @@ class InviteResource extends Resource
|
||||
|
||||
protected static ?string $model = Invite::class;
|
||||
|
||||
protected static ?string $navigationIcon = 'heroicon-o-user-plus';
|
||||
protected static string | \BackedEnum | null $navigationIcon = 'heroicon-o-user-plus';
|
||||
|
||||
protected static ?string $navigationGroup = 'User';
|
||||
protected static string | \UnitEnum | null $navigationGroup = 'User';
|
||||
|
||||
protected static ?int $navigationSort = 7;
|
||||
|
||||
@@ -36,10 +45,10 @@ class InviteResource extends Resource
|
||||
return self::getNavigationLabel();
|
||||
}
|
||||
|
||||
public static function form(Form $form): Form
|
||||
public static function form(Schema $schema): Schema
|
||||
{
|
||||
return $form
|
||||
->schema([
|
||||
return $schema
|
||||
->components([
|
||||
//
|
||||
]);
|
||||
}
|
||||
@@ -48,51 +57,51 @@ class InviteResource extends Resource
|
||||
{
|
||||
return $table
|
||||
->columns([
|
||||
Tables\Columns\TextColumn::make('id')->sortable(),
|
||||
Tables\Columns\TextColumn::make('inviter')
|
||||
TextColumn::make('id')->sortable(),
|
||||
TextColumn::make('inviter')
|
||||
->label(__('invite.fields.inviter'))
|
||||
->formatStateUsing(fn ($state) => username_for_admin($state))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('invitee')
|
||||
TextColumn::make('invitee')
|
||||
->label(__('invite.fields.invitee'))
|
||||
->searchable()
|
||||
,
|
||||
Tables\Columns\TextColumn::make('hash')
|
||||
TextColumn::make('hash')
|
||||
,
|
||||
Tables\Columns\TextColumn::make('time_invited')
|
||||
TextColumn::make('time_invited')
|
||||
->label(__('invite.fields.time_invited'))
|
||||
,
|
||||
Tables\Columns\IconColumn::make('valid')
|
||||
IconColumn::make('valid')
|
||||
->label(__('invite.fields.valid'))
|
||||
->boolean()
|
||||
,
|
||||
Tables\Columns\TextColumn::make('invitee_register_uid')
|
||||
TextColumn::make('invitee_register_uid')
|
||||
->label(__('invite.fields.invitee_register_uid'))
|
||||
->searchable()
|
||||
,
|
||||
Tables\Columns\TextColumn::make('invitee_register_email')
|
||||
TextColumn::make('invitee_register_email')
|
||||
->label(__('invite.fields.invitee_register_email'))
|
||||
->searchable()
|
||||
,
|
||||
Tables\Columns\TextColumn::make('invitee_register_username')
|
||||
TextColumn::make('invitee_register_username')
|
||||
->label(__('invite.fields.invitee_register_username'))
|
||||
->searchable()
|
||||
,
|
||||
Tables\Columns\TextColumn::make('expired_at')
|
||||
TextColumn::make('expired_at')
|
||||
->label(__('invite.fields.expired_at'))
|
||||
->formatStateUsing(fn ($state) => format_datetime($state))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('created_at')
|
||||
TextColumn::make('created_at')
|
||||
->label(__('label.created_at'))
|
||||
->formatStateUsing(fn ($state) => format_datetime($state))
|
||||
,
|
||||
])
|
||||
->defaultSort('id', 'desc')
|
||||
->filters(self::getFilters())
|
||||
->actions([
|
||||
->recordActions([
|
||||
// Tables\Actions\EditAction::make(),
|
||||
])
|
||||
->bulkActions([
|
||||
->toolbarActions([
|
||||
// Tables\Actions\DeleteBulkAction::make(),
|
||||
]);
|
||||
}
|
||||
@@ -107,18 +116,18 @@ class InviteResource extends Resource
|
||||
public static function getPages(): array
|
||||
{
|
||||
return [
|
||||
'index' => Pages\ListInvites::route('/'),
|
||||
'create' => Pages\CreateInvite::route('/create'),
|
||||
'edit' => Pages\EditInvite::route('/{record}/edit'),
|
||||
'index' => ListInvites::route('/'),
|
||||
'create' => CreateInvite::route('/create'),
|
||||
'edit' => EditInvite::route('/{record}/edit'),
|
||||
];
|
||||
}
|
||||
|
||||
private static function getFilters()
|
||||
{
|
||||
$filters = [];
|
||||
$filters[] = Tables\Filters\Filter::make('inviter')
|
||||
->form([
|
||||
Forms\Components\TextInput::make('inviter')
|
||||
$filters[] = Filter::make('inviter')
|
||||
->schema([
|
||||
TextInput::make('inviter')
|
||||
->label(__('invite.fields.inviter'))
|
||||
->placeholder('UID')
|
||||
,
|
||||
@@ -126,13 +135,13 @@ class InviteResource extends Resource
|
||||
return $query->when($data['inviter'], fn (Builder $query, $value) => $query->where("inviter", $value));
|
||||
})
|
||||
;
|
||||
$filters[] = Tables\Filters\SelectFilter::make('valid')
|
||||
$filters[] = SelectFilter::make('valid')
|
||||
->options(self::getYesNoOptions())
|
||||
->label(__('invite.fields.valid'))
|
||||
;
|
||||
$filters[] = Tables\Filters\Filter::make('time_invited_begin')
|
||||
->form([
|
||||
Forms\Components\DatePicker::make('time_invited_begin')
|
||||
$filters[] = Filter::make('time_invited_begin')
|
||||
->schema([
|
||||
DatePicker::make('time_invited_begin')
|
||||
->maxDate(now())
|
||||
->label(__('invite.fields.time_invited_begin'))
|
||||
,
|
||||
@@ -140,9 +149,9 @@ class InviteResource extends Resource
|
||||
return $query->when($data['time_invited_begin'], fn (Builder $query, $value) => $query->where("time_invited", '>=', $value));
|
||||
})
|
||||
;
|
||||
$filters[] = Tables\Filters\Filter::make('time_invited_end')
|
||||
->form([
|
||||
Forms\Components\DatePicker::make('time_invited_end')
|
||||
$filters[] = Filter::make('time_invited_end')
|
||||
->schema([
|
||||
DatePicker::make('time_invited_end')
|
||||
->maxDate(now())
|
||||
->label(__('invite.fields.time_invited_end'))
|
||||
,
|
||||
|
||||
@@ -2,6 +2,7 @@
|
||||
|
||||
namespace App\Filament\Resources\User\InviteResource\Pages;
|
||||
|
||||
use Filament\Actions\DeleteAction;
|
||||
use App\Filament\Resources\User\InviteResource;
|
||||
use Filament\Pages\Actions;
|
||||
use Filament\Resources\Pages\EditRecord;
|
||||
@@ -13,7 +14,7 @@ class EditInvite extends EditRecord
|
||||
protected function getHeaderActions(): array
|
||||
{
|
||||
return [
|
||||
Actions\DeleteAction::make(),
|
||||
DeleteAction::make(),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,11 +2,15 @@
|
||||
|
||||
namespace App\Filament\Resources\User;
|
||||
|
||||
use Filament\Schemas\Schema;
|
||||
use Filament\Tables\Columns\TextColumn;
|
||||
use Filament\Tables\Filters\Filter;
|
||||
use Filament\Forms\Components\TextInput;
|
||||
use App\Filament\Resources\User\LoginLogResource\Pages\ManageLoginLogs;
|
||||
use App\Filament\Resources\User\LoginLogResource\Pages;
|
||||
use App\Filament\Resources\User\LoginLogResource\RelationManagers;
|
||||
use App\Models\LoginLog;
|
||||
use Filament\Forms;
|
||||
use Filament\Forms\Form;
|
||||
use Filament\Resources\Resource;
|
||||
use Filament\Tables\Table;
|
||||
use Filament\Tables;
|
||||
@@ -17,9 +21,9 @@ class LoginLogResource extends Resource
|
||||
{
|
||||
protected static ?string $model = LoginLog::class;
|
||||
|
||||
protected static ?string $navigationIcon = 'heroicon-o-rectangle-stack';
|
||||
protected static string | \BackedEnum | null $navigationIcon = 'heroicon-o-rectangle-stack';
|
||||
|
||||
protected static ?string $navigationGroup = 'User';
|
||||
protected static string | \UnitEnum | null $navigationGroup = 'User';
|
||||
|
||||
protected static ?int $navigationSort = 9;
|
||||
|
||||
@@ -33,10 +37,10 @@ class LoginLogResource extends Resource
|
||||
return self::getNavigationLabel();
|
||||
}
|
||||
|
||||
public static function form(Form $form): Form
|
||||
public static function form(Schema $schema): Schema
|
||||
{
|
||||
return $form
|
||||
->schema([
|
||||
return $schema
|
||||
->components([
|
||||
//
|
||||
]);
|
||||
}
|
||||
@@ -45,22 +49,22 @@ class LoginLogResource extends Resource
|
||||
{
|
||||
return $table
|
||||
->columns([
|
||||
Tables\Columns\TextColumn::make('id')->sortable(),
|
||||
Tables\Columns\TextColumn::make('uid')
|
||||
TextColumn::make('id')->sortable(),
|
||||
TextColumn::make('uid')
|
||||
->formatStateUsing(fn ($state) => username_for_admin($state))
|
||||
->label(__('label.username'))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('ip')->searchable(),
|
||||
Tables\Columns\TextColumn::make('country')->label(__('label.country'))->searchable(),
|
||||
Tables\Columns\TextColumn::make('city')->label(__('label.city'))->searchable(),
|
||||
Tables\Columns\TextColumn::make('client')->label(__('label.client')),
|
||||
Tables\Columns\TextColumn::make('created_at')->label(__('label.created_at')),
|
||||
TextColumn::make('ip')->searchable(),
|
||||
TextColumn::make('country')->label(__('label.country'))->searchable(),
|
||||
TextColumn::make('city')->label(__('label.city'))->searchable(),
|
||||
TextColumn::make('client')->label(__('label.client')),
|
||||
TextColumn::make('created_at')->label(__('label.created_at')),
|
||||
])
|
||||
->defaultSort('id', 'desc')
|
||||
->filters([
|
||||
Tables\Filters\Filter::make('uid')
|
||||
->form([
|
||||
Forms\Components\TextInput::make('uid')
|
||||
Filter::make('uid')
|
||||
->schema([
|
||||
TextInput::make('uid')
|
||||
->label(__('label.username'))
|
||||
->placeholder('UID')
|
||||
,
|
||||
@@ -69,11 +73,11 @@ class LoginLogResource extends Resource
|
||||
})
|
||||
,
|
||||
])
|
||||
->actions([
|
||||
->recordActions([
|
||||
// Tables\Actions\EditAction::make(),
|
||||
// Tables\Actions\DeleteAction::make(),
|
||||
])
|
||||
->bulkActions([
|
||||
->toolbarActions([
|
||||
// Tables\Actions\DeleteBulkAction::make(),
|
||||
]);
|
||||
}
|
||||
@@ -81,7 +85,7 @@ class LoginLogResource extends Resource
|
||||
public static function getPages(): array
|
||||
{
|
||||
return [
|
||||
'index' => Pages\ManageLoginLogs::route('/'),
|
||||
'index' => ManageLoginLogs::route('/'),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,11 +2,16 @@
|
||||
|
||||
namespace App\Filament\Resources\User;
|
||||
|
||||
use Filament\Schemas\Schema;
|
||||
use Filament\Tables\Columns\TextColumn;
|
||||
use Filament\Actions\DeleteAction;
|
||||
use Filament\Actions\BulkActionGroup;
|
||||
use Filament\Actions\DeleteBulkAction;
|
||||
use App\Filament\Resources\User\TokenResource\Pages\ManageTokens;
|
||||
use App\Filament\Resources\User\TokenResource\Pages;
|
||||
use App\Filament\Resources\User\TokenResource\RelationManagers;
|
||||
use App\Models\PersonalAccessToken;
|
||||
use Filament\Forms;
|
||||
use Filament\Forms\Form;
|
||||
use Filament\Resources\Resource;
|
||||
use Filament\Tables;
|
||||
use Filament\Tables\Table;
|
||||
@@ -18,9 +23,9 @@ class TokenResource extends Resource
|
||||
{
|
||||
protected static ?string $model = PersonalAccessToken::class;
|
||||
|
||||
protected static ?string $navigationIcon = 'heroicon-o-rectangle-stack';
|
||||
protected static string | \BackedEnum | null $navigationIcon = 'heroicon-o-rectangle-stack';
|
||||
|
||||
protected static ?string $navigationGroup = 'User';
|
||||
protected static string | \UnitEnum | null $navigationGroup = 'User';
|
||||
|
||||
protected static ?int $navigationSort = 6;
|
||||
|
||||
@@ -34,10 +39,10 @@ class TokenResource extends Resource
|
||||
return self::getNavigationLabel();
|
||||
}
|
||||
|
||||
public static function form(Form $form): Form
|
||||
public static function form(Schema $schema): Schema
|
||||
{
|
||||
return $form
|
||||
->schema([
|
||||
return $schema
|
||||
->components([
|
||||
//
|
||||
]);
|
||||
}
|
||||
@@ -46,31 +51,31 @@ class TokenResource extends Resource
|
||||
{
|
||||
return $table
|
||||
->columns([
|
||||
Tables\Columns\TextColumn::make('id'),
|
||||
Tables\Columns\TextColumn::make('name')->label(__('label.name')),
|
||||
Tables\Columns\TextColumn::make('abilities')
|
||||
TextColumn::make('id'),
|
||||
TextColumn::make('name')->label(__('label.name')),
|
||||
TextColumn::make('abilities')
|
||||
->label(__('token.permission'))
|
||||
->formatStateUsing(fn ($record): string => $record->abilitiesText)
|
||||
,
|
||||
Tables\Columns\TextColumn::make('token')->label(__('token.token')),
|
||||
Tables\Columns\TextColumn::make('tokenable_id')
|
||||
TextColumn::make('token')->label(__('token.token')),
|
||||
TextColumn::make('tokenable_id')
|
||||
->label(__('label.username'))
|
||||
->formatStateUsing(fn ($state) => username_for_admin($state))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('last_used_at')->label(__('token.last_used_at')),
|
||||
Tables\Columns\TextColumn::make('expires_at')->label(__('label.expire_at')),
|
||||
Tables\Columns\TextColumn::make('created_at')->label(__('label.created_at')),
|
||||
TextColumn::make('last_used_at')->label(__('token.last_used_at')),
|
||||
TextColumn::make('expires_at')->label(__('label.expire_at')),
|
||||
TextColumn::make('created_at')->label(__('label.created_at')),
|
||||
])
|
||||
->filters([
|
||||
//
|
||||
])
|
||||
->actions([
|
||||
->recordActions([
|
||||
// Tables\Actions\EditAction::make(),
|
||||
Tables\Actions\DeleteAction::make(),
|
||||
DeleteAction::make(),
|
||||
])
|
||||
->bulkActions([
|
||||
Tables\Actions\BulkActionGroup::make([
|
||||
Tables\Actions\DeleteBulkAction::make(),
|
||||
->toolbarActions([
|
||||
BulkActionGroup::make([
|
||||
DeleteBulkAction::make(),
|
||||
]),
|
||||
]);
|
||||
}
|
||||
@@ -78,7 +83,7 @@ class TokenResource extends Resource
|
||||
public static function getPages(): array
|
||||
{
|
||||
return [
|
||||
'index' => Pages\ManageTokens::route('/'),
|
||||
'index' => ManageTokens::route('/'),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,11 +2,17 @@
|
||||
|
||||
namespace App\Filament\Resources\User;
|
||||
|
||||
use Filament\Schemas\Schema;
|
||||
use Filament\Tables\Columns\TextColumn;
|
||||
use Filament\Tables\Filters\Filter;
|
||||
use Filament\Forms\Components\TextInput;
|
||||
use App\Filament\Resources\User\TorrentBuyLogResource\Pages\ListTorrentBuyLogs;
|
||||
use App\Filament\Resources\User\TorrentBuyLogResource\Pages\CreateTorrentBuyLog;
|
||||
use App\Filament\Resources\User\TorrentBuyLogResource\Pages\EditTorrentBuyLog;
|
||||
use App\Filament\Resources\User\TorrentBuyLogResource\Pages;
|
||||
use App\Filament\Resources\User\TorrentBuyLogResource\RelationManagers;
|
||||
use App\Models\TorrentBuyLog;
|
||||
use Filament\Forms;
|
||||
use Filament\Forms\Form;
|
||||
use Filament\Resources\Resource;
|
||||
use Filament\Tables\Table;
|
||||
use Filament\Tables;
|
||||
@@ -17,9 +23,9 @@ class TorrentBuyLogResource extends Resource
|
||||
{
|
||||
protected static ?string $model = TorrentBuyLog::class;
|
||||
|
||||
protected static ?string $navigationIcon = 'heroicon-o-rectangle-stack';
|
||||
protected static string | \BackedEnum | null $navigationIcon = 'heroicon-o-rectangle-stack';
|
||||
|
||||
protected static ?string $navigationGroup = 'User';
|
||||
protected static string | \UnitEnum | null $navigationGroup = 'User';
|
||||
|
||||
protected static ?int $navigationSort = 10;
|
||||
|
||||
@@ -33,10 +39,10 @@ class TorrentBuyLogResource extends Resource
|
||||
return self::getNavigationLabel();
|
||||
}
|
||||
|
||||
public static function form(Form $form): Form
|
||||
public static function form(Schema $schema): Schema
|
||||
{
|
||||
return $form
|
||||
->schema([
|
||||
return $schema
|
||||
->components([
|
||||
//
|
||||
]);
|
||||
}
|
||||
@@ -45,29 +51,29 @@ class TorrentBuyLogResource extends Resource
|
||||
{
|
||||
return $table
|
||||
->columns([
|
||||
Tables\Columns\TextColumn::make('id')->sortable(),
|
||||
Tables\Columns\TextColumn::make('uid')
|
||||
TextColumn::make('id')->sortable(),
|
||||
TextColumn::make('uid')
|
||||
->formatStateUsing(fn ($state) => username_for_admin($state))
|
||||
->label(__('label.username'))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('torrent_id')
|
||||
TextColumn::make('torrent_id')
|
||||
->formatStateUsing(fn ($record) => torrent_name_for_admin($record->torrent))
|
||||
->label(__('label.torrent.label'))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('price')
|
||||
TextColumn::make('price')
|
||||
->formatStateUsing(fn ($state) => number_format($state))
|
||||
->label(__('label.price'))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('created_at')
|
||||
TextColumn::make('created_at')
|
||||
->formatStateUsing(fn ($state) => format_datetime($state))
|
||||
->label(__('label.created_at'))
|
||||
,
|
||||
])
|
||||
->defaultSort('id','desc')
|
||||
->filters([
|
||||
Tables\Filters\Filter::make('uid')
|
||||
->form([
|
||||
Forms\Components\TextInput::make('uid')
|
||||
Filter::make('uid')
|
||||
->schema([
|
||||
TextInput::make('uid')
|
||||
->label(__('label.username'))
|
||||
->placeholder('UID')
|
||||
,
|
||||
@@ -75,9 +81,9 @@ class TorrentBuyLogResource extends Resource
|
||||
return $query->when($data['uid'], fn (Builder $query, $value) => $query->where("uid", $value));
|
||||
})
|
||||
,
|
||||
Tables\Filters\Filter::make('torrent_id')
|
||||
->form([
|
||||
Forms\Components\TextInput::make('torrent_id')
|
||||
Filter::make('torrent_id')
|
||||
->schema([
|
||||
TextInput::make('torrent_id')
|
||||
->label(__('label.torrent.label'))
|
||||
->placeholder('Torrent ID')
|
||||
,
|
||||
@@ -86,10 +92,10 @@ class TorrentBuyLogResource extends Resource
|
||||
})
|
||||
,
|
||||
])
|
||||
->actions([
|
||||
->recordActions([
|
||||
// Tables\Actions\EditAction::make(),
|
||||
])
|
||||
->bulkActions([
|
||||
->toolbarActions([
|
||||
// Tables\Actions\DeleteBulkAction::make(),
|
||||
]);
|
||||
}
|
||||
@@ -104,9 +110,9 @@ class TorrentBuyLogResource extends Resource
|
||||
public static function getPages(): array
|
||||
{
|
||||
return [
|
||||
'index' => Pages\ListTorrentBuyLogs::route('/'),
|
||||
'create' => Pages\CreateTorrentBuyLog::route('/create'),
|
||||
'edit' => Pages\EditTorrentBuyLog::route('/{record}/edit'),
|
||||
'index' => ListTorrentBuyLogs::route('/'),
|
||||
'create' => CreateTorrentBuyLog::route('/create'),
|
||||
'edit' => EditTorrentBuyLog::route('/{record}/edit'),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,6 +2,7 @@
|
||||
|
||||
namespace App\Filament\Resources\User\TorrentBuyLogResource\Pages;
|
||||
|
||||
use Filament\Actions\DeleteAction;
|
||||
use App\Filament\Resources\User\TorrentBuyLogResource;
|
||||
use Filament\Pages\Actions;
|
||||
use Filament\Resources\Pages\EditRecord;
|
||||
@@ -13,7 +14,7 @@ class EditTorrentBuyLog extends EditRecord
|
||||
protected function getHeaderActions(): array
|
||||
{
|
||||
return [
|
||||
Actions\DeleteAction::make(),
|
||||
DeleteAction::make(),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,6 +2,21 @@
|
||||
|
||||
namespace App\Filament\Resources\User;
|
||||
|
||||
use Filament\Schemas\Schema;
|
||||
use Filament\Tables\Columns\TextColumn;
|
||||
use Filament\Tables\Columns\ImageColumn;
|
||||
use Filament\Tables\Filters\Filter;
|
||||
use Filament\Forms\Components\TextInput;
|
||||
use Filament\Tables\Filters\SelectFilter;
|
||||
use Filament\Actions\DeleteAction;
|
||||
use Filament\Actions\BulkActionGroup;
|
||||
use Filament\Actions\DeleteBulkAction;
|
||||
use Filament\Actions\BulkAction;
|
||||
use Exception;
|
||||
use Filament\Forms\Components\DateTimePicker;
|
||||
use App\Filament\Resources\User\UserMedalResource\Pages\ListUserMedals;
|
||||
use App\Filament\Resources\User\UserMedalResource\Pages\CreateUserMedal;
|
||||
use App\Filament\Resources\User\UserMedalResource\Pages\EditUserMedal;
|
||||
use App\Filament\OptionsTrait;
|
||||
use App\Filament\Resources\User\UserMedalResource\Pages;
|
||||
use App\Filament\Resources\User\UserMedalResource\RelationManagers;
|
||||
@@ -11,7 +26,6 @@ use App\Models\UserMedal;
|
||||
use App\Repositories\MedalRepository;
|
||||
use Carbon\Carbon;
|
||||
use Filament\Forms;
|
||||
use Filament\Forms\Form;
|
||||
use Filament\Resources\Resource;
|
||||
use Filament\Tables\Table;
|
||||
use Filament\Tables;
|
||||
@@ -26,9 +40,9 @@ class UserMedalResource extends Resource
|
||||
|
||||
protected static ?string $model = UserMedal::class;
|
||||
|
||||
protected static ?string $navigationIcon = 'heroicon-o-flag';
|
||||
protected static string | \BackedEnum | null $navigationIcon = 'heroicon-o-flag';
|
||||
|
||||
protected static ?string $navigationGroup = 'User';
|
||||
protected static string | \UnitEnum | null $navigationGroup = 'User';
|
||||
|
||||
protected static ?int $navigationSort = 5;
|
||||
|
||||
@@ -42,10 +56,10 @@ class UserMedalResource extends Resource
|
||||
return self::getNavigationLabel();
|
||||
}
|
||||
|
||||
public static function form(Form $form): Form
|
||||
public static function form(Schema $schema): Schema
|
||||
{
|
||||
return $form
|
||||
->schema([
|
||||
return $schema
|
||||
->components([
|
||||
//
|
||||
]);
|
||||
}
|
||||
@@ -54,25 +68,25 @@ class UserMedalResource extends Resource
|
||||
{
|
||||
return $table
|
||||
->columns([
|
||||
Tables\Columns\TextColumn::make('id')->sortable(),
|
||||
Tables\Columns\TextColumn::make('uid')->searchable(),
|
||||
Tables\Columns\TextColumn::make('user.username')
|
||||
TextColumn::make('id')->sortable(),
|
||||
TextColumn::make('uid')->searchable(),
|
||||
TextColumn::make('user.username')
|
||||
->label(__('label.username'))
|
||||
->searchable()
|
||||
->formatStateUsing(fn ($record) => new HtmlString(get_username($record->uid, false, true, true, true)))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('medal.name')->label(__('label.medal.label'))->searchable(),
|
||||
Tables\Columns\ImageColumn::make('medal.image_large')->label(__('label.image')),
|
||||
Tables\Columns\TextColumn::make('expire_at')->label(__('label.expire_at')),
|
||||
Tables\Columns\TextColumn::make('bonus_addition_expire_at')->label(__('medal.bonus_addition_expire_at')),
|
||||
Tables\Columns\TextColumn::make('wearingStatusText')->label(__('label.status')),
|
||||
Tables\Columns\TextColumn::make('created_at')->label(__('label.created_at')),
|
||||
TextColumn::make('medal.name')->label(__('label.medal.label'))->searchable(),
|
||||
ImageColumn::make('medal.image_large')->label(__('label.image')),
|
||||
TextColumn::make('expire_at')->label(__('label.expire_at')),
|
||||
TextColumn::make('bonus_addition_expire_at')->label(__('medal.bonus_addition_expire_at')),
|
||||
TextColumn::make('wearingStatusText')->label(__('label.status')),
|
||||
TextColumn::make('created_at')->label(__('label.created_at')),
|
||||
])
|
||||
->defaultSort('id', 'desc')
|
||||
->filters([
|
||||
Tables\Filters\Filter::make('uid')
|
||||
->form([
|
||||
Forms\Components\TextInput::make('uid')
|
||||
Filter::make('uid')
|
||||
->schema([
|
||||
TextInput::make('uid')
|
||||
->label('UID')
|
||||
->placeholder('UID')
|
||||
,
|
||||
@@ -80,11 +94,11 @@ class UserMedalResource extends Resource
|
||||
return $query->when($data['uid'], fn (Builder $query, $uid) => $query->where("uid", $uid));
|
||||
})
|
||||
,
|
||||
Tables\Filters\SelectFilter::make('medal_id')
|
||||
SelectFilter::make('medal_id')
|
||||
->options(Medal::query()->pluck('name', 'id')->toArray())
|
||||
->label(__('medal.label'))
|
||||
,
|
||||
Tables\Filters\SelectFilter::make('is_expired')
|
||||
SelectFilter::make('is_expired')
|
||||
->options(self::getYesNoOptions())
|
||||
->label(__('medal.is_expired'))
|
||||
->query(function (Builder $query, array $data) {
|
||||
@@ -100,7 +114,7 @@ class UserMedalResource extends Resource
|
||||
}
|
||||
})
|
||||
,
|
||||
Tables\Filters\SelectFilter::make('is_bonus_addition_expired')
|
||||
SelectFilter::make('is_bonus_addition_expired')
|
||||
->options(self::getYesNoOptions())
|
||||
->label(__('medal.is_bonus_addition_expired'))
|
||||
->query(function (Builder $query, array $data) {
|
||||
@@ -116,41 +130,41 @@ class UserMedalResource extends Resource
|
||||
}
|
||||
})
|
||||
,
|
||||
Tables\Filters\SelectFilter::make('status')
|
||||
SelectFilter::make('status')
|
||||
->options(UserMedal::listWearingStatusLabels())
|
||||
->label(__('label.status'))
|
||||
,
|
||||
])
|
||||
->actions([
|
||||
Tables\Actions\DeleteAction::make()->using(function (NexusModel $record) {
|
||||
->recordActions([
|
||||
DeleteAction::make()->using(function (NexusModel $record) {
|
||||
$record->delete();
|
||||
clear_user_cache($record->uid);
|
||||
})
|
||||
])
|
||||
->bulkActions([
|
||||
Tables\Actions\BulkActionGroup::make([
|
||||
->toolbarActions([
|
||||
BulkActionGroup::make([
|
||||
self::buildBulkActionIncreaseExpireAt('expire_at'),
|
||||
self::buildBulkActionUpdateExpireAt('expire_at'),
|
||||
self::buildBulkActionCancelExpireAt('expire_at'),
|
||||
])->label(sprintf("%s-%s", __('label.bulk'), __('label.expire_at'))),
|
||||
Tables\Actions\BulkActionGroup::make([
|
||||
BulkActionGroup::make([
|
||||
self::buildBulkActionIncreaseExpireAt('bonus_addition_expire_at'),
|
||||
self::buildBulkActionUpdateExpireAt('bonus_addition_expire_at'),
|
||||
self::buildBulkActionCancelExpireAt('bonus_addition_expire_at'),
|
||||
])->label(sprintf("%s-%s", __('label.bulk'), __('medal.bonus_addition_expire_at'))),
|
||||
Tables\Actions\DeleteBulkAction::make(),
|
||||
DeleteBulkAction::make(),
|
||||
])
|
||||
->selectCurrentPageOnly()
|
||||
;
|
||||
}
|
||||
|
||||
private static function buildBulkActionIncreaseExpireAt(string $filed): Tables\Actions\BulkAction
|
||||
private static function buildBulkActionIncreaseExpireAt(string $filed): BulkAction
|
||||
{
|
||||
return Tables\Actions\BulkAction::make("bulkActionIncrease$filed")
|
||||
return BulkAction::make("bulkActionIncrease$filed")
|
||||
->label(__('medal.bulk_action_increase'))
|
||||
->modalHeading(__('medal.bulk_action_increase_' . $filed))
|
||||
->form([
|
||||
Forms\Components\TextInput::make('increase_duration')
|
||||
TextInput::make('increase_duration')
|
||||
->label(__('medal.increase_duration'))
|
||||
->helperText(__('medal.increase_duration_help'))
|
||||
->integer()
|
||||
@@ -161,7 +175,7 @@ class UserMedalResource extends Resource
|
||||
$rep = new MedalRepository();
|
||||
$rep->increaseExpireAt($collection, $filed, $data['increase_duration']);
|
||||
send_admin_success_notification();
|
||||
} catch (\Exception $e) {
|
||||
} catch (Exception $e) {
|
||||
send_admin_fail_notification($e->getMessage());
|
||||
}
|
||||
})
|
||||
@@ -169,13 +183,13 @@ class UserMedalResource extends Resource
|
||||
;
|
||||
}
|
||||
|
||||
private static function buildBulkActionUpdateExpireAt(string $filed): Tables\Actions\BulkAction
|
||||
private static function buildBulkActionUpdateExpireAt(string $filed): BulkAction
|
||||
{
|
||||
return Tables\Actions\BulkAction::make("bulkActionUpdate$filed")
|
||||
return BulkAction::make("bulkActionUpdate$filed")
|
||||
->label(__('medal.bulk_action_update'))
|
||||
->modalHeading(__('medal.bulk_action_update_' . $filed))
|
||||
->form([
|
||||
Forms\Components\DateTimePicker::make('update_expire_at')
|
||||
DateTimePicker::make('update_expire_at')
|
||||
->label(__('medal.update_expire_at'))
|
||||
->helperText(__('medal.update_expire_at_help'))
|
||||
->required(),
|
||||
@@ -186,7 +200,7 @@ class UserMedalResource extends Resource
|
||||
$rep = new MedalRepository();
|
||||
$rep->updateExpireAt($collection, $filed, $expireAt);
|
||||
send_admin_success_notification();
|
||||
} catch (\Exception $e) {
|
||||
} catch (Exception $e) {
|
||||
send_admin_fail_notification($e->getMessage());
|
||||
}
|
||||
})
|
||||
@@ -194,9 +208,9 @@ class UserMedalResource extends Resource
|
||||
;
|
||||
}
|
||||
|
||||
private static function buildBulkActionCancelExpireAt(string $filed): Tables\Actions\BulkAction
|
||||
private static function buildBulkActionCancelExpireAt(string $filed): BulkAction
|
||||
{
|
||||
return Tables\Actions\BulkAction::make("bulkActionCancel$filed")
|
||||
return BulkAction::make("bulkActionCancel$filed")
|
||||
->label(__('medal.bulk_action_cancel'))
|
||||
->modalHeading(__('medal.bulk_action_cancel_' . $filed))
|
||||
->requiresConfirmation()
|
||||
@@ -205,7 +219,7 @@ class UserMedalResource extends Resource
|
||||
$rep = new MedalRepository();
|
||||
$rep->cancelExpireAt($collection, $filed);
|
||||
send_admin_success_notification();
|
||||
} catch (\Exception $e) {
|
||||
} catch (Exception $e) {
|
||||
send_admin_fail_notification($e->getMessage());
|
||||
}
|
||||
})
|
||||
@@ -228,9 +242,9 @@ class UserMedalResource extends Resource
|
||||
public static function getPages(): array
|
||||
{
|
||||
return [
|
||||
'index' => Pages\ListUserMedals::route('/'),
|
||||
'create' => Pages\CreateUserMedal::route('/create'),
|
||||
'edit' => Pages\EditUserMedal::route('/{record}/edit'),
|
||||
'index' => ListUserMedals::route('/'),
|
||||
'create' => CreateUserMedal::route('/create'),
|
||||
'edit' => EditUserMedal::route('/{record}/edit'),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,6 +2,7 @@
|
||||
|
||||
namespace App\Filament\Resources\User\UserMedalResource\Pages;
|
||||
|
||||
use Filament\Actions\DeleteAction;
|
||||
use App\Filament\Resources\User\UserMedalResource;
|
||||
use Filament\Pages\Actions;
|
||||
use Filament\Resources\Pages\EditRecord;
|
||||
@@ -13,7 +14,7 @@ class EditUserMedal extends EditRecord
|
||||
protected function getHeaderActions(): array
|
||||
{
|
||||
return [
|
||||
Actions\DeleteAction::make(),
|
||||
DeleteAction::make(),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,12 +2,20 @@
|
||||
|
||||
namespace App\Filament\Resources\User;
|
||||
|
||||
use Filament\Schemas\Schema;
|
||||
use Filament\Tables\Columns\TextColumn;
|
||||
use Filament\Tables\Filters\Filter;
|
||||
use Filament\Forms\Components\TextInput;
|
||||
use Filament\Tables\Filters\SelectFilter;
|
||||
use Filament\Actions\DeleteAction;
|
||||
use App\Filament\Resources\User\UserMetaResource\Pages\ListUserMetas;
|
||||
use App\Filament\Resources\User\UserMetaResource\Pages\CreateUserMeta;
|
||||
use App\Filament\Resources\User\UserMetaResource\Pages\EditUserMeta;
|
||||
use App\Filament\Resources\User\UserMetaResource\Pages;
|
||||
use App\Filament\Resources\User\UserMetaResource\RelationManagers;
|
||||
use App\Models\NexusModel;
|
||||
use App\Models\UserMeta;
|
||||
use Filament\Forms;
|
||||
use Filament\Forms\Form;
|
||||
use Filament\Resources\Resource;
|
||||
use Filament\Tables\Table;
|
||||
use Filament\Tables;
|
||||
@@ -20,9 +28,9 @@ class UserMetaResource extends Resource
|
||||
{
|
||||
protected static ?string $model = UserMeta::class;
|
||||
|
||||
protected static ?string $navigationIcon = 'heroicon-o-rectangle-stack';
|
||||
protected static string | \BackedEnum | null $navigationIcon = 'heroicon-o-rectangle-stack';
|
||||
|
||||
protected static ?string $navigationGroup = 'User';
|
||||
protected static string | \UnitEnum | null $navigationGroup = 'User';
|
||||
|
||||
protected static ?int $navigationSort = 8;
|
||||
|
||||
@@ -36,10 +44,10 @@ class UserMetaResource extends Resource
|
||||
return self::getNavigationLabel();
|
||||
}
|
||||
|
||||
public static function form(Form $form): Form
|
||||
public static function form(Schema $schema): Schema
|
||||
{
|
||||
return $form
|
||||
->schema([
|
||||
return $schema
|
||||
->components([
|
||||
//
|
||||
]);
|
||||
}
|
||||
@@ -48,28 +56,28 @@ class UserMetaResource extends Resource
|
||||
{
|
||||
return $table
|
||||
->columns([
|
||||
Tables\Columns\TextColumn::make('id')->sortable(),
|
||||
Tables\Columns\TextColumn::make('uid')
|
||||
TextColumn::make('id')->sortable(),
|
||||
TextColumn::make('uid')
|
||||
->searchable()
|
||||
->label(__('label.username'))
|
||||
->formatStateUsing(fn ($state) => username_for_admin($state))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('meta_key_text')
|
||||
TextColumn::make('meta_key_text')
|
||||
->label(__('label.name'))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('deadline')
|
||||
TextColumn::make('deadline')
|
||||
->label(__('label.deadline'))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('created_at')
|
||||
TextColumn::make('created_at')
|
||||
->label(__('label.created_at'))
|
||||
->formatStateUsing(fn ($state) => format_datetime($state))
|
||||
,
|
||||
])
|
||||
->defaultSort('id', 'desc')
|
||||
->filters([
|
||||
Tables\Filters\Filter::make('uid')
|
||||
->form([
|
||||
Forms\Components\TextInput::make('uid')
|
||||
Filter::make('uid')
|
||||
->schema([
|
||||
TextInput::make('uid')
|
||||
->label(__('label.username'))
|
||||
->placeholder('UID')
|
||||
,
|
||||
@@ -77,19 +85,19 @@ class UserMetaResource extends Resource
|
||||
return $query->when($data['uid'], fn (Builder $query, $value) => $query->where("uid", $value));
|
||||
})
|
||||
,
|
||||
Tables\Filters\SelectFilter::make('meta_key')
|
||||
SelectFilter::make('meta_key')
|
||||
->options(UserMeta::listProps())
|
||||
->label(__('label.name'))
|
||||
,
|
||||
])
|
||||
->actions([
|
||||
Tables\Actions\DeleteAction::make()->using(function (NexusModel $record) {
|
||||
->recordActions([
|
||||
DeleteAction::make()->using(function (NexusModel $record) {
|
||||
$record->delete();
|
||||
clear_user_cache($record->uid);
|
||||
do_log(sprintf("user: %d meta: %s was del by %s", $record->uid, $record->meta_key, Auth::user()->username));
|
||||
}),
|
||||
])
|
||||
->bulkActions([
|
||||
->toolbarActions([
|
||||
]);
|
||||
}
|
||||
|
||||
@@ -103,9 +111,9 @@ class UserMetaResource extends Resource
|
||||
public static function getPages(): array
|
||||
{
|
||||
return [
|
||||
'index' => Pages\ListUserMetas::route('/'),
|
||||
'create' => Pages\CreateUserMeta::route('/create'),
|
||||
'edit' => Pages\EditUserMeta::route('/{record}/edit'),
|
||||
'index' => ListUserMetas::route('/'),
|
||||
'create' => CreateUserMeta::route('/create'),
|
||||
'edit' => EditUserMeta::route('/{record}/edit'),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,11 +2,12 @@
|
||||
|
||||
namespace App\Filament\Resources\User\UserMetaResource\Pages;
|
||||
|
||||
use Filament\Actions\Contracts\HasActions;
|
||||
use App\Filament\Resources\User\UserMetaResource;
|
||||
use Filament\Pages\Actions;
|
||||
use Filament\Resources\Pages\CreateRecord;
|
||||
|
||||
class CreateUserMeta extends CreateRecord
|
||||
class CreateUserMeta extends CreateRecord implements HasActions
|
||||
{
|
||||
protected static string $resource = UserMetaResource::class;
|
||||
}
|
||||
|
||||
@@ -2,18 +2,20 @@
|
||||
|
||||
namespace App\Filament\Resources\User\UserMetaResource\Pages;
|
||||
|
||||
use Filament\Actions\Contracts\HasActions;
|
||||
use Filament\Actions\DeleteAction;
|
||||
use App\Filament\Resources\User\UserMetaResource;
|
||||
use Filament\Pages\Actions;
|
||||
use Filament\Resources\Pages\EditRecord;
|
||||
|
||||
class EditUserMeta extends EditRecord
|
||||
class EditUserMeta extends EditRecord implements HasActions
|
||||
{
|
||||
protected static string $resource = UserMetaResource::class;
|
||||
|
||||
protected function getHeaderActions(): array
|
||||
{
|
||||
return [
|
||||
Actions\DeleteAction::make(),
|
||||
DeleteAction::make(),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,6 +2,7 @@
|
||||
|
||||
namespace App\Filament\Resources\User\UserMetaResource\Pages;
|
||||
|
||||
use Filament\Actions\Contracts\HasActions;
|
||||
use App\Filament\PageList;
|
||||
use App\Filament\Resources\User\UserMetaResource;
|
||||
use App\Models\UserMeta;
|
||||
@@ -9,7 +10,7 @@ use Filament\Pages\Actions;
|
||||
use Filament\Resources\Pages\ListRecords;
|
||||
use Illuminate\Database\Eloquent\Builder;
|
||||
|
||||
class ListUserMetas extends PageList
|
||||
class ListUserMetas extends PageList implements HasActions
|
||||
{
|
||||
protected static string $resource = UserMetaResource::class;
|
||||
|
||||
|
||||
@@ -2,11 +2,15 @@
|
||||
|
||||
namespace App\Filament\Resources\User;
|
||||
|
||||
use Filament\Schemas\Schema;
|
||||
use Filament\Tables\Columns\TextColumn;
|
||||
use Filament\Tables\Filters\Filter;
|
||||
use Filament\Forms\Components\TextInput;
|
||||
use App\Filament\Resources\User\UserModifyLogResource\Pages\ManageUserModifyLogs;
|
||||
use App\Filament\Resources\User\UserModifyLogResource\Pages;
|
||||
use App\Filament\Resources\User\UserModifyLogResource\RelationManagers;
|
||||
use App\Models\UserModifyLog;
|
||||
use Filament\Forms;
|
||||
use Filament\Forms\Form;
|
||||
use Filament\Resources\Resource;
|
||||
use Filament\Tables;
|
||||
use Filament\Tables\Table;
|
||||
@@ -17,9 +21,9 @@ class UserModifyLogResource extends Resource
|
||||
{
|
||||
protected static ?string $model = UserModifyLog::class;
|
||||
|
||||
protected static ?string $navigationIcon = 'heroicon-o-rectangle-stack';
|
||||
protected static string | \BackedEnum | null $navigationIcon = 'heroicon-o-rectangle-stack';
|
||||
|
||||
protected static ?string $navigationGroup = 'User';
|
||||
protected static string | \UnitEnum | null $navigationGroup = 'User';
|
||||
|
||||
protected static ?int $navigationSort = 100;
|
||||
|
||||
@@ -33,10 +37,10 @@ class UserModifyLogResource extends Resource
|
||||
return self::getNavigationLabel();
|
||||
}
|
||||
|
||||
public static function form(Form $form): Form
|
||||
public static function form(Schema $schema): Schema
|
||||
{
|
||||
return $form
|
||||
->schema([
|
||||
return $schema
|
||||
->components([
|
||||
//
|
||||
]);
|
||||
}
|
||||
@@ -45,28 +49,28 @@ class UserModifyLogResource extends Resource
|
||||
{
|
||||
return $table
|
||||
->columns([
|
||||
Tables\Columns\TextColumn::make('id'),
|
||||
Tables\Columns\TextColumn::make('user_id')->label('UID'),
|
||||
Tables\Columns\TextColumn::make('user.username')
|
||||
TextColumn::make('id'),
|
||||
TextColumn::make('user_id')->label('UID'),
|
||||
TextColumn::make('user.username')
|
||||
->label(nexus_trans("label.username"))
|
||||
->formatStateUsing(fn ($record) => username_for_admin($record->user_id))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('content')->label(nexus_trans("user-modify-log.content")),
|
||||
Tables\Columns\TextColumn::make('created_at')->label(nexus_trans("label.created_at")),
|
||||
TextColumn::make('content')->label(nexus_trans("user-modify-log.content")),
|
||||
TextColumn::make('created_at')->label(nexus_trans("label.created_at")),
|
||||
])
|
||||
->filters([
|
||||
Tables\Filters\Filter::make('user_id')
|
||||
->form([
|
||||
Forms\Components\TextInput::make('user_id')
|
||||
Filter::make('user_id')
|
||||
->schema([
|
||||
TextInput::make('user_id')
|
||||
->label(__('UID'))
|
||||
,
|
||||
])->query(function (Builder $query, array $data) {
|
||||
return $query->when($data['user_id'], fn (Builder $query, $value) => $query->where("user_id", $value));
|
||||
})
|
||||
,
|
||||
Tables\Filters\Filter::make('user')
|
||||
->form([
|
||||
Forms\Components\TextInput::make('username')
|
||||
Filter::make('user')
|
||||
->schema([
|
||||
TextInput::make('username')
|
||||
->label(__('label.username'))
|
||||
,
|
||||
])->query(function (Builder $query, array $data) {
|
||||
@@ -75,9 +79,9 @@ class UserModifyLogResource extends Resource
|
||||
}));
|
||||
})
|
||||
,
|
||||
Tables\Filters\Filter::make('content')
|
||||
->form([
|
||||
Forms\Components\TextInput::make('content')
|
||||
Filter::make('content')
|
||||
->schema([
|
||||
TextInput::make('content')
|
||||
->label(__('user-modify-log.content'))
|
||||
,
|
||||
])->query(function (Builder $query, array $data) {
|
||||
@@ -86,11 +90,11 @@ class UserModifyLogResource extends Resource
|
||||
,
|
||||
])
|
||||
->defaultSort('id', 'desc')
|
||||
->actions([
|
||||
->recordActions([
|
||||
// Tables\Actions\EditAction::make(),
|
||||
// Tables\Actions\DeleteAction::make(),
|
||||
])
|
||||
->bulkActions([
|
||||
->toolbarActions([
|
||||
// Tables\Actions\BulkActionGroup::make([
|
||||
// Tables\Actions\DeleteBulkAction::make(),
|
||||
// ]),
|
||||
@@ -100,7 +104,7 @@ class UserModifyLogResource extends Resource
|
||||
public static function getPages(): array
|
||||
{
|
||||
return [
|
||||
'index' => Pages\ManageUserModifyLogs::route('/'),
|
||||
'index' => ManageUserModifyLogs::route('/'),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,12 +2,13 @@
|
||||
|
||||
namespace App\Filament\Resources\User\UserModifyLogResource\Pages;
|
||||
|
||||
use Filament\Actions\Contracts\HasActions;
|
||||
use App\Filament\PageListSingle;
|
||||
use App\Filament\Resources\User\UserModifyLogResource;
|
||||
use Filament\Actions;
|
||||
use Filament\Resources\Pages\ManageRecords;
|
||||
|
||||
class ManageUserModifyLogs extends PageListSingle
|
||||
class ManageUserModifyLogs extends PageListSingle implements HasActions
|
||||
{
|
||||
protected static string $resource = UserModifyLogResource::class;
|
||||
|
||||
|
||||
@@ -2,6 +2,26 @@
|
||||
|
||||
namespace App\Filament\Resources\User;
|
||||
|
||||
use Filament\Schemas\Schema;
|
||||
use Filament\Forms\Components\TextInput;
|
||||
use App\Filament\Resources\User\UserResource\Pages\CreateUser;
|
||||
use Filament\Forms\Components\Select;
|
||||
use Filament\Tables\Columns\TextColumn;
|
||||
use Filament\Tables\Columns\Column;
|
||||
use Filament\Tables\Columns\BadgeColumn;
|
||||
use Filament\Tables\Filters\Filter;
|
||||
use Filament\Tables\Filters\SelectFilter;
|
||||
use Filament\Actions\ViewAction;
|
||||
use Filament\Schemas\Components\Group;
|
||||
use Filament\Infolists\Components\TextEntry;
|
||||
use Filament\Forms\Components\Radio;
|
||||
use Filament\Schemas\Components\Utilities\Get;
|
||||
use Filament\Forms\Components\DateTimePicker;
|
||||
use Exception;
|
||||
use Filament\Forms\Components\Hidden;
|
||||
use App\Filament\Resources\User\UserResource\Pages\ListUsers;
|
||||
use App\Filament\Resources\User\UserResource\Pages\UserProfile;
|
||||
use Filament\Actions\BulkAction;
|
||||
use App\Filament\OptionsTrait;
|
||||
use App\Filament\Resources\User\UserResource\Pages;
|
||||
use App\Filament\Resources\User\UserResource\RelationManagers;
|
||||
@@ -10,12 +30,10 @@ use App\Repositories\UserRepository;
|
||||
use Filament\Actions\Action;
|
||||
use Filament\Forms;
|
||||
use Filament\Forms\Components\Grid;
|
||||
use Filament\Forms\Form;
|
||||
use Filament\Resources\Resource;
|
||||
use Filament\Tables\Table;
|
||||
use Filament\Tables;
|
||||
use Filament\Infolists;
|
||||
use Filament\Infolists\Infolist;
|
||||
use Filament\Infolists\Components;
|
||||
|
||||
use Illuminate\Database\Eloquent\Builder;
|
||||
@@ -30,9 +48,9 @@ class UserResource extends Resource
|
||||
|
||||
protected static ?string $model = User::class;
|
||||
|
||||
protected static ?string $navigationIcon = 'heroicon-o-users';
|
||||
protected static string | \BackedEnum | null $navigationIcon = 'heroicon-o-users';
|
||||
|
||||
protected static ?string $navigationGroup = 'User';
|
||||
protected static string | \UnitEnum | null $navigationGroup = 'User';
|
||||
|
||||
protected static ?int $navigationSort = 1;
|
||||
|
||||
@@ -56,16 +74,16 @@ class UserResource extends Resource
|
||||
return self::getNavigationLabel();
|
||||
}
|
||||
|
||||
public static function form(Form $form): Form
|
||||
public static function form(Schema $schema): Schema
|
||||
{
|
||||
return $form
|
||||
->schema([
|
||||
Forms\Components\TextInput::make('username')->required(),
|
||||
Forms\Components\TextInput::make('email')->required(),
|
||||
Forms\Components\TextInput::make('password')->password()->required()->visibleOn(Pages\CreateUser::class),
|
||||
Forms\Components\TextInput::make('password_confirmation')->password()->required()->same('password')->visibleOn(Pages\CreateUser::class),
|
||||
Forms\Components\TextInput::make('id')->integer(),
|
||||
Forms\Components\Select::make('class')->options(User::listClass(User::CLASS_PEASANT, Auth::user()->class - 1)),
|
||||
return $schema
|
||||
->components([
|
||||
TextInput::make('username')->required(),
|
||||
TextInput::make('email')->required(),
|
||||
TextInput::make('password')->password()->required()->visibleOn(CreateUser::class),
|
||||
TextInput::make('password_confirmation')->password()->required()->same('password')->visibleOn(CreateUser::class),
|
||||
TextInput::make('id')->integer(),
|
||||
Select::make('class')->options(User::listClass(User::CLASS_PEASANT, Auth::user()->class - 1)),
|
||||
]);
|
||||
}
|
||||
|
||||
@@ -73,108 +91,108 @@ class UserResource extends Resource
|
||||
{
|
||||
return $table
|
||||
->columns([
|
||||
Tables\Columns\TextColumn::make('id')->sortable()->searchable(),
|
||||
Tables\Columns\TextColumn::make('username')->searchable()->label(__("label.user.username"))
|
||||
TextColumn::make('id')->sortable()->searchable(),
|
||||
TextColumn::make('username')->searchable()->label(__("label.user.username"))
|
||||
->formatStateUsing(fn ($record) => new HtmlString(get_username($record->id, false, true, true, true))),
|
||||
Tables\Columns\TextColumn::make('email')->searchable()->label(__("label.email")),
|
||||
Tables\Columns\TextColumn::make('class')->label('Class')
|
||||
->formatStateUsing(fn(Tables\Columns\Column $column) => $column->getRecord()->classText)
|
||||
TextColumn::make('email')->searchable()->label(__("label.email")),
|
||||
TextColumn::make('class')->label('Class')
|
||||
->formatStateUsing(fn(Column $column) => $column->getRecord()->classText)
|
||||
->sortable()->label(__("label.user.class")),
|
||||
Tables\Columns\TextColumn::make('uploaded')->label('Uploaded')
|
||||
->formatStateUsing(fn(Tables\Columns\Column $column) => $column->getRecord()->uploadedText)
|
||||
TextColumn::make('uploaded')->label('Uploaded')
|
||||
->formatStateUsing(fn(Column $column) => $column->getRecord()->uploadedText)
|
||||
->sortable()->label(__("label.uploaded")),
|
||||
Tables\Columns\TextColumn::make('downloaded')->label('Downloaded')
|
||||
->formatStateUsing(fn(Tables\Columns\Column $column) => $column->getRecord()->downloadedText)
|
||||
TextColumn::make('downloaded')->label('Downloaded')
|
||||
->formatStateUsing(fn(Column $column) => $column->getRecord()->downloadedText)
|
||||
->sortable()->label(__("label.downloaded")),
|
||||
Tables\Columns\BadgeColumn::make('status')->colors(['success' => 'confirmed', 'warning' => 'pending'])->label(__("label.user.status")),
|
||||
Tables\Columns\BadgeColumn::make('enabled')->colors(['success' => 'yes', 'danger' => 'no'])->label(__("label.user.enabled")),
|
||||
Tables\Columns\BadgeColumn::make('downloadpos')->colors(['success' => 'yes', 'danger' => 'no'])->label(__("label.user.downloadpos")),
|
||||
Tables\Columns\BadgeColumn::make('parked')->colors(['success' => 'yes', 'danger' => 'no'])->label(__("label.user.parked")),
|
||||
Tables\Columns\TextColumn::make('added')->sortable()->dateTime('Y-m-d H:i')->label(__("label.added")),
|
||||
Tables\Columns\TextColumn::make('last_access')->dateTime('Y-m-d H:i')->label(__("label.last_access")),
|
||||
BadgeColumn::make('status')->colors(['success' => 'confirmed', 'warning' => 'pending'])->label(__("label.user.status")),
|
||||
BadgeColumn::make('enabled')->colors(['success' => 'yes', 'danger' => 'no'])->label(__("label.user.enabled")),
|
||||
BadgeColumn::make('downloadpos')->colors(['success' => 'yes', 'danger' => 'no'])->label(__("label.user.downloadpos")),
|
||||
BadgeColumn::make('parked')->colors(['success' => 'yes', 'danger' => 'no'])->label(__("label.user.parked")),
|
||||
TextColumn::make('added')->sortable()->dateTime('Y-m-d H:i')->label(__("label.added")),
|
||||
TextColumn::make('last_access')->dateTime('Y-m-d H:i')->label(__("label.last_access")),
|
||||
])
|
||||
->defaultSort('added', 'desc')
|
||||
->filters([
|
||||
Tables\Filters\Filter::make('id')
|
||||
->form([
|
||||
Forms\Components\TextInput::make('id')
|
||||
Filter::make('id')
|
||||
->schema([
|
||||
TextInput::make('id')
|
||||
->placeholder('UID')
|
||||
,
|
||||
])->query(function (Builder $query, array $data) {
|
||||
return $query->when($data['id'], fn (Builder $query, $id) => $query->where("id", $id));
|
||||
})
|
||||
,
|
||||
Tables\Filters\SelectFilter::make('class')->options(array_column(User::$classes, 'text'))->label(__('label.user.class')),
|
||||
Tables\Filters\SelectFilter::make('status')->options(['confirmed' => 'confirmed', 'pending' => 'pending'])->label(__('label.user.status')),
|
||||
Tables\Filters\SelectFilter::make('enabled')->options(self::$yesOrNo)->label(__('label.user.enabled')),
|
||||
Tables\Filters\SelectFilter::make('downloadpos')->options(self::$yesOrNo)->label(__('label.user.downloadpos')),
|
||||
Tables\Filters\SelectFilter::make('parked')->options(self::$yesOrNo)->label(__('label.user.parked')),
|
||||
SelectFilter::make('class')->options(array_column(User::$classes, 'text'))->label(__('label.user.class')),
|
||||
SelectFilter::make('status')->options(['confirmed' => 'confirmed', 'pending' => 'pending'])->label(__('label.user.status')),
|
||||
SelectFilter::make('enabled')->options(self::$yesOrNo)->label(__('label.user.enabled')),
|
||||
SelectFilter::make('downloadpos')->options(self::$yesOrNo)->label(__('label.user.downloadpos')),
|
||||
SelectFilter::make('parked')->options(self::$yesOrNo)->label(__('label.user.parked')),
|
||||
])
|
||||
->actions([
|
||||
Tables\Actions\ViewAction::make(),
|
||||
->recordActions([
|
||||
ViewAction::make(),
|
||||
])
|
||||
->bulkActions(self::getBulkActions());
|
||||
->toolbarActions(self::getBulkActions());
|
||||
}
|
||||
|
||||
public static function infolist(Infolist $infolist): Infolist
|
||||
public static function infolist(Schema $schema): Schema
|
||||
{
|
||||
return $infolist
|
||||
->schema([
|
||||
Components\Grid::make(2)->schema([
|
||||
Components\Group::make([
|
||||
Infolists\Components\TextEntry::make('id')->label("UID"),
|
||||
Infolists\Components\TextEntry::make('username')
|
||||
return $schema
|
||||
->components([
|
||||
\Filament\Schemas\Components\Grid::make(2)->schema([
|
||||
Group::make([
|
||||
TextEntry::make('id')->label("UID"),
|
||||
TextEntry::make('username')
|
||||
->label(__("label.user.username"))
|
||||
->formatStateUsing(fn ($record) => get_username($record->id, false, true, true, true))
|
||||
->html()
|
||||
,
|
||||
Infolists\Components\TextEntry::make('email')
|
||||
TextEntry::make('email')
|
||||
->label(__("label.email"))
|
||||
->copyable()
|
||||
->placeholder("点击复制")
|
||||
,
|
||||
Infolists\Components\TextEntry::make('passkey')->limit(10)->copyable(),
|
||||
Infolists\Components\TextEntry::make('added')->label(__("label.added")),
|
||||
Infolists\Components\TextEntry::make('last_access')->label(__("label.last_access")),
|
||||
Infolists\Components\TextEntry::make('inviter.username')->label(__("label.user.invite_by")),
|
||||
Infolists\Components\TextEntry::make('parked')->label(__("label.user.parked")),
|
||||
Infolists\Components\TextEntry::make('offer_allowed_count')->label(__("label.user.offer_allowed_count")),
|
||||
Infolists\Components\TextEntry::make('seed_points')->label(__("label.user.seed_points")),
|
||||
Infolists\Components\TextEntry::make('uploadedText')->label(__("label.uploaded")),
|
||||
Infolists\Components\TextEntry::make('downloadedText')->label(__("label.downloaded")),
|
||||
Infolists\Components\TextEntry::make('seedbonus')->label(__("label.user.seedbonus")),
|
||||
Infolists\Components\TextEntry::make('seed_points')->label(__("label.user.seed_points")),
|
||||
TextEntry::make('passkey')->limit(10)->copyable(),
|
||||
TextEntry::make('added')->label(__("label.added")),
|
||||
TextEntry::make('last_access')->label(__("label.last_access")),
|
||||
TextEntry::make('inviter.username')->label(__("label.user.invite_by")),
|
||||
TextEntry::make('parked')->label(__("label.user.parked")),
|
||||
TextEntry::make('offer_allowed_count')->label(__("label.user.offer_allowed_count")),
|
||||
TextEntry::make('seed_points')->label(__("label.user.seed_points")),
|
||||
TextEntry::make('uploadedText')->label(__("label.uploaded")),
|
||||
TextEntry::make('downloadedText')->label(__("label.downloaded")),
|
||||
TextEntry::make('seedbonus')->label(__("label.user.seedbonus")),
|
||||
TextEntry::make('seed_points')->label(__("label.user.seed_points")),
|
||||
])
|
||||
->columns(6)
|
||||
->columnSpan(4)
|
||||
,
|
||||
|
||||
Components\Group::make([
|
||||
Infolists\Components\TextEntry::make('status')
|
||||
Group::make([
|
||||
TextEntry::make('status')
|
||||
->label(__('label.user.status'))
|
||||
->badge()
|
||||
->colors(['success' => User::STATUS_CONFIRMED, 'warning' => User::STATUS_PENDING])
|
||||
->hintAction(self::buildActionConfirm())
|
||||
,
|
||||
|
||||
Infolists\Components\TextEntry::make('classText')
|
||||
TextEntry::make('classText')
|
||||
->label(__("label.user.class"))
|
||||
->hintAction(self::buildActionChangeClass())
|
||||
,
|
||||
|
||||
Infolists\Components\TextEntry::make('enabled')
|
||||
TextEntry::make('enabled')
|
||||
->label(__("label.user.enabled"))
|
||||
->badge()
|
||||
->colors(['success' => 'yes', 'warning' => 'no'])
|
||||
->hintAction(self::buildActionEnableDisable())
|
||||
,
|
||||
Infolists\Components\TextEntry::make('downloadpos')
|
||||
TextEntry::make('downloadpos')
|
||||
->label(__("label.user.downloadpos"))
|
||||
->badge()
|
||||
->colors(['success' => 'yes', 'warning' => 'no'])
|
||||
->hintAction(self::buildActionChangeDownloadPos())
|
||||
,
|
||||
Infolists\Components\TextEntry::make('twoFactorAuthenticationStatus')
|
||||
TextEntry::make('twoFactorAuthenticationStatus')
|
||||
->label(__("label.user.two_step_authentication"))
|
||||
->badge()
|
||||
->colors(['success' => 'yes', 'warning' => 'no'])
|
||||
@@ -186,34 +204,34 @@ class UserResource extends Resource
|
||||
]);
|
||||
}
|
||||
|
||||
private static function buildActionChangeClass(): Infolists\Components\Actions\Action
|
||||
private static function buildActionChangeClass(): Action
|
||||
{
|
||||
return Infolists\Components\Actions\Action::make("changeClass")
|
||||
return Action::make("changeClass")
|
||||
->label(__('label.change'))
|
||||
->button()
|
||||
->visible(fn (User $record): bool => (Auth::user()->class > $record->class))
|
||||
->form([
|
||||
Forms\Components\Select::make('class')
|
||||
->schema([
|
||||
Select::make('class')
|
||||
->options(User::listClass(User::CLASS_PEASANT, Auth::user()->class - 1))
|
||||
->default(fn (User $record) => $record->class)
|
||||
->label(__('user.labels.class'))
|
||||
->required()
|
||||
->reactive()
|
||||
,
|
||||
Forms\Components\Radio::make('vip_added')
|
||||
Radio::make('vip_added')
|
||||
->options(self::getYesNoOptions('yes', 'no'))
|
||||
->default(fn (User $record) => $record->vip_added)
|
||||
->label(__('user.labels.vip_added'))
|
||||
->helperText(__('user.labels.vip_added_help'))
|
||||
->hidden(fn (\Filament\Forms\Get $get) => $get('class') != User::CLASS_VIP)
|
||||
->hidden(fn (Get $get) => $get('class') != User::CLASS_VIP)
|
||||
,
|
||||
Forms\Components\DateTimePicker::make('vip_until')
|
||||
DateTimePicker::make('vip_until')
|
||||
->default(fn (User $record) => $record->vip_until)
|
||||
->label(__('user.labels.vip_until'))
|
||||
->helperText(__('user.labels.vip_until_help'))
|
||||
->hidden(fn (\Filament\Forms\Get $get) => $get('class') != User::CLASS_VIP)
|
||||
->hidden(fn (Get $get) => $get('class') != User::CLASS_VIP)
|
||||
,
|
||||
Forms\Components\TextInput::make('reason')
|
||||
TextInput::make('reason')
|
||||
->label(__('admin.resources.user.actions.enable_disable_reason'))
|
||||
->placeholder(__('admin.resources.user.actions.enable_disable_reason_placeholder'))
|
||||
,
|
||||
@@ -223,15 +241,15 @@ class UserResource extends Resource
|
||||
try {
|
||||
$userRep->changeClass(Auth::user(), $record, $data['class'], $data['reason'], $data);
|
||||
send_admin_success_notification();
|
||||
} catch (\Exception $exception) {
|
||||
} catch (Exception $exception) {
|
||||
send_admin_fail_notification($exception->getMessage());
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
private static function buildActionConfirm(): Infolists\Components\Actions\Action
|
||||
private static function buildActionConfirm(): Action
|
||||
{
|
||||
return Infolists\Components\Actions\Action::make(__('admin.resources.user.actions.confirm_btn'))
|
||||
return Action::make(__('admin.resources.user.actions.confirm_btn'))
|
||||
->modalHeading(__('admin.resources.user.actions.confirm_btn'))
|
||||
->requiresConfirmation()
|
||||
->visible(fn (User $record): bool => (Auth::user()->class > $record->class))
|
||||
@@ -250,17 +268,17 @@ class UserResource extends Resource
|
||||
});
|
||||
}
|
||||
|
||||
private static function buildActionEnableDisable(): Infolists\Components\Actions\Action
|
||||
private static function buildActionEnableDisable(): Action
|
||||
{
|
||||
return Infolists\Components\Actions\Action::make("changeClass")
|
||||
return Action::make("changeClass")
|
||||
->label(fn (User $record) => $record->enabled == 'yes' ? __('admin.resources.user.actions.disable_modal_btn') : __('admin.resources.user.actions.enable_modal_btn'))
|
||||
->modalHeading(fn (User $record) => $record->enabled == 'yes' ? __('admin.resources.user.actions.disable_modal_title') : __('admin.resources.user.actions.enable_modal_title'))
|
||||
->button()
|
||||
->visible(fn (User $record): bool => (Auth::user()->class > $record->class))
|
||||
->form([
|
||||
Forms\Components\TextInput::make('reason')->label(__('admin.resources.user.actions.enable_disable_reason'))->placeholder(__('admin.resources.user.actions.enable_disable_reason_placeholder')),
|
||||
Forms\Components\Hidden::make('action')->default(fn (User $record) => $record->enabled == 'yes' ? 'disable' : 'enable'),
|
||||
Forms\Components\Hidden::make('uid')->default(fn (User $record) => $record->id),
|
||||
->schema([
|
||||
TextInput::make('reason')->label(__('admin.resources.user.actions.enable_disable_reason'))->placeholder(__('admin.resources.user.actions.enable_disable_reason_placeholder')),
|
||||
Hidden::make('action')->default(fn (User $record) => $record->enabled == 'yes' ? 'disable' : 'enable'),
|
||||
Hidden::make('uid')->default(fn (User $record) => $record->id),
|
||||
])
|
||||
->action(function (User $record, array $data) {
|
||||
$userRep = self::getRep();
|
||||
@@ -271,15 +289,15 @@ class UserResource extends Resource
|
||||
$userRep->disableUser(Auth::user(), $data['uid'], $data['reason']);
|
||||
}
|
||||
send_admin_success_notification();
|
||||
} catch (\Exception $exception) {
|
||||
} catch (Exception $exception) {
|
||||
send_admin_fail_notification($exception->getMessage());
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
private static function buildActionChangeDownloadPos(): Infolists\Components\Actions\Action
|
||||
private static function buildActionChangeDownloadPos(): Action
|
||||
{
|
||||
return Infolists\Components\Actions\Action::make("changeDownloadPos")
|
||||
return Action::make("changeDownloadPos")
|
||||
->label(fn (User $record) => $record->downloadpos == 'yes' ? __('admin.resources.user.actions.disable_download_privileges_btn') : __('admin.resources.user.actions.enable_download_privileges_btn'))
|
||||
->button()
|
||||
->requiresConfirmation()
|
||||
@@ -289,16 +307,16 @@ class UserResource extends Resource
|
||||
try {
|
||||
$userRep->updateDownloadPrivileges(Auth::user(), $record->id, $record->downloadpos == 'yes' ? 'no' : 'yes');
|
||||
send_admin_success_notification();
|
||||
} catch (\Exception $exception) {
|
||||
} catch (Exception $exception) {
|
||||
send_admin_fail_notification($exception->getMessage());
|
||||
}
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
private static function buildActionCancelTwoStepAuthentication(): Infolists\Components\Actions\Action
|
||||
private static function buildActionCancelTwoStepAuthentication(): Action
|
||||
{
|
||||
return Infolists\Components\Actions\Action::make("twoStepAuthentication")
|
||||
return Action::make("twoStepAuthentication")
|
||||
->label(__('admin.resources.user.actions.disable_two_step_authentication'))
|
||||
->button()
|
||||
->visible(fn (User $record) => $record->two_step_secret != "")
|
||||
@@ -309,7 +327,7 @@ class UserResource extends Resource
|
||||
try {
|
||||
$userRep->removeTwoStepAuthentication(Auth::user(), $record->id);
|
||||
send_admin_success_notification();
|
||||
} catch (\Exception $exception) {
|
||||
} catch (Exception $exception) {
|
||||
send_admin_fail_notification($exception->getMessage());
|
||||
}
|
||||
});
|
||||
@@ -326,11 +344,11 @@ class UserResource extends Resource
|
||||
public static function getPages(): array
|
||||
{
|
||||
return [
|
||||
'index' => Pages\ListUsers::route('/'),
|
||||
'create' => Pages\CreateUser::route('/create'),
|
||||
'index' => ListUsers::route('/'),
|
||||
'create' => CreateUser::route('/create'),
|
||||
// 'edit' => Pages\EditUser::route('/{record}/edit'),
|
||||
// 'view' => Pages\ViewUser::route('/{record}'),
|
||||
'view' => Pages\UserProfile::route('/{record}'),
|
||||
'view' => UserProfile::route('/{record}'),
|
||||
];
|
||||
}
|
||||
|
||||
@@ -338,7 +356,7 @@ class UserResource extends Resource
|
||||
{
|
||||
$actions = [];
|
||||
if (filament()->auth()->user()->class >= User::CLASS_SYSOP) {
|
||||
$actions[] = Tables\Actions\BulkAction::make('confirm')
|
||||
$actions[] = BulkAction::make('confirm')
|
||||
->label(__('admin.resources.user.actions.confirm_bulk'))
|
||||
->requiresConfirmation()
|
||||
->deselectRecordsAfterCompletion()
|
||||
|
||||
@@ -2,13 +2,15 @@
|
||||
|
||||
namespace App\Filament\Resources\User\UserResource\Pages;
|
||||
|
||||
use Filament\Actions\Contracts\HasActions;
|
||||
use Exception;
|
||||
use App\Filament\Resources\User\UserResource;
|
||||
use App\Repositories\UserRepository;
|
||||
use Filament\Pages\Actions;
|
||||
use Filament\Resources\Pages\CreateRecord;
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
|
||||
class CreateUser extends CreateRecord
|
||||
class CreateUser extends CreateRecord implements HasActions
|
||||
{
|
||||
protected static string $resource = UserResource::class;
|
||||
|
||||
@@ -20,7 +22,7 @@ class CreateUser extends CreateRecord
|
||||
$this->record = $userRep->store($data);
|
||||
send_admin_success_notification();
|
||||
$this->redirect($this->getRedirectUrl());
|
||||
} catch (\Exception $exception) {
|
||||
} catch (Exception $exception) {
|
||||
send_admin_fail_notification($exception->getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,18 +2,20 @@
|
||||
|
||||
namespace App\Filament\Resources\User\UserResource\Pages;
|
||||
|
||||
use Filament\Actions\Contracts\HasActions;
|
||||
use Filament\Actions\DeleteAction;
|
||||
use App\Filament\Resources\User\UserResource;
|
||||
use Filament\Pages\Actions;
|
||||
use Filament\Resources\Pages\EditRecord;
|
||||
|
||||
class EditUser extends EditRecord
|
||||
class EditUser extends EditRecord implements HasActions
|
||||
{
|
||||
protected static string $resource = UserResource::class;
|
||||
|
||||
protected function getHeaderActions(): array
|
||||
{
|
||||
return [
|
||||
Actions\DeleteAction::make(),
|
||||
DeleteAction::make(),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,6 +2,9 @@
|
||||
|
||||
namespace App\Filament\Resources\User\UserResource\Pages;
|
||||
|
||||
use Filament\Actions\Contracts\HasActions;
|
||||
use Filament\Actions\CreateAction;
|
||||
use Filament\Tables\Enums\FiltersLayout;
|
||||
use App\Filament\PageList;
|
||||
use App\Filament\Resources\User\UserResource;
|
||||
use Filament\Pages\Actions;
|
||||
@@ -9,14 +12,14 @@ use Filament\Resources\Pages\ListRecords;
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
use Filament\Tables\Filters\Layout;
|
||||
|
||||
class ListUsers extends PageList
|
||||
class ListUsers extends PageList implements HasActions
|
||||
{
|
||||
protected static string $resource = UserResource::class;
|
||||
|
||||
protected function getHeaderActions(): array
|
||||
{
|
||||
return [
|
||||
Actions\CreateAction::make(),
|
||||
CreateAction::make(),
|
||||
];
|
||||
}
|
||||
|
||||
@@ -28,7 +31,7 @@ class ListUsers extends PageList
|
||||
|
||||
protected function getTableFiltersLayout(): ?string
|
||||
{
|
||||
return \Filament\Tables\Enums\FiltersLayout::AboveContent;
|
||||
return FiltersLayout::AboveContent;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -2,6 +2,16 @@
|
||||
|
||||
namespace App\Filament\Resources\User\UserResource\Pages;
|
||||
|
||||
use Filament\Actions\Contracts\HasActions;
|
||||
use Filament\Actions\Action;
|
||||
use Filament\Forms\Components\TextInput;
|
||||
use Filament\Forms\Components\Hidden;
|
||||
use Exception;
|
||||
use Filament\Forms\Components\Radio;
|
||||
use Filament\Schemas\Components\Utilities\Get;
|
||||
use Filament\Forms\Components\Select;
|
||||
use Filament\Forms\Components\DateTimePicker;
|
||||
use Filament\Actions\DeleteAction;
|
||||
use App\Filament\OptionsTrait;
|
||||
use App\Filament\Resources\User\UserResource;
|
||||
use App\Models\Exam;
|
||||
@@ -23,7 +33,7 @@ use Filament\Resources\Pages\ViewRecord;
|
||||
use Illuminate\Support\Facades\Auth;
|
||||
use Nexus\Database\NexusDB;
|
||||
|
||||
class UserProfile extends ViewRecord
|
||||
class UserProfile extends ViewRecord implements HasActions
|
||||
{
|
||||
use InteractsWithRecord;
|
||||
use HasRelationManagers;
|
||||
@@ -71,15 +81,15 @@ class UserProfile extends ViewRecord
|
||||
return $actions;
|
||||
}
|
||||
|
||||
private function buildEnableDisableAction(): Actions\Action
|
||||
private function buildEnableDisableAction(): Action
|
||||
{
|
||||
return Actions\Action::make('enable_disable')
|
||||
return Action::make('enable_disable')
|
||||
->label($this->record->enabled == 'yes' ? __('admin.resources.user.actions.disable_modal_btn') : __('admin.resources.user.actions.enable_modal_btn'))
|
||||
->modalHeading($this->record->enabled == 'yes' ? __('admin.resources.user.actions.disable_modal_title') : __('admin.resources.user.actions.enable_modal_title'))
|
||||
->form([
|
||||
Forms\Components\TextInput::make('reason')->label(__('admin.resources.user.actions.enable_disable_reason'))->placeholder(__('admin.resources.user.actions.enable_disable_reason_placeholder')),
|
||||
Forms\Components\Hidden::make('action')->default($this->record->enabled == 'yes' ? 'disable' : 'enable'),
|
||||
Forms\Components\Hidden::make('uid')->default($this->record->id),
|
||||
->schema([
|
||||
TextInput::make('reason')->label(__('admin.resources.user.actions.enable_disable_reason'))->placeholder(__('admin.resources.user.actions.enable_disable_reason_placeholder')),
|
||||
Hidden::make('action')->default($this->record->enabled == 'yes' ? 'disable' : 'enable'),
|
||||
Hidden::make('uid')->default($this->record->id),
|
||||
])
|
||||
// ->visible(false)
|
||||
// ->hidden(true)
|
||||
@@ -92,15 +102,15 @@ class UserProfile extends ViewRecord
|
||||
$userRep->disableUser(Auth::user(), $data['uid'], $data['reason']);
|
||||
}
|
||||
$this->sendSuccessNotification();
|
||||
} catch (\Exception $exception) {
|
||||
} catch (Exception $exception) {
|
||||
$this->sendFailNotification($exception->getMessage());
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
private function buildDisableTwoStepAuthenticationAction(): Actions\Action
|
||||
private function buildDisableTwoStepAuthenticationAction(): Action
|
||||
{
|
||||
return Actions\Action::make(__('admin.resources.user.actions.disable_two_step_authentication'))
|
||||
return Action::make(__('admin.resources.user.actions.disable_two_step_authentication'))
|
||||
->modalHeading(__('admin.resources.user.actions.disable_two_step_authentication'))
|
||||
->requiresConfirmation()
|
||||
->action(function ($data) {
|
||||
@@ -108,18 +118,18 @@ class UserProfile extends ViewRecord
|
||||
try {
|
||||
$userRep->removeTwoStepAuthentication(Auth::user(), $this->record->id);
|
||||
$this->sendSuccessNotification();
|
||||
} catch (\Exception $exception) {
|
||||
} catch (Exception $exception) {
|
||||
$this->sendFailNotification($exception->getMessage());
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
private function buildChangeBonusEtcAction(): Actions\Action
|
||||
private function buildChangeBonusEtcAction(): Action
|
||||
{
|
||||
return Actions\Action::make(__('admin.resources.user.actions.change_bonus_etc_btn'))
|
||||
return Action::make(__('admin.resources.user.actions.change_bonus_etc_btn'))
|
||||
->modalHeading(__('admin.resources.user.actions.change_bonus_etc_btn'))
|
||||
->form([
|
||||
Forms\Components\Radio::make('field')->options([
|
||||
->schema([
|
||||
Radio::make('field')->options([
|
||||
'uploaded' => __('label.user.uploaded'),
|
||||
'downloaded' => __('label.user.downloaded'),
|
||||
'invites' => __('label.user.invites'),
|
||||
@@ -132,7 +142,7 @@ class UserProfile extends ViewRecord
|
||||
->required()
|
||||
->reactive()
|
||||
,
|
||||
Forms\Components\Radio::make('action')->options([
|
||||
Radio::make('action')->options([
|
||||
'Increment' => __("admin.resources.user.actions.change_bonus_etc_action_increment"),
|
||||
'Decrement' => __("admin.resources.user.actions.change_bonus_etc_action_decrement"),
|
||||
])
|
||||
@@ -140,18 +150,18 @@ class UserProfile extends ViewRecord
|
||||
->inline()
|
||||
->required()
|
||||
,
|
||||
Forms\Components\TextInput::make('value')->integer()->required()
|
||||
TextInput::make('value')->integer()->required()
|
||||
->label(__('admin.resources.user.actions.change_bonus_etc_value_label'))
|
||||
->helperText(__('admin.resources.user.actions.change_bonus_etc_value_help'))
|
||||
,
|
||||
|
||||
Forms\Components\TextInput::make('duration')->integer()
|
||||
TextInput::make('duration')->integer()
|
||||
->label(__('admin.resources.user.actions.change_bonus_etc_duration_label'))
|
||||
->helperText(__('admin.resources.user.actions.change_bonus_etc_duration_help'))
|
||||
->hidden(fn (\Filament\Forms\Get $get) => $get('field') != 'tmp_invites')
|
||||
->hidden(fn (Get $get) => $get('field') != 'tmp_invites')
|
||||
,
|
||||
|
||||
Forms\Components\TextInput::make('reason')
|
||||
TextInput::make('reason')
|
||||
->label(__('admin.resources.user.actions.change_bonus_etc_reason_label'))
|
||||
,
|
||||
])
|
||||
@@ -164,7 +174,7 @@ class UserProfile extends ViewRecord
|
||||
$userRep->incrementDecrement(Auth::user(), $this->record->id, $data['action'], $data['field'], $data['value'], $data['reason']);
|
||||
}
|
||||
$this->sendSuccessNotification();
|
||||
} catch (\Exception $exception) {
|
||||
} catch (Exception $exception) {
|
||||
$this->sendFailNotification($exception->getMessage());
|
||||
}
|
||||
});
|
||||
@@ -172,11 +182,11 @@ class UserProfile extends ViewRecord
|
||||
|
||||
private function buildResetPasswordAction()
|
||||
{
|
||||
return Actions\Action::make(__('admin.resources.user.actions.reset_password_btn'))
|
||||
return Action::make(__('admin.resources.user.actions.reset_password_btn'))
|
||||
->modalHeading(__('admin.resources.user.actions.reset_password_btn'))
|
||||
->form([
|
||||
Forms\Components\TextInput::make('password')->label(__('admin.resources.user.actions.reset_password_label'))->required(),
|
||||
Forms\Components\TextInput::make('password_confirmation')
|
||||
->schema([
|
||||
TextInput::make('password')->label(__('admin.resources.user.actions.reset_password_label'))->required(),
|
||||
TextInput::make('password_confirmation')
|
||||
->label(__('admin.resources.user.actions.reset_password_confirmation_label'))
|
||||
->same('password')
|
||||
->required(),
|
||||
@@ -186,7 +196,7 @@ class UserProfile extends ViewRecord
|
||||
try {
|
||||
$userRep->resetPassword($this->record->id, $data['password'], $data['password_confirmation']);
|
||||
$this->sendSuccessNotification();
|
||||
} catch (\Exception $exception) {
|
||||
} catch (Exception $exception) {
|
||||
$this->sendFailNotification($exception->getMessage());
|
||||
}
|
||||
});
|
||||
@@ -194,14 +204,14 @@ class UserProfile extends ViewRecord
|
||||
|
||||
private function buildAssignExamAction()
|
||||
{
|
||||
return Actions\Action::make(__('admin.resources.user.actions.assign_exam_btn'))
|
||||
return Action::make(__('admin.resources.user.actions.assign_exam_btn'))
|
||||
->modalHeading(__('admin.resources.user.actions.assign_exam_btn'))
|
||||
->form([
|
||||
Forms\Components\Select::make('exam_id')
|
||||
->schema([
|
||||
Select::make('exam_id')
|
||||
->options((new ExamRepository())->listMatchExam($this->record->id)->pluck('name', 'id'))
|
||||
->label(__('admin.resources.user.actions.assign_exam_exam_label'))->required(),
|
||||
Forms\Components\DateTimePicker::make('begin')->label(__('admin.resources.user.actions.assign_exam_begin_label')),
|
||||
Forms\Components\DateTimePicker::make('end')->label(__('admin.resources.user.actions.assign_exam_end_label'))
|
||||
DateTimePicker::make('begin')->label(__('admin.resources.user.actions.assign_exam_begin_label')),
|
||||
DateTimePicker::make('end')->label(__('admin.resources.user.actions.assign_exam_end_label'))
|
||||
->helperText(__('admin.resources.user.actions.assign_exam_end_help')),
|
||||
|
||||
])
|
||||
@@ -210,7 +220,7 @@ class UserProfile extends ViewRecord
|
||||
try {
|
||||
$examRep->assignToUser($this->record->id, $data['exam_id'], $data['begin'], $data['end']);
|
||||
$this->sendSuccessNotification();
|
||||
} catch (\Exception $exception) {
|
||||
} catch (Exception $exception) {
|
||||
$this->sendFailNotification($exception->getMessage());
|
||||
}
|
||||
});
|
||||
@@ -218,15 +228,15 @@ class UserProfile extends ViewRecord
|
||||
|
||||
private function buildGrantMedalAction()
|
||||
{
|
||||
return Actions\Action::make(__('admin.resources.user.actions.grant_medal_btn'))
|
||||
return Action::make(__('admin.resources.user.actions.grant_medal_btn'))
|
||||
->modalHeading(__('admin.resources.user.actions.grant_medal_btn'))
|
||||
->form([
|
||||
Forms\Components\Select::make('medal_id')
|
||||
->schema([
|
||||
Select::make('medal_id')
|
||||
->options(Medal::query()->pluck('name', 'id'))
|
||||
->label(__('admin.resources.user.actions.grant_medal_medal_label'))
|
||||
->required(),
|
||||
|
||||
Forms\Components\TextInput::make('duration')
|
||||
TextInput::make('duration')
|
||||
->label(__('admin.resources.user.actions.grant_medal_duration_label'))
|
||||
->helperText(__('admin.resources.user.actions.grant_medal_duration_help'))
|
||||
->integer(),
|
||||
@@ -237,7 +247,7 @@ class UserProfile extends ViewRecord
|
||||
try {
|
||||
$medalRep->grantToUser($this->record->id, $data['medal_id'], $data['duration']);
|
||||
$this->sendSuccessNotification();
|
||||
} catch (\Exception $exception) {
|
||||
} catch (Exception $exception) {
|
||||
$this->sendFailNotification($exception->getMessage());
|
||||
}
|
||||
});
|
||||
@@ -245,7 +255,7 @@ class UserProfile extends ViewRecord
|
||||
|
||||
private function buildConfirmAction()
|
||||
{
|
||||
return Actions\Action::make(__('admin.resources.user.actions.confirm_btn'))
|
||||
return Action::make(__('admin.resources.user.actions.confirm_btn'))
|
||||
->modalHeading(__('admin.resources.user.actions.confirm_btn'))
|
||||
->requiresConfirmation()
|
||||
->action(function () {
|
||||
@@ -261,9 +271,9 @@ class UserProfile extends ViewRecord
|
||||
}
|
||||
|
||||
|
||||
private function buildEnableDisableDownloadPrivilegesAction(): Actions\Action
|
||||
private function buildEnableDisableDownloadPrivilegesAction(): Action
|
||||
{
|
||||
return Actions\Action::make($this->record->downloadpos == 'yes' ? __('admin.resources.user.actions.disable_download_privileges_btn') : __('admin.resources.user.actions.enable_download_privileges_btn'))
|
||||
return Action::make($this->record->downloadpos == 'yes' ? __('admin.resources.user.actions.disable_download_privileges_btn') : __('admin.resources.user.actions.enable_download_privileges_btn'))
|
||||
// ->modalHeading($this->record->enabled == 'yes' ? __('admin.resources.user.actions.disable_modal_title') : __('admin.resources.user.actions.enable_modal_title'))
|
||||
->requiresConfirmation()
|
||||
->action(function () {
|
||||
@@ -271,7 +281,7 @@ class UserProfile extends ViewRecord
|
||||
try {
|
||||
$userRep->updateDownloadPrivileges(Auth::user(), $this->record->id, $this->record->downloadpos == 'yes' ? 'no' : 'yes');
|
||||
$this->sendSuccessNotification();
|
||||
} catch (\Exception $exception) {
|
||||
} catch (Exception $exception) {
|
||||
$this->sendFailNotification($exception->getMessage());
|
||||
}
|
||||
});
|
||||
@@ -279,13 +289,13 @@ class UserProfile extends ViewRecord
|
||||
|
||||
private function buildGrantPropsAction()
|
||||
{
|
||||
return Actions\Action::make(__('admin.resources.user.actions.grant_prop_btn'))
|
||||
return Action::make(__('admin.resources.user.actions.grant_prop_btn'))
|
||||
->modalHeading(__('admin.resources.user.actions.grant_prop_btn'))
|
||||
->form([
|
||||
Forms\Components\Select::make('meta_key')
|
||||
->schema([
|
||||
Select::make('meta_key')
|
||||
->options(UserMeta::listProps())
|
||||
->label(__('admin.resources.user.actions.grant_prop_form_prop'))->required(),
|
||||
Forms\Components\TextInput::make('duration')->label(__('admin.resources.user.actions.grant_prop_form_duration'))
|
||||
TextInput::make('duration')->label(__('admin.resources.user.actions.grant_prop_form_duration'))
|
||||
->helperText(__('admin.resources.user.actions.grant_prop_form_duration_help')),
|
||||
|
||||
])
|
||||
@@ -294,15 +304,15 @@ class UserProfile extends ViewRecord
|
||||
try {
|
||||
$rep->addMeta($this->record, $data, $data);
|
||||
$this->sendSuccessNotification();
|
||||
} catch (\Exception $exception) {
|
||||
} catch (Exception $exception) {
|
||||
$this->sendFailNotification($exception->getMessage());
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
private function buildDeleteAction(): Actions\DeleteAction
|
||||
private function buildDeleteAction(): DeleteAction
|
||||
{
|
||||
return Actions\DeleteAction::make()->using(function () {
|
||||
return DeleteAction::make()->using(function () {
|
||||
$this->getRep()->destroy($this->record->id);
|
||||
return redirect(self::$resource::getUrl('index'));
|
||||
});
|
||||
@@ -344,32 +354,32 @@ class UserProfile extends ViewRecord
|
||||
->count();
|
||||
}
|
||||
|
||||
private function buildChangeClassAction(): Actions\Action
|
||||
private function buildChangeClassAction(): Action
|
||||
{
|
||||
return Actions\Action::make('change_class')
|
||||
return Action::make('change_class')
|
||||
->label(__('admin.resources.user.actions.change_class_btn'))
|
||||
->form([
|
||||
Forms\Components\Select::make('class')
|
||||
->schema([
|
||||
Select::make('class')
|
||||
->options(User::listClass(User::CLASS_PEASANT, Auth::user()->class - 1))
|
||||
->default($this->record->class)
|
||||
->label(__('user.labels.class'))
|
||||
->required()
|
||||
->reactive()
|
||||
,
|
||||
Forms\Components\Radio::make('vip_added')
|
||||
Radio::make('vip_added')
|
||||
->options(self::getYesNoOptions('yes', 'no'))
|
||||
->default($this->record->vip_added)
|
||||
->label(__('user.labels.vip_added'))
|
||||
->helperText(__('user.labels.vip_added_help'))
|
||||
->hidden(fn (\Filament\Forms\Get $get) => $get('class') != User::CLASS_VIP)
|
||||
->hidden(fn (Get $get) => $get('class') != User::CLASS_VIP)
|
||||
,
|
||||
Forms\Components\DateTimePicker::make('vip_until')
|
||||
DateTimePicker::make('vip_until')
|
||||
->default($this->record->vip_until)
|
||||
->label(__('user.labels.vip_until'))
|
||||
->helperText(__('user.labels.vip_until_help'))
|
||||
->hidden(fn (\Filament\Forms\Get $get) => $get('class') != User::CLASS_VIP)
|
||||
->hidden(fn (Get $get) => $get('class') != User::CLASS_VIP)
|
||||
,
|
||||
Forms\Components\TextInput::make('reason')
|
||||
TextInput::make('reason')
|
||||
->label(__('admin.resources.user.actions.enable_disable_reason'))
|
||||
->placeholder(__('admin.resources.user.actions.enable_disable_reason_placeholder'))
|
||||
,
|
||||
@@ -379,7 +389,7 @@ class UserProfile extends ViewRecord
|
||||
try {
|
||||
$userRep->changeClass(Auth::user(), $this->record, $data['class'], $data['reason'], $data);
|
||||
$this->sendSuccessNotification();
|
||||
} catch (\Exception $exception) {
|
||||
} catch (Exception $exception) {
|
||||
$this->sendFailNotification($exception->getMessage());
|
||||
}
|
||||
});
|
||||
|
||||
@@ -2,11 +2,12 @@
|
||||
|
||||
namespace App\Filament\Resources\User\UserResource\Pages;
|
||||
|
||||
use Filament\Actions\Contracts\HasActions;
|
||||
use App\Filament\Resources\User\UserResource;
|
||||
use Filament\Pages\Actions;
|
||||
use Filament\Resources\Pages\ViewRecord;
|
||||
|
||||
class ViewUser extends ViewRecord
|
||||
class ViewUser extends ViewRecord implements HasActions
|
||||
{
|
||||
protected static string $resource = UserResource::class;
|
||||
}
|
||||
|
||||
+19
-13
@@ -2,25 +2,31 @@
|
||||
|
||||
namespace App\Filament\Resources\User\UserResource\RelationManagers;
|
||||
|
||||
use Filament\Actions\Contracts\HasActions;
|
||||
use Filament\Schemas\Schema;
|
||||
use Filament\Forms\Components\TextInput;
|
||||
use Filament\Tables\Columns\TextColumn;
|
||||
use Filament\Tables\Columns\ImageColumn;
|
||||
use Filament\Actions\DeleteAction;
|
||||
use Filament\Actions\DeleteBulkAction;
|
||||
use Filament\Forms;
|
||||
use Filament\Forms\Form;
|
||||
use Filament\Resources\RelationManagers\RelationManager;
|
||||
use Filament\Tables\Table;
|
||||
use Filament\Tables;
|
||||
use Illuminate\Database\Eloquent\Builder;
|
||||
use Illuminate\Database\Eloquent\SoftDeletingScope;
|
||||
|
||||
class MedalsRelationManager extends RelationManager
|
||||
class MedalsRelationManager extends RelationManager implements HasActions
|
||||
{
|
||||
protected static string $relationship = 'medals';
|
||||
|
||||
protected static ?string $recordTitleAttribute = 'name';
|
||||
|
||||
public function form(Form $form): Form
|
||||
public function form(Schema $schema): Schema
|
||||
{
|
||||
return $form
|
||||
->schema([
|
||||
Forms\Components\TextInput::make('name')
|
||||
return $schema
|
||||
->components([
|
||||
TextInput::make('name')
|
||||
->required()
|
||||
->maxLength(255),
|
||||
]);
|
||||
@@ -30,9 +36,9 @@ class MedalsRelationManager extends RelationManager
|
||||
{
|
||||
return $table
|
||||
->columns([
|
||||
Tables\Columns\TextColumn::make('name')->label(__('label.name')),
|
||||
Tables\Columns\ImageColumn::make('image_large')->label(__('label.image')),
|
||||
Tables\Columns\ImageColumn::make('expire_at')->label(__('label.expire_at')),
|
||||
TextColumn::make('name')->label(__('label.name')),
|
||||
ImageColumn::make('image_large')->label(__('label.image')),
|
||||
ImageColumn::make('expire_at')->label(__('label.expire_at')),
|
||||
])
|
||||
->filters([
|
||||
//
|
||||
@@ -40,12 +46,12 @@ class MedalsRelationManager extends RelationManager
|
||||
->headerActions([
|
||||
// Tables\Actions\CreateAction::make(),
|
||||
])
|
||||
->actions([
|
||||
->recordActions([
|
||||
// Tables\Actions\EditAction::make(),
|
||||
Tables\Actions\DeleteAction::make(),
|
||||
DeleteAction::make(),
|
||||
])
|
||||
->bulkActions([
|
||||
Tables\Actions\DeleteBulkAction::make(),
|
||||
->toolbarActions([
|
||||
DeleteBulkAction::make(),
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user