From 280c74ead4a9f8034b5a783257a1ae514a02491c Mon Sep 17 00:00:00 2001
From: eight <641137800@qq.com>
Date: 星期三, 06 十一月 2024 16:47:49 +0800
Subject: [PATCH] 检查类型新增属性
---
src/views/ecg/doctor/components/DevReadyPanel.vue | 78 +++++++++++++++++++++++++++++++-------
1 files changed, 63 insertions(+), 15 deletions(-)
diff --git a/src/views/ecg/doctor/components/DevReadyPanel.vue b/src/views/ecg/doctor/components/DevReadyPanel.vue
index d7771ed..8179fd1 100644
--- a/src/views/ecg/doctor/components/DevReadyPanel.vue
+++ b/src/views/ecg/doctor/components/DevReadyPanel.vue
@@ -27,12 +27,12 @@
<el-form-item label="璁惧鎻忚堪" prop="">
{{deviceInfo.brand + " " + deviceInfo.model + " " + deviceInfo.state}}
</el-form-item>
- <el-form-item label="瑁呮満鏃堕棿" prop="rentTime">
+ <el-form-item label="棰嗙敤鏃堕棿" prop="rentTime">
<el-date-picker
v-model="formData.rentTime"
type="date"
value-format="x"
- placeholder="閫夋嫨瑁呮満鏃堕棿"
+ placeholder="閫夋嫨棰嗙敤鏃堕棿"
/>
</el-form-item>
<el-form-item label="澶囨敞" prop="remark">
@@ -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,
@@ -209,7 +215,8 @@
return
// formDate 瀵瑰簲 DevRent
- // formData.value = data //涓嶈兘鏁翠釜璧嬪�硷紝1.浼氬鑷� rent_id 鍑虹幇浠庤�屽奖鍝嶅悗绔�昏緫澶勭悊锛�2. 榛樿瑁呮満鏃堕棿琚竻绌�
+ // formData.value = data //涓嶈兘鏁翠釜璧嬪�硷紝 榛樿棰嗙敤鏃堕棿琚竻绌�
+ formData.value.id = data.id;
formData.value.patDetails = data.patDetails
}
@@ -336,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爜璁捐椤甸潰
@@ -360,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: [
@@ -380,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