vue2-client 1.8.310 → 1.8.311

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 (215) 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/LowCodeEditorModal.vue +108 -108
  45. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorPanel.vue +350 -350
  46. package/src/base-client/components/common/LowCodeComponent/LowCodePageOrganization.vue +502 -502
  47. package/src/base-client/components/common/LowCodeComponent/LowCodeRender.vue +699 -699
  48. package/src/base-client/components/common/LowCodeComponent/LowCodeRenderEnter.vue +29 -29
  49. package/src/base-client/components/common/LowCodeComponent/LowCodeUIStore.vue +162 -162
  50. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeAddPageModal.vue +117 -117
  51. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeCustomJSModal.vue +80 -80
  52. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeEventEditorModal.vue +398 -398
  53. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLifeCycleModal.vue +65 -65
  54. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicCallbackModal.vue +64 -64
  55. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicParamModal.vue +73 -73
  56. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeRunFunctionParamModal.vue +76 -76
  57. package/src/base-client/components/common/PersonSetting/PersonSetting.vue +208 -208
  58. package/src/base-client/components/common/PersonSetting/index.js +3 -3
  59. package/src/base-client/components/common/Tree/Tree.vue +149 -149
  60. package/src/base-client/components/common/Tree/index.js +2 -2
  61. package/src/base-client/components/common/Upload/Upload.vue +239 -239
  62. package/src/base-client/components/common/Upload/index.js +3 -3
  63. package/src/base-client/components/common/XAddForm/XAddForm.vue +105 -105
  64. package/src/base-client/components/common/XAddNativeForm/XAddNativeForm.vue +807 -807
  65. package/src/base-client/components/common/XAddNativeForm/index.md +146 -146
  66. package/src/base-client/components/common/XAddNativeForm/lowcodeEditorRegister.js +16 -16
  67. package/src/base-client/components/common/XAddNativeFormOA/XAddNativeFormOA.vue +303 -303
  68. package/src/base-client/components/common/XAddNativeFormOA/index.js +3 -3
  69. package/src/base-client/components/common/XAddNativeFormOA/index.md +146 -146
  70. package/src/base-client/components/common/XBadge/XBadge.vue +78 -78
  71. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  72. package/src/base-client/components/common/XDataDrawer/XDataDrawer.vue +180 -180
  73. package/src/base-client/components/common/XDataDrawer/index.js +3 -3
  74. package/src/base-client/components/common/XDataDrawer/index.md +41 -41
  75. package/src/base-client/components/common/XDescriptions/XDescriptions.vue +187 -187
  76. package/src/base-client/components/common/XDescriptions/XDescriptionsGroup.vue +306 -306
  77. package/src/base-client/components/common/XDescriptions/demo.vue +50 -50
  78. package/src/base-client/components/common/XDescriptions/index.js +3 -3
  79. package/src/base-client/components/common/XDescriptions/index.md +83 -83
  80. package/src/base-client/components/common/XDescriptions/lowcodeEditorRegister.js +31 -31
  81. package/src/base-client/components/common/XDetailsView/XDetailsView.vue +214 -214
  82. package/src/base-client/components/common/XDetailsView/index.js +3 -3
  83. package/src/base-client/components/common/XForm/XForm.vue +294 -294
  84. package/src/base-client/components/common/XForm/XFormItem.vue +911 -911
  85. package/src/base-client/components/common/XForm/XTreeSelect.vue +207 -207
  86. package/src/base-client/components/common/XForm/index.md +178 -178
  87. package/src/base-client/components/common/XFormCol/XFormCol.vue +36 -36
  88. package/src/base-client/components/common/XFormGroup/XFormGroup.vue +241 -241
  89. package/src/base-client/components/common/XFormGroup/demo.vue +40 -40
  90. package/src/base-client/components/common/XFormGroup/index.js +3 -3
  91. package/src/base-client/components/common/XFormGroup/index.md +38 -38
  92. package/src/base-client/components/common/XFormGroupDetails/XFormGroupDetails.vue +72 -72
  93. package/src/base-client/components/common/XFormGroupDetails/index.js +3 -3
  94. package/src/base-client/components/common/XFormTable/XFormTable.vue +539 -539
  95. package/src/base-client/components/common/XFormTable/demo.vue +72 -72
  96. package/src/base-client/components/common/XFormTable/index.md +98 -98
  97. package/src/base-client/components/common/XFormTable/lowcodeEditorRegister.js +30 -30
  98. package/src/base-client/components/common/XImportExcel/XImportExcel.vue +147 -147
  99. package/src/base-client/components/common/XReport/XReport.vue +858 -858
  100. package/src/base-client/components/common/XReport/XReportDemo.vue +266 -266
  101. package/src/base-client/components/common/XReport/XReportDesign.vue +509 -509
  102. package/src/base-client/components/common/XReport/XReportJsonRender.vue +295 -295
  103. package/src/base-client/components/common/XReport/XReportTrGroup.vue +801 -801
  104. package/src/base-client/components/common/XReport/index.js +3 -3
  105. package/src/base-client/components/common/XReport/index.md +44 -44
  106. package/src/base-client/components/common/XReportSlot/XReportSlot.vue +110 -110
  107. package/src/base-client/components/common/XReportSlot/index.js +3 -3
  108. package/src/base-client/components/common/XReportSlot/index.md +48 -48
  109. package/src/base-client/components/common/XStepView/XStepView.vue +252 -252
  110. package/src/base-client/components/common/XStepView/index.js +3 -3
  111. package/src/base-client/components/common/XStepView/index.md +31 -31
  112. package/src/base-client/components/common/XTable/XTable.vue +676 -676
  113. package/src/base-client/components/common/XTable/index.md +255 -255
  114. package/src/base-client/components/common/XTree/XTree.vue +423 -423
  115. package/src/base-client/components/common/XTree/index.js +3 -3
  116. package/src/base-client/components/common/XTree/index.md +36 -36
  117. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +114 -114
  118. package/src/base-client/components/common/XTreeOne/lowcodeEditorRegister.js +11 -11
  119. package/src/base-client/components/index.js +51 -51
  120. package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -232
  121. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  122. package/src/base-client/plugins/AppData.js +121 -121
  123. package/src/base-client/plugins/Config.js +19 -19
  124. package/src/base-client/plugins/GetLoginInfoService.js +183 -183
  125. package/src/base-client/plugins/tabs-page-plugin.js +39 -39
  126. package/src/bootstrap.js +39 -39
  127. package/src/components/FilePreview/FilePreview.vue +166 -166
  128. package/src/components/NumberInfo/NumberInfo.vue +54 -54
  129. package/src/components/STable/index.js +361 -361
  130. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  131. package/src/components/checkbox/ImgCheckbox.vue +163 -163
  132. package/src/components/menu/SideMenu.vue +75 -75
  133. package/src/components/menu/menu.js +273 -273
  134. package/src/components/tool/AStepItem.vue +60 -60
  135. package/src/config/default/antd.config.js +89 -89
  136. package/src/config/default/setting.config.js +55 -55
  137. package/src/font-style/font.css +4 -4
  138. package/src/layouts/CommonLayout.vue +56 -56
  139. package/src/layouts/PageLayout.vue +151 -151
  140. package/src/layouts/SinglePageView.vue +138 -138
  141. package/src/layouts/header/AdminHeader.vue +132 -132
  142. package/src/layouts/header/HeaderNotice.vue +177 -177
  143. package/src/layouts/tabs/TabsHead.vue +189 -189
  144. package/src/layouts/tabs/TabsView.vue +387 -387
  145. package/src/lib.js +1 -1
  146. package/src/main.js +26 -26
  147. package/src/mock/extend/index.js +84 -84
  148. package/src/mock/goods/index.js +108 -108
  149. package/src/pages/AMisDemo/AMisDemo.vue +325 -325
  150. package/src/pages/AMisDemo/AMisDemo2.vue +74 -74
  151. package/src/pages/DynamicStatistics/ChartSelector.vue +331 -331
  152. package/src/pages/DynamicStatistics/DataTabs.vue +83 -83
  153. package/src/pages/DynamicStatistics/DynamicTable.vue +128 -128
  154. package/src/pages/DynamicStatistics/EvaluationArea.vue +69 -69
  155. package/src/pages/DynamicStatistics/FavoriteList.vue +51 -51
  156. package/src/pages/DynamicStatistics/QuestionHistoryAndFavorites.vue +591 -591
  157. package/src/pages/DynamicStatistics/SearchBar.vue +192 -192
  158. package/src/pages/DynamicStatistics/index.vue +282 -282
  159. package/src/pages/Example/index.vue +33 -33
  160. package/src/pages/ServiceReview/index.vue +284 -284
  161. package/src/pages/XReportView/index.vue +62 -62
  162. package/src/pages/login/Login.vue +378 -378
  163. package/src/pages/login/LoginV3.vue +389 -389
  164. package/src/pages/lowCode/lowCodeEditor.vue +1030 -1030
  165. package/src/pages/lowCode/lowCodeRenderPage.vue +43 -43
  166. package/src/pages/resourceManage/orgListManage.vue +98 -98
  167. package/src/pages/system/dictionary/index.vue +44 -44
  168. package/src/pages/system/monitor/loginInfor/index.vue +37 -37
  169. package/src/pages/system/monitor/operLog/index.vue +37 -37
  170. package/src/pages/system/settings/modifyPassword.vue +117 -117
  171. package/src/pages/system/ticket/index.vue +480 -480
  172. package/src/pages/system/ticket/submitTicketSuccess.vue +484 -484
  173. package/src/router/async/config.async.js +34 -34
  174. package/src/router/async/router.map.js +104 -104
  175. package/src/router/guards.js +223 -223
  176. package/src/router/index.js +27 -27
  177. package/src/router.js +19 -19
  178. package/src/services/api/TicketDetailsViewApi.js +46 -46
  179. package/src/services/api/cas.js +79 -79
  180. package/src/services/api/common.js +307 -307
  181. package/src/services/api/entity.js +18 -18
  182. package/src/services/api/index.js +17 -17
  183. package/src/services/api/restTools.js +46 -46
  184. package/src/services/apiService.js +14 -14
  185. package/src/services/user.js +71 -71
  186. package/src/services/v3Api.js +81 -81
  187. package/src/store/modules/index.js +5 -5
  188. package/src/store/modules/lowCode.js +33 -33
  189. package/src/store/modules/setting.js +119 -119
  190. package/src/theme/default/style.less +58 -58
  191. package/src/theme/global.less +139 -139
  192. package/src/utils/authority-utils.js +85 -85
  193. package/src/utils/errorCode.js +6 -6
  194. package/src/utils/formatter.js +80 -80
  195. package/src/utils/htmlToPDF.js +108 -108
  196. package/src/utils/htmlToPDFApi.js +5 -5
  197. package/src/utils/indexedDB.js +258 -258
  198. package/src/utils/login.js +188 -188
  199. package/src/utils/lowcode/lowcodeComponentMixin.js +120 -120
  200. package/src/utils/lowcode/lowcodeLog.js +29 -29
  201. package/src/utils/lowcode/lowcodeUtils.js +373 -373
  202. package/src/utils/lowcode/registerComponentForEditor.js +11 -11
  203. package/src/utils/lowcode/registerComponentForRender.js +11 -11
  204. package/src/utils/map-utils.js +47 -47
  205. package/src/utils/reg.js +95 -95
  206. package/src/utils/request.js +347 -347
  207. package/src/utils/routerUtil.js +435 -435
  208. package/src/utils/runEvalFunction.js +6 -6
  209. package/src/utils/util.js +241 -241
  210. package/src/utils/waterMark.js +31 -31
  211. package/test/Amis.spec.js +163 -163
  212. package/test/Tree.spec.js +167 -167
  213. package/test/myDialog.spec.js +46 -46
  214. package/vue.config.js +181 -181
  215. 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
+ })