2025-10-22 17:09:48 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
namespace App\Filament\Resources\Memberships\Tables;
|
|
|
|
|
|
|
|
|
|
use App\Models\Membership;
|
|
|
|
|
use Filament\Actions\BulkActionGroup;
|
|
|
|
|
use Filament\Actions\DeleteBulkAction;
|
|
|
|
|
use Filament\Actions\EditAction;
|
|
|
|
|
use Filament\Tables\Columns\TextColumn;
|
2026-02-03 10:53:23 +01:00
|
|
|
use Filament\Tables\Enums\FiltersLayout;
|
|
|
|
|
use Filament\Tables\Filters\QueryBuilder;
|
|
|
|
|
use Filament\Tables\Filters\QueryBuilder\Constraints\DateConstraint;
|
|
|
|
|
use Filament\Tables\Filters\QueryBuilder\Constraints\SelectConstraint;
|
2025-10-22 17:09:48 +02:00
|
|
|
use Filament\Tables\Table;
|
|
|
|
|
|
|
|
|
|
class MembershipsTable
|
|
|
|
|
{
|
|
|
|
|
public static function configure(Table $table): Table
|
|
|
|
|
{
|
|
|
|
|
return $table
|
|
|
|
|
->columns([
|
|
|
|
|
TextColumn::make('id')
|
2026-02-03 10:53:23 +01:00
|
|
|
->label('id')
|
|
|
|
|
->sortable(),
|
2025-10-22 17:09:48 +02:00
|
|
|
TextColumn::make('member.full_name')
|
|
|
|
|
->label(Membership::getAttributeLabel('member_id'))
|
|
|
|
|
->sortable(),
|
|
|
|
|
TextColumn::make('author.name')
|
|
|
|
|
->label(Membership::getAttributeLabel('admin_id'))
|
|
|
|
|
->numeric()
|
|
|
|
|
->sortable(),
|
|
|
|
|
TextColumn::make('start_date')
|
|
|
|
|
->label(Membership::getAttributeLabel('start_date'))
|
|
|
|
|
->date()
|
|
|
|
|
->sortable(),
|
|
|
|
|
TextColumn::make('end_date')
|
|
|
|
|
->label(Membership::getAttributeLabel('end_date'))
|
|
|
|
|
->date()
|
|
|
|
|
->sortable(),
|
|
|
|
|
TextColumn::make('status')
|
|
|
|
|
->label(Membership::getAttributeLabel('status'))
|
|
|
|
|
->formatStateUsing(fn (string $state) => Membership::getAttributeLabel($state))
|
|
|
|
|
->badge()
|
|
|
|
|
->color(fn (string $state): string => match ($state) {
|
|
|
|
|
'pending' => 'warning',
|
|
|
|
|
'active' => 'success',
|
|
|
|
|
'expired' => 'danger',
|
|
|
|
|
}),
|
|
|
|
|
TextColumn::make('amount')
|
|
|
|
|
->label(Membership::getAttributeLabel('amount'))
|
|
|
|
|
->money('euro')
|
|
|
|
|
->sortable(),
|
|
|
|
|
TextColumn::make('payment_status')
|
|
|
|
|
->label(Membership::getAttributeLabel('payment_status'))
|
|
|
|
|
->formatStateUsing(fn (string $state) => Membership::getAttributeLabel($state))
|
|
|
|
|
->badge()
|
|
|
|
|
->color(fn (string $state): string => match ($state) {
|
|
|
|
|
'partial' => 'warning',
|
|
|
|
|
'paid' => 'success',
|
|
|
|
|
'unpaid' => 'danger',
|
|
|
|
|
}),
|
|
|
|
|
TextColumn::make('created_at')
|
|
|
|
|
->label(Membership::getAttributeLabel('created_at'))
|
|
|
|
|
->dateTime()
|
|
|
|
|
->sortable()
|
|
|
|
|
->toggleable(isToggledHiddenByDefault: true),
|
|
|
|
|
TextColumn::make('updated_at')
|
|
|
|
|
->label(Membership::getAttributeLabel('updated_at'))
|
|
|
|
|
->dateTime()
|
|
|
|
|
->sortable()
|
|
|
|
|
->toggleable(isToggledHiddenByDefault: true),
|
|
|
|
|
TextColumn::make('deleted_at')
|
|
|
|
|
->dateTime()
|
|
|
|
|
->sortable()
|
|
|
|
|
->toggleable(isToggledHiddenByDefault: true),
|
|
|
|
|
])
|
2026-02-03 10:53:23 +01:00
|
|
|
->searchable([
|
|
|
|
|
'member.firstname',
|
|
|
|
|
'member.lastname',
|
|
|
|
|
'author.name',
|
|
|
|
|
'status',
|
|
|
|
|
'payment_status',
|
|
|
|
|
'amount',
|
2025-10-22 17:09:48 +02:00
|
|
|
])
|
2026-02-03 10:53:23 +01:00
|
|
|
->filters([
|
|
|
|
|
QueryBuilder::make()
|
|
|
|
|
->constraints([
|
|
|
|
|
SelectConstraint::make('status')
|
2026-04-01 15:50:21 +02:00
|
|
|
->label(Membership::getAttributeLabel('status'))
|
2026-02-03 10:53:23 +01:00
|
|
|
->options([
|
2026-04-01 15:50:21 +02:00
|
|
|
'active' => Membership::getAttributeLabel('active'),
|
|
|
|
|
'expired' => Membership::getAttributeLabel('expired'),
|
|
|
|
|
'pending' => Membership::getAttributeLabel('pending'),
|
2026-02-03 10:53:23 +01:00
|
|
|
]),
|
|
|
|
|
DateConstraint::make('start_date')
|
2026-04-01 15:50:21 +02:00
|
|
|
->label(Membership::getAttributeLabel('start_date')),
|
2026-02-03 10:53:23 +01:00
|
|
|
DateConstraint::make('end_date')
|
2026-04-01 15:50:21 +02:00
|
|
|
->label(Membership::getAttributeLabel('end_date')),
|
2026-02-03 10:53:23 +01:00
|
|
|
SelectConstraint::make('payment_status')
|
2026-04-01 15:50:21 +02:00
|
|
|
->label(Membership::getAttributeLabel('payment_status'))
|
2026-02-03 10:53:23 +01:00
|
|
|
->options([
|
2026-04-01 15:50:21 +02:00
|
|
|
'paid' => Membership::getAttributeLabel('paid'),
|
|
|
|
|
'unpaid' => Membership::getAttributeLabel('unpaid'),
|
|
|
|
|
'partial' => Membership::getAttributeLabel('partial'),
|
2026-02-03 10:53:23 +01:00
|
|
|
]),
|
2026-04-01 15:50:21 +02:00
|
|
|
]),
|
2026-02-03 10:53:23 +01:00
|
|
|
], layout: FiltersLayout::Modal)
|
2025-10-22 17:09:48 +02:00
|
|
|
->recordActions([
|
|
|
|
|
EditAction::make(),
|
|
|
|
|
])
|
|
|
|
|
->toolbarActions([
|
|
|
|
|
BulkActionGroup::make([
|
|
|
|
|
DeleteBulkAction::make(),
|
|
|
|
|
]),
|
|
|
|
|
]);
|
|
|
|
|
}
|
|
|
|
|
}
|