migration script

# Conflicts:
#	app/Filament/Resources/Torrent/AnnounceLogResource.php
This commit is contained in:
NekoCH
2025-09-21 18:07:38 +08:00
parent f0b50e4826
commit 532f3bdb3f
131 changed files with 2177 additions and 1644 deletions
@@ -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'),
];
}
}