Process.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254
  1. <?php
  2. namespace app\admin\controller;
  3. use app\BaseController;
  4. use think\App;
  5. use think\facade\Db;
  6. use think\facade\Validate;
  7. use app\admin\model\Process as ProcessModel;
  8. use app\admin\model\ActionProcess as APModel;
  9. //流程单
  10. class Process extends Base
  11. {
  12. public function __construct(App $app)
  13. {
  14. parent::__construct($app);
  15. }
  16. /**
  17. * @return \think\response\Json|void
  18. * @throws \think\db\exception\DataNotFoundException
  19. * @throws \think\db\exception\DbException
  20. * @throws \think\db\exception\ModelNotFoundException
  21. */
  22. public function list()
  23. {
  24. $page = isset($this->post['page']) && $this->post['page'] != "" ? intval($this->post['page']) : 1;
  25. $size = isset($this->post['size']) && $this->post['size'] != "" ? intval($this->post['size']) : 10;
  26. $count = Db::name("process")->where('is_del', 0)->count();
  27. $total = ceil($count / $size);
  28. $page = $page > $total ? $total : $page;
  29. $list = Db::name("process")->where('is_del', 0)->page($page, $size)->select();
  30. return app_show(0, "获取成功", ["list" => $list, "count" => $count]);
  31. }
  32. /**
  33. * @return \think\response\Json|void
  34. * @throws \think\db\exception\DataNotFoundException
  35. * @throws \think\db\exception\DbException
  36. * @throws \think\db\exception\ModelNotFoundException
  37. */
  38. public function info()
  39. {
  40. $id = isset($this->post['id']) && $this->post['id'] != "" ? intval($this->post['id']) : "";
  41. if ($id == "") {
  42. return error_show(1004, "参数id 不能为空");
  43. }
  44. $info = Db::name("process")->where(['id' => $id, "is_del" => 0])->find();
  45. if (empty($info)) {
  46. return error_show(1004, "流程信息未找到");
  47. }
  48. $list = Db::name("action_process")->where(["pid" => $id, "is_del" => 0])->order("weight,id")->select();
  49. $info['item'] = empty($list) ? [] : $list;
  50. return app_show(0, "获取成功", $info);
  51. }
  52. //审核记录
  53. public function process()
  54. {
  55. $param = $this->request->filter('trim')->only(['type', 'orderCode'], 'post');
  56. $val = Validate::rule([]);
  57. if (!$val->check($param)) return error_show(1004, $val->getError());
  58. // $process_type = isset($this->post['type']) && $this->post['type'] != "" ? $this->post['type'] : "";
  59. // if ($process_type == "") {
  60. // return error_show(1004, "参数type 不能为空");
  61. // }
  62. // $orderCode = isset($this->post['orderCode']) && $this->post['orderCode'] != "" ? $this->post['orderCode'] : "";
  63. // if ($orderCode == "") {
  64. // return error_show(1004, "参数orderCode不能为空");
  65. // }
  66. // $list = Db::name("action_process")
  67. // ->where(['order_type' => $param['type'], "is_del" => 0, "status" => 1])
  68. // ->order("weight desc,id desc")
  69. // ->column('*', 'order_process');
  70. //根据所有的状态,查询对应的操作
  71. // $order_process_s = array_column($list, 'order_process');
  72. $rs = Db::name("process_order")
  73. ->alias('a')
  74. ->leftJoin('action_process b', 'b.order_type=a.order_type AND b.order_process=a.action_process')
  75. ->where(["a.order_type" => $param['type']])
  76. ->order('a.id', 'asc')
  77. ->field('a.id,a.action_uid,a.action_name,a.addtime,a.action_process,a.order_type,a.source,a.action_process,b.status_name');
  78. if (is_numeric($param['orderCode'])) $rs->where('a.order_id', $param['orderCode']);
  79. else $rs->where('a.order_code', $param['orderCode']);
  80. $node = $rs
  81. ->select()
  82. ->toArray();
  83. $i = 0;
  84. $data = [['status_name' => '创建', 'order_process' => -1]];
  85. foreach ($node as $value) {
  86. $data[$i] = array_merge($data[$i], [
  87. 'action_uid' => $value['action_uid'],
  88. 'action_name' => $value['action_name'],
  89. 'addtime' => $value['addtime'],
  90. 'source' => $value['source'],
  91. ]);
  92. $data[$i + 1] = [
  93. 'status_name' => $value['status_name'],
  94. 'order_process' => $value['action_process']
  95. ];
  96. // $value['order_process'] = isset($list[$value['action_process']]['order_process']) ? $list[$value['action_process']]['order_process'] : 0;
  97. // $value['order_name'] = isset($list[$value['action_process']]['order_name']) ? $list[$value['action_process']]['order_name'] : '';
  98. // $value['pid'] = isset($list[$value['action_process']]['pid']) ? $list[$value['action_process']]['pid'] : '';
  99. // $value['status_name'] = isset($list[$value['action_process']]['status_name']) ? $list[$value['action_process']]['status_name'] : '';
  100. // $value['roleid'] = isset($list[$value['action_process']]['roleid']) ? $list[$value['action_process']]['roleid'] : '';
  101. // $value['status'] = isset($list[$value['action_process']]['status']) ? $list[$value['action_process']]['status'] : '';
  102. // $value['weight'] = isset($list[$value['action_process']]['weight']) ? $list[$value['action_process']]['weight'] : '';
  103. // $value['is_del'] = isset($list[$value['action_process']]['is_del']) ? $list[$value['action_process']]['is_del'] : '';
  104. $i++;
  105. }
  106. // if ($node) array_unshift($node, ['status_name' => '创建', 'order_process' => -1]);
  107. return app_show(0, "获取成功", $data);
  108. }
  109. //获取流程列表
  110. public function getList()
  111. {
  112. $param = $this->request->filter('trim')->only(['status' => '', 'process_name' => '', 'creater' => '', 'addtime_start' => '', 'addtime_end' => '', 'page' => 1, 'size' => 15], 'post');
  113. $where = [['is_del', '=', ProcessModel::$is_del_normal]];
  114. if ($param['status'] != '') $where[] = ['status', '=', $param['status']];
  115. if ($param['process_name'] != '') $where[] = ['process_name', 'like', '%' . $param['process_name'] . '%'];
  116. if ($param['creater'] != '') $where[] = ['creater', 'like', '%' . $param['creater'] . '%'];
  117. if ($param['addtime_start'] != '' && $param['addtime_end'] != '') $where[] = ['addtime', 'between', [$param['addtime_start'], $param['addtime_end'] . ' 23:59:59']];
  118. $count = Db::name('process')
  119. ->where($where)
  120. ->count('id');
  121. $list = ProcessModel::field('id,process_name,process_type,status,creater,addtime')
  122. ->where($where)
  123. ->order(['weight'=>'desc','id'=>'desc'])
  124. ->page($param['page'], $param['size'])
  125. ->select()
  126. ->toArray();
  127. return app_show(0, '获取成功', ['count' => $count, 'list' => $list]);
  128. }
  129. //增加流程
  130. public function add()
  131. {
  132. $param = $this->request->filter('trim')->only(['token', 'process_name', 'process_type', 'remark' => ''], 'post');
  133. $val = Validate::rule([
  134. 'token' => 'require',
  135. 'process_name|流程名称' => 'require|max:255',
  136. 'process_type|流程值' => 'require|max:255|checkProcessType:',
  137. ]);
  138. $val->extend('checkProcessType', function ($val) {
  139. return ProcessModel::where(['process_type' => $val, 'is_del' => ProcessModel::$is_del_normal])->field('id')->findOrEmpty()->isEmpty() ? true : '该流程值已存在';
  140. });
  141. if (!$val->check($param)) return error_show(1005, $val->getError());
  142. $user = GetUserInfo($param['token']);
  143. $uid = isset($user['data']['id']) ? $user['data']['id'] : 0;
  144. $uname = isset($user['data']['nickname']) ? $user['data']['nickname'] : '';
  145. $date = date('Y-m-d H:i:s');
  146. return ProcessModel::create(array_merge($param, [
  147. 'is_del' => ProcessModel::$is_del_normal,
  148. 'status' => ProcessModel::$status_disable,
  149. 'createrid' => $uid,
  150. 'creater' => $uname,
  151. 'addtime' => $date,
  152. 'updaterid' => $uid,
  153. 'updater' => $uname,
  154. 'updatetime' => $date,
  155. ]))->save() ? app_show(0, '新增流程成功') : error_show(1005, '新增流程失败');
  156. }
  157. //读取
  158. public function read()
  159. {
  160. $id = $this->request->filter('trim')->post('id/d', 0);
  161. $res = ProcessModel::field('id,process_name,process_type')
  162. ->where(['id' => $id, 'is_del' => ProcessModel::$is_del_normal])
  163. ->findOrEmpty()
  164. ->toArray();
  165. return app_show(0, '获取详情成功', $res);
  166. }
  167. //修改流程
  168. public function update()
  169. {
  170. $param = $this->request->filter('trim')->only(['token', 'id', 'process_name', 'process_type', 'status', 'is_del', 'remark'], 'post');
  171. $val = Validate::rule([
  172. 'token' => 'require',
  173. 'id|ID' => 'require|number|gt:0',
  174. 'process_name|流程名称' => 'max:255',
  175. 'process_type|流程值' => 'max:255|checkProcessType:',
  176. 'status|状态' => 'number|in:' . ProcessModel::$status_normal . ',' . ProcessModel::$status_disable,
  177. 'is_del|是否删除' => 'number|eq:' . ProcessModel::$is_deleted,
  178. ]);
  179. $val->extend('checkProcessType', function ($val, $rule, $data) {
  180. return ProcessModel::where(['process_type' => $val, 'is_del' => ProcessModel::$is_del_normal])->where('id', '<>', $data['id'])->field('id')->findOrEmpty()->isEmpty() ? true : '该流程值已存在';
  181. });
  182. if (!$val->check($param)) return error_show(1005, $val->getError());
  183. if (isset($param['status']) && $param['status'] == ProcessModel::$status_normal) {
  184. //启用流程时候,校验该流程下有没有开始节点和结束节点
  185. $ap_info = APModel::where([
  186. 'process_id' => $param['id'],
  187. 'is_del' => APModel::$is_del_normal,
  188. 'status' => APModel::$status_normal
  189. ])->whereIn('action_type', [
  190. APModel::$action_type_start,
  191. APModel::$action_type_end
  192. ])->column('id', 'action_type');
  193. if (count($ap_info) != 2) return error_show(1005, '该流程下缺少开始节点和结束节点');
  194. }
  195. $user = GetUserInfo($param['token']);
  196. $uid = isset($user['data']['id']) ? $user['data']['id'] : 0;
  197. $uname = isset($user['data']['nickname']) ? $user['data']['nickname'] : '';
  198. $date = date('Y-m-d H:i:s');
  199. return ProcessModel::where(['id' => $param['id'], 'is_del' => ProcessModel::$is_del_normal])->strict(false)->save(array_merge($param, [
  200. 'updaterid' => $uid,
  201. 'updater' => $uname,
  202. 'updatetime' => $date,
  203. ])) ? app_show(0, '修改流程成功') : error_show(1005, '修改流程失败');
  204. }
  205. }