*/ public function index($id = null) { $id === null && $this->error('参数错误'); cookie('__forward__', $_SERVER['REQUEST_URI']); // 查询 $map = $this->getMap(); $map['model'] = $id; // 数据列表 $data_list = FieldModel::where($map)->order('id desc')->paginate(); // 使用ZBuilder快速创建数据表格 return ZBuilder::make('table') ->setSearch(['name' => '名称', 'title' => '标题']) // 设置搜索框 ->setPageTips('【显示】表示新增或编辑文档时是否显示该字段
【启用】表示前台是否显示') ->addColumns([ // 批量添加数据列 ['id', 'ID'], ['name', '名称'], ['title', '标题'], ['type', '类型', 'text', '', config('form_item_type')], ['create_time', '创建时间', 'datetime'], ['sort', '排序', 'text.edit'], ['show', '显示', 'switch'], ['status', '启用', 'switch'], ['right_button', '操作', 'btn'] ]) ->addTopButton('back', ['href' => url('model/index')]) // 批量添加顶部按钮 ->addTopButton('add', ['href' => url('add', ['model' => $id])]) // 添加顶部按钮 ->addTopButtons('enable,disable') // 批量添加顶部按钮 ->addRightButtons('edit,delete') // 批量添加右侧按钮 ->replaceRightButton(['fixed' => 1], '') ->setRowList($data_list) // 设置表格数据 ->fetch(); // 渲染模板 } /** * 新增字段 * @param string $model 文档模型id * @author 蔡伟明 <314013107@qq.com> * @return mixed */ public function add($model = '') { // 内容模型类别[0-系统,1-普通,2-独立] $model_type = get_model_type($model); if ($this->request->isPost()) { // 表单数据 $data = $this->request->post(); // 非独立模型需验证字段名称是否为aid if ($model_type != 2) { // 非独立模型需验证新增的字段是否被系统占用 if ($data['name'] == 'aid' || is_default_field($data['name'])) { $this->error('字段名称已存在'); } } $result = $this->validate($data, 'Field'); if(true !== $result) $this->error($result); // 如果是快速联动 switch ($data['type']) { case 'linkages': $data['key'] = $data['key'] == '' ? 'id' : $data['key']; $data['pid'] = $data['pid'] == '' ? 'pid' : $data['pid']; $data['level'] = $data['level'] == '' ? '2' : $data['level']; $data['option'] = $data['option'] == '' ? 'name' : $data['option']; break; case 'number': $data['type'] = 'text'; break; case 'bmap': $data['level'] = !$data['level'] ? 12 : $data['level']; break; } if ($field = FieldModel::create($data)) { $FieldModel = new FieldModel(); // 添加字段 if ($FieldModel->newField($data)) { // 记录行为 $details = '详情:文档模型('.get_model_title($data['model']).')、字段名称('.$data['name'].')、字段标题('.$data['title'].')、字段类型('.$data['type'].')'; action_log('field_add', 'cms_field', $field['id'], UID, $details); // 清除缓存 cache('cms_system_fields', null); $this->success('新增成功', cookie('__forward__')); } else { // 添加失败,删除新增的数据 FieldModel::destroy($field['id']); $this->error($FieldModel->getError()); } } else { $this->error('新增失败'); } } if ($model_type != 2) { $field_exist = Db::name('cms_field')->where('model', 'in', [0, $model])->column('name'); $field_exist[] = 'aid'; } else { $field_exist = ['id','cid','uid','title','model','create_time','update_time','sort','status','view','trash']; } // 显示添加页面 return ZBuilder::make('form') ->setPageTips('以下字段名称已存在,请不要建立同名的字段:
'. implode('、', $field_exist)) ->addFormItems([ ['hidden', 'model', $model], ['text', 'name', '字段名称', '由小写英文字母和下划线组成'], ['text', 'title', '字段标题', '可填写中文'], ['select', 'type', '字段类型', '', config('form_item_type')], ['text', 'define', '字段定义', '可根据实际需求自行填写或修改,但必须是正确的sql语法'], ['text', 'value', '字段默认值'], ['textarea', 'options', '额外选项', '用于单选、多选、下拉、联动等类型'], ['text', 'ajax_url', '异步请求地址', "如请求的地址是 url('ajax/getCity'),那么只需填写 ajax/getCity,或者直接填写以 http开头的url地址"], ['text', 'next_items', '下一级联动下拉框的表单名', "与当前有关联的下级联动下拉框名,多个用逗号隔开,如:area,other"], ['text', 'param', '请求参数名', "联动下拉框请求参数名,默认为配置名称"], ['text', 'level', '级别', '如果类型为【快速联动下拉框】则表示需要显示的级别数量,默认为2。如果类型为【百度地图】,则表示地图默认缩放级别,建议设置为12', 2], ['text', 'table', '表名', '要查询的表,里面必须含有id、name、pid三个字段,其中id和name字段可在下面重新定义'], ['text', 'pid', '父级id字段名', '即表中的父级ID字段名,如果表中的主键字段名为pid则可不填写'], ['text', 'key', '键字段名', '即表中的主键字段名,如果表中的主键字段名为id则可不填写'], ['text', 'option', '值字段名', '下拉菜单显示的字段名,如果表中的该字段名为name则可不填写'], ['text', 'ak', 'APPKEY', '百度编辑器APPKEY'], ['text', 'format', '格式'], ['textarea', 'tips', '字段说明', '字段补充说明'], ['radio', 'fixed', '是否为固定字段', '如果为 固定字段 则添加后不可修改', ['否', '是'], 0], ['radio', 'show', '是否显示', '新增或编辑时是否显示该字段', ['否', '是'], 1], ['radio', 'status', '立即启用', '', ['否', '是'], 1], ['text', 'sort', '排序', '', 100], ]) ->setTrigger('type', 'linkage', 'ajax_url,next_items,param') ->setTrigger('type', 'linkages', 'table,pid,key,option') ->setTrigger('type', 'bmap', 'ak') ->setTrigger('type', 'linkages,bmap', 'level') ->setTrigger('type', 'masked,date,time,datetime', 'format') ->setTrigger('type', 'checkbox,radio,array,select,linkage,linkages', 'options') ->js('field') ->fetch(); } /** * 编辑字段 * @param null $id 字段id * @author 蔡伟明 <314013107@qq.com> * @return mixed */ public function edit($id = null) { if ($id === null) $this->error('参数错误'); // 保存数据 if ($this->request->isPost()) { // 表单数据 $data = $this->request->post(); // 验证 $result = $this->validate($data, 'Field'); if(true !== $result) $this->error($result); // 如果是快速联动 if ($data['type'] == 'linkages') { $data['key'] = $data['key'] == '' ? 'id' : $data['key']; $data['pid'] = $data['pid'] == '' ? 'pid' : $data['pid']; $data['level'] = $data['level'] == '' ? '2' : $data['level']; $data['option'] = $data['option'] == '' ? 'name' : $data['option']; } // 如果是百度地图 if ($data['type'] == 'bmap') { $data['level'] = !$data['level'] ? 12 : $data['level']; } // 更新字段信息 $FieldModel = new FieldModel(); if ($FieldModel->updateField($data)) { if ($FieldModel->isUpdate(true)->save($data)) { // 记录行为 action_log('field_edit', 'cms_field', $id, UID, $data['name']); $this->success('字段更新成功', cookie('__forward__')); } } $this->error('字段更新失败'); } // 获取数据 $info = FieldModel::get($id); // 显示编辑页面 return ZBuilder::make('form') ->addFormItems([ ['hidden', 'id'], ['hidden', 'model'], ['text', 'name', '字段名称', '由小写英文字母和下划线组成'], ['text', 'title', '字段标题', '可填写中文'], ['select', 'type', '字段类型', '', config('form_item_type')], ['text', 'define', '字段定义', '可根据实际需求自行填写或修改,但必须是正确的sql语法'], ['text', 'value', '字段默认值'], ['textarea', 'options', '额外选项', '用于单选、多选、下拉、联动等类型'], ['text', 'ajax_url', '异步请求地址', "如请求的地址是 url('ajax/getCity'),那么只需填写 ajax/getCity,或者直接填写以 http开头的url地址"], ['text', 'next_items', '下一级联动下拉框的表单名', "与当前有关联的下级联动下拉框名,多个用逗号隔开,如:area,other"], ['text', 'param', '请求参数名', "联动下拉框请求参数名,默认为配置名称"], ['text', 'level', '级别', '如果类型为【快速联动下拉框】则表示需要显示的级别数量,默认为2。如果类型为【百度地图】,则表示地图默认缩放级别,建议设置为12'], ['text', 'table', '表名', '要查询的表,里面必须含有id、name、pid三个字段,其中id和name字段可在下面重新定义'], ['text', 'pid', '父级id字段名', '即表中的父级ID字段名,如果表中的主键字段名为pid则可不填写'], ['text', 'key', '键字段名', '即表中的主键字段名,如果表中的主键字段名为id则可不填写'], ['text', 'option', '值字段名', '下拉菜单显示的字段名,如果表中的该字段名为name则可不填写'], ['text', 'ak', 'APPKEY', '百度编辑器APPKEY'], ['text', 'format', '格式'], ['textarea', 'tips', '字段说明', '字段补充说明'], ['radio', 'show', '是否显示', '新增或编辑时是否显示该字段', ['否', '是']], ['radio', 'status', '立即启用', '', ['否', '是']], ['text', 'sort', '排序'], ]) ->setTrigger('type', 'linkage', 'ajax_url,next_items,param') ->setTrigger('type', 'linkages', 'table,pid,key,option') ->setTrigger('type', 'bmap', 'ak') ->setTrigger('type', 'linkages,bmap', 'level') ->setTrigger('type', 'masked,date,time,datetime', 'format') ->setTrigger('type', 'checkbox,radio,array,select,linkage,linkages', 'options') ->js('field') ->setFormData($info) ->fetch(); } /** * 删除字段 * @param null $ids 字段id * @author 蔡伟明 <314013107@qq.com> * @return mixed */ public function delete($ids = null) { if ($ids === null) $this->error('参数错误'); $FieldModel = new FieldModel(); $field = $FieldModel->where('id', $ids)->find(); if ($FieldModel->deleteField($field)) { if ($FieldModel->where('id', $ids)->delete()) { // 记录行为 $details = '详情:文档模型('.get_model_title($field['model']).')、字段名称('.$field['name'].')、字段标题('.$field['title'].')、字段类型('.$field['type'].')'; action_log('field_delete', 'cms_field', $ids, UID, $details); $this->success('删除成功', cookie('__forward__')); } } return $this->error('删除失败'); } /** * 启用字段 * @param array $record 行为日志 * @author 蔡伟明 <314013107@qq.com> * @return mixed */ public function enable($record = []) { return $this->setStatus('enable'); } /** * 禁用字段 * @param array $record 行为日志 * @author 蔡伟明 <314013107@qq.com> * @return mixed */ public function disable($record = []) { return $this->setStatus('disable'); } /** * 设置字段状态:删除、禁用、启用 * @param string $type 类型:enable/disable * @param array $record * @author 蔡伟明 <314013107@qq.com> * @return mixed */ public function setStatus($type = '', $record = []) { $ids = $this->request->isPost() ? input('post.ids/a') : input('param.ids'); $field_delete = is_array($ids) ? '' : $ids; $field_names = FieldModel::where('id', 'in', $ids)->column('name'); return parent::setStatus($type, ['field_'.$type, 'cms_field', $field_delete, UID, implode('、', $field_names)]); } /** * 快速编辑 * @param array $record 行为日志 * @author 蔡伟明 <314013107@qq.com> * @return mixed */ public function quickEdit($record = []) { $id = input('post.pk', ''); $field = input('post.name', ''); $value = input('post.value', ''); $config = FieldModel::where('id', $id)->value($field); $details = '字段(' . $field . '),原值(' . $config . '),新值:(' . $value . ')'; return parent::quickEdit(['field_edit', 'cms_field', $id, UID, $details]); } }