@timeax/form-palette 0.0.3 → 0.0.4

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 (503) hide show
  1. package/dist/adapters/axios.d.ts +21 -0
  2. package/dist/adapters/axios.d.ts.map +1 -0
  3. package/dist/adapters/axios.js +74 -0
  4. package/dist/adapters/axios.js.map +1 -0
  5. package/dist/adapters/index.d.ts +35 -0
  6. package/dist/adapters/index.d.ts.map +1 -0
  7. package/dist/adapters/index.js +74 -0
  8. package/dist/adapters/index.js.map +1 -0
  9. package/dist/adapters/inertia.d.ts +24 -0
  10. package/dist/adapters/inertia.d.ts.map +1 -0
  11. package/dist/adapters/inertia.js +126 -0
  12. package/dist/adapters/inertia.js.map +1 -0
  13. package/dist/core/adapter-registry.d.ts +30 -0
  14. package/dist/core/adapter-registry.d.ts.map +1 -0
  15. package/{src/core/adapter-registry.ts → dist/core/adapter-registry.js} +10 -28
  16. package/dist/core/adapter-registry.js.map +1 -0
  17. package/{src/core/bound/bind-host.ts → dist/core/bound/bind-host.d.ts} +2 -3
  18. package/dist/core/bound/bind-host.d.ts.map +1 -0
  19. package/dist/core/bound/bind-host.js +2 -0
  20. package/dist/core/bound/bind-host.js.map +1 -0
  21. package/dist/core/bound/observe-bound-field.d.ts +21 -0
  22. package/dist/core/bound/observe-bound-field.d.ts.map +1 -0
  23. package/dist/core/bound/observe-bound-field.js +116 -0
  24. package/dist/core/bound/observe-bound-field.js.map +1 -0
  25. package/dist/core/bound/wait-for-bound-field.d.ts +5 -0
  26. package/dist/core/bound/wait-for-bound-field.d.ts.map +1 -0
  27. package/dist/core/bound/wait-for-bound-field.js +35 -0
  28. package/dist/core/bound/wait-for-bound-field.js.map +1 -0
  29. package/{src/core/context.ts → dist/core/context.d.ts} +2 -6
  30. package/dist/core/context.d.ts.map +1 -0
  31. package/dist/core/context.js +11 -0
  32. package/dist/core/context.js.map +1 -0
  33. package/dist/core/core-provider.d.ts +22 -0
  34. package/dist/core/core-provider.d.ts.map +1 -0
  35. package/{src/core/core-provider.tsx → dist/core/core-provider.js} +209 -364
  36. package/dist/core/core-provider.js.map +1 -0
  37. package/dist/core/core-root.d.ts +26 -0
  38. package/dist/core/core-root.d.ts.map +1 -0
  39. package/dist/core/core-root.js +38 -0
  40. package/dist/core/core-root.js.map +1 -0
  41. package/dist/core/core-shell.d.ts +22 -0
  42. package/dist/core/core-shell.d.ts.map +1 -0
  43. package/dist/core/core-shell.js +8 -0
  44. package/dist/core/core-shell.js.map +1 -0
  45. package/{src/core/errors/error-strip.tsx → dist/core/errors/error-strip.d.ts} +2 -39
  46. package/dist/core/errors/error-strip.d.ts.map +1 -0
  47. package/dist/core/errors/error-strip.js +18 -0
  48. package/dist/core/errors/error-strip.js.map +1 -0
  49. package/dist/core/errors/index.d.ts +4 -0
  50. package/dist/core/errors/index.d.ts.map +1 -0
  51. package/dist/core/errors/index.js +4 -0
  52. package/dist/core/errors/index.js.map +1 -0
  53. package/dist/core/errors/map-error-bag.d.ts +24 -0
  54. package/dist/core/errors/map-error-bag.d.ts.map +1 -0
  55. package/{src/core/errors/map-error-bag.ts → dist/core/errors/map-error-bag.js} +10 -22
  56. package/dist/core/errors/map-error-bag.js.map +1 -0
  57. package/dist/core/errors/map-zod.d.ts +18 -0
  58. package/dist/core/errors/map-zod.d.ts.map +1 -0
  59. package/{src/core/errors/map-zod.ts → dist/core/errors/map-zod.js} +7 -19
  60. package/dist/core/errors/map-zod.js.map +1 -0
  61. package/dist/core/hooks/use-button.d.ts +73 -0
  62. package/dist/core/hooks/use-button.d.ts.map +1 -0
  63. package/dist/core/hooks/use-button.js +116 -0
  64. package/dist/core/hooks/use-button.js.map +1 -0
  65. package/dist/core/hooks/use-core-context.d.ts +9 -0
  66. package/dist/core/hooks/use-core-context.d.ts.map +1 -0
  67. package/{src/core/hooks/use-core-context.ts → dist/core/hooks/use-core-context.js} +3 -6
  68. package/dist/core/hooks/use-core-context.js.map +1 -0
  69. package/dist/core/hooks/use-core-utility.d.ts +1 -0
  70. package/dist/core/hooks/use-core-utility.d.ts.map +1 -0
  71. package/dist/core/hooks/use-core-utility.js +2 -0
  72. package/dist/core/hooks/use-core-utility.js.map +1 -0
  73. package/{src/core/hooks/use-core.ts → dist/core/hooks/use-core.d.ts} +9 -13
  74. package/dist/core/hooks/use-core.d.ts.map +1 -0
  75. package/dist/core/hooks/use-core.js +11 -0
  76. package/dist/core/hooks/use-core.js.map +1 -0
  77. package/dist/core/hooks/use-field.d.ts +141 -0
  78. package/dist/core/hooks/use-field.d.ts.map +1 -0
  79. package/dist/core/hooks/use-field.js +256 -0
  80. package/dist/core/hooks/use-field.js.map +1 -0
  81. package/dist/core/hooks/use-optional-field.d.ts +9 -0
  82. package/dist/core/hooks/use-optional-field.d.ts.map +1 -0
  83. package/dist/core/hooks/use-optional-field.js +146 -0
  84. package/dist/core/hooks/use-optional-field.js.map +1 -0
  85. package/dist/core/index.d.ts +11 -0
  86. package/dist/core/index.d.ts.map +1 -0
  87. package/dist/core/index.js +11 -0
  88. package/dist/core/index.js.map +1 -0
  89. package/dist/core/registry/binder-registry.d.ts +38 -0
  90. package/dist/core/registry/binder-registry.d.ts.map +1 -0
  91. package/dist/core/registry/binder-registry.js +52 -0
  92. package/dist/core/registry/binder-registry.js.map +1 -0
  93. package/dist/core/registry/field-registry.d.ts +86 -0
  94. package/dist/core/registry/field-registry.d.ts.map +1 -0
  95. package/{src/core/registry/field-registry.ts → dist/core/registry/field-registry.js} +56 -70
  96. package/dist/core/registry/field-registry.js.map +1 -0
  97. package/dist/core/test.d.ts +2 -0
  98. package/dist/core/test.d.ts.map +1 -0
  99. package/dist/core/test.js +9 -0
  100. package/dist/core/test.js.map +1 -0
  101. package/dist/index.d.ts +15 -0
  102. package/dist/index.d.ts.map +1 -0
  103. package/{src/index.ts → dist/index.js} +5 -47
  104. package/dist/index.js.map +1 -0
  105. package/{src/input/index.ts → dist/input/index.d.ts} +1 -2
  106. package/dist/input/index.d.ts.map +1 -0
  107. package/dist/input/index.js +3 -0
  108. package/dist/input/index.js.map +1 -0
  109. package/dist/input/input-field.d.ts +15 -0
  110. package/dist/input/input-field.d.ts.map +1 -0
  111. package/dist/input/input-field.js +413 -0
  112. package/dist/input/input-field.js.map +1 -0
  113. package/dist/input/input-layout-graph.d.ts +77 -0
  114. package/dist/input/input-layout-graph.d.ts.map +1 -0
  115. package/dist/input/input-layout-graph.js +108 -0
  116. package/dist/input/input-layout-graph.js.map +1 -0
  117. package/{src/input/input-props.ts → dist/input/input-props.d.ts} +22 -84
  118. package/dist/input/input-props.d.ts.map +1 -0
  119. package/dist/input/input-props.js +4 -0
  120. package/dist/input/input-props.js.map +1 -0
  121. package/dist/lib/get-global-countries.d.ts +3 -0
  122. package/dist/lib/get-global-countries.d.ts.map +1 -0
  123. package/dist/lib/get-global-countries.js +70 -0
  124. package/dist/lib/get-global-countries.js.map +1 -0
  125. package/dist/lib/utils.d.ts +3 -0
  126. package/dist/lib/utils.d.ts.map +1 -0
  127. package/dist/lib/utils.js +6 -0
  128. package/dist/lib/utils.js.map +1 -0
  129. package/dist/presets/index.d.ts +1 -0
  130. package/dist/presets/index.d.ts.map +1 -0
  131. package/dist/presets/index.js +2 -0
  132. package/dist/presets/index.js.map +1 -0
  133. package/dist/presets/shadcn-preset.d.ts +1 -0
  134. package/dist/presets/shadcn-preset.d.ts.map +1 -0
  135. package/dist/presets/shadcn-preset.js +2 -0
  136. package/dist/presets/shadcn-preset.js.map +1 -0
  137. package/dist/presets/shadcn-variants/checkbox.d.ts +212 -0
  138. package/dist/presets/shadcn-variants/checkbox.d.ts.map +1 -0
  139. package/dist/presets/shadcn-variants/checkbox.js +315 -0
  140. package/dist/presets/shadcn-variants/checkbox.js.map +1 -0
  141. package/dist/presets/shadcn-variants/chips.d.ts +154 -0
  142. package/dist/presets/shadcn-variants/chips.d.ts.map +1 -0
  143. package/dist/presets/shadcn-variants/chips.js +266 -0
  144. package/dist/presets/shadcn-variants/chips.js.map +1 -0
  145. package/dist/presets/shadcn-variants/color.d.ts +63 -0
  146. package/dist/presets/shadcn-variants/color.d.ts.map +1 -0
  147. package/dist/presets/shadcn-variants/color.js +96 -0
  148. package/dist/presets/shadcn-variants/color.js.map +1 -0
  149. package/dist/presets/shadcn-variants/custom.d.ts +94 -0
  150. package/dist/presets/shadcn-variants/custom.d.ts.map +1 -0
  151. package/dist/presets/shadcn-variants/custom.js +80 -0
  152. package/dist/presets/shadcn-variants/custom.js.map +1 -0
  153. package/dist/presets/shadcn-variants/date.d.ts +114 -0
  154. package/dist/presets/shadcn-variants/date.d.ts.map +1 -0
  155. package/dist/presets/shadcn-variants/date.js +414 -0
  156. package/dist/presets/shadcn-variants/date.js.map +1 -0
  157. package/dist/presets/shadcn-variants/file.d.ts +79 -0
  158. package/dist/presets/shadcn-variants/file.d.ts.map +1 -0
  159. package/dist/presets/shadcn-variants/file.js +289 -0
  160. package/dist/presets/shadcn-variants/file.js.map +1 -0
  161. package/dist/presets/shadcn-variants/keyvalue.d.ts +35 -0
  162. package/dist/presets/shadcn-variants/keyvalue.d.ts.map +1 -0
  163. package/dist/presets/shadcn-variants/keyvalue.js +215 -0
  164. package/dist/presets/shadcn-variants/keyvalue.js.map +1 -0
  165. package/dist/presets/shadcn-variants/multiselect.d.ts +210 -0
  166. package/dist/presets/shadcn-variants/multiselect.d.ts.map +1 -0
  167. package/dist/presets/shadcn-variants/multiselect.js +352 -0
  168. package/dist/presets/shadcn-variants/multiselect.js.map +1 -0
  169. package/dist/presets/shadcn-variants/number.d.ts +31 -0
  170. package/dist/presets/shadcn-variants/number.d.ts.map +1 -0
  171. package/dist/presets/shadcn-variants/number.js +64 -0
  172. package/dist/presets/shadcn-variants/number.js.map +1 -0
  173. package/dist/presets/shadcn-variants/password.d.ts +195 -0
  174. package/dist/presets/shadcn-variants/password.d.ts.map +1 -0
  175. package/dist/presets/shadcn-variants/password.js +296 -0
  176. package/dist/presets/shadcn-variants/password.js.map +1 -0
  177. package/dist/presets/shadcn-variants/phone.d.ts +69 -0
  178. package/dist/presets/shadcn-variants/phone.d.ts.map +1 -0
  179. package/dist/presets/shadcn-variants/phone.js +308 -0
  180. package/dist/presets/shadcn-variants/phone.js.map +1 -0
  181. package/dist/presets/shadcn-variants/radio.d.ts +172 -0
  182. package/dist/presets/shadcn-variants/radio.d.ts.map +1 -0
  183. package/dist/presets/shadcn-variants/radio.js +192 -0
  184. package/dist/presets/shadcn-variants/radio.js.map +1 -0
  185. package/dist/presets/shadcn-variants/select.d.ts +203 -0
  186. package/dist/presets/shadcn-variants/select.d.ts.map +1 -0
  187. package/dist/presets/shadcn-variants/select.js +285 -0
  188. package/dist/presets/shadcn-variants/select.js.map +1 -0
  189. package/dist/presets/shadcn-variants/slider.d.ts +131 -0
  190. package/dist/presets/shadcn-variants/slider.d.ts.map +1 -0
  191. package/dist/presets/shadcn-variants/slider.js +151 -0
  192. package/dist/presets/shadcn-variants/slider.js.map +1 -0
  193. package/dist/presets/shadcn-variants/text.d.ts +155 -0
  194. package/dist/presets/shadcn-variants/text.d.ts.map +1 -0
  195. package/dist/presets/shadcn-variants/text.js +98 -0
  196. package/dist/presets/shadcn-variants/text.js.map +1 -0
  197. package/dist/presets/shadcn-variants/textarea.d.ts +18 -0
  198. package/dist/presets/shadcn-variants/textarea.d.ts.map +1 -0
  199. package/dist/presets/shadcn-variants/textarea.js +24 -0
  200. package/dist/presets/shadcn-variants/textarea.js.map +1 -0
  201. package/dist/presets/shadcn-variants/toggle.d.ts +61 -0
  202. package/dist/presets/shadcn-variants/toggle.d.ts.map +1 -0
  203. package/dist/presets/shadcn-variants/toggle.js +67 -0
  204. package/dist/presets/shadcn-variants/toggle.js.map +1 -0
  205. package/dist/presets/shadcn-variants/treeselect.d.ts +81 -0
  206. package/dist/presets/shadcn-variants/treeselect.d.ts.map +1 -0
  207. package/dist/presets/shadcn-variants/treeselect.js +317 -0
  208. package/dist/presets/shadcn-variants/treeselect.js.map +1 -0
  209. package/dist/presets/ui/badge.d.ts +10 -0
  210. package/dist/presets/ui/badge.d.ts.map +1 -0
  211. package/dist/presets/ui/badge.js +23 -0
  212. package/dist/presets/ui/badge.js.map +1 -0
  213. package/dist/presets/ui/button.d.ts +11 -0
  214. package/dist/presets/ui/button.d.ts.map +1 -0
  215. package/dist/presets/ui/button.js +34 -0
  216. package/dist/presets/ui/button.js.map +1 -0
  217. package/dist/presets/ui/calendar.d.ts +9 -0
  218. package/dist/presets/ui/calendar.d.ts.map +1 -0
  219. package/dist/presets/ui/calendar.js +76 -0
  220. package/dist/presets/ui/calendar.js.map +1 -0
  221. package/dist/presets/ui/checkbox.d.ts +18 -0
  222. package/dist/presets/ui/checkbox.d.ts.map +1 -0
  223. package/dist/presets/ui/checkbox.js +61 -0
  224. package/dist/presets/ui/checkbox.js.map +1 -0
  225. package/dist/presets/ui/custom.d.ts +1 -0
  226. package/dist/presets/ui/custom.d.ts.map +1 -0
  227. package/dist/presets/ui/custom.js +2 -0
  228. package/dist/presets/ui/custom.js.map +1 -0
  229. package/dist/presets/ui/dialog.d.ts +16 -0
  230. package/dist/presets/ui/dialog.d.ts.map +1 -0
  231. package/dist/presets/ui/dialog.js +36 -0
  232. package/dist/presets/ui/dialog.js.map +1 -0
  233. package/dist/presets/ui/field.d.ts +25 -0
  234. package/dist/presets/ui/field.d.ts.map +1 -0
  235. package/dist/presets/ui/field.js +76 -0
  236. package/dist/presets/ui/field.js.map +1 -0
  237. package/dist/presets/ui/input-mask.d.ts +34 -0
  238. package/dist/presets/ui/input-mask.d.ts.map +1 -0
  239. package/dist/presets/ui/input-mask.js +561 -0
  240. package/dist/presets/ui/input-mask.js.map +1 -0
  241. package/dist/presets/ui/input-otp.d.ts +12 -0
  242. package/dist/presets/ui/input-otp.d.ts.map +1 -0
  243. package/dist/presets/ui/input-otp.js +22 -0
  244. package/dist/presets/ui/input-otp.js.map +1 -0
  245. package/dist/presets/ui/input.d.ts +83 -0
  246. package/dist/presets/ui/input.d.ts.map +1 -0
  247. package/dist/presets/ui/input.js +436 -0
  248. package/dist/presets/ui/input.js.map +1 -0
  249. package/dist/presets/ui/label.d.ts +5 -0
  250. package/dist/presets/ui/label.d.ts.map +1 -0
  251. package/dist/presets/ui/label.js +8 -0
  252. package/dist/presets/ui/label.js.map +1 -0
  253. package/dist/presets/ui/number.d.ts +60 -0
  254. package/dist/presets/ui/number.d.ts.map +1 -0
  255. package/dist/presets/ui/number.js +1078 -0
  256. package/dist/presets/ui/number.js.map +1 -0
  257. package/dist/presets/ui/popover.d.ts +8 -0
  258. package/dist/presets/ui/popover.d.ts.map +1 -0
  259. package/dist/presets/ui/popover.js +17 -0
  260. package/dist/presets/ui/popover.js.map +1 -0
  261. package/dist/presets/ui/radio-group.d.ts +6 -0
  262. package/dist/presets/ui/radio-group.d.ts.map +1 -0
  263. package/dist/presets/ui/radio-group.js +12 -0
  264. package/dist/presets/ui/radio-group.js.map +1 -0
  265. package/dist/presets/ui/scroll-area.d.ts +6 -0
  266. package/dist/presets/ui/scroll-area.d.ts.map +1 -0
  267. package/dist/presets/ui/scroll-area.js +13 -0
  268. package/dist/presets/ui/scroll-area.js.map +1 -0
  269. package/dist/presets/ui/select.d.ts +21 -0
  270. package/dist/presets/ui/select.d.ts.map +1 -0
  271. package/dist/presets/ui/select.js +38 -0
  272. package/dist/presets/ui/select.js.map +1 -0
  273. package/dist/presets/ui/separator.d.ts +5 -0
  274. package/dist/presets/ui/separator.d.ts.map +1 -0
  275. package/dist/presets/ui/separator.js +9 -0
  276. package/dist/presets/ui/separator.js.map +1 -0
  277. package/dist/presets/ui/slider.d.ts +5 -0
  278. package/dist/presets/ui/slider.d.ts.map +1 -0
  279. package/dist/presets/ui/slider.js +14 -0
  280. package/dist/presets/ui/slider.js.map +1 -0
  281. package/dist/presets/ui/switch.d.ts +7 -0
  282. package/dist/presets/ui/switch.d.ts.map +1 -0
  283. package/dist/presets/ui/switch.js +9 -0
  284. package/dist/presets/ui/switch.js.map +1 -0
  285. package/dist/presets/ui/textarea.d.ts +76 -0
  286. package/dist/presets/ui/textarea.d.ts.map +1 -0
  287. package/dist/presets/ui/textarea.js +291 -0
  288. package/dist/presets/ui/textarea.js.map +1 -0
  289. package/dist/presets/ui/time-dropdowns.d.ts +58 -0
  290. package/dist/presets/ui/time-dropdowns.d.ts.map +1 -0
  291. package/dist/presets/ui/time-dropdowns.js +133 -0
  292. package/dist/presets/ui/time-dropdowns.js.map +1 -0
  293. package/{src/schema/adapter.ts → dist/schema/adapter.d.ts} +7 -35
  294. package/dist/schema/adapter.d.ts.map +1 -0
  295. package/dist/schema/adapter.js +3 -0
  296. package/dist/schema/adapter.js.map +1 -0
  297. package/{src/schema/core.ts → dist/schema/core.d.ts} +17 -117
  298. package/dist/schema/core.d.ts.map +1 -0
  299. package/dist/schema/core.js +4 -0
  300. package/dist/schema/core.js.map +1 -0
  301. package/dist/schema/field-map.d.ts +1 -0
  302. package/dist/schema/field-map.d.ts.map +1 -0
  303. package/dist/schema/field-map.js +2 -0
  304. package/dist/schema/field-map.js.map +1 -0
  305. package/{src/schema/field.ts → dist/schema/field.d.ts} +1 -34
  306. package/dist/schema/field.d.ts.map +1 -0
  307. package/dist/schema/field.js +4 -0
  308. package/dist/schema/field.js.map +1 -0
  309. package/dist/schema/index.d.ts +1 -0
  310. package/dist/schema/index.d.ts.map +1 -0
  311. package/dist/schema/index.js +2 -0
  312. package/dist/schema/index.js.map +1 -0
  313. package/{src/schema/input-field.ts → dist/schema/input-field.d.ts} +6 -43
  314. package/dist/schema/input-field.d.ts.map +1 -0
  315. package/dist/schema/input-field.js +3 -0
  316. package/dist/schema/input-field.js.map +1 -0
  317. package/dist/schema/presets.d.ts +1 -0
  318. package/dist/schema/presets.d.ts.map +1 -0
  319. package/dist/schema/presets.js +2 -0
  320. package/dist/schema/presets.js.map +1 -0
  321. package/{src/schema/variant.ts → dist/schema/variant.d.ts} +24 -64
  322. package/dist/schema/variant.d.ts.map +1 -0
  323. package/dist/schema/variant.js +3 -0
  324. package/dist/schema/variant.js.map +1 -0
  325. package/dist/variants/core/checkbox.d.ts +15 -0
  326. package/dist/variants/core/checkbox.d.ts.map +1 -0
  327. package/dist/variants/core/checkbox.js +27 -0
  328. package/dist/variants/core/checkbox.js.map +1 -0
  329. package/dist/variants/core/chips.d.ts +3 -0
  330. package/dist/variants/core/chips.d.ts.map +1 -0
  331. package/dist/variants/core/chips.js +20 -0
  332. package/dist/variants/core/chips.js.map +1 -0
  333. package/dist/variants/core/color.d.ts +3 -0
  334. package/dist/variants/core/color.d.ts.map +1 -0
  335. package/dist/variants/core/color.js +14 -0
  336. package/dist/variants/core/color.js.map +1 -0
  337. package/dist/variants/core/custom.d.ts +11 -0
  338. package/dist/variants/core/custom.d.ts.map +1 -0
  339. package/{src/variants/core/custom.tsx → dist/variants/core/custom.js} +15 -18
  340. package/dist/variants/core/custom.js.map +1 -0
  341. package/dist/variants/core/date.d.ts +3 -0
  342. package/dist/variants/core/date.d.ts.map +1 -0
  343. package/dist/variants/core/date.js +20 -0
  344. package/dist/variants/core/date.js.map +1 -0
  345. package/dist/variants/core/file.d.ts +3 -0
  346. package/dist/variants/core/file.d.ts.map +1 -0
  347. package/dist/variants/core/file.js +6 -0
  348. package/dist/variants/core/file.js.map +1 -0
  349. package/dist/variants/core/keyvalue.d.ts +3 -0
  350. package/dist/variants/core/keyvalue.d.ts.map +1 -0
  351. package/dist/variants/core/keyvalue.js +9 -0
  352. package/dist/variants/core/keyvalue.js.map +1 -0
  353. package/dist/variants/core/multiselect.d.ts +11 -0
  354. package/dist/variants/core/multiselect.d.ts.map +1 -0
  355. package/dist/variants/core/multiselect.js +15 -0
  356. package/dist/variants/core/multiselect.js.map +1 -0
  357. package/dist/variants/core/number.d.ts +38 -0
  358. package/dist/variants/core/number.d.ts.map +1 -0
  359. package/dist/variants/core/number.js +62 -0
  360. package/dist/variants/core/number.js.map +1 -0
  361. package/dist/variants/core/password.d.ts +11 -0
  362. package/dist/variants/core/password.d.ts.map +1 -0
  363. package/dist/variants/core/password.js +29 -0
  364. package/dist/variants/core/password.js.map +1 -0
  365. package/dist/variants/core/phone.d.ts +3 -0
  366. package/dist/variants/core/phone.d.ts.map +1 -0
  367. package/dist/variants/core/phone.js +14 -0
  368. package/dist/variants/core/phone.js.map +1 -0
  369. package/dist/variants/core/radio.d.ts +8 -0
  370. package/dist/variants/core/radio.d.ts.map +1 -0
  371. package/dist/variants/core/radio.js +34 -0
  372. package/dist/variants/core/radio.js.map +1 -0
  373. package/dist/variants/core/select.d.ts +5 -0
  374. package/dist/variants/core/select.d.ts.map +1 -0
  375. package/dist/variants/core/select.js +11 -0
  376. package/dist/variants/core/select.js.map +1 -0
  377. package/dist/variants/core/slider.d.ts +19 -0
  378. package/dist/variants/core/slider.d.ts.map +1 -0
  379. package/dist/variants/core/slider.js +36 -0
  380. package/dist/variants/core/slider.js.map +1 -0
  381. package/dist/variants/core/text.d.ts +38 -0
  382. package/dist/variants/core/text.d.ts.map +1 -0
  383. package/{src/variants/core/text.tsx → dist/variants/core/text.js} +4 -56
  384. package/dist/variants/core/text.js.map +1 -0
  385. package/dist/variants/core/textarea.d.ts +3 -0
  386. package/dist/variants/core/textarea.d.ts.map +1 -0
  387. package/dist/variants/core/textarea.js +20 -0
  388. package/dist/variants/core/textarea.js.map +1 -0
  389. package/dist/variants/core/toggle.d.ts +6 -0
  390. package/dist/variants/core/toggle.d.ts.map +1 -0
  391. package/dist/variants/core/toggle.js +41 -0
  392. package/dist/variants/core/toggle.js.map +1 -0
  393. package/dist/variants/core/treeselect.d.ts +4 -0
  394. package/dist/variants/core/treeselect.d.ts.map +1 -0
  395. package/dist/variants/core/treeselect.js +7 -0
  396. package/dist/variants/core/treeselect.js.map +1 -0
  397. package/dist/variants/helpers/selection-summary.d.ts +24 -0
  398. package/dist/variants/helpers/selection-summary.d.ts.map +1 -0
  399. package/dist/variants/helpers/selection-summary.js +105 -0
  400. package/dist/variants/helpers/selection-summary.js.map +1 -0
  401. package/dist/variants/index.d.ts +16 -0
  402. package/dist/variants/index.d.ts.map +1 -0
  403. package/{src/variants/index.ts → dist/variants/index.js} +7 -27
  404. package/dist/variants/index.js.map +1 -0
  405. package/dist/variants/registry.d.ts +19 -0
  406. package/dist/variants/registry.d.ts.map +1 -0
  407. package/dist/variants/registry.js +29 -0
  408. package/dist/variants/registry.js.map +1 -0
  409. package/dist/variants/select-shared.d.ts +1 -0
  410. package/dist/variants/select-shared.d.ts.map +1 -0
  411. package/dist/variants/select-shared.js +2 -0
  412. package/dist/variants/select-shared.js.map +1 -0
  413. package/{src/variants/shared.ts → dist/variants/shared.d.ts} +3 -22
  414. package/dist/variants/shared.d.ts.map +1 -0
  415. package/dist/variants/shared.js +3 -0
  416. package/dist/variants/shared.js.map +1 -0
  417. package/package.json +4 -4
  418. package/.scaffold-cache.json +0 -537
  419. package/src/.scaffold-cache.json +0 -544
  420. package/src/adapters/axios.ts +0 -117
  421. package/src/adapters/index.ts +0 -91
  422. package/src/adapters/inertia.ts +0 -187
  423. package/src/core/bound/observe-bound-field.ts +0 -172
  424. package/src/core/bound/wait-for-bound-field.ts +0 -57
  425. package/src/core/core-root.tsx +0 -72
  426. package/src/core/core-shell.tsx +0 -44
  427. package/src/core/errors/index.ts +0 -2
  428. package/src/core/hooks/use-button.ts +0 -220
  429. package/src/core/hooks/use-core-utility.ts +0 -0
  430. package/src/core/hooks/use-field.ts +0 -497
  431. package/src/core/hooks/use-optional-field.ts +0 -28
  432. package/src/core/index.ts +0 -0
  433. package/src/core/registry/binder-registry.ts +0 -82
  434. package/src/core/test.tsx +0 -17
  435. package/src/global.d.ts +0 -14
  436. package/src/input/input-field.tsx +0 -854
  437. package/src/input/input-layout-graph.ts +0 -230
  438. package/src/lib/get-global-countries.ts +0 -87
  439. package/src/lib/utils.ts +0 -6
  440. package/src/presets/index.ts +0 -0
  441. package/src/presets/shadcn-preset.ts +0 -0
  442. package/src/presets/shadcn-variants/checkbox.tsx +0 -849
  443. package/src/presets/shadcn-variants/chips.tsx +0 -756
  444. package/src/presets/shadcn-variants/color.tsx +0 -284
  445. package/src/presets/shadcn-variants/custom.tsx +0 -227
  446. package/src/presets/shadcn-variants/date.tsx +0 -796
  447. package/src/presets/shadcn-variants/file.tsx +0 -764
  448. package/src/presets/shadcn-variants/keyvalue.tsx +0 -556
  449. package/src/presets/shadcn-variants/multiselect.tsx +0 -1132
  450. package/src/presets/shadcn-variants/number.tsx +0 -176
  451. package/src/presets/shadcn-variants/password.tsx +0 -737
  452. package/src/presets/shadcn-variants/phone.tsx +0 -628
  453. package/src/presets/shadcn-variants/radio.tsx +0 -578
  454. package/src/presets/shadcn-variants/select.tsx +0 -956
  455. package/src/presets/shadcn-variants/slider.tsx +0 -622
  456. package/src/presets/shadcn-variants/text.tsx +0 -343
  457. package/src/presets/shadcn-variants/textarea.tsx +0 -66
  458. package/src/presets/shadcn-variants/toggle.tsx +0 -218
  459. package/src/presets/shadcn-variants/treeselect.tsx +0 -784
  460. package/src/presets/ui/badge.tsx +0 -46
  461. package/src/presets/ui/button.tsx +0 -60
  462. package/src/presets/ui/calendar.tsx +0 -214
  463. package/src/presets/ui/checkbox.tsx +0 -115
  464. package/src/presets/ui/custom.tsx +0 -0
  465. package/src/presets/ui/dialog.tsx +0 -141
  466. package/src/presets/ui/field.tsx +0 -246
  467. package/src/presets/ui/input-mask.tsx +0 -739
  468. package/src/presets/ui/input-otp.tsx +0 -77
  469. package/src/presets/ui/input.tsx +0 -1011
  470. package/src/presets/ui/label.tsx +0 -22
  471. package/src/presets/ui/number.tsx +0 -1370
  472. package/src/presets/ui/popover.tsx +0 -46
  473. package/src/presets/ui/radio-group.tsx +0 -43
  474. package/src/presets/ui/scroll-area.tsx +0 -56
  475. package/src/presets/ui/select.tsx +0 -190
  476. package/src/presets/ui/separator.tsx +0 -28
  477. package/src/presets/ui/slider.tsx +0 -61
  478. package/src/presets/ui/switch.tsx +0 -32
  479. package/src/presets/ui/textarea.tsx +0 -634
  480. package/src/presets/ui/time-dropdowns.tsx +0 -350
  481. package/src/schema/field-map.ts +0 -0
  482. package/src/schema/index.ts +0 -0
  483. package/src/schema/presets.ts +0 -0
  484. package/src/variants/core/checkbox.tsx +0 -54
  485. package/src/variants/core/chips.tsx +0 -22
  486. package/src/variants/core/color.tsx +0 -16
  487. package/src/variants/core/date.tsx +0 -25
  488. package/src/variants/core/file.tsx +0 -9
  489. package/src/variants/core/keyvalue.tsx +0 -12
  490. package/src/variants/core/multiselect.tsx +0 -28
  491. package/src/variants/core/number.tsx +0 -115
  492. package/src/variants/core/password.tsx +0 -35
  493. package/src/variants/core/phone.tsx +0 -16
  494. package/src/variants/core/radio.tsx +0 -38
  495. package/src/variants/core/select.tsx +0 -15
  496. package/src/variants/core/slider.tsx +0 -55
  497. package/src/variants/core/textarea.tsx +0 -22
  498. package/src/variants/core/toggle.tsx +0 -50
  499. package/src/variants/core/treeselect.tsx +0 -11
  500. package/src/variants/helpers/selection-summary.tsx +0 -236
  501. package/src/variants/registry.ts +0 -38
  502. package/src/variants/select-shared.ts +0 -0
  503. package/tsconfig.json +0 -14
@@ -1,556 +0,0 @@
1
- import * as React from "react";
2
- import type { VariantBaseProps, ChangeDetail } from "@/variants/shared";
3
- import { cn } from "@/lib/utils";
4
-
5
- import { Button } from "@/presets/ui/button";
6
- import { Input } from "@/presets/ui/input";
7
- import {
8
- Dialog,
9
- DialogContent,
10
- DialogHeader,
11
- DialogTitle,
12
- DialogFooter,
13
- DialogDescription,
14
- } from "@/presets/ui/dialog";
15
- import { X, Plus, MoreHorizontal, Tag, PenLine } from "lucide-react";
16
-
17
- type Size = "sm" | "md" | "lg";
18
- type Density = "compact" | "comfortable" | "loose";
19
-
20
- export type KeyValueMap = Record<string, string>;
21
-
22
- export interface KV {
23
- key: string;
24
- value: string;
25
- }
26
-
27
- export interface ShadcnKeyValueVariantProps
28
- extends Pick<
29
- VariantBaseProps<KeyValueMap | undefined>,
30
- "value" | "onValue" | "error" | "disabled" | "readOnly" | "size" | "density"
31
- > {
32
- min?: number;
33
- max?: number;
34
- minVisible?: number;
35
- maxVisible?: number;
36
- showAddButton?: boolean;
37
- showMenuButton?: boolean;
38
- placeholder?: React.ReactNode;
39
- dialogTitle?: React.ReactNode;
40
- keyLabel?: React.ReactNode;
41
- valueLabel?: React.ReactNode;
42
- submitLabel?: React.ReactNode;
43
- moreLabel?: (count: number) => React.ReactNode;
44
- emptyLabel?: React.ReactNode;
45
- className?: string;
46
- chipsClassName?: string;
47
- chipClassName?: string;
48
- renderChip?: (ctx: {
49
- pair: KV;
50
- index: number;
51
- onEdit: () => void;
52
- onRemove: () => void;
53
- defaultChip: React.ReactNode;
54
- }) => React.ReactNode;
55
- }
56
-
57
- // ─────────────────────────────────────────────
58
- // Helpers
59
- // ─────────────────────────────────────────────
60
-
61
- function mapToItems(map: KeyValueMap | undefined): KV[] {
62
- if (!map) return [];
63
- return Object.entries(map).map(([key, value]) => ({
64
- key,
65
- value: value ?? "",
66
- }));
67
- }
68
-
69
- function itemsToMap(items: KV[]): KeyValueMap {
70
- const out: KeyValueMap = {};
71
- for (const { key, value } of items) {
72
- if (!key) continue;
73
- out[key] = value;
74
- }
75
- return out;
76
- }
77
-
78
- function clampVisible(
79
- total: number,
80
- minVisible: number,
81
- maxVisible: number
82
- ): number {
83
- if (total === 0) return 0;
84
- const clampedMax = Math.max(minVisible, maxVisible);
85
- return Math.min(total, clampedMax);
86
- }
87
-
88
- function sizeClasses(size?: Size) {
89
- switch (size) {
90
- case "sm":
91
- return "text-xs min-h-[2rem]";
92
- case "lg":
93
- return "text-sm min-h-[2.75rem]";
94
- case "md":
95
- default:
96
- return "text-sm min-h-[2.5rem]";
97
- }
98
- }
99
-
100
- function densityPadding(density?: Density) {
101
- switch (density) {
102
- case "compact":
103
- return "py-1 px-2 gap-1.5";
104
- case "loose":
105
- return "py-3 px-3 gap-3";
106
- case "comfortable":
107
- default:
108
- return "py-2 px-3 gap-2";
109
- }
110
- }
111
-
112
- function defaultMoreLabel(count: number): React.ReactNode {
113
- return `+${count} more`;
114
- }
115
-
116
- // ─────────────────────────────────────────────
117
- // Component
118
- // ─────────────────────────────────────────────
119
-
120
- export const ShadcnKeyValueVariant = React.forwardRef<
121
- HTMLDivElement,
122
- ShadcnKeyValueVariantProps
123
- >(function ShadcnKeyValueVariant(props, _ref) {
124
- const {
125
- value,
126
- onValue,
127
- error,
128
- disabled,
129
- readOnly,
130
- size,
131
- density,
132
-
133
- min = 0,
134
- max = Infinity,
135
- minVisible = 0,
136
- maxVisible = 6,
137
-
138
- showAddButton = true,
139
- showMenuButton = true,
140
-
141
- placeholder,
142
- dialogTitle = "Edit Item",
143
- keyLabel = "Key",
144
- valueLabel = "Value",
145
- submitLabel = "Save Changes",
146
- moreLabel = defaultMoreLabel,
147
- emptyLabel = "No items added",
148
-
149
- className,
150
- chipsClassName,
151
- chipClassName,
152
- renderChip,
153
- } = props;
154
-
155
- const isDisabled = disabled || readOnly;
156
-
157
- const items: KV[] = React.useMemo(
158
- () => mapToItems(value),
159
- [value]
160
- );
161
-
162
- const [dialogOpen, setDialogOpen] = React.useState(false);
163
- const [editingIndex, setEditingIndex] = React.useState<number | null>(
164
- null
165
- );
166
- const [draft, setDraft] = React.useState<KV>({ key: "", value: "" });
167
-
168
- const canAdd = items.length < max;
169
- const canDelete = items.length > min;
170
-
171
- // visible vs overflow
172
- const visibleCount = clampVisible(
173
- items.length,
174
- minVisible,
175
- maxVisible
176
- );
177
- const visibleItems = items.slice(0, visibleCount);
178
- const overflowCount = Math.max(0, items.length - visibleCount);
179
-
180
- // ────────────────────────────────
181
- // Change Logic
182
- // ────────────────────────────────
183
-
184
- const commitItems = React.useCallback(
185
- (next: KV[], meta: ChangeDetail["meta"]) => {
186
- if (!onValue) return;
187
-
188
- const nextMap = itemsToMap(next);
189
- const detail: ChangeDetail = {
190
- source: "variant",
191
- raw: next,
192
- nativeEvent: undefined,
193
- meta,
194
- };
195
- onValue(nextMap, detail);
196
- },
197
- [onValue]
198
- );
199
-
200
- const openForNew = React.useCallback(() => {
201
- if (isDisabled || !canAdd) return;
202
- setEditingIndex(null);
203
- setDraft({ key: "", value: "" });
204
- setDialogOpen(true);
205
- }, [isDisabled, canAdd]);
206
-
207
- const openForEdit = React.useCallback(
208
- (index: number) => {
209
- if (isDisabled) return;
210
- const item = items[index];
211
- if (!item) return;
212
- setEditingIndex(index);
213
- setDraft(item);
214
- setDialogOpen(true);
215
- },
216
- [isDisabled, items]
217
- );
218
-
219
- const handleDelete = React.useCallback(() => {
220
- if (editingIndex == null) return;
221
- if (!canDelete) return;
222
-
223
- const next = items.slice();
224
- next.splice(editingIndex, 1);
225
-
226
- setDialogOpen(false);
227
- commitItems(next, {
228
- action: "delete",
229
- index: editingIndex,
230
- });
231
- }, [editingIndex, items, canDelete, commitItems]);
232
-
233
- const handleSubmit = React.useCallback(() => {
234
- const trimmedKey = draft.key.trim();
235
- const trimmedValue = draft.value;
236
-
237
- if (!trimmedKey) return;
238
-
239
- let next = items.slice();
240
-
241
- if (editingIndex != null) {
242
- // edit
243
- next[editingIndex] = { key: trimmedKey, value: trimmedValue };
244
- } else {
245
- // add / upsert
246
- const existingIndex = next.findIndex(
247
- (kv) => kv.key === trimmedKey
248
- );
249
- if (existingIndex !== -1) {
250
- next[existingIndex] = {
251
- key: trimmedKey,
252
- value: trimmedValue,
253
- };
254
- } else {
255
- if (!canAdd) return;
256
- next.push({ key: trimmedKey, value: trimmedValue });
257
- }
258
- }
259
-
260
- setDialogOpen(false);
261
- commitItems(next, {
262
- action: editingIndex != null ? "edit" : "add",
263
- index: editingIndex ?? next.length - 1,
264
- });
265
- }, [draft, items, editingIndex, canAdd, commitItems]);
266
-
267
- const handleQuickRemove = React.useCallback(
268
- (index: number) => {
269
- if (isDisabled || !canDelete) return;
270
- const next = items.slice();
271
- next.splice(index, 1);
272
- commitItems(next, { action: "delete", index });
273
- },
274
- [isDisabled, canDelete, items, commitItems]
275
- );
276
-
277
- // ────────────────────────────────
278
- // Visuals
279
- // ────────────────────────────────
280
-
281
- const sizeCls = sizeClasses(size as Size | undefined);
282
- const densityCls = densityPadding(density as Density | undefined);
283
-
284
- const renderChipNode = (pair: KV, index: number) => {
285
- const baseChip = (
286
- <button
287
- type="button"
288
- key={index}
289
- className={cn(
290
- "group inline-flex items-center gap-1.5 rounded-md",
291
- "bg-secondary/50 border border-transparent",
292
- "px-2 py-1 text-xs transition-all duration-200",
293
- "hover:bg-secondary hover:border-border/50 hover:shadow-sm",
294
- "animate-in fade-in zoom-in-95 fill-mode-both",
295
- isDisabled && "opacity-50 cursor-not-allowed",
296
- chipClassName
297
- )}
298
- onClick={() => openForEdit(index)}
299
- disabled={isDisabled}
300
- >
301
- <span className="font-semibold text-foreground truncate max-w-[120px]">
302
- {pair.key}
303
- </span>
304
- <span className="text-muted-foreground/40">:</span>
305
- <span className="text-muted-foreground truncate max-w-[120px]">
306
- {pair.value}
307
- </span>
308
-
309
- {canDelete && !isDisabled && (
310
- <div
311
- role="button"
312
- tabIndex={0}
313
- className={cn(
314
- "ml-1 flex h-4 w-4 items-center justify-center rounded-full",
315
- "text-muted-foreground/60 opacity-0 transition-all",
316
- "hover:bg-destructive hover:text-destructive-foreground",
317
- "group-hover:opacity-100",
318
- "focus-visible:opacity-100 focus-visible:ring-2 focus-visible:ring-ring"
319
- )}
320
- onClick={(e) => {
321
- e.stopPropagation();
322
- handleQuickRemove(index);
323
- }}
324
- onKeyDown={(e) => {
325
- if (e.key === "Enter" || e.key === " ") {
326
- e.stopPropagation();
327
- handleQuickRemove(index);
328
- }
329
- }}
330
- aria-label={`Remove ${pair.key}`}
331
- >
332
- <X className="h-3 w-3" />
333
- </div>
334
- )}
335
- </button>
336
- );
337
-
338
- if (!renderChip) return baseChip;
339
-
340
- return renderChip({
341
- pair,
342
- index,
343
- onEdit: () => openForEdit(index),
344
- onRemove: () => handleQuickRemove(index),
345
- defaultChip: baseChip,
346
- });
347
- };
348
-
349
- const hasItems = items.length > 0;
350
-
351
- // ────────────────────────────────
352
- // Dialog
353
- // ────────────────────────────────
354
-
355
- const ManageDialog = (
356
- <Dialog open={dialogOpen} onOpenChange={setDialogOpen}>
357
- <DialogContent className="sm:max-w-[425px]">
358
- <DialogHeader>
359
- <DialogTitle className="flex items-center gap-2">
360
- <PenLine className="h-4 w-4 text-muted-foreground" />
361
- {dialogTitle}
362
- </DialogTitle>
363
- <DialogDescription>
364
- {editingIndex !== null ? "Modify the existing key-value pair." : "Add a new key-value pair to the list."}
365
- </DialogDescription>
366
- </DialogHeader>
367
-
368
- <div className="grid gap-4 py-4">
369
- <div className="grid grid-cols-4 items-center gap-4">
370
- <label className="text-right text-sm font-medium text-muted-foreground">
371
- {keyLabel}
372
- </label>
373
- <Input
374
- value={draft.key}
375
- onChange={(e) =>
376
- setDraft((prev) => ({
377
- ...prev,
378
- key: e.target.value,
379
- }))
380
- }
381
- className="col-span-3"
382
- autoFocus
383
- disabled={isDisabled}
384
- placeholder="e.g. Color"
385
- />
386
- </div>
387
- <div className="grid grid-cols-4 items-center gap-4">
388
- <label className="text-right text-sm font-medium text-muted-foreground">
389
- {valueLabel}
390
- </label>
391
- <Input
392
- value={draft.value}
393
- onChange={(e) =>
394
- setDraft((prev) => ({
395
- ...prev,
396
- value: e.target.value,
397
- }))
398
- }
399
- className="col-span-3"
400
- disabled={isDisabled}
401
- placeholder="e.g. Blue"
402
- onKeyDown={(e) => {
403
- if (e.key === 'Enter') handleSubmit();
404
- }}
405
- />
406
- </div>
407
- </div>
408
-
409
- <DialogFooter className="flex sm:justify-between flex-row items-center">
410
- <div>
411
- {editingIndex != null && canDelete && (
412
- <Button
413
- type="button"
414
- variant="destructive"
415
- size="sm"
416
- onClick={handleDelete}
417
- disabled={isDisabled}
418
- >
419
- Delete
420
- </Button>
421
- )}
422
- </div>
423
-
424
- <div className="flex gap-2">
425
- <Button
426
- type="button"
427
- variant="outline"
428
- size="sm"
429
- onClick={() => setDialogOpen(false)}
430
- >
431
- Cancel
432
- </Button>
433
- <Button
434
- type="button"
435
- size="sm"
436
- onClick={handleSubmit}
437
- disabled={isDisabled}
438
- >
439
- {submitLabel}
440
- </Button>
441
- </div>
442
- </DialogFooter>
443
- </DialogContent>
444
- </Dialog>
445
- );
446
-
447
- // ────────────────────────────────
448
- // Render
449
- // ────────────────────────────────
450
-
451
- return (
452
- <div
453
- className={cn(
454
- "group/container w-full",
455
- isDisabled && "opacity-60 cursor-not-allowed",
456
- className
457
- )}
458
- aria-disabled={isDisabled}
459
- aria-invalid={error ? "true" : undefined}
460
- >
461
- {/* Container mimicking an Input */}
462
- <div
463
- className={cn(
464
- "relative flex w-full flex-wrap items-center rounded-md border border-input bg-background transition-all",
465
- // Focus within styles to mimic Input focus
466
- !isDisabled && "focus-within:ring-2 focus-within:ring-ring focus-within:ring-offset-2 focus-within:ring-offset-background",
467
- densityCls,
468
- sizeCls,
469
- chipsClassName
470
- )}
471
- >
472
- {hasItems ? (
473
- <>
474
- {visibleItems.map((pair, index) =>
475
- renderChipNode(pair, index)
476
- )}
477
-
478
- {overflowCount > 0 && (
479
- <button
480
- type="button"
481
- className={cn(
482
- "inline-flex h-6 items-center gap-1 rounded-full",
483
- "bg-muted px-2 text-[11px] font-medium text-muted-foreground",
484
- "hover:bg-muted/80 hover:text-foreground transition-colors"
485
- )}
486
- onClick={() => {
487
- setDialogOpen(true);
488
- setEditingIndex(null);
489
- setDraft({ key: "", value: "" });
490
- }}
491
- disabled={isDisabled}
492
- >
493
- {moreLabel(overflowCount)}
494
- </button>
495
- )}
496
- </>
497
- ) : (
498
- <div className="flex items-center gap-2 text-muted-foreground/60 select-none">
499
- <Tag className="h-3.5 w-3.5" />
500
- <span className="text-sm">{placeholder ?? emptyLabel}</span>
501
- </div>
502
- )}
503
-
504
- {/* Inline Add Button */}
505
- {showAddButton && canAdd && !isDisabled && (
506
- <button
507
- type="button"
508
- onClick={openForNew}
509
- className={cn(
510
- "inline-flex h-6 items-center gap-1 rounded-full",
511
- "border border-dashed border-muted-foreground/30 px-2",
512
- "text-[11px] font-medium text-muted-foreground",
513
- "hover:border-primary/50 hover:bg-accent hover:text-accent-foreground transition-all",
514
- "focus-visible:ring-2 focus-visible:ring-ring focus-visible:outline-none"
515
- )}
516
- >
517
- <Plus className="h-3 w-3" />
518
- <span>Add</span>
519
- </button>
520
- )}
521
-
522
- {/* Menu/Manage Button */}
523
- {showMenuButton && hasItems && !isDisabled && (
524
- <div className="ml-auto pl-1">
525
- <button
526
- type="button"
527
- onClick={() => {
528
- // Default behavior: open "Add New"
529
- setDialogOpen(true);
530
- setEditingIndex(null);
531
- setDraft({ key: "", value: "" });
532
- }}
533
- className="flex h-6 w-6 items-center justify-center rounded-sm text-muted-foreground hover:bg-accent hover:text-accent-foreground"
534
- aria-label="Add another"
535
- >
536
- <MoreHorizontal className="h-4 w-4" />
537
- </button>
538
- </div>
539
- )}
540
- </div>
541
-
542
- {/* Error Message Support (Optional usage) */}
543
- {error && typeof error === 'string' && (
544
- <p className="mt-1.5 text-xs font-medium text-destructive">
545
- {error}
546
- </p>
547
- )}
548
-
549
- {ManageDialog}
550
- </div>
551
- );
552
- });
553
-
554
- ShadcnKeyValueVariant.displayName = "ShadcnKeyValueVariant";
555
-
556
- export default ShadcnKeyValueVariant;