From b06a903d08d6f5432105d12686ccaf074b45323a Mon Sep 17 00:00:00 2001 From: lkk <364857242@qq.com> Date: 星期四, 24 十月 2024 08:58:35 +0800 Subject: [PATCH] lkk 10.24 --- src/views/system/bill/index.vue | 466 ++++++++++++++++++++++++++++++++++++--------------------- 1 files changed, 292 insertions(+), 174 deletions(-) diff --git a/src/views/system/bill/index.vue b/src/views/system/bill/index.vue index e59b977..ed34e17 100644 --- a/src/views/system/bill/index.vue +++ b/src/views/system/bill/index.vue @@ -18,7 +18,7 @@ </el-form-item> <el-form-item label="浣撴鍙�" prop="tjNum"> <el-input - ref="inputName" + ref="inputName" style="width: 170px" v-model="queryParams.tjNum" placeholder="璇疯緭鍏ヤ綋妫�鍙�" @@ -73,7 +73,8 @@ <el-button type="primary" icon="el-icon-search" - size="mini" style="margin-right:15px;" + size="mini" + style="margin-right: 15px" @click="handleQuery" >鎼滅储</el-button > @@ -84,27 +85,35 @@ </el-form-item> </el-form> - <el-row :gutter="10" class="mb8" style="margin-left:10px"> + <el-row :gutter="10" class="mb8" style="margin-left: 10px"> <el-col :span="1.5"> <el-button - type="primary" - @click="handleReport" - :disabled="single" - size="mini" - v-hasPermi="['hosp:order:export']" - >琛ユ墦瀵兼鍗�</el-button - > + type="primary" + @click="handleReport" + :disabled="single" + size="mini" + v-hasPermi="['hosp:order:export']" + >琛ユ墦瀵兼鍗�</el-button + > </el-col> - <el-col :span="1.5"> + <!-- <el-col :span="1.5"> <el-button - type="primary" - size="mini" - @click="Collection" - :disabled="single" - >鏉$爜鐢熸垚</el-button - > - </el-col> - + type="primary" + size="mini" + @click="Collection" + :disabled="single" + >鏉$爜鐢熸垚</el-button + > + </el-col> --> + <div id="printSection" style="display: none"> + <svg id="barcode"></svg> + </div> + <!-- <img id="base64Image" alt="Base64 Image" /> --> + <!-- 鐢ㄤ簬鏄剧ず鏉″舰鐮佺殑瀹瑰櫒 --> + <!-- <div id="printArea"> + <svg id="barcode" v-if="barcodeVisible"></svg> + </div> --> + <!-- <el-button type="primary" size="mini" :disabled="multiple" @click="viewReport">浣撴鎶ュ憡</el-button> <el-button type="primary" size="mini" :disabled="multiple" @click="printHandle">鎵撳嵃灏忕エ</el-button> --> <!-- <el-col :span="1.5"> @@ -126,145 +135,144 @@ 娴嬭瘯 </div> --> - - <el-table - border - style="margin: 14px; width: 99%" - v-loading="loading" - :default-sort="{ prop: 'createTime', order: 'descending' }" - :data="orderList" - @selection-change="handleSelectionChange" - ref="multipleTable" + <el-table + border + style="margin: 14px; width: 99%" + v-loading="loading" + :default-sort="{ prop: 'createTime', order: 'descending' }" + :data="orderList" + @selection-change="handleSelectionChange" + ref="multipleTable" + > + <el-table-column + type="selection" + width="40px" + align="center" + height="10px" + fixed="left" + /> + <el-table-column + label="搴忓彿" + align="center" + prop="newID" + width="50px" + fixed="left" + height="10px" + /> + <el-table-column + label="濮撳悕" + align="center" + prop="tjCustomerName" + height="10px" + width="90px" + :show-overflow-tooltip="true" + /> + <el-table-column + label="鎬у埆" + align="center" + prop="tjCustomerSex" + width="55px" + height="10px" + :show-overflow-tooltip="true" > - <el-table-column - type="selection" - width="40px" - align="center" - height="10px" - fixed="left" - /> - <el-table-column - label="搴忓彿" - align="center" - prop="newID" - width="50px" - fixed="left" - height="10px" - /> - <el-table-column - label="濮撳悕" - align="center" - prop="tjCustomerName" - height="10px" - width="90px" - :show-overflow-tooltip="true" - /> - <el-table-column - label="鎬у埆" - align="center" - prop="tjCustomerSex" - width="55px" - height="10px" - :show-overflow-tooltip="true" - > - <template slot-scope="scope"> - <span v-if="scope.row.tjCustomerSex == '0'">鐢�</span> - <span v-if="scope.row.tjCustomerSex == '1'">濂�</span> - <span v-if="scope.row.tjCustomerSex == '2'">鏈煡</span> - </template> - </el-table-column> - <el-table-column - label="骞撮緞" - align="center" - prop="tjCustomerAge" - height="10px" - width="60px" - :show-overflow-tooltip="true" - /> - <el-table-column - label="鐢佃瘽" - align="center" - prop="tjCustomerPhone" - :show-overflow-tooltip="true" - height="10px" - width="110px" - /> - <el-table-column - label="浣撴绫诲瀷" - align="center" - prop="tjType" - height="10px" - width="80px" - :show-overflow-tooltip="true" - > - <template slot-scope="scope"> - <span v-if="scope.row.tjType == '2'">涓汉</span> - <span v-if="scope.row.tjType == '1'">鍥㈤槦</span> - </template> - </el-table-column> - <el-table-column - label="浣撴鍙�" - align="center" - prop="tjNumber" - :show-overflow-tooltip="true" - width="160px" - /> - <el-table-column - label="鎵�閫夊椁�" - align="center" - prop="pacName" - height="10px" - :show-overflow-tooltip="true" - width="140px" - /> - <el-table-column - label="鐧昏浜�" - align="center" - prop="createBy" - height="10px" - :show-overflow-tooltip="true" - width="100px" - /> - <el-table-column - label="鐧昏鏃堕棿" - align="center" - prop="createTime" - width="155px" - height="10px" - sortable - :show-overflow-tooltip="true" - > - <template slot-scope="scope"> - <span>{{ parseTime(scope.row.createTime) }}</span> - </template> - </el-table-column> - <!-- <el-table-column label="瀹屾垚鏃堕棿" align="center" prop="finishTime" width="155px" height="10px" + <template slot-scope="scope"> + <span v-if="scope.row.tjCustomerSex == '0'">鐢�</span> + <span v-if="scope.row.tjCustomerSex == '1'">濂�</span> + <span v-if="scope.row.tjCustomerSex == '2'">鏈煡</span> + </template> + </el-table-column> + <el-table-column + label="骞撮緞" + align="center" + prop="tjCustomerAge" + height="10px" + width="60px" + :show-overflow-tooltip="true" + /> + <el-table-column + label="鐢佃瘽" + align="center" + prop="tjCustomerPhone" + :show-overflow-tooltip="true" + height="10px" + width="110px" + /> + <el-table-column + label="浣撴绫诲瀷" + align="center" + prop="tjType" + height="10px" + width="80px" + :show-overflow-tooltip="true" + > + <template slot-scope="scope"> + <span v-if="scope.row.tjType == '2'">涓汉</span> + <span v-if="scope.row.tjType == '1'">鍥㈤槦</span> + </template> + </el-table-column> + <el-table-column + label="浣撴鍙�" + align="center" + prop="tjNumber" + :show-overflow-tooltip="true" + width="160px" + /> + <el-table-column + label="鎵�閫夊椁�" + align="center" + prop="pacName" + height="10px" + :show-overflow-tooltip="true" + width="140px" + /> + <el-table-column + label="鐧昏浜�" + align="center" + prop="createBy" + height="10px" + :show-overflow-tooltip="true" + width="100px" + /> + <el-table-column + label="鐧昏鏃堕棿" + align="center" + prop="createTime" + width="155px" + height="10px" + sortable + :show-overflow-tooltip="true" + > + <template slot-scope="scope"> + <span>{{ parseTime(scope.row.createTime) }}</span> + </template> + </el-table-column> + <!-- <el-table-column label="瀹屾垚鏃堕棿" align="center" prop="finishTime" width="155px" height="10px" :show-overflow-tooltip="true"> <template slot-scope="scope"> <span>{{ parseTime(scope.row.finishTime) }}</span> </template> </el-table-column> --> - <!-- <el-table-column label="鎶ュ憡鏃堕棿" align="center" prop="reportTime" width="155px" height="10px" + <!-- <el-table-column label="鎶ュ憡鏃堕棿" align="center" prop="reportTime" width="155px" height="10px" :show-overflow-tooltip="true"> <template slot-scope="scope"> <span>{{ parseTime(scope.row.reportTime) }}</span> </template> </el-table-column> --> - <el-table-column - label="澶囨敞" - align="center" - prop="remark" - height="10px" - :show-overflow-tooltip="true" - /> - <!-- <el-table-column fixed="right" label="鎿嶄綔" align="center" class-name="small-padding fixed-width" height="10px" + <el-table-column + label="澶囨敞" + align="center" + prop="remark" + height="10px" + :show-overflow-tooltip="true" + /> + <!-- <el-table-column fixed="right" label="鎿嶄綔" align="center" class-name="small-padding fixed-width" height="10px" width="60px"> <template slot-scope="scope"> <el-button size="mini" type="text" icon="el-icon-document" @click="investigation(scope.row)" v-hasPermi="['hosp:order:edit']" title="璇︽儏" style="margin-right: 15px"></el-button> </template> </el-table-column> --> - </el-table> + </el-table> <div class="pag"> <div class="pag1"> @@ -459,7 +467,7 @@ </template> <script> -import print from "print-js"; + import { listOrder, getNumber, @@ -468,12 +476,13 @@ hasReport, hasPrintCode, getOrderList, - getNewDateList + getNewDateList, } from "@/api/hosp/order"; import moment from "moment"; import ViewPdf from "@/components/ViewPdf"; import { projectGetList, getOrder } from "@/api/system/tijian"; import { SubmitCompany, getCompany, queryCompany } from "@/api/team/tuanti"; +import JsBarcode from "jsbarcode"; export default { components: { ViewPdf, @@ -631,19 +640,32 @@ }, ], }, + barcode: "", // 瀛樺偍鏉$爜鍊� + barcodeVisible: false, // 鎺у埗鏉″舰鐮佹槸鍚﹀彲瑙� + single: false, // 鎺у埗鎸夐挳鏄惁绂佺敤鐨勬潯浠� }; }, created() { // this.getNowTime(); - + this.Company(); this.getdate(); }, - mounted() { - this.$nextTick(() => { - this.$refs.inputName.focus(); - }); - }, + // mounted() { + // // const base64String = + // // ""; + // // const binaryString = atob(base64String.split(",")[1]); + // // // 灏嗕簩杩涘埗鏁版嵁杞崲涓� Blob 瀵硅薄 + // // const blob = new Blob([binaryString], { type: "image/png" }); + // // // 鍒涘缓 URL 瀵硅薄骞跺皢鍏跺垎閰嶇粰鍥惧儚鐨� src 灞炴�� + // // const image = document.getElementById("base64Image"); + // // console.log(image, 1111); + // // // image.src = URL.createObjectURL(blob); + // // image.src = base64String; + // // this.$nextTick(() => { + // // this.$refs.inputName.focus(); + // // }); + // }, methods: { getdate() { getNewDateList().then((res) => { @@ -803,37 +825,88 @@ }); }, // 閲囪鍗� - Collection() { - let tjNumber = this.barcode; - hasPrintCode(tjNumber).then((response) => { - this.$message({ - showClose: true, - message: "鏉$爜宸茬敓鎴愶紒", - type: "success", - }); - }); - }, - - // onSubmit() { - // console.log("submit!"); + // Collection() { + // let tjNumber = this.barcode; + // hasPrintCode(tjNumber).then((response) => { + // this.$message({ + // showClose: true, + // message: "鏉$爜宸茬敓鎴愶紒", + // type: "success", + // }); + // }); // }, + // Collection() { + // let tjNumber = this.barcode; + // JsBarcode("#barcode", tjNumber, { + // format: "CODE128", + // width: 2, + // height: 100, + // displayValue: true, + // }); + + // this.$nextTick(() => { + // const barcodeElement = document.querySelector("#barcode"); + // if (barcodeElement) { + // console.log(barcodeElement.innerHTML); // 鎵撳嵃鏉″舰鐮佺殑鍐呭锛岀湅鐪嬫槸鍚︾敓鎴愭垚鍔� + // } else { + // console.log("鏉″舰鐮佸厓绱犳湭鎵惧埌"); + // } + + // const printContents = document.getElementById("printSection").innerHTML; + // const newWindow = window.open("", "_blank", "width=800,height=600"); + // console.log(printContents); + // newWindow.document.write(` + // <html> + // <head> + // <title>Print Barcode</title> + // <style> + // @media print { + // body { + // width: 80mm; + // margin: 0; + // padding: 0; + // height: 25mm; + // } + // /* 灏嗘潯褰㈢爜灞呬腑 */ + // #barcode { + // display: block; + // // margin-left: 50%; + // text-align: center; + // width: 100%; + // height: auto; + // } + // /* 璁╂潯褰㈢爜鍦ㄦ墦鍗版椂鏄剧ず */ + // svg { + // display: block; + // } + // </style> + // </head> + // <body>${printContents}</body> + // </html> + // `); + // newWindow.document.close(); + // newWindow.focus(); + // newWindow.print(); + // newWindow.close(); + // }); + // }, + dateChangebirthday1(val) { this.startTime = val; }, /** 鏌ヨ浣撴璁板綍鍒楄〃 */ getList() { - if(this.createTimeList){ + if (this.createTimeList) { this.queryParams.djbeginTime = this.createTimeList[0]; - this.queryParams.djendTime = this.createTimeList[1]; - }else if(this.createTimeList == null){ + this.queryParams.djendTime = this.createTimeList[1]; + } else if (this.createTimeList == null) { this.queryParams.djbeginTime = null; - this.queryParams.djendTime = null; - }else{ + this.queryParams.djendTime = null; + } else { this.queryParams.djbeginTime = this.startTime[0]; - this.queryParams.djendTime = this.startTime[1]; + this.queryParams.djendTime = this.startTime[1]; } - - + this.loading = true; getOrderList(this.queryParams).then((response) => { this.orderList = response.data.list; @@ -900,9 +973,9 @@ }; this.resetForm("form"); }, - hb(){ + hb() { // console.log(this.queryParams.tjNum); - if (this.queryParams.tjNum != undefined) { + if (this.queryParams.tjNum != undefined) { this.handleQuery(); } }, @@ -913,7 +986,7 @@ }, /** 閲嶇疆鎸夐挳鎿嶄綔 */ resetQuery() { - this.createTimeList=[] + this.createTimeList = []; this.resetForm("queryForm"); this.handleQuery(); }, @@ -1075,7 +1148,7 @@ }, }; </script> -<style lang="scss"> +<style lang="scss" scoped> .pag { width: 100%; display: flex; @@ -1173,4 +1246,49 @@ display: flex; justify-content: center; } + +.print-container { + width: 300px; /* 璁惧畾瀹藉害浠ョ‘淇濇墦鍗版椂甯冨眬鍚堥�� */ + padding: 10px; + border: 1px solid #000; /* 鍙�夛細缁欐墦鍗板尯鍩熷姞涓�涓竟妗� */ + font-family: Arial, sans-serif; +} + +.barcode-section { + text-align: center; + margin-bottom: 10px; +} + +.info-section { + font-size: 14px; + line-height: 1.5; +} + +.info-section p { + margin: 2px 0; /* 鎺у埗淇℃伅闂寸殑闂磋窛 */ +} + +#barcode { + display: block; + margin: 0 auto; +} + +.info-section p { + margin: 2px 0; + font-size: 14px; +} + +/* 鎵撳嵃鏃堕殣钘忔墍鏈夊叾浠栧唴瀹� */ +// @media print { +// #barcode { +// width: 58mm; +// height: auto; +// } +// #printSection { +// display: flex; +// justify-content: center; +// align-items: center; +// height: 100vh; /* 鐖跺鍣ㄩ珮搴︿负鍏ㄩ〉楂樺害 */ +// } +// } </style> -- Gitblit v1.8.0