disableDeleteButton(); $grid->disableRowSelector(); //如果是审核页面,多加where条件判断 if (strpos(Route::current()->uri, 'audit')) { $grid->model()->where('status', UserStatus::UNAUDITED); } $grid->model()->where('id', '>', 1); //隐藏ID=1的领峰云管理员 $grid->column('id')->sortable(); $grid->column('username'); $grid->column('company_name'); $grid->column('对公账号')->display(fn() => $this->corporate_account . ' / ' . $this->deposit_bank)->limit(15); $grid->column('license')->image('', 60, 60); $grid->column('business_license')->image('', 60, 60); $grid->column('director'); $grid->column('contact_phone'); $grid->column('contract')->image('', 60, 60); $grid->column('cost', '入驻费') ->help('该地接已支付的入驻费(入驻时微信支付的费用)') ->if(fn() => !empty($this->settledOrder->paid_money) && floatval($this->settledOrder->paid_money) != 0) ->display(fn() => $this->settledOrder->paid_money ?? 0)->label('success'); $grid->column('created_at', '注册时间'); $grid->column('status', '状态') ->if(fn() => $this->status == UserStatus::UNAUDITED) ->display('') ->then(function ($column) { $column->append((new AuditGuide(null, 1))->setKey($this->id))->append(' '); $column->append((new AuditGuide(null, 2))->setKey($this->id)); }) ->else() ->using(UserStatus::array()) ->dot([ UserStatus::NORMAL => 'success', UserStatus::UNAUDITED => '', UserStatus::REFUSE => 'danger', UserStatus::DISABLED => 'warning', ], 'primary'); $grid->filter(function (Grid\Filter $filter) { $filter->panel(); $filter->equal('id')->width(2); $filter->like('name')->width(3); $filter->equal('status')->select(UserStatus::array())->width(2); }); }); } /** * Make a show builder. * * @param mixed $id * * @return Show */ protected function detail($id) { return Show::make($id, new Guide(), function (Show $show) { $show->disableDeleteButton(); $show->field('id'); $show->field('username'); $show->field('name'); $show->field('company_name'); $show->field('address'); $show->field('credit_codes'); $show->field('license')->image('', 80, 80); $show->field('business_license')->image('', 80, 80); $show->field('director'); $show->field('contact_phone'); $show->field('status')->using(UserStatus::array()); //$show->field('rate'); $show->field('corporate_account'); $show->field('deposit_bank'); $show->field('contract')->image('', 80, 80); $show->field('photo')->image('', 80, 80); $show->field('created_at'); $show->field('updated_at'); }); } /** * Make a form builder. * * @return Form */ protected function form() { return Form::make(new Guide(), function (Form $form) { $form->disableDeleteButton(); $form->display('id'); //新增 if ($form->isCreating()) { $form->text('username')->required(); $form->text('password')->required(); } //编辑 else if ($form->isEditing()) { $form->display('username'); $form->text('password')->customFormat(fn() => ''); } $form->select('status')->options(UserStatus::array())->default(UserStatus::NORMAL); $form->text('name'); $form->text('company_name'); $form->text('address'); $form->text('credit_codes'); $form->distpicker(['province_id', 'city_id', 'area_id'], '请选择区域')->required(); $form->image('photo')->removable(false)->uniqueName(); $form->multipleImage('license')->removable(false)->uniqueName(); $form->image('business_license')->removable(false)->uniqueName(); $form->text('director'); $form->text('contact_phone')->help('此号码将用于接收短信提醒(如订单提醒、付款提醒、核销提醒等)'); $form->text('corporate_account'); $form->text('deposit_bank'); //$form->number('rate')->min(0)->max(100)->help('分成百分比,如10%,则输入10'); })->saving(function (Form $form) { //判断账号是否唯一 if ($form->isCreating()) { if ($form->repository()->model()->where('username', $form->username)->exists()) { return $form->response()->error($form->username . ' 的账号已经存在'); } } //抽成比例 //if ($form->rate < 0 || $form->rate > 100) { // return $form->response()->error('抽成比例在 0 ~ 100 之间'); //} //不允许编辑的字段 if ($form->isEditing()) { $form->ignore(['id', 'username', 'created_at', 'updated_at', 'deleted_at']); } //过滤null字段 foreach ($form->input() as $k => $v) { if (is_null($v)) { $form->$k = ''; } } })->saved(function (Form $form) { //插入权限表 if ($form->status == UserStatus::NORMAL) { DB::table(config('admin-guide.database.role_users_table')) ->insertOrIgnore(['role_id' => 2, 'user_id' => $form->getKey()]); } }); } }