mirror of
https://github.com/lkddi/nexusphp.git
synced 2026-04-23 19:37:23 +08:00
migration script
# Conflicts: # app/Filament/Resources/Torrent/AnnounceLogResource.php
This commit is contained in:
@@ -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'),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user