Process.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  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. 'type'=>'require',
  58. 'orderCode'=>'require',
  59. ]);
  60. if (!$val->check($param)) return error_show(1004, $val->getError());
  61. // $process_type = isset($this->post['type']) && $this->post['type'] != "" ? $this->post['type'] : "";
  62. // if ($process_type == "") {
  63. // return error_show(1004, "参数type 不能为空");
  64. // }
  65. // $orderCode = isset($this->post['orderCode']) && $this->post['orderCode'] != "" ? $this->post['orderCode'] : "";
  66. // if ($orderCode == "") {
  67. // return error_show(1004, "参数orderCode不能为空");
  68. // }
  69. // $list = Db::name("action_process")
  70. // ->where(['order_type' => $param['type'], "is_del" => 0, "status" => 1])
  71. // ->order("weight desc,id desc")
  72. // ->column('*', 'order_process');
  73. //根据所有的状态,查询对应的操作
  74. // $order_process_s = array_column($list, 'order_process');
  75. $rs = Db::name("process_order")
  76. ->alias('a')
  77. ->leftJoin('action_process b', 'b.order_type=a.order_type AND b.order_process=a.action_process')
  78. ->where(["a.order_type" => $param['type']])
  79. ->order('a.id', 'asc')
  80. ->field('a.id,a.action_uid,a.action_name,a.addtime,a.action_process,a.order_type,a.source,a.level,a.action_process,b.status_name');
  81. if (is_numeric($param['orderCode'])) $rs->where('a.order_id', $param['orderCode']);
  82. else $rs->where('a.order_code', $param['orderCode']);
  83. $node = $rs
  84. ->select()
  85. ->toArray();
  86. $i = 0;
  87. if($param['type']=='FHGD') $data = [['status_name' => '创建-待发货', 'order_process' => -1]];//针对发货工单流程特殊处理
  88. else $data = [['status_name' => '创建', 'order_process' => -1]];
  89. foreach ($node as $value) {
  90. $data[$i] = array_merge($data[$i], [
  91. 'action_uid' => $value['action_uid'],
  92. 'action_name' => $value['action_name'],
  93. 'addtime' => $value['addtime'],
  94. 'source' => $value['source'],
  95. 'level' => $value['level'],
  96. ]);
  97. $data[$i + 1] = [
  98. 'status_name' => $value['status_name'],
  99. 'order_process' => $value['action_process']
  100. ];
  101. // $value['order_process'] = isset($list[$value['action_process']]['order_process']) ? $list[$value['action_process']]['order_process'] : 0;
  102. // $value['order_name'] = isset($list[$value['action_process']]['order_name']) ? $list[$value['action_process']]['order_name'] : '';
  103. // $value['pid'] = isset($list[$value['action_process']]['pid']) ? $list[$value['action_process']]['pid'] : '';
  104. // $value['status_name'] = isset($list[$value['action_process']]['status_name']) ? $list[$value['action_process']]['status_name'] : '';
  105. // $value['roleid'] = isset($list[$value['action_process']]['roleid']) ? $list[$value['action_process']]['roleid'] : '';
  106. // $value['status'] = isset($list[$value['action_process']]['status']) ? $list[$value['action_process']]['status'] : '';
  107. // $value['weight'] = isset($list[$value['action_process']]['weight']) ? $list[$value['action_process']]['weight'] : '';
  108. // $value['is_del'] = isset($list[$value['action_process']]['is_del']) ? $list[$value['action_process']]['is_del'] : '';
  109. $i++;
  110. }
  111. // if ($node) array_unshift($node, ['status_name' => '创建', 'order_process' => -1]);
  112. return app_show(0, "获取成功", $data);
  113. }
  114. //获取流程列表
  115. public function getList()
  116. {
  117. $param = $this->request->filter('trim')->only(['status' => '', 'process_name' => '', 'creater' => '', 'addtime_start' => '', 'addtime_end' => '', 'page' => 1, 'size' => 15], 'post');
  118. $where = [['is_del', '=', ProcessModel::$is_del_normal]];
  119. if ($param['status'] != '') $where[] = ['status', '=', $param['status']];
  120. if ($param['process_name'] != '') $where[] = ['process_name', 'like', '%' . $param['process_name'] . '%'];
  121. if ($param['creater'] != '') $where[] = ['creater', 'like', '%' . $param['creater'] . '%'];
  122. if ($param['addtime_start'] != '' && $param['addtime_end'] != '') $where[] = ['addtime', 'between', [$param['addtime_start'], $param['addtime_end'] . ' 23:59:59']];
  123. $count = Db::name('process')
  124. ->where($where)
  125. ->count('id');
  126. $list = ProcessModel::field('id,process_name,process_type,status,creater,addtime')
  127. ->where($where)
  128. ->order(['weight'=>'desc','id'=>'desc'])
  129. ->page($param['page'], $param['size'])
  130. ->select()
  131. ->toArray();
  132. return app_show(0, '获取成功', ['count' => $count, 'list' => $list]);
  133. }
  134. //增加流程
  135. public function add()
  136. {
  137. $param = $this->request->filter('trim')->only(['token', 'process_name', 'process_type', 'remark' => ''], 'post');
  138. $val = Validate::rule([
  139. 'token' => 'require',
  140. 'process_name|流程名称' => 'require|max:255',
  141. 'process_type|流程值' => 'require|max:255|checkProcessType:',
  142. ]);
  143. $val->extend('checkProcessType', function ($val) {
  144. return ProcessModel::where(['process_type' => $val, 'is_del' => ProcessModel::$is_del_normal])->field('id')->findOrEmpty()->isEmpty() ? true : '该流程值已存在';
  145. });
  146. if (!$val->check($param)) return error_show(1005, $val->getError());
  147. $user = GetUserInfo($param['token']);
  148. $uid = isset($user['data']['id']) ? $user['data']['id'] : 0;
  149. $uname = isset($user['data']['nickname']) ? $user['data']['nickname'] : '';
  150. $date = date('Y-m-d H:i:s');
  151. return ProcessModel::create(array_merge($param, [
  152. 'is_del' => ProcessModel::$is_del_normal,
  153. 'status' => ProcessModel::$status_disable,
  154. 'createrid' => $uid,
  155. 'creater' => $uname,
  156. 'addtime' => $date,
  157. 'updaterid' => $uid,
  158. 'updater' => $uname,
  159. 'updatetime' => $date,
  160. ]))->save() ? app_show(0, '新增流程成功') : error_show(1005, '新增流程失败');
  161. }
  162. //读取
  163. public function read()
  164. {
  165. $id = $this->request->filter('trim')->post('id/d', 0);
  166. $res = ProcessModel::field('id,process_name,process_type')
  167. ->where(['id' => $id, 'is_del' => ProcessModel::$is_del_normal])
  168. ->findOrEmpty()
  169. ->toArray();
  170. return app_show(0, '获取详情成功', $res);
  171. }
  172. //修改流程
  173. public function update()
  174. {
  175. $param = $this->request->filter('trim')->only(['token', 'id', 'process_name', 'process_type', 'status', 'is_del', 'remark'], 'post');
  176. $val = Validate::rule([
  177. 'token' => 'require',
  178. 'id|ID' => 'require|number|gt:0',
  179. 'process_name|流程名称' => 'max:255',
  180. 'process_type|流程值' => 'max:255|checkProcessType:',
  181. 'status|状态' => 'number|in:' . ProcessModel::$status_normal . ',' . ProcessModel::$status_disable,
  182. 'is_del|是否删除' => 'number|eq:' . ProcessModel::$is_deleted,
  183. ]);
  184. $val->extend('checkProcessType', function ($val, $rule, $data) {
  185. return ProcessModel::where(['process_type' => $val, 'is_del' => ProcessModel::$is_del_normal])->where('id', '<>', $data['id'])->field('id')->findOrEmpty()->isEmpty() ? true : '该流程值已存在';
  186. });
  187. if (!$val->check($param)) return error_show(1005, $val->getError());
  188. if (isset($param['status']) && $param['status'] == ProcessModel::$status_normal) {
  189. //启用流程时候,校验该流程下有没有开始节点和结束节点
  190. $ap_info = APModel::where([
  191. 'process_id' => $param['id'],
  192. 'is_del' => APModel::$is_del_normal,
  193. 'status' => APModel::$status_normal
  194. ])->whereIn('action_type', [
  195. APModel::$action_type_start,
  196. APModel::$action_type_end
  197. ])->column('id', 'action_type');
  198. if (count($ap_info) != 2) return error_show(1005, '该流程下缺少开始节点和结束节点');
  199. }
  200. $user = GetUserInfo($param['token']);
  201. $uid = isset($user['data']['id']) ? $user['data']['id'] : 0;
  202. $uname = isset($user['data']['nickname']) ? $user['data']['nickname'] : '';
  203. $date = date('Y-m-d H:i:s');
  204. return ProcessModel::where(['id' => $param['id'], 'is_del' => ProcessModel::$is_del_normal])->strict(false)->save(array_merge($param, [
  205. 'updaterid' => $uid,
  206. 'updater' => $uname,
  207. 'updatetime' => $date,
  208. ])) ? app_show(0, '修改流程成功') : error_show(1005, '修改流程失败');
  209. }
  210. }