UserResource show donor status

This commit is contained in:
xiaomlove
2025-10-20 17:16:19 +07:00
parent 8d10cf7970
commit ca8edf8a6a
5 changed files with 37 additions and 7 deletions
+26 -7
View File
@@ -6,9 +6,10 @@ use Filament\Schemas\Schema;
use Filament\Forms\Components\TextInput; use Filament\Forms\Components\TextInput;
use App\Filament\Resources\User\UserResource\Pages\CreateUser; use App\Filament\Resources\User\UserResource\Pages\CreateUser;
use Filament\Forms\Components\Select; use Filament\Forms\Components\Select;
use Filament\Tables\Columns\BadgeColumn;
use Filament\Tables\Columns\IconColumn;
use Filament\Tables\Columns\TextColumn; use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Columns\Column; use Filament\Tables\Columns\Column;
use Filament\Tables\Columns\BadgeColumn;
use Filament\Tables\Filters\Filter; use Filament\Tables\Filters\Filter;
use Filament\Tables\Filters\SelectFilter; use Filament\Tables\Filters\SelectFilter;
use Filament\Actions\ViewAction; use Filament\Actions\ViewAction;
@@ -29,7 +30,6 @@ use App\Models\User;
use App\Repositories\UserRepository; use App\Repositories\UserRepository;
use Filament\Actions\Action; use Filament\Actions\Action;
use Filament\Forms; use Filament\Forms;
use Filament\Forms\Components\Grid;
use Filament\Resources\Resource; use Filament\Resources\Resource;
use Filament\Tables\Table; use Filament\Tables\Table;
use Filament\Tables; use Filament\Tables;
@@ -89,6 +89,7 @@ class UserResource extends Resource
public static function table(Table $table): Table public static function table(Table $table): Table
{ {
$yesNoOptions = ['success' => 'yes', 'danger' => 'no'];
return $table return $table
->columns([ ->columns([
TextColumn::make('id')->sortable()->searchable(), TextColumn::make('id')->sortable()->searchable(),
@@ -104,10 +105,16 @@ class UserResource extends Resource
TextColumn::make('downloaded')->label('Downloaded') TextColumn::make('downloaded')->label('Downloaded')
->formatStateUsing(fn(Column $column) => $column->getRecord()->downloadedText) ->formatStateUsing(fn(Column $column) => $column->getRecord()->downloadedText)
->sortable()->label(__("label.downloaded")), ->sortable()->label(__("label.downloaded")),
BadgeColumn::make('status')->colors(['success' => 'confirmed', 'warning' => 'pending'])->label(__("label.user.status")), TextColumn::make('status')->badge()->colors(['success' => 'confirmed', 'warning' => 'pending'])->label(__("label.user.status")),
BadgeColumn::make('enabled')->colors(['success' => 'yes', 'danger' => 'no'])->label(__("label.user.enabled")), TextColumn::make('enabled')->badge()->colors($yesNoOptions)->label(__("label.user.enabled")),
BadgeColumn::make('downloadpos')->colors(['success' => 'yes', 'danger' => 'no'])->label(__("label.user.downloadpos")), TextColumn::make('downloadpos')->badge()->colors($yesNoOptions)->label(__("label.user.downloadpos")),
BadgeColumn::make('parked')->colors(['success' => 'yes', 'danger' => 'no'])->label(__("label.user.parked")), TextColumn::make('parked')->badge()->colors($yesNoOptions)->label(__("label.user.parked")),
TextColumn::make('isDonating')
->state(fn ($record): string => $record->isDonating() ? 'yes' : 'no')
->badge()
->colors($yesNoOptions)
->label(__("label.user.is_donating"))
,
TextColumn::make('added')->sortable()->dateTime('Y-m-d H:i')->label(__("label.added")), 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")), TextColumn::make('last_access')->dateTime('Y-m-d H:i')->label(__("label.last_access")),
]) ])
@@ -122,11 +129,23 @@ class UserResource extends Resource
return $query->when($data['id'], fn (Builder $query, $id) => $query->where("id", $id)); return $query->when($data['id'], fn (Builder $query, $id) => $query->where("id", $id));
}) })
, ,
SelectFilter::make('class')->options(array_column(User::$classes, 'text'))->label(__('label.user.class')), SelectFilter::make('class')->options(User::listClass())->label(__('label.user.class')),
SelectFilter::make('status')->options(['confirmed' => 'confirmed', 'pending' => 'pending'])->label(__('label.user.status')), SelectFilter::make('status')->options(['confirmed' => 'confirmed', 'pending' => 'pending'])->label(__('label.user.status')),
SelectFilter::make('enabled')->options(self::$yesOrNo)->label(__('label.user.enabled')), SelectFilter::make('enabled')->options(self::$yesOrNo)->label(__('label.user.enabled')),
SelectFilter::make('downloadpos')->options(self::$yesOrNo)->label(__('label.user.downloadpos')), SelectFilter::make('downloadpos')->options(self::$yesOrNo)->label(__('label.user.downloadpos')),
SelectFilter::make('parked')->options(self::$yesOrNo)->label(__('label.user.parked')), SelectFilter::make('parked')->options(self::$yesOrNo)->label(__('label.user.parked')),
SelectFilter::make('is_donating')
->options(self::$yesOrNo)
->label(__('label.user.is_donating'))
->query(function (Builder $query, array $data) {
if ($data['value'] === 'yes') {
return $query->donating();
} else if ($data['value'] === 'no') {
return $query->where('donor', 'no');
}
return $query;
})
,
]) ])
->recordActions([ ->recordActions([
ViewAction::make(), ViewAction::make(),
+8
View File
@@ -364,6 +364,14 @@ class User extends Authenticatable implements FilamentUser, HasName
return $query->where('status', self::STATUS_CONFIRMED)->where('enabled', self::ENABLED_YES); return $query->where('status', self::STATUS_CONFIRMED)->where('enabled', self::ENABLED_YES);
} }
public function scopeDonating(Builder $query): Builder
{
return $query->where('donor', 'yes')->where(function (Builder $query) {
return $query->whereNull('donoruntil')
->orWhere('donoruntil', '0000-00-00 00:00:00')
->orWhere('donoruntil', '>=', now());
});
}
public function exams() public function exams()
{ {
+1
View File
@@ -210,6 +210,7 @@ return [
'parked' => 'Parked', 'parked' => 'Parked',
'offer_allowed_count' => 'Offer allowed count', 'offer_allowed_count' => 'Offer allowed count',
'tmp_invites' => 'Temporary invite', 'tmp_invites' => 'Temporary invite',
'is_donating' => 'Donor',
], ],
'medal' => [ 'medal' => [
'label' => 'Medal', 'label' => 'Medal',
+1
View File
@@ -250,6 +250,7 @@ return [
'parked' => '挂起', 'parked' => '挂起',
'offer_allowed_count' => '候选通过数', 'offer_allowed_count' => '候选通过数',
'tmp_invites' => '临时邀请', 'tmp_invites' => '临时邀请',
'is_donating' => '捐赠',
], ],
'medal' => [ 'medal' => [
'label' => '勋章', 'label' => '勋章',
+1
View File
@@ -209,6 +209,7 @@ return [
'parked' => '掛起', 'parked' => '掛起',
'offer_allowed_count' => '候選通過數', 'offer_allowed_count' => '候選通過數',
'tmp_invites' => '臨時邀請', 'tmp_invites' => '臨時邀請',
'is_donating' => '捐贈',
], ],
'medal' => [ 'medal' => [
'label' => '勛章', 'label' => '勛章',