6
0
Fork 0

调整部分用户管理

release
vine_liutk 2021-12-29 17:00:20 +08:00
parent 07994f9db2
commit 1e31bd6794
7 changed files with 201 additions and 19 deletions

View File

@ -0,0 +1,44 @@
<?php
namespace App\Admin\Actions\Grid;
use App\Admin\Forms\Frozen as FrozenForm;
use Dcat\Admin\Grid\RowAction;
use Dcat\Admin\Widgets\Modal;
class Frozen extends RowAction
{
/**
* @return string
*/
protected $title = '<i class="fa fa-ban grid-action-icon"></i>';
public function title()
{
if ($this->title) {
return $this->title.'&nbsp;资产冻结';
}
return '资产冻结';
}
/**
* @param Model|Authenticatable|HasPermissions|null $user
*
* @return bool
*/
protected function authorize($user): bool
{
return $user->can('dcat.admin.product_sku_verifies.verify');
}
public function render()
{
$form = FrozenForm::make()->payload(['id'=>$this->getKey()]);
return Modal::make()
->lg()
->title($this->title())
->body($form)
->button($this->title());
}
}

View File

@ -4,6 +4,7 @@ namespace App\Admin\Controllers;
use App\Admin\Actions\Grid\DisableUser; use App\Admin\Actions\Grid\DisableUser;
use App\Admin\Actions\Grid\EnableUser; use App\Admin\Actions\Grid\EnableUser;
use App\Admin\Actions\Grid\Frozen;
use App\Admin\Repositories\User; use App\Admin\Repositories\User;
use Dcat\Admin\Admin; use Dcat\Admin\Admin;
use Dcat\Admin\Form; use Dcat\Admin\Form;
@ -11,6 +12,7 @@ use Dcat\Admin\Grid;
use Dcat\Admin\Http\Controllers\AdminController; use Dcat\Admin\Http\Controllers\AdminController;
use Dcat\Admin\Layout\Row; use Dcat\Admin\Layout\Row;
use Dcat\Admin\Show; use Dcat\Admin\Show;
use Illuminate\Support\Facades\Request;
class UserController extends AdminController class UserController extends AdminController
{ {
@ -21,25 +23,42 @@ class UserController extends AdminController
*/ */
protected function grid() protected function grid()
{ {
$builder = User::with(['userVip', 'userInfo', 'userVip.vip']); $builder = User::with(['userVip', 'userInfo', 'wallet', 'balance', 'userInfo.inviterInfo.user']);
return Grid::make($builder, function (Grid $grid) { return Grid::make($builder, function (Grid $grid) {
$grid->column('id')->sortable(); // $grid->column('id')->sortable();
$grid->column('phone'); $grid->column('phone');
// $grid->column('username'); $grid->column('userInfo.agent_level')->display(function ($value) {
// $grid->column('password'); return $this->userInfo?->agent_level_name??'未知';
$grid->column('userInfo.avatar')->image(50); })->label();
$grid->column('userVip.vip.name')->label();
$grid->column('last_login_ip'); $grid->column('userInfo.inviterInfo.user.phone', '推荐人手机');
$grid->column('last_login_at')->sortable(); $grid->column('userInfo.growth_value', '消费值');
$grid->column('userInfo.group_sales_value', '业绩');
$grid->column('wallet.balance', '可提')->display(function ($value) {
$value = bcdiv($value, 100, 2);
if ($this->wallet?->is_frozen) {
$value.= " &nbsp;<span class='label' style='background:#b3b9bf'>冻结</span>";
}
return $value;
})->prepend('¥');
$grid->column('balance.balance', '余额')->display(function ($value) {
$value = bcdiv($value, 100, 2);
if ($this->balance?->is_frozen) {
$value.= " &nbsp;<span class='label' style='background:#b3b9bf'>冻结</span>";
}
return $value;
})->prepend('¥');
$grid->column('created_at')->sortable();
$grid->column('register_ip'); $grid->column('register_ip');
// $grid->column('remember_token');
$grid->column('status')->using([-1=>'冻结', 1=>'正常', 2=>'禁用']) $grid->column('status')->using([-1=>'冻结', 1=>'正常', 2=>'禁用'])
->dot([ ->dot([
-1 => '#b3b9bf', -1 => '#b3b9bf',
1 => 'primary', 1 => 'primary',
2 => '#b3b9bf', 2 => '#b3b9bf',
]); ]);
$grid->column('created_at'); $grid->model()->orderBy('created_at', 'desc');
/** 操作 **/ /** 操作 **/
//新增 //新增
@ -62,7 +81,10 @@ class UserController extends AdminController
} }
} }
// todo-禁用可提,禁用余额 // todo-冻结资产
if (Admin::user()->can('dcat.admin.users.frozen')) {
$actions->append(new Frozen());
}
}); });
$grid->filter(function (Grid\Filter $filter) { $grid->filter(function (Grid\Filter $filter) {
@ -95,14 +117,15 @@ class UserController extends AdminController
$show->panel() $show->panel()
->tools(function ($tools) { ->tools(function ($tools) {
$tools->disableEdit(); $tools->disableEdit();
// $tools->disableList();
$tools->disableDelete(); $tools->disableDelete();
// 显示快捷编辑按钮 // todo-修改手机号
// $tools->showQuickEdit(); // todo-修改银行卡
}); });
})); }));
}); });
$row->column(5, function () { $row->column(5, function () {
// todo_粉丝列表
}); });
}; };
} }
@ -125,6 +148,7 @@ class UserController extends AdminController
$form->display('created_at'); $form->display('created_at');
$form->display('updated_at'); $form->display('updated_at');
$form->hidden('register_ip')->value(Request::getClientIp());
}); });
} }
} }

View File

@ -0,0 +1,103 @@
<?php
namespace App\Admin\Forms;
use App\Models\User;
use Dcat\Admin\Contracts\LazyRenderable;
use Dcat\Admin\Traits\LazyWidget;
use Dcat\Admin\Widgets\Form;
use Illuminate\Support\Facades\DB;
use Throwable;
class Frozen extends Form implements LazyRenderable
{
use LazyWidget;
/**
* @param Model|Authenticatable|HasPermissions|null $user
*
* @return bool
*/
protected function authorize($user): bool
{
return $user->can('dcat.admin.users.frozen');
}
/**
* Handle the form request.
*
* @param array $input
*
* @return mixed
*/
public function handle(array $input)
{
$id = $this->payload['id'] ?? 0;
$user = User::findOrFail($id);
try {
DB::beginTransaction();
//可提冻结
if (in_array('wallet', $input['frozen'])) {
if (is_null($user->wallet)) {
$user->wallet()->create([
'is_frozen' =>1,
]);
} else {
$user->wallet()->update([
'is_frozen' => 1,
]);
}
} else {//可提解冻
$user->wallet()->update([
'is_frozen' => 0,
]);
}
//余额冻结
if (in_array('balance', $input['frozen'])) {
if (is_null($user->balance)) {
$user->balance()->create([
'is_frozen' =>1,
]);
} else {
$user->balance()->update([
'is_frozen' => 1,
]);
}
} else {//余额解冻
$user->balance()->update([
'is_frozen' => 0,
]);
}
DB::commit();
} catch (Throwable $th) {
DB::rollBack();
report($th);
return $this->response()->error('操作失败:'.$th->getMessage());
}
return $this->response()
->success(__('admin.update_succeeded'))
->refresh();
}
/**
* Build a form here.
*/
public function form()
{
$id = $this->payload['id'] ?? 0;
$user = User::findOrFail($id);
$this->checkbox('frozen', '冻结')->options([
'wallet'=>'可提', 'balance'=>'余额',
])->canCheckAll()->customFormat(function () use ($user) {
$v = [];
if ($user->wallet?->is_frozen) {
$v[] = 'wallet';
}
if ($user->balance?->is_frozen) {
$v[] = 'balance';
}
return $v;
});
}
}

View File

@ -335,6 +335,11 @@ class User extends Model implements AuthorizableContract, AuthenticatableContrac
] ]
); );
//初始化钱包
$user->wallet()->create();
//初始化余额
$user->balance()->create();
return $user; return $user;
} }
} }

View File

@ -131,6 +131,16 @@ class UserInfo extends Model
}); });
} }
/**
* 用户
*
* @return void
*/
public function user()
{
return $this->belongsTo(User::class);
}
/** /**
* 获取此用户的邀请人信息 * 获取此用户的邀请人信息
*/ */

View File

@ -33,11 +33,6 @@ class AdminMenuSeeder extends Seeder
'icon' => '', 'icon' => '',
'uri' => 'users', 'uri' => 'users',
], ],
[
'title' => '会员等级',
'icon' => '',
'uri' => 'vips',
],
], ],
], ],
[ [

View File

@ -23,6 +23,7 @@ return [
], ],
'userInfo'=>[ 'userInfo'=>[
'avatar' => '头像', 'avatar' => '头像',
'agent_level'=>'管理级别',
], ],
'status_remark'=>'备注', 'status_remark'=>'备注',
], ],