Facility.php 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733
  1. <?php
  2. namespace app\api\controller;
  3. use app\common\controller\Api;
  4. use think\Db;
  5. use think\Request;
  6. /**
  7. * 质量继绩效管理
  8. */
  9. class Facility extends Api{
  10. protected $noNeedLogin = ['*'];
  11. protected $noNeedRight = ['*'];
  12. /**
  13. * 1.0查询子订单编号
  14. */
  15. public function Apiorderids() {
  16. if ($this->request->isGet() === false) {
  17. $this->error('请求错误');
  18. }
  19. $param = $this->request->param();
  20. $gdlist = \db('工单_印件资料')
  21. ->field('子订单编号')
  22. ->where('订单编号',$param['order'])
  23. ->where('Mod_rq', null)
  24. ->select();
  25. $this->success('成功', [
  26. 'list' => $gdlist,
  27. ]);
  28. }
  29. /**
  30. * 1.1查询订单号或生产款号
  31. */
  32. public function Apiorder() {
  33. if ($this->request->isGet() === false) {
  34. $this->error('请求错误');
  35. }
  36. $param = $this->request->param();
  37. $gdlist = \db('工单_基本资料')
  38. ->field('订单编号,生产款号')
  39. ->where('订单编号|生产款号','like','%'.$param['search'].'%')
  40. ->where('Mod_rq', null)
  41. ->select();
  42. $this->success('成功', [
  43. 'list' => $gdlist,
  44. ]);
  45. }
  46. /**
  47. * 1.2查询新增基本信息
  48. */
  49. public function queryOrderSize() {
  50. // 检查请求类型是否为GET
  51. if ($this->request->isGet() === false) {
  52. $this->error('请求错误');
  53. }
  54. $param = $this->request->param();
  55. //问题分类
  56. $fetchCategory = \db('db_问题分类')->field('问题类型, classification as 分类名称')->select();
  57. $groupedCategories = [];
  58. // 遍历数据,将相同分类名称的问题类型归类
  59. foreach ($fetchCategory as $item) {
  60. $categoryname = $item['分类名称'];
  61. $category = $item['问题类型'];
  62. // 如果分类名称不存在,则初始化为空数组
  63. if (!isset($groupedCategories[$categoryname])) {
  64. $groupedCategories[$categoryname] = [];
  65. }
  66. // 避免重复添加相同的问题类型
  67. if (!in_array($category, $groupedCategories[$categoryname])) {
  68. $groupedCategories[$categoryname][] = $category;
  69. }
  70. }
  71. $gdlist = \db('工单_基本资料')
  72. ->field('订单编号,生产款号,款式,订单数量')
  73. ->where(['订单编号|生产款号' => $param['订单编号']])
  74. ->where('Mod_rq', null)
  75. ->find();
  76. if (empty($gdlist)) {
  77. $this->error('未找到相关数据');
  78. }
  79. // 查询订单尺码信息
  80. $sizeData = \db('工单_印件资料')->where(['订单编号' => $gdlist['订单编号']])->where('Mod_rq', null)->select();
  81. if (empty($sizeData)) {
  82. $this->error('未找到相关数据');
  83. }
  84. // 计算所有尺码数据
  85. $sizes = [];
  86. foreach ($sizeData as $order) {
  87. foreach ($order as $key => $value) {
  88. if (strpos($key, 'cm') === 0 && strpos($key, 'cmsl') === false && $value !== null && $value !== '') {
  89. $sizes[] = $value;
  90. }
  91. }
  92. }
  93. // 去重后所有子订单重复的尺码数据
  94. $sizes = array_values(array_unique($sizes));
  95. // 获取颜色备注并统计每个颜色的sctotal和zdtotal
  96. $colorData = []; // 用于存储每个颜色备注对应的sctotal和zdtotal
  97. foreach ($sizeData as $item) {
  98. if (!empty($item['颜色备注'])) {
  99. $color = $item['颜色备注'];
  100. $sctotal = (int)$item['sctotal'];
  101. $zdtotal = (int)$item['zdtotal'];
  102. if (isset($colorData[$color])) {
  103. $colorData[$color]['sctotal'] += $sctotal;
  104. $colorData[$color]['zdtotal'] += $zdtotal;
  105. } else {
  106. $colorData[$color] = [
  107. 'sctotal' => $sctotal,
  108. 'zdtotal' => $zdtotal
  109. ];
  110. }
  111. }
  112. }
  113. // 获取颜色备注(去重)
  114. $colorremark = array_values(array_unique(array_keys($colorData)));
  115. //面料分类|面料名称
  116. $getarr = \db('工单_bom资料')
  117. ->field('物料分类,BOM_物料名称')
  118. ->where('BOM_工单编号', $param['订单编号'])
  119. ->where('Mod_rq', null)
  120. ->select();
  121. $fabricArr = []; // 存储拼接后的数据
  122. foreach ($getarr as $value) {
  123. $materialName = $value['BOM_物料名称'];
  124. $bomDesc = !empty($value['物料分类']) ? $value['物料分类'] : ''; // 防止null
  125. // 拼接字符串,并去除可能的前后空格
  126. $combinedData = trim($bomDesc . ' - ' . $materialName, ' -');
  127. // 存入数组
  128. $fabricArr[] = $combinedData;
  129. }
  130. // 获取面料颜色
  131. $getAllFabricData = \db('工单_面料资料')
  132. ->field('BOM_物料名称,BOM_定额门幅,BOM_计划门幅,BOM_颜色')
  133. ->where('BOM_工单编号', $param['订单编号'])
  134. ->where('Mod_rq', null)
  135. ->select();
  136. // 用于统计每个物料的用料情况
  137. $uniqueFabricData = []; // 去重后的面料数据
  138. foreach ($getAllFabricData as $fabric) {
  139. $key = $fabric['BOM_颜色'] . '-' . $fabric['BOM_物料名称']; // 以颜色和物料名称为唯一标识
  140. $uniqueFabricData[$key] = $fabric; // 使用唯一标识作为数组的键,自动去重
  141. }
  142. // 重建数组索引,移除键名
  143. $uniqueFabricData = array_values($uniqueFabricData);
  144. $materialUsage = [];
  145. // 遍历每种颜色的统计数据
  146. foreach ($colorData as $color => $data) {
  147. // 遍历去重后的面料数据
  148. foreach ($uniqueFabricData as $fabric) {
  149. // 判断颜色是否匹配
  150. if ($fabric['BOM_颜色'] === $color) {
  151. // 直接统计每个物料的数量,而不进行用料的计算
  152. $materialUsage[$color][$fabric['BOM_物料名称']][] = $fabric; // 使用物料名称作为键,存储所有相关的面料数据
  153. }
  154. }
  155. }
  156. // 生成实际用料数据
  157. $actualUsage = [];
  158. foreach ($materialUsage as $color => $materials) {
  159. foreach ($materials as $materialName => $fabricData) {
  160. // 获取该颜色下的 sctotal 和 zdtotal
  161. $sctotal = isset($colorData[$color]['sctotal']) ? $colorData[$color]['sctotal'] : 0;
  162. $zdtotal = isset($colorData[$color]['zdtotal']) ? $colorData[$color]['zdtotal'] : 0;
  163. // 获取定额门幅和计划门幅
  164. $standardWidth = isset($fabricData[0]['BOM_定额门幅']) ? $fabricData[0]['BOM_定额门幅'] : 0;
  165. $plannedWidth = isset($fabricData[0]['BOM_计划门幅']) ? $fabricData[0]['BOM_计划门幅'] : 0;
  166. // 直接根据去重后的面料数据进行统计
  167. $actualUsage[] = [
  168. '颜色' => $color,
  169. '物料名称' => $materialName,
  170. '定额门幅' => $standardWidth,
  171. '计划门幅' => $plannedWidth,
  172. 'sctotal' => $sctotal,
  173. 'zdtotal' => $zdtotal
  174. ];
  175. }
  176. }
  177. foreach ($actualUsage as &$item) {
  178. // 如果 'sctotal' 或 '定额门幅' 为空,则默认为 0
  179. $sctotal = isset($item['sctotal']) && is_numeric($item['sctotal']) ? $item['sctotal'] : 0;
  180. $demf = isset($item['定额门幅']) && is_numeric($item['定额门幅']) ? $item['定额门幅'] : 0;
  181. $zdtotal = isset($item['zdtotal']) && is_numeric($item['zdtotal']) ? $item['zdtotal'] : 0;
  182. $jhmf = isset($item['计划门幅']) && is_numeric($item['计划门幅']) ? $item['计划门幅'] : 0;
  183. $item['实际用料'] = $sctotal * $demf;
  184. $item['计划用料'] = $zdtotal * $jhmf;
  185. }
  186. // 选择显示的字段
  187. $fieldsToShow = ['颜色', '物料名称', '实际用料', '计划用料'];
  188. $finalResult = array();
  189. foreach ($actualUsage as $item) {
  190. $filteredItem = array();
  191. foreach ($fieldsToShow as $field) {
  192. if (isset($item[$field])) {
  193. $filteredItem[$field] = $item[$field];
  194. }
  195. }
  196. $finalResult[] = $filteredItem;
  197. }
  198. //定义接口
  199. $this->success('成功', [
  200. 'list' => $gdlist,
  201. 'colorremark' => $colorremark,
  202. 'fetchCategory' => $groupedCategories,
  203. 'FabricData' => $fabricArr,
  204. 'size' => $sizes,
  205. '面料统计' => $finalResult
  206. ]);
  207. }
  208. /**
  209. * 1.3新增次品或返工
  210. */
  211. public function ApiAddDefective(){
  212. if (!$this->request->isPost()) {
  213. $this->error('非法请求');
  214. }
  215. $params = $this->request->param();
  216. if (empty($params)){
  217. $this->error('参数错误');
  218. }
  219. $res = \db('设备_质量汇总')->where('mod_rq', null)->order('status_num desc')->find();
  220. //记录每次新增次数排序
  221. $status_num = $res['status_num'];
  222. // 构建单条记录的函数,传递 $list_gd 作为参数
  223. function buildRecords($item,$status_num) {
  224. // 拆分物料名称(假设格式为 面料分类-面料名称)
  225. $materialParts = explode('-', $item['物料名称']);
  226. $materialCategory = isset($materialParts[0]) ? $materialParts[0] : ''; // 面料分类
  227. $materialName = isset($materialParts[1]) ? $materialParts[1] : ''; // 面料名称
  228. // 获取最新的单据编号
  229. $resd = \db('设备_质量汇总')
  230. ->field('单据编号')
  231. ->where('mod_rq', null)
  232. ->order('单据编号 desc')
  233. ->find();
  234. // 获取当前日期
  235. $currentDate = date('Ymd'); // 获取当前日期,格式为:20250327
  236. // 如果查询到最新的单据编号
  237. if ($resd) {
  238. // 提取最新单据编号的日期和流水号部分
  239. preg_match('/ZL(\d{8})(\d{4})/', $resd['单据编号'], $matches);
  240. // 如果匹配成功,进行累加
  241. if ($matches) {
  242. $lastDate = $matches[1];
  243. $lastNumber = (int)$matches[2]; // 将流水号转为数字
  244. // 如果当前日期和最新单据的日期不同,则从0001开始
  245. $newNumber = ($currentDate !== $lastDate) ? '0001' : str_pad($lastNumber + 1, 4, '0', STR_PAD_LEFT);
  246. } else {
  247. // 如果没有匹配到正确的格式,则从0001开始
  248. $newNumber = '0001';
  249. }
  250. } else {
  251. // 如果没有查询到单据编号,默认从0001开始
  252. $newNumber = '0001';
  253. }
  254. return [
  255. '单据编号' => 'ZL' . $currentDate . $newNumber,
  256. '订单编号' => $item['订单编号'],
  257. '生产款号' => $item['生产款号'],
  258. '款式' => $item['款式'],
  259. '颜色' => $item['颜色'],
  260. '尺码' => $item['尺码'],
  261. '数量' => $item['数量'],
  262. '组别' => $item['组别'],
  263. '实际用料' => $item['实际用料'],
  264. '计划用料' => $item['计划用料'],
  265. '备注' => $item['备注'],
  266. '问题分类' => $item['问题分类'],
  267. 'sczl_rq' => date('Y-m-d H:i:s'),
  268. 'Sys_rq' => $item['Sys_rq'],
  269. 'Sys_id' => $item['Sys_id'],
  270. '状态' => $item['状态'],
  271. 'status_num' => $status_num + 1,
  272. '面料分类' => $materialCategory,
  273. '面料名称' => $materialName,
  274. ];
  275. }
  276. // 检查是否是索引数组(多条记录)
  277. if (isset($params[0]) && is_array($params[0])) {
  278. foreach ($params as $item) {
  279. $list[] = buildRecords($item,$status_num);
  280. }
  281. } else {
  282. // 处理单条记录
  283. $list[] = buildRecords($params,$status_num);
  284. }
  285. $result = \db('设备_质量汇总')->insertAll($list);
  286. if ($result) {
  287. $this->success('数据插入成功 : ' . date('H:i:s'));
  288. } else {
  289. $this->error('数据插入失败');
  290. }
  291. }
  292. /**
  293. * 1.4质量管理左侧菜单栏查询
  294. */
  295. public function ApiMouthlist() {
  296. // 检查请求类型是否为GET
  297. if ($this->request->isGet() === false) {
  298. $this->error('请求错误');
  299. }
  300. $param = $this->request->param();
  301. // 查询符合条件的数据
  302. $list = \db('设备_质量汇总')
  303. ->where('状态', $param['code'])
  304. ->where('mod_rq', null)
  305. ->order('Sys_rq desc')
  306. ->group('Sys_rq')
  307. ->select();
  308. if (empty($list)) {
  309. $this->error('未查询到数据');
  310. }
  311. // 用于存储按年和月分类的数据
  312. $data = [];
  313. // 遍历查询结果,将日期按年、月分组
  314. foreach ($list as $item) {
  315. // 获取 Sys_rq 字段的值(日期)
  316. $sys_rq = $item['Sys_rq'];
  317. // 提取年、月、日
  318. $year = date('Y', strtotime($sys_rq));
  319. $month = date('Y-m', strtotime($sys_rq));
  320. $day = date('Y-m-d', strtotime($sys_rq));
  321. // 将数据按年、月、日分类
  322. if (!isset($data[$year])) {
  323. $data[$year] = [];
  324. }
  325. if (!isset($data[$year][$month])) {
  326. $data[$year][$month] = [];
  327. }
  328. // 将日期加入到对应的年、月下
  329. $data[$year][$month][] = $day;
  330. }
  331. $this->success('成功', $data);
  332. }
  333. /**
  334. * 1.5查询单据汇总次片、返工列表数据
  335. */
  336. public function ApiSubPieceAnd() {
  337. if ($this->request->isGet() === false) {
  338. $this->error('请求错误');
  339. }
  340. $params = $this->request->param();
  341. $where = ['mod_rq' => null];
  342. if (!empty($params['code'])) {
  343. $where['状态'] = $params['code'];
  344. }
  345. if (!empty($params['search'])) {
  346. $where['单据编号|订单编号|生产款号|面料名称|面料分类|颜色|问题分类|款式'] = ['like', '%' . $params['search'] . '%'];
  347. }
  348. // 处理日期查询(支持按天和按月)
  349. if (!empty($params['Sys_rq'])) {
  350. if (preg_match('/^\d{4}-\d{2}-\d{2}$/', $params['Sys_rq'])) {
  351. // 按天查询
  352. $where['Sys_rq'] = $params['Sys_rq'];
  353. } elseif (preg_match('/^\d{4}-\d{2}$/', $params['Sys_rq'])) {
  354. // 按月查询
  355. $where['Sys_rq'] = ['like', $params['Sys_rq'] . '%'];
  356. }elseif (preg_match('/^\d{4}$/', $params['Sys_rq'])) {
  357. // 按年查询
  358. //需要年份查询将代码屏蔽取消
  359. // $where['Sys_rq'] = $params['Sys_rq'];
  360. $this->success('成功', ['data' => '', 'total' => '']);
  361. }
  362. }
  363. $data = \db('设备_质量汇总')
  364. ->field('单据编号,订单编号,生产款号,面料名称,面料分类,问题分类,颜色,数量,款式,Sys_rq,尺码,组别')
  365. ->where($where)
  366. ->select();
  367. $mergedData = [];
  368. foreach ($data as $item) {
  369. //一条数据
  370. if (!isset($mergedData[$item['单据编号']])) {
  371. $mergedData[$item['单据编号']] = [
  372. '单据编号' => $item['单据编号'],
  373. '订单编号' => $item['订单编号'],
  374. '款式' => $item['款式'],
  375. '生产款号' => $item['生产款号'],
  376. '问题分类' => $item['问题分类'],
  377. '颜色' => $item['颜色'],
  378. '面料名称' => $item['面料名称'],
  379. '面料分类' => $item['面料分类'],
  380. '数量' => $item['数量'],
  381. '组别' => $item['组别'],
  382. '尺码' => $item['尺码'],
  383. 'Sys_rq' => $item['Sys_rq']
  384. ];
  385. } else {
  386. // 多条合并数据、数量进行累加
  387. $mergedData[$item['单据编号']]['问题分类'] = implode(',', array_unique(array_filter(array_merge(explode(',', $mergedData[$item['单据编号']]['问题分类']), [$item['问题分类']]))));
  388. $mergedData[$item['单据编号']]['颜色'] = implode(',', array_unique(array_filter(array_merge(explode(',', $mergedData[$item['单据编号']]['颜色']), [$item['颜色']]))));
  389. $mergedData[$item['单据编号']]['面料名称'] = implode(',', array_unique(array_filter(array_merge(explode(',', $mergedData[$item['单据编号']]['面料名称']), [$item['面料名称']]))));
  390. $mergedData[$item['单据编号']]['面料分类'] = implode(',', array_unique(array_filter(array_merge(explode(',', $mergedData[$item['单据编号']]['面料分类']), [$item['面料分类']]))));
  391. $mergedData[$item['单据编号']]['订单编号'] = implode(',', array_unique(array_filter(array_merge(explode(',', $mergedData[$item['单据编号']]['订单编号']), [$item['订单编号']]))));
  392. $mergedData[$item['单据编号']]['生产款号'] = implode(',', array_unique(array_filter(array_merge(explode(',', $mergedData[$item['单据编号']]['生产款号']), [$item['生产款号']]))));
  393. $mergedData[$item['单据编号']]['款式'] = implode(',', array_unique(array_filter(array_merge(explode(',', $mergedData[$item['单据编号']]['款式']), [$item['款式']]))));
  394. $mergedData[$item['单据编号']]['尺码'] = implode(',', array_unique(array_filter(array_merge(explode(',', $mergedData[$item['单据编号']]['尺码']), [$item['尺码']]))));
  395. $mergedData[$item['单据编号']]['组别'] = implode(',', array_unique(array_filter(array_merge(explode(',', $mergedData[$item['单据编号']]['组别']), [$item['组别']]))));
  396. $mergedData[$item['单据编号']]['数量'] += $item['数量'];
  397. }
  398. }
  399. $finalData = array_values($mergedData);
  400. $this->success('成功', ['data' => $finalData, 'total' => count($finalData)]);
  401. }
  402. /**
  403. * 1.6查询单据明细次片、返工列表数据
  404. */
  405. public function ApiSubPieceAndReworkList() {
  406. if ($this->request->isGet() === false) {
  407. $this->error('请求错误');
  408. }
  409. $params = $this->request->param();
  410. $where = ['mod_rq' => null];
  411. // 状态查询
  412. if (!empty($params['code'])) {
  413. $where['状态'] = $params['code'];
  414. }
  415. // 关键词模糊搜索
  416. if (!empty($params['search'])) {
  417. $where['单据编号|订单编号|生产款号|面料名称|面料分类|颜色|问题分类'] = ['like', '%' . $params['search'] . '%'];
  418. }
  419. // 处理日期查询(支持按天和按月)
  420. if (!empty($params['Sys_rq'])) {
  421. if (preg_match('/^\d{4}-\d{2}-\d{2}$/', $params['Sys_rq'])) {
  422. // 按天查询(2025-03-27)
  423. $where['Sys_rq'] = $params['Sys_rq'];
  424. } elseif (preg_match('/^\d{4}-\d{2}$/', $params['Sys_rq'])) {
  425. // 按月查询(2025-03),匹配该月的所有数据
  426. $where['Sys_rq'] = ['like', $params['Sys_rq'] . '%'];
  427. }
  428. }
  429. $res = \db('设备_质量汇总')
  430. ->where($where)
  431. ->limit(($params['page'] - 1) * $params['limit'], $params['limit'])
  432. ->select();
  433. $this->success('获取成功', ['data' => $res, 'total' => count($res)]);
  434. }
  435. /**
  436. * 查询获取问题分类
  437. */
  438. public function getProblemCategories() {
  439. if (!$this->request->isGet()) {
  440. $this->error('请求错误');
  441. }
  442. $params = $this->request->param();
  443. $where = ['mod_rq' => null]; // 仅查询未被删除的数据
  444. // 允许通过问题类型进行搜索
  445. if (!empty($params['search'])) {
  446. $where['问题类型'] = ['like', '%' . $params['search'] . '%'];
  447. }
  448. $data = \db('db_问题分类')->where($where)->order('update_time desc')->select();
  449. if (!$data) {
  450. $this->error('未查询到数据');
  451. }
  452. $this->success('获取成功', ['data' => $data, 'total' => count($data)]);
  453. }
  454. /**
  455. * 添加问题分类接口
  456. */
  457. public function addProblemCategory() {
  458. if (!$this->request->isPost()) {
  459. $this->error('非法请求');
  460. }
  461. $params = $this->request->param();
  462. if (empty($params['问题类型'])) {
  463. $this->error('问题类型不能为空');
  464. }
  465. $insertData = [
  466. '问题类型' => $params['问题类型'],
  467. 'sys_id' => $params['sys_id'],
  468. 'classification' => $params['classification'],
  469. 'Sys_rq' => date('Y-m-d H:i:s')
  470. ];
  471. $sql = \db('db_问题分类')
  472. ->fetchSql(true)
  473. ->insert($insertData);
  474. $res = \db()->query($sql);
  475. $this->success('添加成功');
  476. }
  477. /**
  478. * 删除问题分类接口
  479. */
  480. public function deleteProblemCategory() {
  481. if (!$this->request->isPost()) {
  482. $this->error('非法请求');
  483. }
  484. $params = $this->request->param();
  485. if (empty($params['id'])) {
  486. $this->error('ID 不能为空');
  487. }
  488. $updateData = [
  489. 'mod_rq' => date('Y-m-d H:i:s')
  490. ];
  491. $res = \db('db_问题分类')->where('id', $params['id'])->update($updateData);
  492. if ($res) {
  493. $this->success('删除成功');
  494. } else {
  495. $this->error('删除失败');
  496. }
  497. }
  498. /**
  499. * 机台设备查询
  500. */
  501. public function getMachineDeviceTypes(){
  502. $res = \db('设备_基本资料')
  503. ->where('mod_rq', null)
  504. ->select();
  505. $this->success('成功', [
  506. 'list' => $res,
  507. ]);
  508. }
  509. /**
  510. * 更新机台设备
  511. */
  512. public function updateMachineDeviceTypes() {
  513. if (!$this->request->isPost()) {
  514. $this->error('非法请求');
  515. }
  516. $params = $this->request->param();
  517. if (empty($params['UniqId'])) {
  518. $this->error('UniqId 参数不能为空');
  519. }
  520. $deviceData = [
  521. // 'sys_sbID' => $params['sys_sbID'],
  522. // '工序' => $params['工序'],
  523. // '设备编号' => $params['设备编号'],
  524. // '生产工序' => $params['生产工序'],
  525. // '设备编组' => $params['设备编组'],
  526. // '组长' => $params['组长'],
  527. 'status' => $params['status'],
  528. ];
  529. $result = \db('设备_基本资料')
  530. ->where('UniqId', $params['UniqId'])
  531. ->where('mod_rq', null)
  532. ->update($deviceData);
  533. if ($result) {
  534. $this->success('设备更新成功');
  535. } else {
  536. $this->error('设备更新失败');
  537. }
  538. }
  539. /**
  540. * 新增机台设备
  541. */
  542. public function addMachineDeviceTypes() {
  543. if (!$this->request->isPost()) {
  544. $this->error('非法请求');
  545. }
  546. $params = $this->request->param();
  547. // 生产工序与工序号的映射
  548. $processMapping = [
  549. '裁剪' => 2,
  550. '车缝' => 3,
  551. '手工' => 4,
  552. '总检' => 6,
  553. '大烫' => 5,
  554. '包装' => 7,
  555. ];
  556. $productionProcess = $params['生产工序'] ?? '';
  557. $UniqId = \db('设备_基本资料')
  558. ->field('UniqId')
  559. ->order('UniqId desc')
  560. ->find();
  561. // 新的设备数据
  562. $deviceData = [
  563. 'UniqId' => $UniqId['UniqId'] + 1,
  564. 'sys_sbID' => $params['sys_sbID'],
  565. '工序' => $processMapping[$productionProcess],
  566. '设备编号' => $params['设备编号'],
  567. '生产工序' => $params['生产工序'],
  568. '设备编组' => $params['设备编组'],
  569. '组长' => $params['组长'],
  570. 'sys_id' => $params['sys_id'],
  571. 'sys_rq' => date('Y-m-d H:i:s'),
  572. 'status' => 1,
  573. ];
  574. $result = \db('设备_基本资料')->fetchSql(true)
  575. ->insert($deviceData);
  576. $list_gd = \db()->query($result);
  577. if ($result) {
  578. $this->success('设备新增成功');
  579. } else {
  580. $this->error('设备新增失败');
  581. }
  582. }
  583. /**
  584. * 订单状态更新
  585. */
  586. public function Apigdstatus() {
  587. if (!$this->request->isPost()) {
  588. $this->error('非法请求');
  589. }
  590. $params = $this->request->param();
  591. $uniqids = explode(',', $params['Uniqid']);
  592. // 判断gd_statu是否为“3-已完工”,只判断一次
  593. $isFinished = $params['gd_statu'] == '3-已完工';
  594. foreach ($uniqids as $uniqid) {
  595. $uniqid = trim($uniqid);
  596. $updateData = [
  597. 'gd_statu' => $params['gd_statu']
  598. ];
  599. // 如果是“已完工”,加上完工日期
  600. if ($isFinished) {
  601. $updateData['工单完工日期'] = date('Y-m-d H:i:s');
  602. } else {
  603. // 如果不是已完工,清空完工日期
  604. $updateData['工单完工日期'] = null;
  605. }
  606. $ReportSql = \db('工单_基本资料')->where('Uniqid', $uniqid)->fetchSql(true)->update($updateData);
  607. \db()->query($ReportSql);
  608. }
  609. $this->success('订单状态更新成功');
  610. }
  611. /**
  612. * 产品BOM资料
  613. */
  614. public function Apibomlistarr(){
  615. if ($this->request->isGet() === false) {
  616. $this->error('请求错误');
  617. }
  618. $param = $this->request->param();
  619. $page = isset($param['page']) ? (int)$param['page'] : 1; // 默认第1页
  620. $limit = isset($param['limit']) ? (int)$param['limit'] : 50; // 默认每页50条
  621. $bomlist = Db::name('工单_bom资料')
  622. ->alias('a')
  623. ->field('
  624. a.BOM_工单编号 as 订单编号,
  625. a.BOM_desc as 备注,
  626. a.BOM_库存总量 as 库存总量,
  627. a.BOM_面料结余 as 面料结余,
  628. a.BOM_实际门幅 as 实际门幅,
  629. a.BOM_物料编码 as 物料编码,
  630. a.BOM_物料名称 as 物料名称,
  631. a.BOM_投料单位 as 投料单位,
  632. a.BOM_标准用量 as 定额用料,
  633. a.BOM_计划用量 as 计划用料,
  634. a.BOM_实际用量 as 标准用料,
  635. a.Bom_领用数量 as 领用数量,
  636. a.BOM_退还数量 as 退还数量,
  637. a.BOM_退还数量 as 退还数量,
  638. a.Sys_ID,
  639. a.Sys_rq,
  640. a.UNIQID,
  641. a.物料分类 as 物料分类,
  642. a.BOM_计划门幅 as 计划门幅,
  643. a.BOM_定额门幅 as 定额门幅,
  644. b.生产款号,
  645. b.客户编号,
  646. b.款式
  647. ')
  648. ->join('工单_基本资料 b', 'a.BOM_工单编号 = b.订单编号', 'left') // 多条件关联
  649. ->where('a.BOM_工单编号|a.BOM_物料编码|a.BOM_物料名称|a.物料分类|b.生产款号|b.款式|b.客户编号', 'like', "{$param['search']}%")
  650. ->order('a.BOM_工单编号 desc')
  651. ->where('a.Mod_rq',null)
  652. ->limit(($page - 1) * $limit, $limit)
  653. ->select();
  654. // 处理数据,去掉计划用料字段的小数点后多余的0
  655. foreach ($bomlist as &$item) {
  656. // 转换为浮点数,去掉无意义的 0
  657. $item['计划用料'] = floatval($item['计划用料']);
  658. }
  659. // 解除引用,防止意外修改
  660. unset($item);
  661. //统计总数量
  662. $count = Db::name('工单_bom资料')
  663. ->where('Mod_rq',null)
  664. ->count();
  665. $data['total'] = $count;
  666. $data['list'] = $bomlist;
  667. $this->success('成功',$data);
  668. }
  669. }