@nexus-cross/design-system 1.0.13 → 1.1.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 (285) hide show
  1. package/claude-rules/nexus/CLAUDE.md +85 -0
  2. package/claude-rules/nexus/commands/nexus-audit.md +79 -0
  3. package/claude-rules/nexus/commands/nexus-component-map.md +85 -0
  4. package/claude-rules/nexus/commands/nexus-token-check.md +68 -0
  5. package/claude-rules/nexus/skills/nexus-design-system/SKILL.md +92 -0
  6. package/cursor-rules/nexus-ui-api.mdc +824 -41
  7. package/cursor-rules/nexus-ui-decisions.mdc +259 -0
  8. package/dist/accordion.js +0 -1
  9. package/dist/accordion.mjs +0 -1
  10. package/dist/alert.js +0 -1
  11. package/dist/alert.mjs +0 -1
  12. package/dist/avatar.js +0 -1
  13. package/dist/avatar.mjs +0 -1
  14. package/dist/badge.js +0 -1
  15. package/dist/badge.mjs +0 -1
  16. package/dist/breadcrumb.js +0 -1
  17. package/dist/breadcrumb.mjs +0 -1
  18. package/dist/button.js +0 -1
  19. package/dist/button.mjs +0 -1
  20. package/dist/carousel.js +0 -1
  21. package/dist/carousel.mjs +0 -1
  22. package/dist/checkbox.js +0 -1
  23. package/dist/checkbox.mjs +0 -1
  24. package/dist/chip.js +0 -1
  25. package/dist/chip.mjs +0 -1
  26. package/dist/chunks/chunk-2Z52NPWB.js +78 -0
  27. package/dist/chunks/chunk-46P52MFM.mjs +56 -0
  28. package/dist/chunks/{chunk-X3CTJ7TD.js → chunk-4KBFVIKX.js} +41 -11
  29. package/dist/chunks/chunk-56ZOOQFE.mjs +514 -0
  30. package/dist/chunks/chunk-5ASTWFJW.js +538 -0
  31. package/dist/chunks/{chunk-33UFQJIO.mjs → chunk-BJMXZJWO.mjs} +16 -5
  32. package/dist/chunks/chunk-EILXBLEV.mjs +5 -0
  33. package/dist/chunks/chunk-G3RLK2HS.js +7 -0
  34. package/dist/chunks/{chunk-YZV6FWE7.js → chunk-JLDQNDFT.js} +16 -5
  35. package/dist/chunks/{chunk-K574BYHQ.js → chunk-K3CK7NTP.js} +22 -4
  36. package/dist/chunks/{chunk-Z4YM7LU3.mjs → chunk-PIGHBDK5.mjs} +22 -4
  37. package/dist/chunks/{chunk-PEIEVKD5.js → chunk-RCIBLLSF.js} +11 -12
  38. package/dist/chunks/{chunk-MMCA33FW.mjs → chunk-RSFLNWOM.mjs} +41 -11
  39. package/dist/chunks/{chunk-K2TBLM3F.mjs → chunk-THBE27U3.mjs} +11 -12
  40. package/dist/client-only.js +0 -1
  41. package/dist/client-only.mjs +0 -1
  42. package/dist/combobox.js +16 -0
  43. package/dist/combobox.mjs +3 -0
  44. package/dist/components/Combobox.d.ts +48 -0
  45. package/dist/components/Combobox.d.ts.map +1 -0
  46. package/dist/components/DataGrid.d.ts +44 -0
  47. package/dist/components/DataGrid.d.ts.map +1 -0
  48. package/dist/components/DataList.d.ts +3 -1
  49. package/dist/components/DataList.d.ts.map +1 -1
  50. package/dist/components/RadioGroup.d.ts +4 -0
  51. package/dist/components/RadioGroup.d.ts.map +1 -1
  52. package/dist/components/Stepper.d.ts.map +1 -1
  53. package/dist/components/ToggleGroup.d.ts +2 -1
  54. package/dist/components/ToggleGroup.d.ts.map +1 -1
  55. package/dist/countdown.js +0 -1
  56. package/dist/countdown.mjs +0 -1
  57. package/dist/counter.js +0 -1
  58. package/dist/counter.mjs +0 -1
  59. package/dist/data-grid.js +14 -0
  60. package/dist/data-grid.mjs +5 -0
  61. package/dist/data-list.js +2 -3
  62. package/dist/data-list.mjs +1 -2
  63. package/dist/date-picker.js +0 -1
  64. package/dist/date-picker.mjs +0 -1
  65. package/dist/divider.js +0 -1
  66. package/dist/divider.mjs +0 -1
  67. package/dist/drawer.js +0 -1
  68. package/dist/drawer.mjs +0 -1
  69. package/dist/dropdown-menu.js +0 -1
  70. package/dist/dropdown-menu.mjs +0 -1
  71. package/dist/ellipsis.js +0 -1
  72. package/dist/ellipsis.mjs +0 -1
  73. package/dist/empty-state.js +0 -1
  74. package/dist/empty-state.mjs +0 -1
  75. package/dist/error-boundary.js +0 -1
  76. package/dist/error-boundary.mjs +0 -1
  77. package/dist/hooks/useCheckDevice.js +0 -1
  78. package/dist/hooks/useCheckDevice.mjs +0 -1
  79. package/dist/hooks/useClickOutside.js +0 -1
  80. package/dist/hooks/useClickOutside.mjs +0 -1
  81. package/dist/hooks/useDraggableBottomSheet.js +0 -1
  82. package/dist/hooks/useDraggableBottomSheet.mjs +0 -1
  83. package/dist/hooks/useDraggableWindow.js +0 -1
  84. package/dist/hooks/useDraggableWindow.mjs +0 -1
  85. package/dist/hooks/useInView.js +0 -1
  86. package/dist/hooks/useInView.mjs +0 -1
  87. package/dist/hooks/useModal.js +0 -1
  88. package/dist/hooks/useModal.mjs +0 -1
  89. package/dist/image-upload.js +0 -1
  90. package/dist/image-upload.mjs +0 -1
  91. package/dist/index.d.ts +4 -2
  92. package/dist/index.d.ts.map +1 -1
  93. package/dist/index.js +92 -88
  94. package/dist/index.mjs +12 -12
  95. package/dist/infinite-scroll.js +0 -1
  96. package/dist/infinite-scroll.mjs +0 -1
  97. package/dist/marquee.js +0 -1
  98. package/dist/marquee.mjs +0 -1
  99. package/dist/modal/index.js +11 -12
  100. package/dist/modal/index.mjs +2 -3
  101. package/dist/number-input.js +0 -1
  102. package/dist/number-input.mjs +0 -1
  103. package/dist/nx-image.js +0 -1
  104. package/dist/nx-image.mjs +0 -1
  105. package/dist/pagination.js +0 -1
  106. package/dist/pagination.mjs +0 -1
  107. package/dist/popover.js +0 -1
  108. package/dist/popover.mjs +0 -1
  109. package/dist/price-input.js +0 -1
  110. package/dist/price-input.mjs +0 -1
  111. package/dist/progress.js +0 -1
  112. package/dist/progress.mjs +0 -1
  113. package/dist/radio-group.js +5 -6
  114. package/dist/radio-group.mjs +1 -2
  115. package/dist/schemas/_all.json +308 -117
  116. package/dist/schemas/accordion.d.ts.map +1 -1
  117. package/dist/schemas/accordion.json +1 -1
  118. package/dist/schemas/alert.d.ts.map +1 -1
  119. package/dist/schemas/alert.json +1 -1
  120. package/dist/schemas/avatar.d.ts.map +1 -1
  121. package/dist/schemas/avatar.json +1 -1
  122. package/dist/schemas/badge.d.ts.map +1 -1
  123. package/dist/schemas/badge.json +1 -1
  124. package/dist/schemas/breadcrumb.d.ts.map +1 -1
  125. package/dist/schemas/breadcrumb.json +1 -1
  126. package/dist/schemas/button.d.ts.map +1 -1
  127. package/dist/schemas/button.json +1 -1
  128. package/dist/schemas/carousel.d.ts.map +1 -1
  129. package/dist/schemas/carousel.json +1 -1
  130. package/dist/schemas/checkBox.json +1 -1
  131. package/dist/schemas/checkbox.d.ts.map +1 -1
  132. package/dist/schemas/chip.d.ts.map +1 -1
  133. package/dist/schemas/chip.json +1 -1
  134. package/dist/schemas/client-only.d.ts.map +1 -1
  135. package/dist/schemas/clientOnly.json +1 -1
  136. package/dist/schemas/combobox.d.ts +85 -0
  137. package/dist/schemas/combobox.d.ts.map +1 -0
  138. package/dist/schemas/combobox.json +98 -0
  139. package/dist/schemas/comboboxOption.json +30 -0
  140. package/dist/schemas/countdown.d.ts.map +1 -1
  141. package/dist/schemas/countdown.json +1 -1
  142. package/dist/schemas/counter.d.ts.map +1 -1
  143. package/dist/schemas/counter.json +1 -1
  144. package/dist/schemas/data-grid.d.ts +74 -0
  145. package/dist/schemas/data-grid.d.ts.map +1 -0
  146. package/dist/schemas/data-list.d.ts.map +1 -1
  147. package/dist/schemas/dataGrid.json +102 -0
  148. package/dist/schemas/dataList.json +1 -1
  149. package/dist/schemas/date-picker.d.ts.map +1 -1
  150. package/dist/schemas/datePicker.json +1 -1
  151. package/dist/schemas/divider.d.ts.map +1 -1
  152. package/dist/schemas/divider.json +1 -1
  153. package/dist/schemas/drawer.d.ts.map +1 -1
  154. package/dist/schemas/drawer.json +1 -1
  155. package/dist/schemas/dropdown-menu.d.ts.map +1 -1
  156. package/dist/schemas/dropdownMenu.json +1 -1
  157. package/dist/schemas/ellipsis.d.ts.map +1 -1
  158. package/dist/schemas/ellipsis.json +1 -1
  159. package/dist/schemas/empty-state.d.ts.map +1 -1
  160. package/dist/schemas/emptyState.json +1 -1
  161. package/dist/schemas/error-boundary.d.ts.map +1 -1
  162. package/dist/schemas/errorBoundary.json +1 -1
  163. package/dist/schemas/image-upload.d.ts.map +1 -1
  164. package/dist/schemas/imageUpload.json +1 -1
  165. package/dist/schemas/index.d.ts +2 -1
  166. package/dist/schemas/index.d.ts.map +1 -1
  167. package/dist/schemas/infinite-scroll.d.ts.map +1 -1
  168. package/dist/schemas/infiniteScroll.json +1 -1
  169. package/dist/schemas/marquee.d.ts.map +1 -1
  170. package/dist/schemas/marquee.json +1 -1
  171. package/dist/schemas/modal.d.ts.map +1 -1
  172. package/dist/schemas/modalTemplate.json +1 -1
  173. package/dist/schemas/number-input.d.ts.map +1 -1
  174. package/dist/schemas/numberInput.json +1 -1
  175. package/dist/schemas/nx-image.d.ts.map +1 -1
  176. package/dist/schemas/nxImage.json +1 -1
  177. package/dist/schemas/pagination.d.ts.map +1 -1
  178. package/dist/schemas/pagination.json +1 -1
  179. package/dist/schemas/popover.d.ts.map +1 -1
  180. package/dist/schemas/popover.json +1 -1
  181. package/dist/schemas/price-input.d.ts.map +1 -1
  182. package/dist/schemas/priceInput.json +1 -1
  183. package/dist/schemas/progress.d.ts.map +1 -1
  184. package/dist/schemas/progress.json +1 -1
  185. package/dist/schemas/radio-group.d.ts +9 -0
  186. package/dist/schemas/radio-group.d.ts.map +1 -1
  187. package/dist/schemas/radioGroup.json +10 -1
  188. package/dist/schemas/radioItem.json +11 -0
  189. package/dist/schemas/select.d.ts.map +1 -1
  190. package/dist/schemas/select.json +1 -1
  191. package/dist/schemas/skeleton.d.ts.map +1 -1
  192. package/dist/schemas/skeleton.json +1 -1
  193. package/dist/schemas/slider.d.ts.map +1 -1
  194. package/dist/schemas/slider.json +1 -1
  195. package/dist/schemas/spinner.d.ts.map +1 -1
  196. package/dist/schemas/spinner.json +1 -1
  197. package/dist/schemas/stepper.d.ts.map +1 -1
  198. package/dist/schemas/stepper.json +1 -1
  199. package/dist/schemas/switch.d.ts.map +1 -1
  200. package/dist/schemas/switch.json +1 -1
  201. package/dist/schemas/tab.d.ts.map +1 -1
  202. package/dist/schemas/tab.json +1 -1
  203. package/dist/schemas/table.d.ts.map +1 -1
  204. package/dist/schemas/table.json +1 -1
  205. package/dist/schemas/tableRow.json +1 -1
  206. package/dist/schemas/tag-input.d.ts.map +1 -1
  207. package/dist/schemas/tagInput.json +1 -1
  208. package/dist/schemas/tdColumn.json +1 -1
  209. package/dist/schemas/text-area.d.ts.map +1 -1
  210. package/dist/schemas/text-input.d.ts +2 -2
  211. package/dist/schemas/text-input.d.ts.map +1 -1
  212. package/dist/schemas/textArea.json +1 -1
  213. package/dist/schemas/textInput.json +1 -1
  214. package/dist/schemas/toast.d.ts.map +1 -1
  215. package/dist/schemas/toastOptions.json +1 -1
  216. package/dist/schemas/toaster.json +1 -1
  217. package/dist/schemas/toggle-group.d.ts +6 -3
  218. package/dist/schemas/toggle-group.d.ts.map +1 -1
  219. package/dist/schemas/toggleGroup.json +9 -3
  220. package/dist/schemas/tooltip.d.ts.map +1 -1
  221. package/dist/schemas/tooltip.json +1 -1
  222. package/dist/schemas/virtual-scroll.d.ts.map +1 -1
  223. package/dist/schemas/virtualGrid.json +1 -1
  224. package/dist/schemas/virtualList.json +1 -1
  225. package/dist/schemas.js +867 -66
  226. package/dist/schemas.mjs +865 -66
  227. package/dist/select.js +0 -1
  228. package/dist/select.mjs +0 -1
  229. package/dist/skeleton.js +0 -1
  230. package/dist/skeleton.mjs +0 -1
  231. package/dist/slider.js +0 -1
  232. package/dist/slider.mjs +0 -1
  233. package/dist/spinner.js +0 -1
  234. package/dist/spinner.mjs +0 -1
  235. package/dist/stepper.js +3 -4
  236. package/dist/stepper.mjs +1 -2
  237. package/dist/styles/.generated/built.d.ts +1 -1
  238. package/dist/styles/.generated/built.d.ts.map +1 -1
  239. package/dist/styles/layer.js +2 -3
  240. package/dist/styles/layer.mjs +1 -2
  241. package/dist/styles.css +554 -51
  242. package/dist/styles.js +2 -3
  243. package/dist/styles.layered.css +554 -51
  244. package/dist/styles.mjs +1 -2
  245. package/dist/switch.js +0 -1
  246. package/dist/switch.mjs +0 -1
  247. package/dist/tab.js +0 -1
  248. package/dist/tab.mjs +0 -1
  249. package/dist/table.js +0 -1
  250. package/dist/table.mjs +0 -1
  251. package/dist/tag-input.js +0 -1
  252. package/dist/tag-input.mjs +0 -1
  253. package/dist/text-area.js +0 -1
  254. package/dist/text-area.mjs +0 -1
  255. package/dist/text-input.js +0 -1
  256. package/dist/text-input.mjs +0 -1
  257. package/dist/toast.js +0 -1
  258. package/dist/toast.mjs +0 -1
  259. package/dist/toggle-group.js +3 -4
  260. package/dist/toggle-group.mjs +1 -2
  261. package/dist/tooltip.js +0 -1
  262. package/dist/tooltip.mjs +0 -1
  263. package/dist/utils/cn.js +0 -1
  264. package/dist/utils/cn.mjs +0 -1
  265. package/dist/utils/scroll.js +0 -1
  266. package/dist/utils/scroll.mjs +0 -1
  267. package/dist/virtual-scroll.js +0 -1
  268. package/dist/virtual-scroll.mjs +0 -1
  269. package/package.json +14 -8
  270. package/scripts/setup-cursor-rules.cjs +164 -27
  271. package/dist/chunks/chunk-22ULI3BF.js +0 -21
  272. package/dist/chunks/chunk-6ECGMUT6.mjs +0 -5
  273. package/dist/chunks/chunk-CVYXRSXT.mjs +0 -8
  274. package/dist/chunks/chunk-I252NERB.mjs +0 -21
  275. package/dist/chunks/chunk-JNMCYWGY.js +0 -10
  276. package/dist/chunks/chunk-V35IEPRL.js +0 -7
  277. package/dist/components/ThemeProvider.d.ts +0 -25
  278. package/dist/components/ThemeProvider.d.ts.map +0 -1
  279. package/dist/schemas/theme-provider.d.ts +0 -36
  280. package/dist/schemas/theme-provider.d.ts.map +0 -1
  281. package/dist/schemas/themeProvider.json +0 -65
  282. package/dist/theme-provider.js +0 -15
  283. package/dist/theme-provider.mjs +0 -2
  284. package/dist/chunks/{chunk-CWMLTXOH.mjs → chunk-5ZVPTIL3.mjs} +1 -1
  285. package/dist/chunks/{chunk-HFBTS42N.js → chunk-7F4SOLAC.js} +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"accordion.d.ts","sourceRoot":"","sources":["../../src/schemas/accordion.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAYxB,eAAO,MAAM,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAmB2C,CAAC"}
1
+ {"version":3,"file":"accordion.d.ts","sourceRoot":"","sources":["../../src/schemas/accordion.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAYxB,eAAO,MAAM,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAmC9B,CAAC"}
@@ -94,7 +94,7 @@
94
94
  "items"
95
95
  ],
96
96
  "additionalProperties": false,
97
- "description": "Accordion. Supports both items array and composable patterns."
97
+ "description": "Accordion collapsible content sections (FAQ, settings groups).\n\nWHEN TO USE:\n • FAQ, help docs, settings groups\n • Long page where each section is independently scannable\n • Hidden critical info — DO NOT bury what users always need\n • Tab-like content switching → Tab (Accordion is for stacked, not exclusive)\n\ntype=\"single\" + collapsible=true → all-closed allowed (recommended for FAQ).\ntype=\"multiple\" → multiple sections open at once.\n\nANTI-PATTERNS:\n ✗ Hiding the page's primary content inside collapsed Accordion\n ✗ Single-section Accordion (just show the content)\n ✗ Custom toggle div + state — use Accordion (gets a11y, keyboard nav)"
98
98
  }
99
99
  },
100
100
  "$schema": "http://json-schema.org/draft-07/schema#"
@@ -1 +1 @@
1
- {"version":3,"file":"alert.d.ts","sourceRoot":"","sources":["../../src/schemas/alert.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,gBAAgB;;;;;;;;;;;;;;;;;;;;;;;;;;;EAcoD,CAAC"}
1
+ {"version":3,"file":"alert.d.ts","sourceRoot":"","sources":["../../src/schemas/alert.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,gBAAgB;;;;;;;;;;;;;;;;;;;;;;;;;;;EA6B1B,CAAC"}
@@ -42,7 +42,7 @@
42
42
  }
43
43
  },
44
44
  "additionalProperties": false,
45
- "description": "Alert / Banner. Inline notification with icon, title, description."
45
+ "description": "Alert persistent inline notification (banner). Auto icon by variant.\n\nWHEN TO USE:\n • In-page status: form errors, server warnings, info banners, success confirmation\n • Transient toast/snackbar → use a toast library, NOT Alert\n • Modal-blocking error → Modal with semantic=\"danger\"\n • Inline form field error → use error/description prop on TextInput / Select / etc.\n\nvariant maps to semantic colors. closable=true gives users dismiss control. action prop reserved for inline buttons (e.g. \"Retry\").\n\nANTI-PATTERNS:\n ✗ Stacking 5 alerts at top of page (use one with summary)\n ✗ Critical destructive action confirmation in Alert → Modal\n ✗ Wrapping <div className=\"bg-red-100\"> manually → Alert (a11y role + tokens)"
46
46
  }
47
47
  },
48
48
  "$schema": "http://json-schema.org/draft-07/schema#"
@@ -1 +1 @@
1
- {"version":3,"file":"avatar.d.ts","sourceRoot":"","sources":["../../src/schemas/avatar.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,iBAAiB;;;;;;;;;;;;;;;;;;;;;;;;;;;EAiBqC,CAAC"}
1
+ {"version":3,"file":"avatar.d.ts","sourceRoot":"","sources":["../../src/schemas/avatar.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,iBAAiB;;;;;;;;;;;;;;;;;;;;;;;;;;;EAgC3B,CAAC"}
@@ -48,7 +48,7 @@
48
48
  }
49
49
  },
50
50
  "additionalProperties": false,
51
- "description": "Avatar. Supports image, fallback text, and children."
51
+ "description": "Avatar user/entity profile image with text fallback.\n\nWHEN TO USE:\n • User profiles, comment authors, team member lists, message sender icons\n • Image fails / not provided → fallback (initials or icon) shown automatically\n • Need optimized image (Next.js) → pass <Image> via children, omit src\n • Larger illustration / logo → use NxImage instead\n\nshape=\"square\" for organization/team logos; \"circle\" for people (default).\n\nANTI-PATTERNS:\n ✗ <img> + manual fallback handling → Avatar (handles error)\n ✗ Avatar without alt for screen readers (always set alt or aria-label)\n ✗ Mixing avatar sizes inconsistently in a list — pick one size"
52
52
  }
53
53
  },
54
54
  "$schema": "http://json-schema.org/draft-07/schema#"
@@ -1 +1 @@
1
- {"version":3,"file":"badge.d.ts","sourceRoot":"","sources":["../../src/schemas/badge.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,gBAAgB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAesD,CAAC"}
1
+ {"version":3,"file":"badge.d.ts","sourceRoot":"","sources":["../../src/schemas/badge.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,gBAAgB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA+B1B,CAAC"}
@@ -69,7 +69,7 @@
69
69
  }
70
70
  },
71
71
  "additionalProperties": false,
72
- "description": "Badge indicator. Dot or count display. Wraps children when provided."
72
+ "description": "Badge — small status / count indicator overlaid on an anchor (icon, avatar, button).\n\nWHEN TO USE:\n • Notification count on bell icon\n • Unread message count on inbox tab\n • Status dot (online/offline) → dot=true\n • Status label with text (e.g. \"PRO\", \"NEW\") → Chip variant=\"accent\"\n • Removable filter token → Chip with onClose\n\ncount={0} hides badge by default; pass showZero=true to keep visible.\n\nANTI-PATTERNS:\n ✗ Using Badge as standalone label without anchor → Chip\n ✗ count > 999 without max → ugly layout; default max=99 (\"99+\")\n ✗ Multiple badges on same anchor (visual noise)"
73
73
  }
74
74
  },
75
75
  "$schema": "http://json-schema.org/draft-07/schema#"
@@ -1 +1 @@
1
- {"version":3,"file":"breadcrumb.d.ts","sourceRoot":"","sources":["../../src/schemas/breadcrumb.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,yBAAyB;;;;;;;;;EAKoE,CAAC;AAE3G,eAAO,MAAM,qBAAqB;;;;;;;;;;;;;;;EAW/B,CAAC"}
1
+ {"version":3,"file":"breadcrumb.d.ts","sourceRoot":"","sources":["../../src/schemas/breadcrumb.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,yBAAyB;;;;;;;;;EAKoE,CAAC;AAE3G,eAAO,MAAM,qBAAqB;;;;;;;;;;;;;;;EAuB/B,CAAC"}
@@ -20,7 +20,7 @@
20
20
  }
21
21
  },
22
22
  "additionalProperties": false,
23
- "description": "Breadcrumb navigation (compound component pattern). Use <Breadcrumb.Item> children instead of items array. Each Item can wrap arbitrary ReactNode (Link, Select, plain text, etc.)."
23
+ "description": "Breadcrumb — hierarchical location navigation (Home > Settings > Profile).\n\nWHEN TO USE:\n • Multi-level information architecture (>=3 levels deep)\n • Hierarchical category drill-down (file system, taxonomy)\n • Step-based linear flow → Stepper (not Breadcrumb)\n • Tab switching → Tab\n • Single-level navigation → page title alone\n\nCompound pattern: use <Breadcrumb.Item> children. Each Item wraps any ReactNode (Link, Select, plain text). Use maxItems for long paths (auto-collapse with \"…\").\n\nANTI-PATTERNS:\n ✗ Breadcrumb with 1 level — just show page title\n ✗ Breadcrumb with > 6 visible items → set maxItems\n ✗ Last item as a link (it's the current page; should be plain text)"
24
24
  }
25
25
  },
26
26
  "$schema": "http://json-schema.org/draft-07/schema#"
@@ -1 +1 @@
1
- {"version":3,"file":"button.d.ts","sourceRoot":"","sources":["../../src/schemas/button.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAA;AAEvB,eAAO,MAAM,iBAAiB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAuC3B,CAAA"}
1
+ {"version":3,"file":"button.d.ts","sourceRoot":"","sources":["../../src/schemas/button.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAA;AAEvB,eAAO,MAAM,iBAAiB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAiD3B,CAAA"}
@@ -82,7 +82,7 @@
82
82
  }
83
83
  },
84
84
  "additionalProperties": false,
85
- "description": "Interactive button. semantic(color) x variant(style) 2-axis system. Rendering element changeable via asChild."
85
+ "description": "Interactive button (always prefer over native <button>).\n\nWHEN TO USE: any clickable action — submit, navigate (with asChild), open modal, trigger menu.\n2-axis: semantic (color intent) × variant (visual weight). Use semantic=\"primary\" for the page's main CTA, \"danger\" for destructive actions, \"secondary\" for sub actions, \"normal\" for neutral.\n\nANTI-PATTERNS:\n ✗ <button className=\"bg-blue-500\"> <Button semantic=\"primary\">\n ✗ <a className=\"...\"> styled as button → <Button asChild><a href=\"...\"/></Button>\n ✗ Mixing variants randomly within one row — pick one per visual hierarchy level\n ✗ Using primary + contained for every button → only ONE primary CTA per view\n ✗ <Button className=\"!bg-red-500\"> → <Button semantic=\"danger\"> (no !important)"
86
86
  }
87
87
  },
88
88
  "$schema": "http://json-schema.org/draft-07/schema#"
@@ -1 +1 @@
1
- {"version":3,"file":"carousel.d.ts","sourceRoot":"","sources":["../../src/schemas/carousel.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,mBAAmB;;;;;;;;;;;;;;;;;;EAa7B,CAAC;AAEJ,eAAO,MAAM,wBAAwB;;;;;;;;;EAKe,CAAC;AAErD,eAAO,MAAM,yBAAyB;;;;;;;;;EAKuC,CAAC;AAE9E,eAAO,MAAM,uBAAuB;;;;;;EAIc,CAAC"}
1
+ {"version":3,"file":"carousel.d.ts","sourceRoot":"","sources":["../../src/schemas/carousel.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,mBAAmB;;;;;;;;;;;;;;;;;;EA0B7B,CAAC;AAEJ,eAAO,MAAM,wBAAwB;;;;;;;;;EAKe,CAAC;AAErD,eAAO,MAAM,yBAAyB;;;;;;;;;EAKuC,CAAC;AAE9E,eAAO,MAAM,uBAAuB;;;;;;EAIc,CAAC"}
@@ -25,7 +25,7 @@
25
25
  }
26
26
  },
27
27
  "additionalProperties": false,
28
- "description": "Carousel. Based on Embla Carousel. Sub-components: CarouselSlide, CarouselPrev, CarouselNext, CarouselDots."
28
+ "description": "Carousel — horizontal slide gallery. Based on Embla Carousel. Compound: CarouselSlide, CarouselPrev/Next, CarouselDots.\n\nWHEN TO USE:\n • Hero banners, image gallery, product showcase\n • Multi-card horizontal scroll with snap behavior\n • Vertical scrolling list → Marquee or VirtualList (not Carousel)\n • Critical content that must always be visible — Carousel hides slides\n\nopts={{ loop: true, align: 'start' }} for endless loop. Add Embla autoplay plugin for auto-advance.\n\nANTI-PATTERNS:\n ✗ Critical CTA inside non-first slide (users might never scroll)\n ✗ Auto-advance without pause-on-hover (a11y)\n ✗ Manual scroll-snap div → Carousel (gets keyboard nav, indicators)"
29
29
  }
30
30
  },
31
31
  "$schema": "http://json-schema.org/draft-07/schema#"
@@ -68,7 +68,7 @@
68
68
  }
69
69
  },
70
70
  "additionalProperties": false,
71
- "description": "Checkbox. Native input-based, supports square/round shapes."
71
+ "description": "Checkbox for multi-select form fields. Native input-based, supports square/round shapes.\n\nWHEN TO USE:\n • Form field with multiple independent options (T&C agreements, multi-select filters submitted later)\n • Tri-state (parent-child selection) — use indeterminate prop\n • Single binary that takes effect immediately → Switch instead\n • Many options with search → Combobox (multiple)\n\nINDETERMINATE: set indeterminate=true when some children are checked, others not. aria-checked becomes \"mixed\" automatically.\n\nANTI-PATTERNS:\n ✗ <CheckBox> for \"Enable dark mode\" toggle → <Switch>\n ✗ Native <input type=\"checkbox\"> + manual styling → <CheckBox>\n ✗ Forgetting indeterminate for \"select all\" parent"
72
72
  }
73
73
  },
74
74
  "$schema": "http://json-schema.org/draft-07/schema#"
@@ -1 +1 @@
1
- {"version":3,"file":"checkbox.d.ts","sourceRoot":"","sources":["../../src/schemas/checkbox.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,mBAAmB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAoB0C,CAAC"}
1
+ {"version":3,"file":"checkbox.d.ts","sourceRoot":"","sources":["../../src/schemas/checkbox.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,mBAAmB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAmC7B,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"chip.d.ts","sourceRoot":"","sources":["../../src/schemas/chip.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;EAiB2C,CAAC"}
1
+ {"version":3,"file":"chip.d.ts","sourceRoot":"","sources":["../../src/schemas/chip.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;EA+BzB,CAAC"}
@@ -48,7 +48,7 @@
48
48
  }
49
49
  },
50
50
  "additionalProperties": false,
51
- "description": "Chip/tag/badge. Close button displayed via onClose prop."
51
+ "description": "Chip — small interactive token for filters, tags, removable selections, status labels.\n\nWHEN TO USE:\n • Filter token / removable selection (set onClose for X button)\n • Tag/category indicator\n • Status indicator with color (variant=\"accent\")\n • Pure count badge Badge instead\n • Toggleable filter → ToggleGroup or Chip with onClick + active state\n\nANTI-PATTERNS:\n ✗ Building dismiss UI manually with custom div + X icon → use onClose prop\n ✗ Using Chip as a primary CTA → Button\n ✗ Using Chip for hover-only labels → Tooltip"
52
52
  }
53
53
  },
54
54
  "$schema": "http://json-schema.org/draft-07/schema#"
@@ -1 +1 @@
1
- {"version":3,"file":"client-only.d.ts","sourceRoot":"","sources":["../../src/schemas/client-only.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,qBAAqB;;;;;;;;;EAQoD,CAAC"}
1
+ {"version":3,"file":"client-only.d.ts","sourceRoot":"","sources":["../../src/schemas/client-only.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,qBAAqB;;;;;;;;;EAuB/B,CAAC"}
@@ -12,7 +12,7 @@
12
12
  }
13
13
  },
14
14
  "additionalProperties": false,
15
- "description": "Client-only rendering. Prevents hydration mismatch in SSR environments."
15
+ "description": "ClientOnly — defers children to client-side render, preventing SSR hydration mismatch.\n\nWHEN TO USE:\n • Wrap components that read window/document/localStorage at render time\n • Components depending on browser-only APIs (IntersectionObserver eager init, geolocation)\n • Server-renderable content → DON'T wrap (loses SEO/SSR perf benefits)\n • Conditional based on data → use proper SSR-safe state instead\n\nPass fallback to avoid layout shift during hydration.\n\nANTI-PATTERNS:\n ✗ Wrapping the entire page in ClientOnly (defeats SSR)\n ✗ ClientOnly without fallback for above-the-fold UI (CLS)\n ✗ Using ClientOnly to \"fix\" any hydration warning — root-cause the mismatch first"
16
16
  }
17
17
  },
18
18
  "$schema": "http://json-schema.org/draft-07/schema#"
@@ -0,0 +1,85 @@
1
+ import { z } from 'zod';
2
+ export declare const comboboxOptionSchema: z.ZodObject<{
3
+ value: z.ZodString;
4
+ label: z.ZodAny;
5
+ description: z.ZodOptional<z.ZodAny>;
6
+ disabled: z.ZodOptional<z.ZodBoolean>;
7
+ }, "strip", z.ZodTypeAny, {
8
+ value: string;
9
+ label?: any;
10
+ description?: any;
11
+ disabled?: boolean | undefined;
12
+ }, {
13
+ value: string;
14
+ label?: any;
15
+ description?: any;
16
+ disabled?: boolean | undefined;
17
+ }>;
18
+ export declare const comboboxPropsSchema: z.ZodObject<{
19
+ options: z.ZodAny;
20
+ value: z.ZodOptional<z.ZodAny>;
21
+ defaultValue: z.ZodOptional<z.ZodAny>;
22
+ onValueChange: z.ZodOptional<z.ZodAny>;
23
+ multiple: z.ZodDefault<z.ZodBoolean>;
24
+ onSearch: z.ZodOptional<z.ZodAny>;
25
+ searchDebounce: z.ZodDefault<z.ZodNumber>;
26
+ loading: z.ZodDefault<z.ZodBoolean>;
27
+ filter: z.ZodOptional<z.ZodAny>;
28
+ placeholder: z.ZodOptional<z.ZodString>;
29
+ emptyMessage: z.ZodOptional<z.ZodAny>;
30
+ loadingMessage: z.ZodOptional<z.ZodAny>;
31
+ size: z.ZodDefault<z.ZodEnum<["md", "lg", "xl"]>>;
32
+ disabled: z.ZodOptional<z.ZodBoolean>;
33
+ error: z.ZodOptional<z.ZodBoolean>;
34
+ clearable: z.ZodDefault<z.ZodBoolean>;
35
+ autoOpenOnFocus: z.ZodDefault<z.ZodBoolean>;
36
+ label: z.ZodOptional<z.ZodAny>;
37
+ description: z.ZodOptional<z.ZodAny>;
38
+ className: z.ZodOptional<z.ZodString>;
39
+ popoverClassName: z.ZodOptional<z.ZodString>;
40
+ }, "strip", z.ZodTypeAny, {
41
+ loading: boolean;
42
+ size: "xl" | "lg" | "md";
43
+ multiple: boolean;
44
+ searchDebounce: number;
45
+ clearable: boolean;
46
+ autoOpenOnFocus: boolean;
47
+ className?: string | undefined;
48
+ error?: boolean | undefined;
49
+ filter?: any;
50
+ options?: any;
51
+ label?: any;
52
+ description?: any;
53
+ value?: any;
54
+ disabled?: boolean | undefined;
55
+ defaultValue?: any;
56
+ onValueChange?: any;
57
+ placeholder?: string | undefined;
58
+ onSearch?: any;
59
+ emptyMessage?: any;
60
+ loadingMessage?: any;
61
+ popoverClassName?: string | undefined;
62
+ }, {
63
+ className?: string | undefined;
64
+ error?: boolean | undefined;
65
+ filter?: any;
66
+ options?: any;
67
+ label?: any;
68
+ loading?: boolean | undefined;
69
+ description?: any;
70
+ value?: any;
71
+ size?: "xl" | "lg" | "md" | undefined;
72
+ multiple?: boolean | undefined;
73
+ disabled?: boolean | undefined;
74
+ defaultValue?: any;
75
+ onValueChange?: any;
76
+ placeholder?: string | undefined;
77
+ onSearch?: any;
78
+ searchDebounce?: number | undefined;
79
+ emptyMessage?: any;
80
+ loadingMessage?: any;
81
+ clearable?: boolean | undefined;
82
+ autoOpenOnFocus?: boolean | undefined;
83
+ popoverClassName?: string | undefined;
84
+ }>;
85
+ //# sourceMappingURL=combobox.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"combobox.d.ts","sourceRoot":"","sources":["../../src/schemas/combobox.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,oBAAoB;;;;;;;;;;;;;;;EAOK,CAAC;AAEvC,eAAO,MAAM,mBAAmB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAiF7B,CAAC"}
@@ -0,0 +1,98 @@
1
+ {
2
+ "$ref": "#/definitions/comboboxPropsSchema",
3
+ "definitions": {
4
+ "comboboxPropsSchema": {
5
+ "type": "object",
6
+ "properties": {
7
+ "options": {
8
+ "description": "Available options array (ComboboxOption[], required)"
9
+ },
10
+ "value": {
11
+ "description": "Selected value. string for single, string[] for multiple"
12
+ },
13
+ "defaultValue": {
14
+ "description": "Initial value (uncontrolled)"
15
+ },
16
+ "onValueChange": {
17
+ "description": "Value change callback. (value: string | string[]) => void"
18
+ },
19
+ "multiple": {
20
+ "type": "boolean",
21
+ "default": false,
22
+ "description": "Multi-select mode. Selected values shown as chips inside input"
23
+ },
24
+ "onSearch": {
25
+ "description": "Async search callback. (query: string) => void. Triggers external data fetching with debounce"
26
+ },
27
+ "searchDebounce": {
28
+ "type": "number",
29
+ "default": 250,
30
+ "description": "Debounce delay (ms) before onSearch fires"
31
+ },
32
+ "loading": {
33
+ "type": "boolean",
34
+ "default": false,
35
+ "description": "Externally-controlled loading state. Shows spinner in input suffix"
36
+ },
37
+ "filter": {
38
+ "description": "Custom client-side filter. (option, query) => boolean. Default: case-insensitive label includes match"
39
+ },
40
+ "placeholder": {
41
+ "type": "string",
42
+ "description": "Input placeholder"
43
+ },
44
+ "emptyMessage": {
45
+ "description": "Message when no options match (string | ReactNode). Default: \"검색 결과 없음\""
46
+ },
47
+ "loadingMessage": {
48
+ "description": "Message during loading state inside popover (string | ReactNode). Default: \"검색 중…\""
49
+ },
50
+ "size": {
51
+ "type": "string",
52
+ "enum": [
53
+ "md",
54
+ "lg",
55
+ "xl"
56
+ ],
57
+ "default": "md",
58
+ "description": "Input size (matches TextInput tokens)"
59
+ },
60
+ "disabled": {
61
+ "type": "boolean",
62
+ "description": "Disabled"
63
+ },
64
+ "error": {
65
+ "type": "boolean",
66
+ "description": "Error state"
67
+ },
68
+ "clearable": {
69
+ "type": "boolean",
70
+ "default": true,
71
+ "description": "Show clear button when value(s) exist"
72
+ },
73
+ "autoOpenOnFocus": {
74
+ "type": "boolean",
75
+ "default": true,
76
+ "description": "Open popover automatically when input gains focus"
77
+ },
78
+ "label": {
79
+ "description": "Field label (ReactNode)"
80
+ },
81
+ "description": {
82
+ "description": "Helper text below input (ReactNode)"
83
+ },
84
+ "className": {
85
+ "type": "string",
86
+ "description": "Wrapper className"
87
+ },
88
+ "popoverClassName": {
89
+ "type": "string",
90
+ "description": "Popover content className"
91
+ }
92
+ },
93
+ "additionalProperties": false,
94
+ "description": "Searchable select. Text input + popover listbox. Single/multi-select. Sync (auto-filter) or async (onSearch + loading) modes.\n\nWHEN TO USE:\n • Options ≥ 7, OR labels are long, OR search/filter is needed → Combobox (not Select)\n • Multi-select form field → Combobox with multiple (chips render inside input)\n • Async data from server → set onSearch + loading\nFor ≤7 simple options use Select. For free-text tags use TagInput.\n\nASYNC PATTERN:\n <Combobox options={results} loading={isFetching} onSearch={(q) => mutate(q)} />\n — onSearch fires after searchDebounce (default 250ms). Do NOT clear input on result update; component preserves user's typing.\n\nIME (Korean/Japanese/Chinese): Enter during composition is ignored automatically — do not add custom keydown handlers.\n\nANTI-PATTERNS:\n ✗ <Select> with 20 options → <Combobox>\n ✗ Manual <input> + dropdown div + filter logic → <Combobox>\n ✗ Setting value externally to clear input mid-typing → use onValueChange instead"
95
+ }
96
+ },
97
+ "$schema": "http://json-schema.org/draft-07/schema#"
98
+ }
@@ -0,0 +1,30 @@
1
+ {
2
+ "$ref": "#/definitions/comboboxOptionSchema",
3
+ "definitions": {
4
+ "comboboxOptionSchema": {
5
+ "type": "object",
6
+ "properties": {
7
+ "value": {
8
+ "type": "string",
9
+ "description": "Option value (unique key)"
10
+ },
11
+ "label": {
12
+ "description": "Display label (string | ReactNode)"
13
+ },
14
+ "description": {
15
+ "description": "Secondary text below label (ReactNode)"
16
+ },
17
+ "disabled": {
18
+ "type": "boolean",
19
+ "description": "Disabled option"
20
+ }
21
+ },
22
+ "required": [
23
+ "value"
24
+ ],
25
+ "additionalProperties": false,
26
+ "description": "Single Combobox option."
27
+ }
28
+ },
29
+ "$schema": "http://json-schema.org/draft-07/schema#"
30
+ }
@@ -1 +1 @@
1
- {"version":3,"file":"countdown.d.ts","sourceRoot":"","sources":["../../src/schemas/countdown.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAkBF,CAAC"}
1
+ {"version":3,"file":"countdown.d.ts","sourceRoot":"","sources":["../../src/schemas/countdown.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAiC9B,CAAC"}
@@ -51,7 +51,7 @@
51
51
  "endTimestamp"
52
52
  ],
53
53
  "additionalProperties": false,
54
- "description": "Countdown timer."
54
+ "description": "Countdown — live timer counting down to endTimestamp (Unix ms).\n\nWHEN TO USE:\n • Sale ends in / event starts in / token claim window\n • OTP / verification code expiry\n • Counting up (since X) → not Countdown; use Counter or custom interval\n • Persistent server time → pass server-synced endTimestamp (not Date.now offset)\n\nshowDays=false for short timers (<24h) to declutter. Use render prop for fully custom layouts.\n\nANTI-PATTERNS:\n ✗ Countdown without onEnd handler — UI stuck at 0\n ✗ Countdown across SSR without hydration safety — pass endTimestamp from server\n ✗ Updating endTimestamp every render — causes jitter"
55
55
  }
56
56
  },
57
57
  "$schema": "http://json-schema.org/draft-07/schema#"
@@ -1 +1 @@
1
- {"version":3,"file":"counter.d.ts","sourceRoot":"","sources":["../../src/schemas/counter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,kBAAkB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAgBO,CAAC"}
1
+ {"version":3,"file":"counter.d.ts","sourceRoot":"","sources":["../../src/schemas/counter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,kBAAkB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA+B5B,CAAC"}
@@ -53,7 +53,7 @@
53
53
  "endValue"
54
54
  ],
55
55
  "additionalProperties": false,
56
- "description": "Number count animation."
56
+ "description": "Counter animated number tick from startValue to endValue.\n\nWHEN TO USE:\n • Marketing landing — \"10,000+ users\" KPI displays\n • Stat dashboards (animate when value changes)\n • Live tickers / real-time data — re-render plain text instead (Counter is one-shot animation)\n • Currency input / editable number → NumberInput / PriceInput\n\ntriggerOnView=true delays animation until element scrolls into view (good for landing pages).\n\nANTI-PATTERNS:\n ✗ Counter for values that update frequently — animation queue conflicts\n ✗ Long duration on critical numbers (users wait to read)\n ✗ Counter without separator for large numbers (hard to read)"
57
57
  }
58
58
  },
59
59
  "$schema": "http://json-schema.org/draft-07/schema#"
@@ -0,0 +1,74 @@
1
+ import { z } from 'zod';
2
+ export declare const dataGridPropsSchema: z.ZodObject<{
3
+ list: z.ZodNullable<z.ZodArray<z.ZodAny, "many">>;
4
+ columns: z.ZodUnion<[z.ZodNumber, z.ZodObject<{
5
+ base: z.ZodOptional<z.ZodNumber>;
6
+ sm: z.ZodOptional<z.ZodNumber>;
7
+ md: z.ZodOptional<z.ZodNumber>;
8
+ lg: z.ZodOptional<z.ZodNumber>;
9
+ xl: z.ZodOptional<z.ZodNumber>;
10
+ '2xl': z.ZodOptional<z.ZodNumber>;
11
+ }, "strip", z.ZodTypeAny, {
12
+ base?: number | undefined;
13
+ xl?: number | undefined;
14
+ lg?: number | undefined;
15
+ md?: number | undefined;
16
+ sm?: number | undefined;
17
+ '2xl'?: number | undefined;
18
+ }, {
19
+ base?: number | undefined;
20
+ xl?: number | undefined;
21
+ lg?: number | undefined;
22
+ md?: number | undefined;
23
+ sm?: number | undefined;
24
+ '2xl'?: number | undefined;
25
+ }>]>;
26
+ gap: z.ZodOptional<z.ZodUnion<[z.ZodNumber, z.ZodString]>>;
27
+ noDataMessage: z.ZodOptional<z.ZodAny>;
28
+ errorFallback: z.ZodOptional<z.ZodAny>;
29
+ loadingElement: z.ZodOptional<z.ZodAny>;
30
+ skeletonElement: z.ZodOptional<z.ZodAny>;
31
+ skeletonCount: z.ZodDefault<z.ZodNumber>;
32
+ loading: z.ZodDefault<z.ZodBoolean>;
33
+ children: z.ZodAny;
34
+ className: z.ZodOptional<z.ZodString>;
35
+ }, "strip", z.ZodTypeAny, {
36
+ loading: boolean;
37
+ list: any[] | null;
38
+ columns: number | {
39
+ base?: number | undefined;
40
+ xl?: number | undefined;
41
+ lg?: number | undefined;
42
+ md?: number | undefined;
43
+ sm?: number | undefined;
44
+ '2xl'?: number | undefined;
45
+ };
46
+ skeletonCount: number;
47
+ gap?: string | number | undefined;
48
+ className?: string | undefined;
49
+ children?: any;
50
+ loadingElement?: any;
51
+ skeletonElement?: any;
52
+ noDataMessage?: any;
53
+ errorFallback?: any;
54
+ }, {
55
+ list: any[] | null;
56
+ columns: number | {
57
+ base?: number | undefined;
58
+ xl?: number | undefined;
59
+ lg?: number | undefined;
60
+ md?: number | undefined;
61
+ sm?: number | undefined;
62
+ '2xl'?: number | undefined;
63
+ };
64
+ gap?: string | number | undefined;
65
+ className?: string | undefined;
66
+ children?: any;
67
+ loading?: boolean | undefined;
68
+ loadingElement?: any;
69
+ skeletonCount?: number | undefined;
70
+ skeletonElement?: any;
71
+ noDataMessage?: any;
72
+ errorFallback?: any;
73
+ }>;
74
+ //# sourceMappingURL=data-grid.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-grid.d.ts","sourceRoot":"","sources":["../../src/schemas/data-grid.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAWxB,eAAO,MAAM,mBAAmB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA0D7B,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"data-list.d.ts","sourceRoot":"","sources":["../../src/schemas/data-list.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,mBAAmB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAqC7B,CAAC"}
1
+ {"version":3,"file":"data-list.d.ts","sourceRoot":"","sources":["../../src/schemas/data-list.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,mBAAmB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAmD7B,CAAC"}
@@ -0,0 +1,102 @@
1
+ {
2
+ "$ref": "#/definitions/dataGridPropsSchema",
3
+ "definitions": {
4
+ "dataGridPropsSchema": {
5
+ "type": "object",
6
+ "properties": {
7
+ "list": {
8
+ "anyOf": [
9
+ {
10
+ "type": "array"
11
+ },
12
+ {
13
+ "type": "null"
14
+ }
15
+ ],
16
+ "description": "Data array to render. null = loading state (required)"
17
+ },
18
+ "columns": {
19
+ "anyOf": [
20
+ {
21
+ "type": "number"
22
+ },
23
+ {
24
+ "type": "object",
25
+ "properties": {
26
+ "base": {
27
+ "type": "number",
28
+ "description": "Default column count (mobile-first)"
29
+ },
30
+ "sm": {
31
+ "type": "number",
32
+ "description": ">= 640px"
33
+ },
34
+ "md": {
35
+ "type": "number",
36
+ "description": ">= 768px"
37
+ },
38
+ "lg": {
39
+ "type": "number",
40
+ "description": ">= 1024px"
41
+ },
42
+ "xl": {
43
+ "type": "number",
44
+ "description": ">= 1280px"
45
+ },
46
+ "2xl": {
47
+ "type": "number",
48
+ "description": ">= 1536px"
49
+ }
50
+ },
51
+ "additionalProperties": false
52
+ }
53
+ ],
54
+ "description": "Column count. number = fixed | { base, sm, md, lg, xl, 2xl } = responsive (required)"
55
+ },
56
+ "gap": {
57
+ "type": [
58
+ "number",
59
+ "string"
60
+ ],
61
+ "description": "Item gap. number = px | string = CSS value"
62
+ },
63
+ "noDataMessage": {
64
+ "description": "Message for empty array (string | ReactElement)"
65
+ },
66
+ "errorFallback": {
67
+ "description": "Fallback on error (ReactNode)"
68
+ },
69
+ "loadingElement": {
70
+ "description": "Custom loading element (default: Spinner)"
71
+ },
72
+ "skeletonElement": {
73
+ "description": "Skeleton element during loading (ReactElement)"
74
+ },
75
+ "skeletonCount": {
76
+ "type": "number",
77
+ "default": 3,
78
+ "description": "Skeleton repeat count"
79
+ },
80
+ "loading": {
81
+ "type": "boolean",
82
+ "default": false,
83
+ "description": "Force loading state"
84
+ },
85
+ "children": {
86
+ "description": "Item render function: ({ item, index }) => ReactNode (required)"
87
+ },
88
+ "className": {
89
+ "type": "string",
90
+ "description": "Root element style"
91
+ }
92
+ },
93
+ "required": [
94
+ "list",
95
+ "columns"
96
+ ],
97
+ "additionalProperties": false,
98
+ "description": "DataGrid — card grid version of DataList with responsive columns. Built-in ErrorBoundary, loading/skeleton/empty/error states.\n\nWHEN TO USE:\n • Card grids: products, gallery, team members, posts\n • Need responsive column count → pass { base: 1, sm: 2, lg: 3, xl: 4 }\n • Single column / row layout → DataList\n • Tabular data → table component (not DataGrid)\n • Huge dataset → VirtualGrid\n\nANTI-PATTERNS:\n ✗ Tabular data forced into card grid (use a table)\n ✗ Hardcoded column count for responsive layouts → use responsive object\n ✗ Manual loading/empty handling → DataGrid does it"
99
+ }
100
+ },
101
+ "$schema": "http://json-schema.org/draft-07/schema#"
102
+ }
@@ -49,7 +49,7 @@
49
49
  "list"
50
50
  ],
51
51
  "additionalProperties": false,
52
- "description": "Data list. Automatically handles loading/skeleton/empty/data states based on list. Built-in ErrorBoundary."
52
+ "description": "DataList — render-prop list that handles loading / skeleton / empty / error / data in one component. Built-in ErrorBoundary.\n\nWHEN TO USE:\n • Any async list (<200 items) — feed, comments, dashboard rows\n • Pass list={null} during loading (auto-shows skeleton/spinner)\n • Pass list=[] for empty state (auto-shows noDataMessage)\n • Card grid → DataGrid (same API + columns prop)\n • Huge dataset → VirtualList\n\nchildren is render fn: ({ item, index }) => ReactNode.\n\nANTI-PATTERNS:\n ✗ Manual if (loading) {...} else if (!data.length) {...} chains → DataList handles all\n ✗ DataList without skeletonElement when component shape is known (use Skeleton)\n ✗ list=undefined (treated as data, not loading) — use null for loading"
53
53
  }
54
54
  },
55
55
  "$schema": "http://json-schema.org/draft-07/schema#"
@@ -1 +1 @@
1
- {"version":3,"file":"date-picker.d.ts","sourceRoot":"","sources":["../../src/schemas/date-picker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,qBAAqB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAasD,CAAC"}
1
+ {"version":3,"file":"date-picker.d.ts","sourceRoot":"","sources":["../../src/schemas/date-picker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,qBAAqB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA4B/B,CAAC"}
@@ -49,7 +49,7 @@
49
49
  }
50
50
  },
51
51
  "additionalProperties": false,
52
- "description": "DatePicker. Calendar popup for date selection. Based on react-day-picker."
52
+ "description": "DatePicker calendar popup for date selection. Based on react-day-picker.\n\nWHEN TO USE:\n • Single date selection: birthday, due date, appointment\n • Date range → use two DatePickers with minDate/maxDate cross-bound\n • Time selection → not yet supported; use TextInput with type=\"time\" + DatePicker combo\n • Quick relative ranges (Today/Last 7 days) → DropdownMenu of preset Buttons + DatePicker for \"Custom\"\n\nminDate/maxDate disable out-of-range dates. locale=\"ko\" for Korean labels.\n\nANTI-PATTERNS:\n ✗ Native <input type=\"date\"> for branded UI (inconsistent across browsers) → DatePicker\n ✗ Free-text date with parsing → DatePicker (consistent UX)\n ✗ DatePicker without minDate for past-date-invalid fields (e.g. booking)"
53
53
  }
54
54
  },
55
55
  "$schema": "http://json-schema.org/draft-07/schema#"