@ebiz/designer-components 0.1.133 → 0.1.136

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 (231) hide show
  1. package/README.md +29 -29
  2. package/dist/designer-components.css +1 -1
  3. package/dist/index.mjs +113807 -42551
  4. package/dist/{pdf-KomaE0u5.js → pdf-C9oIcL2N.js} +891 -891
  5. package/package.json +5 -4
  6. package/src/App.vue +26 -26
  7. package/src/apiService/SIMPLE_DATA_SERVICE.md +284 -284
  8. package/src/apiService/mockDataService.js +115 -115
  9. package/src/apiService/simpleDataService.js +312 -312
  10. package/src/assets/base.css +86 -86
  11. package/src/assets/logo.svg +1 -1
  12. package/src/components/Button.vue +149 -149
  13. package/src/components/DataContainer.vue +40 -40
  14. package/src/components/EbizApproval.vue +747 -747
  15. package/src/components/EbizApprovalDetail.vue +169 -169
  16. package/src/components/EbizApprovalForm.vue +510 -510
  17. package/src/components/EbizApprovalV2.vue +747 -747
  18. package/src/components/EbizAutoForm.vue +596 -596
  19. package/src/components/EbizAvatar.vue +115 -115
  20. package/src/components/EbizCheckbox.vue +93 -93
  21. package/src/components/EbizCheckboxGroup.vue +69 -69
  22. package/src/components/EbizDepartmentSelector.vue +148 -148
  23. package/src/components/EbizDescriptions.vue +340 -340
  24. package/src/components/EbizDescriptionsItem.vue +47 -47
  25. package/src/components/EbizDetailBlock.vue +81 -81
  26. package/src/components/EbizDetailItem.vue +559 -559
  27. package/src/components/EbizDetailView.md +438 -438
  28. package/src/components/EbizDetailView.vue +356 -356
  29. package/src/components/EbizDialog.vue +260 -260
  30. package/src/components/EbizDictionarySelect.vue +229 -229
  31. package/src/components/EbizDiv.vue +40 -40
  32. package/src/components/EbizDivider.vue +96 -96
  33. package/src/components/EbizDormDashboard.vue +314 -314
  34. package/src/components/EbizDropdown.vue +135 -135
  35. package/src/components/EbizDropdownItem.vue +85 -85
  36. package/src/components/EbizEmployeeInfo.vue +144 -144
  37. package/src/components/EbizEmployeeSelector.vue +1160 -1160
  38. package/src/components/EbizFileList.vue +502 -502
  39. package/src/components/EbizMap.vue +541 -541
  40. package/src/components/EbizMeetingRoomSelector.vue +1149 -1149
  41. package/src/components/EbizMobileMeetingRoomSelector.vue +727 -727
  42. package/src/components/EbizOkrTree.vue +99 -99
  43. package/src/components/EbizPageHeader.vue +98 -98
  44. package/src/components/EbizPagination.vue +162 -162
  45. package/src/components/EbizParkingDashboard.vue +152 -152
  46. package/src/components/EbizPdfViewer.vue +540 -540
  47. package/src/components/EbizPopconfirm.vue +47 -47
  48. package/src/components/EbizQrCode.vue +167 -167
  49. package/src/components/EbizRadio.vue +86 -86
  50. package/src/components/EbizRadioGroup.vue +83 -83
  51. package/src/components/EbizRemoteSelect.vue +232 -232
  52. package/src/components/EbizRichTextEditor.vue +338 -338
  53. package/src/components/EbizRouteBreadcrumb.vue +46 -46
  54. package/src/components/EbizSApprovalProcess.vue +1456 -1456
  55. package/src/components/EbizSelect.vue +85 -85
  56. package/src/components/EbizSpace.vue +100 -100
  57. package/src/components/EbizStatistic.vue +149 -149
  58. package/src/components/EbizStatisticChart.vue +213 -0
  59. package/src/components/EbizStatsCard.vue +113 -113
  60. package/src/components/EbizSwiper.vue +113 -113
  61. package/src/components/EbizSwiperItem.vue +13 -13
  62. package/src/components/EbizSwitch.vue +85 -85
  63. package/src/components/EbizTabHeader.vue +132 -132
  64. package/src/components/EbizTabPanel.vue +22 -22
  65. package/src/components/EbizTable.vue +469 -469
  66. package/src/components/EbizTableColumn.vue +116 -116
  67. package/src/components/EbizTableSort.vue +179 -179
  68. package/src/components/EbizTabs.vue +142 -142
  69. package/src/components/EbizTdesignButtonDialog.vue +332 -332
  70. package/src/components/EbizTdesignLoading.vue +107 -107
  71. package/src/components/EbizTimePicker.vue +143 -143
  72. package/src/components/EbizTitle.vue +91 -91
  73. package/src/components/EbizTree.vue +141 -141
  74. package/src/components/EbizTreeMergeTable.vue +1494 -1494
  75. package/src/components/EbizTreeSelector.vue +469 -469
  76. package/src/components/EbizVideo.vue +553 -553
  77. package/src/components/EbizVxeTable.vue +290 -290
  78. package/src/components/Form.vue +28 -28
  79. package/src/components/Home.vue +7 -7
  80. package/src/components/LaunchInterview.vue +526 -526
  81. package/src/components/MyComponent.vue +39 -39
  82. package/src/components/Table.vue +45 -45
  83. package/src/components/TdesignAlert.vue +115 -115
  84. package/src/components/TdesignButton.vue +135 -135
  85. package/src/components/TdesignCalendar/index.vue +145 -145
  86. package/src/components/TdesignCard.vue +195 -195
  87. package/src/components/TdesignCol.vue +101 -101
  88. package/src/components/TdesignCollapse.vue +142 -142
  89. package/src/components/TdesignCollapsePanel.vue +79 -79
  90. package/src/components/TdesignDatePicker.vue +124 -124
  91. package/src/components/TdesignDescriptions.vue +74 -74
  92. package/src/components/TdesignDescriptionsItem.vue +50 -50
  93. package/src/components/TdesignDialog.vue +225 -225
  94. package/src/components/TdesignForm.vue +138 -138
  95. package/src/components/TdesignFormItem.vue +105 -105
  96. package/src/components/TdesignGrid.vue +55 -55
  97. package/src/components/TdesignIcon.vue +67 -67
  98. package/src/components/TdesignImage.vue +162 -162
  99. package/src/components/TdesignImageViewer.vue +200 -200
  100. package/src/components/TdesignInput.vue +242 -242
  101. package/src/components/TdesignSelect.vue +446 -446
  102. package/src/components/TdesignTag.vue +117 -117
  103. package/src/components/TdesignTextarea.vue +142 -142
  104. package/src/components/TdesignTimeline.vue +58 -58
  105. package/src/components/TdesignTimelineItem.vue +71 -71
  106. package/src/components/TdesignUpload.vue +414 -414
  107. package/src/components/TdesignWatermark.vue +107 -107
  108. package/src/components/ebiz-form/components/cascader.vue +61 -61
  109. package/src/components/ebiz-form/components/checkbox.vue +37 -37
  110. package/src/components/ebiz-form/components/city.vue +137 -137
  111. package/src/components/ebiz-form/components/date-panel.vue +52 -52
  112. package/src/components/ebiz-form/components/date-range-panel.vue +52 -52
  113. package/src/components/ebiz-form/components/date-range.vue +56 -56
  114. package/src/components/ebiz-form/components/date.vue +52 -52
  115. package/src/components/ebiz-form/components/editor-multi-language.vue +47 -47
  116. package/src/components/ebiz-form/components/editor.vue +78 -78
  117. package/src/components/ebiz-form/components/file-multi-language.vue +52 -52
  118. package/src/components/ebiz-form/components/file.vue +149 -149
  119. package/src/components/ebiz-form/components/images-multi-language.vue +52 -52
  120. package/src/components/ebiz-form/components/images.vue +129 -129
  121. package/src/components/ebiz-form/components/img-multi-language.vue +51 -51
  122. package/src/components/ebiz-form/components/img.vue +129 -129
  123. package/src/components/ebiz-form/components/number.vue +50 -50
  124. package/src/components/ebiz-form/components/radio.vue +28 -28
  125. package/src/components/ebiz-form/components/select.vue +119 -119
  126. package/src/components/ebiz-form/components/switch.vue +23 -23
  127. package/src/components/ebiz-form/components/text-multi-language.vue +47 -47
  128. package/src/components/ebiz-form/components/text.vue +52 -52
  129. package/src/components/ebiz-form/components/textarea-multi-language.vue +48 -48
  130. package/src/components/ebiz-form/components/textarea.vue +29 -29
  131. package/src/components/ebiz-form/components/video-multi-language.vue +51 -51
  132. package/src/components/ebiz-form/components/video.vue +97 -97
  133. package/src/components/ebiz-form/index.vue +157 -157
  134. package/src/components/examples/PopconfirmExample.vue +149 -149
  135. package/src/components/icons/IconCommunity.vue +7 -7
  136. package/src/components/icons/IconDocumentation.vue +7 -7
  137. package/src/components/icons/IconEcosystem.vue +7 -7
  138. package/src/components/icons/IconSupport.vue +7 -7
  139. package/src/components/icons/IconTooling.vue +19 -19
  140. package/src/components/mItems/UserInfo.vue +349 -349
  141. package/src/components/senior/EbizApprovalList/ApprovalList.vue +127 -127
  142. package/src/components/senior/EbizSData/index.vue +280 -280
  143. package/src/components/senior/EbizSDialog/index.vue +776 -776
  144. package/src/components/senior/EbizSForm/README.md +157 -157
  145. package/src/components/senior/EbizSForm/index.vue +667 -667
  146. package/src/components/senior/EbizSForm/item.vue +1011 -1011
  147. package/src/components/senior/EbizSForm/mItems/DateTimePicker.vue +51 -51
  148. package/src/components/senior/EbizSForm/mItems/Picker.vue +63 -63
  149. package/src/index.js +330 -327
  150. package/src/main.js +55 -55
  151. package/src/router/index.js +436 -436
  152. package/src/utils/formatCode.js +24 -24
  153. package/src/utils/generateImportStatement.js +52 -52
  154. package/src/utils/hasJsx.js +25 -25
  155. package/src/utils/index.js +166 -166
  156. package/src/utils/mergeOptions.js +29 -29
  157. package/src/utils/parseRequiredBlocks.js +18 -18
  158. package/src/utils/vue-sfc-validator.js +155 -155
  159. package/src/views/Button.vue +23 -23
  160. package/src/views/CheckboxDemo.vue +104 -104
  161. package/src/views/DataContainer.vue +19 -19
  162. package/src/views/DialogDemo.vue +125 -125
  163. package/src/views/EbizApprovalDemo.vue +87 -87
  164. package/src/views/EbizApprovalFormDemo.vue +207 -207
  165. package/src/views/EbizAutoFormDemo.vue +129 -129
  166. package/src/views/EbizAvatar.vue +223 -223
  167. package/src/views/EbizDepartmentSelectorDemo.vue +169 -169
  168. package/src/views/EbizDetailBlockDemo.vue +30 -30
  169. package/src/views/EbizDetailViewDemo.vue +412 -412
  170. package/src/views/EbizDormDashboardDemo.vue +87 -87
  171. package/src/views/EbizEmployeeInfo.vue +249 -249
  172. package/src/views/EbizEmployeeSelector.vue +85 -85
  173. package/src/views/EbizFileListDemo.vue +339 -339
  174. package/src/views/EbizMap.vue +201 -201
  175. package/src/views/EbizMeetingRoomSelectorDemo.vue +293 -293
  176. package/src/views/EbizMobileMeetingRoomSelectorDemo.vue +566 -566
  177. package/src/views/EbizParkingDashboardDemo.vue +28 -28
  178. package/src/views/EbizRadioDemo.vue +151 -151
  179. package/src/views/EbizSDataDemo.vue +136 -136
  180. package/src/views/EbizSDialogDemo.vue +303 -303
  181. package/src/views/EbizSForm/index.vue +352 -352
  182. package/src/views/EbizSFormDemo.vue +420 -420
  183. package/src/views/EbizSpace.vue +185 -185
  184. package/src/views/EbizSwiper.vue +157 -157
  185. package/src/views/EbizTdesignButtonDialogExample.vue +437 -437
  186. package/src/views/Form.vue +19 -19
  187. package/src/views/GridDemo.vue +238 -238
  188. package/src/views/Home.vue +156 -156
  189. package/src/views/LaunchInterviewDemo.vue +111 -111
  190. package/src/views/Mindmap.vue +17 -17
  191. package/src/views/MyComponent.vue +19 -19
  192. package/src/views/OkrTree.vue +19 -19
  193. package/src/views/PageHeaderDemo.vue +104 -104
  194. package/src/views/PaginationDemo.vue +96 -96
  195. package/src/views/PdfViewerDemo.vue +433 -433
  196. package/src/views/PermissionBoxDemo.vue +85 -85
  197. package/src/views/PopconfirmDemo.vue +80 -80
  198. package/src/views/RemoteSelect.vue +350 -350
  199. package/src/views/StatisticDemo.vue +190 -190
  200. package/src/views/SwitchDemo.vue +79 -79
  201. package/src/views/Table.vue +19 -19
  202. package/src/views/TableDemo.vue +334 -334
  203. package/src/views/TableSortDemo.vue +143 -143
  204. package/src/views/TableView.vue +68 -68
  205. package/src/views/TabsDemo.vue +282 -282
  206. package/src/views/TagDemo.vue +101 -101
  207. package/src/views/TdesignAlert.vue +98 -98
  208. package/src/views/TdesignButton.vue +190 -190
  209. package/src/views/TdesignCalendar.vue +94 -94
  210. package/src/views/TdesignCard.vue +296 -296
  211. package/src/views/TdesignCollapse.vue +293 -293
  212. package/src/views/TdesignDatePicker.vue +187 -187
  213. package/src/views/TdesignDescriptions.vue +101 -101
  214. package/src/views/TdesignForm.vue +248 -248
  215. package/src/views/TdesignIcon.vue +203 -203
  216. package/src/views/TdesignImage.vue +215 -215
  217. package/src/views/TdesignImageViewer.vue +198 -198
  218. package/src/views/TdesignInput.vue +252 -252
  219. package/src/views/TdesignSelect.vue +473 -473
  220. package/src/views/TdesignSwiper.vue +157 -157
  221. package/src/views/TextareaDemo.vue +93 -93
  222. package/src/views/TimePickerDemo.vue +146 -146
  223. package/src/views/TimelineDemo.vue +160 -160
  224. package/src/views/Title.vue +19 -19
  225. package/src/views/TreeDemo.vue +254 -254
  226. package/src/views/TreeMergeTableDemo.vue +239 -239
  227. package/src/views/TreeSelectorDemo.vue +245 -245
  228. package/src/views/UploadDemo.vue +128 -128
  229. package/src/views/VideoDemo.vue +245 -245
  230. package/src/views/VxeTableDemo.vue +279 -279
  231. package/src/views/WatermarkDemo.vue +85 -85
@@ -1,155 +1,155 @@
1
- /**
2
- * Copyright (c) 2023 - present TinyEngine Authors.
3
- * Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd.
4
- *
5
- * Use of this source code is governed by an MIT-style license.
6
- *
7
- * THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL,
8
- * BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR
9
- * A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS.
10
- *
11
- */
12
-
13
- import { parse as parseSFC, compileScript, compileStyle, compileTemplate } from '@vue/compiler-sfc'
14
- import { generateCodeFrame } from '@vue/shared'
15
- import { randomString } from '.'
16
-
17
- /**
18
- * 使用 vue-eslint-parser,校验 vue sfc 是否有效
19
- * @param {string} code 源码
20
- * @returns {Error[]} 校验出的报错信息
21
- */
22
- export function validateByParse(code) {
23
- const { parse: parseVue } = require('vue-eslint-parser')
24
- let errors = []
25
-
26
- try {
27
- const { templateBody, errors: parseErrors } = parseVue(code, {
28
- ecmaVersion: 'latest',
29
- sourceType: 'module',
30
- ecmaFeatures: {
31
- jsx: true
32
- }
33
- })
34
- errors = templateBody?.errors || parseErrors || []
35
- } catch (error) {
36
- // 此处可捕获到 SyntaxError,如:嵌套双引号未转义的问题
37
- errors.push(unify(error))
38
- }
39
-
40
- return errors.map(({ message, lineNumber: line, column }) => {
41
- if (line && column) {
42
- return locateErrorMessage(code, { message, loc: { start: { line, column } } })
43
- }
44
-
45
- return { message }
46
- })
47
- }
48
-
49
- /**
50
- * 使用 @vue/compiler-sfc, 校验 vue sfc 是否有效
51
- * @param {string} filename 文件名称
52
- * @param {string} code 源码
53
- * @returns {Error[]} 校验出的错误信息
54
- */
55
- export function validateByCompile(filename, code) {
56
- // validate via parse
57
- const { errors, descriptor } = parseSFC(code, {
58
- filename,
59
- sourceMap: false
60
- })
61
-
62
- if (errors.length) {
63
- return errors.map((error) => locateErrorMessage(code, error))
64
- }
65
-
66
- const id = randomString()
67
-
68
- // validate via compile script
69
- let bindingMetadata
70
- try {
71
- const scriptResult = compileScript(descriptor, { id })
72
- bindingMetadata = scriptResult.bindings
73
- } catch (error) {
74
- // error 可能的类型 string | ParseError (@babel/parser) | CompilerError (compileScript 使用 inlineTemplate 模式时)
75
- const scriptError = unify(error)
76
-
77
- // 如果是 ParseError 类型,转换为 locateErrorMessage 可接受的 CompilerError 类型传入
78
- if (!scriptError?.loc?.start && scriptError?.loc?.line) {
79
- // 只截取原 message 的第一行,后面行数可能已经包含错误的定位信息,避免拼接重复
80
- const message = scriptError.message.match(/.*/)[0]
81
- const { line, column } = scriptError.loc
82
-
83
- // compileScript 内部抛错误时,可能已定位编译报错信息,但报错所在的行可能有大量字符,此处精简一下
84
- return [locateErrorMessage(code, { message, loc: { start: { line, column } } })]
85
- }
86
-
87
- return [{ message: scriptError.message }]
88
- }
89
-
90
- // validate via compile template
91
- const { styles, template, slotted } = descriptor
92
- const scoped = styles.some((s) => s.scoped)
93
-
94
- const templateResult = compileTemplate({
95
- source: template.content,
96
- filename,
97
- id,
98
- scoped,
99
- slotted,
100
- compilerOptions: { bindingMetadata }
101
- })
102
-
103
- if (templateResult.errors.length) {
104
- return templateResult.errors.map(unify).map((error) => locateErrorMessage(code, error))
105
- }
106
-
107
- // validate via compile style
108
- // 目前暂时没有预处理器,如:less
109
- const stylesResult = styles.map(({ content, module }) =>
110
- compileStyle({ source: content, filename, id, scoped, modules: Boolean(module) })
111
- )
112
- const errorsInStyles = stylesResult
113
- .filter(({ errors }) => errors.length)
114
- .map(({ errors }) => errors)
115
- .flat()
116
-
117
- return errorsInStyles
118
- }
119
-
120
- /**
121
- * 统一报错的格式
122
- * @param {(string | Error)} error 原始错误信息
123
- * @returns {Error} 统一格式后的错误信息
124
- */
125
- function unify(error) {
126
- if (typeof error === 'string') {
127
- return { message: error }
128
- }
129
-
130
- return error
131
- }
132
-
133
- /**
134
- * 定位报错信息,如果包含报错位置,则追加到 message 中输出
135
- * @param {string} originalSource 原始代码
136
- * @param {(Error | CompilerError)} error 错误信息
137
- * @returns {{message: string}} 可能包含报错位置的错误信息
138
- */
139
- function locateErrorMessage(originalSource, error) {
140
- let { loc, message } = error
141
-
142
- if (loc?.start) {
143
- const { line, column } = loc.start
144
- const errorLineCode = originalSource.split(/\r?\n/)[line - 1]
145
-
146
- // 源码字符串未经格式化,报错所在的行可能有大量字符,截取报错位置附近范围的错误信息,比如:前后 50 字符内
147
- const SCOPE = 50
148
- const scopeStartIndex = Math.max(0, column - SCOPE)
149
- const scopeCode = errorLineCode.slice(scopeStartIndex, column + SCOPE)
150
-
151
- message = `${message} \n ${generateCodeFrame(scopeCode, column - scopeStartIndex)}`
152
- }
153
-
154
- return { message }
155
- }
1
+ /**
2
+ * Copyright (c) 2023 - present TinyEngine Authors.
3
+ * Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd.
4
+ *
5
+ * Use of this source code is governed by an MIT-style license.
6
+ *
7
+ * THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL,
8
+ * BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR
9
+ * A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS.
10
+ *
11
+ */
12
+
13
+ import { parse as parseSFC, compileScript, compileStyle, compileTemplate } from '@vue/compiler-sfc'
14
+ import { generateCodeFrame } from '@vue/shared'
15
+ import { randomString } from '.'
16
+
17
+ /**
18
+ * 使用 vue-eslint-parser,校验 vue sfc 是否有效
19
+ * @param {string} code 源码
20
+ * @returns {Error[]} 校验出的报错信息
21
+ */
22
+ export function validateByParse(code) {
23
+ const { parse: parseVue } = require('vue-eslint-parser')
24
+ let errors = []
25
+
26
+ try {
27
+ const { templateBody, errors: parseErrors } = parseVue(code, {
28
+ ecmaVersion: 'latest',
29
+ sourceType: 'module',
30
+ ecmaFeatures: {
31
+ jsx: true
32
+ }
33
+ })
34
+ errors = templateBody?.errors || parseErrors || []
35
+ } catch (error) {
36
+ // 此处可捕获到 SyntaxError,如:嵌套双引号未转义的问题
37
+ errors.push(unify(error))
38
+ }
39
+
40
+ return errors.map(({ message, lineNumber: line, column }) => {
41
+ if (line && column) {
42
+ return locateErrorMessage(code, { message, loc: { start: { line, column } } })
43
+ }
44
+
45
+ return { message }
46
+ })
47
+ }
48
+
49
+ /**
50
+ * 使用 @vue/compiler-sfc, 校验 vue sfc 是否有效
51
+ * @param {string} filename 文件名称
52
+ * @param {string} code 源码
53
+ * @returns {Error[]} 校验出的错误信息
54
+ */
55
+ export function validateByCompile(filename, code) {
56
+ // validate via parse
57
+ const { errors, descriptor } = parseSFC(code, {
58
+ filename,
59
+ sourceMap: false
60
+ })
61
+
62
+ if (errors.length) {
63
+ return errors.map((error) => locateErrorMessage(code, error))
64
+ }
65
+
66
+ const id = randomString()
67
+
68
+ // validate via compile script
69
+ let bindingMetadata
70
+ try {
71
+ const scriptResult = compileScript(descriptor, { id })
72
+ bindingMetadata = scriptResult.bindings
73
+ } catch (error) {
74
+ // error 可能的类型 string | ParseError (@babel/parser) | CompilerError (compileScript 使用 inlineTemplate 模式时)
75
+ const scriptError = unify(error)
76
+
77
+ // 如果是 ParseError 类型,转换为 locateErrorMessage 可接受的 CompilerError 类型传入
78
+ if (!scriptError?.loc?.start && scriptError?.loc?.line) {
79
+ // 只截取原 message 的第一行,后面行数可能已经包含错误的定位信息,避免拼接重复
80
+ const message = scriptError.message.match(/.*/)[0]
81
+ const { line, column } = scriptError.loc
82
+
83
+ // compileScript 内部抛错误时,可能已定位编译报错信息,但报错所在的行可能有大量字符,此处精简一下
84
+ return [locateErrorMessage(code, { message, loc: { start: { line, column } } })]
85
+ }
86
+
87
+ return [{ message: scriptError.message }]
88
+ }
89
+
90
+ // validate via compile template
91
+ const { styles, template, slotted } = descriptor
92
+ const scoped = styles.some((s) => s.scoped)
93
+
94
+ const templateResult = compileTemplate({
95
+ source: template.content,
96
+ filename,
97
+ id,
98
+ scoped,
99
+ slotted,
100
+ compilerOptions: { bindingMetadata }
101
+ })
102
+
103
+ if (templateResult.errors.length) {
104
+ return templateResult.errors.map(unify).map((error) => locateErrorMessage(code, error))
105
+ }
106
+
107
+ // validate via compile style
108
+ // 目前暂时没有预处理器,如:less
109
+ const stylesResult = styles.map(({ content, module }) =>
110
+ compileStyle({ source: content, filename, id, scoped, modules: Boolean(module) })
111
+ )
112
+ const errorsInStyles = stylesResult
113
+ .filter(({ errors }) => errors.length)
114
+ .map(({ errors }) => errors)
115
+ .flat()
116
+
117
+ return errorsInStyles
118
+ }
119
+
120
+ /**
121
+ * 统一报错的格式
122
+ * @param {(string | Error)} error 原始错误信息
123
+ * @returns {Error} 统一格式后的错误信息
124
+ */
125
+ function unify(error) {
126
+ if (typeof error === 'string') {
127
+ return { message: error }
128
+ }
129
+
130
+ return error
131
+ }
132
+
133
+ /**
134
+ * 定位报错信息,如果包含报错位置,则追加到 message 中输出
135
+ * @param {string} originalSource 原始代码
136
+ * @param {(Error | CompilerError)} error 错误信息
137
+ * @returns {{message: string}} 可能包含报错位置的错误信息
138
+ */
139
+ function locateErrorMessage(originalSource, error) {
140
+ let { loc, message } = error
141
+
142
+ if (loc?.start) {
143
+ const { line, column } = loc.start
144
+ const errorLineCode = originalSource.split(/\r?\n/)[line - 1]
145
+
146
+ // 源码字符串未经格式化,报错所在的行可能有大量字符,截取报错位置附近范围的错误信息,比如:前后 50 字符内
147
+ const SCOPE = 50
148
+ const scopeStartIndex = Math.max(0, column - SCOPE)
149
+ const scopeCode = errorLineCode.slice(scopeStartIndex, column + SCOPE)
150
+
151
+ message = `${message} \n ${generateCodeFrame(scopeCode, column - scopeStartIndex)}`
152
+ }
153
+
154
+ return { message }
155
+ }
@@ -1,24 +1,24 @@
1
- <template>
2
- <div>
3
- <ebiz-route-breadcrumb />
4
- <ebiz-button :text="测试" :apiConfig="{ apiId: 802, apiType: 5 }" @prepare="onPrepare" />
5
- </div>
6
- </template>
7
-
8
- <script>
9
- import { EbizButton } from '@/index.js'
10
-
11
- export default {
12
- name: 'ButtonDemo',
13
- components: {
14
- EbizButton
15
- },
16
- methods: {
17
- onPrepare() {
18
-
19
- }
20
- }
21
- }
22
- </script>
23
-
1
+ <template>
2
+ <div>
3
+ <ebiz-route-breadcrumb />
4
+ <ebiz-button :text="测试" :apiConfig="{ apiId: 802, apiType: 5 }" @prepare="onPrepare" />
5
+ </div>
6
+ </template>
7
+
8
+ <script>
9
+ import { EbizButton } from '@/index.js'
10
+
11
+ export default {
12
+ name: 'ButtonDemo',
13
+ components: {
14
+ EbizButton
15
+ },
16
+ methods: {
17
+ onPrepare() {
18
+
19
+ }
20
+ }
21
+ }
22
+ </script>
23
+
24
24
  <style scoped></style>
@@ -1,105 +1,105 @@
1
- <template>
2
- <div class="checkbox-demo">
3
- <h2>多选框组件示例</h2>
4
-
5
- <h3>基础多选框</h3>
6
- <div class="demo-section">
7
- <EbizCheckbox>未选中项</EbizCheckbox>
8
- <EbizCheckbox v-model="checkbox1">选中项</EbizCheckbox>
9
- <EbizCheckbox :disabled="true">未选禁用项</EbizCheckbox>
10
- <EbizCheckbox v-model="checkboxDisabled" :disabled="true">选中禁用项</EbizCheckbox>
11
- </div>
12
-
13
- <h3>半选状态</h3>
14
- <div class="demo-section">
15
- <EbizCheckbox :indeterminate="true">半选状态</EbizCheckbox>
16
- </div>
17
-
18
- <h3>多选框组</h3>
19
- <div class="demo-section">
20
- <p>选中值:{{ groupValue }}</p>
21
- <EbizCheckboxGroup v-model="groupValue" :options="options" @change="onGroupChange" />
22
- </div>
23
-
24
- <h3>全选功能</h3>
25
- <div class="demo-section">
26
- <p>选中值:{{ allCheckValue }}</p>
27
- <EbizCheckboxGroup v-model="allCheckValue">
28
- <EbizCheckbox :check-all="true" @change="onCheckAllChange">全选</EbizCheckbox>
29
- <EbizCheckbox value="1">选项一</EbizCheckbox>
30
- <EbizCheckbox value="2">选项二</EbizCheckbox>
31
- <EbizCheckbox value="3">选项三</EbizCheckbox>
32
- </EbizCheckboxGroup>
33
- </div>
34
- </div>
35
- </template>
36
-
37
- <script>
38
- export default {
39
- name: "CheckboxDemo"
40
- }
41
- </script>
42
-
43
- <script setup>
44
- import { ref } from 'vue';
45
- import { EbizCheckbox, EbizCheckboxGroup } from '../index.js';
46
-
47
- // 单个多选框状态
48
- const checkbox1 = ref(true);
49
- const checkboxDisabled = ref(true);
50
-
51
- // 多选框组的值
52
- const groupValue = ref(['option1']);
53
-
54
- // 多选框组的配置选项
55
- const options = [
56
- { label: '选项一', value: 'option1' },
57
- { label: '选项二', value: 'option2' },
58
- { label: '选项三', value: 'option3', disabled: true }
59
- ];
60
-
61
- // 多选框组的值变化事件
62
- const onGroupChange = (value, context) => {
63
- console.log('选中值变化:', value);
64
- console.log('上下文信息:', context);
65
- };
66
-
67
- // 全选功能的值
68
- const allCheckValue = ref(['1']);
69
-
70
- // 全选状态变化事件
71
- const onCheckAllChange = (checked) => {
72
- if (checked) {
73
- allCheckValue.value = ['1', '2', '3'];
74
- } else {
75
- allCheckValue.value = [];
76
- }
77
- };
78
- </script>
79
-
80
- <style lang="less" scoped>
81
- .checkbox-demo {
82
- padding: 20px;
83
-
84
- h2 {
85
- margin-bottom: 20px;
86
- font-size: 24px;
87
- }
88
-
89
- h3 {
90
- margin: 20px 0 10px;
91
- font-size: 18px;
92
- }
93
-
94
- .demo-section {
95
- padding: 16px;
96
- margin-bottom: 16px;
97
- border: 1px solid #eee;
98
- border-radius: 4px;
99
-
100
- .t-checkbox {
101
- margin-right: 16px;
102
- }
103
- }
104
- }
1
+ <template>
2
+ <div class="checkbox-demo">
3
+ <h2>多选框组件示例</h2>
4
+
5
+ <h3>基础多选框</h3>
6
+ <div class="demo-section">
7
+ <EbizCheckbox>未选中项</EbizCheckbox>
8
+ <EbizCheckbox v-model="checkbox1">选中项</EbizCheckbox>
9
+ <EbizCheckbox :disabled="true">未选禁用项</EbizCheckbox>
10
+ <EbizCheckbox v-model="checkboxDisabled" :disabled="true">选中禁用项</EbizCheckbox>
11
+ </div>
12
+
13
+ <h3>半选状态</h3>
14
+ <div class="demo-section">
15
+ <EbizCheckbox :indeterminate="true">半选状态</EbizCheckbox>
16
+ </div>
17
+
18
+ <h3>多选框组</h3>
19
+ <div class="demo-section">
20
+ <p>选中值:{{ groupValue }}</p>
21
+ <EbizCheckboxGroup v-model="groupValue" :options="options" @change="onGroupChange" />
22
+ </div>
23
+
24
+ <h3>全选功能</h3>
25
+ <div class="demo-section">
26
+ <p>选中值:{{ allCheckValue }}</p>
27
+ <EbizCheckboxGroup v-model="allCheckValue">
28
+ <EbizCheckbox :check-all="true" @change="onCheckAllChange">全选</EbizCheckbox>
29
+ <EbizCheckbox value="1">选项一</EbizCheckbox>
30
+ <EbizCheckbox value="2">选项二</EbizCheckbox>
31
+ <EbizCheckbox value="3">选项三</EbizCheckbox>
32
+ </EbizCheckboxGroup>
33
+ </div>
34
+ </div>
35
+ </template>
36
+
37
+ <script>
38
+ export default {
39
+ name: "CheckboxDemo"
40
+ }
41
+ </script>
42
+
43
+ <script setup>
44
+ import { ref } from 'vue';
45
+ import { EbizCheckbox, EbizCheckboxGroup } from '../index.js';
46
+
47
+ // 单个多选框状态
48
+ const checkbox1 = ref(true);
49
+ const checkboxDisabled = ref(true);
50
+
51
+ // 多选框组的值
52
+ const groupValue = ref(['option1']);
53
+
54
+ // 多选框组的配置选项
55
+ const options = [
56
+ { label: '选项一', value: 'option1' },
57
+ { label: '选项二', value: 'option2' },
58
+ { label: '选项三', value: 'option3', disabled: true }
59
+ ];
60
+
61
+ // 多选框组的值变化事件
62
+ const onGroupChange = (value, context) => {
63
+ console.log('选中值变化:', value);
64
+ console.log('上下文信息:', context);
65
+ };
66
+
67
+ // 全选功能的值
68
+ const allCheckValue = ref(['1']);
69
+
70
+ // 全选状态变化事件
71
+ const onCheckAllChange = (checked) => {
72
+ if (checked) {
73
+ allCheckValue.value = ['1', '2', '3'];
74
+ } else {
75
+ allCheckValue.value = [];
76
+ }
77
+ };
78
+ </script>
79
+
80
+ <style lang="less" scoped>
81
+ .checkbox-demo {
82
+ padding: 20px;
83
+
84
+ h2 {
85
+ margin-bottom: 20px;
86
+ font-size: 24px;
87
+ }
88
+
89
+ h3 {
90
+ margin: 20px 0 10px;
91
+ font-size: 18px;
92
+ }
93
+
94
+ .demo-section {
95
+ padding: 16px;
96
+ margin-bottom: 16px;
97
+ border: 1px solid #eee;
98
+ border-radius: 4px;
99
+
100
+ .t-checkbox {
101
+ margin-right: 16px;
102
+ }
103
+ }
104
+ }
105
105
  </style>
@@ -1,20 +1,20 @@
1
- <template>
2
- <div>
3
- <ebiz-route-breadcrumb />
4
- <ebiz-data-container />
5
- </div>
6
- </template>
7
-
8
- <script>
9
- import { EbizDataContainer } from '@/index.js'
10
-
11
- export default {
12
- name: 'DataContainerDemo',
13
- components: {
14
- EbizDataContainer
15
- }
16
- }
17
- </script>
18
-
19
- <style scoped>
1
+ <template>
2
+ <div>
3
+ <ebiz-route-breadcrumb />
4
+ <ebiz-data-container />
5
+ </div>
6
+ </template>
7
+
8
+ <script>
9
+ import { EbizDataContainer } from '@/index.js'
10
+
11
+ export default {
12
+ name: 'DataContainerDemo',
13
+ components: {
14
+ EbizDataContainer
15
+ }
16
+ }
17
+ </script>
18
+
19
+ <style scoped>
20
20
  </style>