From 42474a7ce3521994560ef7810f670ec4c0411619 Mon Sep 17 00:00:00 2001 From: lkk <364857242@qq.com> Date: 星期三, 30 十月 2024 16:42:35 +0800 Subject: [PATCH] 10.30 --- src/views/sampling/sampling/index.vue | 285 +++++++++++++++++++++++++++++++-------------------------- 1 files changed, 155 insertions(+), 130 deletions(-) diff --git a/src/views/sampling/sampling/index.vue b/src/views/sampling/sampling/index.vue index 2894c72..fd4b7e1 100644 --- a/src/views/sampling/sampling/index.vue +++ b/src/views/sampling/sampling/index.vue @@ -274,7 +274,14 @@ <!-- 鍔ㄦ�佺敓鎴愬涓潯褰㈢爜鐨勫鍣� --> <div v-for="(item, index) in selectList" :key="index"> <svg :id="'barcode' + index"></svg> - <div class="name">{{ item.proName }}</div> + <div class="name">{{ getTruncatedName(item.proName).truncated }}</div> + <div class="name1"> + {{ getTruncatedName(item.proName).remaining }} + </div> + <!-- <div class="name">{{ item.proName.slice(0, msg) }}</div> + <div class="name1"> + {{ item.proName.slice(msg) }} + </div> --> <div class="last"> <p>{{ item.cusName }}</p> <div> @@ -285,6 +292,7 @@ <div class="tj"> <span>浣撴涓績</span> <span>{{ item.cardId.substring(0, 14) }}</span> + <!-- <span>{{ item.cardId ? item.cardId.substring(0, 14) : '' }}</span> --> </div> <div class="tj"> <span>{{ item.jyxh }}</span> @@ -347,10 +355,11 @@ getCusCyList, mergeCaiYang, chexiaoCaiYang, + getTxmmccd, + getTxmkd, } from "@/api/sampling/sampling"; import { getNewDateList } from "@/api/hosp/order"; import moment from "moment"; -import ItemVue from "../../../layout/components/Sidebar/Item.vue"; export default { dicts: [ @@ -363,6 +372,8 @@ name: "Sampling", data() { return { + msg: "", + getNumbr: null, list: [], selectList: [], selectedRows: [], @@ -446,7 +457,9 @@ }, created() { // this.getNowTime(); - + getTxmmccd().then((res) => { + this.msg = Number(res.msg); + }); this.getdate(); }, mounted() { @@ -462,7 +475,38 @@ ); }, }, + methods: { + getTruncatedName(proName) { + // 鍘绘帀鎵�鏈夌┖鏍� + const trimmedProName = proName.replace(/\s+/g, ""); + const number = this.msg; + + const truncated = + trimmedProName.length > number + ? trimmedProName.slice(0, number) + : trimmedProName; + const remaining = + trimmedProName.length > number ? trimmedProName.slice(number) : ""; + return { truncated, remaining }; // 杩斿洖缁撴灉 + }, + + /* getTruncatedName(proName) { + const trimmedProName = proName.replace(/\s+/g, ""); // 鍘绘帀鎵�鏈夌┖鏍� + const truncated = + trimmedProName.length > 35 + ? trimmedProName.slice(0, 35) + : trimmedProName; + const remaining = + trimmedProName.length > 35 ? trimmedProName.slice(35) : ""; + return { truncated, remaining }; + }, */ + + // 绀轰緥鐨勬棩鏈熸牸寮忓寲鏂规硶 + formatDate(date) { + const options = { year: "numeric", month: "2-digit", day: "2-digit" }; + return new Date(date).toLocaleDateString(undefined, options); + }, getdate() { getNewDateList().then((res) => { this.createTimeList = [ @@ -533,7 +577,7 @@ return; } else { this.samplingList = response.data.list; - console.log(this.samplingList, 888); + // console.log(this.samplingList, 888); // 鍒ゆ柇鏄惁闇�瑕佸埛鏂板彸杈硅〃鏍� this.$nextTick(() => { this.$refs.tb.toggleRowSelection(this.samplingList[0], true); @@ -603,7 +647,6 @@ this.resetForm("form"); }, hb() { - // console.log(this.queryParams.tjNum); if (this.queryParams.tjNum != null) { this.handleQuery(); } @@ -671,13 +714,11 @@ fetchData(cusId) { this.loading = true; // 鏄剧ず鍔犺浇鐘舵�� - console.log(this.tjStatus, 999); - getCusCyList(cusId, this.tjStatus) // 璋冪敤API鑾峰彇鏁版嵁 .then((response) => { if (response.data) { this.tableList = response.data; // 纭 list 瀛樺湪鍚庡啀杩涜璧嬪�� - console.log(this.tableList, 123); + // console.log(this.tableList, 123); } else { // 濡傛灉娌℃湁鏁版嵁鎴� list 涓虹┖锛屾竻绌鸿〃鏍煎苟鎻愮ず this.tableList = []; @@ -691,35 +732,6 @@ }); }, - /* 鐐瑰嚮鍚堝苟鎸夐挳 */ - /* Merging() { - // 妫�鏌ユ槸鍚﹂�変腑浜嗘暟鎹� - if (this.selectedRows.length === 0) { - this.$message.error("鑷冲皯閫変腑涓�涓汉"); - return; - } - - if (this.selectList.length === 0) { - this.$message.error("璇烽�夋嫨瑕佸悎骞堕」鐩�"); - return; - } - - // 鑾峰彇 tableList 绗竴琛岀殑 specimenTypeCode 浣滀负鍩哄噯 - const baseSpecimenTypeCode = this.selectList[0].specimenTypeCode; - - // 妫�鏌� specimenTypeCode 鏄惁涓�鑷� - const canMergeBySpecimenTypeCode = this.selectList.every( - (row) => row.specimenTypeCode === baseSpecimenTypeCode - ); - - // 鏍规嵁 canMergeBySpecimenTypeCode 鍒ゆ柇鏄惁鍚堝苟 - if (canMergeBySpecimenTypeCode) { - this.$message.success("鍚堝苟鎴愬姛銆�"); - console.log("鍚堝苟鐨勮:", this.selectedRows); - } else { - this.$message.error("椤圭洰鐨� 涓嶄竴鑷达紝鏃犳硶鍚堝苟锛�"); - } - }, */ /* 鐐瑰嚮鍚堝苟鎸夐挳 */ Merging() { // 妫�鏌ユ槸鍚﹂�変腑浜嗘暟鎹� @@ -745,7 +757,7 @@ mergeCaiYang(data).then((response) => { this.$message.success("鍚堝苟鎴愬姛銆�"); - console.log("鍚堝苟鐨勮:", this.selectedRows); + // console.log("鍚堝苟鐨勮:", this.selectedRows); // this.getList(); this.fetchData(this.selectedRows[0].cusId); }); @@ -767,7 +779,7 @@ return; } - console.log("鎾ら攢鐨勫凡鍚堝苟椤圭洰ID:", data); + // console.log("鎾ら攢鐨勫凡鍚堝苟椤圭洰ID:", data); // 璋冪敤鎾ら攢閲囨牱鐨勬帴鍙� chexiaoCaiYang(data) @@ -784,20 +796,21 @@ .catch((error) => { this.$message.error("璇锋眰澶辫触锛岃閲嶈瘯锛�"); }); - - // chexiaoCaiYang(data).then((res) => {}); }, /** 鐐瑰嚮琛ユ墦鏉$爜鎸夐挳 **/ - Collection() { - const jyxh = this.selectList.map((item) => item.jyxh); - // const selectedData = this.selectList.map((item) => ({ - // jyxh: item.jyxh, - // })); - console.log(this.selectList, 999); - // console.log(selectedData, 888); + async Collection() { + try { + // 璇锋眰鎺ュ彛骞惰幏鍙栧搴﹀�� + const widthResponse = await getTxmkd(); + // console.log("浠� getTxmkd 杩斿洖鐨勫搷搴�:", widthResponse); // 鎵撳嵃鍚庣杩斿洖鍊� + const barcodeWidth = `${Number(widthResponse.msg)}%` || "70%"; // 鑾峰彇瀹藉害鍊硷紝榛樿浣跨敤 70% - this.$nextTick(() => { + const jyxh = this.selectList.map((item) => item.jyxh); + // console.log(this.selectList, 999); + + await this.$nextTick(); // 纭繚 DOM 鏇存柊 + jyxh.forEach((number, index) => { const barcodeContent = number; // 纭繚 jyxh 鏄湁鏁堢殑 if (barcodeContent && barcodeContent !== "鏈彁渚涗綋妫�鍙�") { @@ -811,16 +824,15 @@ console.log(`鏉″舰鐮佸唴瀹规棤鏁�: ${barcodeContent}`); // 璋冭瘯杈撳嚭 } }); - }); - this.$nextTick(() => { - const barcodeElement = document.querySelector("#barcode"); - // const barcodeElements = selectedData.map((_, index) => - // document.querySelector(`#barcode${index}`) - // ); + await this.$nextTick(); // 纭繚鏉″舰鐮佺敓鎴愬畬鎴� - if (barcodeElement) { - barcodeElement.forEach((element) => { + const barcodeElements = jyxh.map((_, index) => + document.querySelector(`#barcode${index}`) + ); + + if (barcodeElements) { + barcodeElements.forEach((element) => { if (element) { console.log(element.innerHTML); // 鎵撳嵃鏉″舰鐮佺殑鍐呭锛岀湅鐪嬫槸鍚︾敓鎴愭垚鍔� } @@ -828,83 +840,93 @@ } else { console.log("鏉″舰鐮佸厓绱犳湭鎵惧埌"); } + const newWindow = window.open("", "_blank", "width=800,height=600"); const printContents = document.getElementById("printSection").innerHTML; console.log(printContents); newWindow.document.write(` - <html> + <html> <head> <title>Print Barcode</title> <style> @media print { - * { - margin: 0; - padding: 0; /* 閲嶇疆鎵�鏈夊厓绱犵殑 margin 鍜� padding */ - box-sizing: border-box; /* 浣垮唴杈硅窛鍜岃竟妗嗗寘鍚湪鍏冪礌鐨勬�诲搴﹀拰楂樺害鍐� */ - } - body { - margin: 0; - padding: 0; - } - .barcode-container { - width: 100%; /* 鏍规嵁闇�瑕佽皟鏁� */ - text-align: center; /* 纭繚鏉″舰鐮佸眳涓� */ - } - .name { - padding: 0; - margin: -5px auto 0; - padding-left: 20px; - font-size: 18px; - width: 90%; - display: -webkit-box; - -webkit-box-orient: vertical; - -webkit-line-clamp: 2; - overflow: hidden; - white-space: normal; - } + * { + margin: 0; + padding: 0; /* 閲嶇疆鎵�鏈夊厓绱犵殑 margin 鍜� padding */ + box-sizing: border-box; /* 浣垮唴杈硅窛鍜岃竟妗嗗寘鍚湪鍏冪礌鐨勬�诲搴﹀拰楂樺害鍐� */ + } + .name, .name1, .last, .tj, .last div span, .last p, .tj span { + font-family: Arial, sans-serif !important; /* 閲嶆柊鎸囧畾瀛椾綋 */ + font-weight: bold !important; /* 寮哄埗鍔犵矖 */ + } + body { + margin: 0; + padding: 0; + } + .barcode-container { + // width: 100%; /* 鏍规嵁闇�瑕佽皟鏁� */ + // text-align: center; /* 纭繚鏉″舰鐮佸眳涓� */ + } + .name, .name1 { + padding: 0; + font-size: 18px; + width: 70%; + font-family: "Arial Black", sans-serif; /* 璁剧疆榛戜綋 */ + } + p { + margin: 0; + padding: 0; + } + svg { + display: block; + width: ${barcodeWidth}; /* 浣跨敤浠庢帴鍙h幏鍙栫殑瀹藉害 */ + margin-left: 10mm; + height: auto; + margin-bottom: 0; + } + .last { + width: 66%; + display: flex; + font-size: 19px; + justify-content: space-between; + // font-family: "Arial Black", sans-serif !important; + } + .last div span { + margin-left: 10px; + // font-family: "Arial Black", sans-serif !important; + } + .last p { + margin-left: 10px; + // font-family: "Arial Black", sans-serif !important; + } p { - margin: 0; - padding: 0; - } - svg { - display: block; - width: 70%; - margin: 0 auto; - height: auto; - margin-bottom: 0; - } - .last { - width: 66%; - display: flex; - font-size: 19px; - margin-left: 20px; - justify-content: space-between; - } - .last div span{ - margin-left: 10px - } - .tj{ - width: 70%; - display: flex; - font-size: 19px; - margin-left: 10px; - justify-content: space-between; - } - .tj span{ - margin-left:10px; - } + margin-left: 10px; + // font-family: "Arial Black", sans-serif !important; + } + .tj { + width: 70%; + display: flex; + font-size: 19px; + justify-content: space-between; + font-family: "Arial Black", sans-serif !important; + } + .tj span { + margin-left: 10px; + } } </style> </head> <body>${printContents}</body> </html> - `); + `); newWindow.document.close(); newWindow.focus(); newWindow.print(); newWindow.close(); - }); + } catch (error) { + console.error("鑾峰彇瀹藉害鏃跺嚭閿�:", error); // 鎹曡幏閿欒 + } }, tableRowClassName({ row, rowIndex }) { @@ -916,8 +938,8 @@ }, handleChange(selection) { - console.log(selection); - + // console.log(selection); + this.selectList = selection; this.ids = selection.map((item) => item.id); @@ -943,10 +965,23 @@ this.$message.error("娌℃湁宸插悎骞剁殑椤圭洰鍙互鎾ら攢锛�"); return; } - confirmSampling(data).then((res) => { - this.$modal.msgSuccess("閲囨牱鎴愬姛"); - this.getList(); + const loadingInstance = this.$loading({ + lock: true, // 閿佸畾灞忓箷 + text: "鍔犺浇涓�...", // 鍔犺浇鏂囨湰 + spinner: "el-icon-loading", // 鑷畾涔夊姞杞藉浘鏍� + background: "rgba(255, 255, 255, 0.7)", // 鑳屾櫙棰滆壊 }); + confirmSampling(data) + .then((res) => { + this.$modal.msgSuccess("閲囨牱鎴愬姛"); + this.getList(); + }) + .catch((error) => { + this.$message.error("閲囨牱澶辫触"); + }) + .finally(() => { + loadingInstance.close(); + }); }, // 鍗曢�夋寜閽� @@ -1015,14 +1050,4 @@ .el-table .warning-row { background-color: #e5f3ff !important; } -/* .last { - display: flex; - justify-content: space-around; - justify-content: space-evenly; - background-color:aqua -} */ -/* .last p:nth-child(2) { - margin: 20px; - font-size: 16px; -} */ </style> -- Gitblit v1.8.0