vue2-client 1.8.310 → 1.8.312

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 (222) hide show
  1. package/.env +19 -19
  2. package/.eslintrc.js +90 -90
  3. package/CHANGELOG.md +824 -824
  4. package/Components.md +60 -60
  5. package/babel.config.js +21 -21
  6. package/docs/LowCode/lowcode.md +155 -155
  7. package/docs/LowCode/lowcodeForDeveloper.md +230 -230
  8. package/docs/index.md +30 -30
  9. package/index.js +31 -31
  10. package/jest-transform-stub.js +8 -8
  11. package/jest.config.js +21 -21
  12. package/jest.setup.js +7 -7
  13. package/package.json +97 -97
  14. package/public/index.html +27 -27
  15. package/src/App.vue +188 -188
  16. package/src/ReportView.js +19 -19
  17. package/src/assets/img/querySlotDemo.svg +15 -15
  18. package/src/assets/svg/badtwo.svg +1 -1
  19. package/src/assets/svg/goodtwo.svg +1 -1
  20. package/src/base-client/components/common/AMisRender/index.js +3 -3
  21. package/src/base-client/components/common/AMisRender/index.vue +263 -263
  22. package/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox.vue +438 -416
  23. package/src/base-client/components/common/AddressSearchCombobox/demo.vue +36 -36
  24. package/src/base-client/components/common/AddressSearchCombobox/ic_map.svg +6 -6
  25. package/src/base-client/components/common/AmapMarker/AmapPointRendering.vue +120 -120
  26. package/src/base-client/components/common/CitySelect/CitySelect.vue +342 -342
  27. package/src/base-client/components/common/CitySelect/index.js +3 -3
  28. package/src/base-client/components/common/CitySelect/index.md +109 -109
  29. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +669 -669
  30. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +1014 -1014
  31. package/src/base-client/components/common/CreateQuery/index.js +3 -3
  32. package/src/base-client/components/common/CreateQuery/index.md +42 -42
  33. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +452 -452
  34. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +511 -511
  35. package/src/base-client/components/common/CreateSimpleFormQuery/index.js +3 -3
  36. package/src/base-client/components/common/CreateSimpleFormQuery/index.md +42 -42
  37. package/src/base-client/components/common/FormGroupEdit/FormGroupEdit.vue +149 -149
  38. package/src/base-client/components/common/FormGroupEdit/index.js +3 -3
  39. package/src/base-client/components/common/FormGroupEdit/index.md +43 -43
  40. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +166 -166
  41. package/src/base-client/components/common/FormGroupQuery/index.js +3 -3
  42. package/src/base-client/components/common/FormGroupQuery/index.md +43 -43
  43. package/src/base-client/components/common/JSONToTree/jsontotree.vue +271 -271
  44. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorPanel.vue +413 -350
  45. package/src/base-client/components/common/LowCodeComponent/LowCodePageOrganization.vue +502 -502
  46. package/src/base-client/components/common/LowCodeComponent/LowCodeRender.vue +728 -699
  47. package/src/base-client/components/common/LowCodeComponent/LowCodeRenderEnter.vue +29 -29
  48. package/src/base-client/components/common/LowCodeComponent/LowCodeUIStore.vue +219 -162
  49. package/src/base-client/components/common/PersonSetting/PersonSetting.vue +208 -208
  50. package/src/base-client/components/common/PersonSetting/index.js +3 -3
  51. package/src/base-client/components/common/Tree/Tree.vue +149 -149
  52. package/src/base-client/components/common/Tree/index.js +2 -2
  53. package/src/base-client/components/common/Upload/Upload.vue +239 -239
  54. package/src/base-client/components/common/Upload/index.js +3 -3
  55. package/src/base-client/components/common/XAddForm/XAddForm.vue +105 -105
  56. package/src/base-client/components/common/XAddNativeForm/XAddNativeForm.vue +807 -807
  57. package/src/base-client/components/common/XAddNativeForm/index.md +146 -146
  58. package/src/base-client/components/common/XAddNativeForm/lowcodeEditorRegister.js +16 -16
  59. package/src/base-client/components/common/XAddNativeFormOA/XAddNativeFormOA.vue +303 -303
  60. package/src/base-client/components/common/XAddNativeFormOA/index.js +3 -3
  61. package/src/base-client/components/common/XAddNativeFormOA/index.md +146 -146
  62. package/src/base-client/components/common/XBadge/XBadge.vue +78 -78
  63. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  64. package/src/base-client/components/common/XDataCard/XDataCard.vue +355 -0
  65. package/src/base-client/components/common/XDataCard/index.js +3 -0
  66. package/src/base-client/components/common/XDataCard/index.md +1 -0
  67. package/src/base-client/components/common/XDataDrawer/XDataDrawer.vue +180 -180
  68. package/src/base-client/components/common/XDataDrawer/index.js +3 -3
  69. package/src/base-client/components/common/XDataDrawer/index.md +41 -41
  70. package/src/base-client/components/common/XDescriptions/XDescriptions.vue +188 -187
  71. package/src/base-client/components/common/XDescriptions/XDescriptionsGroup.vue +306 -306
  72. package/src/base-client/components/common/XDescriptions/demo.vue +50 -50
  73. package/src/base-client/components/common/XDescriptions/index.js +3 -3
  74. package/src/base-client/components/common/XDescriptions/index.md +83 -83
  75. package/src/base-client/components/common/XDetailsView/XDetailsView.vue +214 -214
  76. package/src/base-client/components/common/XDetailsView/index.js +3 -3
  77. package/src/base-client/components/common/XForm/XForm.vue +294 -294
  78. package/src/base-client/components/common/XForm/XFormItem.vue +911 -911
  79. package/src/base-client/components/common/XForm/XTreeSelect.vue +207 -207
  80. package/src/base-client/components/common/XForm/index.md +178 -178
  81. package/src/base-client/components/common/XFormCol/XFormCol.vue +36 -36
  82. package/src/base-client/components/common/XFormGroup/XFormGroup.vue +241 -241
  83. package/src/base-client/components/common/XFormGroup/demo.vue +40 -40
  84. package/src/base-client/components/common/XFormGroup/index.js +3 -3
  85. package/src/base-client/components/common/XFormGroup/index.md +38 -38
  86. package/src/base-client/components/common/XFormGroupDetails/XFormGroupDetails.vue +72 -72
  87. package/src/base-client/components/common/XFormGroupDetails/index.js +3 -3
  88. package/src/base-client/components/common/XFormTable/XFormTable.vue +545 -539
  89. package/src/base-client/components/common/XFormTable/demo.vue +72 -72
  90. package/src/base-client/components/common/XFormTable/index.md +98 -98
  91. package/src/base-client/components/common/XFormTable/lowcodeEditorRegister.js +30 -30
  92. package/src/base-client/components/common/XImportExcel/XImportExcel.vue +147 -147
  93. package/src/base-client/components/common/XReport/XReport.vue +858 -858
  94. package/src/base-client/components/common/XReport/XReportDemo.vue +266 -266
  95. package/src/base-client/components/common/XReport/XReportDesign.vue +509 -509
  96. package/src/base-client/components/common/XReport/XReportJsonRender.vue +295 -295
  97. package/src/base-client/components/common/XReport/XReportTrGroup.vue +801 -801
  98. package/src/base-client/components/common/XReport/index.js +3 -3
  99. package/src/base-client/components/common/XReport/index.md +44 -44
  100. package/src/base-client/components/common/XReportSlot/XReportSlot.vue +110 -110
  101. package/src/base-client/components/common/XReportSlot/index.js +3 -3
  102. package/src/base-client/components/common/XSimpleDescriptions/XSimpleDescriptions.vue +137 -0
  103. package/src/base-client/components/common/XSimpleDescriptions/index.js +3 -0
  104. package/src/base-client/components/common/XSimpleDescriptions/index.md +7 -0
  105. package/src/base-client/components/common/XStepView/XStepView.vue +252 -252
  106. package/src/base-client/components/common/XStepView/index.js +3 -3
  107. package/src/base-client/components/common/XStepView/index.md +31 -31
  108. package/src/base-client/components/common/XTable/XTable.vue +715 -676
  109. package/src/base-client/components/common/XTable/index.md +255 -255
  110. package/src/base-client/components/common/XTree/XTree.vue +423 -423
  111. package/src/base-client/components/common/XTree/index.js +3 -3
  112. package/src/base-client/components/common/XTree/index.md +36 -36
  113. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +114 -114
  114. package/src/base-client/components/common/XTreeOne/lowcodeEditorRegister.js +11 -11
  115. package/src/base-client/components/index.js +51 -51
  116. package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -232
  117. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  118. package/src/base-client/plugins/AppData.js +121 -121
  119. package/src/base-client/plugins/Config.js +19 -19
  120. package/src/base-client/plugins/GetLoginInfoService.js +183 -183
  121. package/src/base-client/plugins/tabs-page-plugin.js +39 -39
  122. package/src/bootstrap.js +39 -39
  123. package/src/components/CodeMirror/inedx.vue +118 -118
  124. package/src/components/CodeMirror/setting.js +40 -40
  125. package/src/components/FilePreview/FilePreview.vue +166 -166
  126. package/src/components/NumberInfo/NumberInfo.vue +54 -54
  127. package/src/components/STable/index.js +361 -361
  128. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  129. package/src/components/checkbox/ImgCheckbox.vue +163 -163
  130. package/src/components/menu/SideMenu.vue +75 -75
  131. package/src/components/menu/menu.js +273 -273
  132. package/src/components/tool/AStepItem.vue +60 -60
  133. package/src/config/CreateQueryConfig.js +322 -322
  134. package/src/config/default/antd.config.js +89 -89
  135. package/src/config/default/setting.config.js +55 -55
  136. package/src/font-style/font.css +4 -4
  137. package/src/layouts/CommonLayout.vue +56 -56
  138. package/src/layouts/PageLayout.vue +151 -151
  139. package/src/layouts/SinglePageView.vue +138 -138
  140. package/src/layouts/header/AdminHeader.vue +132 -132
  141. package/src/layouts/header/HeaderNotice.vue +177 -177
  142. package/src/layouts/tabs/TabsHead.vue +189 -189
  143. package/src/layouts/tabs/TabsView.vue +387 -387
  144. package/src/lib.js +1 -1
  145. package/src/main.js +26 -26
  146. package/src/mock/extend/index.js +84 -84
  147. package/src/mock/goods/index.js +108 -108
  148. package/src/pages/AMisDemo/AMisDemo.vue +325 -325
  149. package/src/pages/AMisDemo/AMisDemo2.vue +74 -74
  150. package/src/pages/DynamicStatistics/ChartSelector.vue +331 -331
  151. package/src/pages/DynamicStatistics/DataTabs.vue +83 -83
  152. package/src/pages/DynamicStatistics/DynamicTable.vue +128 -128
  153. package/src/pages/DynamicStatistics/EvaluationArea.vue +69 -69
  154. package/src/pages/DynamicStatistics/FavoriteList.vue +51 -51
  155. package/src/pages/DynamicStatistics/QuestionHistoryAndFavorites.vue +591 -591
  156. package/src/pages/DynamicStatistics/SearchBar.vue +192 -192
  157. package/src/pages/DynamicStatistics/index.vue +282 -282
  158. package/src/pages/Example/index.vue +193 -33
  159. package/src/pages/NewDynamicStatistics/ChartSelector.vue +331 -331
  160. package/src/pages/NewDynamicStatistics/DataTabs.vue +122 -122
  161. package/src/pages/NewDynamicStatistics/DynamicTable.vue +128 -128
  162. package/src/pages/NewDynamicStatistics/EvaluationArea.vue +69 -69
  163. package/src/pages/NewDynamicStatistics/FavoriteList.vue +51 -51
  164. package/src/pages/NewDynamicStatistics/QuestionHistoryAndFavorites.vue +289 -289
  165. package/src/pages/NewDynamicStatistics/SearchBar.vue +193 -193
  166. package/src/pages/NewDynamicStatistics/index.vue +258 -258
  167. package/src/pages/ServiceReview/index.vue +284 -284
  168. package/src/pages/XReportView/index.vue +62 -62
  169. package/src/pages/login/Login.vue +378 -378
  170. package/src/pages/login/LoginV3.vue +389 -389
  171. package/src/pages/lowCode/lowCodeEditor.vue +1219 -1030
  172. package/src/pages/lowCode/lowCodeRenderPage.vue +43 -43
  173. package/src/pages/resourceManage/orgListManage.vue +98 -98
  174. package/src/pages/system/dictionary/index.vue +44 -44
  175. package/src/pages/system/monitor/loginInfor/index.vue +37 -37
  176. package/src/pages/system/monitor/operLog/index.vue +37 -37
  177. package/src/pages/system/settings/modifyPassword.vue +117 -117
  178. package/src/pages/system/ticket/index.vue +480 -480
  179. package/src/pages/system/ticket/submitTicketSuccess.vue +484 -484
  180. package/src/router/async/config.async.js +34 -34
  181. package/src/router/async/router.map.js +104 -104
  182. package/src/router/guards.js +223 -223
  183. package/src/router/index.js +27 -27
  184. package/src/router.js +19 -19
  185. package/src/services/api/TicketDetailsViewApi.js +46 -46
  186. package/src/services/api/cas.js +79 -79
  187. package/src/services/api/common.js +307 -307
  188. package/src/services/api/entity.js +18 -18
  189. package/src/services/api/index.js +17 -17
  190. package/src/services/api/restTools.js +46 -46
  191. package/src/services/apiService.js +14 -14
  192. package/src/services/user.js +71 -71
  193. package/src/services/v3Api.js +81 -81
  194. package/src/store/modules/index.js +5 -5
  195. package/src/store/modules/lowCode.js +33 -33
  196. package/src/store/modules/setting.js +119 -119
  197. package/src/theme/default/style.less +58 -58
  198. package/src/theme/global.less +139 -139
  199. package/src/utils/authority-utils.js +85 -85
  200. package/src/utils/errorCode.js +6 -6
  201. package/src/utils/formatter.js +80 -80
  202. package/src/utils/htmlToPDF.js +108 -108
  203. package/src/utils/htmlToPDFApi.js +5 -5
  204. package/src/utils/indexedDB.js +258 -258
  205. package/src/utils/login.js +188 -188
  206. package/src/utils/lowcode/lowcodeComponentMixin.js +120 -120
  207. package/src/utils/lowcode/lowcodeLog.js +29 -29
  208. package/src/utils/lowcode/lowcodeUtils.js +373 -373
  209. package/src/utils/lowcode/registerComponentForEditor.js +11 -11
  210. package/src/utils/lowcode/registerComponentForRender.js +11 -11
  211. package/src/utils/map-utils.js +47 -47
  212. package/src/utils/reg.js +95 -95
  213. package/src/utils/request.js +347 -347
  214. package/src/utils/routerUtil.js +435 -435
  215. package/src/utils/runEvalFunction.js +6 -6
  216. package/src/utils/util.js +241 -241
  217. package/src/utils/waterMark.js +31 -31
  218. package/test/Amis.spec.js +163 -163
  219. package/test/Tree.spec.js +167 -167
  220. package/test/myDialog.spec.js +46 -46
  221. package/vue.config.js +181 -181
  222. package//350/277/201/347/247/273/346/227/245/345/277/227.md +15 -15
package/test/Tree.spec.js CHANGED
@@ -1,167 +1,167 @@
1
- import { nextTick } from 'vue'
2
- import { shallowMount, mount } from '@vue/test-utils'
3
-
4
- import TreeComponent from '@vue2-client/base-client/components/common/Tree'
5
- import * as CommonApi from '@vue2-client/services/api/common'
6
-
7
- function handleLogic (logicName, parameters) {
8
- // 使用 switch 语句来处理多种业务逻辑
9
- switch (logicName) {
10
- case 'get_root_nodes':
11
- // 返回特定于 'get_root_nodes' 业务逻辑的数据
12
- return Promise.resolve({
13
- data: [{
14
- key: '0-0',
15
- children: [],
16
- title: '某某燃气有限公司',
17
- }],
18
- })
19
-
20
- case 'get_child_nodes':
21
- // 根据 'another_logic' 执行不同的操作
22
- // ...(执行相关操作)
23
- return Promise.resolve({
24
- data: [
25
- { id: '2' },
26
- ],
27
- })
28
-
29
- // ...您可以添加更多的 case 语句来处理更多的业务逻辑
30
-
31
- default:
32
- // 如果传入了一个未处理的业务逻辑名称,您可以有一个默认的行为或返回一个错误。
33
- return Promise.reject(new Error('未知的业务逻辑名称: ' + logicName))
34
- }
35
- }
36
-
37
- describe('TreeComponent', () => {
38
- let runLogicSpy // 将变量声明移动到这里,使其在下面的作用域中可见
39
- let wrapper
40
-
41
- beforeEach(() => {
42
- // 这里,我们使用 'spyOn' 只拦截 'runLogic' 函数,而不影响模块中的其他函数
43
- runLogicSpy = jest.spyOn(CommonApi, 'runLogic')
44
- // 现在,你可以定义这个函数的模拟实现或返回值
45
- runLogicSpy.mockImplementation((logicName, parameters) => {
46
- return handleLogic(logicName, parameters) // 这里是你的模拟实现)
47
- })
48
-
49
- // 在这里,我们通过 propsData 传递 prop
50
- wrapper = mount(TreeComponent, {
51
- propsData: {
52
- configContent: {}, // 这里添加你的配置内容
53
- // ... 如果还有其他 props,也在这里添加 ...
54
- },
55
- })
56
- })
57
-
58
- afterEach(() => {
59
- // 测试之后,你应该清理模拟,以确保它不会影响其他测试
60
- runLogicSpy.mockRestore()
61
- wrapper.destroy()
62
- })
63
-
64
- it('renders a Tree component', () => {
65
- expect(wrapper.findComponent({ name: 'a-tree' }).exists()).toBe(true)
66
- })
67
-
68
- it('calls generateTreeData method on mounted', async () => {
69
- // 首先创建spy
70
- const generateTreeData = jest.spyOn(TreeComponent.methods, 'generateTreeData')
71
-
72
- // 挂载组件,并通过 propsData 传递参数
73
- wrapper = await mount(TreeComponent, {
74
- propsData: {
75
- configContent: {}, // 这里添加实际的配置内容
76
- // ...如果还有其他props,也可以在这里添加...
77
- },
78
- })
79
-
80
- // 现在检查 generateTreeData 是否已被调用
81
- expect(generateTreeData).toHaveBeenCalled()
82
- })
83
-
84
- it('generates treeData correctly', () => {
85
- const expectedTreeData =
86
- [{
87
- key: '0-0',
88
- children: [],
89
- title: '某某燃气有限公司',
90
- }]
91
-
92
- expect(wrapper.vm.treeData).toEqual(expectedTreeData)
93
- })
94
-
95
- it('expands a node and fetches child nodes correctly', async () => {
96
- // 准备一些模拟数据
97
- const mockNode = {
98
- id: '1', // 或其他唯一标识符
99
- children: [], // 初始时假设没有子节点
100
- }
101
-
102
- const mockChildren = [
103
- { id: '2', parentNode: mockNode },
104
- // ...更多子节点
105
- ]
106
-
107
- // 准备handleExpand方法所需的参数
108
- const expandedKeys = ['1'] // 假设这是当前展开的节点keys
109
- const info = {
110
- expanded: true, // 假设节点是被展开的
111
- node: mockNode, // 当前操作的节点
112
- }
113
-
114
- // 现在调用handleExpand方法
115
- await wrapper.vm.handleExpand(expandedKeys, info)
116
-
117
- // 我们还期望mockNode的子节点被更新
118
- expect(mockNode.children).toEqual(mockChildren)
119
-
120
- // 如果handleExpand方法更新了expandedKeys数组,我们也要验证这一点
121
- const expectedExpandedKeys = ['1'] // 假设它应该包含被展开节点的id
122
- expect(wrapper.vm.expandedKeys).toEqual(expectedExpandedKeys)
123
- })
124
-
125
- it('selects a node and emits nodeSelected event correctly', () => {
126
- // 准备 mock 数据
127
- const mockNode = { title: '某某燃气有限公司', parentNode: null }
128
- const selectedKeys = ['1'] // 这个应该基于 mockNode 的数据
129
- const selectInfo = { selected: true, node: mockNode }
130
-
131
- // 调用 handleSelect 方法
132
- wrapper.vm.handleSelect(selectedKeys, selectInfo)
133
-
134
- // 断言已发出正确的事件
135
- const emittedEvents = wrapper.emitted('nodeSelected')
136
- expect(emittedEvents).toBeTruthy() // 确认是否有事件被发出
137
- expect(emittedEvents).toHaveLength(1) // 只有一个事件被发出
138
- expect(emittedEvents[0]).toEqual(['某某燃气有限公司']) // 传出的事件携带了正确的数据
139
-
140
- // 如果 handleSelect 方法更改了内部状态(例如,'selectedKeys'),也要进行断言
141
- expect(wrapper.vm.selectedKeys).toEqual([])
142
- })
143
-
144
- it('expands a node when clicked', async () => {
145
- console.log(wrapper.html()) // 打印组件的 HTML 输出
146
-
147
- // 找到 role 为 "treeitem" 的元素,这代表树节点
148
- const treeNode = wrapper.find('li[role="treeitem"]')
149
-
150
- // 确认我们找到了节点
151
- expect(treeNode.exists()).toBe(true)
152
-
153
- // 模拟用户点击,展开节点
154
- await treeNode.trigger('click')
155
-
156
- // 必须等待 nextTick 以便 Vue 更新 DOM
157
- await nextTick()
158
-
159
- // 现在检查是否更新了 expandedKeys
160
- expect(wrapper.vm.expandedKeys).toContain('0-0') // 假设 '0-0' 是被点击的节点的 key
161
-
162
- // 检查 'expand' 事件是否被正确触发
163
- const expandEvents = wrapper.emitted('expand')
164
- expect(expandEvents).toBeTruthy()
165
- expect(expandEvents.length).toBeGreaterThan(0) // 确认至少触发了一次
166
- })
167
- })
1
+ import { nextTick } from 'vue'
2
+ import { shallowMount, mount } from '@vue/test-utils'
3
+
4
+ import TreeComponent from '@vue2-client/base-client/components/common/Tree'
5
+ import * as CommonApi from '@vue2-client/services/api/common'
6
+
7
+ function handleLogic (logicName, parameters) {
8
+ // 使用 switch 语句来处理多种业务逻辑
9
+ switch (logicName) {
10
+ case 'get_root_nodes':
11
+ // 返回特定于 'get_root_nodes' 业务逻辑的数据
12
+ return Promise.resolve({
13
+ data: [{
14
+ key: '0-0',
15
+ children: [],
16
+ title: '某某燃气有限公司',
17
+ }],
18
+ })
19
+
20
+ case 'get_child_nodes':
21
+ // 根据 'another_logic' 执行不同的操作
22
+ // ...(执行相关操作)
23
+ return Promise.resolve({
24
+ data: [
25
+ { id: '2' },
26
+ ],
27
+ })
28
+
29
+ // ...您可以添加更多的 case 语句来处理更多的业务逻辑
30
+
31
+ default:
32
+ // 如果传入了一个未处理的业务逻辑名称,您可以有一个默认的行为或返回一个错误。
33
+ return Promise.reject(new Error('未知的业务逻辑名称: ' + logicName))
34
+ }
35
+ }
36
+
37
+ describe('TreeComponent', () => {
38
+ let runLogicSpy // 将变量声明移动到这里,使其在下面的作用域中可见
39
+ let wrapper
40
+
41
+ beforeEach(() => {
42
+ // 这里,我们使用 'spyOn' 只拦截 'runLogic' 函数,而不影响模块中的其他函数
43
+ runLogicSpy = jest.spyOn(CommonApi, 'runLogic')
44
+ // 现在,你可以定义这个函数的模拟实现或返回值
45
+ runLogicSpy.mockImplementation((logicName, parameters) => {
46
+ return handleLogic(logicName, parameters) // 这里是你的模拟实现)
47
+ })
48
+
49
+ // 在这里,我们通过 propsData 传递 prop
50
+ wrapper = mount(TreeComponent, {
51
+ propsData: {
52
+ configContent: {}, // 这里添加你的配置内容
53
+ // ... 如果还有其他 props,也在这里添加 ...
54
+ },
55
+ })
56
+ })
57
+
58
+ afterEach(() => {
59
+ // 测试之后,你应该清理模拟,以确保它不会影响其他测试
60
+ runLogicSpy.mockRestore()
61
+ wrapper.destroy()
62
+ })
63
+
64
+ it('renders a Tree component', () => {
65
+ expect(wrapper.findComponent({ name: 'a-tree' }).exists()).toBe(true)
66
+ })
67
+
68
+ it('calls generateTreeData method on mounted', async () => {
69
+ // 首先创建spy
70
+ const generateTreeData = jest.spyOn(TreeComponent.methods, 'generateTreeData')
71
+
72
+ // 挂载组件,并通过 propsData 传递参数
73
+ wrapper = await mount(TreeComponent, {
74
+ propsData: {
75
+ configContent: {}, // 这里添加实际的配置内容
76
+ // ...如果还有其他props,也可以在这里添加...
77
+ },
78
+ })
79
+
80
+ // 现在检查 generateTreeData 是否已被调用
81
+ expect(generateTreeData).toHaveBeenCalled()
82
+ })
83
+
84
+ it('generates treeData correctly', () => {
85
+ const expectedTreeData =
86
+ [{
87
+ key: '0-0',
88
+ children: [],
89
+ title: '某某燃气有限公司',
90
+ }]
91
+
92
+ expect(wrapper.vm.treeData).toEqual(expectedTreeData)
93
+ })
94
+
95
+ it('expands a node and fetches child nodes correctly', async () => {
96
+ // 准备一些模拟数据
97
+ const mockNode = {
98
+ id: '1', // 或其他唯一标识符
99
+ children: [], // 初始时假设没有子节点
100
+ }
101
+
102
+ const mockChildren = [
103
+ { id: '2', parentNode: mockNode },
104
+ // ...更多子节点
105
+ ]
106
+
107
+ // 准备handleExpand方法所需的参数
108
+ const expandedKeys = ['1'] // 假设这是当前展开的节点keys
109
+ const info = {
110
+ expanded: true, // 假设节点是被展开的
111
+ node: mockNode, // 当前操作的节点
112
+ }
113
+
114
+ // 现在调用handleExpand方法
115
+ await wrapper.vm.handleExpand(expandedKeys, info)
116
+
117
+ // 我们还期望mockNode的子节点被更新
118
+ expect(mockNode.children).toEqual(mockChildren)
119
+
120
+ // 如果handleExpand方法更新了expandedKeys数组,我们也要验证这一点
121
+ const expectedExpandedKeys = ['1'] // 假设它应该包含被展开节点的id
122
+ expect(wrapper.vm.expandedKeys).toEqual(expectedExpandedKeys)
123
+ })
124
+
125
+ it('selects a node and emits nodeSelected event correctly', () => {
126
+ // 准备 mock 数据
127
+ const mockNode = { title: '某某燃气有限公司', parentNode: null }
128
+ const selectedKeys = ['1'] // 这个应该基于 mockNode 的数据
129
+ const selectInfo = { selected: true, node: mockNode }
130
+
131
+ // 调用 handleSelect 方法
132
+ wrapper.vm.handleSelect(selectedKeys, selectInfo)
133
+
134
+ // 断言已发出正确的事件
135
+ const emittedEvents = wrapper.emitted('nodeSelected')
136
+ expect(emittedEvents).toBeTruthy() // 确认是否有事件被发出
137
+ expect(emittedEvents).toHaveLength(1) // 只有一个事件被发出
138
+ expect(emittedEvents[0]).toEqual(['某某燃气有限公司']) // 传出的事件携带了正确的数据
139
+
140
+ // 如果 handleSelect 方法更改了内部状态(例如,'selectedKeys'),也要进行断言
141
+ expect(wrapper.vm.selectedKeys).toEqual([])
142
+ })
143
+
144
+ it('expands a node when clicked', async () => {
145
+ console.log(wrapper.html()) // 打印组件的 HTML 输出
146
+
147
+ // 找到 role 为 "treeitem" 的元素,这代表树节点
148
+ const treeNode = wrapper.find('li[role="treeitem"]')
149
+
150
+ // 确认我们找到了节点
151
+ expect(treeNode.exists()).toBe(true)
152
+
153
+ // 模拟用户点击,展开节点
154
+ await treeNode.trigger('click')
155
+
156
+ // 必须等待 nextTick 以便 Vue 更新 DOM
157
+ await nextTick()
158
+
159
+ // 现在检查是否更新了 expandedKeys
160
+ expect(wrapper.vm.expandedKeys).toContain('0-0') // 假设 '0-0' 是被点击的节点的 key
161
+
162
+ // 检查 'expand' 事件是否被正确触发
163
+ const expandEvents = wrapper.emitted('expand')
164
+ expect(expandEvents).toBeTruthy()
165
+ expect(expandEvents.length).toBeGreaterThan(0) // 确认至少触发了一次
166
+ })
167
+ })
@@ -1,46 +1,46 @@
1
- import { createLocalVue, mount } from '@vue/test-utils'
2
- import MyConfirm from '@vue2-client/base-client/components/common/XBadge'
3
- import Plugins from '@vue2-client/base-client/plugins'
4
- import Antd from 'ant-design-vue'
5
-
6
- const localVue = createLocalVue()
7
-
8
- // 此处与index.js保持一致,保证antd的组件和appdata可以正常载入
9
- localVue.use(Antd)
10
- localVue.use(Plugins)
11
-
12
- describe('MyConfirm', () => {
13
- beforeAll(() => {
14
- // mock localStorage的数据
15
- const getItemSpy = jest.spyOn(window.localStorage.__proto__, 'getItem')
16
- getItemSpy.mockImplementation((key) => {
17
- if (key === process.env.VUE_APP_BADGE_KEY) {
18
- return JSON.stringify({
19
- badgeStyleMap: {
20
- red: {
21
- status: 'red',
22
- text: '红色(Red)'
23
- },
24
- blue: {
25
- status: 'blue',
26
- text: '蓝色(Blue)'
27
- }
28
- }
29
- })
30
- }
31
- })
32
- })
33
- // 测试用例:正确渲染组件
34
- it('renders correctly', () => {
35
- const wrapper = mount(MyConfirm, {
36
- localVue: localVue,
37
- // 组件必要的传参
38
- propsData: {
39
- badgeKey: 'badgeStyleMap',
40
- value: 'red'
41
- }
42
- })
43
- console.debug('返回的组件html:' + wrapper.html())
44
- expect(wrapper.exists()).toBe(true)
45
- })
46
- })
1
+ import { createLocalVue, mount } from '@vue/test-utils'
2
+ import MyConfirm from '@vue2-client/base-client/components/common/XBadge'
3
+ import Plugins from '@vue2-client/base-client/plugins'
4
+ import Antd from 'ant-design-vue'
5
+
6
+ const localVue = createLocalVue()
7
+
8
+ // 此处与index.js保持一致,保证antd的组件和appdata可以正常载入
9
+ localVue.use(Antd)
10
+ localVue.use(Plugins)
11
+
12
+ describe('MyConfirm', () => {
13
+ beforeAll(() => {
14
+ // mock localStorage的数据
15
+ const getItemSpy = jest.spyOn(window.localStorage.__proto__, 'getItem')
16
+ getItemSpy.mockImplementation((key) => {
17
+ if (key === process.env.VUE_APP_BADGE_KEY) {
18
+ return JSON.stringify({
19
+ badgeStyleMap: {
20
+ red: {
21
+ status: 'red',
22
+ text: '红色(Red)'
23
+ },
24
+ blue: {
25
+ status: 'blue',
26
+ text: '蓝色(Blue)'
27
+ }
28
+ }
29
+ })
30
+ }
31
+ })
32
+ })
33
+ // 测试用例:正确渲染组件
34
+ it('renders correctly', () => {
35
+ const wrapper = mount(MyConfirm, {
36
+ localVue: localVue,
37
+ // 组件必要的传参
38
+ propsData: {
39
+ badgeKey: 'badgeStyleMap',
40
+ value: 'red'
41
+ }
42
+ })
43
+ console.debug('返回的组件html:' + wrapper.html())
44
+ expect(wrapper.exists()).toBe(true)
45
+ })
46
+ })