@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,739 +0,0 @@
1
- import * as React from "react";
2
- import { Input } from "@/presets/ui/input";
3
-
4
- export interface InputMaskChangeEvent {
5
- originalEvent: React.SyntheticEvent<HTMLInputElement> | Event | undefined;
6
- value: string;
7
- stopPropagation(): void;
8
- preventDefault(): void;
9
- target: {
10
- name?: string;
11
- id?: string;
12
- value: string;
13
- };
14
- }
15
-
16
- export interface InputMaskCompleteEvent {
17
- originalEvent: React.SyntheticEvent<HTMLInputElement> | Event;
18
- value: string;
19
- }
20
-
21
- export interface InputMaskRef {
22
- focus(): void;
23
- getElement(): HTMLInputElement | null;
24
- }
25
-
26
- export interface InputMaskProps
27
- extends Omit<
28
- React.InputHTMLAttributes<HTMLInputElement>,
29
- "onChange" | "value" | "defaultValue"
30
- > {
31
- mask: string | null;
32
- autoClear?: boolean;
33
- autoFocus?: boolean;
34
- invalid?: boolean;
35
- unmask?: boolean;
36
- slotChar?: string;
37
- 'data-slot'?: string;
38
- value?: string | null;
39
- onChange?: (e: InputMaskChangeEvent) => void;
40
- onComplete?: (e: InputMaskCompleteEvent) => void;
41
- }
42
-
43
- const isEmpty = (val: unknown): boolean =>
44
- val === null || val === undefined || val === "";
45
-
46
- const isAndroid = (): boolean =>
47
- typeof navigator !== "undefined" &&
48
- /android/i.test(navigator.userAgent || "");
49
-
50
- const isIOS = (): boolean =>
51
- typeof navigator !== "undefined" &&
52
- /(iphone|ipad|ipod)/i.test(navigator.userAgent || "");
53
-
54
- const isChrome = (): boolean =>
55
- typeof navigator !== "undefined" &&
56
- /chrome/i.test(navigator.userAgent || "");
57
-
58
- const focusEl = (el: HTMLInputElement | null) => {
59
- if (el && typeof el.focus === "function") {
60
- el.focus();
61
- }
62
- };
63
-
64
- function useUpdateEffect(effect: React.EffectCallback, deps: React.DependencyList) {
65
- const mounted = React.useRef(false);
66
-
67
- React.useEffect(() => {
68
- if (mounted.current) {
69
- return effect();
70
- }
71
- mounted.current = true;
72
- // eslint-disable-next-line react-hooks/exhaustive-deps
73
- }, deps);
74
- }
75
-
76
- export const InputMask = React.memo(
77
- React.forwardRef<InputMaskRef, InputMaskProps>((inProps, ref) => {
78
- // merge defaults with incoming props
79
- const props = React.useMemo(
80
- () => ({
81
- autoClear: true,
82
- autoFocus: false,
83
- disabled: false,
84
- invalid: false,
85
- readOnly: false,
86
- required: false,
87
- slotChar: "_",
88
- type: "text",
89
- unmask: false,
90
- ...inProps,
91
- }),
92
- [inProps]
93
- );
94
-
95
- const elementRef = React.useRef<HTMLInputElement | null>(null);
96
- const firstNonMaskPos = React.useRef<number | null>(null);
97
- const lastRequiredNonMaskPos = React.useRef(0);
98
- const tests = React.useRef<(RegExp | null)[]>([]);
99
- const buffer = React.useRef<string[]>([]);
100
- const len = React.useRef(0);
101
- const oldVal = React.useRef<string | null>(null);
102
- const focus = React.useRef(false);
103
- const focusText = React.useRef<string | null>(null);
104
- const isValueChecked = React.useRef<boolean | null>(null);
105
- const partialPosition = React.useRef<number | null>(null);
106
- const defaultBuffer = React.useRef<string | null>(null);
107
- const caretTimeoutId = React.useRef<number | null>(null);
108
- const androidChrome = React.useRef(false);
109
-
110
- const caret = (first?: number, last?: number) => {
111
- let range: any;
112
- let begin: number | null = null;
113
- let end: number | null = null;
114
- const inputEl = elementRef.current;
115
-
116
- if (!inputEl || !inputEl.offsetParent || inputEl !== document.activeElement) {
117
- return null;
118
- }
119
-
120
- if (typeof first === "number") {
121
- begin = first;
122
- end = typeof last === "number" ? last : begin;
123
-
124
- if (inputEl.setSelectionRange) {
125
- inputEl.setSelectionRange(begin, end);
126
- } else if ((inputEl as any).createTextRange) {
127
- range = (inputEl as any).createTextRange();
128
- range.collapse(true);
129
- range.moveEnd("character", end);
130
- range.moveStart("character", begin);
131
- range.select();
132
- }
133
- //@ts-ignore
134
- } else if (inputEl.setSelectionRange) {
135
- begin = inputEl.selectionStart ?? 0;
136
- end = inputEl.selectionEnd ?? begin;
137
- } else if ((document as any).selection && (document as any).selection.createRange) {
138
- range = (document as any).selection.createRange();
139
- begin = 0 - range.duplicate().moveStart("character", -100000);
140
- end = begin + range.text.length;
141
- }
142
-
143
- if (begin === null || end === null) {
144
- return null;
145
- }
146
-
147
- return { begin, end };
148
- };
149
-
150
- const getPlaceholder = React.useCallback(
151
- (i: number): string => {
152
- const slotChar = props.slotChar ?? "_";
153
-
154
- if (i < slotChar.length) {
155
- return slotChar.charAt(i);
156
- }
157
-
158
- return slotChar.charAt(0);
159
- },
160
- [props.slotChar]
161
- );
162
-
163
- const isCompleted = () => {
164
- const first = firstNonMaskPos.current ?? 0;
165
-
166
- for (let i = first; i <= lastRequiredNonMaskPos.current; i++) {
167
- if (tests.current[i] && buffer.current[i] === getPlaceholder(i)) {
168
- return false;
169
- }
170
- }
171
-
172
- return true;
173
- };
174
-
175
- const getValue = () =>
176
- props.unmask ? getUnmaskedValue() : elementRef.current?.value ?? "";
177
-
178
- const seekNext = (pos: number) => {
179
- while (++pos < len.current && !tests.current[pos]) {
180
- /* loop */
181
- }
182
- return pos;
183
- };
184
-
185
- const seekPrev = (pos: number) => {
186
- while (--pos >= 0 && !tests.current[pos]) {
187
- /* loop */
188
- }
189
- return pos;
190
- };
191
-
192
- const shiftL = (begin: number, end: number) => {
193
- if (begin < 0) {
194
- return;
195
- }
196
-
197
- let i: number;
198
- let j: number;
199
-
200
- for (i = begin, j = seekNext(end); i < len.current; i++) {
201
- if (tests.current[i]) {
202
- if (j < len.current && tests.current[i]!.test(buffer.current[j]!)) {
203
- buffer.current[i] = buffer.current[j]!;
204
- buffer.current[j] = getPlaceholder(j);
205
- } else {
206
- break;
207
- }
208
-
209
- j = seekNext(j);
210
- }
211
- }
212
-
213
- writeBuffer();
214
- caret(Math.max(firstNonMaskPos.current ?? 0, begin));
215
- };
216
-
217
- const shiftR = (pos: number) => {
218
- let i: number;
219
- let c: string;
220
- let j: number;
221
- let t: string;
222
-
223
- for (i = pos, c = getPlaceholder(pos); i < len.current; i++) {
224
- if (tests.current[i]) {
225
- j = seekNext(i);
226
- t = buffer.current[i]!;
227
- buffer.current[i] = c;
228
- if (j < len.current && tests.current[j]!.test(t)) {
229
- c = t;
230
- } else {
231
- break;
232
- }
233
- }
234
- }
235
- };
236
-
237
- const clearBuffer = (start: number, end: number) => {
238
- for (let i = start; i < end && i < len.current; i++) {
239
- if (tests.current[i]) {
240
- buffer.current[i] = getPlaceholder(i);
241
- }
242
- }
243
- };
244
-
245
- const writeBuffer = () => {
246
- if (elementRef.current) {
247
- elementRef.current.value = buffer.current.join("");
248
- }
249
- };
250
-
251
- const checkVal = (allow?: boolean): number => {
252
- isValueChecked.current = true;
253
-
254
- const test = elementRef.current?.value ?? "";
255
- let lastMatch = -1;
256
- let i: number;
257
- let c: string;
258
- let pos: number;
259
-
260
- for (i = 0, pos = 0; i < len.current; i++) {
261
- if (tests.current[i]) {
262
- buffer.current[i] = getPlaceholder(i);
263
-
264
- while (pos++ < test.length) {
265
- c = test.charAt(pos - 1);
266
- if (tests.current[i]!.test(c)) {
267
- buffer.current[i] = c;
268
- lastMatch = i;
269
- break;
270
- }
271
- }
272
-
273
- if (pos > test.length) {
274
- clearBuffer(i + 1, len.current);
275
- break;
276
- }
277
- } else {
278
- if (buffer.current[i] === test.charAt(pos)) {
279
- pos++;
280
- }
281
- if (i < (partialPosition.current ?? 0)) {
282
- lastMatch = i;
283
- }
284
- }
285
- }
286
-
287
- if (allow) {
288
- writeBuffer();
289
- } else if (lastMatch + 1 < (partialPosition.current ?? 0)) {
290
- if (props.autoClear || buffer.current.join("") === defaultBuffer.current) {
291
- if (elementRef.current && elementRef.current.value) {
292
- elementRef.current.value = "";
293
- }
294
- clearBuffer(0, len.current);
295
- } else {
296
- writeBuffer();
297
- }
298
- } else {
299
- writeBuffer();
300
- if (elementRef.current) {
301
- elementRef.current.value = elementRef.current.value.substring(0, lastMatch + 1);
302
- }
303
- }
304
-
305
- return partialPosition.current ? i : (firstNonMaskPos.current ?? 0);
306
- };
307
-
308
- const handleAndroidInput = (e: React.SyntheticEvent<HTMLInputElement>) => {
309
- const inputEl = elementRef.current;
310
- if (!inputEl) return;
311
-
312
- const curVal = inputEl.value;
313
- const pos = caret();
314
- if (!pos) return;
315
-
316
- if (oldVal.current && oldVal.current.length > curVal.length) {
317
- // deletion/backspace
318
- checkVal(true);
319
- while (pos.begin > 0 && !tests.current[pos.begin - 1]) {
320
- pos.begin--;
321
- }
322
- if (pos.begin === 0) {
323
- while (
324
- pos.begin < (firstNonMaskPos.current ?? 0) &&
325
- !tests.current[pos.begin]
326
- ) {
327
- pos.begin++;
328
- }
329
- }
330
- caret(pos.begin, pos.begin);
331
- } else {
332
- checkVal(true);
333
- while (pos.begin < len.current && !tests.current[pos.begin]) {
334
- pos.begin++;
335
- }
336
- caret(pos.begin, pos.begin);
337
- }
338
-
339
- if (props.onComplete && isCompleted()) {
340
- props.onComplete({
341
- originalEvent: e,
342
- value: getValue(),
343
- });
344
- }
345
-
346
- updateModel(e);
347
- };
348
-
349
- const onBlur = (e: React.FocusEvent<HTMLInputElement>) => {
350
- console.log("InputMask onBlur");
351
- focus.current = false;
352
- checkVal();
353
- updateModel(e);
354
-
355
- if (props.onBlur) {
356
- props.onBlur(e);
357
- }
358
-
359
- if (elementRef.current && elementRef.current.value !== focusText.current) {
360
- const event = document.createEvent("HTMLEvents");
361
- event.initEvent("change", true, false);
362
- elementRef.current.dispatchEvent(event);
363
- }
364
- };
365
-
366
- const onKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {
367
- if (props.readOnly) {
368
- return;
369
- }
370
-
371
- const k = e.which || e.keyCode;
372
- let pos: { begin: number; end: number } | null;
373
- let begin: number;
374
- let end: number;
375
-
376
- oldVal.current = elementRef.current?.value ?? null;
377
-
378
- // backspace, delete, escape
379
- if (k === 8 || k === 46 || (isIOS() && k === 127)) {
380
- pos = caret();
381
- if (!pos) {
382
- return;
383
- }
384
- begin = pos.begin;
385
- end = pos.end;
386
-
387
- if (end - begin === 0) {
388
- begin = k !== 46 ? seekPrev(begin) : (end = seekNext(begin - 1));
389
- end = k === 46 ? seekNext(end) : end;
390
- }
391
-
392
- clearBuffer(begin, end);
393
- shiftL(begin, end - 1);
394
- updateModel(e as any);
395
- e.preventDefault();
396
- } else if (k === 13) {
397
- // enter
398
- onBlur(e as any);
399
- updateModel(e as any);
400
- } else if (k === 27) {
401
- // escape
402
- if (elementRef.current) {
403
- elementRef.current.value = focusText.current ?? "";
404
- }
405
- caret(0, checkVal());
406
- updateModel(e as any);
407
- e.preventDefault();
408
- }
409
- };
410
-
411
- const onKeyPress = (e: React.KeyboardEvent<HTMLInputElement>) => {
412
- if (props.readOnly) {
413
- return;
414
- }
415
-
416
- const pos = caret();
417
- if (!pos) {
418
- return;
419
- }
420
-
421
- const k = e.which || e.keyCode;
422
- let p: number;
423
- let c: string;
424
- let next: number;
425
- let completed = false;
426
-
427
- if (e.ctrlKey || e.altKey || e.metaKey || k < 32) {
428
- return;
429
- } else if (k && k !== 13) {
430
- if (pos.end - pos.begin !== 0) {
431
- clearBuffer(pos.begin, pos.end);
432
- shiftL(pos.begin, pos.end - 1);
433
- }
434
-
435
- p = seekNext(pos.begin - 1);
436
- if (p < len.current) {
437
- c = String.fromCharCode(k);
438
- if (tests.current[p] && tests.current[p]!.test(c)) {
439
- shiftR(p);
440
- buffer.current[p] = c;
441
- writeBuffer();
442
-
443
- next = seekNext(p);
444
- if (isAndroid()) {
445
- const proxy = () => caret(next);
446
- setTimeout(proxy, 0);
447
- } else {
448
- caret(next);
449
- }
450
-
451
- if (pos.begin <= lastRequiredNonMaskPos.current) {
452
- completed = isCompleted();
453
- }
454
- }
455
- }
456
-
457
- e.preventDefault();
458
- }
459
-
460
- updateModel(e as any);
461
-
462
- if (props.onComplete && completed) {
463
- props.onComplete({
464
- originalEvent: e,
465
- value: getValue(),
466
- });
467
- }
468
- };
469
-
470
- const getUnmaskedValue = React.useCallback((): string => {
471
- const unmaskedBuffer: string[] = [];
472
-
473
- for (let i = 0; i < buffer.current.length; i++) {
474
- const c = buffer.current[i]!;
475
- if (tests.current[i] && c !== getPlaceholder(i)) {
476
- unmaskedBuffer.push(c);
477
- }
478
- }
479
-
480
- return unmaskedBuffer.join("");
481
- }, [getPlaceholder]);
482
-
483
- const updateModel = (e?: React.SyntheticEvent<HTMLInputElement>) => {
484
- if (!props.onChange) return;
485
-
486
- const val = props.unmask ? getUnmaskedValue() : e && (e.target as HTMLInputElement)?.value;
487
-
488
- const normalized = defaultBuffer.current !== val ? (val ?? "") : "";
489
- console.log("InputMask updateModel:", { val, normalized });
490
- const payload: InputMaskChangeEvent = {
491
- originalEvent: e,
492
- value: normalized,
493
- stopPropagation: () => {
494
- (e as any)?.stopPropagation?.();
495
- },
496
- preventDefault: () => {
497
- (e as any)?.preventDefault?.();
498
- },
499
- target: {
500
- name: props.name,
501
- id: props.id,
502
- value: normalized,
503
- },
504
- };
505
-
506
- props.onChange(payload);
507
- };
508
-
509
- const updateValue = (allow?: boolean): number | undefined => {
510
- let pos: number | undefined;
511
-
512
- if (elementRef.current) {
513
- if (isEmpty(props.value)) {
514
- elementRef.current.value = "";
515
- } else {
516
- elementRef.current.value = props.value ?? "";
517
- pos = checkVal(allow);
518
- setTimeout(() => {
519
- if (elementRef.current) {
520
- writeBuffer();
521
- return checkVal(allow);
522
- }
523
- }, 10);
524
- }
525
-
526
- focusText.current = elementRef.current.value;
527
- }
528
-
529
- return pos;
530
- };
531
-
532
- const isValueUpdated = React.useCallback(() => {
533
- const elVal = elementRef.current?.value ?? "";
534
- return props.unmask
535
- ? (props.value ?? "") !== getUnmaskedValue()
536
- : defaultBuffer.current !== elVal && elVal !== (props.value ?? "");
537
- }, [props.unmask, props.value, getUnmaskedValue]);
538
-
539
- const init = () => {
540
- const mask = props.mask;
541
- if (!mask) return;
542
-
543
- tests.current = [];
544
- partialPosition.current = mask.length;
545
- len.current = mask.length;
546
- firstNonMaskPos.current = null;
547
-
548
- const defs: Record<string, string> = {
549
- "9": "[0-9]",
550
- a: "[A-Za-z]",
551
- "*": "[A-Za-z0-9]",
552
- };
553
-
554
- androidChrome.current = isChrome() && isAndroid();
555
- const maskTokens = mask.split("");
556
-
557
- for (let i = 0; i < maskTokens.length; i++) {
558
- const c = maskTokens[i]!;
559
-
560
- if (c === "?") {
561
- len.current--;
562
- partialPosition.current = i;
563
- } else if (defs[c]) {
564
- tests.current.push(new RegExp(defs[c]!));
565
- if (firstNonMaskPos.current === null) {
566
- firstNonMaskPos.current = tests.current.length - 1;
567
- }
568
- if (i < (partialPosition.current ?? 0)) {
569
- lastRequiredNonMaskPos.current = tests.current.length - 1;
570
- }
571
- } else {
572
- tests.current.push(null);
573
- }
574
- }
575
-
576
- buffer.current = [];
577
-
578
- for (let i = 0; i < maskTokens.length; i++) {
579
- const c = maskTokens[i]!;
580
- if (c !== "?") {
581
- if (defs[c]) {
582
- buffer.current.push(getPlaceholder(i));
583
- } else {
584
- buffer.current.push(c);
585
- }
586
- }
587
- }
588
-
589
- defaultBuffer.current = buffer.current.join("");
590
- };
591
-
592
- const onFocus = (e: React.FocusEvent<HTMLInputElement>) => {
593
- console.log("InputMask onFocus");
594
- if (props.readOnly) {
595
- return;
596
- }
597
-
598
- focus.current = true;
599
- if (caretTimeoutId.current) {
600
- window.clearTimeout(caretTimeoutId.current);
601
- }
602
-
603
- let pos: number;
604
-
605
- if (elementRef.current) {
606
- focusText.current = elementRef.current.value;
607
- } else {
608
- focusText.current = "";
609
- }
610
-
611
- pos = checkVal() || 0;
612
-
613
- caretTimeoutId.current = window.setTimeout(() => {
614
- if (elementRef.current !== document.activeElement) {
615
- return;
616
- }
617
-
618
- writeBuffer();
619
-
620
- if (props.mask && pos === props.mask.replace("?", "").length) {
621
- caret(0, pos);
622
- } else {
623
- caret(pos);
624
- }
625
- }, 100);
626
-
627
- if (props.onFocus) {
628
- props.onFocus(e);
629
- }
630
- };
631
-
632
- const handleInputChange = (
633
- e: React.FormEvent<HTMLInputElement>,
634
- isOnPaste = false
635
- ) => {
636
- if (props.readOnly) {
637
- return;
638
- }
639
-
640
- if (!isOnPaste) {
641
- const pos = checkVal(true);
642
- caret(pos);
643
- }
644
-
645
- updateModel(e as any);
646
-
647
- if (props.onComplete && isCompleted()) {
648
- props.onComplete({
649
- originalEvent: e,
650
- value: getValue(),
651
- });
652
- }
653
- };
654
-
655
- const onInput = (event: React.FormEvent<HTMLInputElement>) => {
656
- androidChrome.current
657
- ? handleAndroidInput(event as any)
658
- : handleInputChange(event);
659
- };
660
-
661
- React.useImperativeHandle(
662
- ref,
663
- () => ({
664
- focus: () => focusEl(elementRef.current),
665
- getElement: () => elementRef.current,
666
- }),
667
- []
668
- );
669
-
670
- React.useEffect(() => {
671
- if (!elementRef.current) return;
672
- }, []);
673
-
674
- React.useEffect(() => {
675
- init();
676
- updateValue();
677
- // eslint-disable-next-line react-hooks/exhaustive-deps
678
- }, []);
679
-
680
- useUpdateEffect(() => {
681
- init();
682
- const pos = updateValue(true);
683
- if (typeof pos === "number") {
684
- caret(pos);
685
- }
686
- if (props.unmask) {
687
- updateModel();
688
- }
689
- }, [props.mask, props.unmask]);
690
-
691
- useUpdateEffect(() => {
692
- if (isValueUpdated()) {
693
- updateValue();
694
- }
695
- }, [isValueUpdated]);
696
-
697
- const {
698
- mask,
699
- autoClear,
700
- unmask,
701
- slotChar,
702
- onChange,
703
- onComplete,
704
- value,
705
- autoFocus,
706
- onFocus: i,
707
- onBlur: j,
708
- onKeyDown: k,
709
- onKeyPress: l,
710
- onInput: m,
711
- className,
712
- ...restInputProps
713
- } = props;
714
-
715
- return (
716
- <input
717
- ref={elementRef}
718
- autoFocus={autoFocus}
719
- id={props.id}
720
- name={props.name}
721
- style={props.style}
722
- className={className}
723
- placeholder={props.placeholder}
724
- size={props.size}
725
- maxLength={props.maxLength}
726
- tabIndex={props.tabIndex}
727
- onFocus={onFocus}
728
- onBlur={onBlur}
729
- onKeyDown={onKeyDown}
730
- onKeyPress={onKeyPress}
731
- onInput={onInput}
732
- onPaste={(e) => handleInputChange(e, true)}
733
- {...restInputProps}
734
- />
735
- );
736
- })
737
- );
738
-
739
- InputMask.displayName = "InputMask";