@tribepad/themis 1.0.0 → 1.0.1

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 (326) hide show
  1. package/dist/elements/Accordion/index.js +325 -66
  2. package/dist/elements/Accordion/index.js.map +1 -1
  3. package/dist/elements/Accordion/index.mjs +317 -3
  4. package/dist/elements/Accordion/index.mjs.map +1 -1
  5. package/dist/elements/Avatar/index.js +461 -45
  6. package/dist/elements/Avatar/index.js.map +1 -1
  7. package/dist/elements/Avatar/index.mjs +456 -3
  8. package/dist/elements/Avatar/index.mjs.map +1 -1
  9. package/dist/elements/Badge/index.js +238 -36
  10. package/dist/elements/Badge/index.js.map +1 -1
  11. package/dist/elements/Badge/index.mjs +234 -4
  12. package/dist/elements/Badge/index.mjs.map +1 -1
  13. package/dist/elements/Breadcrumbs/index.js +808 -39
  14. package/dist/elements/Breadcrumbs/index.js.map +1 -1
  15. package/dist/elements/Breadcrumbs/index.mjs +810 -7
  16. package/dist/elements/Breadcrumbs/index.mjs.map +1 -1
  17. package/dist/elements/Button/index.js +282 -19
  18. package/dist/elements/Button/index.js.map +1 -1
  19. package/dist/elements/Button/index.mjs +283 -4
  20. package/dist/elements/Button/index.mjs.map +1 -1
  21. package/dist/elements/ButtonGroup/index.js +229 -56
  22. package/dist/elements/ButtonGroup/index.js.map +1 -1
  23. package/dist/elements/ButtonGroup/index.mjs +222 -3
  24. package/dist/elements/ButtonGroup/index.mjs.map +1 -1
  25. package/dist/elements/Card/Card.d.ts.map +1 -1
  26. package/dist/elements/Card/index.js +563 -67
  27. package/dist/elements/Card/index.js.map +1 -1
  28. package/dist/elements/Card/index.mjs +560 -6
  29. package/dist/elements/Card/index.mjs.map +1 -1
  30. package/dist/elements/Carousel/index.js +782 -14
  31. package/dist/elements/Carousel/index.js.map +1 -1
  32. package/dist/elements/Carousel/index.mjs +786 -8
  33. package/dist/elements/Carousel/index.mjs.map +1 -1
  34. package/dist/elements/Chart/index.js +1833 -36
  35. package/dist/elements/Chart/index.js.map +1 -1
  36. package/dist/elements/Chart/index.mjs +1832 -4
  37. package/dist/elements/Chart/index.mjs.map +1 -1
  38. package/dist/elements/Checkbox/index.js +310 -39
  39. package/dist/elements/Checkbox/index.js.map +1 -1
  40. package/dist/elements/Checkbox/index.mjs +306 -4
  41. package/dist/elements/Checkbox/index.mjs.map +1 -1
  42. package/dist/elements/CheckboxGroup/index.js +445 -59
  43. package/dist/elements/CheckboxGroup/index.js.map +1 -1
  44. package/dist/elements/CheckboxGroup/index.mjs +439 -4
  45. package/dist/elements/CheckboxGroup/index.mjs.map +1 -1
  46. package/dist/elements/DatePicker/index.js +871 -89
  47. package/dist/elements/DatePicker/index.js.map +1 -1
  48. package/dist/elements/DatePicker/index.mjs +853 -4
  49. package/dist/elements/DatePicker/index.mjs.map +1 -1
  50. package/dist/elements/Dropdown/index.js +189 -35
  51. package/dist/elements/Dropdown/index.js.map +1 -1
  52. package/dist/elements/Dropdown/index.mjs +184 -2
  53. package/dist/elements/Dropdown/index.mjs.map +1 -1
  54. package/dist/elements/FileField/index.js +1532 -129
  55. package/dist/elements/FileField/index.js.map +1 -1
  56. package/dist/elements/FileField/index.mjs +1507 -7
  57. package/dist/elements/FileField/index.mjs.map +1 -1
  58. package/dist/elements/FormLayout/index.js +166 -11
  59. package/dist/elements/FormLayout/index.js.map +1 -1
  60. package/dist/elements/FormLayout/index.mjs +167 -2
  61. package/dist/elements/FormLayout/index.mjs.map +1 -1
  62. package/dist/elements/Modal/index.js +228 -46
  63. package/dist/elements/Modal/index.js.map +1 -1
  64. package/dist/elements/Modal/index.mjs +220 -1
  65. package/dist/elements/Modal/index.mjs.map +1 -1
  66. package/dist/elements/NumberField/index.js +659 -48
  67. package/dist/elements/NumberField/index.js.map +1 -1
  68. package/dist/elements/NumberField/index.mjs +654 -6
  69. package/dist/elements/NumberField/index.mjs.map +1 -1
  70. package/dist/elements/OTPInput/index.js +729 -6
  71. package/dist/elements/OTPInput/index.js.map +1 -1
  72. package/dist/elements/OTPInput/index.mjs +732 -2
  73. package/dist/elements/OTPInput/index.mjs.map +1 -1
  74. package/dist/elements/Panel/index.js +326 -27
  75. package/dist/elements/Panel/index.js.map +1 -1
  76. package/dist/elements/Panel/index.mjs +323 -2
  77. package/dist/elements/Panel/index.mjs.map +1 -1
  78. package/dist/elements/Progress/index.js +181 -22
  79. package/dist/elements/Progress/index.js.map +1 -1
  80. package/dist/elements/Progress/index.mjs +181 -3
  81. package/dist/elements/Progress/index.mjs.map +1 -1
  82. package/dist/elements/RadioGroup/index.js +358 -34
  83. package/dist/elements/RadioGroup/index.js.map +1 -1
  84. package/dist/elements/RadioGroup/index.mjs +359 -4
  85. package/dist/elements/RadioGroup/index.mjs.map +1 -1
  86. package/dist/elements/Resizable/components/ResizableHandle.d.ts +0 -8
  87. package/dist/elements/Resizable/components/ResizableHandle.d.ts.map +1 -1
  88. package/dist/elements/Resizable/components/ResizablePanel.d.ts +0 -8
  89. package/dist/elements/Resizable/components/ResizablePanel.d.ts.map +1 -1
  90. package/dist/elements/Resizable/components/ResizablePanelGroup.d.ts +0 -8
  91. package/dist/elements/Resizable/components/ResizablePanelGroup.d.ts.map +1 -1
  92. package/dist/elements/Resizable/components/ResizablePopover.d.ts +0 -8
  93. package/dist/elements/Resizable/components/ResizablePopover.d.ts.map +1 -1
  94. package/dist/elements/Resizable/index.js +1568 -51
  95. package/dist/elements/Resizable/index.js.map +1 -1
  96. package/dist/elements/Resizable/index.mjs +1566 -6
  97. package/dist/elements/Resizable/index.mjs.map +1 -1
  98. package/dist/elements/Select/index.js +580 -22
  99. package/dist/elements/Select/index.js.map +1 -1
  100. package/dist/elements/Select/index.mjs +582 -2
  101. package/dist/elements/Select/index.mjs.map +1 -1
  102. package/dist/elements/Skeleton/index.js +77 -15
  103. package/dist/elements/Skeleton/index.js.map +1 -1
  104. package/dist/elements/Skeleton/index.mjs +78 -3
  105. package/dist/elements/Skeleton/index.mjs.map +1 -1
  106. package/dist/elements/Switch/index.js +153 -21
  107. package/dist/elements/Switch/index.js.map +1 -1
  108. package/dist/elements/Switch/index.mjs +149 -5
  109. package/dist/elements/Switch/index.mjs.map +1 -1
  110. package/dist/elements/Table/index.js +589 -68
  111. package/dist/elements/Table/index.js.map +1 -1
  112. package/dist/elements/Table/index.mjs +578 -5
  113. package/dist/elements/Table/index.mjs.map +1 -1
  114. package/dist/elements/Tabs/index.js +328 -63
  115. package/dist/elements/Tabs/index.js.map +1 -1
  116. package/dist/elements/Tabs/index.mjs +320 -3
  117. package/dist/elements/Tabs/index.mjs.map +1 -1
  118. package/dist/elements/TextField/index.js +695 -51
  119. package/dist/elements/TextField/index.js.map +1 -1
  120. package/dist/elements/TextField/index.mjs +684 -7
  121. package/dist/elements/TextField/index.mjs.map +1 -1
  122. package/dist/elements/TimeField/index.js +244 -33
  123. package/dist/elements/TimeField/index.js.map +1 -1
  124. package/dist/elements/TimeField/index.mjs +238 -2
  125. package/dist/elements/TimeField/index.mjs.map +1 -1
  126. package/dist/elements/Toast/index.js +727 -48
  127. package/dist/elements/Toast/index.js.map +1 -1
  128. package/dist/elements/Toast/index.mjs +724 -5
  129. package/dist/elements/Toast/index.mjs.map +1 -1
  130. package/dist/elements/Tooltip/index.js +315 -49
  131. package/dist/elements/Tooltip/index.js.map +1 -1
  132. package/dist/elements/Tooltip/index.mjs +310 -4
  133. package/dist/elements/Tooltip/index.mjs.map +1 -1
  134. package/dist/elements/index.js +12417 -799
  135. package/dist/elements/index.js.map +1 -1
  136. package/dist/elements/index.mjs +12233 -40
  137. package/dist/elements/index.mjs.map +1 -1
  138. package/dist/index.js +12452 -825
  139. package/dist/index.js.map +1 -1
  140. package/dist/index.mjs +12262 -42
  141. package/dist/index.mjs.map +1 -1
  142. package/dist/schemas/index.js +47 -21
  143. package/dist/schemas/index.js.map +1 -1
  144. package/dist/schemas/index.mjs +47 -2
  145. package/dist/schemas/index.mjs.map +1 -1
  146. package/dist/styles/index.js +161 -147
  147. package/dist/styles/index.js.map +1 -1
  148. package/dist/styles/index.mjs +128 -2
  149. package/dist/styles/index.mjs.map +1 -1
  150. package/dist/utils/index.js +7 -7
  151. package/dist/utils/index.js.map +1 -1
  152. package/dist/utils/index.mjs +9 -2
  153. package/dist/utils/index.mjs.map +1 -1
  154. package/package.json +1 -1
  155. package/dist/Carousel-NTZX5TOW.js +0 -16
  156. package/dist/Carousel-NTZX5TOW.js.map +0 -1
  157. package/dist/Carousel-YH3DOQJU.mjs +0 -7
  158. package/dist/Carousel-YH3DOQJU.mjs.map +0 -1
  159. package/dist/chunk-2HIUTHMU.mjs +0 -234
  160. package/dist/chunk-2HIUTHMU.mjs.map +0 -1
  161. package/dist/chunk-34GTFTDO.js +0 -431
  162. package/dist/chunk-34GTFTDO.js.map +0 -1
  163. package/dist/chunk-3H7ASYR7.js +0 -250
  164. package/dist/chunk-3H7ASYR7.js.map +0 -1
  165. package/dist/chunk-3IEN7JOP.js +0 -316
  166. package/dist/chunk-3IEN7JOP.js.map +0 -1
  167. package/dist/chunk-3JHN4GAL.js +0 -326
  168. package/dist/chunk-3JHN4GAL.js.map +0 -1
  169. package/dist/chunk-3MJPASQU.js +0 -232
  170. package/dist/chunk-3MJPASQU.js.map +0 -1
  171. package/dist/chunk-3XD2JUL3.js +0 -572
  172. package/dist/chunk-3XD2JUL3.js.map +0 -1
  173. package/dist/chunk-3YOY2VJ6.js +0 -189
  174. package/dist/chunk-3YOY2VJ6.js.map +0 -1
  175. package/dist/chunk-4DU5JSXB.js +0 -408
  176. package/dist/chunk-4DU5JSXB.js.map +0 -1
  177. package/dist/chunk-4E4E2GSS.js +0 -352
  178. package/dist/chunk-4E4E2GSS.js.map +0 -1
  179. package/dist/chunk-4NHAP4AN.mjs +0 -3
  180. package/dist/chunk-4NHAP4AN.mjs.map +0 -1
  181. package/dist/chunk-4S33J5NY.mjs +0 -415
  182. package/dist/chunk-4S33J5NY.mjs.map +0 -1
  183. package/dist/chunk-5SMGRT3G.mjs +0 -354
  184. package/dist/chunk-5SMGRT3G.mjs.map +0 -1
  185. package/dist/chunk-5SVLJN2C.mjs +0 -22
  186. package/dist/chunk-5SVLJN2C.mjs.map +0 -1
  187. package/dist/chunk-66WTU4EB.mjs +0 -299
  188. package/dist/chunk-66WTU4EB.mjs.map +0 -1
  189. package/dist/chunk-6S25NMOT.mjs +0 -335
  190. package/dist/chunk-6S25NMOT.mjs.map +0 -1
  191. package/dist/chunk-6SP7UB3D.js +0 -4
  192. package/dist/chunk-6SP7UB3D.js.map +0 -1
  193. package/dist/chunk-6TYWWQHM.mjs +0 -565
  194. package/dist/chunk-6TYWWQHM.mjs.map +0 -1
  195. package/dist/chunk-A3YUJA6W.mjs +0 -384
  196. package/dist/chunk-A3YUJA6W.mjs.map +0 -1
  197. package/dist/chunk-A6KEDVUR.js +0 -61
  198. package/dist/chunk-A6KEDVUR.js.map +0 -1
  199. package/dist/chunk-A77RUEWL.js +0 -730
  200. package/dist/chunk-A77RUEWL.js.map +0 -1
  201. package/dist/chunk-AA4IKMPE.mjs +0 -3
  202. package/dist/chunk-AA4IKMPE.mjs.map +0 -1
  203. package/dist/chunk-AKIA6GW6.mjs +0 -163
  204. package/dist/chunk-AKIA6GW6.mjs.map +0 -1
  205. package/dist/chunk-AL6P275L.mjs +0 -435
  206. package/dist/chunk-AL6P275L.mjs.map +0 -1
  207. package/dist/chunk-AZ3RJYTB.js +0 -37
  208. package/dist/chunk-AZ3RJYTB.js.map +0 -1
  209. package/dist/chunk-B5Q4UPL6.js +0 -32
  210. package/dist/chunk-B5Q4UPL6.js.map +0 -1
  211. package/dist/chunk-B6DHPMDP.mjs +0 -335
  212. package/dist/chunk-B6DHPMDP.mjs.map +0 -1
  213. package/dist/chunk-BDXKKMBZ.mjs +0 -184
  214. package/dist/chunk-BDXKKMBZ.mjs.map +0 -1
  215. package/dist/chunk-BL6E2DLZ.mjs +0 -52
  216. package/dist/chunk-BL6E2DLZ.mjs.map +0 -1
  217. package/dist/chunk-CGFDS4XS.mjs +0 -121
  218. package/dist/chunk-CGFDS4XS.mjs.map +0 -1
  219. package/dist/chunk-CJIW5TKI.js +0 -139
  220. package/dist/chunk-CJIW5TKI.js.map +0 -1
  221. package/dist/chunk-CKNISJOQ.js +0 -314
  222. package/dist/chunk-CKNISJOQ.js.map +0 -1
  223. package/dist/chunk-D6CBOECS.mjs +0 -1757
  224. package/dist/chunk-D6CBOECS.mjs.map +0 -1
  225. package/dist/chunk-DDWEVC2S.js +0 -166
  226. package/dist/chunk-DDWEVC2S.js.map +0 -1
  227. package/dist/chunk-DZ556D2F.mjs +0 -176
  228. package/dist/chunk-DZ556D2F.mjs.map +0 -1
  229. package/dist/chunk-E2KQFV3O.mjs +0 -10
  230. package/dist/chunk-E2KQFV3O.mjs.map +0 -1
  231. package/dist/chunk-EMMLADSC.js +0 -126
  232. package/dist/chunk-EMMLADSC.js.map +0 -1
  233. package/dist/chunk-EP4WOI5D.mjs +0 -926
  234. package/dist/chunk-EP4WOI5D.mjs.map +0 -1
  235. package/dist/chunk-FJRXLJC2.mjs +0 -160
  236. package/dist/chunk-FJRXLJC2.mjs.map +0 -1
  237. package/dist/chunk-FKQI434R.js +0 -345
  238. package/dist/chunk-FKQI434R.js.map +0 -1
  239. package/dist/chunk-FPKEAJRZ.mjs +0 -100
  240. package/dist/chunk-FPKEAJRZ.mjs.map +0 -1
  241. package/dist/chunk-FWQYB22U.js +0 -183
  242. package/dist/chunk-FWQYB22U.js.map +0 -1
  243. package/dist/chunk-GD5GHTMA.js +0 -189
  244. package/dist/chunk-GD5GHTMA.js.map +0 -1
  245. package/dist/chunk-GE5XTSDZ.js +0 -447
  246. package/dist/chunk-GE5XTSDZ.js.map +0 -1
  247. package/dist/chunk-GVE47ZAX.mjs +0 -32
  248. package/dist/chunk-GVE47ZAX.mjs.map +0 -1
  249. package/dist/chunk-HK46BT5U.mjs +0 -18
  250. package/dist/chunk-HK46BT5U.mjs.map +0 -1
  251. package/dist/chunk-HQVRMR6N.js +0 -365
  252. package/dist/chunk-HQVRMR6N.js.map +0 -1
  253. package/dist/chunk-HSGBJPJO.mjs +0 -398
  254. package/dist/chunk-HSGBJPJO.mjs.map +0 -1
  255. package/dist/chunk-I3AUTOMZ.mjs +0 -125
  256. package/dist/chunk-I3AUTOMZ.mjs.map +0 -1
  257. package/dist/chunk-IEI5LD5C.mjs +0 -1161
  258. package/dist/chunk-IEI5LD5C.mjs.map +0 -1
  259. package/dist/chunk-IIPTC2X7.mjs +0 -118
  260. package/dist/chunk-IIPTC2X7.mjs.map +0 -1
  261. package/dist/chunk-J7TLHF2Q.js +0 -4
  262. package/dist/chunk-J7TLHF2Q.js.map +0 -1
  263. package/dist/chunk-JJOWXFXQ.mjs +0 -765
  264. package/dist/chunk-JJOWXFXQ.mjs.map +0 -1
  265. package/dist/chunk-JPTSS2OA.mjs +0 -3
  266. package/dist/chunk-JPTSS2OA.mjs.map +0 -1
  267. package/dist/chunk-KFXXRLTP.js +0 -396
  268. package/dist/chunk-KFXXRLTP.js.map +0 -1
  269. package/dist/chunk-KPRRBSG6.mjs +0 -272
  270. package/dist/chunk-KPRRBSG6.mjs.map +0 -1
  271. package/dist/chunk-NFSBGRDB.mjs +0 -57
  272. package/dist/chunk-NFSBGRDB.mjs.map +0 -1
  273. package/dist/chunk-NGJVCFTM.js +0 -219
  274. package/dist/chunk-NGJVCFTM.js.map +0 -1
  275. package/dist/chunk-NSQ6MZJ6.mjs +0 -728
  276. package/dist/chunk-NSQ6MZJ6.mjs.map +0 -1
  277. package/dist/chunk-NYQYHT76.mjs +0 -296
  278. package/dist/chunk-NYQYHT76.mjs.map +0 -1
  279. package/dist/chunk-OLJJGI5B.js +0 -1193
  280. package/dist/chunk-OLJJGI5B.js.map +0 -1
  281. package/dist/chunk-Q3572X2J.js +0 -292
  282. package/dist/chunk-Q3572X2J.js.map +0 -1
  283. package/dist/chunk-QH7N7D4I.mjs +0 -210
  284. package/dist/chunk-QH7N7D4I.mjs.map +0 -1
  285. package/dist/chunk-R7XUIV25.js +0 -466
  286. package/dist/chunk-R7XUIV25.js.map +0 -1
  287. package/dist/chunk-RFFO4KPM.js +0 -135
  288. package/dist/chunk-RFFO4KPM.js.map +0 -1
  289. package/dist/chunk-RFX7QKA7.mjs +0 -180
  290. package/dist/chunk-RFX7QKA7.mjs.map +0 -1
  291. package/dist/chunk-SN5LFAP3.js +0 -940
  292. package/dist/chunk-SN5LFAP3.js.map +0 -1
  293. package/dist/chunk-T4COXKQ3.js +0 -24
  294. package/dist/chunk-T4COXKQ3.js.map +0 -1
  295. package/dist/chunk-TS54QM27.js +0 -125
  296. package/dist/chunk-TS54QM27.js.map +0 -1
  297. package/dist/chunk-UE2S4PCX.mjs +0 -220
  298. package/dist/chunk-UE2S4PCX.mjs.map +0 -1
  299. package/dist/chunk-UTW3QX2A.mjs +0 -282
  300. package/dist/chunk-UTW3QX2A.mjs.map +0 -1
  301. package/dist/chunk-V74LGMAE.js +0 -1767
  302. package/dist/chunk-V74LGMAE.js.map +0 -1
  303. package/dist/chunk-VIREG536.js +0 -12
  304. package/dist/chunk-VIREG536.js.map +0 -1
  305. package/dist/chunk-VY7M7346.js +0 -4
  306. package/dist/chunk-VY7M7346.js.map +0 -1
  307. package/dist/chunk-W3TJOO7H.mjs +0 -319
  308. package/dist/chunk-W3TJOO7H.mjs.map +0 -1
  309. package/dist/chunk-WIUOB36M.js +0 -54
  310. package/dist/chunk-WIUOB36M.js.map +0 -1
  311. package/dist/chunk-WJGLM4CY.js +0 -291
  312. package/dist/chunk-WJGLM4CY.js.map +0 -1
  313. package/dist/chunk-WNURH5OO.mjs +0 -453
  314. package/dist/chunk-WNURH5OO.mjs.map +0 -1
  315. package/dist/chunk-X25TNRSD.mjs +0 -364
  316. package/dist/chunk-X25TNRSD.mjs.map +0 -1
  317. package/dist/chunk-Y3GT7ETK.js +0 -108
  318. package/dist/chunk-Y3GT7ETK.js.map +0 -1
  319. package/dist/chunk-Z4FRNOF6.mjs +0 -115
  320. package/dist/chunk-Z4FRNOF6.mjs.map +0 -1
  321. package/dist/chunk-ZMYLD3BN.js +0 -166
  322. package/dist/chunk-ZMYLD3BN.js.map +0 -1
  323. package/dist/chunk-ZP2KV6EX.js +0 -815
  324. package/dist/chunk-ZP2KV6EX.js.map +0 -1
  325. package/dist/chunk-ZVKXFELU.js +0 -366
  326. package/dist/chunk-ZVKXFELU.js.map +0 -1
@@ -1,4 +1,734 @@
1
- export { OTPInput } from '../../chunk-NSQ6MZJ6.mjs';
2
- import '../../chunk-E2KQFV3O.mjs';
1
+ "use client";
2
+ import { memo, forwardRef, useRef, useImperativeHandle, useState, useCallback, useEffect } from 'react';
3
+ import { clsx } from 'clsx';
4
+ import { twMerge } from 'tailwind-merge';
5
+ import { cva } from 'class-variance-authority';
6
+ import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
7
+
8
+ // src/elements/OTPInput/OTPInput.tsx
9
+ function cn(...inputs) {
10
+ return twMerge(clsx(inputs));
11
+ }
12
+ function useOTPKeyboard(options) {
13
+ const {
14
+ value,
15
+ length,
16
+ focusedIndex,
17
+ onChange,
18
+ setFocusedIndex,
19
+ disabled = false,
20
+ readOnly = false
21
+ } = options;
22
+ const handleArrowLeft = useCallback(() => {
23
+ if (focusedIndex > 0) {
24
+ setFocusedIndex(focusedIndex - 1);
25
+ }
26
+ }, [focusedIndex, setFocusedIndex]);
27
+ const handleArrowRight = useCallback(() => {
28
+ if (focusedIndex < length - 1) {
29
+ setFocusedIndex(focusedIndex + 1);
30
+ }
31
+ }, [focusedIndex, length, setFocusedIndex]);
32
+ const handleBackspace = useCallback(() => {
33
+ if (readOnly) return;
34
+ const digits = value.split("");
35
+ const currentDigit = digits[focusedIndex];
36
+ if (currentDigit === "_") {
37
+ if (focusedIndex > 0) {
38
+ const newIndex = focusedIndex - 1;
39
+ digits[newIndex] = "_";
40
+ onChange(digits.join(""));
41
+ setFocusedIndex(newIndex);
42
+ }
43
+ } else {
44
+ digits[focusedIndex] = "_";
45
+ onChange(digits.join(""));
46
+ if (focusedIndex > 0) {
47
+ setFocusedIndex(focusedIndex - 1);
48
+ }
49
+ }
50
+ }, [value, focusedIndex, readOnly, onChange, setFocusedIndex]);
51
+ const handleDelete = useCallback(() => {
52
+ if (readOnly) return;
53
+ const digits = value.split("");
54
+ digits[focusedIndex] = "_";
55
+ onChange(digits.join(""));
56
+ }, [value, focusedIndex, readOnly, onChange]);
57
+ const handleHome = useCallback(() => {
58
+ setFocusedIndex(0);
59
+ }, [setFocusedIndex]);
60
+ const handleEnd = useCallback(() => {
61
+ setFocusedIndex(length - 1);
62
+ }, [length, setFocusedIndex]);
63
+ const handleKeyDown = useCallback(
64
+ (e) => {
65
+ if (disabled) return;
66
+ switch (e.key) {
67
+ case "ArrowLeft":
68
+ e.preventDefault();
69
+ handleArrowLeft();
70
+ break;
71
+ case "ArrowRight":
72
+ e.preventDefault();
73
+ handleArrowRight();
74
+ break;
75
+ case "Backspace":
76
+ e.preventDefault();
77
+ handleBackspace();
78
+ break;
79
+ case "Delete":
80
+ e.preventDefault();
81
+ handleDelete();
82
+ break;
83
+ case "Home":
84
+ e.preventDefault();
85
+ handleHome();
86
+ break;
87
+ case "End":
88
+ e.preventDefault();
89
+ handleEnd();
90
+ break;
91
+ // Ctrl/Cmd+A (Select All) - Allow native behavior
92
+ case "a":
93
+ case "A":
94
+ if (e.ctrlKey || e.metaKey) {
95
+ return;
96
+ }
97
+ break;
98
+ // Prevent Enter from submitting the form
99
+ // Form submission should be handled by onComplete callback when all digits are filled
100
+ case "Enter":
101
+ e.preventDefault();
102
+ break;
103
+ }
104
+ },
105
+ [
106
+ disabled,
107
+ handleArrowLeft,
108
+ handleArrowRight,
109
+ handleBackspace,
110
+ handleDelete,
111
+ handleHome,
112
+ handleEnd
113
+ ]
114
+ );
115
+ return {
116
+ handleKeyDown
117
+ };
118
+ }
119
+
120
+ // src/elements/OTPInput/hooks/useOTPInput.ts
121
+ function useOTPInput(props) {
122
+ const {
123
+ value: controlledValue,
124
+ defaultValue = "",
125
+ length = 6,
126
+ type = "numeric",
127
+ pattern,
128
+ onChange,
129
+ onComplete,
130
+ validate,
131
+ error: controlledError,
132
+ disabled = false,
133
+ readOnly = false
134
+ } = props;
135
+ const isControlled = controlledValue !== void 0;
136
+ const [internalValue, setInternalValue] = useState(() => {
137
+ return (defaultValue || "").padEnd(length, "_");
138
+ });
139
+ const [internalError, setInternalError] = useState(null);
140
+ const [focusedIndex, setFocusedIndex] = useState(0);
141
+ const completedRef = useRef(null);
142
+ const debounceTimerRef = useRef(null);
143
+ const currentValue = isControlled ? controlledValue || "".padEnd(length, "_") : internalValue;
144
+ const currentError = controlledError !== void 0 ? controlledError : internalError;
145
+ const runValidation = useCallback(
146
+ (value) => {
147
+ const filledLength = value.replace(/_/g, "").length;
148
+ if (filledLength < length) {
149
+ return null;
150
+ }
151
+ if (validate) {
152
+ return validate(value);
153
+ }
154
+ if (type === "numeric") {
155
+ const numericPattern = /^\d+$/;
156
+ const cleanValue = value.replace(/_/g, "");
157
+ if (!numericPattern.test(cleanValue)) {
158
+ return "Code must contain only digits";
159
+ }
160
+ } else if (type === "alphanumeric") {
161
+ const alphanumericPattern = /^[A-Za-z0-9]+$/;
162
+ const cleanValue = value.replace(/_/g, "");
163
+ if (!alphanumericPattern.test(cleanValue)) {
164
+ return "Code must contain only letters and numbers";
165
+ }
166
+ } else if (type === "custom" && pattern) {
167
+ const cleanValue = value.replace(/_/g, "");
168
+ for (const char of cleanValue) {
169
+ if (!pattern.test(char)) {
170
+ return "Invalid character in code";
171
+ }
172
+ }
173
+ }
174
+ return null;
175
+ },
176
+ [length, type, pattern, validate]
177
+ );
178
+ const updateValue = useCallback(
179
+ (newValue) => {
180
+ if (!isControlled) {
181
+ setInternalValue(newValue);
182
+ }
183
+ onChange?.(newValue);
184
+ const validationError = runValidation(newValue);
185
+ if (!isControlled) {
186
+ setInternalError(validationError);
187
+ }
188
+ const filledLength = newValue.replace(/_/g, "").length;
189
+ const isComplete2 = filledLength === length;
190
+ if (isComplete2 && !validationError && completedRef.current !== newValue) {
191
+ completedRef.current = newValue;
192
+ if (debounceTimerRef.current) {
193
+ clearTimeout(debounceTimerRef.current);
194
+ }
195
+ debounceTimerRef.current = setTimeout(() => {
196
+ onComplete?.(newValue.replace(/_/g, ""));
197
+ }, 200);
198
+ }
199
+ if (!isComplete2 && completedRef.current) {
200
+ completedRef.current = null;
201
+ }
202
+ },
203
+ [isControlled, length, onChange, onComplete, runValidation]
204
+ );
205
+ const handleChange = useCallback(
206
+ (e) => {
207
+ if (disabled) return;
208
+ const inputValue = e.target.value;
209
+ const newChar = inputValue[inputValue.length - 1] || "";
210
+ let isValid = false;
211
+ if (type === "numeric") {
212
+ isValid = /^\d$/.test(newChar);
213
+ } else if (type === "alphanumeric") {
214
+ isValid = /^[A-Za-z0-9]$/.test(newChar);
215
+ } else if (type === "custom" && pattern) {
216
+ isValid = pattern.test(newChar);
217
+ } else {
218
+ isValid = true;
219
+ }
220
+ if (!isValid) {
221
+ return;
222
+ }
223
+ const valueArray = currentValue.split("");
224
+ valueArray[focusedIndex] = newChar;
225
+ const newValue = valueArray.join("");
226
+ updateValue(newValue);
227
+ if (focusedIndex < length - 1) {
228
+ setFocusedIndex(focusedIndex + 1);
229
+ }
230
+ },
231
+ [disabled, type, pattern, currentValue, focusedIndex, length, updateValue]
232
+ );
233
+ const handlePaste = useCallback(
234
+ async (e) => {
235
+ if (disabled || readOnly) return;
236
+ e.preventDefault();
237
+ const pastedText = e.clipboardData.getData("text/plain").trim();
238
+ if (!pastedText) return;
239
+ if (props.onPaste) {
240
+ const shouldProceed = await props.onPaste(pastedText);
241
+ if (shouldProceed === false) return;
242
+ }
243
+ let validChars = "";
244
+ for (const char of pastedText) {
245
+ if (validChars.length >= length) break;
246
+ let isValid = false;
247
+ if (type === "numeric") {
248
+ isValid = /^\d$/.test(char);
249
+ } else if (type === "alphanumeric") {
250
+ isValid = /^[A-Za-z0-9]$/.test(char);
251
+ } else if (type === "custom" && pattern) {
252
+ isValid = pattern.test(char);
253
+ } else {
254
+ isValid = true;
255
+ }
256
+ if (isValid) {
257
+ validChars += char;
258
+ }
259
+ }
260
+ const newValue = validChars.padEnd(length, "_");
261
+ updateValue(newValue);
262
+ const firstEmptyIndex = newValue.indexOf("_");
263
+ setFocusedIndex(firstEmptyIndex === -1 ? length - 1 : firstEmptyIndex);
264
+ },
265
+ [disabled, readOnly, props, length, type, pattern, updateValue]
266
+ );
267
+ const clear = useCallback(() => {
268
+ const emptyValue = "".padEnd(length, "_");
269
+ updateValue(emptyValue);
270
+ setFocusedIndex(0);
271
+ if (!isControlled) {
272
+ setInternalError(null);
273
+ }
274
+ completedRef.current = null;
275
+ }, [length, updateValue, isControlled]);
276
+ const setValue = useCallback(
277
+ (newValue) => {
278
+ const paddedValue = newValue.padEnd(length, "_").slice(0, length);
279
+ updateValue(paddedValue);
280
+ const firstEmptyIndex = paddedValue.indexOf("_");
281
+ setFocusedIndex(firstEmptyIndex === -1 ? length - 1 : firstEmptyIndex);
282
+ },
283
+ [length, updateValue]
284
+ );
285
+ const validateCurrent = useCallback(() => {
286
+ return runValidation(currentValue);
287
+ }, [currentValue, runValidation]);
288
+ const isComplete = currentValue.replace(/_/g, "").length === length;
289
+ const { handleKeyDown } = useOTPKeyboard({
290
+ value: currentValue,
291
+ length,
292
+ focusedIndex,
293
+ onChange: updateValue,
294
+ setFocusedIndex,
295
+ disabled,
296
+ readOnly
297
+ });
298
+ useEffect(() => {
299
+ if (isControlled && controlledValue !== void 0) {
300
+ const firstEmptyIndex = controlledValue.indexOf("_");
301
+ if (firstEmptyIndex !== -1) {
302
+ setFocusedIndex(firstEmptyIndex);
303
+ }
304
+ }
305
+ }, [isControlled, controlledValue]);
306
+ useEffect(() => {
307
+ return () => {
308
+ if (debounceTimerRef.current) {
309
+ clearTimeout(debounceTimerRef.current);
310
+ }
311
+ };
312
+ }, []);
313
+ return {
314
+ value: currentValue,
315
+ focusedIndex,
316
+ error: currentError,
317
+ isComplete,
318
+ handleChange,
319
+ handleKeyDown,
320
+ handlePaste,
321
+ setFocusedIndex,
322
+ clear,
323
+ setValue,
324
+ validate: validateCurrent
325
+ };
326
+ }
327
+ var otpDigitVariants = cva(
328
+ // Base styles - Applied to all variants
329
+ [
330
+ "inline-flex",
331
+ "items-center",
332
+ "justify-center",
333
+ "rounded-md",
334
+ "border-2",
335
+ "font-semibold",
336
+ "transition-all",
337
+ "duration-200",
338
+ "ease-in-out",
339
+ "select-none",
340
+ "tabindex-[-1]"
341
+ // Not tabbable (hidden input handles focus)
342
+ ],
343
+ {
344
+ variants: {
345
+ /**
346
+ * Size Variants
347
+ * All sizes meet WCAG AAA touch target minimum (44x44px)
348
+ */
349
+ size: {
350
+ /**
351
+ * Small: 40×40px base + 4px padding = 44×44px touch target
352
+ * Font: 16px (base size)
353
+ * Use case: Compact layouts, mobile optimization
354
+ */
355
+ sm: [
356
+ "h-10",
357
+ // 40px
358
+ "w-10",
359
+ // 40px
360
+ "text-base",
361
+ // 16px
362
+ "p-1"
363
+ // 4px padding for touch target
364
+ ],
365
+ /**
366
+ * Medium (default): 48×56px
367
+ * Font: 20px (comfortable reading size)
368
+ * Use case: Standard desktop/mobile layouts
369
+ */
370
+ md: [
371
+ "h-14",
372
+ // 56px
373
+ "w-10 sm:w-12 md:w-14",
374
+ // 48px
375
+ "text-xl"
376
+ // 20px
377
+ ],
378
+ /**
379
+ * Large: 56×64px
380
+ * Font: 24px (large reading size)
381
+ * Use case: Accessibility focus, high-visibility needs
382
+ */
383
+ lg: [
384
+ "h-16",
385
+ // 64px
386
+ "w-10 sm:w-12 md:w-16",
387
+ // 56px
388
+ "text-2xl"
389
+ // 24px
390
+ ]
391
+ },
392
+ /**
393
+ * State Variants
394
+ * All states meet WCAG AAA contrast (7:1 minimum)
395
+ */
396
+ state: {
397
+ /**
398
+ * Default: Standard input appearance
399
+ * Border: --border
400
+ * Background: --background
401
+ * Text: --foreground
402
+ */
403
+ default: [
404
+ "border-[var(--input)]",
405
+ "bg-[var(--content-background)]",
406
+ "text-[var(--content-foreground)]",
407
+ "hover:border-[var(--input-hover)]"
408
+ ],
409
+ /**
410
+ * Focus: Active digit being edited
411
+ * Border: --primary
412
+ * Ring: --ring (2px, 2px offset)
413
+ * Contrast: 7:1 minimum
414
+ */
415
+ focus: [
416
+ "border-[var(--input)]",
417
+ "ring-2",
418
+ "ring-[var(--primary)]",
419
+ "ring-offset-2",
420
+ "ring-offset-background",
421
+ "outline-none"
422
+ ],
423
+ /**
424
+ * Filled: Digit has been entered
425
+ * Border: --primary with 50% opacity
426
+ * Text: Bold weight for emphasis
427
+ */
428
+ filled: [
429
+ "border-[var(--primary)]",
430
+ "bg-[var(--content-background)]",
431
+ "text-[var(--content-foreground)]",
432
+ "font-bold"
433
+ ],
434
+ /**
435
+ * Error: Validation failed
436
+ * Border: --destructive
437
+ * Background: --destructive with 10% opacity
438
+ * Text: --destructive-foreground
439
+ * Animation: Shake on error
440
+ */
441
+ error: [
442
+ "border-[var(--destructive)]",
443
+ "bg-[var(--content-background)]",
444
+ "text-[var(--destructive-foreground)]",
445
+ "animate-shake"
446
+ ],
447
+ /**
448
+ * Success: Validation passed (optional)
449
+ * Border: Green (or --success if available)
450
+ * Background: Green with 10% opacity
451
+ * May include checkmark icon
452
+ */
453
+ success: [
454
+ "border-green-600",
455
+ "bg-green-50",
456
+ "text-green-900",
457
+ "dark:border-green-500",
458
+ "dark:bg-green-900/20",
459
+ "dark:text-green-100"
460
+ ],
461
+ /**
462
+ * Disabled: Input not interactive
463
+ * Border: --border with 50% opacity
464
+ * Background: --muted with 50% opacity
465
+ * Text: --muted-foreground
466
+ * Cursor: not-allowed
467
+ * Opacity: 60%
468
+ * Contrast: 4.5:1 minimum (AA standard for disabled)
469
+ */
470
+ disabled: [
471
+ "border-[var(--accent-background)]",
472
+ "bg-[var(--accent-background)]",
473
+ "text-[var(--menu-muted)]",
474
+ "cursor-not-allowed",
475
+ "opacity-60",
476
+ "hover:border-[var(--accent-background)]"
477
+ // Prevent hover effect
478
+ ]
479
+ }
480
+ },
481
+ defaultVariants: {
482
+ size: "md",
483
+ state: "default"
484
+ }
485
+ }
486
+ );
487
+ var otpContainerVariants = cva(
488
+ [
489
+ "inline-flex",
490
+ "flex-col",
491
+ "gap-2"
492
+ ],
493
+ {
494
+ variants: {
495
+ /**
496
+ * Container size variants
497
+ * Affects spacing and layout
498
+ */
499
+ size: {
500
+ sm: ["gap-1.5"],
501
+ md: ["gap-2"],
502
+ lg: ["gap-3"]
503
+ }
504
+ },
505
+ defaultVariants: {
506
+ size: "md"
507
+ }
508
+ }
509
+ );
510
+ var otpDigitGroupVariants = cva(
511
+ [
512
+ "flex",
513
+ "items-center"
514
+ ],
515
+ {
516
+ variants: {
517
+ /**
518
+ * Gap between digits
519
+ */
520
+ size: {
521
+ sm: ["gap-1.5"],
522
+ // 6px
523
+ md: ["gap-2"],
524
+ // 8px
525
+ lg: ["gap-3"]
526
+ // 12px
527
+ }
528
+ },
529
+ defaultVariants: {
530
+ size: "md"
531
+ }
532
+ }
533
+ );
534
+ var otpErrorVariants = cva([
535
+ "text-sm",
536
+ "font-medium",
537
+ "text-[var(--destructive)]",
538
+ "mt-1.5",
539
+ "text-center"
540
+ ]);
541
+ var otpDescriptionVariants = cva([
542
+ "text-sm",
543
+ "text-[var(--menu-muted)]",
544
+ "mt-1"
545
+ ]);
546
+ var OTPDigitComponent = ({
547
+ value,
548
+ focused,
549
+ size = "md",
550
+ state = "default",
551
+ masked = false,
552
+ className,
553
+ index
554
+ }) => {
555
+ const isFilled = value !== "_" && value !== "";
556
+ const computedState = focused && !state ? "focus" : isFilled && state === "default" ? "filled" : state;
557
+ const displayValue = masked && isFilled ? "\u2022" : value === "_" ? "" : value;
558
+ return /* @__PURE__ */ jsx(
559
+ "div",
560
+ {
561
+ className: cn(
562
+ otpDigitVariants({ size, state: computedState }),
563
+ className
564
+ ),
565
+ role: "presentation",
566
+ "aria-hidden": "true",
567
+ "data-focused": focused,
568
+ "data-filled": isFilled,
569
+ "data-index": index,
570
+ children: displayValue || /* @__PURE__ */ jsx("span", { className: "text-[var(--menu-muted)] opacity-40", children: "\u2022" })
571
+ }
572
+ );
573
+ };
574
+ var OTPDigit = memo(OTPDigitComponent);
575
+ OTPDigit.displayName = "OTPDigit";
576
+ var OTPInput = forwardRef((props, ref) => {
577
+ const {
578
+ label,
579
+ description,
580
+ size = "md",
581
+ disabled = false,
582
+ readOnly = false,
583
+ mask = false,
584
+ showSuccess = false,
585
+ className,
586
+ digitClassName,
587
+ onFocus,
588
+ onBlur,
589
+ inputMode = "numeric",
590
+ length = 6
591
+ } = props;
592
+ const {
593
+ value,
594
+ focusedIndex,
595
+ error,
596
+ isComplete,
597
+ handleChange,
598
+ handleKeyDown,
599
+ handlePaste,
600
+ setFocusedIndex,
601
+ clear,
602
+ setValue,
603
+ validate
604
+ } = useOTPInput(props);
605
+ const inputRef = useRef(null);
606
+ useImperativeHandle(ref, () => ({
607
+ focus: () => inputRef.current?.focus(),
608
+ blur: () => inputRef.current?.blur(),
609
+ clear,
610
+ setValue,
611
+ getValue: () => value.replace(/_/g, ""),
612
+ isComplete: () => isComplete,
613
+ validate,
614
+ getElement: () => inputRef.current
615
+ }));
616
+ const digits = value.split("");
617
+ const getDigitState = (index) => {
618
+ if (disabled) return "disabled";
619
+ if (error) return "error";
620
+ if (showSuccess && isComplete && !error) return "success";
621
+ if (index === focusedIndex) return "focus";
622
+ if (digits[index] !== "_") return "filled";
623
+ return "default";
624
+ };
625
+ const handleFocusEvent = (e) => {
626
+ onFocus?.(e);
627
+ };
628
+ const handleBlurEvent = (e) => {
629
+ onBlur?.(e);
630
+ };
631
+ const handleDigitClick = (index) => {
632
+ if (disabled || readOnly) return;
633
+ setFocusedIndex(index);
634
+ inputRef.current?.focus();
635
+ };
636
+ const handleDigitKeyDown = (e, index) => {
637
+ if (e.key === "Enter" || e.key === " ") {
638
+ e.preventDefault();
639
+ handleDigitClick(index);
640
+ }
641
+ };
642
+ const descriptionId = description ? `otp-description-${Math.random().toString(36).slice(2, 9)}` : void 0;
643
+ const errorId = error ? `otp-error-${Math.random().toString(36).slice(2, 9)}` : void 0;
644
+ return /* @__PURE__ */ jsxs("div", { className: cn(otpContainerVariants({ size }), className), children: [
645
+ /* @__PURE__ */ jsx(
646
+ "input",
647
+ {
648
+ ref: inputRef,
649
+ type: "text",
650
+ inputMode,
651
+ value: value.replace(/_/g, ""),
652
+ onChange: handleChange,
653
+ onKeyDown: handleKeyDown,
654
+ onPaste: handlePaste,
655
+ onFocus: handleFocusEvent,
656
+ onBlur: handleBlurEvent,
657
+ disabled,
658
+ readOnly,
659
+ "aria-label": label,
660
+ "aria-describedby": [descriptionId, errorId].filter(Boolean).join(" "),
661
+ "aria-invalid": !!error,
662
+ "aria-errormessage": errorId,
663
+ className: "sr-only",
664
+ autoComplete: "one-time-code",
665
+ maxLength: length
666
+ }
667
+ ),
668
+ /* @__PURE__ */ jsx(
669
+ "div",
670
+ {
671
+ className: cn(otpDigitGroupVariants({ size })),
672
+ role: "presentation",
673
+ "aria-hidden": "true",
674
+ children: digits.map((digit, index) => /* @__PURE__ */ jsx(
675
+ "div",
676
+ {
677
+ onClick: () => handleDigitClick(index),
678
+ onKeyDown: (e) => handleDigitKeyDown(e, index),
679
+ role: "button",
680
+ tabIndex: -1,
681
+ className: "cursor-text",
682
+ children: /* @__PURE__ */ jsx(
683
+ OTPDigit,
684
+ {
685
+ value: digit,
686
+ focused: index === focusedIndex,
687
+ size,
688
+ state: getDigitState(index),
689
+ masked: mask,
690
+ className: digitClassName,
691
+ index
692
+ }
693
+ )
694
+ },
695
+ index
696
+ ))
697
+ }
698
+ ),
699
+ description && /* @__PURE__ */ jsx("p", { id: descriptionId, className: otpDescriptionVariants(), children: description }),
700
+ error && /* @__PURE__ */ jsx(
701
+ "p",
702
+ {
703
+ id: errorId,
704
+ className: otpErrorVariants(),
705
+ role: "alert",
706
+ "aria-live": "assertive",
707
+ children: error
708
+ }
709
+ ),
710
+ /* @__PURE__ */ jsxs(
711
+ "div",
712
+ {
713
+ role: "status",
714
+ "aria-live": "polite",
715
+ "aria-atomic": "true",
716
+ className: "sr-only",
717
+ children: [
718
+ !isComplete && !error && /* @__PURE__ */ jsxs(Fragment, { children: [
719
+ value.replace(/_/g, "").length,
720
+ " of ",
721
+ length,
722
+ " digits entered"
723
+ ] }),
724
+ isComplete && !error && /* @__PURE__ */ jsx(Fragment, { children: "Verification code complete" })
725
+ ]
726
+ }
727
+ )
728
+ ] });
729
+ });
730
+ OTPInput.displayName = "OTPInput";
731
+
732
+ export { OTPInput };
3
733
  //# sourceMappingURL=index.mjs.map
4
734
  //# sourceMappingURL=index.mjs.map