vue2-client 1.14.32 → 1.14.33
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/Users/objecrt/af-vue2-client/src/base-client/components/his/XShiftSchedule/XShiftSchedule.vue +36 -0
- package/package.json +1 -1
- package/src/base-client/components/TreeList/TreeList.vue +91 -0
- package/src/base-client/components/TreeList/TreeNode.vue +81 -0
- package/src/base-client/components/common/XCardSet/XTiltle.vue +191 -0
- package/src/base-client/components/common/XReportGrid/XReportTrGroup.vue +4 -3
- package/src/base-client/components/his/XShiftSchedule/XShiftSchedule.vue +261 -0
- package/src/base-client/components/his/XShiftSchedule/dome.vue +23 -0
- package/src/base-client/components/his/XTextCard/XTextCard.vue +207 -207
- package/src/base-client/components/his/XTreeRows/TreeNode.vue +100 -100
- package/src/base-client/components/his/XTreeRows/XTreeRows.vue +197 -197
- package/src/base-client/components/his/threeTestOrders/editor.vue +111 -111
- package/src/base-client/components/his/threeTestOrders/textBox.vue +522 -522
- package/src/base-client/components/his/threeTestOrders/threeTestOrders.vue +386 -386
|
@@ -1,522 +1,522 @@
|
|
|
1
|
-
<script setup>
|
|
2
|
-
import { ref, reactive, watch } from 'vue'
|
|
3
|
-
import { message } from 'ant-design-vue'
|
|
4
|
-
import { runLogic } from '@vue2-client/services/api/common'
|
|
5
|
-
|
|
6
|
-
// 定义组件属性
|
|
7
|
-
const props = defineProps({
|
|
8
|
-
visible: Boolean,
|
|
9
|
-
id: {
|
|
10
|
-
type: Number,
|
|
11
|
-
default: 180
|
|
12
|
-
},
|
|
13
|
-
modalType: {
|
|
14
|
-
type: String,
|
|
15
|
-
default: 'create',
|
|
16
|
-
validator: (value) => ['create', 'update', 'baby'].includes(value)
|
|
17
|
-
},
|
|
18
|
-
editorReady: {
|
|
19
|
-
type: Boolean,
|
|
20
|
-
default: false
|
|
21
|
-
}
|
|
22
|
-
})
|
|
23
|
-
|
|
24
|
-
// 定义组件事件
|
|
25
|
-
const emit = defineEmits(['update:visible', 'submit', 'cancel'])
|
|
26
|
-
|
|
27
|
-
// 常量
|
|
28
|
-
const modalTitles = {
|
|
29
|
-
create: '创建体温单',
|
|
30
|
-
update: '更新体温单',
|
|
31
|
-
baby: '新生儿体温单'
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
// 响应式状态
|
|
35
|
-
const submitLoading = ref(false)
|
|
36
|
-
const formErrors = ref({})
|
|
37
|
-
|
|
38
|
-
// 表单数据
|
|
39
|
-
const formData = reactive({
|
|
40
|
-
id: '',
|
|
41
|
-
name: '',
|
|
42
|
-
inDate: '',
|
|
43
|
-
diag: '',
|
|
44
|
-
dept: '',
|
|
45
|
-
bed: '',
|
|
46
|
-
medicalNo: '',
|
|
47
|
-
begin: '',
|
|
48
|
-
operateDate: '',
|
|
49
|
-
notes: '',
|
|
50
|
-
sex: '男',
|
|
51
|
-
weight: '',
|
|
52
|
-
heart: '',
|
|
53
|
-
tempType: '',
|
|
54
|
-
temperature: '',
|
|
55
|
-
breath: '',
|
|
56
|
-
sphygmus: '',
|
|
57
|
-
physicalcool: '',
|
|
58
|
-
labels: '',
|
|
59
|
-
data1: '',
|
|
60
|
-
data2: '',
|
|
61
|
-
data3: '',
|
|
62
|
-
data4: '',
|
|
63
|
-
data5: '',
|
|
64
|
-
data6: '',
|
|
65
|
-
data7: '',
|
|
66
|
-
data8: '',
|
|
67
|
-
data9: '',
|
|
68
|
-
pain: ''
|
|
69
|
-
})
|
|
70
|
-
|
|
71
|
-
// 监听 props 变化初始化表单
|
|
72
|
-
watch(() => props.visible, (newVal, oldVal) => {
|
|
73
|
-
if (newVal) {
|
|
74
|
-
// 如果是从关闭状态变为打开状态,重置表单错误
|
|
75
|
-
formErrors.value = {}
|
|
76
|
-
|
|
77
|
-
// 无论何种模式,都先尝试从服务加载数据
|
|
78
|
-
initFormData()
|
|
79
|
-
} else if (oldVal && !newVal) {
|
|
80
|
-
// 当弹窗关闭时,清空表单数据,为下次打开做准备
|
|
81
|
-
resetForm()
|
|
82
|
-
}
|
|
83
|
-
}, { immediate: true })
|
|
84
|
-
|
|
85
|
-
watch(() => props.modalType, (newVal) => {
|
|
86
|
-
if (props.visible) {
|
|
87
|
-
// 无论何种模式,都先尝试从服务加载数据
|
|
88
|
-
initFormData()
|
|
89
|
-
}
|
|
90
|
-
})
|
|
91
|
-
|
|
92
|
-
watch(() => props.id, (newVal) => {
|
|
93
|
-
if (newVal) {
|
|
94
|
-
formData.id = newVal
|
|
95
|
-
}
|
|
96
|
-
}, { immediate: true })
|
|
97
|
-
|
|
98
|
-
// 重置表单为默认值
|
|
99
|
-
const resetForm = () => {
|
|
100
|
-
// 清空表单错误
|
|
101
|
-
formErrors.value = {}
|
|
102
|
-
|
|
103
|
-
const today = new Date().toISOString().split('T')[0]
|
|
104
|
-
const isBaby = props.modalType === 'baby'
|
|
105
|
-
|
|
106
|
-
// 重置所有字段
|
|
107
|
-
formData.id = props.id || (isBaby ? `BY${Date.now()}` : `VS${Date.now()}`)
|
|
108
|
-
formData.name = ''
|
|
109
|
-
formData.inDate = today
|
|
110
|
-
formData.diag = ''
|
|
111
|
-
formData.dept = isBaby ? '妇产科' : ''
|
|
112
|
-
formData.bed = ''
|
|
113
|
-
formData.medicalNo = ''
|
|
114
|
-
formData.begin = today
|
|
115
|
-
formData.operateDate = ''
|
|
116
|
-
formData.notes = isBaby ? '出生-十时二十分' : '入院-十时二十分,,转入ICU,,,,,,,手术,,,,,,,,,,,,,,,出院,死亡于×时×分'
|
|
117
|
-
formData.sex = '男'
|
|
118
|
-
formData.weight = isBaby ? '3200,,,,3300,,,,3400,,,,3400,,,,3500,,,,3400,,,,' : ''
|
|
119
|
-
formData.heart = '112,120,118,111,,,,,,,112,120,118,111'
|
|
120
|
-
formData.tempType = isBaby
|
|
121
|
-
? '2,2,2,3,2,1,2,2,2,1,2,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1'
|
|
122
|
-
: '0,1,2,3,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1'
|
|
123
|
-
formData.temperature = isBaby
|
|
124
|
-
? '37.7,37.9,38.5,37.1,37.5,38.5,,,37.5,38.5,37.4,37.8,,37.5,37.6,37.8,,37.9,37.8,37.5,38.6,37.8,,37.9,37.8'
|
|
125
|
-
: '38.7,38.9,38.5,39.1,38.5,38.5|37.1,38.5,38.5,,,38.5,38.5|36.9,38.4,38.8,,38.5,38.6,38.8,,38.9,38.8,38.5,38.6,38.8,,38.9,38.8,34,34.0'
|
|
126
|
-
formData.physicalcool = isBaby ? ',,,37.6,,,,,,,,37.5,,,,,,,,,37.4,,' : ''
|
|
127
|
-
formData.breath = '30,30,R,,35,35,35,35,35,35,35,35,,R,R,35,35,,R,,,35,35,,R'
|
|
128
|
-
formData.sphygmus = '112,110,109,103,108,85,90,83,90,103,108,85,90,83,90,,90,83,90,103,108,85,90,83,90'
|
|
129
|
-
formData.labels = isBaby
|
|
130
|
-
? '血压(mmHg)|入水量(ml)|出水量(ml)|大便(次)|小便(次)'
|
|
131
|
-
: '血压(mmHg)|入水量(ml)|出水量(ml)|大便(次)|小便(次)|身高(cm)|体重(kg)|过敏药'
|
|
132
|
-
formData.data1 = '120/85,121/84,,110/75,'
|
|
133
|
-
formData.data2 = '1180ml,,,500ml,,40ml'
|
|
134
|
-
formData.data3 = '500ml,,,,500ml,,67ml'
|
|
135
|
-
formData.data4 = '2,4,5,3,3,3,2,,2'
|
|
136
|
-
formData.data5 = '2,4,5,3,3,3,2,,2'
|
|
137
|
-
formData.data6 = '167cm,,,,,,,,,164cm'
|
|
138
|
-
formData.data7 = '95kg,,,,,90kg'
|
|
139
|
-
formData.data8 = '青霉素,'
|
|
140
|
-
formData.data9 = '测试,'
|
|
141
|
-
formData.pain = '2,2,4,5,8,8,9|2,6|3,,,4,4,4'
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
// 处理JSON字符串数据
|
|
145
|
-
const parseFormData = (data) => {
|
|
146
|
-
if (!data) return null
|
|
147
|
-
try {
|
|
148
|
-
// 如果是字符串,尝试解析为JSON
|
|
149
|
-
if (typeof data === 'string') {
|
|
150
|
-
return JSON.parse(data)
|
|
151
|
-
}
|
|
152
|
-
// 如果已经是对象且有f_data字段,尝试解析f_data
|
|
153
|
-
if (typeof data === 'object' && data.f_data) {
|
|
154
|
-
return JSON.parse(data.f_data)
|
|
155
|
-
}
|
|
156
|
-
// 如果是普通对象,直接返回
|
|
157
|
-
return data
|
|
158
|
-
} catch (error) {
|
|
159
|
-
console.error('解析数据失败:', error)
|
|
160
|
-
return null
|
|
161
|
-
}
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
// 初始化表单数据
|
|
165
|
-
const initFormData = async () => {
|
|
166
|
-
try {
|
|
167
|
-
let parsedData = null
|
|
168
|
-
let resultData = null
|
|
169
|
-
try {
|
|
170
|
-
// 尝试从服务器获取数据
|
|
171
|
-
resultData = await runLogic('threeTestOrderDataLOGIC', { id: props.id }, 'af-his')
|
|
172
|
-
console.log('体温单数据 = ', resultData)
|
|
173
|
-
// 处理不同格式的返回数据
|
|
174
|
-
if (resultData) {
|
|
175
|
-
// 如果是数组,取第一项
|
|
176
|
-
if (Array.isArray(resultData) && resultData.length > 0) {
|
|
177
|
-
const firstItem = resultData[0]
|
|
178
|
-
|
|
179
|
-
// 检查是否有f_data字段
|
|
180
|
-
if (firstItem.f_data) {
|
|
181
|
-
parsedData = parseFormData(firstItem.f_data)
|
|
182
|
-
} else {
|
|
183
|
-
// 可能整个对象就是数据
|
|
184
|
-
parsedData = firstItem
|
|
185
|
-
}
|
|
186
|
-
} else if (typeof resultData === 'object') {
|
|
187
|
-
if (resultData.f_data) {
|
|
188
|
-
parsedData = parseFormData(resultData.f_data)
|
|
189
|
-
} else { parsedData = resultData }
|
|
190
|
-
}
|
|
191
|
-
}
|
|
192
|
-
} catch (error) {
|
|
193
|
-
console.error('获取数据失败:', error)
|
|
194
|
-
}
|
|
195
|
-
// 如果解析成功且非创建模式,填充表单
|
|
196
|
-
if (parsedData && props.modalType !== 'create') {
|
|
197
|
-
console.log('解析后的数据:', parsedData)
|
|
198
|
-
// 将解析后的数据填充到表单中
|
|
199
|
-
Object.keys(parsedData).forEach(key => {
|
|
200
|
-
if (key in formData) {
|
|
201
|
-
formData[key] = parsedData[key]
|
|
202
|
-
}
|
|
203
|
-
})
|
|
204
|
-
// 确保formData.id是正确设置的
|
|
205
|
-
if (!formData.id && parsedData.id) {
|
|
206
|
-
formData.id = parsedData.id
|
|
207
|
-
}
|
|
208
|
-
return
|
|
209
|
-
} else if (props.modalType === 'create') {
|
|
210
|
-
// 创建模式下重置表单
|
|
211
|
-
resetForm()
|
|
212
|
-
return
|
|
213
|
-
}
|
|
214
|
-
} catch (error) {
|
|
215
|
-
console.error('初始化表单数据失败:', error)
|
|
216
|
-
message.error('体温单数据加载失败,将使用默认值')
|
|
217
|
-
}
|
|
218
|
-
// 如果没有数据或解析失败,使用默认值
|
|
219
|
-
resetForm()
|
|
220
|
-
}
|
|
221
|
-
|
|
222
|
-
// 关闭弹窗
|
|
223
|
-
const closeModal = () => {
|
|
224
|
-
// 关闭弹窗前清空表单数据
|
|
225
|
-
resetForm()
|
|
226
|
-
emit('update:visible', false)
|
|
227
|
-
emit('cancel')
|
|
228
|
-
}
|
|
229
|
-
|
|
230
|
-
// 验证表单
|
|
231
|
-
const validateForm = () => {
|
|
232
|
-
const isBaby = props.modalType === 'baby'
|
|
233
|
-
const errors = {}
|
|
234
|
-
let hasError = false
|
|
235
|
-
// 通用字段验证
|
|
236
|
-
const requiredFields = [
|
|
237
|
-
{ key: 'id', label: 'ID' },
|
|
238
|
-
{ key: 'name', label: '姓名' },
|
|
239
|
-
{ key: 'inDate', label: '入院日期' },
|
|
240
|
-
{ key: 'dept', label: '科室' },
|
|
241
|
-
{ key: 'bed', label: '床位' },
|
|
242
|
-
{ key: 'medicalNo', label: '病历号' },
|
|
243
|
-
{ key: 'begin', label: '开始日期' },
|
|
244
|
-
{ key: 'notes', label: '备注' },
|
|
245
|
-
{ key: 'heart', label: '心率' },
|
|
246
|
-
{ key: 'tempType', label: '体温类型' },
|
|
247
|
-
{ key: 'temperature', label: '体温' },
|
|
248
|
-
{ key: 'breath', label: '呼吸' },
|
|
249
|
-
{ key: 'labels', label: '标签' },
|
|
250
|
-
{ key: 'data1', label: '血压' },
|
|
251
|
-
{ key: 'data2', label: '入水量' },
|
|
252
|
-
{ key: 'data3', label: '出水量' },
|
|
253
|
-
{ key: 'data4', label: '大便次数' },
|
|
254
|
-
{ key: 'data5', label: '小便次数' }
|
|
255
|
-
]
|
|
256
|
-
// 成人特有字段
|
|
257
|
-
if (!isBaby) {
|
|
258
|
-
requiredFields.push(
|
|
259
|
-
{ key: 'diag', label: '诊断' },
|
|
260
|
-
{ key: 'operateDate', label: '手术日期' },
|
|
261
|
-
{ key: 'sphygmus', label: '脉搏' },
|
|
262
|
-
{ key: 'data6', label: '身高' },
|
|
263
|
-
{ key: 'data7', label: '体重' },
|
|
264
|
-
{ key: 'data8', label: '过敏药' },
|
|
265
|
-
{ key: 'data9', label: '其他数据' }
|
|
266
|
-
)
|
|
267
|
-
} else {
|
|
268
|
-
// 婴儿特有字段
|
|
269
|
-
requiredFields.push(
|
|
270
|
-
{ key: 'weight', label: '体重' },
|
|
271
|
-
{ key: 'physicalcool', label: '物理降温' }
|
|
272
|
-
)
|
|
273
|
-
}
|
|
274
|
-
// 检查每个必填字段
|
|
275
|
-
requiredFields.forEach(field => {
|
|
276
|
-
// 首先检查字段是否存在
|
|
277
|
-
if (formData[field.key] === undefined || formData[field.key] === null) {
|
|
278
|
-
errors[field.key] = `${field.label}不能为空`
|
|
279
|
-
hasError = true
|
|
280
|
-
return
|
|
281
|
-
}
|
|
282
|
-
// 将值转换为字符串后再检查是否为空
|
|
283
|
-
const value = String(formData[field.key])
|
|
284
|
-
if (value.trim() === '') {
|
|
285
|
-
errors[field.key] = `${field.label}不能为空`
|
|
286
|
-
hasError = true
|
|
287
|
-
}
|
|
288
|
-
})
|
|
289
|
-
|
|
290
|
-
formErrors.value = errors
|
|
291
|
-
if (hasError) {
|
|
292
|
-
message.error('表单验证失败,请填写所有必填项')
|
|
293
|
-
return false
|
|
294
|
-
}
|
|
295
|
-
return true
|
|
296
|
-
}
|
|
297
|
-
|
|
298
|
-
// 获取表单数据
|
|
299
|
-
const getFormData = () => {
|
|
300
|
-
const isBaby = props.modalType === 'baby'
|
|
301
|
-
const commonData = {
|
|
302
|
-
id: formData.id || `${isBaby ? 'BY' : 'VS'}${Date.now()}`,
|
|
303
|
-
name: formData.name,
|
|
304
|
-
inDate: formData.inDate,
|
|
305
|
-
dept: formData.dept,
|
|
306
|
-
bed: formData.bed,
|
|
307
|
-
medicalNo: formData.medicalNo,
|
|
308
|
-
begin: formData.begin,
|
|
309
|
-
notes: formData.notes,
|
|
310
|
-
heart: formData.heart,
|
|
311
|
-
tempType: formData.tempType,
|
|
312
|
-
temperature: formData.temperature,
|
|
313
|
-
breath: formData.breath,
|
|
314
|
-
labels: formData.labels,
|
|
315
|
-
data1: formData.data1,
|
|
316
|
-
data2: formData.data2,
|
|
317
|
-
data3: formData.data3,
|
|
318
|
-
data4: formData.data4,
|
|
319
|
-
data5: formData.data5,
|
|
320
|
-
pain: formData.pain
|
|
321
|
-
}
|
|
322
|
-
if (isBaby) {
|
|
323
|
-
return {
|
|
324
|
-
...commonData,
|
|
325
|
-
type: 'baby',
|
|
326
|
-
sex: formData.sex,
|
|
327
|
-
weight: formData.weight,
|
|
328
|
-
physicalcool: formData.physicalcool
|
|
329
|
-
}
|
|
330
|
-
}
|
|
331
|
-
return {
|
|
332
|
-
...commonData,
|
|
333
|
-
diag: formData.diag,
|
|
334
|
-
operateDate: formData.operateDate,
|
|
335
|
-
sphygmus: formData.sphygmus,
|
|
336
|
-
data6: formData.data6,
|
|
337
|
-
data7: formData.data7,
|
|
338
|
-
data8: formData.data8,
|
|
339
|
-
data9: formData.data9
|
|
340
|
-
}
|
|
341
|
-
}
|
|
342
|
-
|
|
343
|
-
// 提交表单
|
|
344
|
-
const submitForm = async () => {
|
|
345
|
-
if (!props.editorReady) {
|
|
346
|
-
message.error('体温单编辑器未加载完成,请等待或刷新页面')
|
|
347
|
-
return
|
|
348
|
-
}
|
|
349
|
-
// 首先验证表单
|
|
350
|
-
if (!validateForm()) {
|
|
351
|
-
return
|
|
352
|
-
}
|
|
353
|
-
submitLoading.value = true
|
|
354
|
-
try {
|
|
355
|
-
const data = getFormData()
|
|
356
|
-
emit('submit', data)
|
|
357
|
-
// 关闭弹窗
|
|
358
|
-
closeModal()
|
|
359
|
-
} catch (err) {
|
|
360
|
-
console.error('提交体温单数据出错:', err)
|
|
361
|
-
message.error(`提交体温单数据失败: ${err.message || '未知错误'}`)
|
|
362
|
-
} finally {
|
|
363
|
-
submitLoading.value = false
|
|
364
|
-
}
|
|
365
|
-
}
|
|
366
|
-
</script>
|
|
367
|
-
|
|
368
|
-
<template>
|
|
369
|
-
<a-modal
|
|
370
|
-
:title="modalTitles[modalType]"
|
|
371
|
-
:visible="visible"
|
|
372
|
-
@cancel="closeModal"
|
|
373
|
-
:width="700"
|
|
374
|
-
:footer="null">
|
|
375
|
-
<a-form :label-col="{ span: 6 }" :wrapper-col="{ span: 18 }">
|
|
376
|
-
<!-- 通用基础信息字段 -->
|
|
377
|
-
<a-form-item label="ID" :validateStatus="formErrors.id ? 'error' : ''" :help="formErrors.id">
|
|
378
|
-
<a-input v-model="formData.id" :placeholder="`请输入ID,如:${modalType === 'baby' ? 'BY' : 'AD'}20230001`" />
|
|
379
|
-
</a-form-item>
|
|
380
|
-
<a-form-item label="姓名" :validateStatus="formErrors.name ? 'error' : ''" :help="formErrors.name">
|
|
381
|
-
<a-input v-model="formData.name" placeholder="请输入姓名,如:张三" />
|
|
382
|
-
</a-form-item>
|
|
383
|
-
<a-form-item label="入院日期" :validateStatus="formErrors.inDate ? 'error' : ''" :help="formErrors.inDate">
|
|
384
|
-
<a-input v-model="formData.inDate" placeholder="请输入日期,如:2023-08-01" />
|
|
385
|
-
</a-form-item>
|
|
386
|
-
<!-- 新生儿特有字段 -->
|
|
387
|
-
<template v-if="modalType === 'baby'">
|
|
388
|
-
<a-form-item label="性别">
|
|
389
|
-
<a-radio-group v-model="formData.sex">
|
|
390
|
-
<a-radio value="男">男</a-radio>
|
|
391
|
-
<a-radio value="女">女</a-radio>
|
|
392
|
-
</a-radio-group>
|
|
393
|
-
</a-form-item>
|
|
394
|
-
</template>
|
|
395
|
-
<!-- 成人特有字段 -->
|
|
396
|
-
<template v-else>
|
|
397
|
-
<a-form-item label="诊断" :validateStatus="formErrors.diag ? 'error' : ''" :help="formErrors.diag">
|
|
398
|
-
<a-input v-model="formData.diag" placeholder="请输入诊断,如:新型冠状病毒肺炎" />
|
|
399
|
-
</a-form-item>
|
|
400
|
-
</template>
|
|
401
|
-
<!-- 通用字段 -->
|
|
402
|
-
<a-form-item label="科室" :validateStatus="formErrors.dept ? 'error' : ''" :help="formErrors.dept">
|
|
403
|
-
<a-input v-model="formData.dept" :placeholder="`请输入科室,如:${modalType === 'baby' ? '妇产科' : '呼吸内科'}`" />
|
|
404
|
-
</a-form-item>
|
|
405
|
-
<a-form-item label="床位" :validateStatus="formErrors.bed ? 'error' : ''" :help="formErrors.bed">
|
|
406
|
-
<a-input v-model="formData.bed" placeholder="请输入床位,如:801" />
|
|
407
|
-
</a-form-item>
|
|
408
|
-
<a-form-item label="病历号" :validateStatus="formErrors.medicalNo ? 'error' : ''" :help="formErrors.medicalNo">
|
|
409
|
-
<a-input v-model="formData.medicalNo" placeholder="请输入病历号,如:202300991" />
|
|
410
|
-
</a-form-item>
|
|
411
|
-
<a-form-item label="开始日期" :validateStatus="formErrors.begin ? 'error' : ''" :help="formErrors.begin">
|
|
412
|
-
<a-input v-model="formData.begin" placeholder="请输入日期,如:2023-08-01" />
|
|
413
|
-
</a-form-item>
|
|
414
|
-
<!-- 成人特有字段 -->
|
|
415
|
-
<template v-if="modalType !== 'baby'">
|
|
416
|
-
<a-form-item label="手术日期" :validateStatus="formErrors.operateDate ? 'error' : ''" :help="formErrors.operateDate">
|
|
417
|
-
<a-input v-model="formData.operateDate" placeholder="请输入日期,如:2023-08-03" />
|
|
418
|
-
</a-form-item>
|
|
419
|
-
</template>
|
|
420
|
-
<!-- 备注字段 -->
|
|
421
|
-
<a-form-item label="备注" :validateStatus="formErrors.notes ? 'error' : ''" :help="formErrors.notes">
|
|
422
|
-
<a-input v-model="formData.notes" :placeholder="`请输入备注,如:${modalType === 'baby' ? '出生-十时二十分' : '入院-十时二十分,,转入ICU,,,,,,,手术'}`" />
|
|
423
|
-
<div class="input-tip">格式:多个值用逗号分隔,对应不同日期</div>
|
|
424
|
-
</a-form-item>
|
|
425
|
-
<!-- 根据表单类型显示不同的数据字段 -->
|
|
426
|
-
<template v-if="modalType !== 'baby'">
|
|
427
|
-
<a-form-item label="脉搏" :validateStatus="formErrors.sphygmus ? 'error' : ''" :help="formErrors.sphygmus">
|
|
428
|
-
<a-input v-model="formData.sphygmus" placeholder="脉搏数据,如:112,110,109,103,108,85" />
|
|
429
|
-
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
430
|
-
</a-form-item>
|
|
431
|
-
</template>
|
|
432
|
-
<template v-else>
|
|
433
|
-
<a-form-item label="体重" :validateStatus="formErrors.weight ? 'error' : ''" :help="formErrors.weight">
|
|
434
|
-
<a-input v-model="formData.weight" placeholder="体重数据,多个值用逗号分隔,如:3200,,,,3300,,,,3400" />
|
|
435
|
-
<div class="input-tip">格式:多个值用逗号分隔,每组数据对应一天</div>
|
|
436
|
-
</a-form-item>
|
|
437
|
-
</template>
|
|
438
|
-
<!-- 生命体征数据字段 -->
|
|
439
|
-
<a-form-item label="心率" :validateStatus="formErrors.heart ? 'error' : ''" :help="formErrors.heart">
|
|
440
|
-
<a-input v-model="formData.heart" placeholder="心率数据,多个值用逗号分隔,如:112,120,118,111" />
|
|
441
|
-
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
442
|
-
</a-form-item>
|
|
443
|
-
<a-form-item label="体温类型" :validateStatus="formErrors.tempType ? 'error' : ''" :help="formErrors.tempType">
|
|
444
|
-
<a-input v-model="formData.tempType" placeholder="体温类型,如:0,1,2,3,0,1" />
|
|
445
|
-
<div class="input-tip">格式:多个值用逗号分隔,0-3表示不同类型</div>
|
|
446
|
-
</a-form-item>
|
|
447
|
-
<a-form-item label="体温" :validateStatus="formErrors.temperature ? 'error' : ''" :help="formErrors.temperature">
|
|
448
|
-
<a-input v-model="formData.temperature" :placeholder="`体温数据,如:${modalType === 'baby' ? '37.7,37.9,38.5,37.1' : '38.7,38.9,38.5,39.1,38.5,38.5|37.1'}`" />
|
|
449
|
-
<div class="input-tip">格式:多个值用逗号分隔<template v-if="modalType !== 'baby'">,|表示新一行数据</template></div>
|
|
450
|
-
</a-form-item>
|
|
451
|
-
<!-- 新生儿特有字段 -->
|
|
452
|
-
<template v-if="modalType === 'baby'">
|
|
453
|
-
<a-form-item label="物理降温" :validateStatus="formErrors.physicalcool ? 'error' : ''" :help="formErrors.physicalcool">
|
|
454
|
-
<a-input v-model="formData.physicalcool" placeholder="物理降温数据,如:,,,37.6,,,,,,,,37.5" />
|
|
455
|
-
<div class="input-tip">格式:多个值用逗号分隔,空值用逗号表示</div>
|
|
456
|
-
</a-form-item>
|
|
457
|
-
</template>
|
|
458
|
-
<!-- 通用数据字段 -->
|
|
459
|
-
<a-form-item label="呼吸" :validateStatus="formErrors.breath ? 'error' : ''" :help="formErrors.breath">
|
|
460
|
-
<a-input v-model="formData.breath" placeholder="呼吸数据,如:30,30,R,,35,35" />
|
|
461
|
-
<div class="input-tip">格式:多个值用逗号分隔,R表示异常</div>
|
|
462
|
-
</a-form-item>
|
|
463
|
-
<a-form-item label="标签" :validateStatus="formErrors.labels ? 'error' : ''" :help="formErrors.labels">
|
|
464
|
-
<a-input v-model="formData.labels" :placeholder="`标签数据,如:血压(mmHg)|入水量(ml)|出水量(ml)|大便(次)|小便(次)${modalType === 'baby' ? '' : '|身高(cm)|体重(kg)|过敏药'}`" />
|
|
465
|
-
<div class="input-tip">格式:多个标签用|分隔</div>
|
|
466
|
-
</a-form-item>
|
|
467
|
-
<!-- 通用数据字段 -->
|
|
468
|
-
<a-form-item label="血压" :validateStatus="formErrors.data1 ? 'error' : ''" :help="formErrors.data1">
|
|
469
|
-
<a-input v-model="formData.data1" placeholder="血压数据,如:120/85,121/84,,110/75" />
|
|
470
|
-
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
471
|
-
</a-form-item>
|
|
472
|
-
<a-form-item label="入水量" :validateStatus="formErrors.data2 ? 'error' : ''" :help="formErrors.data2">
|
|
473
|
-
<a-input v-model="formData.data2" placeholder="入水量数据,如:1180ml,,,500ml,,40ml" />
|
|
474
|
-
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
475
|
-
</a-form-item>
|
|
476
|
-
<a-form-item label="出水量" :validateStatus="formErrors.data3 ? 'error' : ''" :help="formErrors.data3">
|
|
477
|
-
<a-input v-model="formData.data3" placeholder="出水量数据,如:500ml,,,,500ml,,67ml" />
|
|
478
|
-
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
479
|
-
</a-form-item>
|
|
480
|
-
<a-form-item label="大便次数" :validateStatus="formErrors.data4 ? 'error' : ''" :help="formErrors.data4">
|
|
481
|
-
<a-input v-model="formData.data4" placeholder="大便次数数据,如:2,4,5,3,3,3,2,,2" />
|
|
482
|
-
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
483
|
-
</a-form-item>
|
|
484
|
-
<a-form-item label="小便次数" :validateStatus="formErrors.data5 ? 'error' : ''" :help="formErrors.data5">
|
|
485
|
-
<a-input v-model="formData.data5" placeholder="小便次数数据,如:2,4,5,3,3,3,2,,2" />
|
|
486
|
-
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
487
|
-
</a-form-item>
|
|
488
|
-
<!-- 成人特有字段 -->
|
|
489
|
-
<template v-if="modalType !== 'baby'">
|
|
490
|
-
<a-form-item label="身高" :validateStatus="formErrors.data6 ? 'error' : ''" :help="formErrors.data6">
|
|
491
|
-
<a-input v-model="formData.data6" placeholder="身高数据,如:167cm,,,,,,,,,164cm" />
|
|
492
|
-
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
493
|
-
</a-form-item>
|
|
494
|
-
<a-form-item label="体重" :validateStatus="formErrors.data7 ? 'error' : ''" :help="formErrors.data7">
|
|
495
|
-
<a-input v-model="formData.data7" placeholder="体重数据,如:95kg,,,,,90kg" />
|
|
496
|
-
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
497
|
-
</a-form-item>
|
|
498
|
-
<a-form-item label="过敏药" :validateStatus="formErrors.data8 ? 'error' : ''" :help="formErrors.data8">
|
|
499
|
-
<a-input v-model="formData.data8" placeholder="过敏药数据,如:青霉素," />
|
|
500
|
-
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
501
|
-
</a-form-item>
|
|
502
|
-
<a-form-item label="其他数据" :validateStatus="formErrors.data9 ? 'error' : ''" :help="formErrors.data9">
|
|
503
|
-
<a-input v-model="formData.data9" placeholder="其他数据,如:测试," />
|
|
504
|
-
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
505
|
-
</a-form-item>
|
|
506
|
-
</template>
|
|
507
|
-
<!-- 按钮 -->
|
|
508
|
-
<a-form-item :wrapper-col="{ span: 18, offset: 6 }">
|
|
509
|
-
<a-button type="primary" @click="submitForm" :loading="submitLoading" style="margin-right: 10px">确定</a-button>
|
|
510
|
-
<a-button @click="closeModal">取消</a-button>
|
|
511
|
-
</a-form-item>
|
|
512
|
-
</a-form>
|
|
513
|
-
</a-modal>
|
|
514
|
-
</template>
|
|
515
|
-
|
|
516
|
-
<style scoped>
|
|
517
|
-
.input-tip {
|
|
518
|
-
color: #999;
|
|
519
|
-
font-size: 12px;
|
|
520
|
-
margin-top: 4px;
|
|
521
|
-
}
|
|
522
|
-
</style>
|
|
1
|
+
<script setup>
|
|
2
|
+
import { ref, reactive, watch } from 'vue'
|
|
3
|
+
import { message } from 'ant-design-vue'
|
|
4
|
+
import { runLogic } from '@vue2-client/services/api/common'
|
|
5
|
+
|
|
6
|
+
// 定义组件属性
|
|
7
|
+
const props = defineProps({
|
|
8
|
+
visible: Boolean,
|
|
9
|
+
id: {
|
|
10
|
+
type: Number,
|
|
11
|
+
default: 180
|
|
12
|
+
},
|
|
13
|
+
modalType: {
|
|
14
|
+
type: String,
|
|
15
|
+
default: 'create',
|
|
16
|
+
validator: (value) => ['create', 'update', 'baby'].includes(value)
|
|
17
|
+
},
|
|
18
|
+
editorReady: {
|
|
19
|
+
type: Boolean,
|
|
20
|
+
default: false
|
|
21
|
+
}
|
|
22
|
+
})
|
|
23
|
+
|
|
24
|
+
// 定义组件事件
|
|
25
|
+
const emit = defineEmits(['update:visible', 'submit', 'cancel'])
|
|
26
|
+
|
|
27
|
+
// 常量
|
|
28
|
+
const modalTitles = {
|
|
29
|
+
create: '创建体温单',
|
|
30
|
+
update: '更新体温单',
|
|
31
|
+
baby: '新生儿体温单'
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
// 响应式状态
|
|
35
|
+
const submitLoading = ref(false)
|
|
36
|
+
const formErrors = ref({})
|
|
37
|
+
|
|
38
|
+
// 表单数据
|
|
39
|
+
const formData = reactive({
|
|
40
|
+
id: '',
|
|
41
|
+
name: '',
|
|
42
|
+
inDate: '',
|
|
43
|
+
diag: '',
|
|
44
|
+
dept: '',
|
|
45
|
+
bed: '',
|
|
46
|
+
medicalNo: '',
|
|
47
|
+
begin: '',
|
|
48
|
+
operateDate: '',
|
|
49
|
+
notes: '',
|
|
50
|
+
sex: '男',
|
|
51
|
+
weight: '',
|
|
52
|
+
heart: '',
|
|
53
|
+
tempType: '',
|
|
54
|
+
temperature: '',
|
|
55
|
+
breath: '',
|
|
56
|
+
sphygmus: '',
|
|
57
|
+
physicalcool: '',
|
|
58
|
+
labels: '',
|
|
59
|
+
data1: '',
|
|
60
|
+
data2: '',
|
|
61
|
+
data3: '',
|
|
62
|
+
data4: '',
|
|
63
|
+
data5: '',
|
|
64
|
+
data6: '',
|
|
65
|
+
data7: '',
|
|
66
|
+
data8: '',
|
|
67
|
+
data9: '',
|
|
68
|
+
pain: ''
|
|
69
|
+
})
|
|
70
|
+
|
|
71
|
+
// 监听 props 变化初始化表单
|
|
72
|
+
watch(() => props.visible, (newVal, oldVal) => {
|
|
73
|
+
if (newVal) {
|
|
74
|
+
// 如果是从关闭状态变为打开状态,重置表单错误
|
|
75
|
+
formErrors.value = {}
|
|
76
|
+
|
|
77
|
+
// 无论何种模式,都先尝试从服务加载数据
|
|
78
|
+
initFormData()
|
|
79
|
+
} else if (oldVal && !newVal) {
|
|
80
|
+
// 当弹窗关闭时,清空表单数据,为下次打开做准备
|
|
81
|
+
resetForm()
|
|
82
|
+
}
|
|
83
|
+
}, { immediate: true })
|
|
84
|
+
|
|
85
|
+
watch(() => props.modalType, (newVal) => {
|
|
86
|
+
if (props.visible) {
|
|
87
|
+
// 无论何种模式,都先尝试从服务加载数据
|
|
88
|
+
initFormData()
|
|
89
|
+
}
|
|
90
|
+
})
|
|
91
|
+
|
|
92
|
+
watch(() => props.id, (newVal) => {
|
|
93
|
+
if (newVal) {
|
|
94
|
+
formData.id = newVal
|
|
95
|
+
}
|
|
96
|
+
}, { immediate: true })
|
|
97
|
+
|
|
98
|
+
// 重置表单为默认值
|
|
99
|
+
const resetForm = () => {
|
|
100
|
+
// 清空表单错误
|
|
101
|
+
formErrors.value = {}
|
|
102
|
+
|
|
103
|
+
const today = new Date().toISOString().split('T')[0]
|
|
104
|
+
const isBaby = props.modalType === 'baby'
|
|
105
|
+
|
|
106
|
+
// 重置所有字段
|
|
107
|
+
formData.id = props.id || (isBaby ? `BY${Date.now()}` : `VS${Date.now()}`)
|
|
108
|
+
formData.name = ''
|
|
109
|
+
formData.inDate = today
|
|
110
|
+
formData.diag = ''
|
|
111
|
+
formData.dept = isBaby ? '妇产科' : ''
|
|
112
|
+
formData.bed = ''
|
|
113
|
+
formData.medicalNo = ''
|
|
114
|
+
formData.begin = today
|
|
115
|
+
formData.operateDate = ''
|
|
116
|
+
formData.notes = isBaby ? '出生-十时二十分' : '入院-十时二十分,,转入ICU,,,,,,,手术,,,,,,,,,,,,,,,出院,死亡于×时×分'
|
|
117
|
+
formData.sex = '男'
|
|
118
|
+
formData.weight = isBaby ? '3200,,,,3300,,,,3400,,,,3400,,,,3500,,,,3400,,,,' : ''
|
|
119
|
+
formData.heart = '112,120,118,111,,,,,,,112,120,118,111'
|
|
120
|
+
formData.tempType = isBaby
|
|
121
|
+
? '2,2,2,3,2,1,2,2,2,1,2,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1'
|
|
122
|
+
: '0,1,2,3,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1'
|
|
123
|
+
formData.temperature = isBaby
|
|
124
|
+
? '37.7,37.9,38.5,37.1,37.5,38.5,,,37.5,38.5,37.4,37.8,,37.5,37.6,37.8,,37.9,37.8,37.5,38.6,37.8,,37.9,37.8'
|
|
125
|
+
: '38.7,38.9,38.5,39.1,38.5,38.5|37.1,38.5,38.5,,,38.5,38.5|36.9,38.4,38.8,,38.5,38.6,38.8,,38.9,38.8,38.5,38.6,38.8,,38.9,38.8,34,34.0'
|
|
126
|
+
formData.physicalcool = isBaby ? ',,,37.6,,,,,,,,37.5,,,,,,,,,37.4,,' : ''
|
|
127
|
+
formData.breath = '30,30,R,,35,35,35,35,35,35,35,35,,R,R,35,35,,R,,,35,35,,R'
|
|
128
|
+
formData.sphygmus = '112,110,109,103,108,85,90,83,90,103,108,85,90,83,90,,90,83,90,103,108,85,90,83,90'
|
|
129
|
+
formData.labels = isBaby
|
|
130
|
+
? '血压(mmHg)|入水量(ml)|出水量(ml)|大便(次)|小便(次)'
|
|
131
|
+
: '血压(mmHg)|入水量(ml)|出水量(ml)|大便(次)|小便(次)|身高(cm)|体重(kg)|过敏药'
|
|
132
|
+
formData.data1 = '120/85,121/84,,110/75,'
|
|
133
|
+
formData.data2 = '1180ml,,,500ml,,40ml'
|
|
134
|
+
formData.data3 = '500ml,,,,500ml,,67ml'
|
|
135
|
+
formData.data4 = '2,4,5,3,3,3,2,,2'
|
|
136
|
+
formData.data5 = '2,4,5,3,3,3,2,,2'
|
|
137
|
+
formData.data6 = '167cm,,,,,,,,,164cm'
|
|
138
|
+
formData.data7 = '95kg,,,,,90kg'
|
|
139
|
+
formData.data8 = '青霉素,'
|
|
140
|
+
formData.data9 = '测试,'
|
|
141
|
+
formData.pain = '2,2,4,5,8,8,9|2,6|3,,,4,4,4'
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
// 处理JSON字符串数据
|
|
145
|
+
const parseFormData = (data) => {
|
|
146
|
+
if (!data) return null
|
|
147
|
+
try {
|
|
148
|
+
// 如果是字符串,尝试解析为JSON
|
|
149
|
+
if (typeof data === 'string') {
|
|
150
|
+
return JSON.parse(data)
|
|
151
|
+
}
|
|
152
|
+
// 如果已经是对象且有f_data字段,尝试解析f_data
|
|
153
|
+
if (typeof data === 'object' && data.f_data) {
|
|
154
|
+
return JSON.parse(data.f_data)
|
|
155
|
+
}
|
|
156
|
+
// 如果是普通对象,直接返回
|
|
157
|
+
return data
|
|
158
|
+
} catch (error) {
|
|
159
|
+
console.error('解析数据失败:', error)
|
|
160
|
+
return null
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
// 初始化表单数据
|
|
165
|
+
const initFormData = async () => {
|
|
166
|
+
try {
|
|
167
|
+
let parsedData = null
|
|
168
|
+
let resultData = null
|
|
169
|
+
try {
|
|
170
|
+
// 尝试从服务器获取数据
|
|
171
|
+
resultData = await runLogic('threeTestOrderDataLOGIC', { id: props.id }, 'af-his')
|
|
172
|
+
console.log('体温单数据 = ', resultData)
|
|
173
|
+
// 处理不同格式的返回数据
|
|
174
|
+
if (resultData) {
|
|
175
|
+
// 如果是数组,取第一项
|
|
176
|
+
if (Array.isArray(resultData) && resultData.length > 0) {
|
|
177
|
+
const firstItem = resultData[0]
|
|
178
|
+
|
|
179
|
+
// 检查是否有f_data字段
|
|
180
|
+
if (firstItem.f_data) {
|
|
181
|
+
parsedData = parseFormData(firstItem.f_data)
|
|
182
|
+
} else {
|
|
183
|
+
// 可能整个对象就是数据
|
|
184
|
+
parsedData = firstItem
|
|
185
|
+
}
|
|
186
|
+
} else if (typeof resultData === 'object') {
|
|
187
|
+
if (resultData.f_data) {
|
|
188
|
+
parsedData = parseFormData(resultData.f_data)
|
|
189
|
+
} else { parsedData = resultData }
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
} catch (error) {
|
|
193
|
+
console.error('获取数据失败:', error)
|
|
194
|
+
}
|
|
195
|
+
// 如果解析成功且非创建模式,填充表单
|
|
196
|
+
if (parsedData && props.modalType !== 'create') {
|
|
197
|
+
console.log('解析后的数据:', parsedData)
|
|
198
|
+
// 将解析后的数据填充到表单中
|
|
199
|
+
Object.keys(parsedData).forEach(key => {
|
|
200
|
+
if (key in formData) {
|
|
201
|
+
formData[key] = parsedData[key]
|
|
202
|
+
}
|
|
203
|
+
})
|
|
204
|
+
// 确保formData.id是正确设置的
|
|
205
|
+
if (!formData.id && parsedData.id) {
|
|
206
|
+
formData.id = parsedData.id
|
|
207
|
+
}
|
|
208
|
+
return
|
|
209
|
+
} else if (props.modalType === 'create') {
|
|
210
|
+
// 创建模式下重置表单
|
|
211
|
+
resetForm()
|
|
212
|
+
return
|
|
213
|
+
}
|
|
214
|
+
} catch (error) {
|
|
215
|
+
console.error('初始化表单数据失败:', error)
|
|
216
|
+
message.error('体温单数据加载失败,将使用默认值')
|
|
217
|
+
}
|
|
218
|
+
// 如果没有数据或解析失败,使用默认值
|
|
219
|
+
resetForm()
|
|
220
|
+
}
|
|
221
|
+
|
|
222
|
+
// 关闭弹窗
|
|
223
|
+
const closeModal = () => {
|
|
224
|
+
// 关闭弹窗前清空表单数据
|
|
225
|
+
resetForm()
|
|
226
|
+
emit('update:visible', false)
|
|
227
|
+
emit('cancel')
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
// 验证表单
|
|
231
|
+
const validateForm = () => {
|
|
232
|
+
const isBaby = props.modalType === 'baby'
|
|
233
|
+
const errors = {}
|
|
234
|
+
let hasError = false
|
|
235
|
+
// 通用字段验证
|
|
236
|
+
const requiredFields = [
|
|
237
|
+
{ key: 'id', label: 'ID' },
|
|
238
|
+
{ key: 'name', label: '姓名' },
|
|
239
|
+
{ key: 'inDate', label: '入院日期' },
|
|
240
|
+
{ key: 'dept', label: '科室' },
|
|
241
|
+
{ key: 'bed', label: '床位' },
|
|
242
|
+
{ key: 'medicalNo', label: '病历号' },
|
|
243
|
+
{ key: 'begin', label: '开始日期' },
|
|
244
|
+
{ key: 'notes', label: '备注' },
|
|
245
|
+
{ key: 'heart', label: '心率' },
|
|
246
|
+
{ key: 'tempType', label: '体温类型' },
|
|
247
|
+
{ key: 'temperature', label: '体温' },
|
|
248
|
+
{ key: 'breath', label: '呼吸' },
|
|
249
|
+
{ key: 'labels', label: '标签' },
|
|
250
|
+
{ key: 'data1', label: '血压' },
|
|
251
|
+
{ key: 'data2', label: '入水量' },
|
|
252
|
+
{ key: 'data3', label: '出水量' },
|
|
253
|
+
{ key: 'data4', label: '大便次数' },
|
|
254
|
+
{ key: 'data5', label: '小便次数' }
|
|
255
|
+
]
|
|
256
|
+
// 成人特有字段
|
|
257
|
+
if (!isBaby) {
|
|
258
|
+
requiredFields.push(
|
|
259
|
+
{ key: 'diag', label: '诊断' },
|
|
260
|
+
{ key: 'operateDate', label: '手术日期' },
|
|
261
|
+
{ key: 'sphygmus', label: '脉搏' },
|
|
262
|
+
{ key: 'data6', label: '身高' },
|
|
263
|
+
{ key: 'data7', label: '体重' },
|
|
264
|
+
{ key: 'data8', label: '过敏药' },
|
|
265
|
+
{ key: 'data9', label: '其他数据' }
|
|
266
|
+
)
|
|
267
|
+
} else {
|
|
268
|
+
// 婴儿特有字段
|
|
269
|
+
requiredFields.push(
|
|
270
|
+
{ key: 'weight', label: '体重' },
|
|
271
|
+
{ key: 'physicalcool', label: '物理降温' }
|
|
272
|
+
)
|
|
273
|
+
}
|
|
274
|
+
// 检查每个必填字段
|
|
275
|
+
requiredFields.forEach(field => {
|
|
276
|
+
// 首先检查字段是否存在
|
|
277
|
+
if (formData[field.key] === undefined || formData[field.key] === null) {
|
|
278
|
+
errors[field.key] = `${field.label}不能为空`
|
|
279
|
+
hasError = true
|
|
280
|
+
return
|
|
281
|
+
}
|
|
282
|
+
// 将值转换为字符串后再检查是否为空
|
|
283
|
+
const value = String(formData[field.key])
|
|
284
|
+
if (value.trim() === '') {
|
|
285
|
+
errors[field.key] = `${field.label}不能为空`
|
|
286
|
+
hasError = true
|
|
287
|
+
}
|
|
288
|
+
})
|
|
289
|
+
|
|
290
|
+
formErrors.value = errors
|
|
291
|
+
if (hasError) {
|
|
292
|
+
message.error('表单验证失败,请填写所有必填项')
|
|
293
|
+
return false
|
|
294
|
+
}
|
|
295
|
+
return true
|
|
296
|
+
}
|
|
297
|
+
|
|
298
|
+
// 获取表单数据
|
|
299
|
+
const getFormData = () => {
|
|
300
|
+
const isBaby = props.modalType === 'baby'
|
|
301
|
+
const commonData = {
|
|
302
|
+
id: formData.id || `${isBaby ? 'BY' : 'VS'}${Date.now()}`,
|
|
303
|
+
name: formData.name,
|
|
304
|
+
inDate: formData.inDate,
|
|
305
|
+
dept: formData.dept,
|
|
306
|
+
bed: formData.bed,
|
|
307
|
+
medicalNo: formData.medicalNo,
|
|
308
|
+
begin: formData.begin,
|
|
309
|
+
notes: formData.notes,
|
|
310
|
+
heart: formData.heart,
|
|
311
|
+
tempType: formData.tempType,
|
|
312
|
+
temperature: formData.temperature,
|
|
313
|
+
breath: formData.breath,
|
|
314
|
+
labels: formData.labels,
|
|
315
|
+
data1: formData.data1,
|
|
316
|
+
data2: formData.data2,
|
|
317
|
+
data3: formData.data3,
|
|
318
|
+
data4: formData.data4,
|
|
319
|
+
data5: formData.data5,
|
|
320
|
+
pain: formData.pain
|
|
321
|
+
}
|
|
322
|
+
if (isBaby) {
|
|
323
|
+
return {
|
|
324
|
+
...commonData,
|
|
325
|
+
type: 'baby',
|
|
326
|
+
sex: formData.sex,
|
|
327
|
+
weight: formData.weight,
|
|
328
|
+
physicalcool: formData.physicalcool
|
|
329
|
+
}
|
|
330
|
+
}
|
|
331
|
+
return {
|
|
332
|
+
...commonData,
|
|
333
|
+
diag: formData.diag,
|
|
334
|
+
operateDate: formData.operateDate,
|
|
335
|
+
sphygmus: formData.sphygmus,
|
|
336
|
+
data6: formData.data6,
|
|
337
|
+
data7: formData.data7,
|
|
338
|
+
data8: formData.data8,
|
|
339
|
+
data9: formData.data9
|
|
340
|
+
}
|
|
341
|
+
}
|
|
342
|
+
|
|
343
|
+
// 提交表单
|
|
344
|
+
const submitForm = async () => {
|
|
345
|
+
if (!props.editorReady) {
|
|
346
|
+
message.error('体温单编辑器未加载完成,请等待或刷新页面')
|
|
347
|
+
return
|
|
348
|
+
}
|
|
349
|
+
// 首先验证表单
|
|
350
|
+
if (!validateForm()) {
|
|
351
|
+
return
|
|
352
|
+
}
|
|
353
|
+
submitLoading.value = true
|
|
354
|
+
try {
|
|
355
|
+
const data = getFormData()
|
|
356
|
+
emit('submit', data)
|
|
357
|
+
// 关闭弹窗
|
|
358
|
+
closeModal()
|
|
359
|
+
} catch (err) {
|
|
360
|
+
console.error('提交体温单数据出错:', err)
|
|
361
|
+
message.error(`提交体温单数据失败: ${err.message || '未知错误'}`)
|
|
362
|
+
} finally {
|
|
363
|
+
submitLoading.value = false
|
|
364
|
+
}
|
|
365
|
+
}
|
|
366
|
+
</script>
|
|
367
|
+
|
|
368
|
+
<template>
|
|
369
|
+
<a-modal
|
|
370
|
+
:title="modalTitles[modalType]"
|
|
371
|
+
:visible="visible"
|
|
372
|
+
@cancel="closeModal"
|
|
373
|
+
:width="700"
|
|
374
|
+
:footer="null">
|
|
375
|
+
<a-form :label-col="{ span: 6 }" :wrapper-col="{ span: 18 }">
|
|
376
|
+
<!-- 通用基础信息字段 -->
|
|
377
|
+
<a-form-item label="ID" :validateStatus="formErrors.id ? 'error' : ''" :help="formErrors.id">
|
|
378
|
+
<a-input v-model="formData.id" :placeholder="`请输入ID,如:${modalType === 'baby' ? 'BY' : 'AD'}20230001`" />
|
|
379
|
+
</a-form-item>
|
|
380
|
+
<a-form-item label="姓名" :validateStatus="formErrors.name ? 'error' : ''" :help="formErrors.name">
|
|
381
|
+
<a-input v-model="formData.name" placeholder="请输入姓名,如:张三" />
|
|
382
|
+
</a-form-item>
|
|
383
|
+
<a-form-item label="入院日期" :validateStatus="formErrors.inDate ? 'error' : ''" :help="formErrors.inDate">
|
|
384
|
+
<a-input v-model="formData.inDate" placeholder="请输入日期,如:2023-08-01" />
|
|
385
|
+
</a-form-item>
|
|
386
|
+
<!-- 新生儿特有字段 -->
|
|
387
|
+
<template v-if="modalType === 'baby'">
|
|
388
|
+
<a-form-item label="性别">
|
|
389
|
+
<a-radio-group v-model="formData.sex">
|
|
390
|
+
<a-radio value="男">男</a-radio>
|
|
391
|
+
<a-radio value="女">女</a-radio>
|
|
392
|
+
</a-radio-group>
|
|
393
|
+
</a-form-item>
|
|
394
|
+
</template>
|
|
395
|
+
<!-- 成人特有字段 -->
|
|
396
|
+
<template v-else>
|
|
397
|
+
<a-form-item label="诊断" :validateStatus="formErrors.diag ? 'error' : ''" :help="formErrors.diag">
|
|
398
|
+
<a-input v-model="formData.diag" placeholder="请输入诊断,如:新型冠状病毒肺炎" />
|
|
399
|
+
</a-form-item>
|
|
400
|
+
</template>
|
|
401
|
+
<!-- 通用字段 -->
|
|
402
|
+
<a-form-item label="科室" :validateStatus="formErrors.dept ? 'error' : ''" :help="formErrors.dept">
|
|
403
|
+
<a-input v-model="formData.dept" :placeholder="`请输入科室,如:${modalType === 'baby' ? '妇产科' : '呼吸内科'}`" />
|
|
404
|
+
</a-form-item>
|
|
405
|
+
<a-form-item label="床位" :validateStatus="formErrors.bed ? 'error' : ''" :help="formErrors.bed">
|
|
406
|
+
<a-input v-model="formData.bed" placeholder="请输入床位,如:801" />
|
|
407
|
+
</a-form-item>
|
|
408
|
+
<a-form-item label="病历号" :validateStatus="formErrors.medicalNo ? 'error' : ''" :help="formErrors.medicalNo">
|
|
409
|
+
<a-input v-model="formData.medicalNo" placeholder="请输入病历号,如:202300991" />
|
|
410
|
+
</a-form-item>
|
|
411
|
+
<a-form-item label="开始日期" :validateStatus="formErrors.begin ? 'error' : ''" :help="formErrors.begin">
|
|
412
|
+
<a-input v-model="formData.begin" placeholder="请输入日期,如:2023-08-01" />
|
|
413
|
+
</a-form-item>
|
|
414
|
+
<!-- 成人特有字段 -->
|
|
415
|
+
<template v-if="modalType !== 'baby'">
|
|
416
|
+
<a-form-item label="手术日期" :validateStatus="formErrors.operateDate ? 'error' : ''" :help="formErrors.operateDate">
|
|
417
|
+
<a-input v-model="formData.operateDate" placeholder="请输入日期,如:2023-08-03" />
|
|
418
|
+
</a-form-item>
|
|
419
|
+
</template>
|
|
420
|
+
<!-- 备注字段 -->
|
|
421
|
+
<a-form-item label="备注" :validateStatus="formErrors.notes ? 'error' : ''" :help="formErrors.notes">
|
|
422
|
+
<a-input v-model="formData.notes" :placeholder="`请输入备注,如:${modalType === 'baby' ? '出生-十时二十分' : '入院-十时二十分,,转入ICU,,,,,,,手术'}`" />
|
|
423
|
+
<div class="input-tip">格式:多个值用逗号分隔,对应不同日期</div>
|
|
424
|
+
</a-form-item>
|
|
425
|
+
<!-- 根据表单类型显示不同的数据字段 -->
|
|
426
|
+
<template v-if="modalType !== 'baby'">
|
|
427
|
+
<a-form-item label="脉搏" :validateStatus="formErrors.sphygmus ? 'error' : ''" :help="formErrors.sphygmus">
|
|
428
|
+
<a-input v-model="formData.sphygmus" placeholder="脉搏数据,如:112,110,109,103,108,85" />
|
|
429
|
+
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
430
|
+
</a-form-item>
|
|
431
|
+
</template>
|
|
432
|
+
<template v-else>
|
|
433
|
+
<a-form-item label="体重" :validateStatus="formErrors.weight ? 'error' : ''" :help="formErrors.weight">
|
|
434
|
+
<a-input v-model="formData.weight" placeholder="体重数据,多个值用逗号分隔,如:3200,,,,3300,,,,3400" />
|
|
435
|
+
<div class="input-tip">格式:多个值用逗号分隔,每组数据对应一天</div>
|
|
436
|
+
</a-form-item>
|
|
437
|
+
</template>
|
|
438
|
+
<!-- 生命体征数据字段 -->
|
|
439
|
+
<a-form-item label="心率" :validateStatus="formErrors.heart ? 'error' : ''" :help="formErrors.heart">
|
|
440
|
+
<a-input v-model="formData.heart" placeholder="心率数据,多个值用逗号分隔,如:112,120,118,111" />
|
|
441
|
+
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
442
|
+
</a-form-item>
|
|
443
|
+
<a-form-item label="体温类型" :validateStatus="formErrors.tempType ? 'error' : ''" :help="formErrors.tempType">
|
|
444
|
+
<a-input v-model="formData.tempType" placeholder="体温类型,如:0,1,2,3,0,1" />
|
|
445
|
+
<div class="input-tip">格式:多个值用逗号分隔,0-3表示不同类型</div>
|
|
446
|
+
</a-form-item>
|
|
447
|
+
<a-form-item label="体温" :validateStatus="formErrors.temperature ? 'error' : ''" :help="formErrors.temperature">
|
|
448
|
+
<a-input v-model="formData.temperature" :placeholder="`体温数据,如:${modalType === 'baby' ? '37.7,37.9,38.5,37.1' : '38.7,38.9,38.5,39.1,38.5,38.5|37.1'}`" />
|
|
449
|
+
<div class="input-tip">格式:多个值用逗号分隔<template v-if="modalType !== 'baby'">,|表示新一行数据</template></div>
|
|
450
|
+
</a-form-item>
|
|
451
|
+
<!-- 新生儿特有字段 -->
|
|
452
|
+
<template v-if="modalType === 'baby'">
|
|
453
|
+
<a-form-item label="物理降温" :validateStatus="formErrors.physicalcool ? 'error' : ''" :help="formErrors.physicalcool">
|
|
454
|
+
<a-input v-model="formData.physicalcool" placeholder="物理降温数据,如:,,,37.6,,,,,,,,37.5" />
|
|
455
|
+
<div class="input-tip">格式:多个值用逗号分隔,空值用逗号表示</div>
|
|
456
|
+
</a-form-item>
|
|
457
|
+
</template>
|
|
458
|
+
<!-- 通用数据字段 -->
|
|
459
|
+
<a-form-item label="呼吸" :validateStatus="formErrors.breath ? 'error' : ''" :help="formErrors.breath">
|
|
460
|
+
<a-input v-model="formData.breath" placeholder="呼吸数据,如:30,30,R,,35,35" />
|
|
461
|
+
<div class="input-tip">格式:多个值用逗号分隔,R表示异常</div>
|
|
462
|
+
</a-form-item>
|
|
463
|
+
<a-form-item label="标签" :validateStatus="formErrors.labels ? 'error' : ''" :help="formErrors.labels">
|
|
464
|
+
<a-input v-model="formData.labels" :placeholder="`标签数据,如:血压(mmHg)|入水量(ml)|出水量(ml)|大便(次)|小便(次)${modalType === 'baby' ? '' : '|身高(cm)|体重(kg)|过敏药'}`" />
|
|
465
|
+
<div class="input-tip">格式:多个标签用|分隔</div>
|
|
466
|
+
</a-form-item>
|
|
467
|
+
<!-- 通用数据字段 -->
|
|
468
|
+
<a-form-item label="血压" :validateStatus="formErrors.data1 ? 'error' : ''" :help="formErrors.data1">
|
|
469
|
+
<a-input v-model="formData.data1" placeholder="血压数据,如:120/85,121/84,,110/75" />
|
|
470
|
+
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
471
|
+
</a-form-item>
|
|
472
|
+
<a-form-item label="入水量" :validateStatus="formErrors.data2 ? 'error' : ''" :help="formErrors.data2">
|
|
473
|
+
<a-input v-model="formData.data2" placeholder="入水量数据,如:1180ml,,,500ml,,40ml" />
|
|
474
|
+
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
475
|
+
</a-form-item>
|
|
476
|
+
<a-form-item label="出水量" :validateStatus="formErrors.data3 ? 'error' : ''" :help="formErrors.data3">
|
|
477
|
+
<a-input v-model="formData.data3" placeholder="出水量数据,如:500ml,,,,500ml,,67ml" />
|
|
478
|
+
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
479
|
+
</a-form-item>
|
|
480
|
+
<a-form-item label="大便次数" :validateStatus="formErrors.data4 ? 'error' : ''" :help="formErrors.data4">
|
|
481
|
+
<a-input v-model="formData.data4" placeholder="大便次数数据,如:2,4,5,3,3,3,2,,2" />
|
|
482
|
+
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
483
|
+
</a-form-item>
|
|
484
|
+
<a-form-item label="小便次数" :validateStatus="formErrors.data5 ? 'error' : ''" :help="formErrors.data5">
|
|
485
|
+
<a-input v-model="formData.data5" placeholder="小便次数数据,如:2,4,5,3,3,3,2,,2" />
|
|
486
|
+
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
487
|
+
</a-form-item>
|
|
488
|
+
<!-- 成人特有字段 -->
|
|
489
|
+
<template v-if="modalType !== 'baby'">
|
|
490
|
+
<a-form-item label="身高" :validateStatus="formErrors.data6 ? 'error' : ''" :help="formErrors.data6">
|
|
491
|
+
<a-input v-model="formData.data6" placeholder="身高数据,如:167cm,,,,,,,,,164cm" />
|
|
492
|
+
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
493
|
+
</a-form-item>
|
|
494
|
+
<a-form-item label="体重" :validateStatus="formErrors.data7 ? 'error' : ''" :help="formErrors.data7">
|
|
495
|
+
<a-input v-model="formData.data7" placeholder="体重数据,如:95kg,,,,,90kg" />
|
|
496
|
+
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
497
|
+
</a-form-item>
|
|
498
|
+
<a-form-item label="过敏药" :validateStatus="formErrors.data8 ? 'error' : ''" :help="formErrors.data8">
|
|
499
|
+
<a-input v-model="formData.data8" placeholder="过敏药数据,如:青霉素," />
|
|
500
|
+
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
501
|
+
</a-form-item>
|
|
502
|
+
<a-form-item label="其他数据" :validateStatus="formErrors.data9 ? 'error' : ''" :help="formErrors.data9">
|
|
503
|
+
<a-input v-model="formData.data9" placeholder="其他数据,如:测试," />
|
|
504
|
+
<div class="input-tip">格式:多个值用逗号分隔</div>
|
|
505
|
+
</a-form-item>
|
|
506
|
+
</template>
|
|
507
|
+
<!-- 按钮 -->
|
|
508
|
+
<a-form-item :wrapper-col="{ span: 18, offset: 6 }">
|
|
509
|
+
<a-button type="primary" @click="submitForm" :loading="submitLoading" style="margin-right: 10px">确定</a-button>
|
|
510
|
+
<a-button @click="closeModal">取消</a-button>
|
|
511
|
+
</a-form-item>
|
|
512
|
+
</a-form>
|
|
513
|
+
</a-modal>
|
|
514
|
+
</template>
|
|
515
|
+
|
|
516
|
+
<style scoped>
|
|
517
|
+
.input-tip {
|
|
518
|
+
color: #999;
|
|
519
|
+
font-size: 12px;
|
|
520
|
+
margin-top: 4px;
|
|
521
|
+
}
|
|
522
|
+
</style>
|