Config.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | 海豚PHP框架 [ DolphinPHP ]
  4. // +----------------------------------------------------------------------
  5. // | 版权所有 2016~2019 广东卓锐软件有限公司 [ http://www.zrthink.com ]
  6. // +----------------------------------------------------------------------
  7. // | 官方网站: http://dolphinphp.com
  8. // +----------------------------------------------------------------------
  9. namespace app\admin\controller;
  10. use app\common\builder\ZBuilder;
  11. use app\admin\model\Config as ConfigModel;
  12. /**
  13. * 系统配置控制器
  14. * @package app\admin\controller
  15. */
  16. class Config extends Admin
  17. {
  18. /**
  19. * 配置首页
  20. * @param string $group 分组
  21. * @author 蔡伟明 <314013107@qq.com>
  22. * @return mixed
  23. * @throws \think\Exception
  24. * @throws \think\exception\DbException
  25. */
  26. public function index($group = 'base')
  27. {
  28. cookie('__forward__', $_SERVER['REQUEST_URI']);
  29. // 配置分组信息
  30. $list_group = config('config_group');
  31. $tab_list = [];
  32. foreach ($list_group as $key => $value) {
  33. $tab_list[$key]['title'] = $value;
  34. $tab_list[$key]['url'] = url('index', ['group' => $key]);
  35. }
  36. // 查询
  37. $map = $this->getMap();
  38. $map[] = ['group', '=', $group];
  39. $map[] = ['status', 'egt', 0];
  40. // 排序
  41. $order = $this->getOrder('sort asc,id asc');
  42. // 数据列表
  43. $data_list = ConfigModel::where($map)->order($order)->paginate();
  44. // 使用ZBuilder快速创建数据表格
  45. return ZBuilder::make('table')
  46. ->setPageTitle('配置管理') // 设置页面标题
  47. ->setTabNav($tab_list, $group) // 设置tab分页
  48. ->setSearch(['name' => '名称', 'title' => '标题']) // 设置搜索框
  49. ->addColumns([ // 批量添加数据列
  50. ['name', '名称', 'text.edit'],
  51. ['title', '标题', 'text.edit'],
  52. ['type', '类型', 'select', config('form_item_type')],
  53. ['status', '状态', 'switch'],
  54. ['sort', '排序', 'text.edit'],
  55. ['right_button', '操作', 'btn']
  56. ])
  57. ->addValidate('Config', 'name,title') // 添加快捷编辑的验证器
  58. ->addOrder('name,title,status') // 添加标题字段排序
  59. ->addFilter('name,title') // 添加标题字段筛选
  60. ->addFilter('type', config('form_item_type')) // 添加标题字段筛选
  61. ->addFilterMap('name,title', ['group' => $group]) // 添加标题字段筛选条件
  62. ->addTopButton('add', ['href' => url('add', ['group' => $group])], true) // 添加单个顶部按钮
  63. ->addTopButtons('enable,disable,delete') // 批量添加顶部按钮
  64. ->addRightButton('edit', [], true)
  65. ->addRightButton('delete') // 批量添加右侧按钮
  66. ->setRowList($data_list) // 设置表格数据
  67. ->fetch(); // 渲染模板
  68. }
  69. /**
  70. * 新增配置项
  71. * @param string $group 分组
  72. * @author 蔡伟明 <314013107@qq.com>
  73. * @return mixed
  74. * @throws \think\Exception
  75. */
  76. public function add($group = '')
  77. {
  78. // 保存数据
  79. if ($this->request->isPost()) {
  80. // 表单数据
  81. $data = $this->request->post();
  82. // 验证
  83. $result = $this->validate($data, 'Config');
  84. if(true !== $result) $this->error($result);
  85. // 如果是快速联动
  86. if ($data['type'] == 'linkages') {
  87. $data['key'] = $data['key'] == '' ? 'id' : $data['key'];
  88. $data['pid'] = $data['pid'] == '' ? 'pid' : $data['pid'];
  89. $data['level'] = $data['level'] == '' ? '2' : $data['level'];
  90. $data['option'] = $data['option'] == '' ? 'name' : $data['option'];
  91. }
  92. if ($config = ConfigModel::create($data)) {
  93. cache('system_config', null);
  94. $forward = $this->request->param('_pop') == 1 ? null : cookie('__forward__');
  95. // 记录行为
  96. $details = '详情:分组('.$data['group'].')、类型('.$data['type'].')、标题('.$data['title'].')、名称('.$data['name'].')';
  97. action_log('config_add', 'admin_config', $config['id'], UID, $details);
  98. $this->success('新增成功', $forward);
  99. } else {
  100. $this->error('新增失败');
  101. }
  102. }
  103. // 使用ZBuilder快速创建表单
  104. return ZBuilder::make('form')
  105. ->setPageTitle('新增')
  106. ->addRadio('group', '配置分组', '', config('config_group'), $group)
  107. ->addSelect('type', '配置类型', '', config('form_item_type'))
  108. ->addText('title', '配置标题', '一般由中文组成,仅用于显示')
  109. ->addText('name', '配置名称', '由英文字母和下划线组成,如 <code>web_site_title</code>,调用方法:<code>config(\'web_site_title\')</code>')
  110. ->addTextarea('value', '配置值', '该配置的具体内容')
  111. ->addTextarea('options', '配置项', '用于单选、多选、下拉、联动等类型')
  112. ->addText('ajax_url', '异步请求地址', "如请求的地址是 <code>url('ajax/getCity')</code>,那么只需填写 <code>ajax/getCity</code>,或者直接填写以 <code>http</code>开头的url地址")
  113. ->addText('next_items', '下一级联动下拉框的表单名', "与当前有关联的下级联动下拉框名,多个用逗号隔开,如:area,other")
  114. ->addText('param', '请求参数名', "联动下拉框请求参数名,默认为配置名称")
  115. ->addNumber('level', '级别', '需要显示的级别数量,默认为2', 2, 2, 4)
  116. ->addText('table', '表名', '要查询的表,里面必须含有id、name、pid三个字段,其中id和name字段可在下面重新定义')
  117. ->addText('pid', '父级id字段名', '即表中的父级ID字段名,如果表中的主键字段名为pid则可不填写')
  118. ->addText('key', '键字段名', '即表中的主键字段名,如果表中的主键字段名为id则可不填写')
  119. ->addText('option', '值字段名', '下拉菜单显示的字段名,如果表中的该字段名为name则可不填写')
  120. ->addText('ak', 'APPKEY', '百度编辑器APPKEY')
  121. ->addText('format', '格式')
  122. ->addText('tips', '配置说明', '该配置的具体说明')
  123. ->addText('sort', '排序', '', 100)
  124. ->setTrigger('type', 'linkage', 'ajax_url,next_items,param')
  125. ->setTrigger('type', 'linkages', 'table,pid,level,key,option')
  126. ->setTrigger('type', 'bmap', 'ak')
  127. ->setTrigger('type', 'masked,date,time,datetime', 'format')
  128. ->fetch();
  129. }
  130. /**
  131. * 编辑
  132. * @param int $id
  133. * @author 蔡伟明 <314013107@qq.com>
  134. * @return mixed
  135. * @throws \think\Exception
  136. * @throws \think\db\exception\DataNotFoundException
  137. * @throws \think\db\exception\ModelNotFoundException
  138. * @throws \think\exception\DbException
  139. */
  140. public function edit($id = 0)
  141. {
  142. if ($id === 0) $this->error('参数错误');
  143. // 保存数据
  144. if ($this->request->isPost()) {
  145. // 表单数据
  146. $data = $this->request->post();
  147. // 验证
  148. $result = $this->validate($data, 'Config');
  149. if(true !== $result) $this->error($result);
  150. // 如果是快速联动
  151. if ($data['type'] == 'linkages') {
  152. $data['key'] = $data['key'] == '' ? 'id' : $data['key'];
  153. $data['pid'] = $data['pid'] == '' ? 'pid' : $data['pid'];
  154. $data['level'] = $data['level'] == '' ? '2' : $data['level'];
  155. $data['option'] = $data['option'] == '' ? 'name' : $data['option'];
  156. }
  157. // 原配置内容
  158. $config = ConfigModel::where('id', $id)->find();
  159. $details = '原数据:分组('.$config['group'].')、类型('.$config['type'].')、标题('.$config['title'].')、名称('.$config['name'].')';
  160. if ($config = ConfigModel::update($data)) {
  161. cache('system_config', null);
  162. $forward = $this->request->param('_pop') == 1 ? null : cookie('__forward__');
  163. // 记录行为
  164. action_log('config_edit', 'admin_config', $config['id'], UID, $details);
  165. $this->success('编辑成功', $forward, '_parent_reload');
  166. } else {
  167. $this->error('编辑失败');
  168. }
  169. }
  170. // 获取数据
  171. $info = ConfigModel::get($id);
  172. // 使用ZBuilder快速创建表单
  173. return ZBuilder::make('form')
  174. ->setPageTitle('编辑')
  175. ->addHidden('id')
  176. ->addRadio('group', '配置分组', '', config('config_group'))
  177. ->addSelect('type', '配置类型', '', config('form_item_type'))
  178. ->addText('title', '配置标题', '一般由中文组成,仅用于显示')
  179. ->addText('name', '配置名称', '由英文字母和下划线组成,如 <code>web_site_title</code>,调用方法:<code>config(\'web_site_title\')</code>')
  180. ->addTextarea('value', '配置值', '该配置的具体内容')
  181. ->addTextarea('options', '配置项', '用于单选、多选、下拉、联动等类型')
  182. ->addText('ajax_url', '异步请求地址', "如请求的地址是 <code>url('ajax/getCity')</code>,那么只需填写 <code>ajax/getCity</code>,或者直接填写以 <code>http</code>开头的url地址")
  183. ->addText('next_items', '下一级联动下拉框的表单名', "与当前有关联的下级联动下拉框名,多个用逗号隔开,如:area,other")
  184. ->addText('param', '请求参数名', "联动下拉框请求参数名,默认为配置名称")
  185. ->addNumber('level', '级别', '需要显示的级别数量,默认为2', 2, 2, 4)
  186. ->addText('table', '表名', '要查询的表,里面必须含有id、name、pid三个字段,其中id和name字段可在下面重新定义')
  187. ->addText('pid', '父级id字段名', '即表中的父级ID字段名,如果表中的主键字段名为pid则可不填写')
  188. ->addText('key', '键字段名', '即表中的主键字段名,如果表中的主键字段名为id则可不填写')
  189. ->addText('option', '值字段名', '下拉菜单显示的字段名,如果表中的该字段名为name则可不填写')
  190. ->addText('ak', 'APPKEY', '百度编辑器APPKEY')
  191. ->addText('format', '格式')
  192. ->addText('tips', '配置说明', '该配置的具体说明')
  193. ->addText('sort', '排序', '', 100)
  194. ->setTrigger('type', 'linkage', 'ajax_url,next_items,param')
  195. ->setTrigger('type', 'linkages', 'table,pid,level,key,option')
  196. ->setTrigger('type', 'bmap', 'ak')
  197. ->setTrigger('type', 'masked,date,time,datetime', 'format')
  198. ->setFormData($info)
  199. ->fetch();
  200. }
  201. /**
  202. * 删除配置
  203. * @param array $record 行为日志
  204. * @author 蔡伟明 <314013107@qq.com>
  205. * @throws \think\Exception
  206. * @throws \think\exception\PDOException
  207. */
  208. public function delete($record = [])
  209. {
  210. return $this->setStatus('delete');
  211. }
  212. /**
  213. * 启用配置
  214. * @param array $record 行为日志
  215. * @author 蔡伟明 <314013107@qq.com>
  216. * @throws \think\Exception
  217. * @throws \think\exception\PDOException
  218. */
  219. public function enable($record = [])
  220. {
  221. return $this->setStatus('enable');
  222. }
  223. /**
  224. * 禁用配置
  225. * @param array $record 行为日志
  226. * @author 蔡伟明 <314013107@qq.com>
  227. * @throws \think\Exception
  228. * @throws \think\exception\PDOException
  229. */
  230. public function disable($record = [])
  231. {
  232. return $this->setStatus('disable');
  233. }
  234. /**
  235. * 设置配置状态:删除、禁用、启用
  236. * @param string $type 类型:delete/enable/disable
  237. * @param array $record
  238. * @author 蔡伟明 <314013107@qq.com>
  239. * @throws \think\Exception
  240. * @throws \think\exception\PDOException
  241. */
  242. public function setStatus($type = '', $record = [])
  243. {
  244. $ids = $this->request->isPost() ? input('post.ids/a') : input('param.ids');
  245. $uid_delete = is_array($ids) ? '' : $ids;
  246. $ids = ConfigModel::where('id', 'in', $ids)->column('title');
  247. return parent::setStatus($type, ['config_'.$type, 'admin_config', $uid_delete, UID, implode('、', $ids)]);
  248. }
  249. /**
  250. * 快速编辑
  251. * @param array $record 行为日志
  252. * @author 蔡伟明 <314013107@qq.com>
  253. * @return mixed
  254. */
  255. public function quickEdit($record = [])
  256. {
  257. $id = input('post.pk', '');
  258. $field = input('post.name', '');
  259. $value = input('post.value', '');
  260. $config = ConfigModel::where('id', $id)->value($field);
  261. $details = '字段(' . $field . '),原值(' . $config . '),新值:(' . $value . ')';
  262. return parent::quickEdit(['config_edit', 'admin_config', $id, UID, $details]);
  263. }
  264. }