@exem-ui/react 0.1.0 → 0.2.0

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 (264) hide show
  1. package/LICENSE +190 -0
  2. package/README.en.md +142 -0
  3. package/README.md +156 -18
  4. package/dist/index.d.mts +1166 -37
  5. package/dist/index.d.ts +1166 -37
  6. package/dist/index.js +3055 -130
  7. package/dist/index.js.map +1 -1
  8. package/dist/index.mjs +3016 -27
  9. package/dist/index.mjs.map +1 -1
  10. package/package.json +24 -143
  11. package/dist/Button-CMenVfb7.d.mts +0 -35
  12. package/dist/Button-CMenVfb7.d.ts +0 -35
  13. package/dist/Select-DMvWV_rF.d.mts +0 -94
  14. package/dist/Select-DMvWV_rF.d.ts +0 -94
  15. package/dist/avatar/index.d.mts +0 -37
  16. package/dist/avatar/index.d.ts +0 -37
  17. package/dist/avatar/index.js +0 -13
  18. package/dist/avatar/index.js.map +0 -1
  19. package/dist/avatar/index.mjs +0 -4
  20. package/dist/avatar/index.mjs.map +0 -1
  21. package/dist/badge/index.d.mts +0 -29
  22. package/dist/badge/index.d.ts +0 -29
  23. package/dist/badge/index.js +0 -12
  24. package/dist/badge/index.js.map +0 -1
  25. package/dist/badge/index.mjs +0 -3
  26. package/dist/badge/index.mjs.map +0 -1
  27. package/dist/breadcrumb/index.d.mts +0 -43
  28. package/dist/breadcrumb/index.d.ts +0 -43
  29. package/dist/breadcrumb/index.js +0 -13
  30. package/dist/breadcrumb/index.js.map +0 -1
  31. package/dist/breadcrumb/index.mjs +0 -4
  32. package/dist/breadcrumb/index.mjs.map +0 -1
  33. package/dist/button/index.d.mts +0 -9
  34. package/dist/button/index.d.ts +0 -9
  35. package/dist/button/index.js +0 -29
  36. package/dist/button/index.js.map +0 -1
  37. package/dist/button/index.mjs +0 -12
  38. package/dist/button/index.mjs.map +0 -1
  39. package/dist/checkbox/index.d.mts +0 -54
  40. package/dist/checkbox/index.d.ts +0 -54
  41. package/dist/checkbox/index.js +0 -13
  42. package/dist/checkbox/index.js.map +0 -1
  43. package/dist/checkbox/index.mjs +0 -4
  44. package/dist/checkbox/index.mjs.map +0 -1
  45. package/dist/chunk-34QIGWCT.mjs +0 -10
  46. package/dist/chunk-34QIGWCT.mjs.map +0 -1
  47. package/dist/chunk-3FPMWAQT.js +0 -30
  48. package/dist/chunk-3FPMWAQT.js.map +0 -1
  49. package/dist/chunk-3HMT3DQV.js +0 -104
  50. package/dist/chunk-3HMT3DQV.js.map +0 -1
  51. package/dist/chunk-4WAO7CUT.mjs +0 -95
  52. package/dist/chunk-4WAO7CUT.mjs.map +0 -1
  53. package/dist/chunk-5QX4TO4F.js +0 -61
  54. package/dist/chunk-5QX4TO4F.js.map +0 -1
  55. package/dist/chunk-5TEFN2CW.js +0 -97
  56. package/dist/chunk-5TEFN2CW.js.map +0 -1
  57. package/dist/chunk-5TES5PG6.js +0 -41
  58. package/dist/chunk-5TES5PG6.js.map +0 -1
  59. package/dist/chunk-5TVMECVF.js +0 -148
  60. package/dist/chunk-5TVMECVF.js.map +0 -1
  61. package/dist/chunk-5WGNZX7Z.mjs +0 -27
  62. package/dist/chunk-5WGNZX7Z.mjs.map +0 -1
  63. package/dist/chunk-AQ3OIM2T.js +0 -103
  64. package/dist/chunk-AQ3OIM2T.js.map +0 -1
  65. package/dist/chunk-AU5NTBK3.js +0 -361
  66. package/dist/chunk-AU5NTBK3.js.map +0 -1
  67. package/dist/chunk-DJHGCJR4.mjs +0 -224
  68. package/dist/chunk-DJHGCJR4.mjs.map +0 -1
  69. package/dist/chunk-DPUTW5KD.mjs +0 -74
  70. package/dist/chunk-DPUTW5KD.mjs.map +0 -1
  71. package/dist/chunk-E53FHDVN.mjs +0 -336
  72. package/dist/chunk-E53FHDVN.mjs.map +0 -1
  73. package/dist/chunk-ECRQD7UU.js +0 -82
  74. package/dist/chunk-ECRQD7UU.js.map +0 -1
  75. package/dist/chunk-FB4ESGOX.mjs +0 -59
  76. package/dist/chunk-FB4ESGOX.mjs.map +0 -1
  77. package/dist/chunk-FDX4IQK5.js +0 -76
  78. package/dist/chunk-FDX4IQK5.js.map +0 -1
  79. package/dist/chunk-FOMIUDRM.js +0 -96
  80. package/dist/chunk-FOMIUDRM.js.map +0 -1
  81. package/dist/chunk-FR5F3VTU.js +0 -139
  82. package/dist/chunk-FR5F3VTU.js.map +0 -1
  83. package/dist/chunk-GW53LH3I.mjs +0 -81
  84. package/dist/chunk-GW53LH3I.mjs.map +0 -1
  85. package/dist/chunk-GXMRIT5E.mjs +0 -94
  86. package/dist/chunk-GXMRIT5E.mjs.map +0 -1
  87. package/dist/chunk-IANSI7F7.mjs +0 -393
  88. package/dist/chunk-IANSI7F7.mjs.map +0 -1
  89. package/dist/chunk-IDM6MZHF.js +0 -415
  90. package/dist/chunk-IDM6MZHF.js.map +0 -1
  91. package/dist/chunk-J5ZYQ3TP.js +0 -104
  92. package/dist/chunk-J5ZYQ3TP.js.map +0 -1
  93. package/dist/chunk-KPAUBWZA.mjs +0 -39
  94. package/dist/chunk-KPAUBWZA.mjs.map +0 -1
  95. package/dist/chunk-L7P2NDST.mjs +0 -124
  96. package/dist/chunk-L7P2NDST.mjs.map +0 -1
  97. package/dist/chunk-M6OWN7QH.js +0 -118
  98. package/dist/chunk-M6OWN7QH.js.map +0 -1
  99. package/dist/chunk-MQVHREEI.js +0 -448
  100. package/dist/chunk-MQVHREEI.js.map +0 -1
  101. package/dist/chunk-MT47ECUN.js +0 -127
  102. package/dist/chunk-MT47ECUN.js.map +0 -1
  103. package/dist/chunk-N6U54JI4.mjs +0 -126
  104. package/dist/chunk-N6U54JI4.mjs.map +0 -1
  105. package/dist/chunk-NDG4LR3Q.js +0 -139
  106. package/dist/chunk-NDG4LR3Q.js.map +0 -1
  107. package/dist/chunk-PPD4BU4W.mjs +0 -80
  108. package/dist/chunk-PPD4BU4W.mjs.map +0 -1
  109. package/dist/chunk-PU5NO5EZ.js +0 -4
  110. package/dist/chunk-PU5NO5EZ.js.map +0 -1
  111. package/dist/chunk-Q442ZDTI.mjs +0 -117
  112. package/dist/chunk-Q442ZDTI.mjs.map +0 -1
  113. package/dist/chunk-QH23RO3C.mjs +0 -137
  114. package/dist/chunk-QH23RO3C.mjs.map +0 -1
  115. package/dist/chunk-REBHUF4L.js +0 -226
  116. package/dist/chunk-REBHUF4L.js.map +0 -1
  117. package/dist/chunk-RGB3QLQT.js +0 -275
  118. package/dist/chunk-RGB3QLQT.js.map +0 -1
  119. package/dist/chunk-T7U2QRLC.js +0 -94
  120. package/dist/chunk-T7U2QRLC.js.map +0 -1
  121. package/dist/chunk-TEHHJ3CS.mjs +0 -73
  122. package/dist/chunk-TEHHJ3CS.mjs.map +0 -1
  123. package/dist/chunk-TJY4MIBC.js +0 -117
  124. package/dist/chunk-TJY4MIBC.js.map +0 -1
  125. package/dist/chunk-VCMZQOQM.mjs +0 -102
  126. package/dist/chunk-VCMZQOQM.mjs.map +0 -1
  127. package/dist/chunk-VKN4H4WI.mjs +0 -3
  128. package/dist/chunk-VKN4H4WI.mjs.map +0 -1
  129. package/dist/chunk-VSB25XTY.js +0 -12
  130. package/dist/chunk-VSB25XTY.js.map +0 -1
  131. package/dist/chunk-VWTE74UT.mjs +0 -96
  132. package/dist/chunk-VWTE74UT.mjs.map +0 -1
  133. package/dist/chunk-WBTL7PBV.js +0 -105
  134. package/dist/chunk-WBTL7PBV.js.map +0 -1
  135. package/dist/chunk-WOK3EP3O.js +0 -83
  136. package/dist/chunk-WOK3EP3O.js.map +0 -1
  137. package/dist/chunk-WWT73GGM.mjs +0 -83
  138. package/dist/chunk-WWT73GGM.mjs.map +0 -1
  139. package/dist/chunk-XBDXTRK3.mjs +0 -102
  140. package/dist/chunk-XBDXTRK3.mjs.map +0 -1
  141. package/dist/chunk-YGBEKZWU.mjs +0 -81
  142. package/dist/chunk-YGBEKZWU.mjs.map +0 -1
  143. package/dist/chunk-YVFLRPFV.mjs +0 -72
  144. package/dist/chunk-YVFLRPFV.mjs.map +0 -1
  145. package/dist/chunk-ZMVBIQ2Z.mjs +0 -253
  146. package/dist/chunk-ZMVBIQ2Z.mjs.map +0 -1
  147. package/dist/chunk-ZWCMSHDP.mjs +0 -425
  148. package/dist/chunk-ZWCMSHDP.mjs.map +0 -1
  149. package/dist/flat/index.d.mts +0 -13
  150. package/dist/flat/index.d.ts +0 -13
  151. package/dist/flat/index.js +0 -31
  152. package/dist/flat/index.js.map +0 -1
  153. package/dist/flat/index.mjs +0 -10
  154. package/dist/flat/index.mjs.map +0 -1
  155. package/dist/flat/segment.d.mts +0 -39
  156. package/dist/flat/segment.d.ts +0 -39
  157. package/dist/flat/segment.js +0 -13
  158. package/dist/flat/segment.js.map +0 -1
  159. package/dist/flat/segment.mjs +0 -4
  160. package/dist/flat/segment.mjs.map +0 -1
  161. package/dist/flat/select.d.mts +0 -58
  162. package/dist/flat/select.d.ts +0 -58
  163. package/dist/flat/select.js +0 -14
  164. package/dist/flat/select.js.map +0 -1
  165. package/dist/flat/select.mjs +0 -5
  166. package/dist/flat/select.mjs.map +0 -1
  167. package/dist/flat/tooltip.d.mts +0 -98
  168. package/dist/flat/tooltip.d.ts +0 -98
  169. package/dist/flat/tooltip.js +0 -17
  170. package/dist/flat/tooltip.js.map +0 -1
  171. package/dist/flat/tooltip.mjs +0 -4
  172. package/dist/flat/tooltip.mjs.map +0 -1
  173. package/dist/index-CXip5Wb1.d.mts +0 -62
  174. package/dist/index-Drz3P-6Y.d.ts +0 -62
  175. package/dist/input/index.d.mts +0 -82
  176. package/dist/input/index.d.ts +0 -82
  177. package/dist/input/index.js +0 -22
  178. package/dist/input/index.js.map +0 -1
  179. package/dist/input/index.mjs +0 -5
  180. package/dist/input/index.mjs.map +0 -1
  181. package/dist/loading/index.d.mts +0 -54
  182. package/dist/loading/index.d.ts +0 -54
  183. package/dist/loading/index.js +0 -12
  184. package/dist/loading/index.js.map +0 -1
  185. package/dist/loading/index.mjs +0 -3
  186. package/dist/loading/index.mjs.map +0 -1
  187. package/dist/messageBox/index.d.mts +0 -33
  188. package/dist/messageBox/index.d.ts +0 -33
  189. package/dist/messageBox/index.js +0 -13
  190. package/dist/messageBox/index.js.map +0 -1
  191. package/dist/messageBox/index.mjs +0 -4
  192. package/dist/messageBox/index.mjs.map +0 -1
  193. package/dist/modal/index.d.mts +0 -97
  194. package/dist/modal/index.d.ts +0 -97
  195. package/dist/modal/index.js +0 -15
  196. package/dist/modal/index.js.map +0 -1
  197. package/dist/modal/index.mjs +0 -6
  198. package/dist/modal/index.mjs.map +0 -1
  199. package/dist/picker/index.d.mts +0 -12
  200. package/dist/picker/index.d.ts +0 -12
  201. package/dist/picker/index.js +0 -13
  202. package/dist/picker/index.js.map +0 -1
  203. package/dist/picker/index.mjs +0 -4
  204. package/dist/picker/index.mjs.map +0 -1
  205. package/dist/progress/index.d.mts +0 -36
  206. package/dist/progress/index.d.ts +0 -36
  207. package/dist/progress/index.js +0 -12
  208. package/dist/progress/index.js.map +0 -1
  209. package/dist/progress/index.mjs +0 -3
  210. package/dist/progress/index.mjs.map +0 -1
  211. package/dist/radio/index.d.mts +0 -39
  212. package/dist/radio/index.d.ts +0 -39
  213. package/dist/radio/index.js +0 -12
  214. package/dist/radio/index.js.map +0 -1
  215. package/dist/radio/index.mjs +0 -3
  216. package/dist/radio/index.mjs.map +0 -1
  217. package/dist/scrollArea/index.d.mts +0 -31
  218. package/dist/scrollArea/index.d.ts +0 -31
  219. package/dist/scrollArea/index.js +0 -16
  220. package/dist/scrollArea/index.js.map +0 -1
  221. package/dist/scrollArea/index.mjs +0 -3
  222. package/dist/scrollArea/index.mjs.map +0 -1
  223. package/dist/segment/index.d.mts +0 -46
  224. package/dist/segment/index.d.ts +0 -46
  225. package/dist/segment/index.js +0 -12
  226. package/dist/segment/index.js.map +0 -1
  227. package/dist/segment/index.mjs +0 -3
  228. package/dist/segment/index.mjs.map +0 -1
  229. package/dist/star/index.d.mts +0 -30
  230. package/dist/star/index.d.ts +0 -30
  231. package/dist/star/index.js +0 -12
  232. package/dist/star/index.js.map +0 -1
  233. package/dist/star/index.mjs +0 -3
  234. package/dist/star/index.mjs.map +0 -1
  235. package/dist/switch/index.d.mts +0 -32
  236. package/dist/switch/index.d.ts +0 -32
  237. package/dist/switch/index.js +0 -12
  238. package/dist/switch/index.js.map +0 -1
  239. package/dist/switch/index.mjs +0 -3
  240. package/dist/switch/index.mjs.map +0 -1
  241. package/dist/tabs/index.d.mts +0 -52
  242. package/dist/tabs/index.d.ts +0 -52
  243. package/dist/tabs/index.js +0 -12
  244. package/dist/tabs/index.js.map +0 -1
  245. package/dist/tabs/index.mjs +0 -3
  246. package/dist/tabs/index.mjs.map +0 -1
  247. package/dist/tag/index.d.mts +0 -68
  248. package/dist/tag/index.d.ts +0 -68
  249. package/dist/tag/index.js +0 -17
  250. package/dist/tag/index.js.map +0 -1
  251. package/dist/tag/index.mjs +0 -4
  252. package/dist/tag/index.mjs.map +0 -1
  253. package/dist/toast/index.d.mts +0 -175
  254. package/dist/toast/index.d.ts +0 -175
  255. package/dist/toast/index.js +0 -25
  256. package/dist/toast/index.js.map +0 -1
  257. package/dist/toast/index.mjs +0 -4
  258. package/dist/toast/index.mjs.map +0 -1
  259. package/dist/tooltip/index.d.mts +0 -26
  260. package/dist/tooltip/index.d.ts +0 -26
  261. package/dist/tooltip/index.js +0 -12
  262. package/dist/tooltip/index.js.map +0 -1
  263. package/dist/tooltip/index.mjs +0 -3
  264. package/dist/tooltip/index.mjs.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"names":[],"mappings":"","file":"segment.js"}
@@ -1,4 +0,0 @@
1
- export { FlatSegment } from '../chunk-34QIGWCT.mjs';
2
- import '../chunk-Q442ZDTI.mjs';
3
- //# sourceMappingURL=segment.mjs.map
4
- //# sourceMappingURL=segment.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"names":[],"mappings":"","file":"segment.mjs"}
@@ -1,58 +0,0 @@
1
- import * as react_jsx_runtime from 'react/jsx-runtime';
2
- import { ComponentProps } from 'react';
3
- import { S as Select } from '../Select-DMvWV_rF.mjs';
4
- import '@radix-ui/react-select';
5
-
6
- type FlatSelectOption = {
7
- value: string;
8
- label: string | React.ReactNode;
9
- /** 아이템 오른쪽에 표시할 슬롯 요소 */
10
- rightSlot?: React.ReactNode;
11
- disabled?: boolean;
12
- };
13
- interface FlatSelectProps extends React.ComponentProps<typeof Select> {
14
- /** 선택 가능한 옵션 배열 */
15
- options: FlatSelectOption[];
16
- /** 값이 선택되지 않았을 때 표시할 텍스트 */
17
- placeholder?: string;
18
- /** 드롭다운 열림/닫힘 상태 변경 핸들러 */
19
- onOpenChange?: (open: boolean) => void;
20
- /** 포커스 획득 핸들러 */
21
- onFocus?: () => void;
22
- /** 포커스 해제 핸들러 */
23
- onBlur?: () => void;
24
- /** 트리거 왼쪽에 표시할 아이콘 */
25
- leftIcon?: ComponentProps<typeof Select.Trigger>['leftIcon'];
26
- /** 라벨 텍스트 */
27
- label?: ComponentProps<typeof Select.Label>['children'];
28
- /** 필수 입력 여부 */
29
- required?: ComponentProps<typeof Select.Label>['required'];
30
- /** 설명 텍스트 */
31
- description?: ComponentProps<typeof Select.Description>['children'];
32
- /** 드롭다운 리스트 className */
33
- listClassName?: string;
34
- }
35
- /**
36
- * Select 컴포넌트의 간소화된 Flat API입니다.
37
- * options 배열만 전달하면 Compound Component 없이 간편하게 사용할 수 있습니다.
38
- *
39
- * @example
40
- * ```tsx
41
- * <FlatSelect
42
- * options={[
43
- * { value: '1', label: '옵션 1' },
44
- * { value: '2', label: '옵션 2' },
45
- * ]}
46
- * placeholder="선택하세요"
47
- * label="항목"
48
- * />
49
- * ```
50
- *
51
- * @see {@link FlatSelectProps} props 상세
52
- */
53
- declare function FlatSelect({ options, placeholder, onBlur, onFocus, onOpenChange, label, description, required, listClassName, leftIcon, ...props }: FlatSelectProps): react_jsx_runtime.JSX.Element;
54
- declare namespace FlatSelect {
55
- var displayName: string;
56
- }
57
-
58
- export { FlatSelect, type FlatSelectOption, type FlatSelectProps };
@@ -1,58 +0,0 @@
1
- import * as react_jsx_runtime from 'react/jsx-runtime';
2
- import { ComponentProps } from 'react';
3
- import { S as Select } from '../Select-DMvWV_rF.js';
4
- import '@radix-ui/react-select';
5
-
6
- type FlatSelectOption = {
7
- value: string;
8
- label: string | React.ReactNode;
9
- /** 아이템 오른쪽에 표시할 슬롯 요소 */
10
- rightSlot?: React.ReactNode;
11
- disabled?: boolean;
12
- };
13
- interface FlatSelectProps extends React.ComponentProps<typeof Select> {
14
- /** 선택 가능한 옵션 배열 */
15
- options: FlatSelectOption[];
16
- /** 값이 선택되지 않았을 때 표시할 텍스트 */
17
- placeholder?: string;
18
- /** 드롭다운 열림/닫힘 상태 변경 핸들러 */
19
- onOpenChange?: (open: boolean) => void;
20
- /** 포커스 획득 핸들러 */
21
- onFocus?: () => void;
22
- /** 포커스 해제 핸들러 */
23
- onBlur?: () => void;
24
- /** 트리거 왼쪽에 표시할 아이콘 */
25
- leftIcon?: ComponentProps<typeof Select.Trigger>['leftIcon'];
26
- /** 라벨 텍스트 */
27
- label?: ComponentProps<typeof Select.Label>['children'];
28
- /** 필수 입력 여부 */
29
- required?: ComponentProps<typeof Select.Label>['required'];
30
- /** 설명 텍스트 */
31
- description?: ComponentProps<typeof Select.Description>['children'];
32
- /** 드롭다운 리스트 className */
33
- listClassName?: string;
34
- }
35
- /**
36
- * Select 컴포넌트의 간소화된 Flat API입니다.
37
- * options 배열만 전달하면 Compound Component 없이 간편하게 사용할 수 있습니다.
38
- *
39
- * @example
40
- * ```tsx
41
- * <FlatSelect
42
- * options={[
43
- * { value: '1', label: '옵션 1' },
44
- * { value: '2', label: '옵션 2' },
45
- * ]}
46
- * placeholder="선택하세요"
47
- * label="항목"
48
- * />
49
- * ```
50
- *
51
- * @see {@link FlatSelectProps} props 상세
52
- */
53
- declare function FlatSelect({ options, placeholder, onBlur, onFocus, onOpenChange, label, description, required, listClassName, leftIcon, ...props }: FlatSelectProps): react_jsx_runtime.JSX.Element;
54
- declare namespace FlatSelect {
55
- var displayName: string;
56
- }
57
-
58
- export { FlatSelect, type FlatSelectOption, type FlatSelectProps };
@@ -1,14 +0,0 @@
1
- 'use strict';
2
-
3
- var chunkFDX4IQK5_js = require('../chunk-FDX4IQK5.js');
4
- require('../chunk-MQVHREEI.js');
5
- require('../chunk-5M47B2XJ.js');
6
-
7
-
8
-
9
- Object.defineProperty(exports, "FlatSelect", {
10
- enumerable: true,
11
- get: function () { return chunkFDX4IQK5_js.FlatSelect; }
12
- });
13
- //# sourceMappingURL=select.js.map
14
- //# sourceMappingURL=select.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"names":[],"mappings":"","file":"select.js"}
@@ -1,5 +0,0 @@
1
- export { FlatSelect } from '../chunk-DPUTW5KD.mjs';
2
- import '../chunk-ZWCMSHDP.mjs';
3
- import '../chunk-LZWKMQJL.mjs';
4
- //# sourceMappingURL=select.mjs.map
5
- //# sourceMappingURL=select.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"names":[],"mappings":"","file":"select.mjs"}
@@ -1,98 +0,0 @@
1
- import * as React$1 from 'react';
2
- import { ComponentProps } from 'react';
3
- import * as react_jsx_runtime from 'react/jsx-runtime';
4
- import { Tooltip } from '../tooltip/index.mjs';
5
- import 'class-variance-authority/types';
6
- import '@exem-ui/core/utils';
7
- import '@radix-ui/react-tooltip';
8
-
9
- interface FlatTooltipProps {
10
- /** 툴팁을 적용할 자식 요소 */
11
- children: React.ReactNode;
12
- /** 툴팁 제목 (선택) */
13
- title?: React.ReactNode;
14
- /** 툴팁 크기 */
15
- size: ComponentProps<typeof Tooltip.Content>['size'];
16
- /** 툴팁 표시 위치 */
17
- side?: ComponentProps<typeof Tooltip.Content>['side'];
18
- /** 툴팁 정렬 */
19
- align?: ComponentProps<typeof Tooltip.Content>['align'];
20
- /** 사이드 방향 오프셋 (px) */
21
- sideOffset?: ComponentProps<typeof Tooltip.Content>['sideOffset'];
22
- /** 정렬 방향 오프셋 (px) */
23
- alignOffset?: ComponentProps<typeof Tooltip.Content>['alignOffset'];
24
- /** 툴팁 설명 텍스트 */
25
- description: React.ReactNode;
26
- }
27
- /**
28
- * Tooltip 컴포넌트의 간소화된 Flat API입니다.
29
- * Compound Component 없이 props만으로 간편하게 사용할 수 있습니다.
30
- *
31
- * @example
32
- * ```tsx
33
- * <FlatTooltip size="small" description="도움말 텍스트">
34
- * <button>호버하세요</button>
35
- * </FlatTooltip>
36
- *
37
- * <FlatTooltip size="tiny" title="제목" description="설명">
38
- * <span>정보</span>
39
- * </FlatTooltip>
40
- * ```
41
- *
42
- * @see {@link FlatTooltipProps} props 상세
43
- */
44
- declare const FlatTooltip: {
45
- ({ children, title, size, description, ...props }: FlatTooltipProps): react_jsx_runtime.JSX.Element;
46
- displayName: string;
47
- };
48
- /** FlatTooltip 설정 객체 타입 (children 제외) */
49
- type TooltipConfig = Omit<ComponentProps<typeof FlatTooltip>, 'children' | 'size'> & {
50
- /**
51
- * 툴팁 사용 여부
52
- * @default true
53
- */
54
- use?: boolean;
55
- size?: ComponentProps<typeof FlatTooltip>['size'];
56
- };
57
- interface ConditionalTooltipProps {
58
- /** 툴팁으로 감쌀 자식 요소 */
59
- children: React.ReactNode;
60
- /**
61
- * 툴팁 설정값
62
- * - `string`: 기본 tiny 사이즈의 툴팁 description으로 사용
63
- * - `object`: FlatTooltip props를 직접 전달 (`use: false`로 비활성화 가능)
64
- */
65
- tooltip: ComponentProps<typeof FlatTooltip>['description'] | TooltipConfig;
66
- }
67
- /**
68
- * 조건부로 FlatTooltip을 적용하는 래퍼 컴포넌트입니다.
69
- *
70
- * @description
71
- * tooltip prop의 타입에 따라 다르게 동작합니다:
72
- * - `string`: tiny 사이즈의 기본 툴팁으로 렌더링
73
- * - `object` (`use !== false`): 전달된 props로 FlatTooltip 렌더링
74
- * - `object` (`use === false`) 또는 기타: children만 반환 (툴팁 없음)
75
- *
76
- * @example
77
- * ```tsx
78
- * <ConditionalTooltip tooltip="도움말 텍스트">
79
- * <button>버튼</button>
80
- * </ConditionalTooltip>
81
- *
82
- * <ConditionalTooltip tooltip={{ description: "설명", size: "small", side: "top" }}>
83
- * <button>버튼</button>
84
- * </ConditionalTooltip>
85
- *
86
- * <ConditionalTooltip tooltip={{ use: false, description: "" }}>
87
- * <button>툴팁 없음</button>
88
- * </ConditionalTooltip>
89
- * ```
90
- *
91
- * @see {@link ConditionalTooltipProps} props 상세
92
- */
93
- declare function ConditionalTooltip({ children, tooltip }: ConditionalTooltipProps): string | number | bigint | boolean | react_jsx_runtime.JSX.Element | Iterable<React$1.ReactNode> | Promise<string | number | bigint | boolean | React$1.ReactPortal | React$1.ReactElement<unknown, string | React$1.JSXElementConstructor<any>> | Iterable<React$1.ReactNode> | null | undefined> | null | undefined;
94
- declare namespace ConditionalTooltip {
95
- var displayName: string;
96
- }
97
-
98
- export { ConditionalTooltip, type ConditionalTooltipProps, FlatTooltip, type FlatTooltipProps, type TooltipConfig };
@@ -1,98 +0,0 @@
1
- import * as React$1 from 'react';
2
- import { ComponentProps } from 'react';
3
- import * as react_jsx_runtime from 'react/jsx-runtime';
4
- import { Tooltip } from '../tooltip/index.js';
5
- import 'class-variance-authority/types';
6
- import '@exem-ui/core/utils';
7
- import '@radix-ui/react-tooltip';
8
-
9
- interface FlatTooltipProps {
10
- /** 툴팁을 적용할 자식 요소 */
11
- children: React.ReactNode;
12
- /** 툴팁 제목 (선택) */
13
- title?: React.ReactNode;
14
- /** 툴팁 크기 */
15
- size: ComponentProps<typeof Tooltip.Content>['size'];
16
- /** 툴팁 표시 위치 */
17
- side?: ComponentProps<typeof Tooltip.Content>['side'];
18
- /** 툴팁 정렬 */
19
- align?: ComponentProps<typeof Tooltip.Content>['align'];
20
- /** 사이드 방향 오프셋 (px) */
21
- sideOffset?: ComponentProps<typeof Tooltip.Content>['sideOffset'];
22
- /** 정렬 방향 오프셋 (px) */
23
- alignOffset?: ComponentProps<typeof Tooltip.Content>['alignOffset'];
24
- /** 툴팁 설명 텍스트 */
25
- description: React.ReactNode;
26
- }
27
- /**
28
- * Tooltip 컴포넌트의 간소화된 Flat API입니다.
29
- * Compound Component 없이 props만으로 간편하게 사용할 수 있습니다.
30
- *
31
- * @example
32
- * ```tsx
33
- * <FlatTooltip size="small" description="도움말 텍스트">
34
- * <button>호버하세요</button>
35
- * </FlatTooltip>
36
- *
37
- * <FlatTooltip size="tiny" title="제목" description="설명">
38
- * <span>정보</span>
39
- * </FlatTooltip>
40
- * ```
41
- *
42
- * @see {@link FlatTooltipProps} props 상세
43
- */
44
- declare const FlatTooltip: {
45
- ({ children, title, size, description, ...props }: FlatTooltipProps): react_jsx_runtime.JSX.Element;
46
- displayName: string;
47
- };
48
- /** FlatTooltip 설정 객체 타입 (children 제외) */
49
- type TooltipConfig = Omit<ComponentProps<typeof FlatTooltip>, 'children' | 'size'> & {
50
- /**
51
- * 툴팁 사용 여부
52
- * @default true
53
- */
54
- use?: boolean;
55
- size?: ComponentProps<typeof FlatTooltip>['size'];
56
- };
57
- interface ConditionalTooltipProps {
58
- /** 툴팁으로 감쌀 자식 요소 */
59
- children: React.ReactNode;
60
- /**
61
- * 툴팁 설정값
62
- * - `string`: 기본 tiny 사이즈의 툴팁 description으로 사용
63
- * - `object`: FlatTooltip props를 직접 전달 (`use: false`로 비활성화 가능)
64
- */
65
- tooltip: ComponentProps<typeof FlatTooltip>['description'] | TooltipConfig;
66
- }
67
- /**
68
- * 조건부로 FlatTooltip을 적용하는 래퍼 컴포넌트입니다.
69
- *
70
- * @description
71
- * tooltip prop의 타입에 따라 다르게 동작합니다:
72
- * - `string`: tiny 사이즈의 기본 툴팁으로 렌더링
73
- * - `object` (`use !== false`): 전달된 props로 FlatTooltip 렌더링
74
- * - `object` (`use === false`) 또는 기타: children만 반환 (툴팁 없음)
75
- *
76
- * @example
77
- * ```tsx
78
- * <ConditionalTooltip tooltip="도움말 텍스트">
79
- * <button>버튼</button>
80
- * </ConditionalTooltip>
81
- *
82
- * <ConditionalTooltip tooltip={{ description: "설명", size: "small", side: "top" }}>
83
- * <button>버튼</button>
84
- * </ConditionalTooltip>
85
- *
86
- * <ConditionalTooltip tooltip={{ use: false, description: "" }}>
87
- * <button>툴팁 없음</button>
88
- * </ConditionalTooltip>
89
- * ```
90
- *
91
- * @see {@link ConditionalTooltipProps} props 상세
92
- */
93
- declare function ConditionalTooltip({ children, tooltip }: ConditionalTooltipProps): string | number | bigint | boolean | react_jsx_runtime.JSX.Element | Iterable<React$1.ReactNode> | Promise<string | number | bigint | boolean | React$1.ReactPortal | React$1.ReactElement<unknown, string | React$1.JSXElementConstructor<any>> | Iterable<React$1.ReactNode> | null | undefined> | null | undefined;
94
- declare namespace ConditionalTooltip {
95
- var displayName: string;
96
- }
97
-
98
- export { ConditionalTooltip, type ConditionalTooltipProps, FlatTooltip, type FlatTooltipProps, type TooltipConfig };
@@ -1,17 +0,0 @@
1
- 'use strict';
2
-
3
- var chunk3FPMWAQT_js = require('../chunk-3FPMWAQT.js');
4
- require('../chunk-T7U2QRLC.js');
5
-
6
-
7
-
8
- Object.defineProperty(exports, "ConditionalTooltip", {
9
- enumerable: true,
10
- get: function () { return chunk3FPMWAQT_js.ConditionalTooltip; }
11
- });
12
- Object.defineProperty(exports, "FlatTooltip", {
13
- enumerable: true,
14
- get: function () { return chunk3FPMWAQT_js.FlatTooltip; }
15
- });
16
- //# sourceMappingURL=tooltip.js.map
17
- //# sourceMappingURL=tooltip.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"names":[],"mappings":"","file":"tooltip.js"}
@@ -1,4 +0,0 @@
1
- export { ConditionalTooltip, FlatTooltip } from '../chunk-5WGNZX7Z.mjs';
2
- import '../chunk-YVFLRPFV.mjs';
3
- //# sourceMappingURL=tooltip.mjs.map
4
- //# sourceMappingURL=tooltip.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"names":[],"mappings":"","file":"tooltip.mjs"}
@@ -1,62 +0,0 @@
1
- import './Button-CMenVfb7.mjs';
2
- import React__default, { ComponentProps } from 'react';
3
- import { ConditionalTooltip } from './flat/tooltip.mjs';
4
-
5
- type ButtonGroupSize = 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge';
6
- interface ButtonGroupItem {
7
- id: string;
8
- label?: string;
9
- icon?: React__default.ReactElement<{
10
- className?: string;
11
- }>;
12
- /** 툴팁 설정 (문자열 또는 FlatTooltip 설정 객체) */
13
- tooltip?: ComponentProps<typeof ConditionalTooltip>['tooltip'];
14
- onClick?: () => void;
15
- }
16
- interface ButtonGroupProps {
17
- /** 버튼 그룹 스타일 변형 */
18
- variant?: 'contained' | 'outlined';
19
- /** 아이콘만 표시 */
20
- iconOnly?: boolean;
21
- /** 배경색 표시 여부 (뒷 레이어가 보이지 않아야 할 때) */
22
- hasBackground?: boolean;
23
- /** 버튼 크기 */
24
- size?: ButtonGroupSize;
25
- /** 버튼 항목 목록 */
26
- items: ButtonGroupItem[];
27
- /** 커스텀 className */
28
- className?: string;
29
- }
30
- type ButtonGroupComponent = React__default.ForwardRefExoticComponent<ButtonGroupProps & React__default.RefAttributes<HTMLDivElement>>;
31
- declare const ButtonGroup: ButtonGroupComponent;
32
-
33
- type IconButtonVariant = 'contained' | 'outlined' | 'invisible';
34
- type IconButtonColorVariantCombination = {
35
- color?: 'primary';
36
- variant?: 'contained' | 'outlined' | 'invisible';
37
- } | {
38
- color?: 'accent';
39
- variant?: 'contained' | 'outlined' | 'invisible';
40
- } | {
41
- color?: 'critical';
42
- variant?: 'contained' | 'outlined' | 'invisible';
43
- } | {
44
- color?: 'assistive';
45
- variant?: 'contained';
46
- } | {
47
- color?: 'inverse';
48
- variant?: 'contained';
49
- };
50
- type IconButtonProps = Omit<React__default.ButtonHTMLAttributes<HTMLButtonElement>, 'children'> & IconButtonColorVariantCombination & {
51
- icon: React__default.ReactElement<{
52
- className?: string;
53
- }>;
54
- variant?: IconButtonVariant;
55
- size?: 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge';
56
- /** 툴팁 설정 (문자열 또는 FlatTooltip 설정 객체) */
57
- tooltip?: ComponentProps<typeof ConditionalTooltip>['tooltip'];
58
- };
59
- type IconButtonComponent = React__default.ForwardRefExoticComponent<IconButtonProps & React__default.RefAttributes<HTMLButtonElement>>;
60
- declare const IconButton: IconButtonComponent;
61
-
62
- export { ButtonGroup as B, IconButton as I, type ButtonGroupComponent as a, type ButtonGroupItem as b, type ButtonGroupProps as c, type IconButtonComponent as d, type IconButtonProps as e };
@@ -1,62 +0,0 @@
1
- import './Button-CMenVfb7.js';
2
- import React__default, { ComponentProps } from 'react';
3
- import { ConditionalTooltip } from './flat/tooltip.js';
4
-
5
- type ButtonGroupSize = 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge';
6
- interface ButtonGroupItem {
7
- id: string;
8
- label?: string;
9
- icon?: React__default.ReactElement<{
10
- className?: string;
11
- }>;
12
- /** 툴팁 설정 (문자열 또는 FlatTooltip 설정 객체) */
13
- tooltip?: ComponentProps<typeof ConditionalTooltip>['tooltip'];
14
- onClick?: () => void;
15
- }
16
- interface ButtonGroupProps {
17
- /** 버튼 그룹 스타일 변형 */
18
- variant?: 'contained' | 'outlined';
19
- /** 아이콘만 표시 */
20
- iconOnly?: boolean;
21
- /** 배경색 표시 여부 (뒷 레이어가 보이지 않아야 할 때) */
22
- hasBackground?: boolean;
23
- /** 버튼 크기 */
24
- size?: ButtonGroupSize;
25
- /** 버튼 항목 목록 */
26
- items: ButtonGroupItem[];
27
- /** 커스텀 className */
28
- className?: string;
29
- }
30
- type ButtonGroupComponent = React__default.ForwardRefExoticComponent<ButtonGroupProps & React__default.RefAttributes<HTMLDivElement>>;
31
- declare const ButtonGroup: ButtonGroupComponent;
32
-
33
- type IconButtonVariant = 'contained' | 'outlined' | 'invisible';
34
- type IconButtonColorVariantCombination = {
35
- color?: 'primary';
36
- variant?: 'contained' | 'outlined' | 'invisible';
37
- } | {
38
- color?: 'accent';
39
- variant?: 'contained' | 'outlined' | 'invisible';
40
- } | {
41
- color?: 'critical';
42
- variant?: 'contained' | 'outlined' | 'invisible';
43
- } | {
44
- color?: 'assistive';
45
- variant?: 'contained';
46
- } | {
47
- color?: 'inverse';
48
- variant?: 'contained';
49
- };
50
- type IconButtonProps = Omit<React__default.ButtonHTMLAttributes<HTMLButtonElement>, 'children'> & IconButtonColorVariantCombination & {
51
- icon: React__default.ReactElement<{
52
- className?: string;
53
- }>;
54
- variant?: IconButtonVariant;
55
- size?: 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge';
56
- /** 툴팁 설정 (문자열 또는 FlatTooltip 설정 객체) */
57
- tooltip?: ComponentProps<typeof ConditionalTooltip>['tooltip'];
58
- };
59
- type IconButtonComponent = React__default.ForwardRefExoticComponent<IconButtonProps & React__default.RefAttributes<HTMLButtonElement>>;
60
- declare const IconButton: IconButtonComponent;
61
-
62
- export { ButtonGroup as B, IconButton as I, type ButtonGroupComponent as a, type ButtonGroupItem as b, type ButtonGroupProps as c, type IconButtonComponent as d, type IconButtonProps as e };
@@ -1,82 +0,0 @@
1
- import { V as Variant, k as Size, I as Icon } from '../Select-DMvWV_rF.mjs';
2
- export { S as Select, a as SelectBoxProps, b as SelectComponent, c as SelectDescriptionProps, d as SelectEmptyProps, e as SelectGroupProps, f as SelectItemProps, g as SelectLabelProps, h as SelectListProps, i as SelectRootProps, j as SelectTriggerProps } from '../Select-DMvWV_rF.mjs';
3
- import * as React from 'react';
4
- import React__default from 'react';
5
- import '@radix-ui/react-select';
6
-
7
- type TextAreaLabelProps = {
8
- children: React.ReactNode;
9
- required?: boolean;
10
- className?: string;
11
- };
12
- type TextAreaFieldProps = Omit<React.TextareaHTMLAttributes<HTMLTextAreaElement>, 'size' | 'disabled' | 'id' | 'value' | 'onChange' | 'maxLength'>;
13
- type TextAreaDescriptionProps = {
14
- children?: React.ReactNode;
15
- showCounter?: boolean;
16
- className?: string;
17
- };
18
- type TextAreaRootProps = {
19
- children?: React.ReactNode;
20
- /**
21
- * 입력 필드 스타일 유형
22
- * @default 'fill'
23
- */
24
- variant?: Variant;
25
- size?: Size;
26
- error?: boolean;
27
- disabled?: boolean;
28
- /**
29
- * TextArea의 기본값. Context를 통해 하위 컴포넌트로 전달됩니다.
30
- * TextArea.Field에서 value prop이 전달되면 Field의 value가 우선 적용됩니다.
31
- *
32
- * 사용 패턴:
33
- * - 통합 관리: <TextArea value={state}> - Context로 모든 Field에 적용
34
- * - 개별 제어: <TextArea.Field value={localState}> - 특정 Field만 개별 제어
35
- */
36
- value?: string;
37
- maxLength?: number;
38
- className?: string;
39
- } & Omit<React.TextareaHTMLAttributes<HTMLTextAreaElement>, 'size' | 'disabled' | 'id' | 'className'>;
40
- type TextAreaComponent = React.ForwardRefExoticComponent<TextAreaRootProps & React.RefAttributes<HTMLDivElement>> & {
41
- Label: React.ForwardRefExoticComponent<TextAreaLabelProps & React.RefAttributes<HTMLLabelElement>>;
42
- Field: React.ForwardRefExoticComponent<TextAreaFieldProps & React.RefAttributes<HTMLTextAreaElement>>;
43
- Description: React.ForwardRefExoticComponent<TextAreaDescriptionProps & React.RefAttributes<HTMLDivElement>>;
44
- };
45
- declare const TextArea: TextAreaComponent;
46
-
47
- type TextFieldRootProps = {
48
- children?: React__default.ReactNode;
49
- /**
50
- * 입력 필드 스타일 유형
51
- * @default 'fill'
52
- */
53
- variant?: Variant;
54
- size?: Size;
55
- error?: boolean;
56
- disabled?: boolean;
57
- className?: string;
58
- value?: string;
59
- onChange?: React__default.ChangeEventHandler<HTMLInputElement>;
60
- } & Omit<React__default.InputHTMLAttributes<HTMLInputElement>, 'size' | 'disabled' | 'className' | 'value' | 'onChange'>;
61
- type TextFieldLabelProps = {
62
- children: React__default.ReactNode;
63
- required?: boolean;
64
- className?: string;
65
- };
66
- type TextFieldInputProps = Omit<React__default.InputHTMLAttributes<HTMLInputElement>, 'size' | 'disabled' | 'id' | 'value' | 'onChange'> & {
67
- leftIcon?: Icon;
68
- rightIcon?: Icon;
69
- subText?: string;
70
- };
71
- type TextFieldDescriptionProps = {
72
- children: React__default.ReactNode;
73
- className?: string;
74
- };
75
- type TextFieldComponent = React__default.ForwardRefExoticComponent<TextFieldRootProps & React__default.RefAttributes<HTMLDivElement>> & {
76
- Label: React__default.ForwardRefExoticComponent<TextFieldLabelProps & React__default.RefAttributes<HTMLLabelElement>>;
77
- Input: React__default.ForwardRefExoticComponent<TextFieldInputProps & React__default.RefAttributes<HTMLInputElement>>;
78
- Description: React__default.ForwardRefExoticComponent<TextFieldDescriptionProps & React__default.RefAttributes<HTMLParagraphElement>>;
79
- };
80
- declare const TextField: TextFieldComponent;
81
-
82
- export { TextArea, type TextAreaComponent, type TextAreaDescriptionProps, type TextAreaFieldProps, type TextAreaLabelProps, type TextAreaRootProps, TextField, type TextFieldComponent, type TextFieldDescriptionProps, type TextFieldInputProps, type TextFieldLabelProps, type TextFieldRootProps };