调整部分用户管理
parent
07994f9db2
commit
1e31bd6794
|
|
@ -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.' 资产冻结';
|
||||||
|
}
|
||||||
|
|
||||||
|
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());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -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.= " <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.= " <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());
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -335,6 +335,11 @@ class User extends Model implements AuthorizableContract, AuthenticatableContrac
|
||||||
]
|
]
|
||||||
);
|
);
|
||||||
|
|
||||||
|
//初始化钱包
|
||||||
|
$user->wallet()->create();
|
||||||
|
//初始化余额
|
||||||
|
$user->balance()->create();
|
||||||
|
|
||||||
return $user;
|
return $user;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -131,6 +131,16 @@ class UserInfo extends Model
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 用户
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function user()
|
||||||
|
{
|
||||||
|
return $this->belongsTo(User::class);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取此用户的邀请人信息
|
* 获取此用户的邀请人信息
|
||||||
*/
|
*/
|
||||||
|
|
|
||||||
|
|
@ -33,11 +33,6 @@ class AdminMenuSeeder extends Seeder
|
||||||
'icon' => '',
|
'icon' => '',
|
||||||
'uri' => 'users',
|
'uri' => 'users',
|
||||||
],
|
],
|
||||||
[
|
|
||||||
'title' => '会员等级',
|
|
||||||
'icon' => '',
|
|
||||||
'uri' => 'vips',
|
|
||||||
],
|
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
|
|
|
||||||
|
|
@ -23,6 +23,7 @@ return [
|
||||||
],
|
],
|
||||||
'userInfo'=>[
|
'userInfo'=>[
|
||||||
'avatar' => '头像',
|
'avatar' => '头像',
|
||||||
|
'agent_level'=>'管理级别',
|
||||||
],
|
],
|
||||||
'status_remark'=>'备注',
|
'status_remark'=>'备注',
|
||||||
],
|
],
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue