lcap-frontend-library 0.0.1

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 (84) hide show
  1. package/README.md +271 -0
  2. package/bin/lcap-frontend-library.mjs +3 -0
  3. package/dist/index.d.ts +1 -0
  4. package/dist/index.js +27 -0
  5. package/dist/init.d.ts +6 -0
  6. package/dist/init.js +79 -0
  7. package/dist/sync.d.ts +4 -0
  8. package/dist/sync.js +70 -0
  9. package/dist/utils.d.ts +19 -0
  10. package/dist/utils.js +101 -0
  11. package/package.json +34 -0
  12. package/packages/lcap-frontend-library/LEARNINGS.md +11 -0
  13. package/packages/lcap-frontend-library/SKILL.md +86 -0
  14. package/packages/lcap-frontend-library/commands/migrate.check.md +287 -0
  15. package/packages/lcap-frontend-library/commands/migrate.green.md +190 -0
  16. package/packages/lcap-frontend-library/commands/migrate.plan.md +169 -0
  17. package/packages/lcap-frontend-library/commands/migrate.red.md +160 -0
  18. package/packages/lcap-frontend-library/commands/migrate.scan.md +151 -0
  19. package/packages/lcap-frontend-library/commands/migrate.spec.md +144 -0
  20. package/packages/lcap-frontend-library/commands/migrate.tasks.md +179 -0
  21. package/packages/lcap-frontend-library/commands/speckit.create.md +201 -0
  22. package/packages/lcap-frontend-library/commands/speckit.implement.md +88 -0
  23. package/packages/lcap-frontend-library/commands/speckit.plan.md +79 -0
  24. package/packages/lcap-frontend-library/commands/speckit.self-check.md +177 -0
  25. package/packages/lcap-frontend-library/commands/speckit.specify.md +91 -0
  26. package/packages/lcap-frontend-library/commands/speckit.tasks.md +61 -0
  27. package/packages/lcap-frontend-library/references/frontend-design/LICENSE.txt +177 -0
  28. package/packages/lcap-frontend-library/references/frontend-design/SKILL.md +42 -0
  29. package/packages/lcap-frontend-library/references/lcap-extension-component/SKILL.md +360 -0
  30. package/packages/lcap-frontend-library/references/lcap-extension-component/api.md +331 -0
  31. package/packages/lcap-frontend-library/references/lcap-extension-component/block.md +160 -0
  32. package/packages/lcap-frontend-library/references/lcap-extension-component/i18n.md +95 -0
  33. package/packages/lcap-frontend-library/references/lcap-extension-component/icon.md +27 -0
  34. package/packages/lcap-frontend-library/references/lcap-extension-component/ide/container.md +728 -0
  35. package/packages/lcap-frontend-library/references/lcap-extension-component/ide/element.md +312 -0
  36. package/packages/lcap-frontend-library/references/lcap-extension-component/ide/expression.md +154 -0
  37. package/packages/lcap-frontend-library/references/lcap-extension-component/ide/index.md +113 -0
  38. package/packages/lcap-frontend-library/references/lcap-extension-component/ide/modal.md +189 -0
  39. package/packages/lcap-frontend-library/references/lcap-extension-component/ide/popover.md +171 -0
  40. package/packages/lcap-frontend-library/references/lcap-extension-component/ide.md +799 -0
  41. package/packages/lcap-frontend-library/references/lcap-extension-component/implementation-rules.md +242 -0
  42. package/packages/lcap-frontend-library/references/lcap-extension-component/index.md +27 -0
  43. package/packages/lcap-frontend-library/references/lcap-extension-component/nasl-view-component.md +895 -0
  44. package/packages/lcap-frontend-library/references/lcap-extension-component/platform/accessibility.md +185 -0
  45. package/packages/lcap-frontend-library/references/lcap-extension-component/platform/child.md +82 -0
  46. package/packages/lcap-frontend-library/references/lcap-extension-component/platform/data-source.md +261 -0
  47. package/packages/lcap-frontend-library/references/lcap-extension-component/platform/event.md +171 -0
  48. package/packages/lcap-frontend-library/references/lcap-extension-component/platform/form.md +266 -0
  49. package/packages/lcap-frontend-library/references/lcap-extension-component/platform/function.md +80 -0
  50. package/packages/lcap-frontend-library/references/lcap-extension-component/platform/link.md +137 -0
  51. package/packages/lcap-frontend-library/references/lcap-extension-component/platform/slot.md +128 -0
  52. package/packages/lcap-frontend-library/references/lcap-extension-component/platform/theme-variables-ant-design.md +1470 -0
  53. package/packages/lcap-frontend-library/references/lcap-extension-component/platform/theme-variables-cloud-ui.md +259 -0
  54. package/packages/lcap-frontend-library/references/lcap-extension-component/platform/theme-variables-element-plus.md +580 -0
  55. package/packages/lcap-frontend-library/references/lcap-extension-component/platform/theme-variables-element-ui.md +1007 -0
  56. package/packages/lcap-frontend-library/references/lcap-extension-component/platform/theme-variables-mobile-ui.md +85 -0
  57. package/packages/lcap-frontend-library/references/lcap-extension-component/theme.md +234 -0
  58. package/packages/lcap-frontend-library/references/lcap-extension-component/workflow-guardrails.md +328 -0
  59. package/packages/lcap-frontend-library/references/nasl-logic-authoring/SKILL.md +201 -0
  60. package/packages/lcap-frontend-library/scripts/bash/create-component-files.sh +95 -0
  61. package/packages/lcap-frontend-library/scripts/bash/create-extension-project.sh +109 -0
  62. package/packages/lcap-frontend-library/scripts/bash/create-logic-files.sh +149 -0
  63. package/packages/lcap-frontend-library/scripts/bash/create-spec.sh +109 -0
  64. package/packages/lcap-frontend-library/scripts/bash/get-available-port.sh +35 -0
  65. package/packages/lcap-frontend-library/scripts/bash/list-specs.sh +19 -0
  66. package/packages/lcap-frontend-library/scripts/node/setup-extension-project.mjs +166 -0
  67. package/packages/lcap-frontend-library/templates/component-self-check.md +31 -0
  68. package/packages/lcap-frontend-library/templates/component-template.md +96 -0
  69. package/packages/lcap-frontend-library/templates/library-report-template.md +52 -0
  70. package/packages/lcap-frontend-library/templates/logic-template.md +44 -0
  71. package/packages/lcap-frontend-library/templates/migration-manifest-template.md +84 -0
  72. package/packages/lcap-frontend-library/templates/migration-plan-template.md +138 -0
  73. package/packages/lcap-frontend-library/templates/migration-report-template.md +227 -0
  74. package/packages/lcap-frontend-library/templates/migration-spec-template.md +135 -0
  75. package/packages/lcap-frontend-library/templates/migration-tasks-template.md +129 -0
  76. package/packages/lcap-frontend-library/templates/plan-template.md +299 -0
  77. package/packages/lcap-frontend-library/templates/self-check-report-template.md +148 -0
  78. package/packages/lcap-frontend-library/templates/tasks-template.md +81 -0
  79. package/packages/lcap-frontend-library/workflows/create/flow.md +199 -0
  80. package/packages/lcap-frontend-library/workflows/evolve/flow.md +249 -0
  81. package/packages/lcap-frontend-library/workflows/generate/flow.md +10 -0
  82. package/packages/lcap-frontend-library/workflows/harness/flow.md +82 -0
  83. package/packages/lcap-frontend-library/workflows/migrate/flow.md +302 -0
  84. package/packages/lcap-frontend-library/workflows/migrate/knowledge-base.md +564 -0
@@ -0,0 +1,1007 @@
1
+ # 使用 Element UI 全局主题变量
2
+
3
+ ## 复制变量文件
4
+
5
+ 创建文件 `.storybook/vars.css`, 内容如下:
6
+
7
+ ```css
8
+ :root {
9
+ /**
10
+ * @title 品牌色
11
+ * @type color
12
+ */
13
+ --el-color-primary-6: #409eff;
14
+
15
+ /**
16
+ * @title 品牌色浅色/白色悬浮
17
+ * @type color
18
+ */
19
+ --el-color-primary-1: #e8f7ff;
20
+
21
+ /**
22
+ * @title 品牌色文字禁用
23
+ * @type color
24
+ */
25
+ --el-color-primary-2: #c6eaff;
26
+
27
+ /**
28
+ * @title 品牌色一般禁用
29
+ * @type color
30
+ */
31
+ --el-color-primary-3: #a5dbff;
32
+
33
+ /**
34
+ * @title 品牌色特殊场景
35
+ * @type color
36
+ */
37
+ --el-color-primary-4: #83c9ff;
38
+
39
+ /**
40
+ * @title 品牌色悬浮(hover)
41
+ * @type color
42
+ */
43
+ --el-color-primary-5: #62b6ff;
44
+
45
+ /**
46
+ * @title 品牌色点击(click)
47
+ * @type color
48
+ */
49
+ --el-color-primary-7: #2877d2;
50
+ --el-color-primary-8: #1554a6;
51
+ --el-color-primary-9: #083579;
52
+ --el-color-primary-10: #001c4d;
53
+
54
+ /**
55
+ * @title 成功色
56
+ * @type color
57
+ */
58
+ --el-color-success-6: #67c23a;
59
+ /**
60
+ * @title 成功色浅色/白底悬浮
61
+ * @type color
62
+ */
63
+ --el-color-success-1: #f4ffe8;
64
+ /**
65
+ * @title 成功色文字禁用
66
+ * @type color
67
+ */
68
+ --el-color-success-2: #d7f3bf;
69
+ /**
70
+ * @title 成功色一般禁用
71
+ * @type color
72
+ */
73
+ --el-color-success-3: #bbe799;
74
+ /**
75
+ * @title 成功色特殊场景
76
+ * @type color
77
+ */
78
+ --el-color-success-4: #9fda77;
79
+
80
+ /**
81
+ * @title 成功色悬浮(hover)
82
+ * @type color
83
+ */
84
+ --el-color-success-5: #83ce57;
85
+
86
+ /**
87
+ * @title 成功色点击(click)
88
+ * @type color
89
+ */
90
+ --el-color-success-7: #4ba525;
91
+ --el-color-success-8: #338714;
92
+ --el-color-success-9: #1f6a08;
93
+ --el-color-success-10: #0f4d00;
94
+
95
+ /**
96
+ * @title 警示色
97
+ * @type color
98
+ */
99
+ --el-color-warning-6: #e6a23c;
100
+ /**
101
+ * @title 警示色浅色/白底悬浮
102
+ * @type color
103
+ */
104
+ --el-color-warning-1: #fffae8;
105
+ /**
106
+ * @title 警示色文字禁用
107
+ * @type color
108
+ */
109
+ --el-color-warning-2: #faebc3;
110
+
111
+ /**
112
+ * @title 警示色一般禁用
113
+ * @type color
114
+ */
115
+ --el-color-warning-3: #f5db9f;
116
+ /**
117
+ * @title 警示色特殊场景
118
+ * @type color
119
+ */
120
+ --el-color-warning-4: #f0ca7d;
121
+ /**
122
+ * @title 警示色悬浮(hover)
123
+ * @type color
124
+ */
125
+ --el-color-warning-5: #ebb65c;
126
+ /**
127
+ * @title 警示色点击(click)
128
+ * @type color
129
+ */
130
+ --el-color-warning-7: #c07d25;
131
+ --el-color-warning-8: #995b14;
132
+ --el-color-warning-9: #733d07;
133
+ --el-color-warning-10: #4d2400;
134
+
135
+ /**
136
+ * @title 错误色
137
+ * @type color
138
+ */
139
+ --el-color-error-6: #f56c6c;
140
+ /**
141
+ * @title 错误色浅色/白底悬浮
142
+ * @type color
143
+ */
144
+ --el-color-error-1: #ffece8;
145
+ /**
146
+ * @title 错误色文字禁用
147
+ * @type color
148
+ */
149
+ --el-color-error-2: #fdd5ce;
150
+ /**
151
+ * @title 错误色一般禁用
152
+ * @type color
153
+ */
154
+ --el-color-error-3: #fbbcb5;
155
+ /**
156
+ * @title 错误色特殊场景
157
+ * @type color
158
+ */
159
+ --el-color-error-4: #f9a39c;
160
+ /**
161
+ * @title 错误色悬浮(hover)
162
+ * @type color
163
+ */
164
+ --el-color-error-5: #f78884;
165
+ /**
166
+ * @title 错误色点击(click)
167
+ * @type color
168
+ */
169
+ --el-color-error-7: #cb4348;
170
+ --el-color-error-8: #a1232c;
171
+ --el-color-error-9: #770d18;
172
+ --el-color-error-10: #4d000a;
173
+
174
+ /**
175
+ * @title 链接色
176
+ * @type color
177
+ */
178
+ --el-color-link-6: var(--el-color-primary-6);
179
+ /**
180
+ * @title 链接色浅色/白色悬浮
181
+ * @type color
182
+ */
183
+ --el-color-link-1: var(--el-color-primary-1);
184
+ /**
185
+ * @title 链接色文字禁用
186
+ * @type color
187
+ */
188
+ --el-color-link-2: var(--el-color-primary-2);
189
+ /**
190
+ * @title 链接色一般禁用
191
+ * @type color
192
+ */
193
+ --el-color-link-3: var(--el-color-primary-3);
194
+ /**
195
+ * @title 链接色特殊场景
196
+ * @type color
197
+ */
198
+ --el-color-link-4: var(--el-color-primary-4);
199
+ /**
200
+ * @title 链接色悬浮(hover)
201
+ * @type color
202
+ */
203
+ --el-color-link-5: var(--el-color-primary-5);
204
+ /**
205
+ * @title 链接色点击(click)
206
+ * @type color
207
+ */
208
+ --el-color-link-7: var(--el-color-primary-7);
209
+ --el-color-link-8: var(--el-color-primary-8);
210
+ --el-color-link-9: var(--el-color-primary-9);
211
+ --el-color-link-10: var(--el-color-primary-10);
212
+
213
+ /**
214
+ * @title 强调/正文标题
215
+ * @type color
216
+ */
217
+ --el-color-text-1: #303133;
218
+ /**
219
+ * @title 次强调/正文标题
220
+ * @type color
221
+ */
222
+ --el-color-text-2: #606266;
223
+ /**
224
+ * @title 次要信息
225
+ * @type color
226
+ */
227
+ --el-color-text-3: #909399;
228
+ /**
229
+ * @title 置灰信息
230
+ * @type color
231
+ */
232
+ --el-color-text-4: #c0c4cc;
233
+
234
+ /**
235
+ * @title 边框线-浅色
236
+ * @type color
237
+ */
238
+ --el-color-line-1: #F2F6FC;
239
+ /**
240
+ * @title 边框线-一般
241
+ * @type color
242
+ */
243
+ --el-color-line-2: #EBEEF5;
244
+ /**
245
+ * @title 边框线-深色
246
+ * @type color
247
+ */
248
+ --el-color-line-3: #E4E7ED;
249
+ /**
250
+ * @title 边框线-重色
251
+ * @type color
252
+ */
253
+ --el-color-line-4: #dcdfe6;
254
+
255
+ /**
256
+ * @title 导航背景
257
+ * @type color
258
+ */
259
+ --el-color-background-1: #333;
260
+ /**
261
+ * @title 工具提示填充色
262
+ * @type color
263
+ */
264
+ --el-color-background-2: #242424;
265
+ /**
266
+ * @title 弹窗/抽屉遮挡填充色
267
+ * @type color
268
+ */
269
+ --el-color-background-3: rgba(0, 0, 0, 0.6);
270
+ /**
271
+ * @title 标签、薯条等组件填充色
272
+ * @type color
273
+ */
274
+ --el-color-background-4: #909399;
275
+ /**
276
+ * @title 通用背景色/禁用背景色/hover色
277
+ * @type color
278
+ */
279
+ --el-color-background-5: #f5f7fa;
280
+ /**
281
+ * @title 页面背景色/表头色
282
+ * @type color
283
+ */
284
+ --el-color-background-6: #f5f7fa;
285
+ /**
286
+ * @title 表格展开背景色
287
+ * @type color
288
+ */
289
+ --el-color-background-7: #f5f5f5;
290
+ /**
291
+ * @title 白色填充
292
+ * @type color
293
+ */
294
+ --el-color-background-white: #fff;
295
+ /**
296
+ * @title 透明背景
297
+ * @type color
298
+ */
299
+ --el-color-background-transparent: transparent;
300
+
301
+ /**
302
+ * @title 辅助文案
303
+ * @type size
304
+ */
305
+ --el-font-size-1: 12px;
306
+ /**
307
+ * @title 辅助文案行高
308
+ * @type input
309
+ */
310
+ --el-line-height-1: 1.67;
311
+ /**
312
+ * @title 正文-常规
313
+ * @type size
314
+ */
315
+ --el-font-size-2: 14px;
316
+ /**
317
+ * @title 正文行高
318
+ * @type input
319
+ */
320
+ --el-line-height-2: 1.57;
321
+ /**
322
+ * @title 标题-小
323
+ * @type size
324
+ */
325
+ --el-font-size-3: 16px;
326
+ /**
327
+ * @title 小标题行高
328
+ * @type input
329
+ */
330
+ --el-line-height-3: 1.5;
331
+ /**
332
+ * @title 标题-中
333
+ * @type size
334
+ */
335
+ --el-font-size-4: 18px;
336
+ /**
337
+ * @title 中标题行高
338
+ * @type input
339
+ */
340
+ --el-line-height-4: 1.44;
341
+ /**
342
+ * @title 标题-中
343
+ * @type size
344
+ */
345
+ --el-font-size-5: 20x;
346
+ /**
347
+ * @title 中标题行高
348
+ * @type input
349
+ */
350
+ --el-line-height-5: 1.4;
351
+ /**
352
+ * @title 标题-大
353
+ * @type size
354
+ */
355
+ --el-font-size-6: 24px;
356
+ /**
357
+ * @title 大标题行高
358
+ * @type input
359
+ */
360
+ --el-line-height-6: 1.33;
361
+ /**
362
+ * @title 运营标题-小
363
+ * @type size
364
+ */
365
+ --el-font-size-7: 36px;
366
+ /**
367
+ * @title 小运营标题行高
368
+ * @type input
369
+ */
370
+ --el-line-height-7: 1.22;
371
+ /**
372
+ * @title 运营标题-中
373
+ * @type size
374
+ */
375
+ --el-font-size-8: 48px;
376
+ /**
377
+ * @title 中运营标题行高
378
+ * @type input
379
+ */
380
+ --el-line-height-8: 1.17;
381
+ /**
382
+ * @title 运营标题-大
383
+ * @type size
384
+ */
385
+ --el-font-size-9: 56px;
386
+ /**
387
+ * @title 中运营标题行高
388
+ * @type input
389
+ */
390
+ --el-line-height-9: 1.14;
391
+
392
+ /**
393
+ * @title 尺寸部长
394
+ * @type size
395
+ */
396
+ --el-size-step: 4px;
397
+ /**
398
+ * @title 尺寸变化单位
399
+ * @type size
400
+ */
401
+ --el-size-unit: 4px;
402
+
403
+ --el-size-1: 2px;
404
+ --el-size-2: 4px;
405
+ --el-size-3: 6px;
406
+ --el-size-4: 8px;
407
+ --el-size-5: 12px;
408
+ --el-size-6: 16px;
409
+ --el-size-7: 20px;
410
+ --el-size-8: 24px;
411
+ --el-size-9: 28px;
412
+ --el-size-10: 32px;
413
+ --el-size-11: 36px;
414
+ --el-size-12: 40px;
415
+ --el-size-13: 48px;
416
+ --el-size-14: 56px;
417
+ --el-size-15: 64px;
418
+ --el-size-16: 72px;
419
+
420
+ /**
421
+ * @title 组件尺寸 XXXS
422
+ * @type size
423
+ */
424
+ --el-comp-size-xxxs: var(--el-size-6);
425
+ /**
426
+ * @title 组件尺寸 XXS
427
+ * @type size
428
+ */
429
+ --el-comp-size-xxs: var(--el-size-7);
430
+ /**
431
+ * @title 组件尺寸 XS
432
+ * @type size
433
+ */
434
+ --el-comp-size-xs: var(--el-size-8);
435
+ /**
436
+ * @title 组件尺寸 S
437
+ * @type size
438
+ */
439
+ --el-comp-size-s: var(--el-size-9);
440
+ /**
441
+ * @title 组件尺寸 M
442
+ * @type size
443
+ */
444
+ --el-comp-size-m: var(--el-size-10);
445
+ /**
446
+ * @title 组件尺寸 L
447
+ * @type size
448
+ */
449
+ --el-comp-size-l: var(--el-size-11);
450
+ /**
451
+ * @title 组件尺寸 XL
452
+ * @type size
453
+ */
454
+ --el-comp-size-xl: var(--el-size-12);
455
+ /**
456
+ * @title 组件尺寸 XXL
457
+ * @type size
458
+ */
459
+ --el-comp-size-xxl: var(--el-size-13);
460
+ /**
461
+ * @title 组件尺寸 XXXL
462
+ * @type size
463
+ */
464
+ --el-comp-size-xxxl: var(--el-size-14);
465
+ /**
466
+ * @title 组件尺寸 XXXXL
467
+ * @type size
468
+ */
469
+ --el-comp-size-xxxxl: var(--el-size-15);
470
+ /**
471
+ * @title 组件尺寸 XXXXXL
472
+ * @type size
473
+ */
474
+ --el-comp-size-xxxxxl: var(--el-size-16);
475
+
476
+ /**
477
+ * @title 弹出层内边距 S
478
+ * @type size
479
+ */
480
+ --el-pop-padding-s: var(--el-size-2);
481
+ /**
482
+ * @title 弹出层内边距 M
483
+ * @type size
484
+ */
485
+ --el-pop-padding-m: var(--el-size-3);
486
+ /**
487
+ * @title 弹出层内边距 L
488
+ * @type size
489
+ */
490
+ --el-pop-padding-l: var(--el-size-4);
491
+ /**
492
+ * @title 弹出层内边距 XL
493
+ * @type size
494
+ */
495
+ --el-pop-padding-xl: var(--el-size-5);
496
+ /**
497
+ * @title 弹出层内边距 XXL
498
+ * @type size
499
+ */
500
+ --el-pop-padding-xxl: var(--el-size-6);
501
+
502
+ /**
503
+ * @title 水平内边距 XXS
504
+ * @type size
505
+ */
506
+ --el-comp-paddingLR-xxs: var(--el-size-1);
507
+ /**
508
+ * @title 水平内边距 XS
509
+ * @type size
510
+ */
511
+ --el-comp-paddingLR-xs: var(--el-size-2);
512
+ /**
513
+ * @title 水平内边距 S
514
+ * @type size
515
+ */
516
+ --el-comp-paddingLR-s: var(--el-size-4);
517
+ /**
518
+ * @title 水平内边距 M
519
+ * @type size
520
+ */
521
+ --el-comp-paddingLR-m: var(--el-size-5);
522
+ /**
523
+ * @title 水平内边距 L
524
+ * @type size
525
+ */
526
+ --el-comp-paddingLR-l: var(--el-size-6);
527
+ /**
528
+ * @title 水平内边距 XL
529
+ * @type size
530
+ */
531
+ --el-comp-paddingLR-xl: var(--el-size-8);
532
+ /**
533
+ * @title 水平内边距 XXL
534
+ * @type size
535
+ */
536
+ --el-comp-paddingLR-xxl: var(--el-size-10);
537
+
538
+ /**
539
+ * @title 垂直内边距 XXS
540
+ * @type size
541
+ */
542
+ --el-comp-paddingTB-xxs: var(--el-size-1);
543
+ /**
544
+ * @title 垂直内边距 XS
545
+ * @type size
546
+ */
547
+ --el-comp-paddingTB-xs: var(--el-size-2);
548
+ /**
549
+ * @title 垂直内边距 S
550
+ * @type size
551
+ */
552
+ --el-comp-paddingTB-s: var(--el-size-4);
553
+ /**
554
+ * @title 垂直内边距 M
555
+ * @type size
556
+ */
557
+ --el-comp-paddingTB-m: var(--el-size-5);
558
+ /**
559
+ * @title 垂直内边距 L
560
+ * @type size
561
+ */
562
+ --el-comp-paddingTB-l: var(--el-size-6);
563
+ /**
564
+ * @title 垂直内边距 XL
565
+ * @type size
566
+ */
567
+ --el-comp-paddingTB-xl: var(--el-size-8);
568
+ /**
569
+ * @title 垂直内边距 XXL
570
+ * @type size
571
+ */
572
+ --el-comp-paddingTB-xxl: var(--el-size-10);
573
+
574
+ /**
575
+ * @title 外边距 XXS
576
+ * @type size
577
+ */
578
+ --el-comp-margin-xxs: var(--el-size-1);
579
+ /**
580
+ * @title 外边距 XS
581
+ * @type size
582
+ */
583
+ --el-comp-margin-xs: var(--el-size-2);
584
+ /**
585
+ * @title 外边距 S
586
+ * @type size
587
+ */
588
+ --el-comp-margin-s: var(--el-size-4);
589
+ /**
590
+ * @title 外边距 M
591
+ * @type size
592
+ */
593
+ --el-comp-margin-m: var(--el-size-5);
594
+ /**
595
+ * @title 外边距 L
596
+ * @type size
597
+ */
598
+ --el-comp-margin-l: var(--el-size-6);
599
+ /**
600
+ * @title 外边距 XL
601
+ * @type size
602
+ */
603
+ --el-comp-margin-xl: var(--el-size-7);
604
+ /**
605
+ * @title 外边距 XXL
606
+ * @type size
607
+ */
608
+ --el-comp-margin-xxl: var(--el-size-8);
609
+ /**
610
+ * @title 外边距 XXXL
611
+ * @type size
612
+ */
613
+ --el-comp-margin-xxxl: var(--el-size-10);
614
+ /**
615
+ * @title 外边距 XXXXL
616
+ * @type size
617
+ */
618
+ --el-comp-margin-xxxxl: var(--el-size-12);
619
+
620
+ /**
621
+ * @title 直角
622
+ * @type size
623
+ */
624
+ --el-border-radius-1: 0px;
625
+ /**
626
+ * @title 圆角
627
+ * @type size
628
+ */
629
+ --el-border-radius-2: 2px;
630
+ /**
631
+ * @title 圆角
632
+ * @type size
633
+ */
634
+ --el-border-radius-3: 4px;
635
+ /**
636
+ * @title 圆角
637
+ * @type size
638
+ */
639
+ --el-border-radius-4: 6px;
640
+ /**
641
+ * @title 圆角
642
+ * @type size
643
+ */
644
+ --el-border-radius-5: 8px;
645
+ /**
646
+ * @title 圆角
647
+ * @type size
648
+ */
649
+ --el-border-radius-6: 12px;
650
+ /**
651
+ * @title 圆角
652
+ * @type size
653
+ */
654
+ --el-border-radius-7: 16px;
655
+ /**
656
+ * @title 圆角
657
+ * @type size
658
+ */
659
+ --el-border-radius-8: 20px;
660
+ /**
661
+ * @title 圆角
662
+ * @type size
663
+ */
664
+ --el-border-radius-9: 24px;
665
+ /**
666
+ * @title 全圆角
667
+ * @type input
668
+ */
669
+ --el-border-radius-10: 100%;
670
+
671
+ /**
672
+ * @title 一级阴影
673
+ * @type input
674
+ */
675
+ --el-box-shadow-1: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
676
+ /**
677
+ * @title 二级阴影
678
+ * @type input
679
+ */
680
+ --el-box-shadow-2: 0 2px 4px rgba(0, 0, 0, 0.12), 0 0 6px rgba(0, 0, 0, 0.04);
681
+ /**
682
+ * @title 三级阴影
683
+ * @type input
684
+ */
685
+ --el-box-shadow-3: 0 2px 4px rgba(0, 0, 0, 0.12), 0 0 6px rgba(0, 0, 0, 0.12);
686
+
687
+ --all-transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
688
+ --fade-transition: opacity 300ms cubic-bezier(0.23, 1, 0.32, 1);
689
+ --fade-linear-transition: opacity 200ms linear;
690
+ --md-fade-transition: transform 300ms cubic-bezier(0.23, 1, 0.32, 1),
691
+ opacity 300ms cubic-bezier(0.23, 1, 0.32, 1);
692
+ --border-transition-base: border-color 0.2s
693
+ cubic-bezier(0.645, 0.045, 0.355, 1);
694
+ --color-transition-base: color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1);
695
+ --color-primary: #409eff;
696
+ --color-white: #ffffff;
697
+ --color-black: #000000;
698
+ --color-primary-dark-1: #3a8ee6;
699
+ --color-primary-dark-2: #337ecc;
700
+ --color-primary-light-1: #53a8ff;
701
+ --color-primary-light-2: #66b1ff;
702
+ --color-primary-light-3: #79bbff;
703
+ --color-primary-light-4: #8cc5ff;
704
+ --color-primary-light-5: #a0cfff;
705
+ --color-primary-light-6: #b3d8ff;
706
+ --color-primary-light-7: #c6e2ff;
707
+ --color-primary-light-8: #d9ecff;
708
+ --color-primary-light-9: #ecf5ff;
709
+ --color-success: #67c23a;
710
+ --color-success-dark-1: #5daf34;
711
+ --color-success-dark-2: #529b2e;
712
+ --color-success-light-1: #76c84e;
713
+ --color-success-light-2: #85ce61;
714
+ --color-success-light-3: #95d475;
715
+ --color-success-light-4: #a4da89;
716
+ --color-success-light-5: #b3e19d;
717
+ --color-success-light-6: #c2e7b0;
718
+ --color-success-light-7: #d1edc4;
719
+ --color-success-light-8: #e1f3d8;
720
+ --color-success-light-9: #f0f9eb;
721
+ --color-warning: #e6a23c;
722
+ --color-warning-dark-1: #cf9236;
723
+ --color-warning-dark-2: #b88230;
724
+ --color-warning-light-1: #e9ab50;
725
+ --color-warning-light-2: #ebb563;
726
+ --color-warning-light-3: #eebe77;
727
+ --color-warning-light-4: #f0c78a;
728
+ --color-warning-light-5: #f3d19e;
729
+ --color-warning-light-6: #f5dab1;
730
+ --color-warning-light-7: #f8e3c5;
731
+ --color-warning-light-8: #faecd8;
732
+ --color-warning-light-9: #fdf6ec;
733
+ --color-danger: #f56c6c;
734
+ --color-danger-dark-1: #dd6161;
735
+ --color-danger-dark-2: #c45656;
736
+ --color-danger-light-1: #f67b7b;
737
+ --color-danger-light-2: #f78989;
738
+ --color-danger-light-3: #f89898;
739
+ --color-danger-light-4: #f9a7a7;
740
+ --color-danger-light-5: #fab6b6;
741
+ --color-danger-light-6: #fbc4c4;
742
+ --color-danger-light-7: #fcd3d3;
743
+ --color-danger-light-8: #fde2e2;
744
+ --color-danger-light-9: #fef0f0;
745
+ --color-info: #909399;
746
+ --color-info-dark-1: #82848a;
747
+ --color-info-dark-2: #73767a;
748
+ --color-info-light-1: #9b9ea3;
749
+ --color-info-light-2: #a6a9ad;
750
+ --color-info-light-3: #b1b3b8;
751
+ --color-info-light-4: #bcbec2;
752
+ --color-info-light-5: #c8c9cc;
753
+ --color-info-light-6: #d3d4d6;
754
+ --color-info-light-7: #dedfe0;
755
+ --color-info-light-8: #e9e9eb;
756
+ --color-info-light-9: #f4f4f5;
757
+ --color-success-light: #e1f3d8;
758
+ --color-warning-light: #faecd8;
759
+ --color-danger-light: #fde2e2;
760
+ --color-info-light: #e9e9eb;
761
+ --color-success-lighter: #f0f9eb;
762
+ --color-warning-lighter: #fdf6ec;
763
+ --color-danger-lighter: #fef0f0;
764
+ --color-info-lighter: #f4f4f5;
765
+ --color-text-primary: #303133;
766
+ --color-text-regular: #606266;
767
+ --color-text-secondary: #909399;
768
+ --color-text-placeholder: #c0c4cc;
769
+ --border-color-base: #dcdfe6;
770
+ --border-color-light: #e4e7ed;
771
+ --border-color-lighter: #ebeef5;
772
+ --border-color-extra-light: #f2f6fc;
773
+ --background-color-base: #f5f7fa;
774
+ --link-color: var(--color-primary-light-2);
775
+ --link-hover-color: var(--color-primary);
776
+ --border-width-base: 1px;
777
+ --border-style-base: solid;
778
+ --border-color-hover: var(--color-text-placeholder);
779
+ --border-base: var(--border-width-base) var(--border-style-base)
780
+ var(--border-color-base);
781
+ --border-radius-base: 4px;
782
+ --border-radius-small: 2px;
783
+ --border-radius-circle: 100%;
784
+ --border-radius-zero: 0;
785
+ --box-shadow-base: 0 2px 4px rgba(0, 0, 0, 0.12), 0 0 6px rgba(0, 0, 0, 0.04);
786
+ --box-shadow-dark: 0 2px 4px rgba(0, 0, 0, 0.12), 0 0 6px rgba(0, 0, 0, 0.12);
787
+ --box-shadow-light: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
788
+ --fill-base: var(--color-white);
789
+ --font-size-extra-large: 20px;
790
+ --font-size-large: 18px;
791
+ --font-size-medium: 16px;
792
+ --font-size-base: 14px;
793
+ --font-size-small: 13px;
794
+ --font-size-extra-small: 12px;
795
+ --font-weight-primary: 500;
796
+ --font-weight-secondary: 100;
797
+ --font-line-height-primary: 24px;
798
+ --font-line-height-secondary: 16px;
799
+ --font-color-disabled-base: #bbb;
800
+ --size-base: 14px;
801
+ --index-normal: 1;
802
+ --index-top: 1000;
803
+ --index-popper: 2000;
804
+ --disabled-fill-base: var(--background-color-base);
805
+ --disabled-color-base: var(--color-text-placeholder);
806
+ --disabled-border-base: var(--border-color-light);
807
+ /**
808
+ * @title 滚动条颜色
809
+ * @type color
810
+ */
811
+ --scrollbar-background-color: #9093994d;
812
+ /**
813
+ * @title 滚动条悬停颜色
814
+ * @type color
815
+ */
816
+ --scrollbar-hover-background-color: #90939980;
817
+
818
+ /* ====== reset element pro variable ===== */
819
+ --el-bg-color-specialcomponent: #fff;
820
+ --el-mask-disabled: rgba(255, 255, 255, 0.6);
821
+ --el-brand-color-1: var(--el-color-primary-1);
822
+ --el-brand-color-2: var(--el-color-primary-2);
823
+ --el-brand-color-3: var(--el-color-primary-3);
824
+ --el-brand-color-4: var(--el-color-primary-4);
825
+ --el-brand-color-5: var(--el-color-primary-5);
826
+ --el-brand-color-6: var(--el-color-primary-6);
827
+ --el-brand-color-7: var(--el-color-primary-7);
828
+ --el-brand-color-8: var(--el-color-primary-8);
829
+ --el-brand-color-9: var(--el-color-primary-9);
830
+ --el-brand-color-10: var(--el-color-primary-10);
831
+ --el-warning-color-1: var(--el-color-warning-1);
832
+ --el-warning-color-2: var(--el-color-warning-2);
833
+ --el-warning-color-3: var(--el-color-warning-3);
834
+ --el-warning-color-4: var(--el-color-warning-4);
835
+ --el-warning-color-5: var(--el-color-warning-5);
836
+ --el-warning-color-6: var(--el-color-warning-6);
837
+ --el-warning-color-7: var(--el-color-warning-7);
838
+ --el-warning-color-8: var(--el-color-warning-8);
839
+ --el-warning-color-9: var(--el-color-warning-9);
840
+ --el-warning-color-10: var(--el-color-warning-10);
841
+ --el-error-color-1: var(--el-color-error-1);
842
+ --el-error-color-2: var(--el-color-error-2);
843
+ --el-error-color-3: var(--el-color-error-3);
844
+ --el-error-color-4: var(--el-color-error-4);
845
+ --el-error-color-5: var(--el-color-error-5);
846
+ --el-error-color-6: var(--el-color-error-6);
847
+ --el-error-color-7: var(--el-color-error-7);
848
+ --el-error-color-8: var(--el-color-error-8);
849
+ --el-error-color-9: var(--el-color-error-9);
850
+ --el-error-color-10: var(--el-color-error-10);
851
+ --el-success-color-1: var(--el-color-success-1);
852
+ --el-success-color-2: var(--el-color-success-2);
853
+ --el-success-color-3: var(--el-color-success-3);
854
+ --el-success-color-4: var(--el-color-success-4);
855
+ --el-success-color-5: var(--el-color-success-5);
856
+ --el-success-color-6: var(--el-color-success-6);
857
+ --el-success-color-7: var(--el-color-success-7);
858
+ --el-success-color-8: var(--el-color-success-8);
859
+ --el-success-color-9: var(--el-color-success-9);
860
+ --el-success-color-10: var(--el-color-success-10);
861
+ --el-mask-active: var(--el-color-background-3);
862
+
863
+ --el-gray-color-1: #f3f3f4;
864
+ --el-gray-color-2: #edeef0;
865
+ --el-gray-color-3: #e6e8eb;
866
+ --el-gray-color-4: #dadde1;
867
+ --el-gray-color-5: #c1c6cd;
868
+ --el-gray-color-6: #9da6b1;
869
+ --el-gray-color-7: #7f8b97;
870
+ --el-gray-color-8: #697782;
871
+ --el-gray-color-9: #535e67;
872
+ --el-gray-color-10: #424b53;
873
+ --el-gray-color-11: #32393f;
874
+ --el-gray-color-12: #272c31;
875
+ --el-gray-color-13: #202428;
876
+ --el-gray-color-14: #15181b;
877
+
878
+ /* 基础颜色 */
879
+ --el-brand-color: var(--el-brand-color-6); /* 色彩-品牌-可操作 */
880
+ --el-warning-color: var(--el-warning-color-6); /* 色彩-功能-警告 */
881
+ --el-error-color: var(--el-error-color-6); /* 色彩-功能-失败 */
882
+ --el-success-color: var(--el-success-color-6); /* 色彩-功能-成功 */
883
+
884
+ /* 基础颜色的扩展 用于 hover / 聚焦 / 禁用 / 点击 等状态 */
885
+ --el-brand-color-hover: var(--el-brand-color-6); /* hover态 */
886
+ --el-brand-color-focus: var(--el-brand-color-2); /* focus态,包括鼠标和键盘 */
887
+ --el-brand-color-active: var(--el-brand-color-8); /* 点击态 */
888
+ --el-brand-color-disabled: var(--el-brand-color-3); /* 禁用态 */
889
+ --el-brand-color-light: var(--el-brand-color-1); /* 浅色的选中态 */
890
+ --el-brand-color-light-hover: var(--el-brand-color-2);
891
+
892
+ /* 警告色扩展 */
893
+ --el-warning-color-hover: var(--el-warning-color-4);
894
+ --el-warning-color-focus: var(--el-warning-color-2);
895
+ --el-warning-color-active: var(--el-warning-color-7);
896
+ --el-warning-color-disabled: var(--el-warning-color-3);
897
+ --el-warning-color-light: var(--el-warning-color-1);
898
+ --el-warning-color-light-hover: var(--el-warning-color-2);
899
+
900
+ /* 失败/错误色扩展 */
901
+ --el-error-color-hover: var(--el-error-color-5);
902
+ --el-error-color-focus: var(--el-error-color-2);
903
+ --el-error-color-active: var(--el-error-color-7);
904
+ --el-error-color-disabled: var(--el-error-color-3);
905
+ --el-error-color-light: var(--el-error-color-1);
906
+ --el-error-color-light-hover: var(--el-error-color-2);
907
+
908
+ /* 成功色扩展 */
909
+ --el-success-color-hover: var(--el-success-color-4);
910
+ --el-success-color-focus: var(--el-success-color-2);
911
+ --el-success-color-active: var(--el-success-color-7);
912
+ --el-success-color-disabled: var(--el-success-color-3);
913
+ --el-success-color-light: var(--el-success-color-1);
914
+ --el-success-color-light-hover: var(--el-success-color-2);
915
+
916
+ /* 背景色 */
917
+ --el-bg-color-page: var(--el-gray-color-2); /* 色彩 - page */
918
+ --el-bg-color-container: #fff; /* 色彩 - 容器 */
919
+ --el-bg-color-container-hover: var(--el-gray-color-1); /* 色彩 - 容器 - hover */
920
+ --el-bg-color-container-active: var(--el-gray-color-3); /* 色彩 - 容器 - active */
921
+ --el-bg-color-container-select: #fff; /* 色彩 - 容器 - select */
922
+ --el-bg-color-secondarycontainer: var(--el-gray-color-1); /* 色彩 - 次级容器 */
923
+ --el-bg-color-secondarycontainer-hover: var(--el-gray-color-2); /* 色彩 - 次级容器 - hover */
924
+ --el-bg-color-secondarycontainer-active: var(--el-gray-color-4); /* 色彩 - 次级容器 - active */
925
+ --el-bg-color-component: var(--el-gray-color-3); /* 色彩 - 组件 */
926
+ --el-bg-color-component-hover: var(--el-gray-color-4); /* 色彩 - 组件 - hover */
927
+ --el-bg-color-component-active: var(--el-gray-color-6); /* 色彩 - 组件 - active */
928
+ --el-bg-color-secondarycomponent: var(--el-gray-color-4); /* 色彩 - 次级组件 */
929
+ --el-bg-color-secondarycomponent-hover: var(--el-gray-color-5); /* 色彩 - 次级组件 - hover */
930
+ --el-bg-color-secondarycomponent-active: var(--el-gray-color-6); /* 色彩 - 次级组件 - active */
931
+ --el-bg-color-component-disabled: var(--el-gray-color-2); /* 色彩 - 组件 - disabled */
932
+
933
+
934
+ /* 文本颜色 */
935
+ --el-text-color-primary: var(--el-color-text-1); /* 色彩-文字-主要 */
936
+ --el-text-color-secondary: var(--el-color-text-2); /* 色彩-文字-次要 */
937
+ --el-text-color-placeholder: var(--el-color-text-3); /* 色彩-文字-占位符/说明 */
938
+ --el-text-color-disabled: var(--el-color-text-4); /* 色彩-文字-禁用 */
939
+ --el-text-color-anti: #fff; /* 色彩-文字-反色 */
940
+ --el-text-color-brand: var(--el-brand-color-7); /* 色彩-文字-品牌 */
941
+ --el-text-color-link: var(--el-brand-color-8); /* 色彩-文字-链接 */
942
+
943
+ /* 分割线 */
944
+ --el-border-level-1-color: var(--el-color-line-3);
945
+ --el-component-stroke: var(--el-color-line-3);
946
+
947
+ /* 边框 */
948
+ --el-border-level-2-color: var(--el-color-line-4);
949
+ --el-component-border: var(--el-color-line-4);
950
+ --el-shadow-1: var(--el-box-shadow-1);
951
+ --el-shadow-2: var(--el-box-shadow-2);
952
+ --el-shadow-3: var(--el-box-shadow-3);
953
+
954
+ --el-scrollbar-color: var(--scrollbar-background-color);
955
+ --el-scrollbar-hover-color: var(--scrollbar-hover-background-color);
956
+
957
+ --el-radius-small: var(--el-border-radius-2);
958
+ --el-radius-default: var(--el-border-radius-3);
959
+ --el-radius-medium: var(--el-border-radius-4);
960
+ --el-radius-large: var(--el-border-radius-5);
961
+ --el-radius-extraLarge: var(--el-border-radius-6);
962
+
963
+ --el-font-size-link-small: var(--el-font-size-1);
964
+ --el-font-size-link-medium: var(--el-font-size-2);
965
+ --el-font-size-link-large: var(--el-font-size-3);
966
+ --el-font-size-mark-small: var(--el-font-size-1);
967
+ --el-font-size-mark-medium: var(--el-font-size-2);
968
+ --el-font-size-body-small: var(--el-font-size-1);
969
+ --el-font-size-body-medium: var(--el-font-size-2);
970
+ --el-font-size-body-large: var(--el-font-size-3);
971
+ --el-font-size-title-small: var(--el-font-size-2);
972
+ --el-font-size-title-medium: var(--el-font-size-3);
973
+ --el-font-size-title-large: var(--el-font-size-5);
974
+ --el-font-size-headline-small: var(--el-font-size-6);
975
+ --el-font-size-headline-medium: 28px;
976
+ --el-font-size-headline-large: var(--el-font-size-7);
977
+ --el-font-size-display-medium: var(--el-font-size-8);
978
+ --el-font-size-display-large: 64px;
979
+
980
+ --el-line-height-link-small: calc(var(--el-font-size-link-small) + 8px);
981
+ --el-line-height-link-medium: calc(var(--el-font-size-link-medium) + 8px);
982
+ --el-line-height-link-large: calc(var(--el-font-size-link-large) + 8px);
983
+ --el-line-height-mark-small: calc(var(--el-font-size-mark-small) + 8px);
984
+ --el-line-height-mark-medium: calc(var(--el-font-size-mark-medium) + 8px);
985
+ --el-line-height-body-small: calc(var(--el-font-size-body-small) + 8px);
986
+ --el-line-height-body-medium: calc(var(--el-font-size-body-medium) + 8px);
987
+ --el-line-height-body-large: calc(var(--el-font-size-body-large) + 8px);
988
+ --el-line-height-title-small: calc(var(--el-font-size-title-small) + 8px);
989
+ --el-line-height-title-medium: calc(var(--el-font-size-title-medium) + 8px);
990
+ --el-line-height-title-large: calc(var(--el-font-size-title-large) + 8px);
991
+ --el-line-height-headline-small: calc(var(--el-font-size-headline-small) + 8px);
992
+ --el-line-height-headline-medium: calc(var(--el-font-size-headline-medium) + 8px);
993
+ --el-line-height-headline-large: calc(var(--el-font-size-headline-large) + 8px);
994
+ --el-line-height-display-medium: calc(var(--el-font-size-display-medium) + 8px);
995
+ --el-line-height-display-large: calc(var(--el-font-size-display-large) + 8px);
996
+ }
997
+ ```
998
+
999
+ ## 在 `.storybook/preview.js` 文件中导入全局变量
1000
+
1001
+ ```js
1002
+ import './vars.css';
1003
+
1004
+ // ......
1005
+ ```
1006
+
1007
+ 完成后就可以在组件中使用以上的全局 css 变量