bonus logs show category seeding and common

This commit is contained in:
xiaomlove
2026-01-31 19:45:13 +07:00
parent fb440c6d2b
commit 1e997e411c
2 changed files with 71 additions and 42 deletions
@@ -2,6 +2,7 @@
namespace App\Filament\Resources\User;
use App\Repositories\BonusRepository;
use Filament\Schemas\Schema;
use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Filters\Filter;
@@ -9,7 +10,6 @@ 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\Resources\Resource;
@@ -17,6 +17,7 @@ use Filament\Tables\Table;
use Filament\Tables;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\SoftDeletingScope;
use Illuminate\Pagination\LengthAwarePaginator;
use Illuminate\Support\Arr;
use function Filament\Support\get_model_label;
@@ -51,8 +52,10 @@ class BonusLogResource extends Resource
public static function table(Table $table): Table
{
return $table
->records(function (int $page, int $recordsPerPage, array $filters) {
return self::listRecords($page, $recordsPerPage, $filters);
})
->columns([
TextColumn::make('id')->sortable(),
TextColumn::make('uid')
->formatStateUsing(fn ($state) => username_for_admin($state))
->label(__('label.username'))
@@ -79,8 +82,18 @@ class BonusLogResource extends Resource
->label(__('label.created_at'))
,
])
->defaultSort('id', 'desc')
->filters([
SelectFilter::make('category')
->options(BonusLogs::listCategoryOptions(true))
->default(BonusLogs::CATEGORY_COMMON)
->selectablePlaceholder(false)
->label(__('bonus-log.category'))
,
SelectFilter::make('business_type')
->options(BonusLogs::listBusinessTypeOptions())
->label(__('bonus-log.fields.business_type'))
->searchable(true)
,
Filter::make('uid')
->schema([
TextInput::make('uid')
@@ -91,21 +104,6 @@ class BonusLogResource extends Resource
return $query->when($data['uid'], fn (Builder $query, $value) => $query->where("uid", $value));
})
,
SelectFilter::make('business_type')
->options(BonusLogs::listBusinessTypeOptions(BonusLogs::CATEGORY_COMMON))
->label(__('bonus-log.fields.business_type'))
->searchable(true)
,
// Tables\Filters\Filter::make('exclude_seeding_bonus')
// ->toggle()
// ->label(__('bonus-log.exclude_seeding_bonus'))
// ->query(function (Builder $query, array $data) {
// if ($data['isActive']) {
// $query->whereNotIn("business_type", BonusLogs::$businessTypeBonus);
// }
// })
// ->default()
// ,
])
->recordActions([
// Tables\Actions\EditAction::make(),
@@ -122,4 +120,15 @@ class BonusLogResource extends Resource
'index' => ManageBonusLogs::route('/'),
];
}
private static function listRecords(int $page, int $perPage, array $filters = []): LengthAwarePaginator
{
$rep = new BonusRepository();
$category = $filters['category']['value'] ?: BonusLogs::CATEGORY_COMMON;
$userId = intval($filters['userId']['value'] ?? 0);
$businessType = intval($filters['businessType']['value'] ?? 0);
$list = $rep->getList($category, $userId, $businessType, $page, $perPage);
$count = $rep->getCount($category, $userId, $businessType);
return new LengthAwarePaginator($list, $count, $perPage, $page);
}
}