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.
- package/README.md +271 -0
- package/bin/lcap-frontend-library.mjs +3 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +27 -0
- package/dist/init.d.ts +6 -0
- package/dist/init.js +79 -0
- package/dist/sync.d.ts +4 -0
- package/dist/sync.js +70 -0
- package/dist/utils.d.ts +19 -0
- package/dist/utils.js +101 -0
- package/package.json +34 -0
- package/packages/lcap-frontend-library/LEARNINGS.md +11 -0
- package/packages/lcap-frontend-library/SKILL.md +86 -0
- package/packages/lcap-frontend-library/commands/migrate.check.md +287 -0
- package/packages/lcap-frontend-library/commands/migrate.green.md +190 -0
- package/packages/lcap-frontend-library/commands/migrate.plan.md +169 -0
- package/packages/lcap-frontend-library/commands/migrate.red.md +160 -0
- package/packages/lcap-frontend-library/commands/migrate.scan.md +151 -0
- package/packages/lcap-frontend-library/commands/migrate.spec.md +144 -0
- package/packages/lcap-frontend-library/commands/migrate.tasks.md +179 -0
- package/packages/lcap-frontend-library/commands/speckit.create.md +201 -0
- package/packages/lcap-frontend-library/commands/speckit.implement.md +88 -0
- package/packages/lcap-frontend-library/commands/speckit.plan.md +79 -0
- package/packages/lcap-frontend-library/commands/speckit.self-check.md +177 -0
- package/packages/lcap-frontend-library/commands/speckit.specify.md +91 -0
- package/packages/lcap-frontend-library/commands/speckit.tasks.md +61 -0
- package/packages/lcap-frontend-library/references/frontend-design/LICENSE.txt +177 -0
- package/packages/lcap-frontend-library/references/frontend-design/SKILL.md +42 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/SKILL.md +360 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/api.md +331 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/block.md +160 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/i18n.md +95 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/icon.md +27 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/ide/container.md +728 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/ide/element.md +312 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/ide/expression.md +154 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/ide/index.md +113 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/ide/modal.md +189 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/ide/popover.md +171 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/ide.md +799 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/implementation-rules.md +242 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/index.md +27 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/nasl-view-component.md +895 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/platform/accessibility.md +185 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/platform/child.md +82 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/platform/data-source.md +261 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/platform/event.md +171 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/platform/form.md +266 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/platform/function.md +80 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/platform/link.md +137 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/platform/slot.md +128 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/platform/theme-variables-ant-design.md +1470 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/platform/theme-variables-cloud-ui.md +259 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/platform/theme-variables-element-plus.md +580 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/platform/theme-variables-element-ui.md +1007 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/platform/theme-variables-mobile-ui.md +85 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/theme.md +234 -0
- package/packages/lcap-frontend-library/references/lcap-extension-component/workflow-guardrails.md +328 -0
- package/packages/lcap-frontend-library/references/nasl-logic-authoring/SKILL.md +201 -0
- package/packages/lcap-frontend-library/scripts/bash/create-component-files.sh +95 -0
- package/packages/lcap-frontend-library/scripts/bash/create-extension-project.sh +109 -0
- package/packages/lcap-frontend-library/scripts/bash/create-logic-files.sh +149 -0
- package/packages/lcap-frontend-library/scripts/bash/create-spec.sh +109 -0
- package/packages/lcap-frontend-library/scripts/bash/get-available-port.sh +35 -0
- package/packages/lcap-frontend-library/scripts/bash/list-specs.sh +19 -0
- package/packages/lcap-frontend-library/scripts/node/setup-extension-project.mjs +166 -0
- package/packages/lcap-frontend-library/templates/component-self-check.md +31 -0
- package/packages/lcap-frontend-library/templates/component-template.md +96 -0
- package/packages/lcap-frontend-library/templates/library-report-template.md +52 -0
- package/packages/lcap-frontend-library/templates/logic-template.md +44 -0
- package/packages/lcap-frontend-library/templates/migration-manifest-template.md +84 -0
- package/packages/lcap-frontend-library/templates/migration-plan-template.md +138 -0
- package/packages/lcap-frontend-library/templates/migration-report-template.md +227 -0
- package/packages/lcap-frontend-library/templates/migration-spec-template.md +135 -0
- package/packages/lcap-frontend-library/templates/migration-tasks-template.md +129 -0
- package/packages/lcap-frontend-library/templates/plan-template.md +299 -0
- package/packages/lcap-frontend-library/templates/self-check-report-template.md +148 -0
- package/packages/lcap-frontend-library/templates/tasks-template.md +81 -0
- package/packages/lcap-frontend-library/workflows/create/flow.md +199 -0
- package/packages/lcap-frontend-library/workflows/evolve/flow.md +249 -0
- package/packages/lcap-frontend-library/workflows/generate/flow.md +10 -0
- package/packages/lcap-frontend-library/workflows/harness/flow.md +82 -0
- package/packages/lcap-frontend-library/workflows/migrate/flow.md +302 -0
- package/packages/lcap-frontend-library/workflows/migrate/knowledge-base.md +564 -0
|
@@ -0,0 +1,259 @@
|
|
|
1
|
+
# 使用 CloudUI 全局主题变量
|
|
2
|
+
|
|
3
|
+
## 复制变量文件
|
|
4
|
+
|
|
5
|
+
创建文件 `.storybook/vars.css`, 内容如下:
|
|
6
|
+
|
|
7
|
+
```css
|
|
8
|
+
:root {
|
|
9
|
+
/**
|
|
10
|
+
* ========================
|
|
11
|
+
* Global Variables
|
|
12
|
+
* ========================
|
|
13
|
+
*/
|
|
14
|
+
|
|
15
|
+
/* Brand Colors */
|
|
16
|
+
--brand-primary-lightest: #eaf2ff;
|
|
17
|
+
--brand-primary-lighter: #bbd4ff;
|
|
18
|
+
--brand-primary-light: #5c98ff;
|
|
19
|
+
--brand-primary: #337eff;
|
|
20
|
+
--brand-logo-color: var(--brand-primary);
|
|
21
|
+
--brand-primary-dark: #1168ff;
|
|
22
|
+
--brand-primary-darker: #004bcc;
|
|
23
|
+
--brand-primary-darkest: #003eaa;
|
|
24
|
+
--brand-primary-disabled: #bbd4ff;
|
|
25
|
+
--brand-primary-opacity-20:#337eff33;
|
|
26
|
+
|
|
27
|
+
--brand-success-lightest: #e9f8f1;
|
|
28
|
+
--brand-success-lighter: #b0efd0;
|
|
29
|
+
--brand-success-light: #2ed581;
|
|
30
|
+
--brand-success: #26BD71;
|
|
31
|
+
--brand-success-dark: #22a864;
|
|
32
|
+
--brand-success-darker: #197e4b;
|
|
33
|
+
--brand-success-darkest: #15693f;
|
|
34
|
+
|
|
35
|
+
--brand-normal-lightest: #f2f9eb;
|
|
36
|
+
--brand-normal-lighter: #d8eec4;
|
|
37
|
+
--brand-normal-light: #97d362;
|
|
38
|
+
--brand-normal: #8acd4e;
|
|
39
|
+
--brand-normal-dark: #7ac437;
|
|
40
|
+
--brand-normal-darker: #5b932a;
|
|
41
|
+
--brand-normal-darkest: #4c7b23;
|
|
42
|
+
|
|
43
|
+
--brand-problem-lightest: #fffae8;
|
|
44
|
+
--brand-problem-lighter: #ffeca2;
|
|
45
|
+
--brand-problem-light: #ffda45;
|
|
46
|
+
--brand-problem: #ffd52e;
|
|
47
|
+
--brand-problem-dark: #ffce0c;
|
|
48
|
+
--brand-problem-darker: #c9a000;
|
|
49
|
+
--brand-problem-darkest: #a78600;
|
|
50
|
+
|
|
51
|
+
--brand-warning-lightest: #fef7e8;
|
|
52
|
+
--brand-warning-lighter: #ffb21a;
|
|
53
|
+
--brand-warning-light: #ffb82a;
|
|
54
|
+
--brand-warning: #FFB21A;
|
|
55
|
+
--brand-warning-dark: #f0a000;
|
|
56
|
+
--brand-warning-darker: #b47800;
|
|
57
|
+
--brand-warning-darkest: #966400;
|
|
58
|
+
|
|
59
|
+
--brand-error-lightest: #feecee;
|
|
60
|
+
--brand-error-lighter: #fab6bc;
|
|
61
|
+
--brand-error-light: #f56d79;
|
|
62
|
+
--brand-error: #F24957;
|
|
63
|
+
--brand-error-dark: #f02d33;
|
|
64
|
+
--brand-error-darker: #c70f14;
|
|
65
|
+
--brand-error-darkest: #a60c11;
|
|
66
|
+
|
|
67
|
+
--brand-danger-lightest: #ffeded;
|
|
68
|
+
--brand-danger-lighter: #ffc8c8;
|
|
69
|
+
--brand-danger-light: #ff6c6c;
|
|
70
|
+
--brand-danger: #F24957;
|
|
71
|
+
--brand-danger-dark: #ff3434;
|
|
72
|
+
--brand-danger-darker: #e60000;
|
|
73
|
+
--brand-danger-darkest: #c00000;
|
|
74
|
+
--brand-danger-opacity-20: #f2495733;
|
|
75
|
+
--brand-danger-disabled: #fbc2c7;
|
|
76
|
+
|
|
77
|
+
|
|
78
|
+
--brand-assist-lightest: #faf2ff;
|
|
79
|
+
--brand-assist-lighter: #efd9ff;
|
|
80
|
+
--brand-assist-light: #d599ff;
|
|
81
|
+
--brand-assist: #d08cff;
|
|
82
|
+
--brand-assist-dark: #be60ff;
|
|
83
|
+
--brand-assist-darker: #9a08ff;
|
|
84
|
+
--brand-assist-darkest: #8200db;
|
|
85
|
+
|
|
86
|
+
--brand-disabled-light: #ededed; /* 选择且禁用的背景 */
|
|
87
|
+
--brand-disabled: #ebebeb; /* 输入框、选择框的禁用背景 */
|
|
88
|
+
--brand-disabled-dark: #999; /* 禁用文本的颜色 */
|
|
89
|
+
--brand-disabled-darker: #9d9d9d; /* 禁用文本的颜色 */
|
|
90
|
+
|
|
91
|
+
/* Gray Colors */
|
|
92
|
+
--color-white: white;
|
|
93
|
+
--color-black: black;
|
|
94
|
+
--gray-darkest: #333;
|
|
95
|
+
--gray-darker: #666;
|
|
96
|
+
--gray-dark: #999;
|
|
97
|
+
--gray-base: #aaa;
|
|
98
|
+
--gray-light: #ccc;
|
|
99
|
+
--gray-lighter: #ddd;
|
|
100
|
+
--gray-lightest: #eee;
|
|
101
|
+
|
|
102
|
+
/* Component Base Colors */
|
|
103
|
+
--background-color-default: white; /* body 默认的背景 */
|
|
104
|
+
--background-color-default-inverse: #17181f; /* body 默认的背景 */
|
|
105
|
+
--background-color-lightest: #f4f4f4;
|
|
106
|
+
--background-color-lighter: #f4f6f9; /* 选择框的 hover 颜色 */
|
|
107
|
+
--background-color-lighter-inverse: #33353d; /* 选择框的 hover 颜色 */
|
|
108
|
+
--background-color-light: #f4f6f9; /* 表格等组件标题栏颜色 */
|
|
109
|
+
--background-color-base: #ededed; /* 标签、薯条等组件默认颜色 */
|
|
110
|
+
--background-color-base-inverse: #33353d; /* 标签、薯条等组件默认颜色 */
|
|
111
|
+
--background-color-dark: #e3e8f0;
|
|
112
|
+
--background-color-dark-inverse: #2e3038;
|
|
113
|
+
--background-color-darker: #d8dfea;
|
|
114
|
+
--background-color-disabled: var(--el-color-background-5);
|
|
115
|
+
--background-color-hover: #f5f5f5;
|
|
116
|
+
--background-color-disabled-light: #F7F8FA;
|
|
117
|
+
--color-lighter: #ccc; /* Placeholder 字体颜色 */
|
|
118
|
+
--color-light: #999999; /* 次级字体颜色 */
|
|
119
|
+
--color-base: #333333; /* 默认字体颜色 */
|
|
120
|
+
--color-base-inverse: white; /* 默认字体颜色 */
|
|
121
|
+
--color-dark: #363a41; /* 默认字体颜色 */
|
|
122
|
+
--border-color-light: #dee4ed; /* 面板等容器类型的边框颜色 */
|
|
123
|
+
--border-color-base: #e5e5e5; /* 输入框等小组件的边框颜色 */
|
|
124
|
+
--border-color-base-inverse: #212123; /* 输入框等小组件的边框颜色 */
|
|
125
|
+
--border-color-dark: #E3E4E5; /* 按钮等小组件的边框颜色 */
|
|
126
|
+
--border-color-darker: #e0e0e0;
|
|
127
|
+
|
|
128
|
+
--font-first-color: #222222; /* 一级字色 */
|
|
129
|
+
--font-second-color: #666666; /* 二级字色 */
|
|
130
|
+
--font-third-color: #999999; /* 三级字色 */
|
|
131
|
+
--font-third-color-opacity-15: #99999926;
|
|
132
|
+
--font-third-color-opacity-60: #99999999;
|
|
133
|
+
--font-fourth-color: #333333; /* 三级字色 */
|
|
134
|
+
--font-disabled-color: #CCCCCC; /* 禁用字色 */
|
|
135
|
+
--font-disabled-color-opacity-50: #CCCCCC80;
|
|
136
|
+
|
|
137
|
+
/* Space Dimensions */
|
|
138
|
+
--space-shrink: -1px;
|
|
139
|
+
--space-mini: 4px;
|
|
140
|
+
--space-base: 16px;
|
|
141
|
+
--space-small: 10px;
|
|
142
|
+
--space-medium: 24px;
|
|
143
|
+
--space-large: 30px;
|
|
144
|
+
--space-huge: 40px;
|
|
145
|
+
|
|
146
|
+
/* Component Base Dimensions */
|
|
147
|
+
--border-width-base: 1px;
|
|
148
|
+
--width-mini: 80px;
|
|
149
|
+
--width-small: 120px;
|
|
150
|
+
--width-base: 240px; /* 以输入框、选择框为基准的尺寸 */
|
|
151
|
+
--width-medium: 280px;
|
|
152
|
+
--width-large: 440px;
|
|
153
|
+
--width-huge: 580px;
|
|
154
|
+
--height-mini: 22px;
|
|
155
|
+
--height-small: 28px;
|
|
156
|
+
--height-normal: 32px;
|
|
157
|
+
--height-base: 32px; /* 以输入框、选择框为基准的尺寸 */
|
|
158
|
+
--height-medium: 34px;
|
|
159
|
+
--height-large: 38px;
|
|
160
|
+
--height-huge: 42px;
|
|
161
|
+
--border-radius-mini: 2px;
|
|
162
|
+
--border-radius-base: 4px;
|
|
163
|
+
--border-radius-medium: 5px;
|
|
164
|
+
--border-radius-large: 4px;
|
|
165
|
+
|
|
166
|
+
/* Fonts */
|
|
167
|
+
/* stylelint-disable value-keyword-case */
|
|
168
|
+
--font-family-zh-CN: BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Helvetica, Tahoma, Arial, 'Noto Sans', 'PingFang SC', 'Microsoft YaHei', 'Hiragino Sans GB', sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol', 'Noto Color Emoji', -apple-system;
|
|
169
|
+
--font-family-code: menlo, consolas, monaco, monospace;
|
|
170
|
+
--tab-size: 4;
|
|
171
|
+
--line-height-base: 1.6;
|
|
172
|
+
--font-size-base: 14px;
|
|
173
|
+
--font-size-small: calc(var(--font-size-base) * (12 / 14));
|
|
174
|
+
--font-size-large: calc(var(--font-size-base) * (16 / 14));
|
|
175
|
+
--font-size-huge: calc(var(--font-size-base) * (24 / 14));
|
|
176
|
+
--font-weight-lighter: lighter;
|
|
177
|
+
--font-weight-light: 300;
|
|
178
|
+
--font-weight-normal: 400;
|
|
179
|
+
--font-weight-bold: 700;
|
|
180
|
+
--font-weight-bolder: bolder;
|
|
181
|
+
|
|
182
|
+
--box-shadow-base: 0 0 4px rgba(3, 3, 3, .1);
|
|
183
|
+
--box-shadow-small: 0px 2px 12px rgba(0, 0, 0, 0.06);
|
|
184
|
+
--box-shadow-small-hover: 0px 2px 16px rgba(0, 0, 0, 0.12);
|
|
185
|
+
--box-shadow-large: 0px 2px 15px rgba(64, 69, 78, 0.15);
|
|
186
|
+
--box-shadow-form-item-base: 0 0 0 2px var(--brand-primary-opacity-20);
|
|
187
|
+
|
|
188
|
+
/* Z-Index */
|
|
189
|
+
--z-index-loading: 9000;
|
|
190
|
+
--z-index-toast: 8000;
|
|
191
|
+
--z-index-tooltip: 7010;
|
|
192
|
+
--z-index-popper: 7000;
|
|
193
|
+
--z-index-modal: 7000;
|
|
194
|
+
--z-index-plugin: 2000;
|
|
195
|
+
--z-index-layout: 100;
|
|
196
|
+
--z-index-base: 1;
|
|
197
|
+
|
|
198
|
+
/* Component Action Hints */
|
|
199
|
+
--cursor-pointer: pointer;
|
|
200
|
+
--cursor-not-allowed: not-allowed;
|
|
201
|
+
--focus-outline: none;
|
|
202
|
+
|
|
203
|
+
/* Transition Duration */
|
|
204
|
+
--transition-duration-none: 0s;
|
|
205
|
+
--transition-duration-base: 0.2s;
|
|
206
|
+
--transition-duration-fast: 0.1s;
|
|
207
|
+
--transition-duration-slow: 0.3s;
|
|
208
|
+
--transition-duration-slower: 0.5s;
|
|
209
|
+
--transition-collapse-base: var(--transition-duration-base) height ease-in-out, var(--transition-duration-base) padding-top ease-in-out, var(--transition-duration-base) padding-bottom ease-in-out;
|
|
210
|
+
|
|
211
|
+
/**
|
|
212
|
+
* ========================
|
|
213
|
+
* 排版
|
|
214
|
+
* ========================
|
|
215
|
+
*/
|
|
216
|
+
|
|
217
|
+
--hr-border-color: var(--border-color-base);
|
|
218
|
+
--blockquote-padding: 8px 16px;
|
|
219
|
+
--ulol-padding-left: 20px;
|
|
220
|
+
--pre-font-size: var(--code-font-size);
|
|
221
|
+
--pre-font-family: var(--font-family-code);
|
|
222
|
+
--pre-padding-y: 5px;
|
|
223
|
+
--pre-padding-x: 10px;
|
|
224
|
+
--code-margin-x: 2px;
|
|
225
|
+
--code-padding-y: 3px;
|
|
226
|
+
--code-padding-x: 3px;
|
|
227
|
+
--code-background: var(--background-color-lighter);
|
|
228
|
+
--code-color: #e0276e;
|
|
229
|
+
--code-font-size: var(--font-size-small);
|
|
230
|
+
|
|
231
|
+
--kbd-padding-y: 2px;
|
|
232
|
+
--kbd-padding-x: 4px;
|
|
233
|
+
--kbd-font-size: var(--font-size-small);
|
|
234
|
+
--kbd-background: var(--background-color-base);
|
|
235
|
+
--kbd-border-width: var(--border-width-base);
|
|
236
|
+
--kbd-border-color: var(--border-color-dark);
|
|
237
|
+
--kbd-border-radius: var(--border-radius-base);
|
|
238
|
+
--kbd-box-shadow: 0 1px 1px rgba(0,0,0,.2), 0 2px 0 0 rgba(255,255,255,.7) inset;
|
|
239
|
+
|
|
240
|
+
--scrollbar-size: 4px;
|
|
241
|
+
--scrollbar-background: rgba(0, 0, 0, 0.15);
|
|
242
|
+
--scrollbar-background-inverse: rgba(0, 0, 0, 0.15);
|
|
243
|
+
--scrollbar-background-hover: rgba(0, 0, 0, 0.25);
|
|
244
|
+
--scrollbar-background-hover-inverse: rgba(0, 0, 0, 0.25);
|
|
245
|
+
--scrollbar-border-radius: 3px;
|
|
246
|
+
--scrollbar-border-color: transparent;
|
|
247
|
+
--scrollbar-border-width: 4px;
|
|
248
|
+
}
|
|
249
|
+
```
|
|
250
|
+
|
|
251
|
+
## 在 `.storybook/preview.js` 文件中导入全局变量
|
|
252
|
+
|
|
253
|
+
```js
|
|
254
|
+
import './vars.css';
|
|
255
|
+
|
|
256
|
+
// ......
|
|
257
|
+
```
|
|
258
|
+
|
|
259
|
+
完成后就可以在组件中使用以上的全局 css 变量
|