From b6200ca167033983858e96a1176a149dd43d37a5 Mon Sep 17 00:00:00 2001
From: eight <641137800@qq.com>
Date: 星期一, 04 十一月 2024 09:51:34 +0800
Subject: [PATCH] update
---
src/views/ecg/doctor/components/DevReadyPanel.vue | 137 +++++++++++++++++++++++++++++++++++++++++----
1 files changed, 123 insertions(+), 14 deletions(-)
diff --git a/src/views/ecg/doctor/components/DevReadyPanel.vue b/src/views/ecg/doctor/components/DevReadyPanel.vue
index 153682f..c058733 100644
--- a/src/views/ecg/doctor/components/DevReadyPanel.vue
+++ b/src/views/ecg/doctor/components/DevReadyPanel.vue
@@ -1,3 +1,4 @@
+<!--璁惧棰嗙敤鐣岄潰-->
<template>
<!-- 褰撳墠鎮h��: {{patient?.patId}} {{isStringEmpty(patient?.patName)?'鏃�':patient.patName}}-->
@@ -18,7 +19,7 @@
</el-form-item>
<el-form-item label="鎮h�呮弿杩�" prop="patDeptDesc">
- 绉戝: {{formData.patDeptDesc}} 鐥呭尯: {{formData.patWardDesc}} 搴婁綅: {{formData.patBedNo}}
+ {{formData.patDetails}}
</el-form-item>
<el-form-item label="璁惧缂栧彿" prop="devId">
<el-input v-model="formData.devId" placeholder="璇疯緭鍏ヨ澶囩紪鍙�" @input="getDevInfo"/>
@@ -26,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">
@@ -46,7 +47,7 @@
</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="cancelInstall" :disabled="formLoading">鏀惧純瑁呮満</el-button>
<!-- 鍖荤敓瑁呮満鍒楄〃 -->
@@ -126,11 +127,15 @@
import { DevRentApi, DevRentVO } from '@/api/ecg/devrent'
import {QueueVO} from "@/api/ecg/queue";
import {isStringEmpty} from "@/utils/stringUtil";
-import {dateFormatter, timeFormatter} from "@/utils/formatTime";
+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 {PatientStatisticVO, RoomBedVO} from "@/api/ecg/doctor";
+import {calculateAge, curDayEnd, curDayStart, formatTimestamp} from "@/utils/dateUtil";
+import {RoomBedVO} from "@/api/ecg/doctor";
+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' })
@@ -150,7 +155,8 @@
const dialogVisible = ref(false) // 寮圭獥鐨勬槸鍚﹀睍绀�
const formLoading = ref(false) // 琛ㄥ崟鐨勫姞杞戒腑锛�1锛変慨鏀规椂鐨勬暟鎹姞杞斤紱2锛夋彁浜ょ殑鎸夐挳绂佺敤
-const formType = ref('create') // 琛ㄥ崟鐨勭被鍨嬶細create - 鏂板锛泆pdate - 淇敼
+
+const checkTypeStore = useCheckTypeStoreWithOut()
const formData = ref({
id: undefined,
@@ -162,6 +168,7 @@
patWardCode: undefined,
patWardDesc: undefined,
patBedNo: undefined,
+ patDetails: undefined,
rentTime: new Date().getTime(),
returnTime: undefined,
interference: undefined,
@@ -189,6 +196,28 @@
purchaseDate: 0,
state: 0,
})
+
+const getRentInfoByPatId = () => {
+ const tempPatId = formData.value.patId;
+ resetForm()
+ if (isStringEmpty(tempPatId))
+ return
+
+ formData.value.patId = tempPatId;
+ getFreeRentInfo(formData.value)
+}
+
+// 鏍规嵁鎮h�呮垨璁惧, 鑾峰彇 Free鐨勭璧�
+const getFreeRentInfo = async (devRentVO) => {
+ const data = await DevRentApi.getFreeRent(devRentVO)
+ if (null === data)
+ return
+
+ // formDate 瀵瑰簲 DevRent
+ // formData.value = data //涓嶈兘鏁翠釜璧嬪�硷紝 榛樿棰嗙敤鏃堕棿琚竻绌�
+ formData.value.id = data.id;
+ formData.value.patDetails = data.patDetails
+}
/** 鎻愪氦琛ㄥ崟 */
const submitForm = async () => {
@@ -260,10 +289,16 @@
deviceInfo.value.state = 0
}
+// const setPatient = (queueVO: QueueVO | undefined) => {
+// resetForm()
+// formData.value.patId = queueVO?.patId
+// formData.value.patName = queueVO?.patName
+// }
const setPatient = (queueVO: QueueVO | undefined) => {
resetForm()
formData.value.patId = queueVO?.patId
formData.value.patName = queueVO?.patName
+ getFreeRentInfo(formData.value)
}
defineExpose({ setPatient }) // 鎻愪緵 setPatient 鏂规硶锛岀敤浜庤缃偅鑰�
@@ -307,12 +342,86 @@
formData.value = await DevRentApi.getDevRent(rentId)
}
-const printBill = async () => {
- ElNotification({
- title: '娓╅Θ鎻愮ず',
- message: '寰呭疄鐜帮紒',
- type: 'warning'
- })
+const printBill = async (patId: string) => {
+
+ const curAppointment: AppointmentVO = await AppointmentApi.getCurAppointmentByPatId( patId )
+ console.info( curAppointment )
+
+// 寮曞叆鍚庝娇鐢ㄧず渚�
+ hiprint.init({
+ // 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: 15, top: 20, left: 20, title: checkTypeName, textAlign: 'center', fontSize: 11 } });
+ const patientBaisc = curAppointment.patName + " " + calGender(curAppointment.patGender) + " " + calculateAge(curAppointment.patBirthday) + "宀�"
+ panel.addPrintText({ options: { width: 140, height: 15, top: 40, left: 20, title: patientBaisc, textAlign: 'center' , fontSize: 11} });
+ const ward_bed = curAppointment.patWardDesc + "-" + curAppointment.patBedNo
+ panel.addPrintText({ options: { width: 140, height: 15, top: 60, left: 20, title: ward_bed, textAlign: 'center', fontSize: 11 } });
+ const bookTime = formatTimestamp(curAppointment.bookDate) + " " + getBookBeginTime(curAppointment.bookTimeslot)
+ panel.addPrintText({ options: { width: 140, height: 15, top: 80, left: 20, title: bookTime, textAlign: 'center', fontSize: 10 } });
+ panel.addPrintText({ options: { width: 140, height: 15, top: 100, left: 20, title: curAppointment.patId, textAlign: 'center', fontSize: 10} });
+ panel.addPrintText({ options: { width: 140, height: 15, top: 120, left: 20, title: curAppointment.patMobile, textAlign: 'center', fontSize: 10 } });
+//鏉″舰鐮�
+ panel.addPrintText({ options: { width: 140, height: 35, top: 140, left: 20, title: curAppointment.patId, textType: 'barcode' } });
+
+//鎵撳嵃
+ hiprintTemplate.print([{},{},{}]); // 鍙互浼� [瀹氫綅鍙傛暟] 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 绀轰緥
+// 寮曞叆鍚庝娇鐢ㄧず渚�
+ hiprint.init({
+ // 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 });
+//鏂囨湰
+ panel.addPrintText({ options: { width: 140, height: 15, top: 20, left: 20, title: 'hiprint鎻掍欢鎵嬪姩娣诲姞text', textAlign: 'center' } });
+//鏉″舰鐮�
+ panel.addPrintText({ options: { width: 140, height: 35, top: 40, left: 20, title: '123456', textType: 'barcode' } });
+//浜岀淮鐮�
+ 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: [
+ {
+ text: 'Hello World!'
+ },
+ {
+ html: '<div><h1>Hello World!</h1></div>',
+ pageBreak: true
+ },
+ {
+ image: 'image.png'
+ }
+ ]
+});
+*/
+
+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 () => {
--
Gitblit v1.9.3