sampleConfirmationJS.js 38 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607
  1. import repostCurd from '@/business/platform/form/utils/custom/joinCURD.js'
  2. import * as dayjs from 'dayjs'
  3. const options = {
  4. '一个月': 1,
  5. '两个月': 2,
  6. '三个月': 3,
  7. '四个月': 4,
  8. '半年': 6,
  9. '九个月': 9,
  10. '一年': 12
  11. }
  12. export default {
  13. methods: {
  14. /* 唤醒扫码 前端脚本直接调用*/
  15. openRedar(type) {
  16. this.redar = true // 扫码图标显示
  17. this.visible = false // 结果列表,一开始为false
  18. this.$refs.redarInput.focus(); // 聚焦input
  19. this.listData = [] // 清空列表
  20. },
  21. facilityData(id) {
  22. if (!id) return // 无参直接反
  23. this.loadData(id)
  24. //开始查询设备
  25. this.facilityId = ''
  26. },
  27. /* 获取数据 ,开始查阅记录 */
  28. loadData(id) {
  29. let flag = true // 重复扫码标志位
  30. for (let index in this.listData) { // 判断是否重复,重复扫码 数量自增
  31. if (this.listData[index].yang_pin_bian_hao == id) {
  32. this.listData[index].jie_yang_shu_lian = parseInt(this.listData[index].jie_yang_shu_lian) + 1
  33. flag = false
  34. }
  35. }
  36. let sql = `select lei_xing_ from t_yplxb`
  37. let sql2 = `select yang_pin_gui_ge_ from t_ypbzggb`
  38. Promise.all([repostCurd('sql',sql),repostCurd('sql',sql2)]).then(([res1,res2]) =>{
  39. let data = res1.variables.data
  40. let data2 = res2.variables.data
  41. let types = []
  42. let guiGes = []
  43. data.forEach(item=>{
  44. let obj = {
  45. value:item.lei_xing_,
  46. label:item.lei_xing_
  47. }
  48. types.push(obj)
  49. })
  50. data2.forEach(item=>{
  51. let o = {
  52. value:item.yang_pin_gui_ge_,
  53. label:item.yang_pin_gui_ge_
  54. }
  55. guiGes.push(o)
  56. })
  57. this.sampleTypes = types
  58. this.sampleSpecifications = guiGes
  59. })
  60. // 扫码扫到新数据,查询 回填展示
  61. if (flag) {
  62. let sql = `select ypb.*,sqb.chu_ju_bao_gao_ya from t_lhypb ypb join t_lhwtsqb sqb on ypb.parent_id_ = sqb.id_ and find_in_set(ypb.yang_pin_bian_hao,'${id}') and ypb.jie_yang_zhuang_t = '待接收' and ypb.shi_fou_guo_shen_ = '1'`
  63. let liuYangSQL = `select liu_yang_qi_xian_ from t_lyqxpzb limit 1`
  64. let cfIDSQL = `select cun_fang_id_,liu_yang_id_ FROM t_ypwzmrxzb`
  65. Promise.all([repostCurd('sql', sql), repostCurd('sql', liuYangSQL),repostCurd('sql',cfIDSQL)]).then((res) => {
  66. let temp = res[0].variables.data
  67. let option = res[1].variables.data[0].liu_yang_qi_xian_
  68. let cfID = res[2].variables.data[0].cun_fang_id_
  69. let lyID = res[2].variables.data[0].liu_yang_id_
  70. let rq = options[option]
  71. if (temp) {
  72. temp.forEach(item => {
  73. item.jie_yang_shu_lian = item.yang_pin_zong_shu
  74. item.jie_yang_zhuang_t = '已确认'
  75. item.biao_zhi_uuid_1 = this.uuid()
  76. item.biao_zhi_uuid_2 = this.uuid()
  77. item.biao_zhi_uuid_3 = this.uuid()
  78. item.biao_zhi_uuid_4 = this.uuid()
  79. item.shi_fou_liu_yang_ = '是'
  80. item.yan_shou_jie_guo_ = '完好'
  81. item.liu_yang_shu_lian_yi = ' ml/支×1支'
  82. item.shou_yang_wei_zhi_yi = cfID
  83. item.liu_yang_wei_zhi_yi = lyID
  84. item.yang_pin_lei_er_ ?
  85. (item.liu_yang_shu_lian_er = ' ml/支×1支' ,item.shou_yang_wei_zhi_er = cfID,item.liu_yang_wei_zhi_er = lyID) : null
  86. item.yang_pin_lei_san_ ?
  87. (item.liu_yang_shu_lian_san = ' ml/支×1支',item.shou_yang_wei_zhi_san = cfID,item.liu_yang_wei_zhi_san = lyID) : null
  88. item.yang_pin_lei_si_ ?
  89. (item.liu_yang_shu_lian_si = ' ml/支×1支',item.shou_yang_wei_zhi_si = cfID,item.liu_yang_wei_zhi_si = lyID) : null
  90. // item.yang_pin_lei_er_ ? item.liu_yang_shu_lian_er = ' ml/支×1支' : null
  91. // item.yang_pin_lei_san_ ? item.liu_yang_shu_lian_san = ' ml/支×1支' : null
  92. // item.yang_pin_lei_si_ ? item.liu_yang_shu_lian_si = ' ml/支×1支' : null
  93. item.liu_yang_ri_qi_ = new Date(new Date().getTime() + 28800000).toJSON().slice(0, 10).replace('T', ' ')
  94. item.yang_pin_lei_er_ ? this.$set(item, 'flag2', true) : this.$set(item, 'flag2', false)
  95. item.yang_pin_lei_san_ ? this.$set(item, 'flag3', true) : this.$set(item, 'flag3', false)
  96. item.yang_pin_lei_si_ ? this.$set(item, 'flag4', true) : this.$set(item, 'flag4', false)
  97. item.liu_yang_qi_xian = dayjs(item.song_jian_shi_jia).add(rq, 'month').format("YYYY-MM-DD")
  98. })
  99. this.listData.push(temp[0])
  100. // console.log(this.listData)
  101. }
  102. })
  103. }
  104. },
  105. /* 列表失去焦点*/
  106. handleChange() {
  107. this.$refs.redarInput.focus(); //聚焦input
  108. },
  109. /* 关闭弹出列表框*/
  110. closeDialog() {
  111. this.remRedar()
  112. //回传关闭事件。隐藏当前组件。
  113. },
  114. handleClose() {
  115. this.handleChange()
  116. this.$confirm('确认关闭扫码列表页面?').then(_ => {
  117. this.closeDialog();
  118. }).catch(_ => {});
  119. },
  120. handleAnySituation(callBackBool,msg,type){
  121. this.$emit('callback', callBackBool)
  122. this.visable = false
  123. this.$message({
  124. message: msg,
  125. type: type
  126. })
  127. this.closeDialog();
  128. },
  129. submitData(type) {
  130. // this指针
  131. let this_ = this;
  132. // 回传关闭事件。隐藏当前组件。
  133. let judge = true;
  134. if (this_.listData.length == 0) {
  135. this.$emit('callback', true)
  136. this.visable = false
  137. this.$message({
  138. message: '暂无样品待接收确认!',
  139. type: 'error'
  140. })
  141. this.closeDialog();
  142. } else {
  143. this.$confirm('请再次确认 [样品接收信息]').then(_ => {
  144. // 获取样品列表
  145. let ypInfoList = this_.listData
  146. // console.log(ypInfoList, "样品信息")
  147. let dWhere = []
  148. let ypbh = []
  149. let ypbhList = [] // 样品编号列表
  150. // 罗湖样品编号列表
  151. let lhypbhList = []
  152. let lhypmcList = []
  153. // 罗湖样品表外键
  154. let lhypbWJ = []
  155. // 罗湖委托表主键
  156. let lhwtbID = []
  157. // 罗湖委托表展示表ID
  158. let lhwtzsbID = []
  159. // 罗湖样品id列表
  160. let lhypIdList = []
  161. // 罗湖样品id格式列表
  162. let lhypIdNewList = []
  163. // 样品所选择的位置ID字符串
  164. let localStr = ''
  165. let locationIds = new Set()
  166. let localArr = []
  167. let sampleList = []
  168. for (let yp in ypInfoList) { //样品数据
  169. let cfwz = ''
  170. /*
  171. 校验:
  172. 1、样品数量 <= 确认数量
  173. 2、是否留样 => 填收样位置|留样位置
  174. 3、验收结果必填
  175. 4、如果留样 => 必填项:留样日期、留样数量、留样期限至、销毁日期
  176. */
  177. if (ypInfoList[yp].jie_yang_shu_lian > ypInfoList[yp].yang_pin_zong_shu) {
  178. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 接收确认数量不得大于收样数量。')
  179. return;
  180. }
  181. if (ypInfoList[yp].jie_yang_zhuang_t == '未确认') {
  182. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 接收确认状态必须为已确认。')
  183. return;
  184. }
  185. if (ypInfoList[yp].yan_shou_jie_guo_ == null || ypInfoList[yp].yan_shou_jie_guo_ == '') {
  186. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 验收结果不能为空!')
  187. return;
  188. }
  189. if (ypInfoList[yp].shi_fou_liu_yang_ == null || ypInfoList[yp].shi_fou_liu_yang_ == '') {
  190. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 是否留样不能为空!')
  191. return;
  192. }
  193. if (ypInfoList[yp].shi_fou_liu_yang_ == "是") {
  194. if (ypInfoList[yp].liu_yang_ri_qi_ == null || ypInfoList[yp].liu_yang_ri_qi_ == '') {
  195. this_.$message.error("留样时必须填写留样日期!")
  196. return;
  197. }
  198. // 判断位置是否为空
  199. if (ypInfoList[yp].liu_yang_wei_zhi_yi == null || ypInfoList[yp].liu_yang_wei_zhi_yi == '') {
  200. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型1的留样位置选择不能为空!')
  201. return;
  202. }
  203. if (ypInfoList[yp].flag2 == true && (ypInfoList[yp].liu_yang_wei_zhi_er == '' || ypInfoList[yp].liu_yang_wei_zhi_er == null)) {
  204. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型2的留样位置选择不能为空!')
  205. return;
  206. }
  207. if (ypInfoList[yp].flag3 == true && (ypInfoList[yp].liu_yang_wei_zhi_san == '' || ypInfoList[yp].liu_yang_wei_zhi_san == null)) {
  208. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型3的留样位置选择不能为空!')
  209. return;
  210. }
  211. if (ypInfoList[yp].flag4 == true && (ypInfoList[yp].liu_yang_wei_zhi_si == '' || ypInfoList[yp].liu_yang_wei_zhi_si == null)) {
  212. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型4的留样位置选择不能为空!')
  213. return;
  214. }
  215. }
  216. // 判断位置是否为空
  217. if (ypInfoList[yp].shou_yang_wei_zhi_yi == null || ypInfoList[yp].shou_yang_wei_zhi_yi == '') {
  218. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型1的位置选择不能为空!')
  219. return;
  220. }
  221. if (ypInfoList[yp].flag2 == true && (ypInfoList[yp].shou_yang_wei_zhi_er == '' || ypInfoList[yp].shou_yang_wei_zhi_er == null)) {
  222. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型2的位置选择不能为空!')
  223. return;
  224. }
  225. if (ypInfoList[yp].flag3 == true && (ypInfoList[yp].shou_yang_wei_zhi_san == '' || ypInfoList[yp].shou_yang_wei_zhi_san == null)) {
  226. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型3的位置选择不能为空!')
  227. return;
  228. }
  229. if (ypInfoList[yp].flag4 == true && (ypInfoList[yp].shou_yang_wei_zhi_si == '' || ypInfoList[yp].shou_yang_wei_zhi_si == null)) {
  230. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型4的位置选择不能为空!')
  231. return;
  232. }
  233. ypbhList.push('{"yang_pin_bian_hao":"' + ypInfoList[yp].yang_pin_bian_hao + '"}') // 样品编号列表
  234. // 罗湖
  235. dWhere.push('{"id_":"' + cfwz + '"}')
  236. lhypbhList.push(ypInfoList[yp].yang_pin_bian_hao)
  237. lhypbWJ.push(ypInfoList[yp].parent_id_)
  238. lhypIdList.push(ypInfoList[yp].id_)
  239. lhypIdNewList.push('{"id_":"' + ypInfoList[yp].id_ + '"}')
  240. ypbh.push(ypInfoList[yp].yang_pin_bian_hao)
  241. lhypmcList.push(ypInfoList[yp].yang_pin_ming_che)
  242. localArr.push(
  243. ypInfoList[yp].shou_yang_wei_zhi_yi, ypInfoList[yp].liu_yang_wei_zhi_yi,
  244. ypInfoList[yp].shou_yang_wei_zhi_er, ypInfoList[yp].liu_yang_wei_zhi_er,
  245. ypInfoList[yp].shou_yang_wei_zhi_san, ypInfoList[yp].liu_yang_wei_zhi_san,
  246. ypInfoList[yp].shou_yang_wei_zhi_si, ypInfoList[yp].liu_yang_wei_zhi_si
  247. )
  248. let o = {
  249. where:{
  250. id_ : ypInfoList[yp].id_
  251. },
  252. param:{
  253. yang_pin_lei_xing: ypInfoList[yp].yang_pin_lei_xing,
  254. yang_ben_yun_shu_: ypInfoList[yp].yang_ben_yun_shu_,
  255. shu_liang_: ypInfoList[yp].shu_liang_,
  256. yang_pin_gui_ge_: ypInfoList[yp].yang_pin_gui_ge_,
  257. yang_pin_lei_er_: ypInfoList[yp].yang_pin_lei_er_,
  258. yang_pin_yun_shu_: ypInfoList[yp].yang_pin_yun_shu_,
  259. shu_liang_er_: ypInfoList[yp].shu_liang_er_,
  260. yang_pin_gui_ge_e: ypInfoList[yp].yang_pin_gui_ge_e,
  261. yang_pin_lei_san_: ypInfoList[yp].yang_pin_lei_san_,
  262. yang_pin_yun_san: ypInfoList[yp].yang_pin_yun_san,
  263. shu_liang_san_: ypInfoList[yp].shu_liang_san_,
  264. yang_pin_gui_ge_s: ypInfoList[yp].yang_pin_gui_ge_s,
  265. yang_pin_lei_si_: ypInfoList[yp].yang_pin_lei_si_,
  266. yang_pin_yun_si_: ypInfoList[yp].yang_pin_yun_si_,
  267. shu_liang_si_: ypInfoList[yp].shu_liang_si_,
  268. yang_pin_gui_si_: ypInfoList[yp].yang_pin_gui_si_,
  269. jie_yang_zhuang_t:"已接收",
  270. yang_pin_zong_shu:ypInfoList[yp].yang_pin_zong_shu
  271. }
  272. }
  273. sampleList.push(o)
  274. }
  275. localStr = localArr.filter(i => i).join(',')
  276. let value = ''
  277. let lhypIdStr = ''
  278. for (let i = 0; i < lhypbWJ.length; i++) {
  279. value += lhypbWJ[i] + ','
  280. }
  281. value = value.substring(0, value.length - 1)
  282. value = value.replace(/,/g, "','")
  283. for (let i = 0; i < lhypIdList.length; i++) {
  284. lhypIdStr += lhypIdList[i] + ','
  285. }
  286. lhypIdStr = lhypIdStr.substring(0, lhypIdStr.length - 1)
  287. lhypIdStr = lhypIdStr.replace(/,/g, "','")
  288. let currentTime = new Date(new Date().getTime() + 28800000).toJSON().slice(0, 16).replace('T', ' ')
  289. let allSQL = `select a.id_ as wtID,a.chu_ju_bao_gao_ya,a.zhan_shi_biao_id_,a.wei_tuo_lei_xing_,a.he_tong_id_,a.bao_gao_lei_xing_,a.wei_tuo_bian_hao_, a.wei_tuo_dan_wei_ as wtdh, a.wei_tuo_fang_lian, a.wei_tuo_lian,a.bao_gao_bian_zhi_,a.bao_gao_fu_he_yua,b.* from t_lhwtsqb a inner join t_lhypb b on a.id_ = b.parent_id_ where b.parent_id_ in ('${value}')and b.id_ in ('${lhypIdStr}')`
  290. // 搜集所有选择的位置信息
  291. // console.log('当前选择的位置ids:',locationIds)
  292. var allLocal = `select * from t_ypcfwz where find_in_set(id_,'${localStr}')`
  293. Promise.all([repostCurd("sql", allSQL), repostCurd("sql", allLocal)]).then((res) => {
  294. let result = res[0].variables.data
  295. let localInfo = res[1].variables.data
  296. // todo
  297. // console.log(localInfo)
  298. /* 1、更新货架位置信息 */
  299. this.emptyLocal = []
  300. this.fullLocal = []
  301. let allUUID = []
  302. ypInfoList.forEach(item => {
  303. allUUID.push(item.biao_zhi_uuid_1, item.biao_zhi_uuid_2, item.biao_zhi_uuid_3, item.biao_zhi_uuid_4)
  304. let allResult = []
  305. allResult.push(this.handleLocationInfo(item.shou_yang_wei_zhi_yi, '否', localInfo, locationIds, item, item.biao_zhi_uuid_1, currentTime))
  306. if (item.shou_yang_wei_zhi_er != undefined) {
  307. allResult.push(this.handleLocationInfo(item.shou_yang_wei_zhi_er, '否', localInfo, locationIds, item, item.biao_zhi_uuid_2, currentTime))
  308. }
  309. if (item.shou_yang_wei_zhi_san != undefined) {
  310. allResult.push(this.handleLocationInfo(item.shou_yang_wei_zhi_san, '否', localInfo, locationIds, item, item.biao_zhi_uuid_3, currentTime))
  311. }
  312. if (item.shou_yang_wei_zhi_si != undefined) {
  313. allResult.push(this.handleLocationInfo(item.shou_yang_wei_zhi_si, '否', localInfo, locationIds, item, item.biao_zhi_uuid_4, currentTime))
  314. }
  315. allResult.push(this.handleLocationInfo(item.liu_yang_wei_zhi_yi, '是', localInfo, locationIds, item, item.biao_zhi_uuid_1, currentTime))
  316. if (item.liu_yang_wei_zhi_er != undefined) {
  317. allResult.push(this.handleLocationInfo(item.liu_yang_wei_zhi_er, '是', localInfo, locationIds, item, item.biao_zhi_uuid_2, currentTime))
  318. }
  319. if (item.liu_yang_wei_zhi_san != undefined) {
  320. allResult.push(this.handleLocationInfo(item.liu_yang_wei_zhi_san, '是', localInfo, locationIds, item, item.biao_zhi_uuid_3, currentTime))
  321. }
  322. if (item.liu_yang_wei_zhi_si != undefined) {
  323. allResult.push(this.handleLocationInfo(item.liu_yang_wei_zhi_si, '是', localInfo, locationIds, item, item.biao_zhi_uuid_4, currentTime))
  324. }
  325. allResult.forEach(item => {
  326. item.name === 'emptyLocation' ? this.emptyLocal.push(item.value) : this.fullLocal.push(item.value)
  327. })
  328. })
  329. let allUUIDStr = allUUID.filter(i => i).join(',')
  330. // console.log(allUUIDStr)
  331. // 更新样品位置list
  332. // console.log('emptyLocal:',this.emptyLocal)
  333. let allParams = {
  334. tableName: 't_ypcfwz',
  335. updList: this.emptyLocal
  336. }
  337. repostCurd('updatesByWhere', JSON.stringify(allParams))
  338. // 插入样品位置list
  339. // console.log('fullLocal:',this.fullLocal)
  340. repostCurd('add', '{"tableName":"t_ypcfwz","paramWhere":' + JSON.stringify(this.fullLocal) + '}').then(res => {
  341. // 再次查询位置表,对比当前样品列表 替换初始值为占用的样品位置id
  342. let findLocationAgain = `select id_,shi_fou_liu_yang_,biao_zhi_uuid_ from t_ypcfwz where find_in_set(biao_zhi_uuid_,'${allUUIDStr}')`
  343. // console.log(findLocationAgain)
  344. repostCurd('sql', findLocationAgain).then(res => {
  345. let data = res.variables.data
  346. let uuidArgs = ['biao_zhi_uuid_1', 'biao_zhi_uuid_2', 'biao_zhi_uuid_3', 'biao_zhi_uuid_4']
  347. let shouYangArgs = ['shou_yang_wei_zhi_yi', 'shou_yang_wei_zhi_er', 'shou_yang_wei_zhi_san', 'shou_yang_wei_zhi_si']
  348. let liuYangArgs = ['liu_yang_wei_zhi_yi', 'liu_yang_wei_zhi_er', 'liu_yang_wei_zhi_san', 'liu_yang_wei_zhi_si']
  349. data.forEach(item => {
  350. uuidArgs.forEach((uuid, index) => {
  351. let ypIndex = ypInfoList.findIndex(i => i[uuid] === item.biao_zhi_uuid_)
  352. if (ypIndex != -1) {
  353. item.shi_fou_liu_yang_ === '否' ?
  354. ypInfoList[ypIndex][shouYangArgs[index]] = item.id_ :
  355. ypInfoList[ypIndex][liuYangArgs[index]] = item.id_
  356. }
  357. })
  358. })
  359. // repostCurd('updates', '{"tableName":"t_lhypb","paramWhere":[' + lhypIdNewList + '],"paramCond":{"jie_yang_zhuang_t":"已接收"}}')
  360. /* 2、封装样品登记表对象,插入样品登记表 顺便封装任务分配表 */
  361. let ypdjb = []
  362. let rws = []
  363. result.forEach((item, index) => {
  364. // 2-1:统计每个样品有多少类型[数量]
  365. let lxList = []
  366. let ypggList = []
  367. let liuYangList = []
  368. lxList.push(ypInfoList[index].yang_pin_lei_xing, ypInfoList[index].yang_pin_lei_er_, ypInfoList[index].yang_pin_lei_san_, ypInfoList[index].yang_pin_lei_si_)
  369. ypggList.push(ypInfoList[index].yang_pin_gui_ge_, ypInfoList[index].yang_pin_gui_ge_e, ypInfoList[index].yang_pin_gui_ge_s, ypInfoList[index].yang_pin_gui_si_)
  370. liuYangList.push(ypInfoList[index].liu_yang_shu_lian_yi, ypInfoList[index].liu_yang_shu_lian_er, ypInfoList[index].liu_yang_shu_lian_san, ypInfoList[index].liu_yang_shu_lian_si)
  371. let yplxz = lxList.filter(i => i).join(';')
  372. let ypggStr = ypggList.filter(i => i).join(';')
  373. let liuyangStr = liuYangList.filter(i => i).join(';')
  374. // let count = lxList.filter(i => i).join(',').match(/,/g).length + 1
  375. let size = lxList.filter(i => i).join(',').match(/,/g)
  376. let count = 1
  377. size == null ? count = 1 : count = size.length + 1
  378. for (let c = 0; c < count; c++) {
  379. let xmmc = []
  380. xmmc.push(item.chang_gui_xiang_m, item.tao_can_ming_chen)
  381. let xiangMuZh = xmmc.filter(i => i).join(',')
  382. let yblx = c == 0 ? ypInfoList[index].yang_pin_lei_xing : c == 1 ? ypInfoList[index].yang_pin_lei_er_ : c == 2 ? ypInfoList[index].yang_pin_lei_san_ : c == 3 ? ypInfoList[index].yang_pin_lei_si_ : ''
  383. let ystj = c == 0 ? ypInfoList[index].yang_ben_yun_shu_ : c == 1 ? ypInfoList[index].yang_pin_yun_shu_ : c == 2 ? ypInfoList[index].yang_pin_yun_san : c == 3 ? ypInfoList[index].yang_pin_yun_si_ : ''
  384. let ypsl = c == 0 ? ypInfoList[index].shu_liang_ : c == 1 ? ypInfoList[index].shu_liang_er_ : c == 2 ? ypInfoList[index].shu_liang_san_ : c == 3 ? ypInfoList[index].shu_liang_si_ : ''
  385. let ybgg = c == 0 ? ypInfoList[index].yang_pin_gui_ge_ : c == 1 ? ypInfoList[index].yang_pin_gui_ge_e : c == 2 ? ypInfoList[index].yang_pin_gui_ge_s : c == 3 ? ypInfoList[index].yang_pin_gui_si_ : ''
  386. let sywz = c == 0 ? ypInfoList[index].shou_yang_wei_zhi_yi : c == 1 ? ypInfoList[index].shou_yang_wei_zhi_er : c == 2 ? ypInfoList[index].shou_yang_wei_zhi_san : c == 3 ? ypInfoList[index].shou_yang_wei_zhi_si : ''
  387. let lycf = c == 0 ? ypInfoList[index].liu_yang_wei_zhi_yi : c == 1 ? ypInfoList[index].liu_yang_wei_zhi_er : c == 2 ? ypInfoList[index].liu_yang_wei_zhi_san : c == 3 ? ypInfoList[index].liu_yang_wei_zhi_si : ''
  388. let lysl = c == 0 ? ypInfoList[index].liu_yang_shu_lian_yi : c == 1 ? ypInfoList[index].liu_yang_shu_lian_er : c == 2 ? ypInfoList[index].liu_yang_shu_lian_san : c == 3 ? ypInfoList[index].liu_yang_shu_lian_si : ''
  389. let currentUUID = c == 0 ? ypInfoList[index].biao_zhi_uuid_1 : c == 1 ? ypInfoList[index].biao_zhi_uuid_2 : c == 2 ? ypInfoList[index].biao_zhi_uuid_3 : c == 3 ? ypInfoList[index].biao_zhi_uuid_4 : ''
  390. let obj = {
  391. wei_tuo_dan_hao_: item.wei_tuo_bian_hao_,
  392. wei_tuo_dan_wei_: item.wtdh,
  393. lian_xi_ren_: item.wei_tuo_fang_lian,
  394. lian_xi_dian_hua_: item.wei_tuo_lian,
  395. yang_ben_ming_che: item.yang_pin_ming_che,
  396. yang_ben_bian_hao: item.yang_pin_bian_hao,
  397. pi_hao_bian_hao_: item.song_jian_pi_hao_,
  398. song_jian_dan_wei: item.song_jian_dan_wei,
  399. xing_ming_: ypInfoList[index].xing_ming_,
  400. xing_bie_: ypInfoList[index].xing_bie_,
  401. nian_ling_: ypInfoList[index].nian_ling_,
  402. yang_ben_zhuang_t: item.yang_pin_zhuang_t,
  403. shou_yang_ri_qi_: currentTime,
  404. bei_zhu_: ypInfoList[index].bei_zhu_,
  405. yang_ben_lei_xing: yblx,
  406. yun_shu_tiao_jian: ystj,
  407. yang_pin_shu_lian: ypsl,
  408. yang_ben_gui_ge_s: ybgg,
  409. yan_shou_jie_guo_: ypInfoList[index].yan_shou_jie_guo_,
  410. cun_fang_wei_zhi_: sywz,
  411. liu_zhuan_zhuang_: '待任务分配',
  412. shi_fou_liu_yang_: ypInfoList[index].shi_fou_liu_yang_,
  413. liu_yang_ri_qi_: ypInfoList[index].liu_yang_ri_qi_,
  414. liu_yang_cun_fang: lycf,
  415. liu_yang_shu_lian: lysl,
  416. liu_yang_qi_xian: ypInfoList[index].liu_yang_qi_xian,
  417. xiao_hui_ri_qi_: ypInfoList[index].xiao_hui_ri_qi_,
  418. fan_yang_ri_qi_: ypInfoList[index].fan_yang_ri_qi_,
  419. fan_yang_jyr: ypInfoList[index].fan_yang_jyr,
  420. biao_zhi_uuid_: currentUUID,
  421. song_yang_yao_qiu: ypInfoList[index].song_yang_yao_qiu,
  422. jian_ce_xiang_mu_: xiangMuZh,
  423. shou_yang_ren_:this.$store.getters.userInfo.user.name
  424. }
  425. ypdjb.push(obj)
  426. }
  427. // 2-2:封装任务分配表
  428. let rw = {
  429. yang_pin_ming_che: item.yang_pin_ming_che,
  430. yang_pin_bian_hao: item.yang_pin_bian_hao,
  431. wei_tuo_lei_xing_: item.wei_tuo_lei_xing_,
  432. yang_pin_lei_xing: yplxz,
  433. yang_pin_gui_ge_: ypggStr,
  434. wei_tuo_id_: item.wtID,
  435. he_tong_id_: item.he_tong_id_,
  436. zhuang_tai_: '待任务分配',
  437. wan_cheng_shi_jia: item.song_jian_shi_jia,
  438. bao_gao_lei_xing_: item.bao_gao_lei_xing_,
  439. xin_xiang_mu_ming: item.xiang_mu_ming_che,
  440. zhan_shi_biao_id_: item.zhan_shi_biao_id_,
  441. fen_zhuang_liu_ya: liuyangStr,
  442. shi_fou_jia_ji_: item.chu_ju_bao_gao_ya, // 是否加急【2023/2/23王嘎嘎提出】
  443. yang_pin_shu_lian: ypInfoList[index].jie_yang_shu_lian // 样品确认总数【2023/3/7王嘎嘎提出】
  444. }
  445. rws.push(rw)
  446. lhwtzsbID.push('{"shen_qing_id_":"' + item.zhan_shi_biao_id_ + '"}')
  447. lhwtbID.push('{"id_":"' + item.wtID + '"}')
  448. })
  449. /* 4、任务分配
  450. 4-1、根据 wtdAndYpb 的 wtID 更改委托表的 委托状态 wei_tuo_zhuang_ta 变成 已完成
  451. 4-2、根据每个样品一个任务分配流程 遍历样品表开任务分配流程
  452. 4-3、委托表找zhan_shi_biao_id_ 修改 t_lhwtzsb "zhuang_tai_"为"任务分配进行中"
  453. 优化:将其他不冲突的更改状态脚本放在任务分配后并行处理
  454. */
  455. // console.log("4、任务分配",rws)
  456. repostCurd('add', '{"tableName":"t_lhrwfpb","paramWhere":' + JSON.stringify(rws) + ',"defKey":"Process_04o0csc","formKey":"lhrwfp"}').then(res=>{
  457. // console.log('4、更改委托表的 委托状态',lhwtbID)
  458. repostCurd('updates', '{"tableName":"t_lhwtsqb","paramWhere":[' + lhwtbID + '],"paramCond":{"wei_tuo_zhuang_ta":"已完成"}}')
  459. /* 5、更新展示表 */
  460. if (lhwtzsbID.length > 0) {
  461. // console.log('5、更新展示表',lhwtzsbID)
  462. repostCurd('updates', '{"tableName":"t_lhwtzsb","paramWhere":[' + lhwtzsbID + '],"paramCond":{"zhuang_tai_":"任务分配进行中"}}')
  463. }
  464. console.log('样品登记表:',ypdjb)
  465. repostCurd('add', '{"tableName":"t_lhypdjb","paramWhere":' + JSON.stringify(ypdjb) + '}')
  466. /* 3、更新样品表
  467. // console.log('3、更新样品表',lhypIdNewList)
  468. repostCurd('updates', '{"tableName":"t_lhypb","paramWhere":[' + lhypIdNewList + '],"paramCond":{"jie_yang_zhuang_t":"已接收"}}').then(res=>{
  469. this.handleAnySituation(true,"样品成功接收,正在开启任务分配!",'success')
  470. })*/
  471. console.log('更新样品表',sampleList)
  472. let allSampleParams ={
  473. tableName:'t_lhypb',
  474. updList:sampleList
  475. }
  476. repostCurd('updatesByWhere', JSON.stringify(allSampleParams)).then(res=>{
  477. this.handleAnySituation(true,"样品成功接收,正在开启任务分配!",'success')
  478. })
  479. })
  480. })
  481. })
  482. })
  483. }).catch(_ => { });
  484. }
  485. },
  486. /* 去除指定行数据 使用过滤器filter过滤指定行号数据 */
  487. deleteData(val) {
  488. this.listData = this.listData.filter((data) => {
  489. return data.id_ != val
  490. })
  491. },
  492. uuid() {
  493. var s = [];
  494. var hexDigits = "0123456789abcdef";
  495. for (var i = 0; i < 36; i++) {
  496. s[i] = hexDigits.substr(Math.floor(Math.random() * 0x10), 1);
  497. }
  498. s[14] = "4"; // bits 12-15 of the time_hi_and_version field to 0010
  499. s[19] = hexDigits.substr((s[19] & 0x3) | 0x8, 1); // bits 6-7 of the clock_seq_hi_and_reserved to 01
  500. s[8] = s[13] = s[18] = s[23] = "-";
  501. var uuid = s.join("");
  502. return uuid;
  503. },
  504. unique(arr) {
  505. return arr.filter((item, index) => {
  506. return arr.indexOf(item, 0) === index;
  507. });
  508. },
  509. // 根据旧位置数据生成新位置数据
  510. generateNewLocation(oldLocation, sampleInfo) {
  511. let temp = {
  512. fang_jian_lei_xin: oldLocation.fang_jian_lei_xin,
  513. wei_zhi_: oldLocation.wei_zhi_,
  514. qu_yu_: oldLocation.qu_yu_,
  515. huo_jia_lei_xing_: oldLocation.huo_jia_lei_xing_,
  516. huo_jia_hao_: oldLocation.huo_jia_hao_,
  517. ceng_hao_: oldLocation.ceng_hao_,
  518. shui_ping_fen_qu_: oldLocation.shui_ping_fen_qu_,
  519. wei_zhi_bian_hao_: oldLocation.wei_zhi_bian_hao_,
  520. wei_zhi_zhuang_ta: oldLocation.wei_zhi_zhuang_ta,
  521. cun_chu_tiao_jian: oldLocation.cun_chu_tiao_jian,
  522. shi_fou_guo_shen_: '启用',
  523. yang_pin_bian_hao: sampleInfo.yang_pin_bian_hao,
  524. yang_pin_ming_che: sampleInfo.yang_pin_ming_che,
  525. ru_ku_shi_jian_: sampleInfo.ru_ku_shi_jian_,
  526. shi_fou_liu_yang_: sampleInfo.shi_fou_liu_yang_,
  527. biao_zhi_uuid_: sampleInfo.biao_zhi_uuid_
  528. }
  529. return temp
  530. },
  531. handleLocationInfo(currentLocation, isLiuYang, localInfo, locationIds, item, UUID, currentTime) {
  532. !locationIds.has(currentLocation) ? locationIds.add(currentLocation) : localInfo.find(i => i.id_ === currentLocation).wei_zhi_zhuang_ta = '占用'
  533. console.log(localInfo.find(i => i.id_ === currentLocation), currentLocation)
  534. if (localInfo.find(i => i.id_ === currentLocation).wei_zhi_zhuang_ta === '空余') {
  535. let obj = {
  536. where: {
  537. id_: currentLocation
  538. },
  539. param: {
  540. wei_zhi_zhuang_ta: "占用",
  541. ru_ku_shi_jian_: currentTime,
  542. yang_pin_bian_hao: item.yang_pin_bian_hao,
  543. yang_pin_ming_che: item.yang_pin_ming_che,
  544. shi_fou_liu_yang_: isLiuYang
  545. }
  546. }
  547. let result = {
  548. name: 'emptyLocation',
  549. value: obj
  550. }
  551. return result
  552. } else { // 新增一条位置信息(修改它的样品编号,样品名称,入库时间,标识UUID)
  553. let sampleInfo = {
  554. yang_pin_bian_hao: item.yang_pin_bian_hao,
  555. yang_pin_ming_che: item.yang_pin_ming_che,
  556. ru_ku_shi_jian_: currentTime,
  557. biao_zhi_uuid_: UUID,
  558. shi_fou_liu_yang_: isLiuYang
  559. }
  560. let newLocation = this.generateNewLocation(localInfo.find(i => i.id_ === currentLocation), sampleInfo)
  561. let result = {
  562. name: 'fullLocation',
  563. value: newLocation
  564. }
  565. return result
  566. }
  567. },
  568. /* 关闭*/
  569. remRedar() {
  570. this.visible = false // 列表隐藏
  571. this.listData = [] // 清空列表数据
  572. this.redar = false // 扫码图标隐藏
  573. this.$emit('scanOff', false)
  574. },
  575. }
  576. }