vue2-client 1.14.57 → 1.14.59

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