temporary invite

This commit is contained in:
xiaomlove
2022-12-13 13:51:39 +08:00
parent 6fa604ce56
commit f413c61901
42 changed files with 727 additions and 47 deletions
@@ -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();
}
}