DataGroup.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311
  1. <?php
  2. namespace app\admin\controller;
  3. //用户组
  4. use think\Exception;
  5. use think\facade\Db;
  6. use think\facade\Validate;
  7. use app\admin\model\DataGroup as DataGroupModel;
  8. class DataGroup extends Base
  9. {
  10. //用户组列表
  11. public function getDataGroupList()
  12. {
  13. $param = $this->request->filter('trim')->only(['page' => 1, 'size' => 10, 'status' => '', 'title' => '', 'nickname' => '', 'type' => '']);
  14. $db = new DataGroupModel();
  15. $rs = $db
  16. ->alias('a')
  17. ->leftJoin('data_group_userid b', 'b.data_group_id=a.id AND b.is_del=' . DataGroupModel::$delete_正常)
  18. ->leftJoin('depart_user u', 'u.uid=b.uid AND u.is_del=0')
  19. ->group('a.id')
  20. ->where('a.is_del', DataGroupModel::$delete_正常);
  21. $val = Validate::rule([
  22. 'page|页码' => 'require|number|gt:0',
  23. 'size|每页数量' => 'require|number|gt:0|elt:100',
  24. 'status|状态' => 'number|in:' . DataGroupModel::$status_启用 . ',' . DataGroupModel::$status_禁用,
  25. 'title|用户组名称' => 'max:100',
  26. 'nickname|成员名称' => 'max:100',
  27. 'type|共享类型' => 'number|in:' . DataGroupModel::$type_可编辑 . ',' . DataGroupModel::$type_只读 . ',' . DataGroupModel::$type_不共享,
  28. ]);
  29. if (!$val->check($param)) return error_show(1005, $val->getError());
  30. if ($param['status'] != '') $rs->where('a.status', $param['status']);
  31. if ($param['title'] != '') $rs->whereLike('a.title', '%' . $param['title'] . '%');
  32. if ($param['nickname'] != '') $rs->whereLike('u.nickname', '%' . $param['nickname'] . '%');
  33. if ($param['type'] != '') $rs->where('a.type', $param['type']);
  34. $count = $rs->count('a.id');
  35. $list = $rs
  36. ->field('a.*,GROUP_CONCAT(u.nickname) nickname')
  37. ->page($param['page'], $param['size'])
  38. ->order('a.id', 'desc')
  39. ->select()
  40. ->toArray();
  41. return app_show(0, '请求成功', ['count' => $count, 'list' => $list]);
  42. }
  43. //添加
  44. public function addDataGroup()
  45. {
  46. $param = $this->request->filter('trim')->only(['title', 'uids', 'type', 'remark' => '']);
  47. $val = Validate::rule([
  48. 'title|用户组名称' => 'require|max:100',
  49. 'uids|组成员' => 'require|array|max:100',
  50. 'type|共享类型' => 'require|number|in:' . DataGroupModel::$type_可编辑 . ',' . DataGroupModel::$type_只读 . ',' . DataGroupModel::$type_不共享,
  51. 'remark|备注' => 'max:100',
  52. ]);
  53. if (!$val->check($param)) return error_show(1005, $val->getError());
  54. Db::startTrans();
  55. try {
  56. //添加用户组
  57. $group_id = Db::name('data_group')->insertGetId([
  58. 'title' => $param['title'],
  59. 'type' => $param['type'],
  60. 'remark' => $param['remark'],
  61. 'is_del' => DataGroupModel::$delete_正常,
  62. 'status' => DataGroupModel::$status_启用,
  63. 'createrid' => $this->uid,
  64. 'creater' => $this->uname,
  65. 'addtime' => date('Y-m-d H:i:s'),
  66. 'updatetime' => date('Y-m-d H:i:s'),
  67. ]);
  68. //用户组-用户集合
  69. $insert_data = [];
  70. foreach ($param['uids'] as $uids) {
  71. $insert_data[] = [
  72. 'data_group_id' => $group_id,
  73. 'uid' => $uids['uid'],
  74. 'is_del' => DataGroupModel::$delete_正常,
  75. 'status' => DataGroupModel::$status_启用,
  76. ];
  77. }
  78. if ($insert_data) Db::name('data_group_userid')->insertAll($insert_data);
  79. Db::commit();
  80. return app_show(0, '添加用户组成功');
  81. } catch (Exception $exception) {
  82. Db::rollback();
  83. return error_show(1005, '添加用户组失败');
  84. }
  85. }
  86. //获取详情
  87. public function getDataGroupDetail()
  88. {
  89. $id = $this->request->filter('trim')->post('id/d', 0);
  90. $info = DataGroupModel::field(true)
  91. ->where(['id' => $id, 'is_del' => DataGroupModel::$delete_正常])
  92. ->append(['user_list'])
  93. ->withAttr('user_list', function ($val, $data) {
  94. return Db::name('data_group_userid')
  95. ->alias('a')
  96. ->field('a.id,a.uid,u.nickname,a.is_del')
  97. ->leftJoin('depart_user u', 'u.uid=a.uid AND u.is_del=0')
  98. ->where([
  99. 'a.is_del' => DataGroupModel::$delete_正常,
  100. // 'a.status' => DataGroupModel::$status_启用,
  101. 'a.data_group_id' => $data['id']
  102. ])
  103. ->select()
  104. ->toArray();
  105. })
  106. ->findOrEmpty()
  107. ->toArray();
  108. return app_show(0, '获取详情成功', $info);
  109. }
  110. //修改
  111. public function editDataGroup()
  112. {
  113. $param = $this->request->filter('trim')->only(['id', 'title', 'uids', 'type', 'remark']);
  114. $val = Validate::rule([
  115. 'id' => 'require|number|gt:0',
  116. 'title|用户组名称' => 'require|max:100',
  117. 'uids|组成员' => 'require|array|max:100',
  118. 'type|共享类型' => 'require|number|in:' . DataGroupModel::$type_可编辑 . ',' . DataGroupModel::$type_只读 . ',' . DataGroupModel::$type_不共享,
  119. 'remark|备注' => 'max:100',
  120. ]);
  121. if (!$val->check($param)) return error_show(1005, $val->getError());
  122. Db::startTrans();
  123. try {
  124. $res = DataGroupModel::field('id,status')
  125. ->where(['id' => $param['id'], 'is_del' => DataGroupModel::$delete_正常])
  126. ->findOrEmpty();
  127. if ($res->isEmpty()) throw new Exception('该记录不存在');
  128. $param['updatetime'] = date('Y-m-d H:i:s');
  129. DataGroupModel::where(['id' => $param['id'], 'is_del' => DataGroupModel::$delete_正常])->strict(false)->save($param);
  130. //用户组-用户集合
  131. $insert_data = $delete_data = [];
  132. foreach ($param['uids'] as $uid) {
  133. if (isset($uid['id']) && ((int)$uid['id']) != 0) {
  134. if ($uid['is_del'] == DataGroupModel::$delete_删除) $delete_data[] = $uid['id'];
  135. } else $insert_data[] = [
  136. 'data_group_id' => $param['id'],
  137. 'uid' => $uid['uid'],
  138. 'is_del' => DataGroupModel::$delete_正常,
  139. 'status' => $res->status,
  140. 'addtime' => date('Y-m-d H:i:s'),
  141. 'updatetime' => date('Y-m-d H:i:s'),
  142. ];
  143. }
  144. if ($delete_data) Db::name('data_group_userid')
  145. ->whereIn('id', $delete_data)
  146. ->where(['is_del' => DataGroupModel::$delete_正常, 'data_group_id' => $param['id']])
  147. ->update(['is_del' => DataGroupModel::$delete_删除, 'updatetime' => date('Y-m-d H:i:s')]);
  148. if ($insert_data) Db::name('data_group_userid')->insertAll($insert_data);
  149. Db::commit();
  150. return app_show(0, '修改用户组成功');
  151. } catch (Exception $exception) {
  152. Db::rollback();
  153. return error_show(1005, '修改用户组失败,' . $exception->getMessage());
  154. }
  155. }
  156. //删除
  157. public function deleteDataGroup()
  158. {
  159. $param = $this->request->filter('trim')->only(['id']);
  160. $val = Validate::rule(['id' => 'require|array|max:100']);
  161. if (!$val->check($param)) return error_show(1005, $val->getError());
  162. Db::startTrans();
  163. try {
  164. Db::name('data_group')
  165. ->whereIn('id', $param['id'])
  166. ->where(['is_del' => DataGroupModel::$delete_正常])
  167. ->update(['is_del' => DataGroupModel::$delete_删除, 'updatetime' => date('Y-m-d H:i:s')]);
  168. Db::name('data_group_userid')
  169. ->whereIn('data_group_id', $param['id'])
  170. ->where('is_del', DataGroupModel::$delete_正常)
  171. ->update(['is_del' => DataGroupModel::$delete_删除, 'updatetime' => date('Y-m-d H:i:s')]);
  172. Db::commit();
  173. return app_show(0, '删除用户组成功');
  174. } catch (Exception $exception) {
  175. Db::rollback();
  176. return error_show(1005, '删除用户组失败');
  177. }
  178. }
  179. //启/禁用用户组
  180. public function statusDataGroup()
  181. {
  182. $param = $this->request->filter('trim')->only(['id', 'status']);
  183. $val = Validate::rule([
  184. 'id' => 'require|array|max:100',
  185. 'status|状态' => 'require|number|in:' . DataGroupModel::$status_启用 . ',' . DataGroupModel::$status_禁用,
  186. ]);
  187. if (!$val->check($param)) return error_show(1005, $val->getError());
  188. $status = [0 => '禁用', 1 => '启用'];
  189. Db::startTrans();
  190. try {
  191. Db::name('data_group')
  192. ->where([
  193. ['id', 'in', $param['id']],
  194. ['is_del', '=', DataGroupModel::$delete_正常],
  195. ['status', '<>', $param['status']],
  196. ])->update(['status' => $param['status'], 'updatetime' => date('Y-m-d H:i:s')]);
  197. Db::name('data_group_userid')
  198. ->where([
  199. ['data_group_id', 'in', $param['id']],
  200. ['is_del', '=', DataGroupModel::$delete_正常],
  201. ['status', '<>', $param['status']],
  202. ])->update(['status' => $param['status'], 'updatetime' => date('Y-m-d H:i:s')]);
  203. Db::commit();
  204. return app_show(0, $status[$param['status']] . '用户组成功');
  205. } catch (Exception $exception) {
  206. Db::rollback();
  207. return error_show(1005, $status[$param['status']] . '用户组失败');
  208. }
  209. }
  210. //用户组列表(全部)
  211. public function getDataGroupListAll()
  212. {
  213. // $param = $this->request->filter('trim')->only(['status' => '', 'title' => '', 'type' => '']);
  214. $db = new DataGroupModel();
  215. $rs = $db
  216. ->alias('a')
  217. // ->leftJoin('data_group_userid b', 'b.data_group_id=a.id AND b.is_del=' . DataGroupModel::$delete_正常)
  218. // ->leftJoin('depart_user u', 'u.uid=b.uid AND u.is_del=0')
  219. // ->group('a.id')
  220. ->where('a.is_del', DataGroupModel::$delete_正常);
  221. // $val = Validate::rule([
  222. // 'status|状态' => 'number|in:' . DataGroupModel::$status_启用 . ',' . DataGroupModel::$status_禁用,
  223. // 'title|用户组名称' => 'max:100',
  224. //// 'nickname|成员名称' => 'max:100',
  225. // 'type|共享类型' => 'number|in:' . DataGroupModel::$type_可编辑 . ',' . DataGroupModel::$type_只读 . ',' . DataGroupModel::$type_不共享,
  226. // ]);
  227. // if (!$val->check($param)) return error_show(1005, $val->getError());
  228. // if ($param['status'] != '') $rs->where('a.status', $param['status']);
  229. // if ($param['title'] != '') $rs->whereLike('a.title', '%' . $param['title'] . '%');
  230. // if ($param['nickname'] != '') $rs->whereLike('u.nickname', '%' . $param['nickname'] . '%');
  231. // if ($param['type'] != '') $rs->where('a.type', $param['type']);
  232. $list = $db
  233. ->where('is_del', DataGroupModel::$delete_正常)
  234. // ->field('a.*,GROUP_CONCAT(u.nickname) nickname')
  235. ->field('id,title,status')
  236. ->order('id', 'desc')
  237. ->select()
  238. ->toArray();
  239. return app_show(0, '请求成功', $list);
  240. }
  241. }