WorkOrder.php 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547
  1. <?php
  2. namespace app\api\controller;
  3. use app\common\controller\Api;
  4. use Monolog\Handler\IFTTTHandler;
  5. use think\Db;
  6. /**
  7. * 工单资料管理
  8. */
  9. class WorkOrder extends Api
  10. {
  11. protected $noNeedLogin = ['*'];
  12. protected $noNeedRight = ['*'];
  13. /**
  14. * 工单资料菜单列表
  15. *
  16. * @ApiMethod (GET)
  17. * @return false|string
  18. * @throws \think\Exception
  19. */
  20. public function DataList()
  21. {
  22. if ($this->request->isGet() === false){
  23. $this->error('请求错误');
  24. }
  25. $where = [
  26. '行号' => '1',
  27. ];
  28. $ClientList = Db::table('erp_客户供应商')->where('类型','客户')->cache(true)->column('简称','编号');
  29. //获取总计划中数量和总生产中数量
  30. $productingAll = Db::table('工单_基本资料')->where('gd_statu','2-生产中')->cache(true)->count();
  31. $progressAll = Db::table('工单_基本资料')->where('gd_statu','3-计划中')->cache(true)->count();
  32. $data = [
  33. 'productingAll' => $productingAll,
  34. 'progressAll' => $progressAll
  35. ];
  36. //按客户编号查询生产中,计划中数量
  37. foreach ($ClientList as $key=>$value){
  38. $order = Db::table('工单_基本资料')->where('Gd_客户代号',$key)->cache(true)->count();
  39. if ($order !== 0){
  40. $productIng = Db::table('工单_基本资料')->where('Gd_客户代号',$key)->where($where)->where('gd_statu','2-生产中')->cache(true)->count();
  41. $proGress = Db::table('工单_基本资料')->where('Gd_客户代号',$key)->where($where)->where('gd_statu','3-计划中')->cache(true)->count();
  42. $code = Db::table('工单_基本资料')->where('Gd_客户代号',$key)->field('rtrim(成品代号) as 成品代号')->cache(true)->find();
  43. $Detail = [
  44. 'Gd_khdh' => substr($code['成品代号'],0,4),
  45. 'Gd_khmc' => rtrim($value),
  46. 'producting' => $productIng = 0?'':"生产中:".$productIng,
  47. 'progress' => $proGress=0?'':'计划中:'.$proGress,
  48. ];
  49. $menu = $Detail['Gd_khdh'].'【'.$Detail['producting'].$Detail['progress'].'】'.'【'.$Detail['Gd_khmc'].'】';
  50. array_push($data,$menu);
  51. }
  52. }
  53. $this->success('成功',$data);
  54. }
  55. /**
  56. * 工单基本资料列表
  57. * @ApiMethod (GET)
  58. * @param string $limit 查询长度
  59. * @param string $Gd_khdh 客户代号
  60. * @param string $startTime 接单日期开始时间
  61. * @param string $endTime 接单日期结束时间
  62. * @return \think\response\Json
  63. * @throws \think\exception\DbException
  64. */
  65. public function WorkList()
  66. {
  67. if ($this->request->isGet() === false){
  68. $this->error('请求错误');
  69. }
  70. $limit = input('limit');
  71. // $page = input('page');
  72. $clientNumber = input('Gd_khdh');
  73. $startTime = input('start');
  74. $endTime = input('end');
  75. $where = [
  76. '成品代号' => ['like',$clientNumber.'%']
  77. ];
  78. if (isset($startTime) && isset($endTime)){
  79. $where['接单日期'] = ['between',[$startTime,$endTime]];
  80. }
  81. // $config = [
  82. // 'page_param' => $page,
  83. // 'per_page' => $limit
  84. // ];
  85. $list = Db::table('工单_基本资料')
  86. ->where($where)
  87. ->order('接单日期 desc')
  88. ->paginate($limit);
  89. //工单基本资料数据整理
  90. $data = [];
  91. foreach ($list->items() as $key=>$value){
  92. $data[$key] = [
  93. '工单编号' => rtrim($value['Gd_gdbh']),
  94. '生产分类' => rtrim($value['Gd_生产分类']),
  95. '销售订单号' => rtrim($value['销售订单号']),
  96. '产品代号' => rtrim($value['Gd_cpdh']),
  97. '产品名称' => rtrim($value['Gd_cpmc']),
  98. '订单数量' => rtrim($value['订单数量']),
  99. '单位' => rtrim($value['计量单位']),
  100. '折合大箱' => rtrim((int)$value['投料大箱']),
  101. '投料率' => rtrim($value['投料率']),
  102. '平均合格率' => '',
  103. '开单日期' => date('Y-m-d',strtotime(rtrim($value['接单日期']))),
  104. '交货日期' => date('Y-m-d',strtotime(rtrim($value['交货日期']))),
  105. '工单类型' => rtrim($value['Gd_lx']),
  106. '工单状态' => rtrim($value['gd_statu']),
  107. '当前生产工序' => '',
  108. '产量提交时间' => '',
  109. '建档用户' => rtrim($value['Sys_id']),
  110. '建档时间' => rtrim($value['Sys_rq']),
  111. '更新时间' => rtrim($value['Mod_rq']),
  112. ];
  113. }
  114. $this->success('成功',$data);
  115. }
  116. /**
  117. * 印件资料
  118. * @ApiMethod (GET)
  119. * @param string $Gd_gdbh 工单编号
  120. * @return \think\response\Json
  121. * @throws \think\db\exception\DataNotFoundException
  122. * @throws \think\db\exception\ModelNotFoundException
  123. * @throws \think\exception\DbException
  124. */
  125. public function Printed()
  126. {
  127. if ($this->request->isGet() === false){
  128. $this->error('请求错误');
  129. }
  130. $Gd_gdbh = input('Gd_gdbh');
  131. if (empty($Gd_gdbh)){
  132. $this->error('参数错误');
  133. }
  134. $list = Db::table('工单_印件资料')->where('Yj_Gdbh',$Gd_gdbh)->select();
  135. $data = [];
  136. if ($list){
  137. foreach ($list as $key=>$value){
  138. $data[$key] = [
  139. '印件号' => rtrim($value['yj_Yjno']),
  140. '印件代号' => rtrim($value['yj_Yjdh']),
  141. '印件名称' => rtrim($value['yj_yjmc']),
  142. '纸张代号' => rtrim($value['yj_zzdh']),
  143. '纸张名称' => rtrim($value['yj_zzmc']),
  144. '投料规格' => rtrim($value['yj_tlgg']),
  145. '平张投料' => rtrim($value['yj_平张投料']),
  146. '开料规格' => rtrim($value['yj_klgg']),
  147. '开数*联数' => rtrim($value['yj_ks']).'*'.rtrim($value['yj_ls']),
  148. '建档用户' => rtrim($value['Sys_id']),
  149. '建档时间' => rtrim($value['Sys_rq']),
  150. '更新时间' => rtrim($value['Mod_rq']),
  151. ];
  152. }
  153. }
  154. $this->success('成功',$data);
  155. }
  156. /**
  157. * 工艺资料
  158. * @ApiMethod (GET)
  159. * @param string $Gd_gdbh 工单编号
  160. * @return \think\response\Json
  161. * @throws \think\db\exception\DataNotFoundException
  162. * @throws \think\db\exception\ModelNotFoundException
  163. * @throws \think\exception\DbException
  164. */
  165. public function Craft()
  166. {
  167. if ($this->request->isGet() === false){
  168. $this->error('请求错误');
  169. }
  170. $Gd_gdbh = input('Gd_gdbh');
  171. if (empty($Gd_gdbh)){
  172. $this->error('参数错误');
  173. }
  174. $list = Db::table('工单_工艺资料')
  175. ->where('Gy0_gdbh',$Gd_gdbh)
  176. ->select();
  177. $Gd_cpdh = Db::table('工单_基本资料')->where('Gd_gdbh',$Gd_gdbh)->field('Gd_cpdh')->find();
  178. $data = [];
  179. if ($list){
  180. foreach ($list as $key=>$value){
  181. if ($value['Gy0_yjno']<10){
  182. $value['Gy0_yjno'] = '0'.$value['Gy0_yjno'];
  183. }
  184. if ($value['Gy0_gxh']<10){
  185. $value['Gy0_gxh'] = '0'.$value['Gy0_gxh'];
  186. }
  187. $where = [
  188. 'Gy0_cpdh' => $Gd_cpdh['Gd_cpdh'],
  189. 'Gy0_yjno' => $value['Gy0_yjno'],
  190. 'Gy0_gxh' => $value['Gy0_gxh'],
  191. ];
  192. $product = Db::table('产品_工艺资料')->where($where)->field('工价系数,损耗系数')->find();
  193. $data[$key] = [
  194. '重点工序' => rtrim($value['重点工序']),
  195. '印件-工序' => rtrim($value['Gy0_yjno']).'-'.rtrim($value['Gy0_gxh']),
  196. '备选工序' => '',
  197. '工序名称' => rtrim($value['Gy0_gxmc']).'【'.rtrim($value['Add_gxmc']).'】',
  198. '计划产量' => '',
  199. '基础损耗' => rtrim($value['Gy0_Rate0']),
  200. '损耗率' => rtrim($value['Gy0_Rate1']),
  201. '报废定额' => '',
  202. '允损比例' => '',
  203. '难度系数' => isset($product['工价系数'])?rtrim($product['工价系数']):'',
  204. '损耗系数' => isset($product['损耗系数'])?rtrim($product['损耗系数']):'',
  205. '人工检_次品板' => (int)$value['人工检_次品板']=0?'':$value['人工检_次品板'],
  206. '人工检_废检' => (int)$value['人工检_废检']=0?'':$value['人工检_废检'],
  207. '机检_正品板' => (int)$value['机检_正品板']=0?'':$value['机检_正品板'],
  208. '机检_次品板' => (int)$value['机检_次品板']=0?'':$value['机检_次品板'],
  209. '机检_废检' => (int)$value['机检_废检']=0?'':$value['机检_废检'],
  210. '开数*联数' => rtrim($value['Gy0_ks']).'*'.rtrim($value['Gy0_ls']),
  211. '备注' => isset($value['工序备注'])?rtrim($value['工序备注']):'',
  212. '印刷方式' => isset($value['印刷方式'])?rtrim($value['印刷方式']):'',
  213. '版距' => isset($value['版距'])?rtrim($value['版距']):'',
  214. '建档用户' => rtrim($value['Sys_id']),
  215. '建档日期' => isset($value['Sys_rq'])?rtrim($value['Sys_rq']):'',
  216. '更新时间' => isset($value['Mod_rq'])?rtrim($value['Mod_rq']):'',
  217. ];
  218. }
  219. }
  220. $this->success('成功',$data);
  221. }
  222. /**
  223. * BOM资料
  224. * @ApiMethod (GET)
  225. * @param string $Gd_gdbh 工单编号
  226. * @return \think\response\Json
  227. * @throws \think\db\exception\DataNotFoundException
  228. * @throws \think\db\exception\ModelNotFoundException
  229. * @throws \think\exception\DbException
  230. */
  231. public function Bom()
  232. {
  233. if ($this->request->isGet() === false){
  234. $this->error('请求错误');
  235. }
  236. $Gd_gdbh = input('Gd_gdbh');
  237. if (empty($Gd_gdbh)){
  238. $this->error('参数错误');
  239. }
  240. $field = 'rtrim(BOM_方案) as 方案,rtrim(BOM_物料编码) as 物料编号,rtrim(BOM_物料名称) as 物料名称,BOM_投料单位,
  241. BOM_投入数,BOM_产出数,BOM_产出单位,rtrim(BOM_计划用量) as 计划用量,rtrim(Sys_ID) as 建档用户,rtrim(Sys_rq) as 建档时间,rtrim(Mod_rq) as 更新时间';
  242. $list = Db::table('工单_bom资料')
  243. ->where('BOM_工单编号',$Gd_gdbh)
  244. ->field($field)
  245. ->select();
  246. foreach ($list as $key=>$value){
  247. $list[$key]['消耗定量'] = rtrim($value['BOM_投入数']).rtrim($value['BOM_投料单位']).'/'.rtrim($value['BOM_产出数']).rtrim($value['BOM_产出单位']);
  248. unset($list[$key]['BOM_投料单位'],$list[$key]['BOM_投入数'],$list[$key]['BOM_产出数'],$list[$key]['BOM_产出单位']);
  249. $list[$key]['计划用量'] = rtrim((float)$value['计划用量']);
  250. }
  251. $this->success('成功',$list);
  252. }
  253. /**
  254. * 编辑页面展示
  255. * @ApiMethod (GET)
  256. * @param string $workOrder 工单编号
  257. * @return void
  258. * @throws \think\db\exception\DataNotFoundException
  259. * @throws \think\db\exception\ModelNotFoundException
  260. * @throws \think\exception\DbException
  261. */
  262. public function DataCorrection()
  263. {
  264. if ($this->request->isGet() === false){
  265. $this->error('请求错误');
  266. }
  267. $workOrder = input('Gd_gdbh');
  268. if (empty($workOrder)){
  269. $this->error('参数错误');
  270. }
  271. $field = 'rtrim(Gd_lx) as 重点工单,rtrim(Gd_gdbh) as 工单编号,rtrim(Gd_生产分类) as 生产类型,rtrim(Gd_khdh) as 客户代号,rtrim(Gd_客户名称) as 客户名称,
  272. rtrim(Gd_cpdh) as 产品代号,rtrim(Gd_cpmc) as 产品名称,rtrim(开单日期) as 开单日期,rtrim(订单数量) as 订单数量,rtrim(交货日期) as 交货日期,
  273. rtrim(投料率) as 投料率,rtrim(实际投料) as 万小张,rtrim(计量单位) as 单位,rtrim(投料大箱) as 投料大箱,rtrim(排产时库存) as 库存大箱,rtrim(警语版面) as 警语版面,
  274. rtrim(销售订单号) as 销售订单号,rtrim(产品版本号) as 版本号,rtrim(客户ERP编码) as 客户ERP编码,rtrim(码源数量) as 码源数量,rtrim(进程备注) as 进程备注,rtrim(Gd_desc) as 备注';
  275. $list = Db::table('工单_基本资料')->where('Gd_gdbh',$workOrder)->field($field)->find();
  276. if (empty($list)){
  277. $this->error('未找到该工单信息');
  278. }
  279. $printData = Db::table('工单_印件资料')
  280. ->where('Yj_Gdbh',$workOrder)
  281. ->field('rtrim(yj_yjmc) as 印件名称,rtrim(yj_Yjdh) as 印件代号,rtrim(yj_平张投料) as 平张投料')
  282. ->find();
  283. if (empty($printData)){
  284. $this->error('未找到该工单印件资料');
  285. }
  286. $list['印件名称'] = $printData['印件名称'];
  287. $list['印件代号'] = $printData['印件代号'];
  288. $list['平张投料'] = $printData['平张投料'];
  289. $this->success('成功',$list);
  290. }
  291. /**
  292. * 工单资料修改
  293. * @ApiMethod (POST)
  294. * @param array $data 上传数据
  295. * @return void
  296. * @throws \think\Exception
  297. * @throws \think\exception\PDOException
  298. */
  299. public function WorkOrderEdit()
  300. {
  301. if ($this->request->isPost() === false){
  302. $this->error('请求错误');
  303. }
  304. $data = input('data');
  305. if (empty($data)){
  306. $this->error('参数错误');
  307. }
  308. $sql = Db::table('工单_基本资料')->where('Gd_gdbh',$data['Gd_gdbh'])->fetchSql(true)->update($data);
  309. $res = Db::query($sql);
  310. if ($res === 0){
  311. $this->error('修改失败');
  312. }
  313. $this->success('成功');
  314. }
  315. //U8投料试算
  316. public function U8Trial()
  317. {
  318. if ($this->request->isGet() === false)
  319. {
  320. $this->error('请求错误');
  321. }
  322. $productCode = input('productCode');
  323. if (empty($productCode)){
  324. $this->error('参数错误');
  325. }
  326. // $field = 'rtrim(Gy0_cpdh) as 产品代号,rtrim(Gy0_yjno) as 印件号,rtrim(Gy0_gxh) as 工序号,rtrim(gy0_gxmc) as gxmc,rtrim(Add_gxmc) as add_gxmc,
  327. // rtrim(Gy0_Ms) as 墨色数,rtrim(Gy0_shdh) as 损耗代号,rtrim(损耗系数) as 损耗系数,rtrim(Gy0_ls) as 加工联数,'
  328. }
  329. /**
  330. * 引用产品资料->获取产品资料
  331. * @ApiMethod (GET)
  332. * @param string $workOrder 工单编号
  333. * @return void
  334. * @throws \think\db\exception\DataNotFoundException
  335. * @throws \think\db\exception\ModelNotFoundException
  336. * @throws \think\exception\DbException
  337. */
  338. public function ProductInformation()
  339. {
  340. if ($this->request->isGet() === false)
  341. {
  342. $this->error('请求错误');
  343. }
  344. $workOrder = input('workOrder');
  345. if (empty($workOrder)){
  346. $this->error('参数错误');
  347. }
  348. $field = 'rtrim(Gd_gdbh) as 工单编号,rtrim(Gd_客户名称) as 客户名称,rtrim(成品代号) as 产品代号,rtrim(成品名称) as 产品名称';
  349. $Detail = Db::table('工单_基本资料')->where('Gd_gdbh',$workOrder)->field($field)->find();
  350. if (empty($Detail)){
  351. $this->error('未找到工单信息');
  352. }
  353. $Detail['客户代号'] = substr($Detail['产品代号'],0,4);
  354. $this->success('成功',$Detail);
  355. }
  356. /**
  357. * 引用产品资料->复制产品工艺资料
  358. * @ApiMethod (POST)
  359. * @param string $oldWorkOrder 被复制工单编号
  360. * @param string $newWorkOrder 复制工单编号
  361. * @return void
  362. * @throws \think\Exception
  363. * @throws \think\db\exception\DataNotFoundException
  364. * @throws \think\db\exception\ModelNotFoundException
  365. * @throws \think\exception\DbException
  366. * @throws \think\exception\PDOException
  367. */
  368. public function ProductInformationEdit()
  369. {
  370. if ($this->request->isPost() === false)
  371. {
  372. $this->error('请求错误');
  373. }
  374. $oldWorkOrder = input('oldWorkOrder');
  375. $newWorkOrder = input('newWorkOrder');
  376. if (empty($oldWorkOrder) || empty($newWorkOrder))
  377. {
  378. $this->error('参数错误');
  379. }
  380. //获取原工单工艺资料
  381. $oldProcessData = Db::table('工单_工艺资料')->where('Gy0_gdbh',$oldWorkOrder)->select();
  382. $ProsessUniqId = Db::table('工单_工艺资料')->field('UniqId')->order('UniqId desc')->find();
  383. foreach ($oldProcessData as $k=>$v){
  384. $oldProcessData[$k]['Gy0_gdbh'] = $newWorkOrder;
  385. $oldProcessData[$k]['Sys_id'] = '';
  386. $oldProcessData[$k]['UniqId'] = $ProsessUniqId['UniqId'] + $k + 1;
  387. }
  388. if (Db::table('工单_工艺资料')->where('Gy0_gdbh',$newWorkOrder)->find()){
  389. Db::table('工单_工艺资料')->where('Gy0_gdbh',$newWorkOrder)->delete();
  390. }
  391. //获取原工单印件资料
  392. $oldPrintData = Db::table('工单_印件资料')->where('Yj_Gdbh',$oldWorkOrder)->select();
  393. $PrintUniqId = Db::table('工单_印件资料')->field('Uniqid')->order('Uniqid desc')->find();
  394. foreach ($oldPrintData as $k=>$v){
  395. $oldPrintData[$k]['Yj_Gdbh'] = $newWorkOrder;
  396. $oldPrintData[$k]['Sys_id'] = '';
  397. $oldPrintData[$k]['Uniqid'] = $PrintUniqId['Uniqid'] +$k +1;
  398. }
  399. if (Db::table('工单_印件资料')->where('Yj_Gdbh',$newWorkOrder)->find()){
  400. Db::table('工单_印件资料')->where('Yj_Gdbh',$newWorkOrder)->delete();
  401. }
  402. //复制印件、工艺资料
  403. $ProcessSQL = Db::table('工单_工艺资料')->fetchSql(true)->insertAll($oldProcessData);
  404. $ProcessRes = Db::query($ProcessSQL);
  405. $PrintSQL = Db::table('工单_印件资料')->fetchSql(true)->insertAll($oldPrintData);
  406. $PrintRes = Db::query($PrintSQL);
  407. if ($ProcessRes !== false && $PrintRes !== false){
  408. $this->success('成功');
  409. }else{
  410. $this->error('失败');
  411. }
  412. }
  413. /**
  414. * 工艺流程调成->获取当前工单工艺资料
  415. * @ApiMethod (GET)
  416. * @param string $workorder 当前工单编号
  417. * @return void
  418. * @throws \think\db\exception\DataNotFoundException
  419. * @throws \think\db\exception\ModelNotFoundException
  420. * @throws \think\exception\DbException
  421. */
  422. public function ProcessFlow()
  423. {
  424. if ($this->request->isGet() === false){
  425. $this->error('请求错误');
  426. }
  427. $workOrder = input('workOrder');
  428. if (empty($workOrder)){
  429. $this->error('参数错误');
  430. }
  431. $list = Db::table('工单_基本资料')->where('Gd_gdbh',$workOrder)->field('rtrim(成品代号) as 成品编号,rtrim(成品名称) as 成品名称')->find();
  432. if (empty($list)){
  433. $this->error('未找到工单信息');
  434. }
  435. $filed = 'rtrim(Gy0_方案) as 方案,rtrim(Gy0_yjno) as 印件号,rtrim(Gy0_gxh) as 工序号,rtrim(Gy0_gxmc) as gxmc,rtrim(Add_gxmc) as add_gxmc,
  436. rtrim(工价系数) as 工价系数,rtrim(损耗系数) as 损耗系数,rtrim(Gy0_ks) as ks,rtrim(Gy0_ls) as ls,rtrim(工序备注) as 备注,rtrim(Gy0_SITE) as 车间,
  437. rtrim(Gy0_sbbh) as 设备编号,rtrim(Gy0_sbmc) as 设备名称,rtrim(Sys_id) as 建档用户,rtrim(Sys_rq) as 建档时间,rtrim(Mod_rq) as 更新时间';
  438. $process = Db::table('工单_工艺资料')->where('Gy0_gdbh',$workOrder)->field($filed)->select();
  439. if (empty($process)){
  440. $this->error('未找到该工单工艺资料');
  441. }
  442. foreach ($process as $key=>$value){
  443. if (isset($value['add_gxmc'])){
  444. $process[$key]['工序名称'] = $value['gxmc'] . '【'.$value['add_gxmc'].'】';
  445. }else{
  446. $process[$key]['工序名称'] = $value['gxmc'];
  447. }
  448. $process[$key]['工价系数'] = (float)$value['工价系数'];
  449. $process[$key]['损耗系数'] = (float)$value['损耗系数'];
  450. $process[$key]['开数*联数'] = $value['ks'].'*'.$value['ls'];
  451. }
  452. $list['process'] = $process;
  453. $this->success('成功',$list);
  454. }
  455. /**
  456. * 参照工单列表获取
  457. * @ApiMethod (GET)
  458. * @param string $workOrder 工单编号
  459. * @param string $productCode 产品代号
  460. * @return void
  461. */
  462. public function ReferenceWorkOrder()
  463. {
  464. if ($this->request->isGet() === false){
  465. $this->error('请求错误');
  466. }
  467. $productCode = input('productCode');
  468. $workOrder = input('workOrder');
  469. if (empty($productCode) || empty($workOrder)){
  470. $this->error('参数错误');
  471. }
  472. $list = Db::table('工单_基本资料')->where('成品代号',$productCode)->where('Gd_gdbh','<>',$workOrder)->column('Gd_gdbh');
  473. if (empty($list)){
  474. $this->error('未获取该产品其他工单信息');
  475. }
  476. $this->success('成功',$list);
  477. }
  478. /**
  479. * 工艺资料复制
  480. * @ApiMethod (POST)
  481. * @param string $oldWorkOrder 被复制工单编号
  482. * @param string $newWorkOrder 复制工单编号
  483. * @return void
  484. * @throws \think\Exception
  485. * @throws \think\db\exception\DataNotFoundException
  486. * @throws \think\db\exception\ModelNotFoundException
  487. * @throws \think\exception\DbException
  488. * @throws \think\exception\PDOException
  489. *
  490. */
  491. public function ProcessCopy()
  492. {
  493. if ($this->request->isPost() === false){
  494. $this->error('请求错误');
  495. }
  496. $oldWorkOrder = input('oldWorkOrder');
  497. $newWorkOrder = input('newWorkOrder');
  498. if (empty($oldWorkOrder) || empty($newWorkOrder))
  499. {
  500. $this->error('参数错误');
  501. }
  502. //获取原工单工艺资料
  503. $oldProcessData = Db::table('工单_工艺资料')->where('Gy0_gdbh',$oldWorkOrder)->select();
  504. $ProsessUniqId = Db::table('工单_工艺资料')->field('UniqId')->order('UniqId desc')->find();
  505. foreach ($oldProcessData as $k=>$v){
  506. $oldProcessData[$k]['Gy0_gdbh'] = $newWorkOrder;
  507. $oldProcessData[$k]['Sys_id'] = '';
  508. $oldProcessData[$k]['Mod_rq'] = date('Y-m-d H:i:s',time());
  509. $oldProcessData[$k]['UniqId'] = $ProsessUniqId['UniqId'] + $k + 1;
  510. }
  511. if (Db::table('工单_工艺资料')->where('Gy0_gdbh',$newWorkOrder)->find()){
  512. Db::table('工单_工艺资料')->where('Gy0_gdbh',$newWorkOrder)->delete();
  513. }
  514. //插入工艺资料
  515. $ProcessSQL = Db::table('工单_工艺资料')->fetchSql(true)->insertAll($oldProcessData);
  516. $ProcessRes = Db::query($ProcessSQL);
  517. if ($ProcessRes !== false){
  518. $this->success('成功');
  519. }else{
  520. $this->error('失败');
  521. }
  522. }
  523. }