ReportingWork.php 37 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997
  1. <?php
  2. namespace app\api\controller;
  3. use app\common\controller\Api;
  4. use think\db\exception\BindParamException;
  5. use think\exception\PDOException;
  6. use \think\Request;
  7. use \think\Db;
  8. /**
  9. * 车间报工接口
  10. */
  11. class ReportingWork extends Api
  12. {
  13. protected $noNeedLogin = ['*'];
  14. protected $noNeedRight = ['*'];
  15. /**
  16. * 首页
  17. *
  18. */
  19. public function index()
  20. {
  21. $this->success('请求成功');
  22. }
  23. /**
  24. * 设置机台状态
  25. * @ApiMethod POST
  26. * @params
  27. */
  28. public function setMachineStatus(){
  29. if (Request::instance()->isPost() == false){
  30. $this->error('非法请求');
  31. }
  32. $params = Request::instance()->post();
  33. if (!isset($params['machine']) || empty($params['machine'])){
  34. $this->error('参数不能为空');
  35. }
  36. $machine = $params['machine'].'#';
  37. $data = [];
  38. // $lastData = \db('设备_产量采集')->where('设备编号',$machine)->order('UniqId desc')->find();
  39. $lastData = \db('设备_产量采集')
  40. // ->where('设备编号',$machine)
  41. ->order('UniqId desc')
  42. ->find();
  43. $id = $lastData['UniqId'] + 1;
  44. if (empty($params['order'])){
  45. unset($lastData['UniqId']);
  46. $data = $lastData;
  47. $data['当前状态'] = $params['status'];
  48. }else{
  49. $data['当前状态'] = $params['status'];
  50. $data['时间'] = date('Y-m-d H:i:s');
  51. $data['设备编号'] = $machine;
  52. $data['工单编号'] = $params['order'];
  53. $data['印件号'] = $params['yjno'];
  54. $data['工序号'] = (int)substr($params['gy_name'],0,2);
  55. $data['工序名称'] = $params['gy_name'];
  56. $data['当班产量'] = $params['production_now'];
  57. $data['累计产量'] = $params['production_all'];
  58. $class = explode(',',$params['class']);
  59. $where = [];
  60. $where['sczl_jtbh'] = $machine;
  61. for ($i=1;$i<=count($class);$i++){
  62. $where['sczl_bh'.$i] = $class[$i-1];
  63. }
  64. // $classData = \db('设备_班组资料')->where($where)->field('sczl_bzdh,UniqId')->find();
  65. $classData = \db('设备_班组资料')->where($where)->field('sczl_bzdh,UniqId')->find();
  66. $data['班组编号'] = $classData['sczl_bzdh'];
  67. $data['班组ID'] = $classData['UniqId'];
  68. // 获取当前时间
  69. $current_time = time();
  70. // 设置时间范围
  71. $start_time1 = strtotime(date('Y-m-d') . ' 08:30:00');
  72. $end_time1 = strtotime(date('Y-m-d') . ' 20:30:00');
  73. $end_time2 = strtotime(date('Y-m-d') . ' 24:00:00');
  74. $start_time3 = strtotime(date('Y-m-d', strtotime('+1 day')) . ' 08:30:00');
  75. // 判断当前时间属于哪个时间范围
  76. if ($current_time >= $start_time1 && $current_time <= $end_time1) {
  77. $data['开工时间'] = date('Y-m-d') . ' 08:30:00';
  78. } elseif ($current_time > $end_time1 && $current_time <= $end_time2) {
  79. $data['开工时间'] = date('Y-m-d') . ' 20:30:00';
  80. } elseif ($current_time > $end_time1 && $current_time <= $start_time3) {
  81. $data['开工时间'] = date('Y-m-d',strtotime('+1 day')) . ' 08:30:00';
  82. }
  83. $option['Gy0_gdbh'] = $params['order'];
  84. $option['Gy0_yjno'] = $params['yjno'];
  85. $option['Gy0_gxh'] = $data['工序号'];
  86. $data['任务ID'] = \db('工单_工艺资料')->where($option)->value('UniqId');
  87. }
  88. $data['UniqId'] = $id;
  89. // $sql = \db('设备_产量采集')->fetchSql(true)->insert($data);
  90. $sql = \db('设备_产量采集')->fetchSql(true)->insert($data);
  91. $res = Db::query($sql);
  92. if ($res === false){
  93. $this->error('设置失败');
  94. }else{
  95. $this->success('设置成功');
  96. }
  97. }
  98. /**
  99. * 设置工单工序完工
  100. * @ApiMethod POST
  101. * @params string order
  102. * @params string yjno
  103. * @params string gxh
  104. */
  105. public function setProcessStatus(){
  106. if (Request::instance()->isPost() == false){
  107. $this->error('非法请求');
  108. }
  109. $params = Request::instance()->post();
  110. if (!isset($params['order']) || empty($params['order'])){
  111. $this->error('参数不能为空');
  112. }
  113. if (!isset($params['yjno']) || empty($params['yjno'])){
  114. $this->error('参数不能为空');
  115. }
  116. if (!isset($params['gxh']) || empty($params['gxh'])){
  117. $this->error('参数不能为空');
  118. }
  119. $where['Gy0_gdbh'] = $params['order'];
  120. $where['Gy0_yjno'] = $params['yjno'];
  121. $where['Gy0_gxh'] = $params['gxh'];
  122. $date = date('Y-m-d H:i:s');
  123. $res = \db('工单_工艺资料')->where($where)->setField('PD_WG',$date);
  124. if ($res === false){
  125. $this->error('设置失败');
  126. }else{
  127. $this->success('设置成功');
  128. }
  129. }
  130. /**
  131. * 根据机台获取生产信息
  132. * @ApiMethod GET
  133. * @params string machine
  134. */
  135. public function getProduceInfo(){
  136. if (Request::instance()->isGet() == false) {
  137. $this->error('非法请求');
  138. }
  139. $params = Request::instance()->param();
  140. if (!isset($params['machine']) || empty($params['machine'])) {
  141. $this->error('参数错误');
  142. }
  143. $machine = $params['machine'].'#';
  144. $data = \db('设备_产量采集')->where('设备编号',$machine)->order('UniqId desc')->find();
  145. $list = [];
  146. $list['order'] = $data['工单编号'];
  147. $list['yjno'] = $data['印件号'];
  148. $name = \db('工单_基本资料')->where('Gd_Gdbh',$data['工单编号'])->value('成品名称');
  149. $list['product_name'] = rtrim($name);
  150. $where['Gy0_gdbh'] = $data['工单编号'];
  151. $where['Gy0_yjno'] = $data['印件号'];
  152. $where['Gy0_gxh'] = $data['工序号'];
  153. $gxmc = \db('工单_工艺资料')->where($where)->value('Gy0_gxmc');
  154. $list['gxmc'] = rtrim($gxmc);
  155. $this->success('请求成功',$list);
  156. }
  157. /**
  158. * 根据员工编号获取姓名
  159. * @ApiMethod GET
  160. * @params string code
  161. */
  162. public function getStaffName(){
  163. if (Request::instance()->isGet() == false) {
  164. $this->error('非法请求');
  165. }
  166. $params = Request::instance()->param();
  167. if (!isset($params['code']) || empty($params['code'])) {
  168. $this->error('参数错误');
  169. }
  170. $data = \db('人事_基本资料')->where('员工编号',$params['code'])->value('员工姓名');
  171. if (empty($data)){
  172. $data = \db('人事_基本资料')->where('pycode',$params['code'])->value('员工姓名');
  173. }
  174. $this->success('请求成功',rtrim($data));
  175. }
  176. /**
  177. * 根据员工编号获取姓名-优化
  178. * @ApiMethod GET
  179. * @params string code
  180. */
  181. public function getStaffNameTwo(){
  182. if (Request::instance()->isGet() == false) {
  183. $this->error('非法请求');
  184. }
  185. $params = Request::instance()->param();
  186. if (!isset($params['code']) || empty($params['code'])) {
  187. $this->error('参数错误');
  188. }
  189. $data = \db('人事_基本资料')->where('员工编号',$params['code'])->field('员工姓名')->select();
  190. if (empty($data)){
  191. $data = \db('人事_基本资料')->where('pycode',$params['code'])->field('rtrim(员工姓名) as 员工姓名')->select();
  192. }
  193. $num = count($data);
  194. $res['total'] = $num;
  195. $res['data'] = $data;
  196. $this->success('请求成功',$res);
  197. }
  198. /**
  199. * 提交巡查记录
  200. * @ApiMethod POST
  201. * @params
  202. */
  203. public function submitPatrolRecord(){
  204. if (Request::instance()->isPost() == false){
  205. $this->error('非法请求');
  206. }
  207. $params = Request::instance()->post();
  208. if (empty($params['machine']) || empty($params['type']) || empty($params['order'])) {
  209. $this->error('参数错误');
  210. }
  211. if (empty($params['yjno']) || empty($params['process']) || empty($params['no'])) {
  212. $this->error('参数错误');
  213. }
  214. $data = [];
  215. $data['类别'] = $params['type'];
  216. $data['工单编号'] = $params['order'];
  217. $data['印件号'] = $params['yjno'];
  218. $data['工序名称'] = '';
  219. $data['班组编号'] = '';
  220. $data['开工时间'] = '';
  221. $data['流程单号'] = $params['process'];
  222. $data['设备编号'] = $params['machine'].'#';
  223. $data['检验项目'] = '['.$params['no'].'/'.$params['name'].']';
  224. $data['检验备注'] = $params['remark'];
  225. $data['提交时间'] = date('Y-m-d H:i:s');
  226. $data['sys_rq'] = date('Y-m-d H:i:s');
  227. $produce = \db('设备_产量采集')->where('设备编号',$params['machine'].'#')->where('工单编号',$params['order'])->order('UniqId desc')->find();
  228. // $produce = \db('设备_产量采集')->where('设备编号',$params['machine'].'#')->where('工单编号',$params['order'])->order('UniqId desc')->find();
  229. if (!empty($produce)){
  230. $data['工序名称'] = $produce['工序名称'];
  231. $data['班组编号'] = rtrim($produce['班组编号']);
  232. $data['开工时间'] = $produce['开工时间'];
  233. }
  234. // $res = \db('制程检验_记录')->field('UniqId')->order('UniqId desc')->find();
  235. $res = \db('制程检验_记录')->field('UniqId')->order('UniqId desc')->find();
  236. if (empty($res['UniqId'])){
  237. $data['UniqId'] = 1;
  238. }else{
  239. $data['UniqId'] = $res['UniqId'] + 1;
  240. }
  241. // $sql = \db('制程检验_记录')->fetchSql(true)->insert($data);
  242. $sql = \db('制程检验_记录')->fetchSql(true)->insert($data);
  243. $result = Db::query($sql);
  244. if ($result === false){
  245. $this->error('提交失败');
  246. }else{
  247. $this->success('提交成功');
  248. }
  249. }
  250. /**
  251. * 获取报工单其他信息
  252. * @ApiMethod Get
  253. * @params string machine
  254. */
  255. public function getMachineReportInfo(){
  256. if (Request::instance()->isGet() == false) {
  257. $this->error('非法请求');
  258. }
  259. $params = Request::instance()->param();
  260. if (!isset($params['machine']) || empty($params['machine'])) {
  261. $this->error('参数错误');
  262. }
  263. $machine = $params['machine'].'#';
  264. $data = [];
  265. $produce = \db('设备_产量采集')->where('设备编号',$machine)->order('UniqId desc')->find();
  266. if (empty($produce)){
  267. $this->error('无此设备数据');
  268. }
  269. $data['order_info']['order'] = $produce['工单编号'];
  270. $data['order_info']['yjno'] = $produce['印件号'];
  271. $data['order_info']['gxh'] = $produce['工序号'];
  272. $data['order_info']['gxmc'] = $produce['工序名称'];
  273. // $data['order_info']['dedh'] = \db('dic_lzde')->where('适用机型',$machine)->value('sys_bh');
  274. $product = \db('工单_基本资料')->alias('a')
  275. ->join('工单_工艺资料 b','a.Gd_Gdbh = b.Gy0_gdbh','left')
  276. ->join('工单_印件资料 c','a.Gd_Gdbh = c.Yj_gdbh','left')
  277. ->field('a.成品名称,b.Gy0_gxmc,b.Gy0_ms,b.Gy0_ls,c.yj_yjmc')
  278. ->where('a.Gd_Gdbh',$produce['工单编号'])
  279. ->where('b.Gy0_yjno',$produce['印件号'])
  280. ->where('b.Gy0_gxh',$produce['工序号'])
  281. ->where('c.Yj_yjno',$produce['印件号'])
  282. ->select();
  283. if (empty($product)){
  284. $this->error('无此工单数据');
  285. }
  286. $data['order_info']['product_name'] = '';
  287. $data['order_info']['yj_name'] = '';
  288. $data['order_info']['gy_name'] = '';
  289. if (!empty($product)){
  290. $data['order_info']['product_name'] = rtrim($product[0]['成品名称']);
  291. $data['order_info']['yj_name'] = rtrim($product[0]['yj_yjmc']);
  292. $data['order_info']['gy_name'] = rtrim($product[0]['Gy0_gxmc']);
  293. $data['order_info']['Gy0_ms'] = rtrim($product[0]['Gy0_ms']);
  294. $data['order_info']['Gy0_ls'] = rtrim($product[0]['Gy0_ls']);
  295. }
  296. $dedh = \db('dic_lzde')->where('适用机型',$machine)->value('sys_bh');
  297. if (strpos($params['machine'],'JP') !== false){
  298. if (strpos($data['order_info']['product_name'],'小盒') !== false){
  299. $data['order_info']['dedh'] = $dedh.'001';
  300. }else{
  301. $data['order_info']['dedh'] = $dedh.'002';
  302. }
  303. }else{
  304. $data['order_info']['dedh'] = $dedh;
  305. }
  306. $class = \db('设备_班组资料')->where('UniqId',$produce['班组ID'])->find();
  307. for ($i=1;$i<11;$i++){
  308. $name = '';
  309. if (!empty($class['sczl_bh'.$i])){
  310. $name = \db('人事_基本资料')->where('员工编号',$class['sczl_bh'.$i])->value('员工姓名');
  311. }
  312. $class['sczl_name'.$i] = rtrim($name);
  313. }
  314. $data['class'] = $class;
  315. $where['st_gdbh'] = $produce['工单编号'];
  316. $machine = substr($machine,0,2);
  317. if ($machine == 'JY' || $machine == 'QZ'){
  318. $where['st_dpt'] = '胶印车间';
  319. }elseif ($machine == 'WY' || $machine == 'DW'){
  320. $where['st_dpt'] = '凹印车间';
  321. }elseif ($machine == 'SY' || $machine == 'PM'){
  322. $where['st_dpt'] = '丝印车间';
  323. }elseif ($machine == 'MQ' || $machine == 'TJ'){
  324. $where['st_dpt'] = '烫模车间';
  325. }elseif ($machine == 'JP'){
  326. $where['st_dpt'] = '检验车间';
  327. }
  328. $material = \db('物料_收发记录')
  329. ->alias('a')
  330. ->join('工单_bom资料 b', 'a.st_gdbh = b.BOM_工单编号 AND a.st_wlbh = b.BOM_物料编码','left')
  331. ->where($where)
  332. ->field('RTRIM(a.供方批次) as batch, rtrim(采购单号) as 采购单号, st_wlbh, MIN(a.Uniqid) AS Uniqid, rtrim(b.BOM_物料名称) as BOM_物料名称')
  333. ->group('batch')
  334. ->order('a.st_wlbh')
  335. ->select();
  336. $data['bom'] = $material;
  337. $this->success('请求成功',$data);
  338. }
  339. /**
  340. * 日产量上报
  341. * @ApiMethod POST
  342. * @params array data
  343. */
  344. // public function submitDailyProduction(){
  345. // if (Request::instance()->isPost() == false){
  346. // $this->error('非法请求');
  347. // }
  348. // $params = Request::instance()->post();
  349. // $time = date('Y-m-d 00:00:00',time()-86400);
  350. // if ($params['sczl_sj2']<date('Y-m-d 08:30:00',time()) && $params['sczl_sj2']>date('Y-m-d 00:00:00')){
  351. // $params['sczl_rq'] = $time;
  352. // }
  353. // $machine = $params['sczl_jtbh'].'#';
  354. // $batchData = []; //批次追踪数据
  355. // $batch = $params['bom'];
  356. // $data = $params;//产量数据
  357. // $data['sczl_type'] = $params['sczl_gxmc'];
  358. // $data['sczl_前工序废'] = $params['last_fp'];
  359. // $data['sczl_来料少数'] = $params['less_sl'];
  360. // $data['sczl_装版总工时'] = $params['zb_time'];
  361. // $data['sczl_打样总工时'] = $params['dy_time'];
  362. // $data['sczl_设备运行工时'] = $params['run_time'];
  363. // $data['sczl_jtbh'] = $machine;
  364. // $data['码包'] = $params['code'];
  365. // $data['主电表'] = $params['main_meter'];
  366. // $data['辅电表'] = $params['auxiliary_meter'];
  367. // unset($data['last_fp']);
  368. // unset($data['less_sl']);
  369. // unset($data['zb_time']);
  370. // unset($data['dy_time']);
  371. // unset($data['run_time']);
  372. // unset($data['code']);
  373. // unset($data['main_meter']);
  374. // unset($data['auxiliary_meter']);
  375. // unset($data['bom']);
  376. // $start_time = \db('设备_产量采集')->where('设备编号',$machine)->order('UniqId desc')->find();
  377. // if (!empty($start_time)){
  378. // $data['开工时间'] = $start_time['开工时间'];
  379. // }else{
  380. // $data['开工时间'] = '';
  381. // }
  382. // $sys_id = \db('设备_基本资料')->where('设备编号',$machine)->value('sys_sbID');
  383. // $data['sys_id'] = '['.$sys_id.'/'.$machine.']';
  384. // $UniqId = \db('设备_产量计酬')->order('UniqId desc')->value('UniqId');
  385. // if ($UniqId < 10000000){
  386. // $data['UniqId'] = 10000000;
  387. // }else{
  388. // $data['UniqId'] = $UniqId + 1;
  389. // }
  390. // $data['sczl_Pgcl'] = 0;
  391. // $data['sczl_oil'] = 0;
  392. // $data['sczl_计产系数'] = 0;
  393. // $data['sczl_工价系数'] = 0;
  394. // $data['sczl_装版工时'] = 0;
  395. // $data['sczl_保养工时'] = 0;
  396. // $data['sczl_打样工时'] = 0;
  397. // $data['sczl_异常停机工时'] = 0;
  398. // $data['sczl_异常工时1'] = 0;
  399. // $data['sczl_异常类型1'] = '';
  400. // $data['sczl_废品率系数'] = '';
  401. // $data['sczl_desc'] = '';
  402. // $data['sczl_wgsj'] = '1900-01-01 00:00:00';
  403. // $data['码开始行'] = $params['ma_start'];
  404. // $data['码结束行'] = $params['ma_end'];
  405. // $data['mod_rq'] = '1900-01-01 00:00:00';
  406. // $data['sys_rq'] = date('Y-m-d H:i:s');
  407. // unset($data['ma_start']);
  408. // unset($data['ma_end']);
  409. // if (!empty($batch)){
  410. // $batchData = explode(',',$batch);
  411. // $newData = [];
  412. // $batchUniqId = \db('物料_批次跟踪')->order('UniqId desc')->value('UniqId');
  413. // if ($batchUniqId < 10000000){
  414. // $batchUniqId = 10000000;
  415. // }
  416. // foreach ($batchData as $key=>$item){
  417. // $batchUniqId++;
  418. // $val = explode('-',$item);
  419. // $newData[$key]['wlbh'] = $val[0];
  420. // $newData[$key]['wlBatch'] = $val[1];
  421. // $newData[$key]['sczl_gdbh'] = $data['sczl_gdbh'];
  422. // $newData[$key]['sczl_yjno'] = $data['sczl_yjno'];
  423. // $newData[$key]['sczl_gxh'] = $data['sczl_gxh'];
  424. // $newData[$key]['sczl_gxmc'] = $data['sczl_gxmc'];
  425. // $newData[$key]['sczl_num'] = $data['sczl_num'];
  426. // $newData[$key]['sys_id'] = $data['sys_id'];
  427. // $newData[$key]['sys_rq'] = $data['sys_rq'];
  428. // $newData[$key]['UniqID'] = $batchUniqId;
  429. // }
  430. // }
  431. // if (!empty($data['sczl_装版总工时']) && $data['sczl_装版总工时'] !== 0){
  432. // $priData = [
  433. // 'gdbh' => $data['sczl_gdbh'] ?? '',
  434. // 'yjno' => $data['sczl_yjno'] ?? '',
  435. // 'gxh' => $data['sczl_gxh'] ?? '',
  436. // 'jtbh' => $data['sczl_jtbh'] ?? '',
  437. // 'startTime' => $data['sczl_sj1'] ?? '',
  438. // 'endTime' => $data['sczl_sj2'] ?? '',
  439. // '换版总工时' => $data['sczl_装版总工时'],
  440. // '换版联拼数' => $data['sczl_换版联拼数'] ?? 0,
  441. // '换版类型' => $data['换版类型'] ?? ''
  442. // ];
  443. // $priSql = \db('设备_装版工时')->fetchSql(true)->insert($priData);
  444. // $priRes = \db()->query($priSql);
  445. // }
  446. // unset($data['sczl_换版联拼数']);
  447. // unset($data['换版类型']);
  448. // $res = false;
  449. // $batch_res = false;
  450. // Db::startTrans();
  451. // try {
  452. // $sql = \db('设备_产量计酬')->fetchSql(true)->insert($data);
  453. // $res = Db::query($sql);
  454. // if (!empty($batch)){
  455. // $batch_sql = \db('物料_批次跟踪')->fetchSql(true)->insertAll($newData);
  456. // $batch_res = Db::query($batch_sql);
  457. // }else{
  458. // $batch_res = true;
  459. // }
  460. //
  461. // Db::commit();
  462. // cache('MachineProductReport-getList',null);
  463. // }catch (\Exception $e){
  464. // Db::rollback();
  465. // }
  466. // if ($res === false || $batch_res === false){
  467. // $this->error('报工失败');
  468. // }else{
  469. // $this->success('报工成功');
  470. // }
  471. //
  472. // }
  473. public function submitDailyProduction()
  474. {
  475. // 1. 请求验证优化
  476. if (!Request::instance()->isPost()) {
  477. $this->error('非法请求');
  478. }
  479. $params = Request::instance()->post();
  480. // 2. 数据预处理
  481. $processedData = $this->preprocessData($params);
  482. // 3. 数据验证
  483. if (!$this->validateData($processedData)) {
  484. $this->error('数据验证失败');
  485. }
  486. // 4. 数据库操作
  487. $result = $this->saveProductionData($processedData);
  488. if ($result) {
  489. // 5. 清理缓存
  490. cache('MachineProductReport-getList', null);
  491. $this->success('报工成功');
  492. } else {
  493. $this->error('报工失败');
  494. }
  495. }
  496. /**
  497. * 数据预处理
  498. */
  499. private function preprocessData($params)
  500. {
  501. $currentTime = time();
  502. // 处理日期逻辑
  503. if ($this->isEarlyMorningProduction($params['sczl_sj2'], $currentTime)) {
  504. $params['sczl_rq'] = date('Y-m-d 00:00:00', $currentTime - 86400);
  505. }
  506. $machine = $params['sczl_jtbh'] . '#';
  507. // 构建基础数据
  508. $data = [
  509. // 字段映射
  510. 'sczl_type' => $params['sczl_gxmc'],
  511. 'sczl_前工序废' => $params['last_fp'],
  512. 'sczl_来料少数' => $params['less_sl'],
  513. 'sczl_装版总工时' => $params['zb_time'],
  514. 'sczl_打样总工时' => $params['dy_time'],
  515. 'sczl_设备运行工时' => $params['run_time'],
  516. 'sczl_jtbh' => $machine,
  517. '码包' => $params['code'],
  518. '主电表' => $params['main_meter'],
  519. '辅电表' => $params['auxiliary_meter'],
  520. '码开始行' => $params['ma_start'],
  521. '码结束行' => $params['ma_end'],
  522. // 系统字段
  523. 'sys_rq' => date('Y-m-d H:i:s'),
  524. 'mod_rq' => '1900-01-01 00:00:00',
  525. 'sczl_wgsj' => '1900-01-01 00:00:00',
  526. // 默认值字段
  527. 'sczl_Pgcl' => 0,
  528. 'sczl_oil' => 0,
  529. 'sczl_计产系数' => 0,
  530. 'sczl_工价系数' => 0,
  531. 'sczl_装版工时' => 0,
  532. 'sczl_保养工时' => 0,
  533. 'sczl_打样工时' => 0,
  534. 'sczl_异常停机工时' => 0,
  535. 'sczl_异常工时1' => 0,
  536. 'sczl_异常类型1' => '',
  537. 'sczl_废品率系数' => '',
  538. 'sczl_desc' => '',
  539. ];
  540. // 保留原始参数中的相关字段
  541. $preserveFields = [
  542. 'sczl_gdbh', 'sczl_yjno', 'sczl_gxh', 'sczl_gxmc',
  543. 'sczl_num', 'sczl_sj1', 'sczl_sj2', 'sczl_rq'
  544. ];
  545. foreach ($preserveFields as $field) {
  546. if (isset($params[$field])) {
  547. $data[$field] = $params[$field];
  548. }
  549. }
  550. // 获取开工时间
  551. $data['开工时间'] = $this->getMachineStartTime($machine);
  552. // 生成唯一ID
  553. $data['UniqId'] = $this->generateUniqId();
  554. // 设置系统ID
  555. $data['sys_id'] = $this->getSystemId($machine);
  556. return [
  557. 'data' => $data,
  558. 'batch' => $params['bom'] ?? '',
  559. 'plateChangeData' => $this->preparePlateChangeData($data, $params)
  560. ];
  561. }
  562. /**
  563. * 判断是否为凌晨生产
  564. */
  565. private function isEarlyMorningProduction($productionTime, $currentTime)
  566. {
  567. $productionTimestamp = strtotime($productionTime);
  568. $startOfDay = strtotime(date('Y-m-d 00:00:00', $currentTime));
  569. $morningTime = strtotime(date('Y-m-d 08:30:00', $currentTime));
  570. return $productionTimestamp < $morningTime && $productionTimestamp > $startOfDay;
  571. }
  572. /**
  573. * 获取设备开工时间
  574. */
  575. private function getMachineStartTime($machine)
  576. {
  577. $startTimeRecord = \db('设备_产量采集')
  578. ->where('设备编号', $machine)
  579. ->order('UniqId desc')
  580. ->find();
  581. return $startTimeRecord['开工时间'] ?? '';
  582. }
  583. /**
  584. * 生成唯一ID
  585. */
  586. private function generateUniqId()
  587. {
  588. $lastUniqId = \db('设备_产量计酬')->order('UniqId desc')->value('UniqId');
  589. return ($lastUniqId < 10000000) ? 10000000 : $lastUniqId + 1;
  590. }
  591. /**
  592. * 获取系统ID
  593. */
  594. private function getSystemId($machine)
  595. {
  596. $sysId = \db('设备_基本资料')->where('设备编号', $machine)->value('sys_sbID');
  597. return '[' . $sysId . '/' . $machine . ']';
  598. }
  599. /**
  600. * 准备装版数据
  601. */
  602. private function preparePlateChangeData($data, $params)
  603. {
  604. if (empty($data['sczl_装版总工时']) || $data['sczl_装版总工时'] == 0) {
  605. return null;
  606. }
  607. return [
  608. 'gdbh' => $data['sczl_gdbh'] ?? '',
  609. 'yjno' => $data['sczl_yjno'] ?? '',
  610. 'gxh' => $data['sczl_gxh'] ?? '',
  611. 'jtbh' => $data['sczl_jtbh'] ?? '',
  612. 'startTime' => $data['sczl_sj1'] ?? '',
  613. 'endTime' => $data['sczl_sj2'] ?? '',
  614. '换版总工时' => $data['sczl_装版总工时'],
  615. '换版联拼数' => $params['sczl_换版联拼数'] ?? 0,
  616. '换版类型' => $params['换版类型'] ?? '',
  617. 'yieldUid' => $this->generateUniqId(),
  618. 'sys_rq' => date('Y-m-d H:i:s'),
  619. 'sys_id' => $this->getSystemId($data['sczl_jtbh'])
  620. ];
  621. }
  622. /**
  623. * 准备批次数据
  624. */
  625. private function prepareBatchData($batch, $baseData)
  626. {
  627. if (empty($batch)) {
  628. return [];
  629. }
  630. $batchData = explode(',', $batch);
  631. $batchUniqId = \db('物料_批次跟踪')->order('UniqId desc')->value('UniqId');
  632. $batchUniqId = ($batchUniqId < 10000000) ? 10000000 : $batchUniqId;
  633. $newData = [];
  634. foreach ($batchData as $item) {
  635. $batchUniqId++;
  636. $val = explode('-', $item);
  637. $newData[] = [
  638. 'wlbh' => $val[0],
  639. 'wlBatch' => $val[1],
  640. 'sczl_gdbh' => $baseData['sczl_gdbh'],
  641. 'sczl_yjno' => $baseData['sczl_yjno'],
  642. 'sczl_gxh' => $baseData['sczl_gxh'],
  643. 'sczl_gxmc' => $baseData['sczl_gxmc'],
  644. 'sczl_num' => $baseData['sczl_num'],
  645. 'sys_id' => $baseData['sys_id'],
  646. 'sys_rq' => $baseData['sys_rq'],
  647. 'UniqID' => $batchUniqId
  648. ];
  649. }
  650. return $newData;
  651. }
  652. /**
  653. * 数据验证
  654. */
  655. private function validateData($data)
  656. {
  657. // 必要的字段验证
  658. $requiredFields = ['sczl_gdbh', 'sczl_jtbh', 'sczl_sj1', 'sczl_sj2'];
  659. foreach ($requiredFields as $field) {
  660. if (empty($data['data'][$field])) {
  661. return false;
  662. }
  663. }
  664. // 时间逻辑验证
  665. if (strtotime($data['data']['sczl_sj1']) > strtotime($data['data']['sczl_sj2'])) {
  666. return false;
  667. }
  668. return true;
  669. }
  670. /**
  671. * 保存生产数据
  672. */
  673. private function saveProductionData($processedData)
  674. {
  675. Db::startTrans();
  676. try {
  677. // 保存主数据
  678. $mainSql = \db('设备_产量计酬')->fetchSql(true)->insert($processedData['data']);
  679. $mainResult = \db()->query($mainSql);
  680. // 保存批次数据
  681. $batchData = $this->prepareBatchData($processedData['batch'], $processedData['data']);
  682. $batchResult = true;
  683. if (!empty($batchData)) {
  684. $batchResult = \db('物料_批次跟踪')->insertAll($batchData);
  685. }
  686. // 保存装版数据
  687. $plateResult = true;
  688. if (!empty($processedData['plateChangeData'])) {
  689. $plateSql = \db('设备_装版工时')->fetchSql(true)->insert($processedData['plateChangeData']);
  690. $plateResult = \db()->query($plateSql);
  691. }
  692. if ($mainResult !== false && $batchResult !== false && $plateResult !== false) {
  693. Db::commit();
  694. return true;
  695. } else {
  696. Db::rollback();
  697. return false;
  698. }
  699. } catch (\Exception $e) {
  700. Db::rollback();
  701. // 记录日志
  702. \think\Log::error('生产数据保存失败: ' . $e->getMessage());
  703. return false;
  704. }
  705. }
  706. /**
  707. * 获取机台编号
  708. * @ApiMethod POST
  709. * @params string addr
  710. */
  711. public function getMachineMac(){
  712. if (Request::instance()->isGet() == false){
  713. $this->error('非法请求');
  714. }
  715. $params = Request::instance()->get();
  716. if (empty($params['addr'])){
  717. $this->error('参数不能为空');
  718. }
  719. $data = \db('设备_基本资料')->where('sys_sbID',$params['addr'])->field('设备编号,rtrim(使用部门) as 使用部门')->find();
  720. $this->success('请求成功',$data);
  721. }
  722. /**
  723. * 6获取拉料人员
  724. * @ApiMethod GET
  725. * @params department
  726. */
  727. public function getMaterialStrippingPeople(){
  728. if (Request::instance()->isGet() == false) {
  729. $this->error('非法请求');
  730. }
  731. $params = Request::instance()->param();
  732. $where = [];
  733. if (!isset($params['department']) || empty($params['department'])) {
  734. $this->error('参数错误');
  735. }if (!isset($params['search']) || !empty($params['search'])) {
  736. $where['员工编号|员工姓名'] = array('like','%'.$params['search'].'%');
  737. }
  738. $where['职称职务'] = '拉纸工';
  739. $where['在职状态'] = '在职';
  740. $where['U8在职'] = '在职';
  741. if ($params['department'] == 1){
  742. $where['所在部门'] = '生产部';
  743. }else{
  744. $where['所在部门'] = '检验车间';
  745. }
  746. $list[0]['员工编号'] = '000000';
  747. $list[0]['员工姓名'] = '自备';
  748. $data = \db('人事_基本资料')->where($where)->field('rtrim(员工编号) as 员工编号,rtrim(员工姓名) as 员工姓名')->order('班组代号 desc')->select();
  749. if (!empty($data)){
  750. foreach ($data as $item){
  751. array_push($list,$item);
  752. }
  753. }
  754. $this->success('请求成功',$list);
  755. }
  756. /**
  757. * 设置当前生产工单
  758. * @return void
  759. * @throws \think\Exception
  760. * @throws \think\db\exception\BindParamException
  761. * @throws \think\db\exception\DataNotFoundException
  762. * @throws \think\db\exception\ModelNotFoundException
  763. * @throws \think\exception\DbException
  764. * @throws \think\exception\PDOException
  765. */
  766. public function MachineWorkOrderEdit()
  767. {
  768. if (Request::instance()->isPost() === false) {
  769. $this->error('非法请求');
  770. }
  771. $params = Request::instance()->post();
  772. $list = \db('工单_基本资料')
  773. ->alias('a')
  774. ->field([
  775. 'RTRIM( b.Gy0_sj1 )' => 'sj1',
  776. 'RTRIM( b.Gy0_sj2 )' => 'sj2',
  777. 'RTRIM( b.UniqId )' => 'id'
  778. ])
  779. ->join('工单_工艺资料 b', 'a.Gd_gdbh = b.Gy0_gdbh')
  780. ->where([
  781. 'a.gd_statu' => '2-生产中',
  782. 'a.行号' => '1',
  783. 'b.Gy0_sbbh' => ['LIKE', '%' . $params['machine'] . '%'],
  784. 'b.PD_WG' => '1900-01-01 00:00:00',
  785. 'b.Gy0_sj1' => ['>', '1900-01-01 00:00:00'],
  786. ])
  787. ->where('b.Gy0_sj1', '<', '2099-01-01 00:00:00')
  788. ->group('a.Gd_gdbh,b.Gy0_yjno,b.Gy0_gxh')
  789. ->order('Gy0_sj1')
  790. ->select();
  791. $start = date('Y-m-d H:i:s', time());
  792. if ($start < date('Y-m-d H:15:00', time())) {
  793. $start = date('Y-m-d H:00:00', time());
  794. } elseif ($start > date('Y-m-d H:45:00', time())) {
  795. $start = date('Y-m-d H:00:00', time());
  796. } else {
  797. $start = date('Y-m-d H:30:00', time());
  798. }
  799. $data = $time = [];
  800. $i = 0;
  801. foreach ($list as $key => $value) {
  802. if ($value['id'] === $params['UniqId']) {
  803. $time = [
  804. 'Gy0_sj1' => $start,
  805. 'Gy0_sj2' => date('Y-m-d H:i:s', strtotime($start) + (strtotime($value['sj1']) - strtotime($value['sj2']))),
  806. 'id' => $value['id']
  807. ];
  808. unset($list[$key]);
  809. }
  810. }
  811. $arr = array_values($list);
  812. $data[0] = $time;
  813. foreach ($arr as $key => $value){
  814. $workTime = [
  815. 'Gy0_sj1' => $data[$key]['Gy0_sj2'],
  816. 'Gy0_sj2' => date('Y-m-d H:i:s', strtotime($data[$key]['Gy0_sj2']) + (strtotime($value['sj1']) - strtotime($value['sj2']))),
  817. 'id' => $value['id']
  818. ];
  819. array_push($data,$workTime);
  820. }
  821. foreach ($data as $key=>$value){
  822. unset($value['id']);
  823. $sql = \db('工单_工艺资料')
  824. ->where('UniqId',$data[$key]['id'])
  825. ->fetchSql(true)
  826. ->update($value);
  827. $res = \db()->query($sql);
  828. if ($res === false){
  829. $i++;
  830. }
  831. }
  832. if ($i !== 0){
  833. $this->error('失败');
  834. }else{
  835. $this->success('成功');
  836. }
  837. }
  838. /**
  839. * 检品机报工
  840. * @return void
  841. * @throws \think\db\exception\BindParamException
  842. * @throws \think\db\exception\DataNotFoundException
  843. * @throws \think\db\exception\ModelNotFoundException
  844. * @throws \think\exception\DbException
  845. * @throws \think\exception\PDOException
  846. */
  847. public function JpUploade()
  848. {
  849. if (Request::instance()->isPost() == false){
  850. $this->error('非法请求');
  851. }
  852. $params = Request::instance()->post();
  853. $time = date('Y-m-d 00:00:00',time()-86400);
  854. $data = $params;
  855. $data['sczl_装版总工时'] = $params['sczl_装版工时'];
  856. $data['sczl_装版工时'] = 0;
  857. $data['sczl_sj1'] = '1900-01-01 00:00:00';
  858. $data['sczl_sj2'] = date('Y-m-d H:i:s',time());
  859. if ($data['sczl_sj2']<date('Y-m-d 08:30:00',time()) && $data['sczl_sj2']>date('Y-m-d 00:00:00')){
  860. $data['sczl_rq'] = $time;
  861. }
  862. $start_time = \db('设备_产量采集')->where('设备编号',$data['sczl_jtbh'])->order('UniqId desc')->find();
  863. if (!empty($start_time)){
  864. $data['开工时间'] = $start_time['开工时间'];
  865. }else{
  866. $data['开工时间'] = '1900-01-01 00:00:00';
  867. }
  868. $sys_id = \db('设备_基本资料')->where('设备编号',$data['sczl_jtbh'])->value('sys_sbID');
  869. $data['sys_id'] = '['.$sys_id.'/'.$data['sczl_jtbh'].']';
  870. $UniqId = \db('设备_产量计酬')->order('UniqId desc')->value('UniqId');
  871. $data['UniqId'] = $UniqId + 1;
  872. $data['sczl_ls'] = 1;
  873. $data['sczl_zcfp'] = 0;
  874. $data['sczl_zccp'] = 0;
  875. $data['sczl_前工序废'] = 0;
  876. $data['sczl_来料少数'] = 0;
  877. $data['sczl_ms'] = 0;
  878. $data['sczl_oil'] = 0;
  879. $data['sczl_计产系数'] = 0;
  880. $data['sczl_工价系数'] = 0;
  881. $data['sczl_保养工时'] = 0;
  882. $data['sczl_打样工时'] = 0;
  883. $data['sczl_异常停机工时'] = 0;
  884. $data['sczl_异常工时1'] = 0;
  885. $data['sczl_异常类型1'] = '';
  886. $data['sczl_desc'] = '';
  887. $data['sczl_wgsj'] = '1900-01-01 00:00:00';
  888. $data['码开始行'] = 0;
  889. $data['码结束行'] = 0;
  890. $data['码包'] = 0;
  891. $data['主电表'] = 0;
  892. $data['辅电表'] = 0;
  893. $data['mod_rq'] = '1900-01-01 00:00:00';
  894. $data['sys_rq'] = date('Y-m-d H:i:s');
  895. $sql = \db('设备_产量计酬')->fetchSql(true)->insert($data);
  896. $res = \db()->query($sql);
  897. if ($res === false){
  898. $this->error('添加失败');
  899. }else{
  900. $this->success('成功');
  901. }
  902. }
  903. /**
  904. * 获取当前日期和时间
  905. * @return void
  906. */
  907. public function getTime()
  908. {
  909. $data = [
  910. 'date' => date('Y-m-d',time()),
  911. 'hours' => date('Y-m-d H:i:s',time())
  912. ];
  913. $this->success('成功',$data);
  914. }
  915. /**检品机获取废品率系数
  916. * @return void
  917. */
  918. public function getRejectRate()
  919. {
  920. if ($this->request->isGet() === false){
  921. $this->error('请求错误');
  922. }
  923. $param = $this->request->param();
  924. if (!isset($param['order']) || !isset($param['yjno']) || !isset($param['gxh']) || !isset($param['type'])){
  925. $this->error('参数错误');
  926. }
  927. if (strpos($param['type'],'正品') !== false){
  928. $param['type'] = '正品板';
  929. }
  930. if (strpos($param['type'],'次品') !== false){
  931. $param['type'] = '次品板';
  932. }
  933. if (strpos($param['type'],'废品') !== false){
  934. $param['type'] = '废检';
  935. }
  936. $res = \db('工单_工艺资料')
  937. ->where('Gy0_gdbh',$param['order'])
  938. ->where('Gy0_yjno',$param['yjno'])
  939. ->where('Gy0_gxh',$param['gxh'])
  940. ->column('机检_'.$param['type'])[0];
  941. $this->success('成功',$res);
  942. }
  943. }