From 491955d354201d9013f74cd21e824f30611bbb60 Mon Sep 17 00:00:00 2001
From: eight <641137800@qq.com>
Date: 星期三, 06 十一月 2024 18:17:05 +0800
Subject: [PATCH] 检查类型相关
---
src/views/ecg/doctor/components/DevReadyPanel.vue | 71 +++++++++++++++++++++++++++++------
1 files changed, 59 insertions(+), 12 deletions(-)
diff --git a/src/views/ecg/doctor/components/DevReadyPanel.vue b/src/views/ecg/doctor/components/DevReadyPanel.vue
index e273b17..8179fd1 100644
--- a/src/views/ecg/doctor/components/DevReadyPanel.vue
+++ b/src/views/ecg/doctor/components/DevReadyPanel.vue
@@ -47,7 +47,8 @@
</el-form>
<el-button @click="submitForm" type="primary" :disabled="formLoading">棰嗙敤瀹屾垚</el-button>
<el-button @click="resetForm()">閲� 缃�</el-button>
- <el-button @click="printBill()">鎵撳嵃灏忕エ</el-button>
+ <el-button @click="printBill(formData.patId)">鎵撳嵃灏忕エ</el-button>
+ <el-button @click="printBill(formData.patId, 8)">鎵撳嵃灏忕エ2</el-button>
<el-button @click="cancelInstall" :disabled="formLoading">鏀惧純瑁呮満</el-button>
<!-- 鍖荤敓瑁呮満鍒楄〃 -->
@@ -130,9 +131,12 @@
import {dateFormatter} from "@/utils/formatTime";
import {JobRecordApi, JobRecordVO} from "@/api/ecg/jobrecord";
import {DeviceApi, DeviceVO} from "@/api/ecg/devmanage";
-import {curDayEnd, curDayStart} from "@/utils/dateUtil";
+import {calculateAge, curDayEnd, curDayStart, formatTimestamp} from "@/utils/dateUtil";
import {RoomBedVO} from "@/api/ecg/doctor";
-import {hiprint, defaultElementTypeProvider} from "vue-plugin-hiprint"
+import {hiprint} from "vue-plugin-hiprint";
+import {AppointmentApi, AppointmentVO} from "@/api/ecg/appointment";
+import { useCheckTypeStoreWithOut } from '@/store/modules/checkType'
+import {PrefixInteger} from "@/utils/formatter";
/** 璁惧棰嗙敤 琛ㄥ崟 */
defineComponent({ name: 'DevReadyPanel' })
@@ -152,6 +156,8 @@
const dialogVisible = ref(false) // 寮圭獥鐨勬槸鍚﹀睍绀�
const formLoading = ref(false) // 琛ㄥ崟鐨勫姞杞戒腑锛�1锛変慨鏀规椂鐨勬暟鎹姞杞斤紱2锛夋彁浜ょ殑鎸夐挳绂佺敤
+
+const checkTypeStore = useCheckTypeStoreWithOut()
const formData = ref({
id: undefined,
@@ -337,16 +343,44 @@
formData.value = await DevRentApi.getDevRent(rentId)
}
-const printBill = async () => {
- // ElNotification({
- // title: '娓╅Θ鎻愮ず',
- // message: '寰呭疄鐜帮紒',
- // type: 'warning'
- // })
+const printBill = async (patId: string, printMode?: number) => {
+
+ const curAppointment: AppointmentVO = await AppointmentApi.getCurAppointmentByPatId( patId )
+ console.info( curAppointment )
// 寮曞叆鍚庝娇鐢ㄧず渚�
hiprint.init({
-// host: 'http://192.168.2.100:17521',
+ // host: 'http://192.168.2.100:17521',
+ token: '111111'
+ });
+// 涓嬪垪鏂规硶閮芥槸娌℃湁鎷栨嫿璁捐椤甸潰鐨�, 鐩稿綋浜庝唬鐮佹ā寮�, 浣跨敤浠g爜璁捐椤甸潰
+// 鎯宠瀹炵幇鎷栨嫿璁捐椤甸潰,璇峰線涓嬬湅 '鑷畾涔夎璁�'
+ var hiprintTemplate = new hiprint.PrintTemplate(); // 鍙紶鍙傛暟
+ var panel = hiprintTemplate.addPrintPanel({ width: 100, height: 130, paperFooter: 340, paperHeader: 10 });
+//鏂囨湰
+ const checkTypeName = checkTypeStore.getCheckTypeName(curAppointment.bookCheckType)
+ panel.addPrintText({ options: { width: 140, height: 12, top: 2, left: 20, title: checkTypeName, textAlign: 'center', fontSize: 8 } });
+ const patientBaisc = curAppointment.patName + " " + calGender(curAppointment.patGender) + " " + calculateAge(curAppointment.patBirthday) + "宀�"
+ panel.addPrintText({ options: { width: 140, height: 12, top: 16, left: 20, title: patientBaisc, textAlign: 'center' , fontSize: 8 } });
+ const ward_bed = curAppointment.patWardDesc + "-" + curAppointment.patBedNo
+ panel.addPrintText({ options: { width: 140, height: 12, top: 30, left: 20, title: ward_bed, textAlign: 'center', fontSize: 8 } });
+ const bookTime = formatTimestamp(curAppointment.bookDate) + " " + getBookBeginTime(curAppointment.bookTimeslot)
+ panel.addPrintText({ options: { width: 140, height: 12, top: 44, left: 20, title: bookTime, textAlign: 'center', fontSize: 8 } });
+ panel.addPrintText({ options: { width: 140, height: 12, top: 58, left: 20, title: curAppointment.patId, textAlign: 'center', fontSize: 8 } });
+ panel.addPrintText({ options: { width: 140, height: 12, top: 72, left: 20, title: curAppointment.patMobile, textAlign: 'center', fontSize: 8 } });
+//鏉″舰鐮�
+ panel.addPrintText({ options: { width: 140, height: 22, top: 86, left: 20, title: curAppointment.patId, textType: 'barcode' } });
+
+//鎵撳嵃
+ if (undefined === printMode)
+ hiprintTemplate.print2([{},{},{}]); // 鍙互浼� [瀹氫綅鍙傛暟] http://https://ccsimple.github.io/sv-print-docs/config/template.html#%E8%87%AA%E5%AE%9A%E4%B9%89%E8%AE%BE%E8%AE%A1%E4%BD%BF%E7%94%A8%E7%A4%BA%E4%BE%8B
+ else
+ hiprintTemplate.print([{},{},{}]);
+}
+/* hiprint 绀轰緥
+// 寮曞叆鍚庝娇鐢ㄧず渚�
+ hiprint.init({
+ // host: 'http://192.168.2.100:17521',
token: '111111'
});
// 涓嬪垪鏂规硶閮芥槸娌℃湁鎷栨嫿璁捐椤甸潰鐨�, 鐩稿綋浜庝唬鐮佹ā寮�, 浣跨敤浠g爜璁捐椤甸潰
@@ -361,9 +395,9 @@
panel.addPrintText({ options: { width: 35, height: 35, top: 40, left: 165, title: '123456', textType: 'qrcode' } });
//闀挎枃鏈�
panel.addPrintLongText({ options: { width: 180, height: 35, top: 90, left: 20, title: '闀挎枃鏈細hiprint鏄竴涓緢濂界殑webjs鎵撳嵃,娴忚鍣ㄥ湪鐨勫湴鏂逛粬閮藉彲浠ヨ繍琛�' } });
-//鎵撳嵃
+//鎵撳嵃 鐩存帴鎵撳嵃
hiprintTemplate.print2({}); // 鍙互浼� [瀹氫綅鍙傛暟] http://https://ccsimple.github.io/sv-print-docs/config/template.html#%E8%87%AA%E5%AE%9A%E4%B9%89%E8%AE%BE%E8%AE%A1%E4%BD%BF%E7%94%A8%E7%A4%BA%E4%BE%8B
-}
+*/
/* 鍒嗛〉鎵撳嵃
HiPrint.print({
pages: [
@@ -381,6 +415,19 @@
});
*/
+const getBookBeginTime = (bookTimeslot: number): string => {
+ const hour = parseInt( bookTimeslot/1000000 );
+ const minute = parseInt( bookTimeslot/10000 ) % 100;
+ return PrefixInteger(hour,2) + ":" + PrefixInteger(minute, 2);
+}
+
+const calGender = (_gender: number): string => {
+ if (1 === _gender)
+ return "鐢�"
+ else
+ return "濂�"
+}
+
const getDevInfo = async () => {
deviceInfo.value.category = ''
deviceInfo.value.brand = ''
--
Gitblit v1.9.3