331 lines
16 KiB
PHP
331 lines
16 KiB
PHP
<?php
|
||
// +----------------------------------------------------------------------
|
||
// | 海豚PHP框架 [ DolphinPHP ]
|
||
// +----------------------------------------------------------------------
|
||
// | 版权所有 2016~2017 河源市卓锐科技有限公司 [ http://www.zrthink.com ]
|
||
// +----------------------------------------------------------------------
|
||
// | 官方网站: http://dolphinphp.com
|
||
// +----------------------------------------------------------------------
|
||
// | 开源协议 ( http://www.apache.org/licenses/LICENSE-2.0 )
|
||
// +----------------------------------------------------------------------
|
||
|
||
namespace app\cms\admin;
|
||
|
||
use app\admin\controller\Admin;
|
||
use app\common\builder\ZBuilder;
|
||
use app\cms\model\Field as FieldModel;
|
||
use think\Db;
|
||
|
||
/**
|
||
* 字段管理控制器
|
||
* @package app\cms\admin
|
||
*/
|
||
class Field extends Admin
|
||
{
|
||
/**
|
||
* 字段列表
|
||
* @param null $id 文档模型id
|
||
* @author 蔡伟明 <314013107@qq.com>
|
||
*/
|
||
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('【显示】表示新增或编辑文档时是否显示该字段<br>【启用】表示前台是否显示')
|
||
->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], '<button class="btn btn-danger btn-xs" type="button" disabled>固定字段禁止操作</button>')
|
||
->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('以下字段名称已存在,请不要建立同名的字段:<br>'. 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', '异步请求地址', "如请求的地址是 <code>url('ajax/getCity')</code>,那么只需填写 <code>ajax/getCity</code>,或者直接填写以 <code>http</code>开头的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', '是否为固定字段', '如果为 <code>固定字段</code> 则添加后不可修改', ['否', '是'], 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', '异步请求地址', "如请求的地址是 <code>url('ajax/getCity')</code>,那么只需填写 <code>ajax/getCity</code>,或者直接填写以 <code>http</code>开头的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]);
|
||
}
|
||
}
|