mirror of
https://github.com/lkddi/nexusphp.git
synced 2026-04-14 12:30:49 +08:00
backend change class to vip can set until time
This commit is contained in:
@@ -5,6 +5,7 @@ namespace App\Filament\Resources\User;
|
||||
use App\Filament\Resources\User\UserMedalResource\Pages;
|
||||
use App\Filament\Resources\User\UserMedalResource\RelationManagers;
|
||||
use App\Models\Medal;
|
||||
use App\Models\NexusModel;
|
||||
use App\Models\UserMedal;
|
||||
use Filament\Forms;
|
||||
use Filament\Resources\Form;
|
||||
@@ -57,6 +58,7 @@ class UserMedalResource extends Resource
|
||||
Tables\Columns\TextColumn::make('medal.name')->label(__('label.medal.label'))->searchable(),
|
||||
Tables\Columns\ImageColumn::make('medal.image_large')->label(__('label.image')),
|
||||
Tables\Columns\TextColumn::make('expire_at')->label(__('label.expire_at'))->dateTime(),
|
||||
Tables\Columns\TextColumn::make('wearingStatusText')->label(__('label.status')),
|
||||
])
|
||||
->defaultSort('id', 'desc')
|
||||
->filters([
|
||||
@@ -76,10 +78,13 @@ class UserMedalResource extends Resource
|
||||
,
|
||||
])
|
||||
->actions([
|
||||
Tables\Actions\DeleteAction::make(),
|
||||
Tables\Actions\DeleteAction::make()->using(function (NexusModel $record) {
|
||||
$record->delete();
|
||||
clear_user_cache($record->uid);
|
||||
})
|
||||
])
|
||||
->bulkActions([
|
||||
Tables\Actions\DeleteBulkAction::make(),
|
||||
|
||||
]);
|
||||
}
|
||||
|
||||
|
||||
@@ -4,6 +4,7 @@ namespace App\Filament\Resources\User;
|
||||
|
||||
use App\Filament\Resources\User\UserMetaResource\Pages;
|
||||
use App\Filament\Resources\User\UserMetaResource\RelationManagers;
|
||||
use App\Models\NexusModel;
|
||||
use App\Models\UserMeta;
|
||||
use Filament\Forms;
|
||||
use Filament\Resources\Form;
|
||||
@@ -12,6 +13,7 @@ use Filament\Resources\Table;
|
||||
use Filament\Tables;
|
||||
use Illuminate\Database\Eloquent\Builder;
|
||||
use Illuminate\Database\Eloquent\SoftDeletingScope;
|
||||
use Illuminate\Support\Facades\Auth;
|
||||
use Illuminate\Support\HtmlString;
|
||||
|
||||
class UserMetaResource extends Resource
|
||||
@@ -81,10 +83,13 @@ class UserMetaResource extends Resource
|
||||
,
|
||||
])
|
||||
->actions([
|
||||
// Tables\Actions\EditAction::make(),
|
||||
Tables\Actions\DeleteAction::make()->using(function (NexusModel $record) {
|
||||
$record->delete();
|
||||
clear_user_cache($record->uid);
|
||||
do_log(sprintf("user: %d meta: %s was del by %s", $record->uid, $record->meta_key, Auth::user()->username));
|
||||
}),
|
||||
])
|
||||
->bulkActions([
|
||||
// Tables\Actions\DeleteBulkAction::make(),
|
||||
]);
|
||||
}
|
||||
|
||||
|
||||
@@ -2,6 +2,7 @@
|
||||
|
||||
namespace App\Filament\Resources\User\UserResource\Pages;
|
||||
|
||||
use App\Filament\OptionsTrait;
|
||||
use App\Filament\Resources\User\UserResource;
|
||||
use App\Models\Invite;
|
||||
use App\Models\Medal;
|
||||
@@ -24,6 +25,7 @@ class UserProfile extends ViewRecord
|
||||
{
|
||||
use InteractsWithRecord;
|
||||
use HasRelationManagers;
|
||||
use OptionsTrait;
|
||||
|
||||
private static $rep;
|
||||
|
||||
@@ -369,6 +371,20 @@ class UserProfile extends ViewRecord
|
||||
->default($this->record->class)
|
||||
->label(__('user.labels.class'))
|
||||
->required()
|
||||
->reactive()
|
||||
,
|
||||
Forms\Components\Radio::make('vip_added')
|
||||
->options(self::getYesNoOptions('yes', 'no'))
|
||||
->default($this->record->vip_added)
|
||||
->label(__('user.labels.vip_added'))
|
||||
->helperText(__('user.labels.vip_added_help'))
|
||||
->hidden(fn (\Closure $get) => $get('class') != User::CLASS_VIP)
|
||||
,
|
||||
Forms\Components\DateTimePicker::make('vip_until')
|
||||
->default($this->record->vip_until)
|
||||
->label(__('user.labels.vip_until'))
|
||||
->helperText(__('user.labels.vip_until_help'))
|
||||
->hidden(fn (\Closure $get) => $get('class') != User::CLASS_VIP)
|
||||
,
|
||||
Forms\Components\TextInput::make('reason')
|
||||
->label(__('admin.resources.user.actions.enable_disable_reason'))
|
||||
@@ -378,7 +394,7 @@ class UserProfile extends ViewRecord
|
||||
->action(function ($data) {
|
||||
$userRep = $this->getRep();
|
||||
try {
|
||||
$userRep->changeClass(Auth::user(), $this->record, $data['class'], $data['reason']);
|
||||
$userRep->changeClass(Auth::user(), $this->record, $data['class'], $data['reason'], $data);
|
||||
$this->notify('success', 'Success!');
|
||||
$this->emitSelf(self::EVENT_RECORD_UPDATED, $this->record->id);
|
||||
} catch (\Exception $exception) {
|
||||
|
||||
@@ -9,6 +9,11 @@ class UserMedal extends NexusModel
|
||||
const STATUS_NOT_WEARING = 0;
|
||||
const STATUS_WEARING = 1;
|
||||
|
||||
public function getWearingStatusTextAttribute()
|
||||
{
|
||||
return nexus_trans("medal.wearing_status_text." . $this->status);
|
||||
}
|
||||
|
||||
public function medal()
|
||||
{
|
||||
return $this->belongsTo(Medal::class, 'medal_id');
|
||||
|
||||
@@ -468,7 +468,7 @@ class UserRepository extends BaseRepository
|
||||
return true;
|
||||
}
|
||||
|
||||
public function changeClass($operator, $targetUser, $newClass, $reason = ''): bool
|
||||
public function changeClass($operator, $targetUser, $newClass, $reason = '', array $extra = []): bool
|
||||
{
|
||||
user_can('user-change-class', true);
|
||||
$operator = $this->getUser($operator);
|
||||
@@ -477,7 +477,7 @@ class UserRepository extends BaseRepository
|
||||
if ($operator->class <= $targetUser->class || $operator->class <= $newClass)
|
||||
throw new InsufficientPermissionException();
|
||||
}
|
||||
if ($targetUser->class == $newClass) {
|
||||
if ($targetUser->class == $newClass && $newClass != User::CLASS_VIP) {
|
||||
return true;
|
||||
}
|
||||
$locale = $targetUser->locale;
|
||||
@@ -495,11 +495,34 @@ class UserRepository extends BaseRepository
|
||||
'msg' => $body,
|
||||
'added' => Carbon::now(),
|
||||
];
|
||||
|
||||
NexusDB::transaction(function () use ($targetUser, $newClass, $message) {
|
||||
$userUpdates = [
|
||||
'class' => $newClass,
|
||||
];
|
||||
if ($newClass == User::CLASS_VIP) {
|
||||
if (!empty($extra['vip_added']) && in_array($extra['vip_added'], ['yes', 'no'])) {
|
||||
$userUpdates['vip_added'] = $extra['vip_added'];
|
||||
} else {
|
||||
$userUpdates['vip_added'] = 'no';
|
||||
}
|
||||
if (!empty($extra['vip_until'])) {
|
||||
$until = Carbon::parse($extra['vip_until']);
|
||||
$userUpdates['vip_until'] = $until;
|
||||
} else {
|
||||
$userUpdates['vip_until'] = null;
|
||||
}
|
||||
} else {
|
||||
$userUpdates['vip_added'] = 'no';
|
||||
$userUpdates['vip_until'] = null;
|
||||
}
|
||||
do_log("userUpdates: " . json_encode($userUpdates));
|
||||
NexusDB::transaction(function () use ($targetUser, $userUpdates, $message) {
|
||||
$modComment = date('Y-m-d') . " - " . $message['msg'];
|
||||
$targetUser->updateWithModComment(['class' => $newClass], $modComment);
|
||||
Message::add($message);
|
||||
if ($targetUser->class != $userUpdates['class']) {
|
||||
$targetUser->updateWithModComment($userUpdates, $modComment);
|
||||
Message::add($message);
|
||||
} else {
|
||||
$targetUser->update($userUpdates);
|
||||
}
|
||||
$this->clearCache($targetUser);
|
||||
});
|
||||
|
||||
|
||||
Reference in New Issue
Block a user