manualConfirmationJS.js 69 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001
  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. props: {
  14. obj: {
  15. default: [],
  16. type: Array
  17. }
  18. },
  19. methods: {
  20. facilityData(page) {
  21. let sql = `select lei_xing_ from t_yplxb`
  22. let sql2 = `select yang_pin_gui_ge_ from t_ypbzggb`
  23. Promise.all([repostCurd('sql',sql),repostCurd('sql',sql2)]).then(([res1,res2]) =>{
  24. let data = res1.variables.data
  25. let data2 = res2.variables.data
  26. let types = []
  27. let guiGes = []
  28. data.forEach(item=>{
  29. let obj = {
  30. value:item.lei_xing_,
  31. label:item.lei_xing_
  32. }
  33. types.push(obj)
  34. })
  35. data2.forEach(item=>{
  36. let o = {
  37. value:item.yang_pin_gui_ge_,
  38. label:item.yang_pin_gui_ge_
  39. }
  40. guiGes.push(o)
  41. })
  42. this.sampleTypes = types
  43. this.sampleSpecifications = guiGes
  44. })
  45. if (this.obj.length > 0) {
  46. this.loadData(this.obj)
  47. } else {
  48. this.loadDataBySQL(page)
  49. }
  50. },
  51. /* 获取数据 ,开始查阅记录 */
  52. loadData(obj) {
  53. 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.id_,'${obj}') and ypb.jie_yang_zhuang_t = '待接收' and ypb.shi_fou_guo_shen_ = '1'`
  54. let liuYangSQL = `select liu_yang_qi_xian_ from t_lyqxpzb limit 1`
  55. let cfIDSQL = `select cun_fang_id_,liu_yang_id_ FROM t_ypwzmrxzb`
  56. Promise.all([repostCurd('sql', sql), repostCurd('sql', liuYangSQL),repostCurd('sql',cfIDSQL)]).then((res) => {
  57. let temp = res[0].variables.data
  58. let option = res[1].variables.data[0].liu_yang_qi_xian_
  59. let cfID = res[2].variables.data[0].cun_fang_id_
  60. let lyID = res[2].variables.data[0].liu_yang_id_
  61. let rq = options[option]
  62. if (temp) {
  63. temp.forEach(item => {
  64. item.jie_yang_shu_lian = item.yang_pin_zong_shu
  65. item.jie_yang_zhuang_t = '已确认'
  66. item.biao_zhi_uuid_1 = this.uuid()
  67. item.biao_zhi_uuid_2 = this.uuid()
  68. item.biao_zhi_uuid_3 = this.uuid()
  69. item.biao_zhi_uuid_4 = this.uuid()
  70. // item.shi_fou_liu_yang_ = '是'
  71. item.shi_fou_liu_yang_yi = '是'
  72. item.shi_fou_liu_yang_er = '是'
  73. item.shi_fou_liu_yang_san = '是'
  74. item.shi_fou_liu_yang_si = '是'
  75. item.yan_shou_jie_guo_ = '完好'
  76. item.liu_yang_shu_lian_yi = ' ml/支×1支'
  77. item.shou_yang_wei_zhi_yi = cfID
  78. item.liu_yang_wei_zhi_yi = lyID
  79. item.yang_pin_lei_er_ ?
  80. (item.liu_yang_shu_lian_er = ' ml/支×1支' ,item.shou_yang_wei_zhi_er = cfID,item.liu_yang_wei_zhi_er = lyID) : null
  81. item.yang_pin_lei_san_ ?
  82. (item.liu_yang_shu_lian_san = ' ml/支×1支',item.shou_yang_wei_zhi_san = cfID,item.liu_yang_wei_zhi_san = lyID) : null
  83. item.yang_pin_lei_si_ ?
  84. (item.liu_yang_shu_lian_si = ' ml/支×1支',item.shou_yang_wei_zhi_si = cfID,item.liu_yang_wei_zhi_si = lyID) : null
  85. item.liu_yang_ri_qi_ = new Date(new Date().getTime() + 28800000).toJSON().slice(0, 10).replace('T', ' ')
  86. item.yang_pin_lei_er_ ? this.$set(item, 'flag2', true) : this.$set(item, 'flag2', false)
  87. item.yang_pin_lei_san_ ? this.$set(item, 'flag3', true) : this.$set(item, 'flag3', false)
  88. item.yang_pin_lei_si_ ? this.$set(item, 'flag4', true) : this.$set(item, 'flag4', false)
  89. item.liu_yang_qi_xian = dayjs(item.song_jian_shi_jia).add(rq, 'month').format("YYYY-MM-DD")
  90. // temp[i].xiao_hui_ri_qi_ = dayjs(temp[i].liu_yang_qi_xian).endOf('month').format("YYYY-MM-DD")
  91. item.dan_wei_yi = item.yang_pin_gui_ge_ ? this.handleSpecificationsToUnit(item.yang_pin_gui_ge_) : ''
  92. item.dan_wei_er = item.yang_pin_gui_ge_e ? this.handleSpecificationsToUnit(item.yang_pin_gui_ge_e) : ''
  93. item.dan_wei_san = item.yang_pin_gui_ge_s ? this.handleSpecificationsToUnit(item.yang_pin_gui_ge_s) : ''
  94. item.dan_wei_si = item.yang_pin_gui_si_ ? this.handleSpecificationsToUnit(item.yang_pin_gui_si_) : ''
  95. })
  96. this.listData = temp
  97. } else {
  98. this.handleEmptyData();
  99. }
  100. })
  101. },
  102. loadDataBySQL(page) {
  103. // 扫码扫到新数据,查询 并分页 回填展示
  104. let fysql = `select ypb.*,sqb.chu_ju_bao_gao_ya from t_lhypb ypb join t_lhwtsqb sqb on ypb.parent_id_ = sqb.id_ and ypb.jie_yang_zhuang_t = '待接收' and ypb.shi_fou_guo_shen_ = '1'`
  105. let liuYangSQL = `select liu_yang_qi_xian_ from t_lyqxpzb limit 1`
  106. let cfIDSQL = `select cun_fang_id_,liu_yang_id_ FROM t_ypwzmrxzb`
  107. Promise.all([repostCurd('sql', fysql), repostCurd('sql', liuYangSQL),repostCurd('sql',cfIDSQL)]).then(([res1,res2,res3]) => {
  108. let cfID = res3.variables.data[0].cun_fang_id_
  109. let lyID = res3.variables.data[0].liu_yang_id_
  110. this.listData = []
  111. let temp = res1.variables.data
  112. let option = res2.variables.data[0].liu_yang_qi_xian_
  113. let rq = options[option]
  114. if (temp) {
  115. temp.forEach(item => {
  116. item.jie_yang_shu_lian = item.yang_pin_zong_shu
  117. item.jie_yang_zhuang_t = '已确认'
  118. item.biao_zhi_uuid_1 = this.uuid()
  119. item.biao_zhi_uuid_2 = this.uuid()
  120. item.biao_zhi_uuid_3 = this.uuid()
  121. item.biao_zhi_uuid_4 = this.uuid()
  122. // item.shi_fou_liu_yang_ = '是'
  123. item.shi_fou_liu_yang_yi = '是'
  124. item.shi_fou_liu_yang_er = '是'
  125. item.shi_fou_liu_yang_san = '是'
  126. item.shi_fou_liu_yang_si = '是'
  127. item.yan_shou_jie_guo_ = '完好'
  128. item.liu_yang_shu_lian_yi = ' ml/支×1支'
  129. item.shou_yang_wei_zhi_yi = cfID
  130. item.liu_yang_wei_zhi_yi = lyID
  131. item.yang_pin_lei_er_ ?
  132. (item.liu_yang_shu_lian_er = ' ml/支×1支' ,item.shou_yang_wei_zhi_er = cfID,item.liu_yang_wei_zhi_er = lyID) : null
  133. item.yang_pin_lei_san_ ?
  134. (item.liu_yang_shu_lian_san = ' ml/支×1支',item.shou_yang_wei_zhi_san = cfID,item.liu_yang_wei_zhi_san = lyID) : null
  135. item.yang_pin_lei_si_ ?
  136. (item.liu_yang_shu_lian_si = ' ml/支×1支',item.shou_yang_wei_zhi_si = cfID,item.liu_yang_wei_zhi_si = lyID) : null
  137. // item.yang_pin_lei_er_ ? item.liu_yang_shu_lian_er = ' ml/支×1支' : null
  138. // item.yang_pin_lei_san_ ? item.liu_yang_shu_lian_san = ' ml/支×1支' : null
  139. // item.yang_pin_lei_si_ ? item.liu_yang_shu_lian_si = ' ml/支×1支' : null
  140. item.liu_yang_ri_qi_ = new Date(new Date().getTime() + 28800000).toJSON().slice(0, 10).replace('T', ' ')
  141. item.yang_pin_lei_er_ ? this.$set(item, 'flag2', true) : this.$set(item, 'flag2', false)
  142. item.yang_pin_lei_san_ ? this.$set(item, 'flag3', true) : this.$set(item, 'flag3', false)
  143. item.yang_pin_lei_si_ ? this.$set(item, 'flag4', true) : this.$set(item, 'flag4', false)
  144. item.liu_yang_qi_xian = dayjs(item.song_jian_shi_jia).add(rq, 'month').format("YYYY-MM-DD")
  145. item.dan_wei_yi = item.yang_pin_gui_ge_ ? this.handleSpecificationsToUnit(item.yang_pin_gui_ge_) : ''
  146. item.dan_wei_er = item.yang_pin_gui_ge_e ? this.handleSpecificationsToUnit(item.yang_pin_gui_ge_e) : ''
  147. item.dan_wei_san = item.yang_pin_gui_ge_s ? this.handleSpecificationsToUnit(item.yang_pin_gui_ge_s) : ''
  148. item.dan_wei_si = item.yang_pin_gui_si_ ? this.handleSpecificationsToUnit(item.yang_pin_gui_si_) : ''
  149. })
  150. this.listData = temp
  151. } else {
  152. this.handleEmptyList();
  153. }
  154. })
  155. },
  156. handleEmptyData() {
  157. this.$confirm('您所选择的样品还未到实验室现场,无法接样!').then(_ => {
  158. this.closeDialog();
  159. }).catch(_ => { });
  160. },
  161. handleEmptyList() {
  162. this.$confirm('目前暂无样品需要接样!').then(_ => {
  163. this.closeDialog();
  164. }).catch(_ => { });
  165. },
  166. /* 列表失去焦点*/
  167. handleChange() {
  168. this.$refs.redarInput.focus(); //聚焦input
  169. },
  170. /* 关闭弹出列表框*/
  171. closeDialog() {
  172. this.remRedar()
  173. //回传关闭事件。隐藏当前组件。
  174. },
  175. handleClose() {
  176. this.handleChange()
  177. this.$confirm('确认关闭样品列表页面?').then(_ => {
  178. this.closeDialog();
  179. }).catch(_ => { });
  180. },
  181. handleAnySituation(callBackBool,msg,type){
  182. this.$emit('callback', callBackBool)
  183. this.visable = false
  184. this.$message({
  185. message: msg,
  186. type: type
  187. })
  188. this.closeDialog();
  189. },
  190. handleErrorData(msg){
  191. const { error } = this.$form.$message
  192. error(`${msg}`)
  193. return
  194. },
  195. submitData(type) {
  196. // this指针
  197. let this_ = this;
  198. // 回传关闭事件。隐藏当前组件。
  199. let judge = true;
  200. if (this_.listData.length == 0) {
  201. this.$emit('callback', true)
  202. this.visable = false
  203. this.$message({
  204. message: '暂无样品待接收确认!',
  205. type: 'error'
  206. })
  207. this.closeDialog();
  208. } else {
  209. this.$confirm('请再次确认 [样品接收信息]').then(_ => {
  210. // 获取样品列表
  211. let ypInfoList = this_.listData
  212. // console.log(ypInfoList, "样品信息")
  213. let dWhere = []
  214. let ypbh = []
  215. let ypbhList = [] // 样品编号列表
  216. // 罗湖样品编号列表
  217. let lhypbhList = []
  218. let lhypmcList = []
  219. // 罗湖样品表外键
  220. let lhypbWJ = []
  221. // 罗湖委托表主键
  222. let lhwtbID = []
  223. // 罗湖委托表展示表ID
  224. let lhwtzsbID = []
  225. // 罗湖样品id列表
  226. let lhypIdList = []
  227. // 罗湖样品id格式列表
  228. let lhypIdNewList = []
  229. // 样品所选择的位置ID字符串
  230. let localStr = ''
  231. let locationIds = new Set()
  232. let localArr = []
  233. let sampleList = []
  234. const currentTime = new Date(new Date().getTime() + 28800000).toJSON().slice(0, 16).replace('T', ' ')
  235. const curTime = new Date(new Date().getTime() + 28800000).toJSON().slice(0, 10).replace('T', ' ')
  236. for (let yp in ypInfoList) { //样品数据
  237. let cfwz = ''
  238. /*
  239. 校验:
  240. 1、样品数量 <= 确认数量
  241. 2、是否留样 => 填收样位置|留样位置
  242. 3、验收结果必填
  243. 4、如果留样 => 必填项:留样日期、留样数量、留样期限至、销毁日期
  244. */
  245. if (ypInfoList[yp].jie_yang_shu_lian > ypInfoList[yp].yang_pin_zong_shu) {
  246. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 接收确认数量不得大于收样数量。')
  247. return;
  248. }
  249. if (ypInfoList[yp].jie_yang_zhuang_t == '未确认') {
  250. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 接收确认状态必须为已确认。')
  251. return;
  252. }
  253. if (ypInfoList[yp].yan_shou_jie_guo_ == null || ypInfoList[yp].yan_shou_jie_guo_ == '') {
  254. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 验收结果不能为空!')
  255. return;
  256. }
  257. /** 如果四个是否留样中有一个为‘是’ 则 留样日期 和对应的留样位置就不能为空 */
  258. if (ypInfoList[yp].shi_fou_liu_yang_yi == "是" ||
  259. (ypInfoList[yp].flag2 == true && ypInfoList[yp].shi_fou_liu_yang_er == "是") ||
  260. (ypInfoList[yp].flag3 == true && ypInfoList[yp].shi_fou_liu_yang_san == "是") ||
  261. (ypInfoList[yp].flag4 == true && ypInfoList[yp].shi_fou_liu_yang_si == "是")) {
  262. if (ypInfoList[yp].liu_yang_ri_qi_ == null || ypInfoList[yp].liu_yang_ri_qi_ == '') {
  263. this_.$message.error('留样时必须填写留样日期!')
  264. return;
  265. // this_.handleErrorData("") todo 失效
  266. }
  267. if(ypInfoList[yp].shi_fou_liu_yang_yi == "是"){
  268. // 判断位置是否为空
  269. if (ypInfoList[yp].liu_yang_wei_zhi_yi == null || ypInfoList[yp].liu_yang_wei_zhi_yi == '') {
  270. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型1的留样位置选择不能为空!')
  271. return;
  272. }
  273. if(ypInfoList[yp].liu_yang_shu_lian_yi == null || ypInfoList[yp].liu_yang_shu_lian_yi == ''){
  274. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型1的留样数量不能为空!')
  275. return;
  276. }
  277. }
  278. if(ypInfoList[yp].shi_fou_liu_yang_er == "是"){
  279. if(ypInfoList[yp].flag2 == true){
  280. if (ypInfoList[yp].liu_yang_wei_zhi_er == '' || ypInfoList[yp].liu_yang_wei_zhi_er == null) {
  281. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型2的留样位置选择不能为空!')
  282. return;
  283. }
  284. if(ypInfoList[yp].liu_yang_shu_lian_er == null || ypInfoList[yp].liu_yang_shu_lian_er == ''){
  285. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型2的留样数量不能为空!')
  286. return;
  287. }
  288. }
  289. }
  290. if(ypInfoList[yp].shi_fou_liu_yang_san == "是"){
  291. if(ypInfoList[yp].flag3 == true ){
  292. if (ypInfoList[yp].liu_yang_wei_zhi_san == '' || ypInfoList[yp].liu_yang_wei_zhi_san == null) {
  293. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型3的留样位置选择不能为空!')
  294. return;
  295. }
  296. if(ypInfoList[yp].liu_yang_shu_lian_san == null || ypInfoList[yp].liu_yang_shu_lian_san == ''){
  297. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型3的留样数量不能为空!')
  298. return;
  299. }
  300. }
  301. }
  302. if(ypInfoList[yp].shi_fou_liu_yang_si == "是"){
  303. if(ypInfoList[yp].flag4 == true ){
  304. if (ypInfoList[yp].liu_yang_wei_zhi_si == '' || ypInfoList[yp].liu_yang_wei_zhi_si == null) {
  305. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型4的留样位置选择不能为空!')
  306. return;
  307. }
  308. if(ypInfoList[yp].liu_yang_shu_lian_si == null || ypInfoList[yp].liu_yang_shu_lian_si == ''){
  309. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型4的留样数量不能为空!')
  310. return;
  311. }
  312. }
  313. }
  314. }
  315. // 判断位置是否为空 且判断单位是否为空
  316. if (ypInfoList[yp].shou_yang_wei_zhi_yi == null || ypInfoList[yp].shou_yang_wei_zhi_yi == '') {
  317. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型1的位置选择不能为空!')
  318. return;
  319. }
  320. if(ypInfoList[yp].dan_wei_yi == null || ypInfoList[yp].dan_wei_yi == ''){
  321. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型1的单位不能为空!')
  322. return;
  323. }
  324. if(ypInfoList[yp].flag2 == true){
  325. if (ypInfoList[yp].shou_yang_wei_zhi_er == '' || ypInfoList[yp].shou_yang_wei_zhi_er == null) {
  326. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型2的位置选择不能为空!')
  327. return;
  328. }
  329. if(ypInfoList[yp].dan_wei_er == null || ypInfoList[yp].dan_wei_er == ''){
  330. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型2的单位不能为空!')
  331. return;
  332. }
  333. }
  334. if(ypInfoList[yp].flag3 == true){
  335. if(ypInfoList[yp].shou_yang_wei_zhi_san == '' || ypInfoList[yp].shou_yang_wei_zhi_san == null) {
  336. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型3的位置选择不能为空!')
  337. return;
  338. }
  339. if(ypInfoList[yp].dan_wei_san == null || ypInfoList[yp].dan_wei_san == ''){
  340. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型3的单位不能为空!')
  341. return;
  342. }
  343. }
  344. if(ypInfoList[yp].flag4 == true){
  345. if (ypInfoList[yp].shou_yang_wei_zhi_si == '' || ypInfoList[yp].shou_yang_wei_zhi_si == null) {
  346. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型4的位置选择不能为空!')
  347. return;
  348. }
  349. if(ypInfoList[yp].dan_wei_si == null || ypInfoList[yp].dan_wei_si == ''){
  350. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 类型4的单位不能为空!')
  351. return;
  352. }
  353. }
  354. // 判断留样日期不得早于当前日期
  355. if(ypInfoList[yp].liu_yang_ri_qi_ != null && ypInfoList[yp].liu_yang_ri_qi_ != ''){
  356. if(ypInfoList[yp].liu_yang_ri_qi_ < curTime){
  357. console.log(ypInfoList[yp].liu_yang_ri_qi_,curTime)
  358. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 的留样日期不得早于收样日期!')
  359. return;
  360. }
  361. }
  362. // 判断留样期限日期不得早于当前日期
  363. if(ypInfoList[yp].liu_yang_qi_xian != null && ypInfoList[yp].liu_yang_qi_xian != ''){
  364. if(ypInfoList[yp].liu_yang_qi_xian < curTime){
  365. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 的留样期限日期不得早于收样日期!')
  366. return;
  367. }
  368. }
  369. // 判断返样日期不得早于当前日期
  370. if(ypInfoList[yp].fan_yang_ri_qi_ != null && ypInfoList[yp].fan_yang_ri_qi_ != ''){
  371. if(ypInfoList[yp].fan_yang_ri_qi_ < curTime){
  372. this_.$message.error('操作失败,[' + ypInfoList[yp].yang_pin_ming_che + '] 的返样日期不得早于收样日期!')
  373. return;
  374. }
  375. }
  376. ypbhList.push('{"yang_pin_bian_hao":"' + ypInfoList[yp].yang_pin_bian_hao + '"}') // 样品编号列表
  377. // 罗湖
  378. dWhere.push('{"id_":"' + cfwz + '"}')
  379. lhypbhList.push(ypInfoList[yp].yang_pin_bian_hao)
  380. lhypbWJ.push(ypInfoList[yp].parent_id_)
  381. lhypIdList.push(ypInfoList[yp].id_)
  382. lhypIdNewList.push('{"id_":"' + ypInfoList[yp].id_ + '"}')
  383. ypbh.push(ypInfoList[yp].yang_pin_bian_hao)
  384. lhypmcList.push(ypInfoList[yp].yang_pin_ming_che)
  385. localArr.push(
  386. ypInfoList[yp].shou_yang_wei_zhi_yi, ypInfoList[yp].liu_yang_wei_zhi_yi,
  387. ypInfoList[yp].shou_yang_wei_zhi_er, ypInfoList[yp].liu_yang_wei_zhi_er,
  388. ypInfoList[yp].shou_yang_wei_zhi_san, ypInfoList[yp].liu_yang_wei_zhi_san,
  389. ypInfoList[yp].shou_yang_wei_zhi_si, ypInfoList[yp].liu_yang_wei_zhi_si
  390. )
  391. let o = {
  392. where:{
  393. id_ : ypInfoList[yp].id_
  394. },
  395. param:{
  396. yang_pin_lei_xing: ypInfoList[yp].yang_pin_lei_xing,
  397. yang_ben_yun_shu_: ypInfoList[yp].yang_ben_yun_shu_,
  398. shu_liang_: ypInfoList[yp].shu_liang_,
  399. yang_pin_gui_ge_: ypInfoList[yp].yang_pin_gui_ge_,
  400. yang_pin_lei_er_: ypInfoList[yp].yang_pin_lei_er_,
  401. yang_pin_yun_shu_: ypInfoList[yp].yang_pin_yun_shu_,
  402. shu_liang_er_: ypInfoList[yp].shu_liang_er_,
  403. yang_pin_gui_ge_e: ypInfoList[yp].yang_pin_gui_ge_e,
  404. yang_pin_lei_san_: ypInfoList[yp].yang_pin_lei_san_,
  405. yang_pin_yun_san: ypInfoList[yp].yang_pin_yun_san,
  406. shu_liang_san_: ypInfoList[yp].shu_liang_san_,
  407. yang_pin_gui_ge_s: ypInfoList[yp].yang_pin_gui_ge_s,
  408. yang_pin_lei_si_: ypInfoList[yp].yang_pin_lei_si_,
  409. yang_pin_yun_si_: ypInfoList[yp].yang_pin_yun_si_,
  410. shu_liang_si_: ypInfoList[yp].shu_liang_si_,
  411. yang_pin_gui_si_: ypInfoList[yp].yang_pin_gui_si_,
  412. jie_yang_zhuang_t:"已接收",
  413. yang_pin_zong_shu:ypInfoList[yp].yang_pin_zong_shu,
  414. bei_zhu_1_:ypInfoList[yp].bei_zhu_1_
  415. }
  416. }
  417. sampleList.push(o)
  418. }
  419. localStr = localArr.filter(i => i).join(',')
  420. let value = ''
  421. let lhypIdStr = ''
  422. for (let i = 0; i < lhypbWJ.length; i++) {
  423. value += lhypbWJ[i] + ','
  424. }
  425. value = value.substring(0, value.length - 1)
  426. value = value.replace(/,/g, "','")
  427. for (let i = 0; i < lhypIdList.length; i++) {
  428. lhypIdStr += lhypIdList[i] + ','
  429. }
  430. lhypIdStr = lhypIdStr.substring(0, lhypIdStr.length - 1)
  431. lhypIdStr = lhypIdStr.replace(/,/g, "','")
  432. 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}')`
  433. // console.log(allSQL)
  434. // 搜集所有选择的位置信息
  435. // console.log('当前选择的位置ids:',locationIds)
  436. var allLocal = `select * from t_ypcfwz where find_in_set(id_,'${localStr}')`
  437. Promise.all([repostCurd("sql", allSQL), repostCurd("sql", allLocal)]).then((res) => {
  438. let initResult = res[0].variables.data
  439. let result = []
  440. let localInfo = res[1].variables.data
  441. // 排序
  442. ypInfoList.forEach(item=>{
  443. result.push(initResult.find(i => i.yang_pin_bian_hao === item.yang_pin_bian_hao))
  444. })
  445. // console.log(localInfo)
  446. /* 1、更新货架位置信息 */
  447. this.emptyLocal = []
  448. this.fullLocal = []
  449. let allUUID = []
  450. ypInfoList.forEach(item => {
  451. allUUID.push(item.biao_zhi_uuid_1, item.biao_zhi_uuid_2, item.biao_zhi_uuid_3, item.biao_zhi_uuid_4)
  452. let allResult = []
  453. if(item.shou_yang_wei_zhi_yi != undefined && item.shou_yang_wei_zhi_yi){
  454. allResult.push(this.handleLocationInfo(item.shou_yang_wei_zhi_yi, '否', localInfo, locationIds, item, item.biao_zhi_uuid_1, currentTime,item.yang_pin_lei_xing,item.liu_yang_shu_lian_yi))
  455. }
  456. if (item.shou_yang_wei_zhi_er != undefined && item.shou_yang_wei_zhi_er) {
  457. allResult.push(this.handleLocationInfo(item.shou_yang_wei_zhi_er, '否', localInfo, locationIds, item, item.biao_zhi_uuid_2, currentTime,item.yang_pin_lei_er_,item.liu_yang_shu_lian_er))
  458. }
  459. if (item.shou_yang_wei_zhi_san != undefined && item.shou_yang_wei_zhi_san) {
  460. allResult.push(this.handleLocationInfo(item.shou_yang_wei_zhi_san, '否', localInfo, locationIds, item, item.biao_zhi_uuid_3, currentTime,item.yang_pin_lei_san_,item.liu_yang_shu_lian_san))
  461. }
  462. if (item.shou_yang_wei_zhi_si != undefined && item.shou_yang_wei_zhi_si) {
  463. allResult.push(this.handleLocationInfo(item.shou_yang_wei_zhi_si, '否', localInfo, locationIds, item, item.biao_zhi_uuid_4, currentTime,item.yang_pin_lei_si_,item.liu_yang_shu_lian_si))
  464. }
  465. if(item.liu_yang_wei_zhi_yi != undefined && item.liu_yang_wei_zhi_yi && item.shi_fou_liu_yang_yi === '是'){
  466. allResult.push(this.handleLocationInfo(item.liu_yang_wei_zhi_yi, '是', localInfo, locationIds, item, item.biao_zhi_uuid_1, currentTime,item.yang_pin_lei_xing,item.liu_yang_shu_lian_yi))
  467. }
  468. if (item.liu_yang_wei_zhi_er != undefined && item.liu_yang_wei_zhi_er && item.shi_fou_liu_yang_er === '是') {
  469. allResult.push(this.handleLocationInfo(item.liu_yang_wei_zhi_er, '是', localInfo, locationIds, item, item.biao_zhi_uuid_2, currentTime,item.yang_pin_lei_er_,item.liu_yang_shu_lian_er))
  470. }
  471. if (item.liu_yang_wei_zhi_san != undefined && item.liu_yang_wei_zhi_san && item.shi_fou_liu_yang_san === '是') {
  472. allResult.push(this.handleLocationInfo(item.liu_yang_wei_zhi_san, '是', localInfo, locationIds, item, item.biao_zhi_uuid_3, currentTime,item.yang_pin_lei_san_,item.liu_yang_shu_lian_san))
  473. }
  474. if (item.liu_yang_wei_zhi_si != undefined && item.liu_yang_wei_zhi_si && item.shi_fou_liu_yang_si === '是') {
  475. allResult.push(this.handleLocationInfo(item.liu_yang_wei_zhi_si, '是', localInfo, locationIds, item, item.biao_zhi_uuid_4, currentTime,item.yang_pin_lei_si_,item.liu_yang_shu_lian_si))
  476. }
  477. allResult.forEach(item => {
  478. item.name === 'emptyLocation' ? this.emptyLocal.push(item.value) : this.fullLocal.push(item.value)
  479. })
  480. })
  481. let allUUIDStr = allUUID.filter(i => i).join(',')
  482. // 更新样品位置list
  483. // console.log('emptyLocal:',this.emptyLocal)
  484. if(this.emptyLocal.length > 0){
  485. let allParams = {
  486. tableName: 't_ypcfwz',
  487. updList: this.emptyLocal
  488. }
  489. repostCurd('updatesByWhere', JSON.stringify(allParams))
  490. }
  491. // 插入样品位置list
  492. console.log('fullLocal:',this.fullLocal)
  493. if(this.fullLocal.length == 0){
  494. /* 2、封装样品登记表对象,插入样品登记表 顺便封装任务分配表 */
  495. let ypdjb = []
  496. let rws = []
  497. console.log(result)
  498. console.log(ypInfoList)
  499. result.forEach((item, index) => {
  500. // 2-1:统计每个样品有多少类型[数量]
  501. let lxList = []
  502. let ypggList = []
  503. let liuYangList = []
  504. 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_)
  505. ypggList.push(
  506. ypInfoList[index].yang_pin_gui_ge_? ypInfoList[index].yang_pin_gui_ge_ +'*'+ ypInfoList[index].shu_liang_+ ypInfoList[index].dan_wei_yi:'',
  507. ypInfoList[index].yang_pin_gui_ge_e? ypInfoList[index].yang_pin_gui_ge_e+'*'+ ypInfoList[index].shu_liang_er_+ ypInfoList[index].dan_wei_er:'',
  508. ypInfoList[index].yang_pin_gui_ge_s?ypInfoList[index].yang_pin_gui_ge_s +'*'+ ypInfoList[index].shu_liang_san_+ ypInfoList[index].dan_wei_san:'',
  509. ypInfoList[index].yang_pin_gui_si_?ypInfoList[index].yang_pin_gui_si_ +'*'+ ypInfoList[index].shu_liang_si_+ ypInfoList[index].dan_wei_si:'')
  510. 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)
  511. let yplxz = lxList.filter(i => i).join(';')
  512. let ypggStr = ypggList.filter(i => i).join(';')
  513. let liuyangStr = liuYangList.filter(i => i).join(';')
  514. // let count = lxList.filter(i => i).join(',').match(/,/g).length + 1
  515. let size = lxList.filter(i => i).join(',').match(/,/g)
  516. let count = 1
  517. size == null ? count = 1 : count = size.length + 1
  518. let xmmc = []
  519. xmmc.push(item.chang_gui_xiang_m, item.tao_can_ming_chen)
  520. let xiangMuZh = xiangMuZh = xmmc.filter(i => i).join(',')
  521. for (let c = 0; c < count; c++) {
  522. let yblx = c == 0 ? ypInfoList[index].yang_pin_lei_xing :
  523. c == 1 ? ypInfoList[index].yang_pin_lei_er_ :
  524. c == 2 ? ypInfoList[index].yang_pin_lei_san_ :
  525. c == 3 ? ypInfoList[index].yang_pin_lei_si_ : ''
  526. let ystj = c == 0 ? ypInfoList[index].yang_ben_yun_shu_ :
  527. c == 1 ? ypInfoList[index].yang_pin_yun_shu_ :
  528. c == 2 ? ypInfoList[index].yang_pin_yun_san :
  529. c == 3 ? ypInfoList[index].yang_pin_yun_si_ : ''
  530. let ypsl = c == 0 ? ypInfoList[index].shu_liang_ :
  531. c == 1 ? ypInfoList[index].shu_liang_er_ :
  532. c == 2 ? ypInfoList[index].shu_liang_san_ :
  533. c == 3 ? ypInfoList[index].shu_liang_si_ : ''
  534. let ybgg = c == 0 ? ypInfoList[index].yang_pin_gui_ge_ :
  535. c == 1 ? ypInfoList[index].yang_pin_gui_ge_e :
  536. c == 2 ? ypInfoList[index].yang_pin_gui_ge_s :
  537. c == 3 ? ypInfoList[index].yang_pin_gui_si_ : ''
  538. let sywz = c == 0 ? ypInfoList[index].shou_yang_wei_zhi_yi :
  539. c == 1 ? ypInfoList[index].shou_yang_wei_zhi_er :
  540. c == 2 ? ypInfoList[index].shou_yang_wei_zhi_san :
  541. c == 3 ? ypInfoList[index].shou_yang_wei_zhi_si : ''
  542. let lycf = c == 0 ? ypInfoList[index].liu_yang_wei_zhi_yi :
  543. c == 1 ? ypInfoList[index].liu_yang_wei_zhi_er :
  544. c == 2 ? ypInfoList[index].liu_yang_wei_zhi_san :
  545. c == 3 ? ypInfoList[index].liu_yang_wei_zhi_si : ''
  546. let lysl = c == 0 ? ypInfoList[index].liu_yang_shu_lian_yi :
  547. c == 1 ? ypInfoList[index].liu_yang_shu_lian_er :
  548. c == 2 ? ypInfoList[index].liu_yang_shu_lian_san :
  549. c == 3 ? ypInfoList[index].liu_yang_shu_lian_si : ''
  550. let currentUUID = c == 0 ? ypInfoList[index].biao_zhi_uuid_1 :
  551. c == 1 ? ypInfoList[index].biao_zhi_uuid_2 :
  552. c == 2 ? ypInfoList[index].biao_zhi_uuid_3 :
  553. c == 3 ? ypInfoList[index].biao_zhi_uuid_4 : ''
  554. let ifLy = c == 0 ? ypInfoList[index].shi_fou_liu_yang_yi :
  555. c == 1 ? ypInfoList[index].shi_fou_liu_yang_er :
  556. c == 2 ? ypInfoList[index].shi_fou_liu_yang_san:
  557. c == 3 ? ypInfoList[index].shi_fou_liu_yang_si : ''
  558. let obj = {
  559. wei_tuo_dan_hao_: item.wei_tuo_bian_hao_,
  560. wei_tuo_dan_wei_: item.wtdh,
  561. lian_xi_ren_: item.wei_tuo_fang_lian,
  562. lian_xi_dian_hua_: item.wei_tuo_lian,
  563. yang_ben_ming_che: item.yang_pin_ming_che,
  564. yang_ben_bian_hao: item.yang_pin_bian_hao,
  565. pi_hao_bian_hao_: item.song_jian_pi_hao_,
  566. song_jian_dan_wei: item.song_jian_dan_wei,
  567. xing_ming_: ypInfoList[index].xing_ming_=== undefined?'':ypInfoList[index].xing_ming_,
  568. xing_bie_: ypInfoList[index].xing_bie_=== undefined?'':ypInfoList[index].xing_bie_,
  569. nian_ling_: ypInfoList[index].nian_ling_=== undefined?'':ypInfoList[index].nian_ling_,
  570. yang_ben_zhuang_t: item.yang_pin_zhuang_t,
  571. shou_yang_ri_qi_: currentTime,
  572. bei_zhu_: ypInfoList[index].bei_zhu_1_ === undefined?'':ypInfoList[index].bei_zhu_1_,
  573. yang_ben_lei_xing: yblx,
  574. yun_shu_tiao_jian: ystj,
  575. yang_pin_shu_lian: ypsl,
  576. yang_ben_gui_ge_s: ybgg,
  577. yan_shou_jie_guo_: ypInfoList[index].yan_shou_jie_guo_,
  578. cun_fang_wei_zhi_: sywz,
  579. liu_zhuan_zhuang_: '待任务分配',
  580. shi_fou_liu_yang_: ifLy,
  581. liu_yang_ri_qi_: ifLy == '是'? ypInfoList[index].liu_yang_ri_qi_:'',
  582. liu_yang_cun_fang: ifLy == '是'?lycf:'',
  583. liu_yang_shu_lian: ifLy == '是'? (lysl == null ?'':lysl) : '',
  584. liu_yang_qi_xian: ifLy == '是'? ypInfoList[index].liu_yang_qi_xian:'',
  585. xiao_hui_ri_qi_: ypInfoList[index].xiao_hui_ri_qi_=== undefined?'':ypInfoList[index].xiao_hui_ri_qi_,
  586. fan_yang_ri_qi_: ypInfoList[index].fan_yang_ri_qi_=== undefined?'':ypInfoList[index].fan_yang_ri_qi_,
  587. fan_yang_jyr: ypInfoList[index].fan_yang_jyr=== undefined?'':ypInfoList[index].fan_yang_jyr,
  588. biao_zhi_uuid_: currentUUID,
  589. song_yang_yao_qiu: ypInfoList[index].song_yang_yao_qiu=== undefined?'':ypInfoList[index].song_yang_yao_qiu,
  590. jian_ce_xiang_mu_: xiangMuZh,
  591. shou_yang_ren_:this.$store.getters.userInfo.user.name,
  592. wei_tuo_lei_xing_:item.wei_tuo_lei_xing_
  593. }
  594. // console.log(obj)
  595. ypdjb.push(obj)
  596. }
  597. // 2-2:封装任务分配表
  598. let rw = {
  599. yang_pin_ming_che: item.yang_pin_ming_che,
  600. yang_pin_bian_hao: item.yang_pin_bian_hao,
  601. wei_tuo_lei_xing_: item.wei_tuo_lei_xing_,
  602. yang_pin_lei_xing: yplxz,
  603. yang_pin_gui_ge_: ypggStr,
  604. wei_tuo_id_: item.wtID,
  605. he_tong_id_: item.he_tong_id_,
  606. zhuang_tai_: '待任务分配',
  607. wan_cheng_shi_jia: item.song_jian_shi_jia,
  608. shou_yang_ri_qi_: currentTime,
  609. bao_gao_lei_xing_: item.bao_gao_lei_xing_,
  610. xin_xiang_mu_ming: item.xiang_mu_ming_che,
  611. zhan_shi_biao_id_: item.zhan_shi_biao_id_,
  612. fen_zhuang_liu_ya: liuyangStr,
  613. shi_fou_jia_ji_: item.chu_ju_bao_gao_ya, // 是否加急【2023/2/23王提出】
  614. yang_pin_shu_lian: ypInfoList[index].jie_yang_shu_lian, // 样品确认总数【2023/3/7王提出】
  615. suo_you_xiang_mu_: xiangMuZh, // 所有项目的中文名称 【2023/12/11 Mr王】
  616. song_jian_pi_hao_: item.song_jian_pi_hao_// 送检批号 【2023/12/11 Mr王】
  617. }
  618. rws.push(rw)
  619. lhwtzsbID.push('{"shen_qing_id_":"' + item.zhan_shi_biao_id_ + '"}')
  620. lhwtbID.push('{"id_":"' + item.wtID + '"}')
  621. })
  622. /* 4、任务分配
  623. 4-1、根据 wtdAndYpb 的 wtID 更改委托表的 委托状态 wei_tuo_zhuang_ta 变成 已完成
  624. 4-2、根据每个样品一个任务分配流程 遍历样品表开任务分配流程
  625. 4-3、委托表找zhan_shi_biao_id_ 修改 t_lhwtzsb "zhuang_tai_"为"任务分配进行中"
  626. 优化:将其他不冲突的更改状态脚本放在任务分配后并行处理
  627. */
  628. // console.log("4、任务分配",rws) 2023/12/11 Mr王 去掉 ,"defKey":"Process_04o0csc","formKey":"lhrwfp"
  629. repostCurd('add', '{"tableName":"t_lhrwfpb","paramWhere":' + JSON.stringify(rws) + '}').then(res=>{
  630. // console.log('4、更改委托表的 委托状态',lhwtbID)
  631. repostCurd('updates', '{"tableName":"t_lhwtsqb","paramWhere":[' + lhwtbID + '],"paramCond":{"wei_tuo_zhuang_ta":"已完成"}}')
  632. /* 5、更新展示表 */
  633. if (lhwtzsbID.length > 0) {
  634. // console.log('5、更新展示表',lhwtzsbID)
  635. repostCurd('updates', '{"tableName":"t_lhwtzsb","paramWhere":[' + lhwtzsbID + '],"paramCond":{"zhuang_tai_":"任务分配进行中"}}')
  636. }
  637. console.log('样品登记表:',ypdjb)
  638. if(ypdjb.length > 0){
  639. repostCurd('add', '{"tableName":"t_lhypdjb","paramWhere":' + JSON.stringify(ypdjb) + '}').then(()=>{
  640. console.log("样品登记表数据添加成功!")
  641. this.$emit('callback', true)
  642. }).catch(error =>{
  643. console.log(error)
  644. this.handleAnySituation(true,"样品登记表数据添加失败!请勿关闭此页面,联系开发人员解决",'error')
  645. })
  646. }else{
  647. this.handleAnySituation(true,"样品登记表数据添加失败!请勿关闭此页面,联系开发人员解决",'error')
  648. }
  649. /* 3、更新样品表
  650. // console.log('3、更新样品表',lhypIdNewList)
  651. repostCurd('updates', '{"tableName":"t_lhypb","paramWhere":[' + lhypIdNewList + '],"paramCond":{"jie_yang_zhuang_t":"已接收"}}').then(res=>{
  652. this.handleAnySituation(true,"样品成功接收,正在开启任务分配!",'success')
  653. })
  654. */
  655. console.log('更新样品表',sampleList)
  656. let allSampleParams ={
  657. tableName:'t_lhypb',
  658. updList:sampleList
  659. }
  660. repostCurd('updatesByWhere', JSON.stringify(allSampleParams)).then(res=>{
  661. this.handleAnySituation(true,"样品成功接收,正在开启任务分配!",'success')
  662. })
  663. })
  664. }else{
  665. repostCurd('add', '{"tableName":"t_ypcfwz","paramWhere":' + JSON.stringify(this.fullLocal) + '}').then(res => {
  666. // 再次查询位置表,对比当前样品列表 替换初始值为占用的样品位置id
  667. let findLocationAgain = `select id_,shi_fou_liu_yang_,biao_zhi_uuid_ from t_ypcfwz where find_in_set(biao_zhi_uuid_,'${allUUIDStr}')`
  668. // console.log(findLocationAgain)
  669. repostCurd('sql', findLocationAgain).then(res => {
  670. let data = res.variables.data
  671. let uuidArgs = ['biao_zhi_uuid_1', 'biao_zhi_uuid_2', 'biao_zhi_uuid_3', 'biao_zhi_uuid_4']
  672. let shouYangArgs = ['shou_yang_wei_zhi_yi', 'shou_yang_wei_zhi_er', 'shou_yang_wei_zhi_san', 'shou_yang_wei_zhi_si']
  673. let liuYangArgs = ['liu_yang_wei_zhi_yi', 'liu_yang_wei_zhi_er', 'liu_yang_wei_zhi_san', 'liu_yang_wei_zhi_si']
  674. data.forEach(item => {
  675. uuidArgs.forEach((uuid, index) => {
  676. let ypIndex = ypInfoList.findIndex(i => i[uuid] === item.biao_zhi_uuid_)
  677. if (ypIndex != -1) {
  678. item.shi_fou_liu_yang_ === '否' ?
  679. ypInfoList[ypIndex][shouYangArgs[index]] = item.id_ :
  680. ypInfoList[ypIndex][liuYangArgs[index]] = item.id_
  681. }
  682. })
  683. })
  684. // repostCurd('updates', '{"tableName":"t_lhypb","paramWhere":[' + lhypIdNewList + '],"paramCond":{"jie_yang_zhuang_t":"已接收"}}')
  685. /* 2、封装样品登记表对象,插入样品登记表 顺便封装任务分配表 */
  686. let ypdjb = []
  687. let rws = []
  688. console.log(result)
  689. console.log(ypInfoList)
  690. result.forEach((item, index) => {
  691. // 2-1:统计每个样品有多少类型[数量]
  692. let lxList = []
  693. let ypggList = []
  694. let liuYangList = []
  695. 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_)
  696. ypggList.push(
  697. ypInfoList[index].yang_pin_gui_ge_? ypInfoList[index].yang_pin_gui_ge_ +'*'+ ypInfoList[index].shu_liang_+ ypInfoList[index].dan_wei_yi:'',
  698. ypInfoList[index].yang_pin_gui_ge_e? ypInfoList[index].yang_pin_gui_ge_e+'*'+ ypInfoList[index].shu_liang_er_+ ypInfoList[index].dan_wei_er:'',
  699. ypInfoList[index].yang_pin_gui_ge_s?ypInfoList[index].yang_pin_gui_ge_s +'*'+ ypInfoList[index].shu_liang_san_+ ypInfoList[index].dan_wei_san:'',
  700. ypInfoList[index].yang_pin_gui_si_?ypInfoList[index].yang_pin_gui_si_ +'*'+ ypInfoList[index].shu_liang_si_+ ypInfoList[index].dan_wei_si:'')
  701. 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)
  702. let yplxz = lxList.filter(i => i).join(';')
  703. let ypggStr = ypggList.filter(i => i).join(';')
  704. let liuyangStr = liuYangList.filter(i => i).join(';')
  705. // let count = lxList.filter(i => i).join(',').match(/,/g).length + 1
  706. let size = lxList.filter(i => i).join(',').match(/,/g)
  707. let count = 1
  708. size == null ? count = 1 : count = size.length + 1
  709. let xmmc = []
  710. xmmc.push(item.chang_gui_xiang_m, item.tao_can_ming_chen)
  711. let xiangMuZh = xiangMuZh = xmmc.filter(i => i).join(',')
  712. for (let c = 0; c < count; c++) {
  713. let yblx = c == 0 ? ypInfoList[index].yang_pin_lei_xing :
  714. c == 1 ? ypInfoList[index].yang_pin_lei_er_ :
  715. c == 2 ? ypInfoList[index].yang_pin_lei_san_ :
  716. c == 3 ? ypInfoList[index].yang_pin_lei_si_ : ''
  717. let ystj = c == 0 ? ypInfoList[index].yang_ben_yun_shu_ :
  718. c == 1 ? ypInfoList[index].yang_pin_yun_shu_ :
  719. c == 2 ? ypInfoList[index].yang_pin_yun_san :
  720. c == 3 ? ypInfoList[index].yang_pin_yun_si_ : ''
  721. let ypsl = c == 0 ? ypInfoList[index].shu_liang_ :
  722. c == 1 ? ypInfoList[index].shu_liang_er_ :
  723. c == 2 ? ypInfoList[index].shu_liang_san_ :
  724. c == 3 ? ypInfoList[index].shu_liang_si_ : ''
  725. let ybgg = c == 0 ? ypInfoList[index].yang_pin_gui_ge_ :
  726. c == 1 ? ypInfoList[index].yang_pin_gui_ge_e :
  727. c == 2 ? ypInfoList[index].yang_pin_gui_ge_s :
  728. c == 3 ? ypInfoList[index].yang_pin_gui_si_ : ''
  729. let sywz = c == 0 ? ypInfoList[index].shou_yang_wei_zhi_yi :
  730. c == 1 ? ypInfoList[index].shou_yang_wei_zhi_er :
  731. c == 2 ? ypInfoList[index].shou_yang_wei_zhi_san :
  732. c == 3 ? ypInfoList[index].shou_yang_wei_zhi_si : ''
  733. let lycf = c == 0 ? ypInfoList[index].liu_yang_wei_zhi_yi :
  734. c == 1 ? ypInfoList[index].liu_yang_wei_zhi_er :
  735. c == 2 ? ypInfoList[index].liu_yang_wei_zhi_san :
  736. c == 3 ? ypInfoList[index].liu_yang_wei_zhi_si : ''
  737. let lysl = c == 0 ? ypInfoList[index].liu_yang_shu_lian_yi :
  738. c == 1 ? ypInfoList[index].liu_yang_shu_lian_er :
  739. c == 2 ? ypInfoList[index].liu_yang_shu_lian_san :
  740. c == 3 ? ypInfoList[index].liu_yang_shu_lian_si : ''
  741. let currentUUID = c == 0 ? ypInfoList[index].biao_zhi_uuid_1 :
  742. c == 1 ? ypInfoList[index].biao_zhi_uuid_2 :
  743. c == 2 ? ypInfoList[index].biao_zhi_uuid_3 :
  744. c == 3 ? ypInfoList[index].biao_zhi_uuid_4 : ''
  745. let ifLy = c == 0 ? ypInfoList[index].shi_fou_liu_yang_yi :
  746. c == 1 ? ypInfoList[index].shi_fou_liu_yang_er :
  747. c == 2 ? ypInfoList[index].shi_fou_liu_yang_san:
  748. c == 3 ? ypInfoList[index].shi_fou_liu_yang_si : ''
  749. let obj = {
  750. wei_tuo_dan_hao_: item.wei_tuo_bian_hao_,
  751. wei_tuo_dan_wei_: item.wtdh,
  752. lian_xi_ren_: item.wei_tuo_fang_lian,
  753. lian_xi_dian_hua_: item.wei_tuo_lian,
  754. yang_ben_ming_che: item.yang_pin_ming_che,
  755. yang_ben_bian_hao: item.yang_pin_bian_hao,
  756. pi_hao_bian_hao_: item.song_jian_pi_hao_,
  757. song_jian_dan_wei: item.song_jian_dan_wei,
  758. xing_ming_: ypInfoList[index].xing_ming_=== undefined?'':ypInfoList[index].xing_ming_,
  759. xing_bie_: ypInfoList[index].xing_bie_=== undefined?'':ypInfoList[index].xing_bie_,
  760. nian_ling_: ypInfoList[index].nian_ling_=== undefined?'':ypInfoList[index].nian_ling_,
  761. yang_ben_zhuang_t: item.yang_pin_zhuang_t,
  762. shou_yang_ri_qi_: currentTime,
  763. bei_zhu_: ypInfoList[index].bei_zhu_1_ === undefined?'':ypInfoList[index].bei_zhu_1_,
  764. yang_ben_lei_xing: yblx,
  765. yun_shu_tiao_jian: ystj,
  766. yang_pin_shu_lian: ypsl,
  767. yang_ben_gui_ge_s: ybgg,
  768. yan_shou_jie_guo_: ypInfoList[index].yan_shou_jie_guo_,
  769. cun_fang_wei_zhi_: sywz,
  770. liu_zhuan_zhuang_: '待任务分配',
  771. shi_fou_liu_yang_: ifLy,
  772. liu_yang_ri_qi_: ifLy == '是'? ypInfoList[index].liu_yang_ri_qi_:'',
  773. liu_yang_cun_fang: ifLy == '是'?lycf:'',
  774. liu_yang_shu_lian: ifLy == '是'? (lysl == null ?'':lysl) : '',
  775. liu_yang_qi_xian: ifLy == '是'? ypInfoList[index].liu_yang_qi_xian:'',
  776. xiao_hui_ri_qi_: ypInfoList[index].xiao_hui_ri_qi_=== undefined?'':ypInfoList[index].xiao_hui_ri_qi_,
  777. fan_yang_ri_qi_: ypInfoList[index].fan_yang_ri_qi_=== undefined?'':ypInfoList[index].fan_yang_ri_qi_,
  778. fan_yang_jyr: ypInfoList[index].fan_yang_jyr=== undefined?'':ypInfoList[index].fan_yang_jyr,
  779. biao_zhi_uuid_: currentUUID,
  780. song_yang_yao_qiu: ypInfoList[index].song_yang_yao_qiu=== undefined?'':ypInfoList[index].song_yang_yao_qiu,
  781. jian_ce_xiang_mu_: xiangMuZh,
  782. shou_yang_ren_:this.$store.getters.userInfo.user.name,
  783. wei_tuo_lei_xing_:item.wei_tuo_lei_xing_
  784. }
  785. // console.log(obj)
  786. ypdjb.push(obj)
  787. }
  788. // 2-2:封装任务分配表
  789. let rw = {
  790. yang_pin_ming_che: item.yang_pin_ming_che,
  791. yang_pin_bian_hao: item.yang_pin_bian_hao,
  792. wei_tuo_lei_xing_: item.wei_tuo_lei_xing_,
  793. yang_pin_lei_xing: yplxz,
  794. yang_pin_gui_ge_: ypggStr,
  795. wei_tuo_id_: item.wtID,
  796. he_tong_id_: item.he_tong_id_,
  797. zhuang_tai_: '待任务分配',
  798. wan_cheng_shi_jia: item.song_jian_shi_jia,
  799. shou_yang_ri_qi_: currentTime,
  800. bao_gao_lei_xing_: item.bao_gao_lei_xing_,
  801. xin_xiang_mu_ming: item.xiang_mu_ming_che,
  802. zhan_shi_biao_id_: item.zhan_shi_biao_id_,
  803. fen_zhuang_liu_ya: liuyangStr,
  804. shi_fou_jia_ji_: item.chu_ju_bao_gao_ya, // 是否加急【2023/2/23王嘎嘎提出】
  805. yang_pin_shu_lian: ypInfoList[index].jie_yang_shu_lian, // 样品确认总数【2023/3/7王嘎嘎提出】
  806. suo_you_xiang_mu_: xiangMuZh, // 所有项目的中文名称 【2023/12/11 Mr王】
  807. song_jian_pi_hao_: item.song_jian_pi_hao_// 送检批号 【2023/12/11 Mr王】
  808. }
  809. rws.push(rw)
  810. lhwtzsbID.push('{"shen_qing_id_":"' + item.zhan_shi_biao_id_ + '"}')
  811. lhwtbID.push('{"id_":"' + item.wtID + '"}')
  812. })
  813. /* 4、任务分配
  814. 4-1、根据 wtdAndYpb 的 wtID 更改委托表的 委托状态 wei_tuo_zhuang_ta 变成 已完成
  815. 4-2、根据每个样品一个任务分配流程 遍历样品表开任务分配流程
  816. 4-3、委托表找zhan_shi_biao_id_ 修改 t_lhwtzsb "zhuang_tai_"为"任务分配进行中"
  817. 优化:将其他不冲突的更改状态脚本放在任务分配后并行处理
  818. */
  819. // console.log("4、任务分配",rws) 2023/12/11 Mr王 去掉 ,"defKey":"Process_04o0csc","formKey":"lhrwfp"
  820. repostCurd('add', '{"tableName":"t_lhrwfpb","paramWhere":' + JSON.stringify(rws) + '}').then(res=>{
  821. // console.log('4、更改委托表的 委托状态',lhwtbID)
  822. repostCurd('updates', '{"tableName":"t_lhwtsqb","paramWhere":[' + lhwtbID + '],"paramCond":{"wei_tuo_zhuang_ta":"已完成"}}')
  823. /* 5、更新展示表 */
  824. if (lhwtzsbID.length > 0) {
  825. // console.log('5、更新展示表',lhwtzsbID)
  826. repostCurd('updates', '{"tableName":"t_lhwtzsb","paramWhere":[' + lhwtzsbID + '],"paramCond":{"zhuang_tai_":"任务分配进行中"}}')
  827. }
  828. console.log('样品登记表:',ypdjb)
  829. if(ypdjb.length > 0){
  830. repostCurd('add', '{"tableName":"t_lhypdjb","paramWhere":' + JSON.stringify(ypdjb) + '}').then(()=>{
  831. console.log("样品登记表数据添加成功!")
  832. this.$emit('callback', true)
  833. }).catch(error =>{
  834. console.log(error)
  835. this.handleAnySituation(true,"样品登记表数据添加失败!请勿关闭此页面,联系开发人员解决",'error')
  836. })
  837. }else{
  838. this.handleAnySituation(true,"样品登记表数据添加失败!请勿关闭此页面,联系开发人员解决",'error')
  839. }
  840. /* 3、更新样品表
  841. // console.log('3、更新样品表',lhypIdNewList)
  842. repostCurd('updates', '{"tableName":"t_lhypb","paramWhere":[' + lhypIdNewList + '],"paramCond":{"jie_yang_zhuang_t":"已接收"}}').then(res=>{
  843. this.handleAnySituation(true,"样品成功接收,正在开启任务分配!",'success')
  844. })
  845. */
  846. console.log('更新样品表',sampleList)
  847. let allSampleParams ={
  848. tableName:'t_lhypb',
  849. updList:sampleList
  850. }
  851. repostCurd('updatesByWhere', JSON.stringify(allSampleParams)).then(res=>{
  852. this.handleAnySituation(true,"样品成功接收,正在开启任务分配!",'success')
  853. })
  854. })
  855. })
  856. })
  857. }
  858. })
  859. }).catch(_ => { });
  860. }
  861. },
  862. /* 去除指定行数据 使用过滤器filter过滤指定行号数据 */
  863. deleteData(val) {
  864. this.listData = this.listData.filter((data) => {
  865. return data.id_ != val
  866. })
  867. },
  868. unique(arr) {
  869. return arr.filter((item, index) => {
  870. return arr.indexOf(item, 0) === index;
  871. });
  872. },
  873. uuid() {
  874. var s = [];
  875. var hexDigits = "0123456789abcdef";
  876. for (var i = 0; i < 36; i++) {
  877. s[i] = hexDigits.substr(Math.floor(Math.random() * 0x10), 1);
  878. }
  879. s[14] = "4"; // bits 12-15 of the time_hi_and_version field to 0010
  880. s[19] = hexDigits.substr((s[19] & 0x3) | 0x8, 1); // bits 6-7 of the clock_seq_hi_and_reserved to 01
  881. s[8] = s[13] = s[18] = s[23] = "-";
  882. var uuid = s.join("");
  883. return uuid;
  884. },
  885. // 根据旧位置数据生成新位置数据
  886. generateNewLocation(oldLocation, sampleInfo) {
  887. // console.log(oldLocation)
  888. let temp = {
  889. fang_jian_lei_xin: oldLocation.fang_jian_lei_xin,
  890. wei_zhi_: oldLocation.wei_zhi_,
  891. qu_yu_: oldLocation.qu_yu_,
  892. huo_jia_lei_xing_: oldLocation.huo_jia_lei_xing_,
  893. huo_jia_hao_: oldLocation.huo_jia_hao_,
  894. ceng_hao_: oldLocation.ceng_hao_,
  895. shui_ping_fen_qu_: oldLocation.shui_ping_fen_qu_,
  896. wei_zhi_bian_hao_: oldLocation.wei_zhi_bian_hao_,
  897. wei_zhi_zhuang_ta: oldLocation.wei_zhi_zhuang_ta,
  898. cun_chu_tiao_jian: oldLocation.cun_chu_tiao_jian,
  899. shi_fou_guo_shen_: '启用',
  900. yang_pin_bian_hao: sampleInfo.yang_pin_bian_hao,
  901. yang_pin_ming_che: sampleInfo.yang_pin_ming_che,
  902. ru_ku_shi_jian_: sampleInfo.ru_ku_shi_jian_,
  903. shi_fou_liu_yang_: sampleInfo.shi_fou_liu_yang_,
  904. biao_zhi_uuid_: sampleInfo.biao_zhi_uuid_,
  905. yang_pin_lei_xing: sampleInfo.type,
  906. liu_yang_shu_lian: sampleInfo.num
  907. }
  908. return temp
  909. },
  910. handleLocationInfo(currentLocation, isLiuYang, localInfo, locationIds, item, UUID, currentTime,sampleType,liuYangNum) {
  911. !locationIds.has(currentLocation) ? locationIds.add(currentLocation) : localInfo.find(i => i.id_ === currentLocation).wei_zhi_zhuang_ta = '占用'
  912. if (localInfo.find(i => i.id_ === currentLocation)!=undefined &&localInfo.find(i => i.id_ === currentLocation).wei_zhi_zhuang_ta === '空余') {
  913. let obj = {
  914. where: {
  915. id_: currentLocation
  916. },
  917. param: {
  918. wei_zhi_zhuang_ta: "占用",
  919. ru_ku_shi_jian_: currentTime,
  920. yang_pin_bian_hao: item.yang_pin_bian_hao,
  921. yang_pin_ming_che: item.yang_pin_ming_che,
  922. shi_fou_liu_yang_: isLiuYang,
  923. yang_pin_lei_xing: sampleType,
  924. liu_yang_shu_lian: liuYangNum == null? '':liuYangNum
  925. }
  926. }
  927. let result = {
  928. name: 'emptyLocation',
  929. value: obj
  930. }
  931. return result
  932. } else { // 新增一条位置信息(修改它的样品编号,样品名称,入库时间,标识UUID)
  933. let sampleInfo = {
  934. yang_pin_bian_hao: item.yang_pin_bian_hao,
  935. yang_pin_ming_che: item.yang_pin_ming_che,
  936. ru_ku_shi_jian_: currentTime,
  937. biao_zhi_uuid_: UUID,
  938. shi_fou_liu_yang_: isLiuYang,
  939. type: sampleType,
  940. num: liuYangNum == null? '':liuYangNum
  941. }
  942. let newLocation = this.generateNewLocation(localInfo.find(i => i.id_ === currentLocation), sampleInfo)
  943. let result = {
  944. name: 'fullLocation',
  945. value: newLocation
  946. }
  947. return result
  948. }
  949. },
  950. /* 关闭*/
  951. remRedar() {
  952. this.visible = false // 列表隐藏
  953. this.listData = [] // 清空列表数据
  954. this.redar = false // 扫码图标隐藏
  955. this.$emit('scanOff', false)
  956. },
  957. }
  958. }