vue2-client 1.15.59 → 1.15.61

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 (134) 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_20250609151519.vue +222 -0
  107. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250612155514.vue +183 -0
  108. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250612155556.vue +183 -0
  109. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250612155600.vue +183 -0
  110. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250612181609.vue +206 -0
  111. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250612181629.vue +209 -0
  112. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613095553.vue +242 -0
  113. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613095610.vue +242 -0
  114. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613095612.vue +242 -0
  115. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613100041.vue +251 -0
  116. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613100047.vue +251 -0
  117. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613100054.vue +250 -0
  118. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613100105.vue +250 -0
  119. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613100107.vue +250 -0
  120. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613100114.vue +250 -0
  121. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613140844.vue +238 -0
  122. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613140910.vue +238 -0
  123. package/.history/src/base-client/components/his/XShiftSchedule/XShiftSchedule_20250613140912.vue +238 -0
  124. package/Users/objecrt/af-vue2-client/src/base-client/components/his/XShiftSchedule/XShiftSchedule.vue +36 -0
  125. package/package.json +1 -1
  126. package/src/base-client/components/TreeList/TreeList.vue +91 -0
  127. package/src/base-client/components/TreeList/TreeNode.vue +81 -0
  128. package/src/base-client/components/common/XCardSet/XTiltle.vue +191 -0
  129. package/src/base-client/components/common/XFormTable/demo.vue +38 -38
  130. package/src/base-client/components/common/XTable/XTable.vue +2 -2
  131. package/src/base-client/components/his/XHisEditor/XHisEditor.vue +4 -2
  132. package/src/base-client/components/his/XTextCard/XTextCard.vue +207 -207
  133. package/src/base-client/components/his/threeTestOrders/editor.vue +111 -111
  134. package/src/router/async/router.map.js +0 -1
@@ -0,0 +1,492 @@
1
+ <template>
2
+ <!-- 列表卡片模式 listMode: card -->
3
+ <div v-if="listMode"
4
+ class="demo-infinite-container"
5
+ ref="listRef"
6
+ @scroll="handleInfiniteOnLoad">
7
+ <a-list :grid="{ gutter: 16, xs: 1, sm: 2, md: 2, lg: 3, xl: 3, xxl: 4 }"
8
+ :data-source="localData">
9
+ <a-list-item slot="renderItem" slot-scope="item, index">
10
+ <div class="card-a-col">
11
+ <a-row class="card-row">
12
+ <a-col class="id-a-col" :span="4" v-for="(detail,idx) in item.filter(d => d.label == label)" :key="idx">
13
+ {{detail.value}}<span style="font-size: 16px;font-weight: 400 !important;">床</span>
14
+ </a-col>
15
+ <a-col :span="20" class="id-a-col-2">
16
+ <template v-for="(detail,idx) in item">
17
+ <span class="describe-list-a-col" :class="{name: detail.bold}" :key="idx" v-if="detail.type == 'title'">{{detail.value}}</span>
18
+ <span :key="idx" class="component-a-col" v-else-if="detail.type == 'component' && detail.label != label">
19
+ {{`${detail.label}:`}}
20
+ <component
21
+ :is="detail.slotType"
22
+ :key="idx"
23
+ :ref="`dynamicComponent_${ idx.slotType || idx}_${idx}`"
24
+ :serviceName="serviceName"
25
+ v-on="forwardAllEvents"
26
+ :queryParamsName="detail.value"
27
+ :countVisible="false"
28
+ />
29
+ </span>
30
+ <span :key="idx" class="component-a-col" v-else-if="detail.type == 'date'">
31
+ {{`${detail.label}:`}}
32
+ <a-date-picker @change="onChange" />
33
+ </span>
34
+ <span class="describe-list-a-col" :class="{name: detail.bold}" :key="idx" v-else-if="detail.label != label">{{`${detail.label}:${detail.value}`}}</span>
35
+ </template>
36
+ <a-button v-for="(btn, i) in buttonNames"
37
+ :key="i"
38
+ icon="search"
39
+ class="button-a-col"
40
+ @click.stop="click(item, index)">
41
+ {{btn}}
42
+ </a-button>
43
+ </a-col>
44
+ </a-row>
45
+ </div>
46
+ </a-list-item>
47
+ <div v-if="loading" class="demo-loading-container">
48
+ <a-spin />
49
+ </div>
50
+ <div v-if="allLoaded">
51
+ <div class="demo-infinite-list-bottom">
52
+ 已经显示全部数据
53
+ </div>
54
+ </div>
55
+ </a-list>
56
+ </div>
57
+
58
+ <!-- 默认标签模式 -->
59
+ <div class="list-wrapper" v-else>
60
+ <a-list size="large" :data-source="data" itemLayout="horizontal" class="list-container" ref="listRef">
61
+ <a-list-item slot="renderItem"
62
+ slot-scope="item, index"
63
+ class="list-item"
64
+ @click="handleClick(index)"
65
+ @mouseenter="enableHoverOptions && handleMouseEnter(index)"
66
+ @mouseleave="handleMouseLeave"
67
+ :class="{ 'hover-active': enableHoverOptions && hoveredIndex === index }">
68
+ <i v-if="icon"
69
+ class="icon-menu"
70
+ :style="getIconStyle(item)">
71
+ </i>
72
+ <span
73
+ class="item-text">
74
+ {{ item.number }} {{ item.name }}
75
+ </span>
76
+
77
+ <div v-if="button" class="button-group">
78
+ <a-button
79
+ v-for="(name, idx) in buttonNames"
80
+ :key="idx"
81
+ type="link"
82
+ :class="['confirm-btn', buttonMode ? 'hover-btn' : '']"
83
+ @click.stop="click(index, idx)">
84
+ <span :class="{ 'hover-active': enableHoverOptions && hoveredIndex === index }">{{ name }}</span>
85
+ </a-button>
86
+ </div>
87
+
88
+ <!-- 悬浮选项框 -->
89
+ <div v-show="enableHoverOptions && hoveredIndex === index"
90
+ class="hover-options"
91
+ @mouseenter="handleOptionsEnter"
92
+ @mouseleave="handleOptionsLeave">
93
+ <div class="hover-options-content">
94
+ <div v-for="(item, idx) in select_options"
95
+ :key="idx"
96
+ class="option-item"
97
+ @click="handleOptionClick(index, item)">
98
+ {{ item }}
99
+ </div>
100
+ </div>
101
+ </div>
102
+ </a-list-item>
103
+ </a-list>
104
+ </div>
105
+ </template>
106
+
107
+ <script>
108
+
109
+ import { getConfigByName, runLogic } from '@vue2-client/services/api/common'
110
+
111
+ export default {
112
+ name: 'XList',
113
+ components: {
114
+ XReport: () => import('@vue2-client/base-client/components/common/XReport/XReport.vue'),
115
+ XButtons: () => import('@vue2-client/base-client/components/common/XButtons/XButtons.vue'),
116
+ XInput: () => import('@vue2-client/base-client/components/common/XInput/XInput.vue'),
117
+ XRadio: () => import('@vue2-client/base-client/components/his/XRadio/XRadio.vue'),
118
+ XTimeSelect: () => import('@vue2-client/base-client/components/his/XTimeSelect/XTimeSelect.vue'),
119
+ XCheckbox: () => import('@vue2-client/base-client/components/his/XCheckbox/XCheckbox.vue'),
120
+ XTitle: () => import('@vue2-client/base-client/components/his/XTitle/XTitle.vue'),
121
+ XSelect: () => import('@vue2-client/base-client/components/his/XSelect/XSelect.vue')
122
+ },
123
+ props: {
124
+ queryParamsName: {
125
+ type: Object,
126
+ default: null
127
+ },
128
+ fixedQueryForm: {
129
+ type: Object,
130
+ default: { condition: '1=1' }
131
+ },
132
+ enableHoverOptions: {
133
+ type: Boolean,
134
+ default: true
135
+ },
136
+ serviceName: {
137
+ type: String,
138
+ default: 'af-his'
139
+ }
140
+ },
141
+ inject: ['getComponentByName'],
142
+ data () {
143
+ return {
144
+ data: [], // 数据源
145
+ localData: [], // 本地数据源
146
+ loading: false, // 加载中
147
+ busy: false, // 繁忙状态
148
+ button: false,
149
+ icon: false,
150
+ buttonNames: [],
151
+ listMode: undefined, // 列表模式
152
+ buttonMode: true,
153
+ hoveredIndex: -1, // 当前悬浮的索引
154
+ isOptionsHovered: false, // 悬浮选项框是否悬浮
155
+ hoverTimer: null, // 悬浮选项框定时器
156
+ leaveTimer: null, // 离开选项框定时器
157
+ select_options: [], // 悬浮选项框
158
+ logicName: '',
159
+ nowPage: 0, // 当前页
160
+ pageSize: 12,
161
+ allLoaded: false,
162
+ label: 'id',
163
+ scrollTimer: null
164
+ }
165
+ },
166
+ created () {
167
+ this.getData(this.queryParamsName, this.fixedQueryForm)
168
+ },
169
+ mounted () {},
170
+ computed: {
171
+ forwardAllEvents () {
172
+ return {
173
+ // 监听所有事件并转发给父组件
174
+ '*': (eventName, ...payload) => {
175
+ this.$emit(eventName, ...payload)
176
+ }
177
+ }
178
+ }
179
+ },
180
+ methods: {
181
+ onChange (date, dateString) {
182
+ this.$emit('dateChange', date, dateString)
183
+ },
184
+ handleInfiniteOnLoad (event) {
185
+ if (this.busy || this.allLoaded) return // 防止重复加载
186
+ const container = event.target // 获取列表容器元素
187
+ const scrollTop = container.scrollTop // 获取滚动条的当前位置
188
+ const scrollHeight = container.scrollHeight // 获取列表容器的总高度
189
+ const clientHeight = container.clientHeight // 获取列表容器的可见高度
190
+ const bottomOffset = 5
191
+ // 判断是否滚动到底部
192
+ if (scrollTop + clientHeight >= scrollHeight - bottomOffset) {
193
+ this.busy = true
194
+ this.loading = true
195
+ if (this.scrollTimer) clearTimeout(this.scrollTimer)
196
+ this.scrollTimer = setTimeout(() => {
197
+ try {
198
+ this.nowPage = this.nowPage + this.pageSize
199
+ this.fixedQueryForm.condition = `Limit ${this.nowPage}, ${this.pageSize}`
200
+ runLogic(this.logicName, this.fixedQueryForm, 'af-his').then(async (res) => {
201
+ this.localData = [...this.localData, ...res]
202
+ // 如果返回的数据长度小于每页的记录数,则认为已经加载完所有数据
203
+ if (res.length < this.pageSize) {
204
+ this.allLoaded = true
205
+ }
206
+ })
207
+ } catch (e) {
208
+ this.$message.error(e.message)
209
+ } finally {
210
+ this.loading = false
211
+ this.busy = false
212
+ }
213
+ }, 100)
214
+ }
215
+ },
216
+ async getData (config, param) {
217
+ const that = this
218
+ getConfigByName(config, 'af-his', async (res) => {
219
+ that.listMode = await res.listMode == 'card'
220
+ that.logicName = await res.data
221
+ that.button = await res.button // 按钮
222
+ that.icon = await res.icon // 图标
223
+ that.label = await res.label // 标签
224
+ that.buttonNames = await res.buttonNames || []// 按钮文本
225
+ that.buttonMode = await res.buttonMode || false// 按钮模式
226
+ this.enableHoverOptions = await res.enableHoverOptions || false// 悬浮选项框
227
+ if (this.enableHoverOptions) {
228
+ this.select_options = await res.select_options
229
+ }
230
+ if (that.listMode) { param.condition = `Limit ${that.nowPage}, ${that.pageSize}` }
231
+ runLogic(res.data, param, 'af-his').then(result => {
232
+ that.data = result
233
+ if (that.nowPage == 0) { this.localData = result }
234
+ })
235
+ })
236
+ },
237
+ // 点击列表项
238
+ handleClick (index) {
239
+ this.$emit('listClick', this.data[index])
240
+ },
241
+ refreshList (param) {
242
+ this.getData(this.queryParamsName, param)
243
+ },
244
+ click (index, buttonIndex) {
245
+ this.$emit('click', { data: this.data[index], name: this.buttonNames[buttonIndex] })
246
+ },
247
+ getIconStyle (item) {
248
+ return item.picture
249
+ ? { backgroundImage: `url(${item.picture})` }
250
+ : {}
251
+ },
252
+ filterData (par) {
253
+ runLogic(this.queryParamsName, par, 'af-his').then(res => {
254
+ this.data = res.data
255
+ })
256
+ },
257
+ // 鼠标进入列表项
258
+ handleMouseEnter (index) {
259
+ this.clearAllTimers()
260
+ this.hoveredIndex = index
261
+ this.isOptionsHovered = true
262
+ },
263
+ // 鼠标离开列表项
264
+ handleMouseLeave () {
265
+ this.clearAllTimers()
266
+ this.leaveTimer = setTimeout(() => {
267
+ this.isOptionsHovered = false
268
+ this.hoveredIndex = -1
269
+ }, 100)
270
+ },
271
+ // 鼠标进入悬浮选项框
272
+ handleOptionsEnter () {
273
+ this.clearAllTimers()
274
+ this.isOptionsHovered = true
275
+ },
276
+ // 鼠标离开悬浮选项框
277
+ handleOptionsLeave () {
278
+ this.clearAllTimers()
279
+ this.leaveTimer = setTimeout(() => {
280
+ this.isOptionsHovered = false
281
+ this.hoveredIndex = -1
282
+ }, 100)
283
+ },
284
+ // 清除所有定时器
285
+ clearAllTimers () {
286
+ if (this.hoverTimer) {
287
+ clearTimeout(this.hoverTimer)
288
+ this.hoverTimer = null
289
+ }
290
+ if (this.leaveTimer) {
291
+ clearTimeout(this.leaveTimer)
292
+ this.leaveTimer = null
293
+ }
294
+ },
295
+ // 选项框点击
296
+ handleOptionClick (index, action) {
297
+ this.$emit('optionClick', { data: this.data[index], action })
298
+ }
299
+ },
300
+ watch: {
301
+ fixedQueryForm: {
302
+ deep: true,
303
+ handler (val) {
304
+ this.refreshList(val)
305
+ }
306
+ }
307
+ },
308
+ beforeDestroy () {
309
+ const ref = this.$refs.listRef
310
+ if (ref && ref.removeEventListener) {
311
+ ref.removeEventListener('scroll', this.handleInfiniteOnLoad)
312
+ }
313
+ this.clearAllTimers()
314
+ }
315
+ }
316
+ </script>
317
+
318
+ <style scoped>
319
+ .list-wrapper {
320
+ max-height: 240px;
321
+ overflow-y: auto;
322
+ padding-right: 2px;
323
+ }
324
+
325
+ .list-container {
326
+ width: 100%;
327
+ }
328
+
329
+ .list-item {
330
+ height: 35px;
331
+ border-radius: 6px;
332
+ background-color: #F4F4F4;
333
+ padding: 8px 15px;
334
+ font-size: 16px;
335
+ display: flex;
336
+ align-items: center;
337
+ width: 100%;
338
+ border: 1px solid #D9D9D9;
339
+ box-sizing: border-box;
340
+ margin-bottom: 8px !important;
341
+ position: relative;
342
+ transition: background-color 0.3s ease;
343
+ }
344
+
345
+ .icon-menu {
346
+ display: inline-block;
347
+ width: 20px;
348
+ height: 20px;
349
+ background-color: #ccc;
350
+ margin-right: 8px;
351
+ }
352
+
353
+ .item-text {
354
+ flex: 1;
355
+ }
356
+
357
+ .confirm-btn {
358
+ margin-left: auto;
359
+ padding: 0 8px;
360
+ }
361
+
362
+ .confirm-btn.hover-btn {
363
+ opacity: 0;
364
+ transition: opacity 0.3s ease;
365
+ }
366
+
367
+ .button-group {
368
+ display: flex;
369
+ gap: 2px; /* 按钮之间的间距 */
370
+ }
371
+
372
+ .list-item:hover .confirm-btn.hover-btn {
373
+ opacity: 1;
374
+ }
375
+
376
+ /* 自定义滚动条样式 */
377
+ .list-wrapper::-webkit-scrollbar {
378
+ width: 6px;
379
+ }
380
+
381
+ .list-wrapper::-webkit-scrollbar-thumb {
382
+ background-color: #d9d9d9;
383
+ border-radius: 3px;
384
+ }
385
+
386
+ .list-wrapper::-webkit-scrollbar-track {
387
+ background-color: #f0f0f0;
388
+ }
389
+
390
+ .hover-active {
391
+ color: white;
392
+ }
393
+
394
+ .list-item.hover-active {
395
+ background-color: rgb(0, 87, 254) !important;
396
+ color: white;
397
+ border: 1px solid black;
398
+ }
399
+
400
+ .hover-options {
401
+ position: absolute;
402
+ left: 0;
403
+ right: 0;
404
+ top: 100%;
405
+ background: white;
406
+ border: 1px solid #d9d9d9;
407
+ border-radius: 4px;
408
+ box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
409
+ z-index: 1000;
410
+ margin-top: 4px;
411
+ width: 100%;
412
+ box-sizing: border-box;
413
+ pointer-events: auto;
414
+ }
415
+
416
+ .hover-options-content {
417
+ padding: 4px 0;
418
+ display: flex;
419
+ flex-direction: column;
420
+ width: 100%;
421
+ }
422
+
423
+ .option-item {
424
+ padding: 8px 12px;
425
+ cursor: pointer;
426
+ transition: all 0.3s ease;
427
+ color: #333;
428
+ font-size: 14px;
429
+ display: flex;
430
+ align-items: center;
431
+ }
432
+
433
+ .option-item:hover {
434
+ background-color: #f5f5f5;
435
+ color: #1890ff;
436
+ }
437
+
438
+ .option-item:active {
439
+ background-color: #e6f7ff;
440
+ }
441
+
442
+ .demo-loading-container {
443
+ position: absolute;
444
+ bottom: 40px;
445
+ width: 100%;
446
+ text-align: center;
447
+ }
448
+
449
+ .demo-infinite-container{
450
+ overflow-x: hidden;
451
+ overflow-y: auto;
452
+ height: 80vh;
453
+ }
454
+ .card-row{
455
+ height: 100%;
456
+ width: 100%;
457
+ border-radius: 6px;
458
+ padding: 6px;
459
+ }
460
+ .id-a-col{
461
+ font-size: 22px;
462
+ font-weight: 700;
463
+ display: flex;
464
+ justify-content: space-evenly;
465
+ align-items: center;
466
+ }
467
+ .id-a-col-2{}
468
+ .describe-list-a-col{
469
+ display: block;
470
+ font-size: 16px;
471
+ }
472
+ .name{
473
+ font-size: 18px;
474
+ font-weight: 700;
475
+ }
476
+ .component-a-col{
477
+ display: flex;
478
+ align-items: center;
479
+ }
480
+ .button-a-col{
481
+ position: absolute;
482
+ top: 245px;
483
+ left: 225px;
484
+ }
485
+ .card-a-col{
486
+ background-color: rgba(247, 249, 252);
487
+ height: 297px;
488
+ width: auto;
489
+ border-radius: 6px;
490
+ border: 1px solid #E5E9F0;
491
+ }
492
+ </style>