mirror of
https://github.com/lkddi/nexusphp.git
synced 2026-04-24 20:17:24 +08:00
temporary invite
This commit is contained in:
@@ -0,0 +1,112 @@
|
||||
<?php
|
||||
|
||||
namespace App\Filament\Resources\User;
|
||||
|
||||
use App\Filament\Resources\User\InviteResource\Pages;
|
||||
use App\Filament\Resources\User\InviteResource\RelationManagers;
|
||||
use App\Models\Invite;
|
||||
use Filament\Forms;
|
||||
use Filament\Resources\Form;
|
||||
use Filament\Resources\Resource;
|
||||
use Filament\Resources\Table;
|
||||
use Filament\Tables;
|
||||
use Illuminate\Database\Eloquent\Builder;
|
||||
use Illuminate\Database\Eloquent\SoftDeletingScope;
|
||||
|
||||
class InviteResource extends Resource
|
||||
{
|
||||
protected static ?string $model = Invite::class;
|
||||
|
||||
protected static ?string $navigationIcon = 'heroicon-o-user-add';
|
||||
|
||||
protected static ?string $navigationGroup = 'User';
|
||||
|
||||
protected static ?int $navigationSort = 7;
|
||||
|
||||
protected static function getNavigationLabel(): string
|
||||
{
|
||||
return __('admin.sidebar.invite');
|
||||
}
|
||||
|
||||
public static function getBreadcrumb(): string
|
||||
{
|
||||
return self::getNavigationLabel();
|
||||
}
|
||||
|
||||
public static function form(Form $form): Form
|
||||
{
|
||||
return $form
|
||||
->schema([
|
||||
//
|
||||
]);
|
||||
}
|
||||
|
||||
public static function table(Table $table): Table
|
||||
{
|
||||
return $table
|
||||
->columns([
|
||||
Tables\Columns\TextColumn::make('id'),
|
||||
Tables\Columns\TextColumn::make('inviter')
|
||||
->label(__('invite.fields.inviter'))
|
||||
->formatStateUsing(fn ($state) => username_for_admin($state))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('invitee')
|
||||
->label(__('invite.fields.invitee'))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('hash')
|
||||
,
|
||||
Tables\Columns\TextColumn::make('time_invited')
|
||||
->label(__('invite.fields.time_invited'))
|
||||
,
|
||||
Tables\Columns\IconColumn::make('valid')
|
||||
->label(__('invite.fields.valid'))
|
||||
->boolean()
|
||||
,
|
||||
Tables\Columns\TextColumn::make('invitee_register_uid')
|
||||
->label(__('invite.fields.invitee_register_uid'))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('invitee_register_email')
|
||||
->label(__('invite.fields.invitee_register_email'))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('invitee_register_email')
|
||||
->label(__('invite.fields.invitee_register_email'))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('invitee_register_username')
|
||||
->label(__('invite.fields.invitee_register_username'))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('expired_at')
|
||||
->label(__('invite.fields.expired_at'))
|
||||
->formatStateUsing(fn ($state) => format_datetime($state))
|
||||
,
|
||||
Tables\Columns\TextColumn::make('created_at')
|
||||
->label(__('label.created_at'))
|
||||
->formatStateUsing(fn ($state) => format_datetime($state))
|
||||
,
|
||||
])
|
||||
->filters([
|
||||
//
|
||||
])
|
||||
->actions([
|
||||
// Tables\Actions\EditAction::make(),
|
||||
])
|
||||
->bulkActions([
|
||||
// Tables\Actions\DeleteBulkAction::make(),
|
||||
]);
|
||||
}
|
||||
|
||||
public static function getRelations(): array
|
||||
{
|
||||
return [
|
||||
//
|
||||
];
|
||||
}
|
||||
|
||||
public static function getPages(): array
|
||||
{
|
||||
return [
|
||||
'index' => Pages\ListInvites::route('/'),
|
||||
'create' => Pages\CreateInvite::route('/create'),
|
||||
'edit' => Pages\EditInvite::route('/{record}/edit'),
|
||||
];
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,12 @@
|
||||
<?php
|
||||
|
||||
namespace App\Filament\Resources\User\InviteResource\Pages;
|
||||
|
||||
use App\Filament\Resources\User\InviteResource;
|
||||
use Filament\Pages\Actions;
|
||||
use Filament\Resources\Pages\CreateRecord;
|
||||
|
||||
class CreateInvite extends CreateRecord
|
||||
{
|
||||
protected static string $resource = InviteResource::class;
|
||||
}
|
||||
@@ -0,0 +1,19 @@
|
||||
<?php
|
||||
|
||||
namespace App\Filament\Resources\User\InviteResource\Pages;
|
||||
|
||||
use App\Filament\Resources\User\InviteResource;
|
||||
use Filament\Pages\Actions;
|
||||
use Filament\Resources\Pages\EditRecord;
|
||||
|
||||
class EditInvite extends EditRecord
|
||||
{
|
||||
protected static string $resource = InviteResource::class;
|
||||
|
||||
protected function getActions(): array
|
||||
{
|
||||
return [
|
||||
Actions\DeleteAction::make(),
|
||||
];
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,27 @@
|
||||
<?php
|
||||
|
||||
namespace App\Filament\Resources\User\InviteResource\Pages;
|
||||
|
||||
use App\Filament\PageList;
|
||||
use App\Filament\Resources\User\InviteResource;
|
||||
use App\Models\Invite;
|
||||
use Filament\Pages\Actions;
|
||||
use Filament\Resources\Pages\ListRecords;
|
||||
use Illuminate\Database\Eloquent\Builder;
|
||||
|
||||
class ListInvites extends PageList
|
||||
{
|
||||
protected static string $resource = InviteResource::class;
|
||||
|
||||
protected function getActions(): array
|
||||
{
|
||||
return [
|
||||
// Actions\CreateAction::make(),
|
||||
];
|
||||
}
|
||||
|
||||
protected function getTableQuery(): Builder
|
||||
{
|
||||
return Invite::query()->with(['inviter_user']);
|
||||
}
|
||||
}
|
||||
@@ -3,12 +3,14 @@
|
||||
namespace App\Filament\Resources\User\UserResource\Pages;
|
||||
|
||||
use App\Filament\Resources\User\UserResource;
|
||||
use App\Models\Invite;
|
||||
use App\Models\Medal;
|
||||
use App\Models\User;
|
||||
use App\Models\UserMeta;
|
||||
use App\Repositories\ExamRepository;
|
||||
use App\Repositories\MedalRepository;
|
||||
use App\Repositories\UserRepository;
|
||||
use Carbon\Carbon;
|
||||
use Filament\Resources\Pages\Concerns\HasRelationManagers;
|
||||
use Filament\Resources\Pages\Concerns\InteractsWithRecord;
|
||||
use Filament\Resources\Pages\Page;
|
||||
@@ -129,20 +131,44 @@ class UserProfile extends ViewRecord
|
||||
'invites' => __('label.user.invites'),
|
||||
'seedbonus' => __('label.user.seedbonus'),
|
||||
'attendance_card' => __('label.user.attendance_card'),
|
||||
])->label(__('admin.resources.user.actions.change_bonus_etc_field_label'))->inline()->required(),
|
||||
'tmp_invites' => __('label.user.tmp_invites'),
|
||||
])
|
||||
->label(__('admin.resources.user.actions.change_bonus_etc_field_label'))
|
||||
->inline()
|
||||
->required()
|
||||
->reactive()
|
||||
,
|
||||
Forms\Components\Radio::make('action')->options([
|
||||
'Increment' => __("admin.resources.user.actions.change_bonus_etc_action_increment"),
|
||||
'Decrement' => __("admin.resources.user.actions.change_bonus_etc_action_decrement"),
|
||||
])->label(__('admin.resources.user.actions.change_bonus_etc_action_label'))->inline()->required(),
|
||||
])
|
||||
->label(__('admin.resources.user.actions.change_bonus_etc_action_label'))
|
||||
->inline()
|
||||
->required()
|
||||
,
|
||||
Forms\Components\TextInput::make('value')->integer()->required()
|
||||
->label(__('admin.resources.user.actions.change_bonus_etc_value_label'))
|
||||
->helperText(__('admin.resources.user.actions.change_bonus_etc_value_help')),
|
||||
Forms\Components\Textarea::make('reason')->label(__('admin.resources.user.actions.change_bonus_etc_reason_label')),
|
||||
->helperText(__('admin.resources.user.actions.change_bonus_etc_value_help'))
|
||||
,
|
||||
|
||||
Forms\Components\TextInput::make('duration')->integer()
|
||||
->label(__('admin.resources.user.actions.change_bonus_etc_duration_label'))
|
||||
->helperText(__('admin.resources.user.actions.change_bonus_etc_duration_help'))
|
||||
->hidden(fn (\Closure $get) => $get('field') != 'tmp_invites')
|
||||
,
|
||||
|
||||
Forms\Components\Textarea::make('reason')
|
||||
->label(__('admin.resources.user.actions.change_bonus_etc_reason_label'))
|
||||
,
|
||||
])
|
||||
->action(function ($data) {
|
||||
$userRep = $this->getRep();
|
||||
try {
|
||||
$userRep->incrementDecrement(Auth::user(), $this->record->id, $data['action'], $data['field'], $data['value'], $data['reason']);
|
||||
if ($data['field'] == 'tmp_invites') {
|
||||
$userRep->addTemporaryInvite(Auth::user(), $this->record->id, $data['action'], $data['value'], $data['duration'], $data['reason']);
|
||||
} else {
|
||||
$userRep->incrementDecrement(Auth::user(), $this->record->id, $data['action'], $data['field'], $data['value'], $data['reason']);
|
||||
}
|
||||
$this->notify('success', 'Success!');
|
||||
$this->emitSelf(self::EVENT_RECORD_UPDATED, $this->record->id);
|
||||
} catch (\Exception $exception) {
|
||||
@@ -298,6 +324,7 @@ class UserProfile extends ViewRecord
|
||||
{
|
||||
return [
|
||||
'props' => $this->listUserProps(),
|
||||
'temporary_invite_count' => $this->countTemporaryInvite()
|
||||
];
|
||||
}
|
||||
|
||||
@@ -319,4 +346,13 @@ class UserProfile extends ViewRecord
|
||||
}
|
||||
return $props;
|
||||
}
|
||||
|
||||
private function countTemporaryInvite()
|
||||
{
|
||||
return Invite::query()->where('inviter', $this->record->id)
|
||||
->where('invitee', '')
|
||||
->whereNotNull('expired_at')
|
||||
->where('expired_at', '>', Carbon::now())
|
||||
->count();
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user