*/ namespace app\admin\controller; use app\common\model\Attachment; use app\common\model\BankAccount; use think\Request; use app\admin\model\AdminRole; use app\admin\model\AdminUser; use app\admin\validate\AdminUserValidate; class AdminUserController extends Controller { //列表 public function index(Request $request, AdminUser $model) { $param = $request->param(); $data = $model->scope('where,admin', $param) ->paginate($this->admin['per_page'], false, ['query' => $request->get()]); //关键词,排序等赋值 $this->assign($request->get()); $this->assign([ 'data' => $data, 'page' => $data->render(), 'total' => $data->total(), ]); return $this->fetch(); } //添加 public function add(Request $request, AdminUser $model, AdminUserValidate $validate) { if ($request->isPost()) { $param = $request->param(); $validate_result = $validate->scene('add')->check($param); if (!$validate_result) { return admin_error($validate->getError()); } $result = $model::create($param); $url = URL_BACK; if (isset($param['_create']) && $param['_create'] == 1) { $url = URL_RELOAD; } return $result ? admin_success('添加成功', $url) : admin_error(); } $role = AdminRole::all(function ($query) { $query->column('id,name', 'id'); }); $this->assign([ 'role' => $role, ]); return $this->fetch(); } //修改 public function edit($id, Request $request, AdminUser $model, AdminUserValidate $validate) { $data = $model::get($id); if ($request->isPost()) { $param = $request->param(); $validate_result = $validate->scene('edit')->check($param); if (!$validate_result) { return admin_error($validate->getError()); } $result = $data->save($param); return $result ? admin_success() : admin_error(); } $role = AdminRole::all(function ($query) { $query->column('id,name', 'id'); }); $this->assign([ 'data' => $data, 'role' => $role, ]); return $this->fetch('add'); } //删除 public function del($id, AdminUser $model) { if (count($model->noDeletionId) > 0) { if (is_array($id)) { if (array_intersect($model->noDeletionId, $id)) { return admin_error('ID为' . implode(',', $model->noDeletionId) . '的数据无法删除'); } } else if (in_array($id, $model->noDeletionId)) { return admin_error('ID为' . $id . '的数据无法删除'); } } if ($model->softDelete) { $result = $model->whereIn('id', $id)->useSoftDelete('delete_time', time())->delete(); } else { $result = $model->whereIn('id', $id)->delete(); } return $result ? admin_success('操作成功', URL_RELOAD) : admin_error(); } //启用 public function enable($id, AdminUser $model) { $result = $model->whereIn('id', $id)->update(['status' => 1]); return $result ? admin_success('操作成功', URL_RELOAD) : admin_error(); } //禁用 public function disable($id, AdminUser $model) { $result = $model->whereIn('id', $id)->update(['status' => 0]); return $result ? admin_success('操作成功', URL_RELOAD) : admin_error(); } //个人资料 public function profile(Request $request, AdminUserValidate $validate) { $data = BankAccount::with([ 'agency' => function ($query) { $query->field('id, username'); }, ])->whereIn('agency_id', $this->user->id) ->find(); if ($request->isPost()) { $param = $request->param(); if ($param['update_type'] === 'password') { $validate_result = $validate->scene('password')->check($param); if (!$validate_result) { return admin_error($validate->getError()); } if (!password_verify($param['password'], base64_decode($this->user->password))) { return admin_error('当前密码不正确'); } $param['password'] = $param['new_password']; } if (!$data) { $result = BankAccount::create($param); } else { $result = BankAccount::update($param, ['agency_id' => $this->user->id]); } return $result ? admin_success(lang('success'), URL_CURRENT) : admin_error(lang('error'), URL_CURRENT); } $this->assign([ 'data' => $data, ]); return $this->fetch(); } }