ReportingWork.php 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424
  1. <?php
  2. namespace app\api\controller;
  3. use app\common\controller\Api;
  4. use \think\Request;
  5. use \think\Db;
  6. /**
  7. * 车间报工接口
  8. */
  9. class ReportingWork extends Api
  10. {
  11. protected $noNeedLogin = ['*'];
  12. protected $noNeedRight = ['*'];
  13. /**
  14. * 首页
  15. *
  16. */
  17. public function index()
  18. {
  19. $this->success('请求成功');
  20. }
  21. /**
  22. * 设置机台状态
  23. * @ApiMethod POST
  24. * @params
  25. */
  26. public function setMachineStatus(){
  27. if (Request::instance()->isPost() == false){
  28. $this->error('非法请求');
  29. }
  30. $params = Request::instance()->request();
  31. if (!isset($params['machine']) || empty($params['machine'])){
  32. $this->error('参数不能为空');
  33. }
  34. $machine = $params['machine'].'#';
  35. $data = [];
  36. // $lastData = \db('设备_产量采集')->where('设备编号',$machine)->order('UniqId desc')->find();
  37. $lastData = \db('设备_产量采集')->where('设备编号',$machine)->order('UniqId desc')->find();
  38. if ($lastData['UniqId'] < 160000000){
  39. $id = 160000000;
  40. }else{
  41. $id = $lastData['UniqId'] + 1;
  42. }
  43. if (empty($params['order'])){
  44. unset($lastData['UniqId']);
  45. $data = $lastData;
  46. $data['当前状态'] = $params['status'];
  47. }else{
  48. $data['当前状态'] = $params['status'];
  49. $data['时间'] = date('Y-m-d H:i:s');
  50. $data['设备编号'] = $machine;
  51. $data['工单编号'] = $params['order'];
  52. $data['印件号'] = $params['yjno'];
  53. $data['工序号'] = (int)substr($params['gy_name'],0,2);
  54. $data['工序名称'] = $params['gy_name'];
  55. $data['当班产量'] = $params['production_now'];
  56. $data['累计产量'] = $params['production_all'];
  57. $class = explode(',',$params['class']);
  58. $where = [];
  59. $where['sczl_jtbh'] = $machine;
  60. for ($i=1;$i<=count($class);$i++){
  61. $where['sczl_bh'.$i] = $class[$i-1];
  62. }
  63. // $classData = \db('设备_班组资料')->where($where)->field('sczl_bzdh,UniqId')->find();
  64. $classData = \db('设备_班组资料')->where($where)->field('sczl_bzdh,UniqId')->find();
  65. $data['班组编号'] = $classData['sczl_bzdh'];
  66. $data['班组ID'] = $classData['UniqId'];
  67. // 获取当前时间
  68. $current_time = time();
  69. // 设置时间范围
  70. $start_time1 = strtotime(date('Y-m-d') . ' 08:30:00');
  71. $end_time1 = strtotime(date('Y-m-d') . ' 20:30:00');
  72. $end_time2 = strtotime(date('Y-m-d') . ' 24:00:00');
  73. $start_time3 = strtotime(date('Y-m-d', strtotime('+1 day')) . ' 08:30:00');
  74. // 判断当前时间属于哪个时间范围
  75. if ($current_time >= $start_time1 && $current_time <= $end_time1) {
  76. $data['开工时间'] = date('Y-m-d') . ' 08:30:00';
  77. } elseif ($current_time > $end_time1 && $current_time <= $end_time2) {
  78. $data['开工时间'] = date('Y-m-d') . ' 20:30:00';
  79. } elseif ($current_time > $end_time1 && $current_time <= $start_time3) {
  80. $data['开工时间'] = date('Y-m-d',strtotime('+1 day')) . ' 08:30:00';
  81. }
  82. $option['Gy0_gdbh'] = $params['order'];
  83. $option['Gy0_yjno'] = $params['yjno'];
  84. $option['Gy0_gxh'] = $data['工序号'];
  85. $data['任务ID'] = \db('工单_工艺资料')->where($option)->value('UniqId');
  86. }
  87. $data['UniqId'] = $id;
  88. // $sql = \db('设备_产量采集')->fetchSql(true)->insert($data);
  89. $sql = \db('设备_产量采集')->fetchSql(true)->insert($data);
  90. $res = Db::query($sql);
  91. if ($res === false){
  92. $this->success('设置成功');
  93. }else{
  94. $this->error('设置失败');
  95. }
  96. }
  97. /**
  98. * 设置工单工序完工
  99. * @ApiMethod POST
  100. * @params string order
  101. * @params string yjno
  102. * @params string gxh
  103. */
  104. public function setProcessStatus(){
  105. if (Request::instance()->isPost() == false){
  106. $this->error('非法请求');
  107. }
  108. $params = Request::instance()->request();
  109. if (!isset($params['order']) || empty($params['order'])){
  110. $this->error('参数不能为空');
  111. }
  112. if (!isset($params['yjno']) || empty($params['yjno'])){
  113. $this->error('参数不能为空');
  114. }
  115. if (!isset($params['gxh']) || empty($params['gxh'])){
  116. $this->error('参数不能为空');
  117. }
  118. $where['Gy0_gdbh'] = $params['order'];
  119. $where['Gy0_yjno'] = $params['yjno'];
  120. $where['Gy0_gxh'] = $params['gxh'];
  121. $date = date('Y-m-d H:i:s');
  122. $res = \db('工单_工艺资料')->where($where)->setField('PD_WG',$date);
  123. if ($res === false){
  124. $this->success('设置成功');
  125. }else{
  126. $this->error('设置失败');
  127. }
  128. }
  129. /**
  130. * 根据机台获取生产信息
  131. * @ApiMethod GET
  132. * @params string machine
  133. */
  134. public function getProduceInfo(){
  135. if (Request::instance()->isGet() == false) {
  136. $this->error('非法请求');
  137. }
  138. $params = Request::instance()->param();
  139. if (!isset($params['machine']) || empty($params['machine'])) {
  140. $this->error('参数错误');
  141. }
  142. $machine = $params['machine'].'#';
  143. $data = \db('设备_产量采集')->where('设备编号',$machine)->order('UniqId desc')->find();
  144. $list = [];
  145. $list['order'] = $data['工单编号'];
  146. $list['yjno'] = $data['印件号'];
  147. $name = \db('工单_基本资料')->where('Gd_Gdbh',$data['工单编号'])->value('成品名称');
  148. $list['product_name'] = rtrim($name);
  149. $where['Gy0_gdbh'] = $data['工单编号'];
  150. $where['Gy0_yjno'] = $data['印件号'];
  151. $where['Gy0_gxh'] = $data['工序号'];
  152. $gxmc = \db('工单_工艺资料')->where($where)->value('Gy0_gxmc');
  153. $list['gxmc'] = rtrim($gxmc);
  154. $this->success('请求成功',$list);
  155. }
  156. /**
  157. * 根据员工编号获取姓名
  158. * @ApiMethod GET
  159. * @params string code
  160. */
  161. public function getStaffName(){
  162. if (Request::instance()->isGet() == false) {
  163. $this->error('非法请求');
  164. }
  165. $params = Request::instance()->param();
  166. if (!isset($params['code']) || empty($params['code'])) {
  167. $this->error('参数错误');
  168. }
  169. if (substr($params['code'],0,2) == 'ZM'){
  170. $code = $params['code'];
  171. }else{
  172. if (strlen($params['code']) != 5){
  173. $length = strlen($params['code']);
  174. $len = 5 -$length;
  175. $str = '';
  176. for ($i=0;$i<$len;$i++){
  177. $str .= '0';
  178. }
  179. $code = 'ZM'.$str.$params['code'];
  180. }else{
  181. $code = 'ZM'.$params['code'];
  182. }
  183. }
  184. $data = \db('人事_基本资料')->where('员工编号',$code)->value('员工姓名');
  185. $this->success('请求成功',rtrim($data));
  186. }
  187. /**
  188. * 提交巡查记录
  189. * @ApiMethod POST
  190. * @params
  191. */
  192. public function submitPatrolRecord(){
  193. if (Request::instance()->isPost() == false){
  194. $this->error('非法请求');
  195. }
  196. $params = Request::instance()->request();
  197. if (empty($params['machine']) || empty($params['type']) || empty($params['order'])) {
  198. $this->error('参数错误');
  199. }
  200. if (empty($params['yjno']) || empty($params['process']) || empty($params['no'])) {
  201. $this->error('参数错误');
  202. }
  203. $data = [];
  204. $data['类别'] = $params['type'];
  205. $data['工单编号'] = $params['order'];
  206. $data['印件号'] = $params['yjno'];
  207. $data['工序名称'] = '';
  208. $data['班组编号'] = '';
  209. $data['开工时间'] = '';
  210. $data['流程单号'] = $params['process'];
  211. $data['设备编号'] = $params['machine'].'#';
  212. $data['检验项目'] = '['.$params['no'].'/'.$params['name'].']';
  213. $data['检验备注'] = $params['remark'];
  214. $data['提交时间'] = date('Y-m-d H:i:s');
  215. $data['sys_rq'] = date('Y-m-d H:i:s');
  216. $produce = \db('设备_产量采集')->where('设备编号',$params['machine'].'#')->where('工单编号',$params['order'])->order('UniqId desc')->find();
  217. // $produce = \db('设备_产量采集')->where('设备编号',$params['machine'].'#')->where('工单编号',$params['order'])->order('UniqId desc')->find();
  218. if (!empty($produce)){
  219. $data['工序名称'] = $produce['工序名称'];
  220. $data['班组编号'] = rtrim($produce['班组编号']);
  221. $data['开工时间'] = $produce['开工时间'];
  222. }
  223. // $res = \db('制程检验_记录')->field('UniqId')->order('UniqId desc')->find();
  224. $res = \db('制程检验_记录')->field('UniqId')->order('UniqId desc')->find();
  225. if ($res['UniqId'] < 100000000){
  226. $data['UniqId'] = 100000000;
  227. }else{
  228. $data['UniqId'] = $res['UniqId'] + 1;
  229. }
  230. // $sql = \db('制程检验_记录')->fetchSql(true)->insert($data);
  231. $sql = \db('制程检验_记录')->fetchSql(true)->insert($data);
  232. $result = Db::query($sql);
  233. if ($result === false){
  234. $this->error('提交失败');
  235. }else{
  236. $this->success('提交成功');
  237. }
  238. }
  239. /**
  240. * 获取报工单其他信息
  241. * @ApiMethod Get
  242. * @params string machine
  243. */
  244. public function getMachineReportInfo(){
  245. if (Request::instance()->isGet() == false) {
  246. $this->error('非法请求');
  247. }
  248. $params = Request::instance()->param();
  249. if (!isset($params['machine']) || empty($params['machine'])) {
  250. $this->error('参数错误');
  251. }
  252. $machine = $params['machine'].'#';
  253. $data = [];
  254. $produce = \db('设备_产量采集')->where('设备编号',$machine)->order('UniqId desc')->find();
  255. $data['order_info']['order'] = $produce['工单编号'];
  256. $data['order_info']['yjno'] = $produce['印件号'];
  257. $data['order_info']['gxh'] = $produce['工序号'];
  258. $data['order_info']['gxmc'] = $produce['工序名称'];
  259. $product = \db('工单_基本资料')->alias('a')
  260. ->join('工单_工艺资料 b','a.Gd_Gdbh = b.Gy0_gdbh','left')
  261. ->join('工单_印件资料 c','a.Gd_Gdbh = c.Yj_gdbh','left')
  262. ->field('a.成品名称,b.Gy0_gxmc,c.yj_yjmc')
  263. ->where('a.Gd_Gdbh',$produce['工单编号'])
  264. ->where('b.Gy0_yjno',$produce['印件号'])
  265. ->where('b.Gy0_gxh',$produce['工序号'])
  266. ->where('c.Yj_yjno',$produce['印件号'])
  267. ->select();
  268. $data['order_info']['product_name'] = '';
  269. $data['order_info']['yj_name'] = '';
  270. $data['order_info']['gy_name'] = '';
  271. if (!empty($product)){
  272. $data['order_info']['product_name'] = rtrim($product[0]['成品名称']);
  273. $data['order_info']['yj_name'] = rtrim($product[0]['yj_yjmc']);
  274. $data['order_info']['gy_name'] = rtrim($product[0]['Gy0_gxmc']);
  275. }
  276. $class = \db('设备_班组资料')->where('UniqId',$produce['班组ID'])->find();
  277. for ($i=1;$i<11;$i++){
  278. $name = '';
  279. if (!empty($class['sczl_bh'.$i])){
  280. $name = \db('人事_基本资料')->where('员工编号',$class['sczl_bh'.$i])->value('员工姓名');
  281. }
  282. $class['sczl_name'.$i] = rtrim($name);
  283. }
  284. $data['class'] = $class;
  285. $where['st_gdbh'] = $produce['工单编号'];
  286. $machine = substr($machine,0,2);
  287. if ($machine == 'JY' || $machine == 'QZ'){
  288. $where['st_dpt'] = '胶印车间';
  289. }elseif ($machine == 'WY' || $machine == 'DW'){
  290. $where['st_dpt'] = '凹印车间';
  291. }elseif ($machine == 'SY' || $machine == 'PM'){
  292. $where['st_dpt'] = '丝印车间';
  293. }elseif ($machine == 'MQ' || $machine == 'TJ'){
  294. $where['st_dpt'] = '烫模车间';
  295. }elseif ($machine == 'JP'){
  296. $where['st_dpt'] = '检验车间';
  297. }
  298. $sql = "SELECT RTRIM(a.供方批次) as batch, rtrim(采购单号) as 采购单号,st_wlbh, MIN(a.Uniqid) AS Uniqid,rtrim(b.`BOM_物料名称`) as `BOM_物料名称`
  299. FROM `物料_收发记录` a
  300. LEFT JOIN `工单_bom资料` b ON a.st_gdbh = b.`BOM_工单编号` AND a.st_wlbh = b.`BOM_物料编码`
  301. WHERE a.st_gdbh = '{$where['st_gdbh']}' AND a.st_dpt = '{$where['st_dpt']}'
  302. GROUP BY batch ORDER BY a.st_wlbh";
  303. $material = Db::query($sql);
  304. $data['bom'] = $material;
  305. $this->success('请求成功',$data);
  306. }
  307. /**
  308. * 日产量上报
  309. * @ApiMethod POST
  310. * @params array data
  311. */
  312. public function submitDailyProduction(){
  313. if (Request::instance()->isPost() == false){
  314. $this->error('非法请求');
  315. }
  316. $params = Request::instance()->request();
  317. $machine = $params['sczl_jtbh'].'#';
  318. $batchData = []; //批次追踪数据
  319. $batch = $params['bom'];
  320. $data = $params;//产量数据
  321. $data['sczl_type'] = $params['sczl_gxmc'];
  322. $data['sczl_前工序废'] = $params['last_fp'];
  323. $data['sczl_来料少数'] = $params['less_sl'];
  324. $data['sczl_装版总工时'] = $params['zb_time'];
  325. $data['sczl_打样总工时'] = $params['dy_time'];
  326. $data['sczl_设备运行工时'] = $params['run_time'];
  327. $data['sczl_jtbh'] = $machine;
  328. $data['码包'] = $params['code'];
  329. $data['主电表'] = $params['main_meter'];
  330. $data['辅电表'] = $params['auxiliary_meter'];
  331. unset($data['last_fp']);
  332. unset($data['less_sl']);
  333. unset($data['zb_time']);
  334. unset($data['dy_time']);
  335. unset($data['run_time']);
  336. unset($data['code']);
  337. unset($data['main_meter']);
  338. unset($data['auxiliary_meter']);
  339. unset($data['bom']);
  340. $start_time = \db('设备_产量采集')->where('设备编号',$machine)->order('UniqId desc')->find();
  341. $data['开工时间'] = $start_time['开工时间'];
  342. $sys_id = \db('设备_基本资料')->where('设备编号',$machine)->value('sys_sbID');
  343. $data['sys_id'] = '['.$sys_id.'/'.$machine.']';
  344. $UniqId = \db('设备_产量计酬')->order('UniqId desc')->value('UniqId');
  345. if ($UniqId < 10000000){
  346. $data['UniqId'] = 10000000;
  347. }else{
  348. $data['UniqId'] = $UniqId + 1;
  349. }
  350. $data['sczl_Pgcl'] = 0;
  351. $data['sczl_oil'] = 0;
  352. $data['sczl_计产系数'] = 0;
  353. $data['sczl_工价系数'] = 0;
  354. $data['sczl_装版工时'] = 0;
  355. $data['sczl_保养工时'] = 0;
  356. $data['sczl_打样工时'] = 0;
  357. $data['sczl_异常停机工时'] = 0;
  358. $data['sczl_异常工时1'] = 0;
  359. $data['sczl_异常类型1'] = '';
  360. $data['sczl_废品率系数'] = '';
  361. $data['sczl_desc'] = '';
  362. $data['sczl_wgsj'] = '1900-01-01 00:00:00';
  363. $data['码开始行'] = 0;
  364. $data['码结束行'] = 0;
  365. $data['mod_rq'] = '1900-01-01 00:00:00';
  366. $data['sys_rq'] = date('Y-m-d H:i:s');
  367. $batchData = explode(',',$batch);
  368. $newData = [];
  369. $batchUniqId = \db('物料_批次跟踪')->order('UniqId desc')->value('UniqId');
  370. if ($batchUniqId < 10000000){
  371. $batchUniqId = 10000000;
  372. }
  373. foreach ($batchData as $key=>$item){
  374. $batchUniqId++;
  375. $val = explode('-',$item);
  376. $newData[$key]['wlbh'] = $val[0];
  377. $newData[$key]['wlBatch'] = $val[1];
  378. $newData[$key]['sczl_gdbh'] = $data['sczl_gdbh'];
  379. $newData[$key]['sczl_yjno'] = $data['sczl_yjno'];
  380. $newData[$key]['sczl_gxh'] = $data['sczl_gxh'];
  381. $newData[$key]['sczl_gxmc'] = $data['sczl_gxmc'];
  382. $newData[$key]['sczl_num'] = $data['sczl_num'];
  383. $newData[$key]['sys_id'] = $data['sys_id'];
  384. $newData[$key]['sys_rq'] = $data['sys_rq'];
  385. $newData[$key]['UniqID'] = $batchUniqId;
  386. }
  387. $res = true;
  388. $batch_res = true;
  389. Db::startTrans();
  390. try {
  391. $sql = \db('设备_产量计酬')->fetchSql(true)->insert($data);
  392. $res = Db::query($sql);
  393. $batch_sql = \db('物料_批次跟踪')->fetchSql(true)->insertAll($newData);
  394. $batch_res = Db::query($batch_sql);
  395. Db::commit();
  396. }catch (\Exception $e){
  397. Db::rollback();
  398. }
  399. if ($res === false || $batch_res === false){
  400. $this->error('报工失败');
  401. }else{
  402. $this->success('报工成功');
  403. }
  404. }
  405. /**
  406. * 获取机台编号
  407. * @ApiMethod POST
  408. * @params string addr
  409. */
  410. public function getMachineMac(){
  411. if (Request::instance()->isGet() == false){
  412. $this->error('非法请求');
  413. }
  414. $params = Request::instance()->get();
  415. $data = \db('设备_基本资料')->where('sys_sbID',$params['addr'])->field('设备编号')->find();
  416. $this->success('请求成功',$data);
  417. }
  418. }