You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

331 lines
16 KiB
PHTML

3 years ago
<?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]);
}
}