vue2-client 1.15.93 → 1.15.96

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 (147) hide show
  1. package/docs//345/207/275/346/225/260/344/275/277/347/224/250/347/233/270/345/205/263.md +0 -6
  2. package/package.json +1 -1
  3. package/src/base-client/components/common/XFormTable/demo.vue +2 -2
  4. package/src/base-client/components/his/XHisEditor/XHisEditor.vue +2 -52
  5. package/src/base-client/components/his/XImportExcelButton/XFrontImportExcel.vue +11 -7
  6. package/src/base-client/components/his/XImportExcelButton/XFrontImportExcelDemo.vue +1 -1
  7. package/src/base-client/components/his/XList/XList.vue +1 -1
  8. package/src/base-client/components/his/XTextCard/XTextCard.vue +207 -207
  9. package/src/base-client/components/his/threeTestOrders/editor.vue +111 -111
  10. package/src/layouts/BlankView.vue +5 -3
  11. package/src/pages/WorkflowDetail/WorkflowDetail.vue +5 -5
  12. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowBaseInformation.vue +1 -1
  13. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowBaseInformationDetails.vue +1 -1
  14. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandle.vue +4 -4
  15. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowTimeline.vue +1 -1
  16. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkOrderParentDetails.vue +2 -6
  17. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowListResolution.vue +2 -2
  18. package/src/router/async/router.map.js +2 -1
  19. package/src/utils/routerUtil.js +16 -2
  20. package/.history/public/his/editor/editor_20250606134713.html +0 -51
  21. package/.history/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox_20250527173925.vue +0 -509
  22. package/.history/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox_20250527174316.vue +0 -524
  23. package/.history/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox_20250527174419.vue +0 -524
  24. package/.history/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox_20250527174422.vue +0 -524
  25. package/.history/src/base-client/components/common/XAddReport/XAddReport_20250611172825.vue +0 -207
  26. package/.history/src/base-client/components/common/XAddReport/XAddReport_20250611172945.vue +0 -211
  27. package/.history/src/base-client/components/common/XAddReport/XAddReport_20250611172949.vue +0 -212
  28. package/.history/src/base-client/components/common/XAddReport/XAddReport_20250611173010.vue +0 -212
  29. package/.history/src/base-client/components/common/XForm/XFormItem_20250508134122.vue +0 -1320
  30. package/.history/src/base-client/components/common/XForm/XFormItem_20250527171604.vue +0 -1332
  31. package/.history/src/base-client/components/common/XForm/XFormItem_20250527171613.vue +0 -1331
  32. package/.history/src/base-client/components/common/XForm/XFormItem_20250527171703.vue +0 -1331
  33. package/.history/src/base-client/components/common/XForm/XFormItem_20250527171720.vue +0 -1331
  34. package/.history/src/base-client/components/common/XForm/XFormItem_20250527174327.vue +0 -1339
  35. package/.history/src/base-client/components/common/XReportGrid/XReportTrGroup_20250612092804.vue +0 -731
  36. package/.history/src/base-client/components/common/XReportGrid/XReportTrGroup_20250612112546.vue +0 -748
  37. package/.history/src/base-client/components/common/XReportGrid/XReportTrGroup_20250612113808.vue +0 -748
  38. package/.history/src/base-client/components/common/XReportGrid/XReport_20250612115237.vue +0 -1071
  39. package/.history/src/base-client/components/common/XReportGrid/XReport_20250612115346.vue +0 -1078
  40. package/.history/src/base-client/components/common/XReportGrid/XReport_20250612115350.vue +0 -1077
  41. package/.history/src/base-client/components/common/XReportGrid/XReport_20250612115415.vue +0 -1077
  42. package/.history/src/base-client/components/common/XReportGrid/XReport_20250612115429.vue +0 -1077
  43. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611091619.vue +0 -442
  44. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611092547.vue +0 -442
  45. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611092552.vue +0 -442
  46. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611092744.vue +0 -475
  47. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611092955.vue +0 -475
  48. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611092957.vue +0 -475
  49. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611095652.vue +0 -477
  50. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611095701.vue +0 -477
  51. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611095704.vue +0 -477
  52. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611100005.vue +0 -473
  53. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611100011.vue +0 -473
  54. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611100014.vue +0 -473
  55. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611100833.vue +0 -473
  56. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611100853.vue +0 -473
  57. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611100940.vue +0 -473
  58. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101011.vue +0 -473
  59. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101013.vue +0 -473
  60. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101014.vue +0 -473
  61. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101159.vue +0 -473
  62. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101238.vue +0 -474
  63. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101240.vue +0 -474
  64. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101242.vue +0 -474
  65. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101404.vue +0 -472
  66. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101410.vue +0 -472
  67. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101459.vue +0 -472
  68. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101500.vue +0 -472
  69. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101502.vue +0 -472
  70. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101504.vue +0 -472
  71. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101610.vue +0 -501
  72. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101700.vue +0 -501
  73. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101702.vue +0 -501
  74. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101741.vue +0 -504
  75. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101749.vue +0 -504
  76. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101759.vue +0 -504
  77. package/.history/src/base-client/components/his/XHisEditor/dome_20250611091349.vue +0 -131
  78. package/.history/src/base-client/components/his/XHisEditor/dome_20250611105854.vue +0 -160
  79. package/.history/src/base-client/components/his/XHisEditor/dome_20250611105902.vue +0 -160
  80. package/.history/src/base-client/components/his/XHisEditor/dome_20250611105924.vue +0 -160
  81. package/.history/src/base-client/components/his/XHisEditor/dome_20250611105932.vue +0 -158
  82. package/.history/src/base-client/components/his/XList/XList_20250609135848.vue +0 -173
  83. package/.history/src/base-client/components/his/XList/XList_20250609141026.vue +0 -222
  84. package/.history/src/base-client/components/his/XList/XList_20250609141035.vue +0 -229
  85. package/.history/src/base-client/components/his/XList/XList_20250609141103.vue +0 -229
  86. package/.history/src/base-client/components/his/XList/XList_20250609141105.vue +0 -229
  87. package/.history/src/base-client/components/his/XList/XList_20250609141334.vue +0 -241
  88. package/.history/src/base-client/components/his/XList/XList_20250609141404.vue +0 -241
  89. package/.history/src/base-client/components/his/XList/XList_20250609141406.vue +0 -241
  90. package/.history/src/base-client/components/his/XList/XList_20250609141801.vue +0 -245
  91. package/.history/src/base-client/components/his/XList/XList_20250609142033.vue +0 -245
  92. package/.history/src/base-client/components/his/XList/XList_20250609142038.vue +0 -245
  93. package/.history/src/base-client/components/his/XList/XList_20250609142435.vue +0 -255
  94. package/.history/src/base-client/components/his/XList/XList_20250609142503.vue +0 -255
  95. package/.history/src/base-client/components/his/XList/XList_20250609142504.vue +0 -255
  96. package/.history/src/base-client/components/his/XList/XList_20250609143012.vue +0 -270
  97. package/.history/src/base-client/components/his/XList/XList_20250609143044.vue +0 -270
  98. package/.history/src/base-client/components/his/XList/XList_20250609143046.vue +0 -270
  99. package/.history/src/base-client/components/his/XList/XList_20250609143210.vue +0 -270
  100. package/.history/src/base-client/components/his/XList/XList_20250609144339.vue +0 -294
  101. package/.history/src/base-client/components/his/XList/XList_20250609144410.vue +0 -294
  102. package/.history/src/base-client/components/his/XList/XList_20250609144412.vue +0 -294
  103. package/.history/src/base-client/components/his/XList/XList_20250609144647.vue +0 -303
  104. package/.history/src/base-client/components/his/XList/XList_20250609144716.vue +0 -303
  105. package/.history/src/base-client/components/his/XList/XList_20250609144729.vue +0 -303
  106. package/.history/src/base-client/components/his/XList/XList_20250609151232.vue +0 -288
  107. package/.history/src/base-client/components/his/XList/XList_20250609151247.vue +0 -288
  108. package/.history/src/base-client/components/his/XList/XList_20250609151252.vue +0 -288
  109. package/.history/src/base-client/components/his/XList/XList_20250609161220.vue +0 -317
  110. package/.history/src/base-client/components/his/XList/XList_20250609161258.vue +0 -306
  111. package/.history/src/base-client/components/his/XList/XList_20250609161319.vue +0 -306
  112. package/.history/src/base-client/components/his/XList/XList_20250609161320.vue +0 -306
  113. package/.history/src/base-client/components/his/XList/XList_20250704142024.vue +0 -495
  114. package/.history/src/base-client/components/his/XList/XList_20250704142033.vue +0 -495
  115. package/.history/src/base-client/components/his/XList/XList_20250704142040.vue +0 -494
  116. package/.history/src/base-client/components/his/XList/XList_20250704142211.vue +0 -494
  117. package/.history/src/base-client/components/his/XList/XList_20250704142214.vue +0 -494
  118. package/.history/src/base-client/components/his/XList/XList_20250704143010.vue +0 -495
  119. package/.history/src/base-client/components/his/XList/XList_20250704143203.vue +0 -495
  120. package/.history/src/base-client/components/his/XList/XList_20250707095101.vue +0 -492
  121. package/.history/src/base-client/components/his/XList/XList_20250707100152.vue +0 -492
  122. package/.history/src/base-client/components/his/XList/XList_20250707100200.vue +0 -485
  123. package/.history/src/base-client/components/his/XList/XList_20250707100208.vue +0 -485
  124. package/.history/src/base-client/components/his/XList/XList_20250707100259.vue +0 -488
  125. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250609151519.vue +0 -222
  126. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250612155514.vue +0 -183
  127. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250612155556.vue +0 -183
  128. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250612155600.vue +0 -183
  129. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250612181609.vue +0 -206
  130. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250612181629.vue +0 -209
  131. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613095553.vue +0 -242
  132. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613095610.vue +0 -242
  133. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613095612.vue +0 -242
  134. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613100041.vue +0 -251
  135. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613100047.vue +0 -251
  136. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613100054.vue +0 -250
  137. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613100105.vue +0 -250
  138. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613100107.vue +0 -250
  139. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613100114.vue +0 -250
  140. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613140844.vue +0 -238
  141. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613140910.vue +0 -238
  142. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613140912.vue +0 -238
  143. package/Users/objecrt/af-vue2-client/src/base-client/components/his/XShiftSchedule/XShiftSchedule.vue +0 -36
  144. package/src/base-client/components/TreeList/TreeList.vue +0 -91
  145. package/src/base-client/components/TreeList/TreeNode.vue +0 -81
  146. package/src/base-client/components/common/XCardSet/XTiltle.vue +0 -191
  147. package/src/base-client/components/his/XHisEditor/dome.vue +0 -144
@@ -19,12 +19,6 @@
19
19
  - getOutEnv 获取获取 outEnv
20
20
  - this.getRealKeyData(obj) 获取真实的数据 传递 {a_a:"1"} 返回 {a:"1"}
21
21
  - this.currUser.operaInfo 获取当前用户信息
22
- - 返回:{
23
- f_operator: "心血管内科医生2", f_operatorid: "387280281096290306",
24
- f_orgid: "387184994751217666", f_orgname: "门诊部",
25
- f_depid: "387185267599081474", f_depname: "心血管内科"
26
- }
27
-
28
22
 
29
23
  ```js
30
24
  this.openDialog('xxx', 5, {}, {}, {})
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "vue2-client",
3
- "version": "1.15.93",
3
+ "version": "1.15.96",
4
4
  "private": false,
5
5
  "scripts": {
6
6
  "serve": "SET NODE_OPTIONS=--openssl-legacy-provider && vue-cli-service serve --no-eslint",
@@ -8,7 +8,7 @@
8
8
  @action="action"
9
9
  @selectRow="selectRow"
10
10
  @columnClick="columnClick"
11
- serviceName="af-system"
11
+ serviceName="af-revenue"
12
12
  ref="xFormTable">
13
13
  </x-form-table>
14
14
  </a-card>
@@ -26,7 +26,7 @@ export default {
26
26
  data () {
27
27
  return {
28
28
  // 查询配置文件名
29
- queryParamsName: 'ceshiCRUD',
29
+ queryParamsName: 'UserFilesListCRUD',
30
30
  // 新增表单固定值
31
31
  fixedAddForm: {},
32
32
  // 是否显示详情抽屉
@@ -39,9 +39,7 @@
39
39
  <!-- >-->
40
40
  <!-- 使用-->
41
41
  <!-- </a-button>-->
42
- <a-button type="primary" @click="Recording" v-if="this.resId !== -1" v-model="recording">
43
- {{recording? '停止' : '录音'}}
44
- </a-button>
42
+
45
43
  <a-button type="primary" @click="openRenameModal" v-if="this.resId !== -1">
46
44
  重命名
47
45
  </a-button>
@@ -78,7 +76,7 @@
78
76
  <a-modal
79
77
  title="保存"
80
78
  :visible="saveVisible"
81
- :confirm-loading = "false"
79
+ confirm-loading = false
82
80
  @ok="handleSaveConfirm"
83
81
  @cancel="saveVisible = false"
84
82
  >
@@ -157,7 +155,6 @@ export default {
157
155
  },
158
156
  data () {
159
157
  return {
160
- recording: false, // 是否正在录音
161
158
  readonly: false,
162
159
  ready: false,
163
160
  loading: false,
@@ -200,7 +197,6 @@ export default {
200
197
  ],
201
198
  // 编辑器实例
202
199
  editorRef: null,
203
-
204
200
  // 文档资源列表
205
201
  resList: [],
206
202
  // 文档资源ID
@@ -332,7 +328,6 @@ export default {
332
328
  }
333
329
  },
334
330
  init (params) {
335
-
336
331
  const {
337
332
  fileUrl,
338
333
  resId,
@@ -419,51 +414,6 @@ export default {
419
414
  changeMode (e) {
420
415
  this.editorRef.execCommand(this.modeType)
421
416
  },
422
- // 启动录音功能
423
- async Recording () {
424
- this.recording = !this.recording
425
- if (this.recording) {
426
- const recording = await this.$recording.startRecording()
427
- this.$message.warn(recording.msg)
428
- } else {
429
- try {
430
- // 1. 获取录音和接口数据
431
- const recording = this.$recording.stopRecording()
432
- this.$message.warn(recording.msg)
433
- const data = await this.$recording.getRecordingData()
434
- const result = await this.runLogic('communacation', {record_content: data}, 'af-his')
435
- // 验证基础结构
436
- if (!result || typeof result.value !== 'string') {
437
- throw new Error('接口返回格式错误,缺少有效的value字段')
438
- }
439
- // 2. 处理外层JSON字符串(关键修复)
440
- let outerJsonStr = result.value
441
- // 修复1:处理布尔值
442
- outerJsonStr = outerJsonStr.replace(/\bTrue\b/g, 'true')
443
- // 修复2:移除所有控制字符
444
- outerJsonStr = outerJsonStr.replace(/[\x00-\x1F]/g, '')
445
- // 修复3:精准转义data字段内的双引号
446
- // 匹配 "data": "..." 结构并转义内容中的双引号
447
- outerJsonStr = outerJsonStr.replace(/"data":\s*"([^"]*)"/g, (match, content) => {
448
- // 转义内容中的双引号为\"
449
- const escapedContent = content.replace(/"/g, '\\"')
450
- return `"data": "${escapedContent}"`
451
- })
452
- // 直接在整个字符串里匹配 ```json{...}```
453
- const regex = /```json([\s\S]*?)```/
454
- const match = outerJsonStr.match(regex)
455
- let extractedJsonStr = ''
456
- if (match && match[1]) {
457
- extractedJsonStr = match[1].trim()
458
- }
459
- const outerObj = JSON.parse(extractedJsonStr)
460
- console.log("outerObj = ", outerObj)
461
- } catch (e) {
462
- console.error('总错误:', e.message)
463
- this.$message.error(`解析失败: ${e.message}`)
464
- }
465
- }
466
- },
467
417
  // 打开文档信息修改面板
468
418
  openRenameModal () {
469
419
  this.resDataModalMode = 'modify'
@@ -50,7 +50,7 @@
50
50
 
51
51
  <script>
52
52
 
53
- import { importData, downloadImportExcel, getConfigByName } from '@vue2-client/services/api/common'
53
+ import { importData, downloadImportExcel, getNativeConfig } from '@vue2-client/services/api/common'
54
54
  import { excleParseArrays } from '@vue2-client/utils/excel/Export2Excel'
55
55
  import { mapState } from 'vuex'
56
56
 
@@ -135,13 +135,17 @@ export default {
135
135
  }
136
136
  },
137
137
  /** 读取excle导入模板 */
138
- readTemplateConfig () {
139
- getConfigByName(this.queryParamsName, 'af-his', res => {
140
- console.log('res2=====>', res)
141
- if (res != null && res != undefined) {
142
- this.excelImportTemplate = res.excelImportTemplate[0]?.column
138
+ async readTemplateConfig () {
139
+ try {
140
+ const config = await getNativeConfig(this.queryParamsName, 'af-his', true)
141
+ if (config != null && config != undefined) {
142
+ this.excelImportTemplate = config.column.filter(item =>
143
+ item.dataModeArray && item.dataModeArray.includes('excelImportItem')
144
+ ).map(item => item.key.replace('.', '_'))
143
145
  }
144
- })
146
+ } catch (e) {
147
+ console.error('读取excle模板列报错:', e.msg)
148
+ }
145
149
  },
146
150
  beforeUpload (file) {
147
151
  this.fileList = [file]
@@ -7,7 +7,7 @@ export default {
7
7
  },
8
8
  data () {
9
9
  return {
10
- queryParamsName: 'testImprot'
10
+ queryParamsName: 'IkukuImportButtonConfig'
11
11
  }
12
12
  }
13
13
  }
@@ -452,7 +452,7 @@ export default {
452
452
  .demo-infinite-container{
453
453
  overflow-x: hidden;
454
454
  overflow-y: auto;
455
- height: 85vh;
455
+ height: 80vh;
456
456
  }
457
457
  .card-row{
458
458
  height: 100%;
@@ -1,207 +1,207 @@
1
- <template>
2
- <div>
3
- <div class="text-card">
4
- <div
5
- v-for="(item, index) in displayItems"
6
- :key="index"
7
- class="text-item"
8
- @click="handleItemClick(index, item.id)"
9
- @contextmenu.prevent="handleContextMenu(index, item.id)">
10
- <div class="text-content" :class="{ 'is-empty': !item.content }">
11
- {{ item.content || '+' }}
12
- </div>
13
- </div>
14
- <!-- 编辑弹出框 -->
15
- <div
16
- v-if="showEdit"
17
- class="edit-overlay"
18
- @click.self="handleOverlayClick">
19
- <div class="edit-card">
20
- <a-textarea
21
- v-model="editingContent"
22
- :autoSize="{ minRows: 3 }"
23
- @keyup.enter="handleSave"
24
- ref="textarea"/>
25
- </div>
26
- </div>
27
- <!-- 删除确认弹框 -->
28
- <a-modal
29
- v-model="showDeleteModal"
30
- title="确认删除"
31
- okText="确认"
32
- cancelText="取消"
33
- @ok="handleDeleteConfirm">
34
- <p>确定要删除这条内容吗?</p>
35
- </a-modal>
36
- </div>
37
- </div>
38
- </template>
39
-
40
- <script>
41
- import { runLogic } from '@vue2-client/services/api/common'
42
-
43
- export default {
44
- name: 'XTextCard',
45
- props: {
46
- // logic配置名,要求返回一个数组[{ id: , content: }]
47
- queryParamsName: {
48
- type: String,
49
- default: 'memorandumLOGIC'
50
- },
51
- queryParams: {
52
- type: Object,
53
- default: () => { return {} }
54
- },
55
- // 请求参数
56
- parameter: {
57
- type: Object,
58
- default: () => { return {} }
59
- }
60
- },
61
- data () {
62
- return {
63
- localItems: [], // 本地数据
64
- showEdit: false, // 是否显示编辑框
65
- editingIndex: -1, // 当前编辑的索引
66
- editingContent: '', // 编辑框的内容
67
- showDeleteModal: false, // 是否显示删除确认框
68
- deleteIndex: -1, // 要删除的项目索引
69
- ID: 0
70
- }
71
- },
72
- computed: {
73
- // 显示的列表,始终保持一个空行
74
- displayItems () {
75
- const items = [...this.localItems]
76
- // 如果最后一项不是空的,添加一个空项
77
- if (!items.length || items[items.length - 1].content) {
78
- items.push({ content: '' })
79
- }
80
- return items
81
- }
82
- },
83
- methods: {
84
- // 点击项目
85
- handleItemClick (index, id) {
86
- this.ID = id
87
- this.editingIndex = index
88
- this.editingContent = this.displayItems[index].content
89
- this.showEdit = true
90
- this.$nextTick(() => {
91
- this.$refs.textarea?.focus()
92
- })
93
- },
94
- // 点击遮罩层保存
95
- handleOverlayClick () {
96
- this.handleSave()
97
- },
98
- // 保存内容
99
- handleSave () {
100
- if (this.editingContent.trim()) {
101
- if (this.editingIndex === this.localItems.length) {
102
- // 如果是在最后一个空行添加,push新内容
103
- this.localItems.push({ content: this.editingContent.trim() })
104
- } else {
105
- // 否则更新现有内容
106
- this.localItems[this.editingIndex].content = this.editingContent.trim()
107
- }
108
- const addData = { data: this.editingContent.trim(), ID: this.ID }
109
- // 触发更新事件
110
- this.$emit('add', addData)
111
- }
112
- this.showEdit = false
113
- this.editingIndex = -1
114
- this.editingContent = ''
115
- },
116
- // 初始化数据
117
- async initData (data, parameter) {
118
- // 从配置中获取数据
119
- const resData = await runLogic(data, parameter, 'af-his')
120
- this.localItems = resData
121
- return resData
122
- },
123
- // 处理右键菜单
124
- handleContextMenu (index, id) {
125
- // 如果是最后一个空行,不显示删除框
126
- if (index === this.localItems.length) {
127
- return
128
- }
129
- this.ID = id
130
- this.deleteIndex = index
131
- this.showDeleteModal = true
132
- },
133
- // 确认删除
134
- handleDeleteConfirm () {
135
- if (this.deleteIndex > -1) {
136
- this.localItems.splice(this.deleteIndex, 1)
137
- const deleteData = { data: [...this.localItems][this.deleteIndex], ID: this.ID }
138
- this.$emit('deleteData', deleteData)
139
- this.deleteIndex = -1
140
- }
141
- this.showDeleteModal = false
142
- }
143
- },
144
- watch: {
145
- queryParamsName: {
146
- immediate: true,
147
- handler (newVal) {
148
- this.initData(newVal, this.parameter)
149
- },
150
- deep: true
151
- }
152
- }
153
- }
154
- </script>
155
-
156
- <style scoped lang="less">
157
- .text-card {
158
- position: relative;
159
- width: 100%;
160
- .text-item {
161
- padding: 8px 12px;
162
- border-bottom: 1px solid #f0f0f0;
163
- cursor: pointer;
164
- transition: all 0.3s;
165
- user-select: none;
166
-
167
- &:hover {
168
- background-color: #f5f5f5;
169
- }
170
-
171
- .text-content {
172
- white-space: nowrap;
173
- overflow: hidden;
174
- text-overflow: ellipsis;
175
- line-height: 1.5;
176
-
177
- &.is-empty {
178
- color: #5D5C5C;
179
- font-weight: 400;
180
- }
181
- }
182
- }
183
- .edit-overlay {
184
- position: fixed;
185
- top: 0;
186
- left: 0;
187
- right: 0;
188
- bottom: 0;
189
- background-color: rgba(0, 0, 0, 0.45);
190
- z-index: 1000;
191
- display: flex;
192
- align-items: center;
193
- justify-content: center;
194
- .edit-card {
195
- background: white;
196
- padding: 16px;
197
- border-radius: 8px;
198
- width: 90%;
199
- max-width: 500px;
200
- box-shadow: 0 3px 6px -4px rgba(0, 0, 0, 0.12);
201
- .ant-input {
202
- width: 100%;
203
- }
204
- }
205
- }
206
- }
207
- </style>
1
+ <template>
2
+ <div>
3
+ <div class="text-card">
4
+ <div
5
+ v-for="(item, index) in displayItems"
6
+ :key="index"
7
+ class="text-item"
8
+ @click="handleItemClick(index, item.id)"
9
+ @contextmenu.prevent="handleContextMenu(index, item.id)">
10
+ <div class="text-content" :class="{ 'is-empty': !item.content }">
11
+ {{ item.content || '+' }}
12
+ </div>
13
+ </div>
14
+ <!-- 编辑弹出框 -->
15
+ <div
16
+ v-if="showEdit"
17
+ class="edit-overlay"
18
+ @click.self="handleOverlayClick">
19
+ <div class="edit-card">
20
+ <a-textarea
21
+ v-model="editingContent"
22
+ :autoSize="{ minRows: 3 }"
23
+ @keyup.enter="handleSave"
24
+ ref="textarea"/>
25
+ </div>
26
+ </div>
27
+ <!-- 删除确认弹框 -->
28
+ <a-modal
29
+ v-model="showDeleteModal"
30
+ title="确认删除"
31
+ okText="确认"
32
+ cancelText="取消"
33
+ @ok="handleDeleteConfirm">
34
+ <p>确定要删除这条内容吗?</p>
35
+ </a-modal>
36
+ </div>
37
+ </div>
38
+ </template>
39
+
40
+ <script>
41
+ import { runLogic } from '@vue2-client/services/api/common'
42
+
43
+ export default {
44
+ name: 'XTextCard',
45
+ props: {
46
+ // logic配置名,要求返回一个数组[{ id: , content: }]
47
+ queryParamsName: {
48
+ type: String,
49
+ default: 'memorandumLOGIC'
50
+ },
51
+ queryParams: {
52
+ type: Object,
53
+ default: () => { return {} }
54
+ },
55
+ // 请求参数
56
+ parameter: {
57
+ type: Object,
58
+ default: () => { return {} }
59
+ }
60
+ },
61
+ data () {
62
+ return {
63
+ localItems: [], // 本地数据
64
+ showEdit: false, // 是否显示编辑框
65
+ editingIndex: -1, // 当前编辑的索引
66
+ editingContent: '', // 编辑框的内容
67
+ showDeleteModal: false, // 是否显示删除确认框
68
+ deleteIndex: -1, // 要删除的项目索引
69
+ ID: 0
70
+ }
71
+ },
72
+ computed: {
73
+ // 显示的列表,始终保持一个空行
74
+ displayItems () {
75
+ const items = [...this.localItems]
76
+ // 如果最后一项不是空的,添加一个空项
77
+ if (!items.length || items[items.length - 1].content) {
78
+ items.push({ content: '' })
79
+ }
80
+ return items
81
+ }
82
+ },
83
+ methods: {
84
+ // 点击项目
85
+ handleItemClick (index, id) {
86
+ this.ID = id
87
+ this.editingIndex = index
88
+ this.editingContent = this.displayItems[index].content
89
+ this.showEdit = true
90
+ this.$nextTick(() => {
91
+ this.$refs.textarea?.focus()
92
+ })
93
+ },
94
+ // 点击遮罩层保存
95
+ handleOverlayClick () {
96
+ this.handleSave()
97
+ },
98
+ // 保存内容
99
+ handleSave () {
100
+ if (this.editingContent.trim()) {
101
+ if (this.editingIndex === this.localItems.length) {
102
+ // 如果是在最后一个空行添加,push新内容
103
+ this.localItems.push({ content: this.editingContent.trim() })
104
+ } else {
105
+ // 否则更新现有内容
106
+ this.localItems[this.editingIndex].content = this.editingContent.trim()
107
+ }
108
+ const addData = { data: this.editingContent.trim(), ID: this.ID }
109
+ // 触发更新事件
110
+ this.$emit('add', addData)
111
+ }
112
+ this.showEdit = false
113
+ this.editingIndex = -1
114
+ this.editingContent = ''
115
+ },
116
+ // 初始化数据
117
+ async initData (data, parameter) {
118
+ // 从配置中获取数据
119
+ const resData = await runLogic(data, parameter, 'af-his')
120
+ this.localItems = resData
121
+ return resData
122
+ },
123
+ // 处理右键菜单
124
+ handleContextMenu (index, id) {
125
+ // 如果是最后一个空行,不显示删除框
126
+ if (index === this.localItems.length) {
127
+ return
128
+ }
129
+ this.ID = id
130
+ this.deleteIndex = index
131
+ this.showDeleteModal = true
132
+ },
133
+ // 确认删除
134
+ handleDeleteConfirm () {
135
+ if (this.deleteIndex > -1) {
136
+ this.localItems.splice(this.deleteIndex, 1)
137
+ const deleteData = { data: [...this.localItems][this.deleteIndex], ID: this.ID }
138
+ this.$emit('deleteData', deleteData)
139
+ this.deleteIndex = -1
140
+ }
141
+ this.showDeleteModal = false
142
+ }
143
+ },
144
+ watch: {
145
+ queryParamsName: {
146
+ immediate: true,
147
+ handler (newVal) {
148
+ this.initData(newVal, this.parameter)
149
+ },
150
+ deep: true
151
+ }
152
+ }
153
+ }
154
+ </script>
155
+
156
+ <style scoped lang="less">
157
+ .text-card {
158
+ position: relative;
159
+ width: 100%;
160
+ .text-item {
161
+ padding: 8px 12px;
162
+ border-bottom: 1px solid #f0f0f0;
163
+ cursor: pointer;
164
+ transition: all 0.3s;
165
+ user-select: none;
166
+
167
+ &:hover {
168
+ background-color: #f5f5f5;
169
+ }
170
+
171
+ .text-content {
172
+ white-space: nowrap;
173
+ overflow: hidden;
174
+ text-overflow: ellipsis;
175
+ line-height: 1.5;
176
+
177
+ &.is-empty {
178
+ color: #5D5C5C;
179
+ font-weight: 400;
180
+ }
181
+ }
182
+ }
183
+ .edit-overlay {
184
+ position: fixed;
185
+ top: 0;
186
+ left: 0;
187
+ right: 0;
188
+ bottom: 0;
189
+ background-color: rgba(0, 0, 0, 0.45);
190
+ z-index: 1000;
191
+ display: flex;
192
+ align-items: center;
193
+ justify-content: center;
194
+ .edit-card {
195
+ background: white;
196
+ padding: 16px;
197
+ border-radius: 8px;
198
+ width: 90%;
199
+ max-width: 500px;
200
+ box-shadow: 0 3px 6px -4px rgba(0, 0, 0, 0.12);
201
+ .ant-input {
202
+ width: 100%;
203
+ }
204
+ }
205
+ }
206
+ }
207
+ </style>