@kingsoft-ai/design 0.1.9
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 +67 -0
- package/dist/index.cjs +2485 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.mjs +9638 -0
- package/dist/index.mjs.map +1 -0
- package/dist/types/__tests__/setup.d.ts +1 -0
- package/dist/types/__tests__/test-utils.d.ts +26 -0
- package/dist/types/button/Button.d.ts +56 -0
- package/dist/types/button/Button.style.d.ts +69 -0
- package/dist/types/button/IconButton.d.ts +47 -0
- package/dist/types/button/IconButton.style.d.ts +32 -0
- package/dist/types/button/__tests__/Button.test.d.ts +14 -0
- package/dist/types/button/__tests__/IconButton.test.d.ts +1 -0
- package/dist/types/button/index.d.ts +4 -0
- package/dist/types/button/tokens.d.ts +4 -0
- package/dist/types/checkbox/Checkbox.d.ts +42 -0
- package/dist/types/checkbox/Checkbox.style.d.ts +9 -0
- package/dist/types/checkbox/CheckboxButton.d.ts +52 -0
- package/dist/types/checkbox/CheckboxButton.style.d.ts +26 -0
- package/dist/types/checkbox/__tests__/Checkbox.test.d.ts +4 -0
- package/dist/types/checkbox/__tests__/CheckboxButton.test.d.ts +4 -0
- package/dist/types/checkbox/index.d.ts +7 -0
- package/dist/types/checkbox/tokens.d.ts +3 -0
- package/dist/types/collapse/Collapse.d.ts +50 -0
- package/dist/types/collapse/Collapse.style.d.ts +153 -0
- package/dist/types/collapse/CollapseItem.d.ts +46 -0
- package/dist/types/collapse/__tests__/Collapse.test.d.ts +14 -0
- package/dist/types/collapse/index.d.ts +4 -0
- package/dist/types/collapse/tokens.d.ts +3 -0
- package/dist/types/index.d.ts +18 -0
- package/dist/types/input/Input.d.ts +73 -0
- package/dist/types/input/Input.style.d.ts +96 -0
- package/dist/types/input/__tests__/Input.test.d.ts +17 -0
- package/dist/types/input/index.d.ts +2 -0
- package/dist/types/input/tokens.d.ts +3 -0
- package/dist/types/menu/Menu.d.ts +37 -0
- package/dist/types/menu/Menu.style.d.ts +122 -0
- package/dist/types/menu/MenuFooter.d.ts +32 -0
- package/dist/types/menu/MenuGroup.d.ts +26 -0
- package/dist/types/menu/MenuHeader.d.ts +32 -0
- package/dist/types/menu/MenuItem.d.ts +40 -0
- package/dist/types/menu/SubMenuItem.d.ts +26 -0
- package/dist/types/menu/SubMenuPopover.d.ts +29 -0
- package/dist/types/menu/__tests__/Menu.test.d.ts +1 -0
- package/dist/types/menu/index.d.ts +13 -0
- package/dist/types/menu/tokens.d.ts +3 -0
- package/dist/types/numberInput/NumberInput.d.ts +59 -0
- package/dist/types/numberInput/NumberInput.style.d.ts +44 -0
- package/dist/types/numberInput/__tests__/NumberInput.test.d.ts +1 -0
- package/dist/types/numberInput/index.d.ts +2 -0
- package/dist/types/numberInput/tokens.d.ts +3 -0
- package/dist/types/progress/Progress.d.ts +64 -0
- package/dist/types/progress/Progress.style.d.ts +117 -0
- package/dist/types/progress/__tests__/Progress.test.d.ts +1 -0
- package/dist/types/progress/index.d.ts +3 -0
- package/dist/types/radio/Radio.d.ts +9 -0
- package/dist/types/radio/Radio.style.d.ts +36 -0
- package/dist/types/radio/__tests__/Radio.test.d.ts +13 -0
- package/dist/types/radio/index.d.ts +2 -0
- package/dist/types/radio/tokens.d.ts +3 -0
- package/dist/types/select/ListBox.d.ts +11 -0
- package/dist/types/select/Popover.d.ts +10 -0
- package/dist/types/select/Select.d.ts +140 -0
- package/dist/types/select/Select.style.d.ts +73 -0
- package/dist/types/select/__tests__/Select.test.d.ts +1 -0
- package/dist/types/select/index.d.ts +3 -0
- package/dist/types/select/tokens.d.ts +3 -0
- package/dist/types/skeleton/Skeleton.d.ts +23 -0
- package/dist/types/skeleton/Skeleton.style.d.ts +32 -0
- package/dist/types/skeleton/index.d.ts +3 -0
- package/dist/types/skeleton/tokens.d.ts +3 -0
- package/dist/types/stepper/Step.d.ts +24 -0
- package/dist/types/stepper/Stepper.d.ts +20 -0
- package/dist/types/stepper/Stepper.style.d.ts +57 -0
- package/dist/types/stepper/index.d.ts +3 -0
- package/dist/types/stepper/tokens.d.ts +3 -0
- package/dist/types/switch/Switch.d.ts +68 -0
- package/dist/types/switch/Switch.style.d.ts +100 -0
- package/dist/types/switch/__tests__/Switch.test.d.ts +14 -0
- package/dist/types/switch/index.d.ts +6 -0
- package/dist/types/switch/tokens.d.ts +3 -0
- package/dist/types/table/Table.d.ts +88 -0
- package/dist/types/table/Table.style.d.ts +97 -0
- package/dist/types/table/index.d.ts +2 -0
- package/dist/types/tag/Tag.d.ts +80 -0
- package/dist/types/tag/Tag.style.d.ts +83 -0
- package/dist/types/tag/__tests__/Tag.test.d.ts +14 -0
- package/dist/types/tag/index.d.ts +2 -0
- package/dist/types/tag/tokens.d.ts +3 -0
- package/dist/types/theme.d.ts +14 -0
- package/dist/types/types/component-tokens.types.d.ts +765 -0
- package/dist/types/types/theme-utils.d.ts +20 -0
- package/dist/types/upload/Upload.d.ts +80 -0
- package/dist/types/upload/Upload.style.d.ts +158 -0
- package/dist/types/upload/__tests__/Upload.test.d.ts +16 -0
- package/dist/types/upload/index.d.ts +3 -0
- package/package.json +73 -0
package/README.md
ADDED
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
# @kingsoft-ai/design
|
|
2
|
+
|
|
3
|
+
基于 React 和 Emotion 的设计组件库,使用三层 Design Token 体系。
|
|
4
|
+
|
|
5
|
+
## 组件
|
|
6
|
+
|
|
7
|
+
- **Button**: 支持多种变体(primary, secondary, text, danger, gradient)的按钮组件
|
|
8
|
+
- **Checkbox**: 支持多种色调的复选框组件
|
|
9
|
+
- **Radio**: 单选框组件
|
|
10
|
+
|
|
11
|
+
## 开发
|
|
12
|
+
|
|
13
|
+
### 构建
|
|
14
|
+
|
|
15
|
+
```bash
|
|
16
|
+
pnpm build:lib
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
### 测试
|
|
20
|
+
|
|
21
|
+
本包使用 Vitest + Testing Library 作为测试框架,覆盖率达到 **100% 语句覆盖**。
|
|
22
|
+
|
|
23
|
+
```bash
|
|
24
|
+
# 交互式测试(watch 模式)
|
|
25
|
+
pnpm test
|
|
26
|
+
|
|
27
|
+
# 一次性运行所有测试
|
|
28
|
+
pnpm test:run
|
|
29
|
+
|
|
30
|
+
# 生成覆盖率报告
|
|
31
|
+
pnpm test:coverage
|
|
32
|
+
|
|
33
|
+
# 打开 Vitest UI
|
|
34
|
+
pnpm test:ui
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
测试文件位于 `src/<component>/__tests__/*.test.tsx`。
|
|
38
|
+
|
|
39
|
+
详细测试文档请参阅 [TESTING.md](./TESTING.md)。
|
|
40
|
+
|
|
41
|
+
## 使用
|
|
42
|
+
|
|
43
|
+
```tsx
|
|
44
|
+
import { Button, Checkbox, Radio } from '@kingsoft-ai/design'
|
|
45
|
+
import { CustomThemeProvider } from '@kingsoft-ai/theme'
|
|
46
|
+
|
|
47
|
+
function App() {
|
|
48
|
+
return (
|
|
49
|
+
<CustomThemeProvider>
|
|
50
|
+
<Button variant="primary" size="md">
|
|
51
|
+
点击我
|
|
52
|
+
</Button>
|
|
53
|
+
<Checkbox label="同意条款" />
|
|
54
|
+
<Radio label="选项 A" name="choice" value="a" />
|
|
55
|
+
</CustomThemeProvider>
|
|
56
|
+
)
|
|
57
|
+
}
|
|
58
|
+
```
|
|
59
|
+
|
|
60
|
+
## 依赖
|
|
61
|
+
|
|
62
|
+
- React >= 18
|
|
63
|
+
- @emotion/react >= 11
|
|
64
|
+
- @emotion/styled >= 11
|
|
65
|
+
- react-aria >= 3
|
|
66
|
+
- @kingsoft-ai/theme (workspace)
|
|
67
|
+
|