@lotte-innovate/ui-component-test 0.2.71 → 0.2.72

Sign up to get free protection for your applications and to get access to all the features.
Files changed (76) hide show
  1. package/README.md +225 -226
  2. package/dist/globals.css +4 -4
  3. package/dist/lib/color/constants.js +1 -1
  4. package/dist/lib/color/constants.mjs +1 -1
  5. package/dist/lib/color/constants.mjs.map +1 -1
  6. package/dist/lib/components/Badge/index.js +3 -3
  7. package/dist/lib/components/Badge/index.mjs +1 -1
  8. package/dist/lib/components/Box/index.js +2 -2
  9. package/dist/lib/components/Box/index.mjs +1 -1
  10. package/dist/lib/components/Box/index.mjs.map +1 -1
  11. package/dist/lib/components/Breadcrumb/BreadcrumbLink.js +2 -2
  12. package/dist/lib/components/Breadcrumb/BreadcrumbLink.mjs +1 -1
  13. package/dist/lib/components/Breadcrumb/BreadcrumbLink.mjs.map +1 -1
  14. package/dist/lib/components/Breadcrumb/BreadcrumbPage.js +3 -3
  15. package/dist/lib/components/Breadcrumb/BreadcrumbPage.mjs +1 -1
  16. package/dist/lib/components/Breadcrumb/BreadcrumbPage.mjs.map +1 -1
  17. package/dist/lib/components/Breadcrumb/BreadcrumbRoot.js +2 -2
  18. package/dist/lib/components/Breadcrumb/BreadcrumbRoot.mjs +1 -1
  19. package/dist/lib/components/CheckboxGroup/CheckboxGroupRoot.d.ts +1 -1
  20. package/dist/lib/components/CheckboxGroup/index.d.ts +1 -1
  21. package/dist/lib/components/Container/index.js +2 -2
  22. package/dist/lib/components/Container/index.mjs +1 -1
  23. package/dist/lib/components/Container/index.mjs.map +1 -1
  24. package/dist/lib/components/Datepicker/index.d.ts +2 -1
  25. package/dist/lib/components/Datepicker/index.js +2 -2
  26. package/dist/lib/components/Datepicker/index.mjs +1 -1
  27. package/dist/lib/components/Dialog/DialogRoot.d.ts +4 -3
  28. package/dist/lib/components/Dialog/index.d.ts +1 -1
  29. package/dist/lib/components/DropdownMenu/DropdownMenuTrigger.js +3 -3
  30. package/dist/lib/components/DropdownMenu/DropdownMenuTrigger.mjs +1 -1
  31. package/dist/lib/components/Editor/index.js +0 -1
  32. package/dist/lib/components/Flex/index.js +2 -2
  33. package/dist/lib/components/Flex/index.mjs +1 -1
  34. package/dist/lib/components/Flex/index.mjs.map +1 -1
  35. package/dist/lib/components/Gnb/GnbInfo.js +2 -2
  36. package/dist/lib/components/Gnb/GnbInfo.mjs +1 -1
  37. package/dist/lib/components/Gnb/GnbLogo.js +1 -1
  38. package/dist/lib/components/Gnb/GnbLogo.mjs +1 -1
  39. package/dist/lib/components/Gnb/GnbLogo.mjs.map +1 -1
  40. package/dist/lib/components/Grid/NumberingPagination.d.ts +1 -1
  41. package/dist/lib/components/Grid/NumberingPagination.js +59 -17
  42. package/dist/lib/components/Grid/NumberingPagination.mjs +1 -1
  43. package/dist/lib/components/Grid/NumberingPagination.mjs.map +1 -1
  44. package/dist/lib/components/Grid/index.d.ts +2 -2
  45. package/dist/lib/components/Grid/index.js +57 -39
  46. package/dist/lib/components/Grid/index.mjs +1 -1
  47. package/dist/lib/components/Grid/useGrid.js +19 -14
  48. package/dist/lib/components/Grid/useGrid.mjs +1 -1
  49. package/dist/lib/components/IconButton/index.js +10 -10
  50. package/dist/lib/components/IconButton/index.mjs +1 -1
  51. package/dist/lib/components/Modal/ModalRoot.d.ts +2 -2
  52. package/dist/lib/components/Radio/index.js +2 -2
  53. package/dist/lib/components/Radio/index.mjs +1 -1
  54. package/dist/lib/components/RadioCards/RadioCardsRoot.d.ts +3 -1
  55. package/dist/lib/components/RadioCards/index.d.ts +1 -1
  56. package/dist/lib/components/SearchBar/index.js +2 -2
  57. package/dist/lib/components/SearchBar/index.mjs +1 -1
  58. package/dist/lib/components/Select/index.d.ts +4 -4
  59. package/dist/lib/components/Select/index.js +2 -2
  60. package/dist/lib/components/Select/index.mjs +1 -1
  61. package/dist/lib/components/Separator/index.d.ts +1 -1
  62. package/dist/lib/components/SideBar/index.d.ts +27 -0
  63. package/dist/lib/components/SideBar/index.js +17 -4
  64. package/dist/lib/components/SideBar/index.mjs +1 -1
  65. package/dist/lib/components/Slider/index.d.ts +1 -1
  66. package/dist/lib/components/Table/index.d.ts +1 -1
  67. package/dist/lib/components/Table/index.js +17 -10
  68. package/dist/lib/components/Table/index.mjs +1 -1
  69. package/dist/lib/components/Tabs/DynamicTabs.d.ts +4 -2
  70. package/dist/lib/components/Tabs/DynamicTabs.js +21 -18
  71. package/dist/lib/components/Tabs/DynamicTabs.mjs +1 -1
  72. package/dist/lib/components/TextField/index.js +2 -0
  73. package/dist/lib/components/TextField/index.mjs +1 -1
  74. package/dist/lib/tsconfig.tsbuildinfo +1 -1
  75. package/dist/tsconfig.tsbuildinfo +1 -1
  76. package/package.json +150 -150
package/README.md CHANGED
@@ -1,226 +1,225 @@
1
- # LOTTE UI COMPONENT LIBRARY
2
-
3
- <br />
4
-
5
- ## 목차
6
-
7
- - [Introduction](#introduction)
8
- - [Installation](#installation)
9
- - [Setup](#setup)
10
- - [Usage](#usage)
11
- - [Components](#components)
12
- - [Theme](#theme)
13
- - [License](#license)
14
-
15
- ## Introduction
16
-
17
- 모든 L-UI 구성 요소를 내보내는 단일 패키지입니다.
18
-
19
- 일관되고 통일된 컴포넌트를 제공하며 사용자 정의 및 재사용 가능합니다.
20
-
21
- 이 라이브러리는 React로 구축된 프로젝트를 지원합니다.
22
-
23
- ## Installation
24
-
25
- 패키지를 설치하기 위해 아래 명령어를 사용합니다.
26
-
27
- ```bash
28
- npm i @lotte-innovate/lui
29
- ```
30
-
31
- ```bash
32
- yarn add @lotte-innovate/lui
33
- ```
34
-
35
- ## Setup
36
-
37
- 패키지를 설치한 후 css 스타일을 프로젝트로 가져옵니다.
38
-
39
- 프로젝트 App 진입 파일에 다음 줄을 추가해줍니다.
40
-
41
- ```
42
- import '@lotte-innovate/lui/dist/globals.css';
43
- ```
44
-
45
- ## Usage
46
-
47
- React 프로젝트에서 컴포넌트를 사용하는 방법에 대한 예시입니다.
48
-
49
- ```javascript
50
- import React from 'react';
51
- import { Button } from '@lotte-innovate/lui';
52
-
53
- const App = () => {
54
- return (
55
- <div>
56
- <Button onClick={() => alert('Button clicked!')}>Click Me</Button>
57
- </div>
58
- );
59
- };
60
-
61
- export default App;
62
- ```
63
-
64
- 컴포넌트에서 아이콘을 사용하려면, 다음과 같은 방법으로 아이콘을 가져올 수 있습니다.
65
-
66
- ```javascript
67
- import React from 'react';
68
- import { IconButton } from '@lotte-innovate/lui';
69
- import { MagnifyingGlassIcon } from '@radix-ui/react-icons';
70
-
71
- const App = () => {
72
- return (
73
- <div>
74
- <IconButton>
75
- <MagnifyingGlassIcon />
76
- </IconButton>
77
- </div>
78
- );
79
- };
80
-
81
- export default App;
82
- ```
83
-
84
- ## Components
85
-
86
- <br />
87
-
88
- <details>
89
- <summary>컴포넌트 목록</summary>
90
-
91
- | 구분 | 종류 |
92
- | ------------------- | ----------------------------------------------------------------------------------------------------------------------------- |
93
- | Typography 컴포넌트 | Header, Text |
94
- | 기본 컴포넌트 | Avatar, Badge, Button, IconButton, Label |
95
- | 입력 컴포넌트 | DatePicker, Editor, Slider, TextArea, TextField |
96
- | 선택 컴포넌트 | Checkbox, CheckboxCards, CheckboxGroup, Radio, RadioCards, RadioGroup, Select, Toggle, ToggleGroup, ToggleSwitch |
97
- | 네비게이션 컴포넌트 | Breadcrumb, DynamicTabs, GNB, Menubar, NavigationMenu, SNB, Tab Nav, Tabs |
98
- | 레이아웃 컴포넌트 | AspectRatio, Box, Card, Collapsible, Container, Flex, Footer, Grid, GridLayout, Inset, ScrollArea, Separator, Table, Timeline |
99
- | 피드백 컴포넌트 | AlertDialog, Dialog, HoverCard, Modal, Popover, Toast, Tooltip |
100
- | 로딩 컴포넌트 | Progress, Skeleton, Spinner |
101
- | 메뉴 선택 컴포넌트 | ContextMenu, DropdownMenu, SegmentedControl |
102
- | 그 외 컴포넌트 | Accordian, Callout, DataList, SearchBar |
103
-
104
- </details>
105
- <details>
106
- <summary>차트 목록</summary>
107
-
108
- | 구분 | 종류 |
109
- | --------- | ------------- |
110
- | 비교 차트 | Bar, Line |
111
- | 구성 차트 | Pie, Doughnut |
112
- | 분포 차트 | Bubble |
113
- | 관계 차트 | Radar |
114
-
115
- </details>
116
-
117
- <details>
118
- <summary>공통 Props 목록</summary>
119
-
120
- | name | description | 단계 | option | 테마적용여부 |
121
- | ---------- | ------------------------------------------------- | -------- | --------------------------------------------- | ------------ |
122
- | Color | 27가지 색상을 라이트/다크/알파/알파다크 모드 제공 | 1~12단계 | blue, crimson, teal, orange, purple, amber... | O |
123
- | Radius | 컴포넌트의 둥글기 적용 | 5단계 | none, small, medium, large, full | O |
124
- | Scaling | 컴포넌트의 비율 | 5단계 | 90%, 95%, 100%, 105%, 110% | O |
125
- | Weight | 컴포넌트의 텍스트 굵기 | 4단계 | regular, medium, semibold, bold | O |
126
- | Appearance | 컴포넌트의 디자인 스타일 | 6단계 | classic, ghost, outline, soft, solid, surface | X |
127
- | Size | 컴포넌트의 크기 | 5단계 | x-small, small, medium, large, x-large | X |
128
-
129
- </details>
130
-
131
- <br />
132
-
133
- ## Theme
134
-
135
- 각 컴포넌트들은 공통 Props를 개별적으로 적용할 수도 있고, 테마를 통해 컴포넌트의 스타일을 한번에 변경할 수도 있습니다.
136
-
137
- L-UI는 테마 컨텍스트를 제공하여 `Color`, `Radius`, `Scaling`, `Weight` 를 모든 컴포넌트에 동일한 스타일을 지정할 수 있습니다..
138
-
139
- 먼저 App 최상단에 `LuiThemeProvider`를 추가하여 테마 컨텍스트를 제공합니다.
140
-
141
- > Next.js와 같은 프레임워크를 사용하는 프로젝트에서 사용 예시
142
-
143
- ```javascript
144
- import { LuiThemeProvider } from '@lotte-innovate/lui';
145
-
146
- export default function RootLayout({
147
- children,
148
- }: Readonly<{
149
- children: React.ReactNode;
150
- }>) {
151
- return (
152
- <html lang="en" className="bg-white">
153
- <body>
154
- <LuiThemeProvider>{children}</LuiThemeProvider>
155
- </body>
156
- </html>
157
- );
158
- }
159
-
160
- ```
161
-
162
- > 클라이언트 사이드 프로젝트에서 사용 예시
163
-
164
- ```javascript
165
- import { LuiThemeProvider } from '@lotte-innovate/lui';
166
-
167
- const root = ReactDOM.createRoot(document.getElementById('root'));
168
- root.render(
169
- <LuiThemeProvider>
170
- <App />
171
- </LuiThemeProvider>,
172
- );
173
- ```
174
-
175
- 테마를 변경하려면 `useTheme`훅을 사용합니다.
176
-
177
- `useTheme`훅은 현재 테마와 테마를 업데이트할 수 있는 함수를 제공합니다.
178
-
179
- ```javascript
180
- import { useTheme, Button } from '@lotte-innovate/lui';
181
-
182
- const ThemeChanger = () => {
183
- const { theme, updateTheme } = useTheme();
184
-
185
- // 초기 값 설정 시
186
- theme.themeRadius = 'none';
187
- theme.themeColor = 'olive';
188
- theme.themeScaling = '90%';
189
- theme.themeWeight = 'regular';
190
-
191
- // 테마 변경
192
- updateTheme({ themeRadius: 'full', themeColor: 'amber', themeScaling: '110%' });
193
-
194
- return (
195
- <div>
196
- <Button>버튼</Button>
197
- </div>
198
- );
199
- };
200
- ```
201
-
202
- 테마가 적용되었지만 일부 컴포넌트는 스타일을 다르게 하고 싶은 경우, 각 컴포넌트에 직접 Props를 전달하여 스타일을 재정의할 수 있습니다.
203
-
204
- ```javascript
205
- import { useTheme, Button } from '@lotte-innovate/lui';
206
-
207
- const ThemeChanger = () => {
208
- const { theme } = useTheme();
209
-
210
- theme.themeRadius: 'full';
211
- theme.themeColor: 'blue';
212
-
213
- return (
214
- <div>
215
- <Button>테마 적용 버튼</Button>
216
- <Button radius="none" color="crimson">테마 미적용 버튼</Button>
217
- </div>
218
- );
219
- };
220
- ```
221
-
222
- <br />
223
-
224
- ## License
225
-
226
- @lotte-innovate
1
+ # LOTTE UI COMPONENT LIBRARY
2
+
3
+ <br />
4
+
5
+ ## 목차
6
+
7
+ - [Introduction](#introduction)
8
+ - [Installation](#installation)
9
+ - [Setup](#setup)
10
+ - [Usage](#usage)
11
+ - [Components](#components)
12
+ - [Theme](#theme)
13
+ - [License](#license)
14
+
15
+ ## Introduction
16
+
17
+ 모든 L-UI 구성 요소를 내보내는 단일 패키지입니다.
18
+
19
+ 일관되고 통일된 컴포넌트를 제공하며 사용자 정의 및 재사용 가능합니다.
20
+
21
+ 이 라이브러리는 React로 구축된 프로젝트를 지원합니다.
22
+
23
+ ## Installation
24
+
25
+ 패키지를 설치하기 위해 아래 명령어를 사용합니다.
26
+
27
+ ```bash
28
+ npm i @lotte-innovate/lui
29
+ ```
30
+
31
+ ```bash
32
+ yarn add @lotte-innovate/lui
33
+ ```
34
+
35
+ ## Setup
36
+
37
+ 패키지를 설치한 후 css 스타일을 프로젝트로 가져옵니다.
38
+
39
+ 프로젝트 App 진입 파일에 다음 줄을 추가해줍니다.
40
+
41
+ ```javascript
42
+ import '@lotte-innovate/lui/dist/globals.css';
43
+ ```
44
+
45
+ ## Usage
46
+
47
+ React 프로젝트에서 컴포넌트를 사용하는 방법에 대한 예시입니다.
48
+
49
+ ```tsx
50
+ import React from 'react';
51
+ import { Button } from '@lotte-innovate/lui';
52
+
53
+ const App = () => {
54
+ return (
55
+ <div>
56
+ <Button onClick={() => alert('Button clicked!')}>Click Me</Button>
57
+ </div>
58
+ );
59
+ };
60
+
61
+ export default App;
62
+ ```
63
+
64
+ 컴포넌트에서 아이콘을 사용하려면, 다음과 같은 방법으로 아이콘을 가져올 수 있습니다.
65
+
66
+ ```tsx
67
+ import React from 'react';
68
+ import { IconButton } from '@lotte-innovate/lui';
69
+ import { MagnifyingGlassIcon } from '@radix-ui/react-icons';
70
+
71
+ const App = () => {
72
+ return (
73
+ <div>
74
+ <IconButton>
75
+ <MagnifyingGlassIcon />
76
+ </IconButton>
77
+ </div>
78
+ );
79
+ };
80
+
81
+ export default App;
82
+ ```
83
+
84
+ ## Components
85
+
86
+ <br />
87
+
88
+ <details>
89
+ <summary>컴포넌트 목록</summary>
90
+
91
+ | 구분 | 종류 |
92
+ | ------------------- | ----------------------------------------------------------------------------------------------------------------------------- |
93
+ | Typography 컴포넌트 | Header, Text |
94
+ | 기본 컴포넌트 | Avatar, Badge, Button, IconButton, Label |
95
+ | 입력 컴포넌트 | DatePicker, Editor, Slider, TextArea, TextField |
96
+ | 선택 컴포넌트 | Checkbox, CheckboxCards, CheckboxGroup, Radio, RadioCards, RadioGroup, Select, Toggle, ToggleGroup, ToggleSwitch |
97
+ | 네비게이션 컴포넌트 | Breadcrumb, DynamicTabs, GNB, Menubar, NavigationMenu, SNB, Tab Nav, Tabs |
98
+ | 레이아웃 컴포넌트 | AspectRatio, Box, Card, Collapsible, Container, Flex, Footer, Grid, GridLayout, Inset, ScrollArea, Separator, Table, Timeline |
99
+ | 피드백 컴포넌트 | AlertDialog, Dialog, HoverCard, Modal, Popover, Toast, Tooltip |
100
+ | 로딩 컴포넌트 | Progress, Skeleton, Spinner |
101
+ | 메뉴 선택 컴포넌트 | ContextMenu, DropdownMenu, SegmentedControl |
102
+ | 그 외 컴포넌트 | Accordian, Callout, DataList, SearchBar |
103
+
104
+ </details>
105
+ <details>
106
+ <summary>차트 목록</summary>
107
+
108
+ | 구분 | 종류 |
109
+ | --------- | ------------- |
110
+ | 비교 차트 | Bar, Line |
111
+ | 구성 차트 | Pie, Doughnut |
112
+ | 분포 차트 | Bubble |
113
+ | 관계 차트 | Radar |
114
+
115
+ </details>
116
+
117
+ <details>
118
+ <summary>공통 Props 목록</summary>
119
+
120
+ | name | description | 단계 | option | 테마적용여부 |
121
+ | ---------- | ------------------------------------------------- | -------- | --------------------------------------------- | ------------ |
122
+ | Color | 27가지 색상을 라이트/다크/알파/알파다크 모드 제공 | 1~12단계 | blue, crimson, teal, orange, purple, amber... | O |
123
+ | Radius | 컴포넌트의 둥글기 적용 | 5단계 | none, small, medium, large, full | O |
124
+ | Scaling | 컴포넌트의 비율 | 5단계 | 90%, 95%, 100%, 105%, 110% | O |
125
+ | Weight | 컴포넌트의 텍스트 굵기 | 4단계 | regular, medium, semibold, bold | O |
126
+ | Appearance | 컴포넌트의 디자인 스타일 | 6단계 | classic, ghost, outline, soft, solid, surface | X |
127
+ | Size | 컴포넌트의 크기 | 5단계 | x-small, small, medium, large, x-large | X |
128
+
129
+ </details>
130
+
131
+ <br />
132
+
133
+ ## Theme
134
+
135
+ 각 컴포넌트들은 공통 Props를 개별적으로 적용할 수도 있고, 테마를 통해 컴포넌트의 스타일을 한번에 변경할 수도 있습니다.
136
+
137
+ L-UI는 테마 컨텍스트를 제공하여 `Color`, `Radius`, `Scaling`, `Weight` 를 모든 컴포넌트에 동일한 스타일을 지정할 수 있습니다..
138
+
139
+ 먼저 App 최상단에 `LuiThemeProvider`를 추가하여 테마 컨텍스트를 제공합니다.
140
+
141
+ > Next.js와 같은 프레임워크를 사용하는 프로젝트에서 사용 예시
142
+
143
+ ```tsx
144
+ import { LuiThemeProvider } from '@lotte-innovate/lui';
145
+
146
+ export default function RootLayout({
147
+ children,
148
+ }: Readonly<{
149
+ children: React.ReactNode;
150
+ }>) {
151
+ return (
152
+ <html lang="en" className="bg-white">
153
+ <body>
154
+ <LuiThemeProvider>{children}</LuiThemeProvider>
155
+ </body>
156
+ </html>
157
+ );
158
+ }
159
+ ```
160
+
161
+ > 클라이언트 사이드 프로젝트에서 사용 예시
162
+
163
+ ```tsx
164
+ import { LuiThemeProvider } from '@lotte-innovate/lui';
165
+
166
+ const root = ReactDOM.createRoot(document.getElementById('root'));
167
+ root.render(
168
+ <LuiThemeProvider>
169
+ <App />
170
+ </LuiThemeProvider>,
171
+ );
172
+ ```
173
+
174
+ 테마를 변경하려면 `useTheme`훅을 사용합니다.
175
+
176
+ `useTheme`훅은 현재 테마와 테마를 업데이트할 수 있는 함수를 제공합니다.
177
+
178
+ ```tsx
179
+ import { useTheme, Button } from '@lotte-innovate/lui';
180
+
181
+ const ThemeChanger = () => {
182
+ const { theme, updateTheme } = useTheme();
183
+
184
+ // 초기 값 설정 시
185
+ theme.themeRadius = 'none';
186
+ theme.themeColor = 'olive';
187
+ theme.themeScaling = '90%';
188
+ theme.themeWeight = 'regular';
189
+
190
+ // 테마 변경 시
191
+ updateTheme({ themeRadius: 'full', themeColor: 'amber', themeScaling: '110%' });
192
+
193
+ return (
194
+ <div>
195
+ <Button>버튼</Button>
196
+ </div>
197
+ );
198
+ };
199
+ ```
200
+
201
+ 테마가 적용되었지만 일부 컴포넌트는 스타일을 다르게 하고 싶은 경우, 각 컴포넌트에 직접 Props를 전달하여 스타일을 재정의할 수 있습니다.
202
+
203
+ ```tsx
204
+ import { useTheme, Button } from '@lotte-innovate/lui';
205
+
206
+ const ThemeChanger = () => {
207
+ const { theme } = useTheme();
208
+
209
+ theme.themeRadius: 'full';
210
+ theme.themeColor: 'blue';
211
+
212
+ return (
213
+ <div>
214
+ <Button>테마 적용 버튼</Button>
215
+ <Button radius="none" color="crimson">테마 미적용 버튼</Button>
216
+ </div>
217
+ );
218
+ };
219
+ ```
220
+
221
+ <br />
222
+
223
+ ## License
224
+
225
+ @lotte-innovate