vue2-client 1.15.102 → 1.15.104

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 (184) hide show
  1. package/.history/public/his/editor/editor_20250606134713.html +51 -0
  2. package/.history/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox_20250527173925.vue +509 -0
  3. package/.history/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox_20250527174316.vue +524 -0
  4. package/.history/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox_20250527174419.vue +524 -0
  5. package/.history/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox_20250527174422.vue +524 -0
  6. package/.history/src/base-client/components/common/XAddReport/XAddReport_20250611172825.vue +207 -0
  7. package/.history/src/base-client/components/common/XAddReport/XAddReport_20250611172945.vue +211 -0
  8. package/.history/src/base-client/components/common/XAddReport/XAddReport_20250611172949.vue +212 -0
  9. package/.history/src/base-client/components/common/XAddReport/XAddReport_20250611173010.vue +212 -0
  10. package/.history/src/base-client/components/common/XForm/XFormItem_20250508134122.vue +1320 -0
  11. package/.history/src/base-client/components/common/XForm/XFormItem_20250527171604.vue +1332 -0
  12. package/.history/src/base-client/components/common/XForm/XFormItem_20250527171613.vue +1331 -0
  13. package/.history/src/base-client/components/common/XForm/XFormItem_20250527171703.vue +1331 -0
  14. package/.history/src/base-client/components/common/XForm/XFormItem_20250527171720.vue +1331 -0
  15. package/.history/src/base-client/components/common/XForm/XFormItem_20250527174327.vue +1339 -0
  16. package/.history/src/base-client/components/common/XReportGrid/XReportTrGroup_20250612092804.vue +731 -0
  17. package/.history/src/base-client/components/common/XReportGrid/XReportTrGroup_20250612112546.vue +748 -0
  18. package/.history/src/base-client/components/common/XReportGrid/XReportTrGroup_20250612113808.vue +748 -0
  19. package/.history/src/base-client/components/common/XReportGrid/XReport_20250612115237.vue +1071 -0
  20. package/.history/src/base-client/components/common/XReportGrid/XReport_20250612115346.vue +1078 -0
  21. package/.history/src/base-client/components/common/XReportGrid/XReport_20250612115350.vue +1077 -0
  22. package/.history/src/base-client/components/common/XReportGrid/XReport_20250612115415.vue +1077 -0
  23. package/.history/src/base-client/components/common/XReportGrid/XReport_20250612115429.vue +1077 -0
  24. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611091619.vue +442 -0
  25. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611092547.vue +442 -0
  26. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611092552.vue +442 -0
  27. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611092744.vue +475 -0
  28. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611092955.vue +475 -0
  29. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611092957.vue +475 -0
  30. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611095652.vue +477 -0
  31. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611095701.vue +477 -0
  32. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611095704.vue +477 -0
  33. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611100005.vue +473 -0
  34. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611100011.vue +473 -0
  35. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611100014.vue +473 -0
  36. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611100833.vue +473 -0
  37. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611100853.vue +473 -0
  38. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611100940.vue +473 -0
  39. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101011.vue +473 -0
  40. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101013.vue +473 -0
  41. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101014.vue +473 -0
  42. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101159.vue +473 -0
  43. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101238.vue +474 -0
  44. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101240.vue +474 -0
  45. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101242.vue +474 -0
  46. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101404.vue +472 -0
  47. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101410.vue +472 -0
  48. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101459.vue +472 -0
  49. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101500.vue +472 -0
  50. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101502.vue +472 -0
  51. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101504.vue +472 -0
  52. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101610.vue +501 -0
  53. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101700.vue +501 -0
  54. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101702.vue +501 -0
  55. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101741.vue +504 -0
  56. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101749.vue +504 -0
  57. package/.history/src/base-client/components/his/XHisEditor/XHisEditor_20250611101759.vue +504 -0
  58. package/.history/src/base-client/components/his/XHisEditor/dome_20250611091349.vue +131 -0
  59. package/.history/src/base-client/components/his/XHisEditor/dome_20250611105854.vue +160 -0
  60. package/.history/src/base-client/components/his/XHisEditor/dome_20250611105902.vue +160 -0
  61. package/.history/src/base-client/components/his/XHisEditor/dome_20250611105924.vue +160 -0
  62. package/.history/src/base-client/components/his/XHisEditor/dome_20250611105932.vue +158 -0
  63. package/.history/src/base-client/components/his/XList/XList_20250609135848.vue +173 -0
  64. package/.history/src/base-client/components/his/XList/XList_20250609141026.vue +222 -0
  65. package/.history/src/base-client/components/his/XList/XList_20250609141035.vue +229 -0
  66. package/.history/src/base-client/components/his/XList/XList_20250609141103.vue +229 -0
  67. package/.history/src/base-client/components/his/XList/XList_20250609141105.vue +229 -0
  68. package/.history/src/base-client/components/his/XList/XList_20250609141334.vue +241 -0
  69. package/.history/src/base-client/components/his/XList/XList_20250609141404.vue +241 -0
  70. package/.history/src/base-client/components/his/XList/XList_20250609141406.vue +241 -0
  71. package/.history/src/base-client/components/his/XList/XList_20250609141801.vue +245 -0
  72. package/.history/src/base-client/components/his/XList/XList_20250609142033.vue +245 -0
  73. package/.history/src/base-client/components/his/XList/XList_20250609142038.vue +245 -0
  74. package/.history/src/base-client/components/his/XList/XList_20250609142435.vue +255 -0
  75. package/.history/src/base-client/components/his/XList/XList_20250609142503.vue +255 -0
  76. package/.history/src/base-client/components/his/XList/XList_20250609142504.vue +255 -0
  77. package/.history/src/base-client/components/his/XList/XList_20250609143012.vue +270 -0
  78. package/.history/src/base-client/components/his/XList/XList_20250609143044.vue +270 -0
  79. package/.history/src/base-client/components/his/XList/XList_20250609143046.vue +270 -0
  80. package/.history/src/base-client/components/his/XList/XList_20250609143210.vue +270 -0
  81. package/.history/src/base-client/components/his/XList/XList_20250609144339.vue +294 -0
  82. package/.history/src/base-client/components/his/XList/XList_20250609144410.vue +294 -0
  83. package/.history/src/base-client/components/his/XList/XList_20250609144412.vue +294 -0
  84. package/.history/src/base-client/components/his/XList/XList_20250609144647.vue +303 -0
  85. package/.history/src/base-client/components/his/XList/XList_20250609144716.vue +303 -0
  86. package/.history/src/base-client/components/his/XList/XList_20250609144729.vue +303 -0
  87. package/.history/src/base-client/components/his/XList/XList_20250609151232.vue +288 -0
  88. package/.history/src/base-client/components/his/XList/XList_20250609151247.vue +288 -0
  89. package/.history/src/base-client/components/his/XList/XList_20250609151252.vue +288 -0
  90. package/.history/src/base-client/components/his/XList/XList_20250609161220.vue +317 -0
  91. package/.history/src/base-client/components/his/XList/XList_20250609161258.vue +306 -0
  92. package/.history/src/base-client/components/his/XList/XList_20250609161319.vue +306 -0
  93. package/.history/src/base-client/components/his/XList/XList_20250609161320.vue +306 -0
  94. package/.history/src/base-client/components/his/XList/XList_20250704142024.vue +495 -0
  95. package/.history/src/base-client/components/his/XList/XList_20250704142033.vue +495 -0
  96. package/.history/src/base-client/components/his/XList/XList_20250704142040.vue +494 -0
  97. package/.history/src/base-client/components/his/XList/XList_20250704142211.vue +494 -0
  98. package/.history/src/base-client/components/his/XList/XList_20250704142214.vue +494 -0
  99. package/.history/src/base-client/components/his/XList/XList_20250704143010.vue +495 -0
  100. package/.history/src/base-client/components/his/XList/XList_20250704143203.vue +495 -0
  101. package/.history/src/base-client/components/his/XList/XList_20250707095101.vue +492 -0
  102. package/.history/src/base-client/components/his/XList/XList_20250707100152.vue +492 -0
  103. package/.history/src/base-client/components/his/XList/XList_20250707100200.vue +485 -0
  104. package/.history/src/base-client/components/his/XList/XList_20250707100208.vue +485 -0
  105. package/.history/src/base-client/components/his/XList/XList_20250707100259.vue +488 -0
  106. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807134604.vue +263 -0
  107. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807134615.vue +302 -0
  108. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807134621.vue +301 -0
  109. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807134634.vue +311 -0
  110. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807134644.vue +330 -0
  111. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807134653.vue +330 -0
  112. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807134836.vue +330 -0
  113. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807135247.vue +330 -0
  114. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807135303.vue +354 -0
  115. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807135316.vue +363 -0
  116. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807135323.vue +363 -0
  117. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807135334.vue +366 -0
  118. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807135342.vue +364 -0
  119. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807135349.vue +364 -0
  120. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807135351.vue +346 -0
  121. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807135354.vue +346 -0
  122. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807135401.vue +346 -0
  123. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807135406.vue +346 -0
  124. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807135424.vue +346 -0
  125. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807143043.vue +254 -0
  126. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807155506.vue +329 -0
  127. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807155535.vue +330 -0
  128. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807155543.vue +330 -0
  129. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807155926.vue +304 -0
  130. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807155928.vue +304 -0
  131. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807172548.vue +298 -0
  132. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807172609.vue +298 -0
  133. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807172623.vue +298 -0
  134. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807172631.vue +298 -0
  135. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807172701.vue +298 -0
  136. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807172704.vue +298 -0
  137. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807175937.vue +290 -0
  138. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807175942.vue +290 -0
  139. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807180210.vue +290 -0
  140. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807180424.vue +290 -0
  141. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807180448.vue +290 -0
  142. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807180915.vue +262 -0
  143. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250807180917.vue +262 -0
  144. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250808101106.vue +283 -0
  145. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250808101112.vue +289 -0
  146. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250808101118.vue +289 -0
  147. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250808101129.vue +294 -0
  148. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250808101137.vue +318 -0
  149. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250808101145.vue +320 -0
  150. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250808101154.vue +320 -0
  151. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250808101211.vue +320 -0
  152. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250808101236.vue +320 -0
  153. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250808101239.vue +320 -0
  154. package/.history/src/base-client/components/his/XShiftSchedule/dome_20250807103845.vue +142 -0
  155. package/.history/src/base-client/components/his/XShiftSchedule/dome_20250807103852.vue +142 -0
  156. package/.history/src/base-client/components/his/XShiftSchedule/dome_20250807103857.vue +142 -0
  157. package/.history/src/base-client/components/his/XShiftSchedule/dome_20250807103859.vue +142 -0
  158. package/.history/src/base-client/components/his/XShiftSchedule/dome_20250807103907.vue +142 -0
  159. package/.history/src/base-client/components/his/XShiftSchedule/dome_20250807103910.vue +142 -0
  160. package/.history/src/base-client/components/his/XShiftSchedule/dome_20250807103911.vue +142 -0
  161. package/.history/src/base-client/components/his/XShiftSchedule/dome_20250807103913.vue +142 -0
  162. package/.history/src/base-client/components/his/XShiftSchedule/dome_20250807103916.vue +142 -0
  163. package/.history/src/base-client/components/his/XShiftSchedule/dome_20250807103931.vue +142 -0
  164. package/.history/src/base-client/components/his/XShiftSchedule/dome_20250807145127.vue +85 -0
  165. package/.history/src/base-client/components/his/XShiftSchedule/dome_20250807145136.vue +81 -0
  166. package/.history/src/base-client/components/his/XShiftSchedule/dome_20250807145142.vue +81 -0
  167. package/.history/src/base-client/components/his/XShiftSchedule/dome_20250807145145.vue +81 -0
  168. package/.history/src/base-client/components/his/XShiftSchedule/dome_20250807145148.vue +81 -0
  169. package/.history/src/base-client/components/his/XShiftSchedule/dome_20250807145151.vue +81 -0
  170. package/.history/src/base-client/components/his/XShiftSchedule/dome_20250807145155.vue +81 -0
  171. package/Users/objecrt/af-vue2-client/src/base-client/components/his/XShiftSchedule/XShiftSchedule.vue +213 -0
  172. package/docs//345/207/275/346/225/260/344/275/277/347/224/250/347/233/270/345/205/263.md +6 -0
  173. package/package.json +1 -1
  174. package/src/base-client/components/TreeList/TreeList.vue +91 -0
  175. package/src/base-client/components/TreeList/TreeNode.vue +81 -0
  176. package/src/base-client/components/common/XCardSet/XTiltle.vue +191 -0
  177. package/src/base-client/components/his/XHisEditor/XHisEditor.vue +51 -2
  178. package/src/base-client/components/his/XHisEditor/dome.vue +144 -0
  179. package/src/base-client/components/his/XList/XList.vue +1 -1
  180. package/src/base-client/components/his/XShiftSchedule/XShiftSchedule.vue +145 -40
  181. package/src/base-client/components/his/XShiftSchedule/dome.vue +3 -3
  182. package/src/base-client/components/his/XTextCard/XTextCard.vue +207 -207
  183. package/src/base-client/components/his/threeTestOrders/editor.vue +111 -111
  184. package/src/router/async/router.map.js +1 -1
@@ -0,0 +1,317 @@
1
+ <template>
2
+ <div class="list-wrapper">
3
+ <a-list size="large" :data-source="data" itemLayout="horizontal" class="list-container" ref="listRef">
4
+ <a-list-item
5
+ slot="renderItem"
6
+ slot-scope="item, index"
7
+ class="list-item"
8
+ @click="handleClick(index)"
9
+ @mouseenter="enableHoverOptions && handleMouseEnter(index)"
10
+ @mouseleave="handleMouseLeave"
11
+ :class="{ 'hover-active': enableHoverOptions && hoveredIndex === index }"
12
+ >
13
+ <i
14
+ v-if="icon"
15
+ class="icon-menu"
16
+ :style="getIconStyle(item)"
17
+ ></i>
18
+ <span
19
+ class="item-text">
20
+ {{ item.number }} {{ item.name }}
21
+ </span>
22
+
23
+ <div v-if="button" class="button-group">
24
+ <a-button
25
+ v-for="(name, idx) in buttonNames"
26
+ :key="idx"
27
+ type="link"
28
+ :class="['confirm-btn', buttonMode ? 'hover-btn' : '']"
29
+ @click.stop="click(index, idx)"
30
+ >
31
+ <span :class="{ 'hover-active': enableHoverOptions && hoveredIndex === index }">{{ name }}</span>
32
+ </a-button>
33
+ </div>
34
+
35
+ <!-- 悬浮选项框 -->
36
+ <div
37
+ v-show="enableHoverOptions && hoveredIndex === index"
38
+ class="hover-options"
39
+ @mouseenter="handleOptionsEnter"
40
+ @mouseleave="handleOptionsLeave"
41
+ >
42
+ <div class="hover-options-content">
43
+ <div
44
+ v-for="(item, idx) in select_options"
45
+ :key="idx"
46
+ class="option-item"
47
+ @click="handleOptionClick(index, item)"
48
+ >
49
+ {{ item }}
50
+ </div>
51
+ </div>
52
+ </div>
53
+ </a-list-item>
54
+ </a-list>
55
+ </div>
56
+ </template>
57
+
58
+ <script>
59
+
60
+ import { getConfigByName, runLogic } from '@vue2-client/services/api/common'
61
+
62
+ export default {
63
+ name: 'XList',
64
+ props: {
65
+ queryParamsName: {
66
+ type: Object,
67
+ default: null
68
+ },
69
+ fixedQueryForm: {
70
+ type: Object,
71
+ default: { condition: '1=1' }
72
+ },
73
+ enableHoverOptions: {
74
+ type: Boolean,
75
+ default: true
76
+ }
77
+ },
78
+ inject: ['getComponentByName'],
79
+ data () {
80
+ return {
81
+ data: [],
82
+ button: false,
83
+ icon: false,
84
+ buttonNames: [],
85
+ buttonMode: false,
86
+ hoveredIndex: -1,
87
+ isOptionsHovered: false,
88
+ hoverTimer: null,
89
+ leaveTimer: null,
90
+ select_options: []
91
+ }
92
+ },
93
+ created () {
94
+ this.getData(this.queryParamsName, this.fixedQueryForm)
95
+ },
96
+ methods: {
97
+ async getData (config, param) {
98
+ const that = this
99
+ getConfigByName(config, 'af-his', res => {
100
+ that.button = res.button
101
+ that.icon = res.icon
102
+ that.buttonNames = res.buttonNames || []
103
+ that.buttonMode = res.buttonMode || false
104
+ this.enableHoverOptions = res.enableHoverOptions || false
105
+ if (this.enableHoverOptions) {
106
+ this.select_options = res.select_options
107
+ }
108
+ runLogic(res.data, param, 'af-his').then(ress => {
109
+ that.data = ress
110
+ })
111
+ })
112
+ },
113
+ handleClick (index) {
114
+ this.$emit('listClick', this.data[index])
115
+ },
116
+ refreshList (param) {
117
+ this.getData(this.queryParamsName, param)
118
+ },
119
+ click (index, buttonIndex) {
120
+ this.$emit('click', { data: this.data[index], name: this.buttonNames[buttonIndex] })
121
+ },
122
+ getIconStyle (item) {
123
+ return item.picture
124
+ ? { backgroundImage: `url(${item.picture})` }
125
+ : {}
126
+ },
127
+ filterData (par) {
128
+ runLogic(this.queryParamsName, par, 'af-his').then(res => {
129
+ this.data = res.data
130
+ })
131
+ },
132
+ handleMouseEnter (index) {
133
+ this.clearAllTimers()
134
+ this.hoveredIndex = index
135
+ this.isOptionsHovered = true
136
+ },
137
+ handleMouseLeave () {
138
+ this.clearAllTimers()
139
+ this.leaveTimer = setTimeout(() => {
140
+ this.isOptionsHovered = false
141
+ this.hoveredIndex = -1
142
+ }, 100)
143
+ },
144
+ handleOptionsEnter () {
145
+ this.clearAllTimers()
146
+ this.isOptionsHovered = true
147
+ },
148
+ handleOptionsLeave () {
149
+ this.clearAllTimers()
150
+ this.leaveTimer = setTimeout(() => {
151
+ this.isOptionsHovered = false
152
+ this.hoveredIndex = -1
153
+ }, 100)
154
+ },
155
+ clearAllTimers () {
156
+ if (this.hoverTimer) {
157
+ clearTimeout(this.hoverTimer)
158
+ this.hoverTimer = null
159
+ }
160
+ if (this.leaveTimer) {
161
+ clearTimeout(this.leaveTimer)
162
+ this.leaveTimer = null
163
+ }
164
+ },
165
+ handleOptionClick (index, action) {
166
+ this.$emit('optionClick', { data: this.data[index], action })
167
+ }
168
+ },
169
+ watch: {
170
+ fixedQueryForm: {
171
+ deep: true,
172
+ handler (val) {
173
+ this.refreshList(val)
174
+ }
175
+ }
176
+ },
177
+ beforeDestroy () {
178
+ this.clearAllTimers()
179
+ }
180
+ }
181
+ </script>
182
+
183
+ <style scoped>
184
+ .list-wrapper {
185
+ max-height: 240px;
186
+ overflow-y: auto;
187
+ padding-right: 2px;
188
+ }
189
+
190
+ .list-container {
191
+ width: 100%;
192
+ }
193
+
194
+ .list-item {
195
+ height: 35px;
196
+ border-radius: 6px;
197
+ background-color: #F4F4F4;
198
+ padding: 8px 15px;
199
+ font-size: 16px;
200
+ display: flex;
201
+ align-items: center;
202
+ width: 100%;
203
+ border: 1px solid #D9D9D9;
204
+ box-sizing: border-box;
205
+ margin-bottom: 8px !important;
206
+ position: relative;
207
+ transition: background-color 0.3s ease;
208
+ }
209
+
210
+ .icon-menu {
211
+ display: inline-block;
212
+ width: 20px;
213
+ height: 20px;
214
+ background-color: #ccc;
215
+ margin-right: 8px;
216
+ }
217
+
218
+ .item-text {
219
+ flex: 1;
220
+ }
221
+
222
+ .confirm-btn {
223
+ margin-left: auto;
224
+ padding: 0 8px;
225
+ }
226
+
227
+ .confirm-btn.hover-btn {
228
+ opacity: 0;
229
+ transition: opacity 0.3s ease;
230
+ }
231
+
232
+ .button-group {
233
+ display: flex;
234
+ gap: 2px; /* 按钮之间的间距 */
235
+ }
236
+
237
+ .list-item:hover .confirm-btn.hover-btn {
238
+ opacity: 1;
239
+ }
240
+
241
+ /* 自定义滚动条样式 */
242
+ .list-wrapper::-webkit-scrollbar {
243
+ width: 6px;
244
+ }
245
+
246
+ .list-wrapper::-webkit-scrollbar-thumb {
247
+ background-color: #d9d9d9;
248
+ border-radius: 3px;
249
+ }
250
+
251
+ .list-wrapper::-webkit-scrollbar-track {
252
+ background-color: #f0f0f0;
253
+ }
254
+
255
+ .hover-active {
256
+ color: white;
257
+ }
258
+
259
+ .list-item.hover-active {
260
+ background-color: rgb(0, 87, 254) !important;
261
+ color: white;
262
+ border: 1px solid black;
263
+ }
264
+
265
+ .hover-options {
266
+ position: absolute;
267
+ left: 0;
268
+ right: 0;
269
+ top: 100%;
270
+ background: white;
271
+ border: 1px solid #d9d9d9;
272
+ border-radius: 4px;
273
+ box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
274
+ z-index: 1000;
275
+ margin-top: 4px;
276
+ width: 100%;
277
+ box-sizing: border-box;
278
+ pointer-events: auto;
279
+ }
280
+
281
+ .hover-options-content {
282
+ padding: 4px 0;
283
+ display: flex;
284
+ flex-direction: column;
285
+ width: 100%;
286
+ }
287
+
288
+ .option-item {
289
+ padding: 8px 12px;
290
+ cursor: pointer;
291
+ transition: all 0.3s ease;
292
+ color: #333;
293
+ font-size: 14px;
294
+ display: flex;
295
+ align-items: center;
296
+ position: relative;
297
+ }
298
+
299
+ .option-item:hover {
300
+ background-color: #f5f5f5;
301
+ color: #1890ff;
302
+ }
303
+
304
+ .option-item:active {
305
+ background-color: #e6f7ff;
306
+ }
307
+
308
+ .option-item:not(:last-child)::after {
309
+ content: '';
310
+ position: absolute;
311
+ left: 12px;
312
+ right: 12px;
313
+ bottom: 0;
314
+ height: 1px;
315
+ background-color: #f0f0f0;
316
+ }
317
+ </style>
@@ -0,0 +1,306 @@
1
+ <template>
2
+ <div class="list-wrapper">
3
+ <a-list size="large" :data-source="data" itemLayout="horizontal" class="list-container" ref="listRef">
4
+ <a-list-item
5
+ slot="renderItem"
6
+ slot-scope="item, index"
7
+ class="list-item"
8
+ @click="handleClick(index)"
9
+ @mouseenter="enableHoverOptions && handleMouseEnter(index)"
10
+ @mouseleave="handleMouseLeave"
11
+ :class="{ 'hover-active': enableHoverOptions && hoveredIndex === index }"
12
+ >
13
+ <i
14
+ v-if="icon"
15
+ class="icon-menu"
16
+ :style="getIconStyle(item)"
17
+ ></i>
18
+ <span
19
+ class="item-text">
20
+ {{ item.number }} {{ item.name }}
21
+ </span>
22
+
23
+ <div v-if="button" class="button-group">
24
+ <a-button
25
+ v-for="(name, idx) in buttonNames"
26
+ :key="idx"
27
+ type="link"
28
+ :class="['confirm-btn', buttonMode ? 'hover-btn' : '']"
29
+ @click.stop="click(index, idx)"
30
+ >
31
+ <span :class="{ 'hover-active': enableHoverOptions && hoveredIndex === index }">{{ name }}</span>
32
+ </a-button>
33
+ </div>
34
+
35
+ <!-- 悬浮选项框 -->
36
+ <div
37
+ v-show="enableHoverOptions && hoveredIndex === index"
38
+ class="hover-options"
39
+ @mouseenter="handleOptionsEnter"
40
+ @mouseleave="handleOptionsLeave"
41
+ >
42
+ <div class="hover-options-content">
43
+ <div
44
+ v-for="(item, idx) in select_options"
45
+ :key="idx"
46
+ class="option-item"
47
+ @click="handleOptionClick(index, item)"
48
+ >
49
+ {{ item }}
50
+ </div>
51
+ </div>
52
+ </div>
53
+ </a-list-item>
54
+ </a-list>
55
+ </div>
56
+ </template>
57
+
58
+ <script>
59
+
60
+ import { getConfigByName, runLogic } from '@vue2-client/services/api/common'
61
+
62
+ export default {
63
+ name: 'XList',
64
+ props: {
65
+ queryParamsName: {
66
+ type: Object,
67
+ default: null
68
+ },
69
+ fixedQueryForm: {
70
+ type: Object,
71
+ default: { condition: '1=1' }
72
+ },
73
+ enableHoverOptions: {
74
+ type: Boolean,
75
+ default: true
76
+ }
77
+ },
78
+ inject: ['getComponentByName'],
79
+ data () {
80
+ return {
81
+ data: [],
82
+ button: false,
83
+ icon: false,
84
+ buttonNames: [],
85
+ buttonMode: false,
86
+ hoveredIndex: -1,
87
+ isOptionsHovered: false,
88
+ hoverTimer: null,
89
+ leaveTimer: null,
90
+ select_options: []
91
+ }
92
+ },
93
+ created () {
94
+ this.getData(this.queryParamsName, this.fixedQueryForm)
95
+ },
96
+ methods: {
97
+ async getData (config, param) {
98
+ const that = this
99
+ getConfigByName(config, 'af-his', res => {
100
+ that.button = res.button
101
+ that.icon = res.icon
102
+ that.buttonNames = res.buttonNames || []
103
+ that.buttonMode = res.buttonMode || false
104
+ this.enableHoverOptions = res.enableHoverOptions || false
105
+ if (this.enableHoverOptions) {
106
+ this.select_options = res.select_options
107
+ }
108
+ runLogic(res.data, param, 'af-his').then(ress => {
109
+ that.data = ress
110
+ })
111
+ })
112
+ },
113
+ handleClick (index) {
114
+ this.$emit('listClick', this.data[index])
115
+ },
116
+ refreshList (param) {
117
+ this.getData(this.queryParamsName, param)
118
+ },
119
+ click (index, buttonIndex) {
120
+ this.$emit('click', { data: this.data[index], name: this.buttonNames[buttonIndex] })
121
+ },
122
+ getIconStyle (item) {
123
+ return item.picture
124
+ ? { backgroundImage: `url(${item.picture})` }
125
+ : {}
126
+ },
127
+ filterData (par) {
128
+ runLogic(this.queryParamsName, par, 'af-his').then(res => {
129
+ this.data = res.data
130
+ })
131
+ },
132
+ handleMouseEnter (index) {
133
+ this.clearAllTimers()
134
+ this.hoveredIndex = index
135
+ this.isOptionsHovered = true
136
+ },
137
+ handleMouseLeave () {
138
+ this.clearAllTimers()
139
+ this.leaveTimer = setTimeout(() => {
140
+ this.isOptionsHovered = false
141
+ this.hoveredIndex = -1
142
+ }, 100)
143
+ },
144
+ handleOptionsEnter () {
145
+ this.clearAllTimers()
146
+ this.isOptionsHovered = true
147
+ },
148
+ handleOptionsLeave () {
149
+ this.clearAllTimers()
150
+ this.leaveTimer = setTimeout(() => {
151
+ this.isOptionsHovered = false
152
+ this.hoveredIndex = -1
153
+ }, 100)
154
+ },
155
+ clearAllTimers () {
156
+ if (this.hoverTimer) {
157
+ clearTimeout(this.hoverTimer)
158
+ this.hoverTimer = null
159
+ }
160
+ if (this.leaveTimer) {
161
+ clearTimeout(this.leaveTimer)
162
+ this.leaveTimer = null
163
+ }
164
+ },
165
+ handleOptionClick (index, action) {
166
+ this.$emit('optionClick', { data: this.data[index], action })
167
+ }
168
+ },
169
+ watch: {
170
+ fixedQueryForm: {
171
+ deep: true,
172
+ handler (val) {
173
+ this.refreshList(val)
174
+ }
175
+ }
176
+ },
177
+ beforeDestroy () {
178
+ this.clearAllTimers()
179
+ }
180
+ }
181
+ </script>
182
+
183
+ <style scoped>
184
+ .list-wrapper {
185
+ max-height: 240px;
186
+ overflow-y: auto;
187
+ padding-right: 2px;
188
+ }
189
+
190
+ .list-container {
191
+ width: 100%;
192
+ }
193
+
194
+ .list-item {
195
+ height: 35px;
196
+ border-radius: 6px;
197
+ background-color: #F4F4F4;
198
+ padding: 8px 15px;
199
+ font-size: 16px;
200
+ display: flex;
201
+ align-items: center;
202
+ width: 100%;
203
+ border: 1px solid #D9D9D9;
204
+ box-sizing: border-box;
205
+ margin-bottom: 8px !important;
206
+ position: relative;
207
+ transition: background-color 0.3s ease;
208
+ }
209
+
210
+ .icon-menu {
211
+ display: inline-block;
212
+ width: 20px;
213
+ height: 20px;
214
+ background-color: #ccc;
215
+ margin-right: 8px;
216
+ }
217
+
218
+ .item-text {
219
+ flex: 1;
220
+ }
221
+
222
+ .confirm-btn {
223
+ margin-left: auto;
224
+ padding: 0 8px;
225
+ }
226
+
227
+ .confirm-btn.hover-btn {
228
+ opacity: 0;
229
+ transition: opacity 0.3s ease;
230
+ }
231
+
232
+ .button-group {
233
+ display: flex;
234
+ gap: 2px; /* 按钮之间的间距 */
235
+ }
236
+
237
+ .list-item:hover .confirm-btn.hover-btn {
238
+ opacity: 1;
239
+ }
240
+
241
+ /* 自定义滚动条样式 */
242
+ .list-wrapper::-webkit-scrollbar {
243
+ width: 6px;
244
+ }
245
+
246
+ .list-wrapper::-webkit-scrollbar-thumb {
247
+ background-color: #d9d9d9;
248
+ border-radius: 3px;
249
+ }
250
+
251
+ .list-wrapper::-webkit-scrollbar-track {
252
+ background-color: #f0f0f0;
253
+ }
254
+
255
+ .hover-active {
256
+ color: white;
257
+ }
258
+
259
+ .list-item.hover-active {
260
+ background-color: rgb(0, 87, 254) !important;
261
+ color: white;
262
+ border: 1px solid black;
263
+ }
264
+
265
+ .hover-options {
266
+ position: absolute;
267
+ left: 0;
268
+ right: 0;
269
+ top: 100%;
270
+ background: white;
271
+ border: 1px solid #d9d9d9;
272
+ border-radius: 4px;
273
+ box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
274
+ z-index: 1000;
275
+ margin-top: 4px;
276
+ width: 100%;
277
+ box-sizing: border-box;
278
+ pointer-events: auto;
279
+ }
280
+
281
+ .hover-options-content {
282
+ padding: 4px 0;
283
+ display: flex;
284
+ flex-direction: column;
285
+ width: 100%;
286
+ }
287
+
288
+ .option-item {
289
+ padding: 8px 12px;
290
+ cursor: pointer;
291
+ transition: all 0.3s ease;
292
+ color: #333;
293
+ font-size: 14px;
294
+ display: flex;
295
+ align-items: center;
296
+ }
297
+
298
+ .option-item:hover {
299
+ background-color: #f5f5f5;
300
+ color: #1890ff;
301
+ }
302
+
303
+ .option-item:active {
304
+ background-color: #e6f7ff;
305
+ }
306
+ </style>