Rule.php 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  1. <?php
  2. namespace app\admin\controller\user;
  3. use ba\Tree;
  4. use Exception;
  5. use think\facade\Db;
  6. use app\admin\model\UserRule;
  7. use app\common\controller\Backend;
  8. use think\db\exception\PDOException;
  9. use think\exception\ValidateException;
  10. class Rule extends Backend
  11. {
  12. /**
  13. * @var UserRule
  14. */
  15. protected $model = null;
  16. /**
  17. * @var Tree
  18. */
  19. protected $tree = null;
  20. protected $noNeedLogin = ['index'];
  21. protected $preExcludeFields = ['createtime', 'updatetime'];
  22. protected $quickSearchField = 'title';
  23. /**
  24. * 远程select初始化传值
  25. * @var array
  26. */
  27. protected $initValue;
  28. /**
  29. * 是否组装Tree
  30. * @var bool
  31. */
  32. protected $assembleTree;
  33. /**
  34. * 搜索关键词
  35. * @var array
  36. */
  37. protected $keyword = false;
  38. public function initialize()
  39. {
  40. parent::initialize();
  41. $this->model = new UserRule();
  42. $this->tree = Tree::instance();
  43. $isTree = $this->request->param('isTree', true);
  44. $this->initValue = $this->request->get("initValue/a", '');
  45. $this->keyword = $this->request->request("quick_search");
  46. // 有初始化值时不组装树状(初始化出来的值更好看)
  47. $this->assembleTree = $isTree && !$this->initValue;
  48. }
  49. public function index()
  50. {
  51. if ($this->request->param('select')) {
  52. $this->select();
  53. }
  54. $this->success('', [
  55. 'list' => $this->getRules(),
  56. 'remark' => get_route_remark(),
  57. ]);
  58. }
  59. /**
  60. * 编辑
  61. */
  62. public function edit()
  63. {
  64. $id = $this->request->param($this->model->getPk());
  65. $row = $this->model->find($id);
  66. if (!$row) {
  67. $this->error(__('Record not found'));
  68. }
  69. $dataLimitAdminIds = $this->getDataLimitAdminIds();
  70. if ($dataLimitAdminIds && !in_array($row[$this->dataLimitField], $dataLimitAdminIds)) {
  71. $this->error(__('You have no permission'));
  72. }
  73. if ($this->request->isPost()) {
  74. $data = $this->request->post();
  75. if (!$data) {
  76. $this->error(__('Parameter %s can not be empty', ['']));
  77. }
  78. $data = $this->excludeFields($data);
  79. $result = false;
  80. Db::startTrans();
  81. try {
  82. // 模型验证
  83. if ($this->modelValidate) {
  84. $validate = str_replace("\\model\\", "\\validate\\", get_class($this->model));
  85. if (class_exists($validate)) {
  86. $validate = new $validate;
  87. if ($this->modelSceneValidate) $validate->scene('edit');
  88. $validate->check($data);
  89. }
  90. }
  91. if (isset($data['pid']) && $data['pid'] > 0) {
  92. // 满足意图并消除副作用
  93. $parent = $this->model->where('id', $data['pid'])->find();
  94. if ($parent['pid'] == $row['id']) {
  95. $parent->pid = 0;
  96. $parent->save();
  97. }
  98. }
  99. $result = $row->save($data);
  100. Db::commit();
  101. } catch (ValidateException|Exception|PDOException $e) {
  102. Db::rollback();
  103. $this->error($e->getMessage());
  104. }
  105. if ($result !== false) {
  106. $this->success(__('Update successful'));
  107. } else {
  108. $this->error(__('No rows updated'));
  109. }
  110. }
  111. $this->success('', [
  112. 'row' => $row
  113. ]);
  114. }
  115. /**
  116. * 删除
  117. * @param array $ids
  118. */
  119. public function del(array $ids = [])
  120. {
  121. if (!$this->request->isDelete() || !$ids) {
  122. $this->error(__('Parameter error'));
  123. }
  124. $dataLimitAdminIds = $this->getDataLimitAdminIds();
  125. if ($dataLimitAdminIds) {
  126. $this->model->where($this->dataLimitField, 'in', $dataLimitAdminIds);
  127. }
  128. $pk = $this->model->getPk();
  129. $data = $this->model->where($pk, 'in', $ids)->select();
  130. $subData = $this->model->where('pid', 'in', $ids)->column('pid', 'id');
  131. foreach ($subData as $key => $subDatum) {
  132. if (!in_array($key, $ids)) {
  133. $this->error(__('Please delete the child element first, or use batch deletion'));
  134. }
  135. }
  136. $count = 0;
  137. Db::startTrans();
  138. try {
  139. foreach ($data as $v) {
  140. $count += $v->delete();
  141. }
  142. Db::commit();
  143. } catch (PDOException|Exception $e) {
  144. Db::rollback();
  145. $this->error($e->getMessage());
  146. }
  147. if ($count) {
  148. $this->success(__('Deleted successfully'));
  149. } else {
  150. $this->error(__('No rows were deleted'));
  151. }
  152. }
  153. public function select()
  154. {
  155. $data = $this->getRules([['status', '=', '1']]);
  156. if ($this->assembleTree) {
  157. $data = $this->tree->assembleTree($this->tree->getTreeArray($data, 'title'));
  158. }
  159. $this->success('', [
  160. 'options' => $data
  161. ]);
  162. }
  163. public function getRules($where = []): array
  164. {
  165. $pk = $this->model->getPk();
  166. $initKey = $this->request->get("initKey/s", $pk);
  167. if ($this->keyword) {
  168. $keyword = explode(' ', $this->keyword);
  169. foreach ($keyword as $item) {
  170. $where[] = [$this->quickSearchField, 'like', '%' . $item . '%'];
  171. }
  172. }
  173. if ($this->initValue) {
  174. $where[] = [$initKey, 'in', $this->initValue];
  175. }
  176. $data = $this->model->where($where)->order('weigh desc,id asc')->select()->toArray();
  177. return $this->assembleTree ? $this->tree->assembleChild($data) : $data;
  178. }
  179. }