@svelte-atoms/core 1.0.0-alpha.41 → 1.0.0-alpha.44

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 (628) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +67 -197
  3. package/dist/attachments/clickout.svelte.d.ts +4 -1
  4. package/dist/attachments/clickout.svelte.js +2 -1
  5. package/dist/components/accordion/accordion-root.svelte +61 -66
  6. package/dist/components/accordion/accordion-root.svelte.d.ts +2 -2
  7. package/dist/components/accordion/bond.svelte.d.ts +11 -10
  8. package/dist/components/accordion/bond.svelte.js +26 -16
  9. package/dist/components/accordion/item/accordion-item-body.svelte +3 -1
  10. package/dist/components/accordion/item/accordion-item-header.svelte +1 -1
  11. package/dist/components/accordion/item/accordion-item-indicator.svelte +1 -1
  12. package/dist/components/accordion/item/accordion-item-root.svelte +3 -2
  13. package/dist/components/accordion/item/bond.svelte.d.ts +32 -18
  14. package/dist/components/accordion/item/bond.svelte.js +88 -64
  15. package/dist/components/accordion/item/types.d.ts +4 -24
  16. package/dist/components/accordion/types.d.ts +5 -9
  17. package/dist/components/alert/alert-root.svelte +68 -68
  18. package/dist/components/alert/types.d.ts +12 -46
  19. package/dist/components/atom/html-atom.svelte +84 -95
  20. package/dist/components/atom/html-atom.svelte.d.ts +1 -2
  21. package/dist/components/atom/index.d.ts +1 -0
  22. package/dist/components/atom/index.js +1 -0
  23. package/dist/components/atom/types.d.ts +52 -10
  24. package/dist/components/atom/types.js +1 -1
  25. package/dist/components/atom/utils.d.ts +10 -3
  26. package/dist/components/atom/utils.js +112 -45
  27. package/dist/components/avatar/types.d.ts +1 -6
  28. package/dist/components/badge/index.d.ts +1 -0
  29. package/dist/components/badge/types.d.ts +4 -7
  30. package/dist/components/button/button.svelte +31 -31
  31. package/dist/components/button/types.d.ts +9 -6
  32. package/dist/components/calendar/calendar-body.svelte +0 -1
  33. package/dist/components/calendar/calendar-day.svelte +99 -99
  34. package/dist/components/calendar/calendar-header.svelte +1 -1
  35. package/dist/components/calendar/calendar-root.svelte +206 -206
  36. package/dist/components/calendar/calendar-root.svelte.d.ts +1 -1
  37. package/dist/components/calendar/calendar-week-day.svelte +33 -33
  38. package/dist/components/calendar/types.d.ts +7 -10
  39. package/dist/components/card/card-root.svelte +92 -92
  40. package/dist/components/card/types.d.ts +12 -51
  41. package/dist/components/checkbox/checkbox.svelte +65 -55
  42. package/dist/components/checkbox/checkbox.svelte.d.ts +1 -3
  43. package/dist/components/checkbox/index.d.ts +2 -0
  44. package/dist/components/checkbox/index.js +1 -0
  45. package/dist/components/checkbox/motion.d.ts +17 -0
  46. package/dist/components/checkbox/motion.js +34 -0
  47. package/dist/components/checkbox/types.d.ts +14 -7
  48. package/dist/components/chip/chip-close-button.svelte +33 -0
  49. package/dist/components/chip/chip-close-button.svelte.d.ts +4 -0
  50. package/dist/components/chip/chip.svelte +34 -41
  51. package/dist/components/chip/chip.svelte.d.ts +1 -3
  52. package/dist/components/chip/index.d.ts +2 -0
  53. package/dist/components/chip/index.js +2 -0
  54. package/dist/components/chip/types.d.ts +15 -8
  55. package/dist/components/collapsible/bond.svelte.d.ts +34 -24
  56. package/dist/components/collapsible/bond.svelte.js +73 -60
  57. package/dist/components/collapsible/collapsible-body.svelte +1 -1
  58. package/dist/components/collapsible/collapsible-header.svelte +1 -1
  59. package/dist/components/collapsible/collapsible-indicator.svelte +1 -1
  60. package/dist/components/collapsible/collapsible-root.svelte +67 -67
  61. package/dist/components/collapsible/types.d.ts +10 -22
  62. package/dist/components/combobox/bond.svelte.d.ts +13 -8
  63. package/dist/components/combobox/bond.svelte.js +30 -20
  64. package/dist/components/combobox/combobox-control.svelte +66 -66
  65. package/dist/components/combobox/combobox-item.svelte +62 -62
  66. package/dist/components/combobox/combobox-root.svelte +65 -65
  67. package/dist/components/combobox/combobox-root.svelte.d.ts +2 -2
  68. package/dist/components/combobox/combobox-selections.svelte +17 -17
  69. package/dist/components/combobox/combobox-trigger.svelte +34 -34
  70. package/dist/components/combobox/types.d.ts +6 -10
  71. package/dist/components/container/index.d.ts +1 -0
  72. package/dist/components/container/types.d.ts +6 -12
  73. package/dist/components/context-menu/atoms.d.ts +4 -0
  74. package/dist/components/context-menu/atoms.js +4 -0
  75. package/dist/components/context-menu/context-menu-content.svelte +52 -0
  76. package/dist/components/context-menu/context-menu-content.svelte.d.ts +27 -0
  77. package/dist/components/context-menu/context-menu-root.svelte +8 -0
  78. package/dist/components/context-menu/context-menu-root.svelte.d.ts +4 -0
  79. package/dist/components/context-menu/context-menu-trigger.svelte +59 -0
  80. package/dist/components/context-menu/context-menu-trigger.svelte.d.ts +27 -0
  81. package/dist/components/context-menu/index.d.ts +2 -0
  82. package/dist/components/context-menu/index.js +2 -0
  83. package/dist/components/{contextmenu → context-menu}/types.d.ts +1 -6
  84. package/dist/components/datagrid/atoms.d.ts +11 -5
  85. package/dist/components/datagrid/atoms.js +11 -5
  86. package/dist/components/datagrid/bond.svelte.d.ts +29 -14
  87. package/dist/components/datagrid/bond.svelte.js +45 -33
  88. package/dist/components/datagrid/cell/bond.svelte.d.ts +29 -0
  89. package/dist/components/datagrid/cell/bond.svelte.js +42 -0
  90. package/dist/components/datagrid/cell/datagrid-cell.svelte +49 -0
  91. package/dist/components/datagrid/cell/datagrid-cell.svelte.d.ts +26 -0
  92. package/dist/components/datagrid/cell/index.d.ts +4 -0
  93. package/dist/components/datagrid/cell/index.js +4 -0
  94. package/dist/components/datagrid/col/index.d.ts +4 -0
  95. package/dist/components/datagrid/col/index.js +4 -0
  96. package/dist/components/datagrid/column/bond.svelte.d.ts +45 -0
  97. package/dist/components/datagrid/column/bond.svelte.js +76 -0
  98. package/dist/components/datagrid/{th/datagrid-th-sort-icon.svelte → column/datagrid-column-sort-icon.svelte} +3 -3
  99. package/dist/components/datagrid/{th/datagrid-th-sort-icon.svelte.d.ts → column/datagrid-column-sort-icon.svelte.d.ts} +3 -3
  100. package/dist/components/datagrid/{th/datagrid-th.svelte → column/datagrid-column.svelte} +27 -36
  101. package/dist/components/datagrid/column/datagrid-column.svelte.d.ts +26 -0
  102. package/dist/components/datagrid/column/index.d.ts +4 -0
  103. package/dist/components/datagrid/column/index.js +4 -0
  104. package/dist/components/datagrid/context.d.ts +2 -29
  105. package/dist/components/datagrid/context.js +4 -18
  106. package/dist/components/datagrid/datagrid-body.svelte +7 -20
  107. package/dist/components/datagrid/datagrid-body.svelte.d.ts +8 -15
  108. package/dist/components/datagrid/datagrid-checkbox.svelte +60 -63
  109. package/dist/components/datagrid/datagrid-checkbox.svelte.d.ts +1 -3
  110. package/dist/components/datagrid/datagrid-footer.svelte +27 -34
  111. package/dist/components/datagrid/datagrid-footer.svelte.d.ts +12 -12
  112. package/dist/components/datagrid/datagrid-header.svelte +10 -17
  113. package/dist/components/datagrid/datagrid-header.svelte.d.ts +12 -12
  114. package/dist/components/datagrid/datagrid-root.svelte +49 -59
  115. package/dist/components/datagrid/datagrid-root.svelte.d.ts +15 -14
  116. package/dist/components/datagrid/row/bond.svelte.d.ts +42 -0
  117. package/dist/components/datagrid/row/bond.svelte.js +72 -0
  118. package/dist/components/datagrid/{tr/datagrid-tr.css → row/datagrid-row.css} +1 -1
  119. package/dist/components/datagrid/row/datagrid-row.svelte +64 -0
  120. package/dist/components/datagrid/row/datagrid-row.svelte.d.ts +27 -0
  121. package/dist/components/datagrid/row/index.d.ts +4 -0
  122. package/dist/components/datagrid/row/index.js +4 -0
  123. package/dist/components/datagrid/types.d.ts +56 -116
  124. package/dist/components/date-picker/bond.svelte.d.ts +0 -12
  125. package/dist/components/date-picker/date-picker-calendar.svelte +58 -58
  126. package/dist/components/date-picker/date-picker-months.svelte +1 -1
  127. package/dist/components/date-picker/date-picker-root.svelte +96 -96
  128. package/dist/components/date-picker/date-picker-root.svelte.d.ts +1 -1
  129. package/dist/components/date-picker/date-picker-years.svelte +1 -1
  130. package/dist/components/date-picker/types.d.ts +6 -3
  131. package/dist/components/dialog/atoms.d.ts +1 -1
  132. package/dist/components/dialog/atoms.js +1 -1
  133. package/dist/components/dialog/bond.svelte.d.ts +66 -28
  134. package/dist/components/dialog/bond.svelte.js +136 -117
  135. package/dist/components/dialog/dialog-body.svelte +1 -1
  136. package/dist/components/dialog/dialog-close.svelte +58 -0
  137. package/dist/components/dialog/dialog-close.svelte.d.ts +26 -0
  138. package/dist/components/dialog/dialog-content.svelte +2 -2
  139. package/dist/components/dialog/dialog-description.svelte +1 -1
  140. package/dist/components/dialog/dialog-footer.svelte +1 -1
  141. package/dist/components/dialog/dialog-header.svelte +1 -1
  142. package/dist/components/dialog/dialog-root.svelte +102 -82
  143. package/dist/components/dialog/dialog-title.svelte +1 -1
  144. package/dist/components/dialog/motion.svelte.js +68 -26
  145. package/dist/components/dialog/types.d.ts +16 -51
  146. package/dist/components/divider/types.d.ts +1 -6
  147. package/dist/components/drawer/bond.svelte.d.ts +61 -36
  148. package/dist/components/drawer/bond.svelte.js +149 -121
  149. package/dist/components/drawer/drawer-backdrop.svelte +2 -1
  150. package/dist/components/drawer/drawer-body.svelte +1 -1
  151. package/dist/components/drawer/drawer-content.svelte +5 -5
  152. package/dist/components/drawer/drawer-content.svelte.d.ts +4 -1
  153. package/dist/components/drawer/drawer-description.svelte +1 -1
  154. package/dist/components/drawer/drawer-footer.svelte +1 -1
  155. package/dist/components/drawer/drawer-header.svelte +1 -1
  156. package/dist/components/drawer/drawer-root.svelte +96 -87
  157. package/dist/components/drawer/drawer-title.svelte +1 -1
  158. package/dist/components/drawer/motion.d.ts +59 -5
  159. package/dist/components/drawer/motion.js +133 -15
  160. package/dist/components/drawer/types.d.ts +15 -24
  161. package/dist/components/dropdown/atoms.d.ts +4 -8
  162. package/dist/components/dropdown/atoms.js +4 -9
  163. package/dist/components/dropdown/bond.svelte.d.ts +4 -53
  164. package/dist/components/dropdown/bond.svelte.js +4 -89
  165. package/dist/components/dropdown/dropdown-query.svelte +43 -43
  166. package/dist/components/dropdown/dropdown-root.svelte +79 -79
  167. package/dist/components/dropdown/dropdown-root.svelte.d.ts +4 -4
  168. package/dist/components/dropdown/dropdown-selection.svelte +55 -55
  169. package/dist/components/dropdown/dropdown-selections.svelte +70 -70
  170. package/dist/components/dropdown/dropdown-trigger.svelte +30 -30
  171. package/dist/components/dropdown/index.d.ts +43 -7
  172. package/dist/components/dropdown/index.js +34 -6
  173. package/dist/components/dropdown/item/bond.svelte.d.ts +36 -0
  174. package/dist/components/dropdown/item/bond.svelte.js +85 -0
  175. package/dist/components/dropdown/item/controller.svelte.d.ts +1 -1
  176. package/dist/components/dropdown/item/dropdown-item.svelte +81 -107
  177. package/dist/components/dropdown/item/index.d.ts +11 -3
  178. package/dist/components/dropdown/item/index.js +10 -3
  179. package/dist/components/dropdown/types.d.ts +2 -67
  180. package/dist/components/dropdown-menu/atoms.d.ts +9 -0
  181. package/dist/components/dropdown-menu/atoms.js +9 -0
  182. package/dist/components/dropdown-menu/attachments.svelte.d.ts +2 -0
  183. package/dist/components/dropdown-menu/attachments.svelte.js +5 -0
  184. package/dist/components/dropdown-menu/bond.svelte.d.ts +72 -0
  185. package/dist/components/dropdown-menu/bond.svelte.js +173 -0
  186. package/dist/components/dropdown-menu/dropdown-menu-content.svelte +40 -0
  187. package/dist/components/dropdown-menu/dropdown-menu-content.svelte.d.ts +37 -0
  188. package/dist/components/dropdown-menu/dropdown-menu-root.svelte +14 -0
  189. package/dist/components/dropdown-menu/dropdown-menu-root.svelte.d.ts +4 -0
  190. package/dist/components/dropdown-menu/index.d.ts +7 -0
  191. package/dist/components/dropdown-menu/index.js +6 -0
  192. package/dist/components/dropdown-menu/item/bond.svelte.d.ts +26 -0
  193. package/dist/components/dropdown-menu/item/bond.svelte.js +54 -0
  194. package/dist/components/dropdown-menu/item/controller.svelte.d.ts +39 -0
  195. package/dist/components/dropdown-menu/item/controller.svelte.js +73 -0
  196. package/dist/components/dropdown-menu/item/dropdown-menu-item.svelte +75 -0
  197. package/dist/components/dropdown-menu/item/dropdown-menu-item.svelte.d.ts +32 -0
  198. package/dist/components/dropdown-menu/item/index.d.ts +3 -0
  199. package/dist/components/dropdown-menu/item/index.js +3 -0
  200. package/dist/components/dropdown-menu/item/types.d.ts +57 -0
  201. package/dist/components/dropdown-menu/item/types.js +1 -0
  202. package/dist/components/dropdown-menu/types.d.ts +3 -0
  203. package/dist/components/dropdown-menu/types.js +1 -0
  204. package/dist/components/element/html-element.svelte +114 -85
  205. package/dist/components/element/html-element.svelte.d.ts +1 -1
  206. package/dist/components/element/svg-element.svelte +88 -88
  207. package/dist/components/element/types.d.ts +32 -20
  208. package/dist/components/form/field/atoms.d.ts +1 -1
  209. package/dist/components/form/field/atoms.js +1 -1
  210. package/dist/components/form/field/bond.svelte.js +0 -6
  211. package/dist/components/form/field/field-control.svelte +30 -9
  212. package/dist/components/form/field/field-control.svelte.d.ts +12 -22
  213. package/dist/components/form/field/field-helper-text.svelte +23 -0
  214. package/dist/components/form/field/field-helper-text.svelte.d.ts +26 -0
  215. package/dist/components/form/field/field-label.svelte +5 -7
  216. package/dist/components/form/field/field-label.svelte.d.ts +2 -2
  217. package/dist/components/form/field/field-root.svelte +17 -8
  218. package/dist/components/form/form-root.svelte +66 -66
  219. package/dist/components/form/types.d.ts +34 -58
  220. package/dist/components/icon/icon.svelte +40 -40
  221. package/dist/components/icon/types.d.ts +4 -7
  222. package/dist/components/image/index.d.ts +2 -0
  223. package/dist/components/image/index.js +2 -1
  224. package/dist/components/index.d.ts +11 -0
  225. package/dist/components/index.js +11 -0
  226. package/dist/components/input/atoms.d.ts +19 -1
  227. package/dist/components/input/atoms.js +19 -1
  228. package/dist/components/input/color/color-control.svelte +197 -0
  229. package/dist/components/input/color/color-control.svelte.d.ts +4 -0
  230. package/dist/components/input/color/index.d.ts +5 -0
  231. package/dist/components/input/color/index.js +5 -0
  232. package/dist/components/input/color/segment.svelte +240 -0
  233. package/dist/components/input/color/segment.svelte.d.ts +6 -0
  234. package/dist/components/input/color/shared.d.ts +23 -0
  235. package/dist/components/input/color/shared.js +349 -0
  236. package/dist/components/input/color/swatch.svelte +23 -0
  237. package/dist/components/input/color/swatch.svelte.d.ts +8 -0
  238. package/dist/components/input/color/types.d.ts +56 -0
  239. package/dist/components/input/color/types.js +2 -0
  240. package/dist/components/input/index.d.ts +1 -0
  241. package/dist/components/input/index.js +1 -0
  242. package/dist/components/input/input-control.svelte +3 -1
  243. package/dist/components/input/input-currency-control.svelte +189 -0
  244. package/dist/components/input/input-currency-control.svelte.d.ts +4 -0
  245. package/dist/components/input/input-email-control.svelte +128 -0
  246. package/dist/components/input/input-email-control.svelte.d.ts +4 -0
  247. package/dist/components/input/input-file-control.svelte +127 -0
  248. package/dist/components/input/input-file-control.svelte.d.ts +4 -0
  249. package/dist/components/input/input-icon.svelte.d.ts +1 -1
  250. package/dist/components/input/input-location.svelte +335 -0
  251. package/dist/components/input/input-location.svelte.d.ts +4 -0
  252. package/dist/components/input/input-number-control.svelte +114 -0
  253. package/dist/components/input/input-number-control.svelte.d.ts +6 -0
  254. package/dist/components/input/input-otp-control.svelte +206 -0
  255. package/dist/components/input/input-otp-control.svelte.d.ts +4 -0
  256. package/dist/components/input/input-password-control.svelte +91 -0
  257. package/dist/components/input/input-password-control.svelte.d.ts +3 -0
  258. package/dist/components/input/input-phone-control.svelte +394 -0
  259. package/dist/components/input/input-phone-control.svelte.d.ts +4 -0
  260. package/dist/components/input/input-placeholder.svelte.d.ts +1 -1
  261. package/dist/components/input/input-root.svelte +74 -74
  262. package/dist/components/input/input-text-control.svelte +59 -0
  263. package/dist/components/input/input-text-control.svelte.d.ts +4 -0
  264. package/dist/components/input/input-url-control.svelte +218 -0
  265. package/dist/components/input/input-url-control.svelte.d.ts +4 -0
  266. package/dist/components/input/time/datetime-control.svelte +281 -0
  267. package/dist/components/input/time/datetime-control.svelte.d.ts +5 -0
  268. package/dist/components/input/time/index.d.ts +6 -0
  269. package/dist/components/input/time/index.js +6 -0
  270. package/dist/components/input/time/segment.svelte +143 -0
  271. package/dist/components/input/time/segment.svelte.d.ts +6 -0
  272. package/dist/components/input/time/shared.d.ts +29 -0
  273. package/dist/components/input/time/shared.js +150 -0
  274. package/dist/components/input/time/time-control.svelte +237 -0
  275. package/dist/components/input/time/time-control.svelte.d.ts +3 -0
  276. package/dist/components/input/time/types.d.ts +34 -0
  277. package/dist/components/input/time/types.js +4 -0
  278. package/dist/components/input/types.d.ts +355 -17
  279. package/dist/components/label/types.d.ts +4 -7
  280. package/dist/components/layer/bond.svelte.d.ts +2 -2
  281. package/dist/components/layer/bond.svelte.js +1 -1
  282. package/dist/components/layer/index.d.ts +1 -0
  283. package/dist/components/layer/layer-inner.svelte.d.ts +1 -1
  284. package/dist/components/layer/layer-root.svelte +65 -65
  285. package/dist/components/layer/layer-root.svelte.d.ts +1 -1
  286. package/dist/components/layer/types.d.ts +6 -6
  287. package/dist/components/lazy/index.d.ts +1 -0
  288. package/dist/components/lazy/lazy.svelte +29 -29
  289. package/dist/components/lazy/types.d.ts +4 -4
  290. package/dist/components/link/index.d.ts +1 -0
  291. package/dist/components/link/types.d.ts +5 -6
  292. package/dist/components/list/index.d.ts +1 -0
  293. package/dist/components/list/types.d.ts +5 -6
  294. package/dist/components/menu/atoms.d.ts +2 -7
  295. package/dist/components/menu/atoms.js +2 -7
  296. package/dist/components/menu/bond.svelte.d.ts +9 -23
  297. package/dist/components/menu/bond.svelte.js +6 -0
  298. package/dist/components/menu/index.d.ts +40 -4
  299. package/dist/components/menu/index.js +26 -3
  300. package/dist/components/menu/item/bond.svelte.d.ts +27 -0
  301. package/dist/components/menu/item/bond.svelte.js +54 -0
  302. package/dist/components/menu/item/controller.svelte.d.ts +1 -1
  303. package/dist/components/menu/item/index.d.ts +5 -2
  304. package/dist/components/menu/item/index.js +4 -2
  305. package/dist/components/menu/item/menu-item.svelte +87 -103
  306. package/dist/components/menu/item/menu-item.svelte.d.ts +15 -14
  307. package/dist/components/menu/item/types.d.ts +5 -12
  308. package/dist/components/menu/menu-content.svelte +40 -40
  309. package/dist/components/menu/menu-root.svelte +15 -15
  310. package/dist/components/menu/menu-root.svelte.d.ts +1 -1
  311. package/dist/components/menu/types.d.ts +2 -6
  312. package/dist/components/popover/bond.svelte.d.ts +67 -39
  313. package/dist/components/popover/bond.svelte.js +159 -197
  314. package/dist/components/popover/index.d.ts +3 -1
  315. package/dist/components/popover/index.js +3 -1
  316. package/dist/components/popover/motion.d.ts +29 -1
  317. package/dist/components/popover/motion.js +128 -50
  318. package/dist/components/popover/popover-arrow.svelte +97 -110
  319. package/dist/components/popover/popover-arrow.svelte.d.ts +1 -2
  320. package/dist/components/popover/popover-content.svelte +159 -123
  321. package/dist/components/popover/popover-engine.svelte +118 -0
  322. package/dist/components/popover/popover-engine.svelte.d.ts +3 -0
  323. package/dist/components/popover/popover-indicator.svelte +2 -13
  324. package/dist/components/popover/popover-indicator.svelte.d.ts +0 -6
  325. package/dist/components/popover/popover-root.svelte +87 -49
  326. package/dist/components/popover/popover-root.svelte.d.ts +2 -1
  327. package/dist/components/popover/popover-trigger.svelte +35 -35
  328. package/dist/components/popover/strategies/floating.svelte +109 -0
  329. package/dist/components/popover/strategies/floating.svelte.d.ts +3 -0
  330. package/dist/components/popover/strategies/index.d.ts +1 -0
  331. package/dist/components/popover/strategies/index.js +1 -0
  332. package/dist/components/popover/strategy-types.d.ts +40 -0
  333. package/dist/components/popover/strategy-types.js +1 -0
  334. package/dist/components/popover/types.d.ts +10 -36
  335. package/dist/components/portal/active-portal.svelte +5 -4
  336. package/dist/components/portal/bond.svelte.d.ts +12 -8
  337. package/dist/components/portal/bond.svelte.js +25 -27
  338. package/dist/components/portal/index.d.ts +1 -0
  339. package/dist/components/portal/index.js +1 -0
  340. package/dist/components/portal/portal-inner.svelte +1 -1
  341. package/dist/components/portal/portal-inner.svelte.d.ts +1 -1
  342. package/dist/components/portal/portal-root.svelte +76 -76
  343. package/dist/components/portal/portal-root.svelte.d.ts +1 -1
  344. package/dist/components/portal/portals/bond.svelte.d.ts +2 -2
  345. package/dist/components/portal/portals/bond.svelte.js +2 -2
  346. package/dist/components/portal/teleport.svelte +47 -49
  347. package/dist/components/portal/teleport.svelte.d.ts +1 -2
  348. package/dist/components/portal/types.d.ts +7 -25
  349. package/dist/components/portal/utils.js +3 -3
  350. package/dist/components/portal/zlayer.svelte.d.ts +16 -0
  351. package/dist/components/portal/zlayer.svelte.js +25 -0
  352. package/dist/components/radio/index.d.ts +2 -0
  353. package/dist/components/radio/index.js +1 -0
  354. package/dist/components/radio/motion.d.ts +24 -0
  355. package/dist/components/radio/motion.js +59 -0
  356. package/dist/components/radio/radio.svelte +22 -12
  357. package/dist/components/radio/types.d.ts +5 -14
  358. package/dist/components/root/bond.svelte.d.ts +2 -2
  359. package/dist/components/root/bond.svelte.js +1 -1
  360. package/dist/components/root/root.svelte +82 -92
  361. package/dist/components/root/root.svelte.d.ts +2 -2
  362. package/dist/components/root/types.d.ts +4 -15
  363. package/dist/components/scrollable/atoms.d.ts +1 -0
  364. package/dist/components/scrollable/atoms.js +1 -0
  365. package/dist/components/scrollable/bond.svelte.d.ts +73 -189
  366. package/dist/components/scrollable/bond.svelte.js +195 -371
  367. package/dist/components/scrollable/scrollable-container.css +22 -22
  368. package/dist/components/scrollable/scrollable-container.svelte +66 -61
  369. package/dist/components/scrollable/scrollable-container.svelte.d.ts +12 -12
  370. package/dist/components/scrollable/scrollable-content.svelte +22 -17
  371. package/dist/components/scrollable/scrollable-content.svelte.d.ts +12 -12
  372. package/dist/components/scrollable/scrollable-root.svelte +106 -101
  373. package/dist/components/scrollable/scrollable-root.svelte.d.ts +12 -12
  374. package/dist/components/scrollable/scrollable-thumb.svelte +21 -45
  375. package/dist/components/scrollable/scrollable-thumb.svelte.d.ts +12 -12
  376. package/dist/components/scrollable/scrollable-track.svelte +21 -22
  377. package/dist/components/scrollable/scrollable-track.svelte.d.ts +12 -12
  378. package/dist/components/scrollable/types.d.ts +15 -38
  379. package/dist/components/select/atoms.d.ts +8 -0
  380. package/dist/components/select/atoms.js +8 -0
  381. package/dist/components/select/attachments.svelte.d.ts +2 -0
  382. package/dist/components/select/attachments.svelte.js +5 -0
  383. package/dist/components/select/bond.svelte.d.ts +56 -0
  384. package/dist/components/select/bond.svelte.js +112 -0
  385. package/dist/components/select/index.d.ts +11 -0
  386. package/dist/components/select/index.js +10 -0
  387. package/dist/components/select/item/attachments.svelte.d.ts +3 -0
  388. package/dist/components/select/item/attachments.svelte.js +6 -0
  389. package/dist/components/select/item/bond.svelte.d.ts +33 -0
  390. package/dist/components/select/item/bond.svelte.js +77 -0
  391. package/dist/components/select/item/controller.svelte.d.ts +39 -0
  392. package/dist/components/select/item/controller.svelte.js +105 -0
  393. package/dist/components/select/item/index.d.ts +5 -0
  394. package/dist/components/select/item/index.js +5 -0
  395. package/dist/components/select/item/select-item.svelte +81 -0
  396. package/dist/components/select/item/select-item.svelte.d.ts +25 -0
  397. package/dist/components/select/item/types.d.ts +29 -0
  398. package/dist/components/select/item/types.js +1 -0
  399. package/dist/components/select/runes.svelte.d.ts +10 -0
  400. package/dist/components/select/runes.svelte.js +15 -0
  401. package/dist/components/select/select-placeholder.svelte +40 -0
  402. package/dist/components/select/select-placeholder.svelte.d.ts +34 -0
  403. package/dist/components/select/select-root.svelte +80 -0
  404. package/dist/components/select/select-root.svelte.d.ts +30 -0
  405. package/dist/components/select/select-selection.svelte +55 -0
  406. package/dist/components/select/select-selection.svelte.d.ts +26 -0
  407. package/dist/components/select/select-selections.svelte +70 -0
  408. package/dist/components/select/select-selections.svelte.d.ts +5 -0
  409. package/dist/components/select/select-trigger.svelte +30 -0
  410. package/dist/components/select/select-trigger.svelte.d.ts +26 -0
  411. package/dist/components/select/types.d.ts +61 -0
  412. package/dist/components/select/types.js +1 -0
  413. package/dist/components/sidebar/bond.svelte.d.ts +10 -7
  414. package/dist/components/sidebar/bond.svelte.js +20 -15
  415. package/dist/components/sidebar/sidebar-content.svelte +1 -1
  416. package/dist/components/sidebar/sidebar-root.svelte +50 -41
  417. package/dist/components/sidebar/types.d.ts +10 -15
  418. package/dist/components/slider/index.d.ts +2 -0
  419. package/dist/components/slider/index.js +2 -0
  420. package/dist/components/slider/slider.svelte +164 -0
  421. package/dist/components/slider/slider.svelte.d.ts +6 -0
  422. package/dist/components/slider/types.d.ts +78 -0
  423. package/dist/components/slider/types.js +1 -0
  424. package/dist/components/stack/bond.svelte.d.ts +50 -0
  425. package/dist/components/stack/bond.svelte.js +174 -0
  426. package/dist/components/stack/index.d.ts +2 -0
  427. package/dist/components/stack/index.js +2 -0
  428. package/dist/components/stack/stack-item.svelte +40 -4
  429. package/dist/components/stack/stack-item.svelte.d.ts +6 -5
  430. package/dist/components/stack/stack-root.svelte +33 -4
  431. package/dist/components/stack/stack-root.svelte.d.ts +14 -5
  432. package/dist/components/stack/types.d.ts +11 -10
  433. package/dist/components/stepper/bond.svelte.d.ts +8 -7
  434. package/dist/components/stepper/bond.svelte.js +14 -11
  435. package/dist/components/stepper/step/README.md +97 -97
  436. package/dist/components/stepper/step/bond.svelte.d.ts +74 -63
  437. package/dist/components/stepper/step/bond.svelte.js +105 -69
  438. package/dist/components/stepper/step/step-body.svelte +39 -39
  439. package/dist/components/stepper/step/step-description.svelte +33 -33
  440. package/dist/components/stepper/step/step-header.svelte +34 -34
  441. package/dist/components/stepper/step/step-indicator.svelte +62 -62
  442. package/dist/components/stepper/step/step-root.svelte +42 -42
  443. package/dist/components/stepper/step/step-separator.svelte +48 -48
  444. package/dist/components/stepper/step/step-title.svelte +33 -33
  445. package/dist/components/stepper/step/types.d.ts +13 -57
  446. package/dist/components/stepper/stepper-body.svelte +31 -43
  447. package/dist/components/stepper/stepper-content.svelte +45 -45
  448. package/dist/components/stepper/stepper-footer.svelte +31 -31
  449. package/dist/components/stepper/stepper-header.svelte +27 -39
  450. package/dist/components/stepper/stepper-root.svelte +55 -61
  451. package/dist/components/stepper/types.d.ts +10 -36
  452. package/dist/components/swatch/index.d.ts +1 -0
  453. package/dist/components/swatch/index.js +1 -0
  454. package/dist/components/swatch/swatch.svelte +57 -0
  455. package/dist/components/swatch/swatch.svelte.d.ts +9 -0
  456. package/dist/components/switch/index.d.ts +2 -0
  457. package/dist/components/switch/index.js +2 -0
  458. package/dist/components/switch/switch.svelte +76 -0
  459. package/dist/components/switch/switch.svelte.d.ts +6 -0
  460. package/dist/components/switch/types.d.ts +43 -0
  461. package/dist/components/switch/types.js +1 -0
  462. package/dist/components/tabs/bond.svelte.d.ts +38 -19
  463. package/dist/components/tabs/bond.svelte.js +53 -46
  464. package/dist/components/tabs/tab/attachments.svelte.d.ts +5 -2
  465. package/dist/components/tabs/tab/attachments.svelte.js +4 -3
  466. package/dist/components/tabs/tab/bond.svelte.d.ts +35 -23
  467. package/dist/components/tabs/tab/bond.svelte.js +81 -56
  468. package/dist/components/tabs/tab/tab-body.svelte +61 -43
  469. package/dist/components/tabs/tab/tab-description.svelte +33 -33
  470. package/dist/components/tabs/tab/tab-header.svelte +61 -61
  471. package/dist/components/tabs/tab/tab-root.svelte +49 -50
  472. package/dist/components/tabs/tab/tab-root.svelte.d.ts +13 -35
  473. package/dist/components/tabs/tabs-body.svelte +39 -35
  474. package/dist/components/tabs/tabs-body.svelte.d.ts +1 -1
  475. package/dist/components/tabs/tabs-content.svelte +32 -51
  476. package/dist/components/tabs/tabs-header.svelte +32 -32
  477. package/dist/components/tabs/tabs-root.svelte +56 -56
  478. package/dist/components/tabs/types.d.ts +20 -37
  479. package/dist/components/textarea/types.d.ts +6 -12
  480. package/dist/components/toast/atoms.d.ts +1 -0
  481. package/dist/components/toast/atoms.js +1 -0
  482. package/dist/components/toast/index.d.ts +1 -0
  483. package/dist/components/toast/index.js +1 -0
  484. package/dist/components/toast/manager.svelte.d.ts +38 -0
  485. package/dist/components/toast/manager.svelte.js +82 -0
  486. package/dist/components/toast/toast-description.svelte.d.ts +1 -1
  487. package/dist/components/toast/toast-root-managed.svelte +64 -0
  488. package/dist/components/toast/toast-root-managed.svelte.d.ts +7 -0
  489. package/dist/components/toast/toast-root.svelte.d.ts +1 -1
  490. package/dist/components/toast/toast-title.svelte.d.ts +1 -1
  491. package/dist/components/toast/toast-toaster.svelte +42 -0
  492. package/dist/components/toast/toast-toaster.svelte.d.ts +4 -0
  493. package/dist/components/toast/types.d.ts +22 -31
  494. package/dist/components/tooltip/index.d.ts +1 -0
  495. package/dist/components/tooltip/tooltip-trigger.svelte +39 -39
  496. package/dist/components/tooltip/types.d.ts +5 -8
  497. package/dist/components/tree/bond.svelte.d.ts +28 -19
  498. package/dist/components/tree/bond.svelte.js +62 -53
  499. package/dist/components/tree/tree-body.svelte +1 -1
  500. package/dist/components/tree/tree-header.svelte +1 -1
  501. package/dist/components/tree/tree-header.svelte.d.ts +1 -1
  502. package/dist/components/tree/tree-indicator.svelte +1 -1
  503. package/dist/components/tree/tree-root.svelte +66 -66
  504. package/dist/components/tree/types.d.ts +4 -28
  505. package/dist/components/virtual/index.d.ts +2 -0
  506. package/dist/components/virtual/index.js +2 -0
  507. package/dist/components/virtual/types.d.ts +1 -6
  508. package/dist/constants/motion.d.ts +9 -0
  509. package/dist/constants/motion.js +9 -0
  510. package/dist/context/index.d.ts +1 -1
  511. package/dist/context/preset.svelte.d.ts +169 -2
  512. package/dist/runes/color-scheme.svelte.js +17 -5
  513. package/dist/shared/bond.svelte.d.ts +29 -3
  514. package/dist/shared/bond.svelte.js +126 -4
  515. package/dist/shared/index.d.ts +1 -1
  516. package/dist/shared/index.js +1 -1
  517. package/dist/shared/motion.d.ts +1 -0
  518. package/dist/shared/motion.js +2 -8
  519. package/dist/types/index.d.ts +4 -0
  520. package/dist/utils/index.d.ts +1 -1
  521. package/dist/utils/index.js +1 -1
  522. package/dist/utils/promise.svelte.d.ts +5 -0
  523. package/dist/utils/promise.svelte.js +17 -0
  524. package/dist/utils/variant.d.ts +10 -1
  525. package/dist/utils/variant.js +11 -1
  526. package/package.json +171 -48
  527. package/dist/components/accordion/accordion.stories.svelte +0 -70
  528. package/dist/components/accordion/accordion.stories.svelte.d.ts +0 -18
  529. package/dist/components/alert/alert.stories.svelte +0 -400
  530. package/dist/components/alert/alert.stories.svelte.d.ts +0 -3
  531. package/dist/components/avatar/avatar.stories.svelte +0 -22
  532. package/dist/components/avatar/avatar.stories.svelte.d.ts +0 -26
  533. package/dist/components/badge/badge.stories.svelte +0 -12
  534. package/dist/components/badge/badge.stories.svelte.d.ts +0 -26
  535. package/dist/components/breadcrumb/breadcrumb.stories.svelte +0 -16
  536. package/dist/components/breadcrumb/breadcrumb.stories.svelte.d.ts +0 -26
  537. package/dist/components/button/button.stories.svelte +0 -27
  538. package/dist/components/button/button.stories.svelte.d.ts +0 -18
  539. package/dist/components/calendar/calendar.stories.svelte +0 -26
  540. package/dist/components/calendar/calendar.stories.svelte.d.ts +0 -26
  541. package/dist/components/card/card.stories.svelte +0 -133
  542. package/dist/components/card/card.stories.svelte.d.ts +0 -19
  543. package/dist/components/checkbox/checkbox.stories.svelte +0 -22
  544. package/dist/components/checkbox/checkbox.stories.svelte.d.ts +0 -6
  545. package/dist/components/collapsible/collapsible.stories.svelte +0 -172
  546. package/dist/components/collapsible/collapsible.stories.svelte.d.ts +0 -18
  547. package/dist/components/combobox/combobox.stories.svelte +0 -63
  548. package/dist/components/combobox/combobox.stories.svelte.d.ts +0 -3
  549. package/dist/components/container/container.stories.svelte +0 -20
  550. package/dist/components/container/container.stories.svelte.d.ts +0 -26
  551. package/dist/components/contextmenu/atoms.d.ts +0 -0
  552. package/dist/components/contextmenu/atoms.js +0 -1
  553. package/dist/components/contextmenu/contextmenu-trigger.svelte +0 -0
  554. package/dist/components/contextmenu/contextmenu-trigger.svelte.d.ts +0 -26
  555. package/dist/components/contextmenu/indext.d.ts +0 -0
  556. package/dist/components/contextmenu/indext.js +0 -1
  557. package/dist/components/datagrid/datagrid.stories.svelte +0 -72
  558. package/dist/components/datagrid/datagrid.stories.svelte.d.ts +0 -6
  559. package/dist/components/datagrid/td/bond.svelte.d.ts +0 -28
  560. package/dist/components/datagrid/td/bond.svelte.js +0 -40
  561. package/dist/components/datagrid/td/datagrid-td.svelte +0 -66
  562. package/dist/components/datagrid/td/datagrid-td.svelte.d.ts +0 -30
  563. package/dist/components/datagrid/td/index.d.ts +0 -2
  564. package/dist/components/datagrid/td/index.js +0 -2
  565. package/dist/components/datagrid/th/bond.svelte.d.ts +0 -38
  566. package/dist/components/datagrid/th/bond.svelte.js +0 -66
  567. package/dist/components/datagrid/th/datagrid-th.svelte.d.ts +0 -26
  568. package/dist/components/datagrid/th/index.d.ts +0 -2
  569. package/dist/components/datagrid/th/index.js +0 -2
  570. package/dist/components/datagrid/tr/bond.svelte.d.ts +0 -37
  571. package/dist/components/datagrid/tr/bond.svelte.js +0 -72
  572. package/dist/components/datagrid/tr/datagrid-tr.svelte +0 -90
  573. package/dist/components/datagrid/tr/datagrid-tr.svelte.d.ts +0 -28
  574. package/dist/components/datagrid/tr/index.d.ts +0 -2
  575. package/dist/components/datagrid/tr/index.js +0 -2
  576. package/dist/components/date-picker/date-picker.stories.svelte +0 -35
  577. package/dist/components/date-picker/date-picker.stories.svelte.d.ts +0 -3
  578. package/dist/components/dialog/dialog.stories.svelte +0 -64
  579. package/dist/components/dialog/dialog.stories.svelte.d.ts +0 -3
  580. package/dist/components/drawer/drawer.stories.svelte +0 -141
  581. package/dist/components/drawer/drawer.stories.svelte.d.ts +0 -3
  582. package/dist/components/dropdown/dropdown.stories.svelte +0 -127
  583. package/dist/components/dropdown/dropdown.stories.svelte.d.ts +0 -3
  584. package/dist/components/element/element.stories.svelte +0 -37
  585. package/dist/components/element/element.stories.svelte.d.ts +0 -3
  586. package/dist/components/form/field/field-errors.svelte +0 -9
  587. package/dist/components/form/field/field-errors.svelte.d.ts +0 -11
  588. package/dist/components/form/form.stories.svelte +0 -96
  589. package/dist/components/form/form.stories.svelte.d.ts +0 -18
  590. package/dist/components/image/image.stories.svelte +0 -20
  591. package/dist/components/image/image.stories.svelte.d.ts +0 -26
  592. package/dist/components/input/input.stories.svelte +0 -35
  593. package/dist/components/input/input.stories.svelte.d.ts +0 -18
  594. package/dist/components/label/label.stories.svelte +0 -15
  595. package/dist/components/label/label.stories.svelte.d.ts +0 -26
  596. package/dist/components/lazy/lazy.stories.svelte +0 -28
  597. package/dist/components/lazy/lazy.stories.svelte.d.ts +0 -19
  598. package/dist/components/link/link.stories.svelte +0 -15
  599. package/dist/components/link/link.stories.svelte.d.ts +0 -26
  600. package/dist/components/menu/menu.stories.svelte +0 -33
  601. package/dist/components/menu/menu.stories.svelte.d.ts +0 -3
  602. package/dist/components/popover/popover.stories.svelte +0 -37
  603. package/dist/components/popover/popover.stories.svelte.d.ts +0 -3
  604. package/dist/components/qr-code/qr-code.stories.svelte +0 -18
  605. package/dist/components/qr-code/qr-code.stories.svelte.d.ts +0 -26
  606. package/dist/components/radio/radio-group.stories.svelte +0 -41
  607. package/dist/components/radio/radio-group.stories.svelte.d.ts +0 -6
  608. package/dist/components/radio/radio.stories.svelte +0 -17
  609. package/dist/components/radio/radio.stories.svelte.d.ts +0 -6
  610. package/dist/components/root/l0-portal.svelte +0 -8
  611. package/dist/components/root/l0-portal.svelte.d.ts +0 -26
  612. package/dist/components/root/l1-portal.svelte +0 -7
  613. package/dist/components/root/l1-portal.svelte.d.ts +0 -26
  614. package/dist/components/root/toasts-portal.svelte +0 -7
  615. package/dist/components/root/toasts-portal.svelte.d.ts +0 -26
  616. package/dist/components/scrollable/scrollable.stories.svelte +0 -116
  617. package/dist/components/scrollable/scrollable.stories.svelte.d.ts +0 -26
  618. package/dist/components/sidebar/sidebar.stories.svelte +0 -43
  619. package/dist/components/sidebar/sidebar.stories.svelte.d.ts +0 -3
  620. package/dist/components/stepper/stepper.stories.svelte +0 -264
  621. package/dist/components/stepper/stepper.stories.svelte.d.ts +0 -4
  622. package/dist/components/tabs/tabs.stories.svelte +0 -70
  623. package/dist/components/tabs/tabs.stories.svelte.d.ts +0 -3
  624. package/dist/components/tooltip/tooltip.stories.svelte +0 -32
  625. package/dist/components/tooltip/tooltip.stories.svelte.d.ts +0 -3
  626. package/dist/components/tree/tree.stories.svelte +0 -142
  627. package/dist/components/tree/tree.stories.svelte.d.ts +0 -3
  628. /package/dist/components/{contextmenu → context-menu}/types.js +0 -0
@@ -0,0 +1,29 @@
1
+ /**
2
+ * Pure helpers for time-related input controls.
3
+ * No Svelte reactivity here — import freely from .svelte files and plain .ts.
4
+ */
5
+ export type { SegmentProps, TimeParts, DateTimeParts, LooseParts } from './types';
6
+ import type { TimeParts, DateTimeParts } from './types';
7
+ export declare function mergeParts<T extends object>(base: T, overrides: T): T;
8
+ /** Parse a HH:MM[:SS] string (always 24 h internally) into TimeParts. */
9
+ export declare function parseTimeString(str: string, date?: Date, hourFormat?: 12 | 24): TimeParts;
10
+ /** Build a HH:MM[:SS] string from TimeParts. Returns '' if incomplete. */
11
+ export declare function buildTimeValue(parts: TimeParts, withSeconds: boolean): string;
12
+ /** Convert 1–12 display hours to 0–23 internal, given current period. */
13
+ export declare function displayToInternal(displayH: number, period: 'AM' | 'PM'): number;
14
+ /** Convert 0–23 internal hours to 1–12 display. */
15
+ export declare function internalToDisplay(h: number): number;
16
+ /** Seconds since midnight — used for min/max clamping. */
17
+ export declare function timeToSeconds(h?: number, m?: number, s?: number): number;
18
+ /** Clamp TimeParts to optional min/max strings. Returns clamped parts or original if in range. */
19
+ export declare function clampTimeParts(parts: TimeParts, min?: string, max?: string): TimeParts;
20
+ /** Parse a YYYY-MM-DD string into DateTimeParts (date-only, no time fields). */
21
+ export declare function parseDateString(str: string): DateTimeParts;
22
+ /** Build a YYYY-MM-DD string from DateTimeParts. Returns '' if incomplete. */
23
+ export declare function buildDateValue(parts: DateTimeParts): string;
24
+ /** Parse a YYYY-MM-DDTHH:MM[:SS] string into DateTimeParts. */
25
+ export declare function parseDateTimeString(str: string): DateTimeParts;
26
+ /** Build a YYYY-MM-DDTHH:MM[:SS] string from DateTimeParts. Returns '' if incomplete. */
27
+ export declare function buildDateTimeValue(parts: DateTimeParts, withSeconds: boolean): string;
28
+ /** Max days in a given month/year (falls back to year 2000 if year unknown). */
29
+ export declare function maxDaysInMonth(month?: number, year?: number): number;
@@ -0,0 +1,150 @@
1
+ // ── Merge utility ──────────────────────────────────────────────────────────
2
+ export function mergeParts(base, overrides) {
3
+ const clean = Object.fromEntries(Object.entries(overrides).filter(([, v]) => v !== undefined));
4
+ return { ...base, ...clean };
5
+ }
6
+ // ── Time helpers ───────────────────────────────────────────────────────────
7
+ /** Parse a HH:MM[:SS] string (always 24 h internally) into TimeParts. */
8
+ export function parseTimeString(str, date, hourFormat = 24) {
9
+ if (!str) {
10
+ if (date) {
11
+ const h = date.getHours();
12
+ const result = {
13
+ hh: h,
14
+ mm: date.getMinutes(),
15
+ ss: date.getSeconds()
16
+ };
17
+ if (hourFormat === 12)
18
+ result.period = h >= 12 ? 'PM' : 'AM';
19
+ return result;
20
+ }
21
+ return {};
22
+ }
23
+ const parts = str.split(':');
24
+ const result = {};
25
+ if (parts[0] !== undefined)
26
+ result.hh = parseInt(parts[0], 10);
27
+ if (parts[1] !== undefined)
28
+ result.mm = parseInt(parts[1], 10);
29
+ if (parts[2] !== undefined)
30
+ result.ss = parseInt(parts[2], 10);
31
+ if (hourFormat === 12 && result.hh !== undefined)
32
+ result.period = result.hh >= 12 ? 'PM' : 'AM';
33
+ return result;
34
+ }
35
+ /** Build a HH:MM[:SS] string from TimeParts. Returns '' if incomplete. */
36
+ export function buildTimeValue(parts, withSeconds) {
37
+ const { hh, mm, ss } = parts;
38
+ if (hh === undefined || mm === undefined)
39
+ return '';
40
+ const h = String(hh).padStart(2, '0');
41
+ const m = String(mm).padStart(2, '0');
42
+ if (withSeconds)
43
+ return `${h}:${m}:${String(ss ?? 0).padStart(2, '0')}`;
44
+ return `${h}:${m}`;
45
+ }
46
+ /** Convert 1–12 display hours to 0–23 internal, given current period. */
47
+ export function displayToInternal(displayH, period) {
48
+ if (period === 'AM')
49
+ return displayH === 12 ? 0 : displayH;
50
+ return displayH === 12 ? 12 : displayH + 12;
51
+ }
52
+ /** Convert 0–23 internal hours to 1–12 display. */
53
+ export function internalToDisplay(h) {
54
+ return h % 12 === 0 ? 12 : h % 12;
55
+ }
56
+ /** Seconds since midnight — used for min/max clamping. */
57
+ export function timeToSeconds(h = 0, m = 0, s = 0) {
58
+ return h * 3600 + m * 60 + s;
59
+ }
60
+ /** Clamp TimeParts to optional min/max strings. Returns clamped parts or original if in range. */
61
+ export function clampTimeParts(parts, min, max) {
62
+ const { hh, mm, ss } = parts;
63
+ if (hh === undefined || mm === undefined)
64
+ return parts;
65
+ const secs = timeToSeconds(hh, mm, ss);
66
+ if (min) {
67
+ const mp = parseTimeString(min);
68
+ if (mp.hh !== undefined && secs < timeToSeconds(mp.hh, mp.mm, mp.ss)) {
69
+ const r = { hh: mp.hh };
70
+ if (mp.mm !== undefined)
71
+ r.mm = mp.mm;
72
+ if (mp.ss !== undefined)
73
+ r.ss = mp.ss;
74
+ if (parts.period)
75
+ r.period = parts.period;
76
+ return r;
77
+ }
78
+ }
79
+ if (max) {
80
+ const mp = parseTimeString(max);
81
+ if (mp.hh !== undefined && secs > timeToSeconds(mp.hh, mp.mm, mp.ss)) {
82
+ const r = { hh: mp.hh };
83
+ if (mp.mm !== undefined)
84
+ r.mm = mp.mm;
85
+ if (mp.ss !== undefined)
86
+ r.ss = mp.ss;
87
+ if (parts.period)
88
+ r.period = parts.period;
89
+ return r;
90
+ }
91
+ }
92
+ return parts;
93
+ }
94
+ // ── DateTime helpers ───────────────────────────────────────────────────────
95
+ /** Parse a YYYY-MM-DD string into DateTimeParts (date-only, no time fields). */
96
+ export function parseDateString(str) {
97
+ if (!str)
98
+ return {};
99
+ const m = str.match(/^(\d{4})-(\d{2})-(\d{2})$/);
100
+ if (!m)
101
+ return {};
102
+ return {
103
+ year: parseInt(m[1], 10),
104
+ month: parseInt(m[2], 10),
105
+ day: parseInt(m[3], 10)
106
+ };
107
+ }
108
+ /** Build a YYYY-MM-DD string from DateTimeParts. Returns '' if incomplete. */
109
+ export function buildDateValue(parts) {
110
+ const { year, month, day } = parts;
111
+ if (year === undefined || month === undefined || day === undefined)
112
+ return '';
113
+ const pad = (n, len = 2) => String(n).padStart(len, '0');
114
+ return `${pad(year, 4)}-${pad(month)}-${pad(day)}`;
115
+ }
116
+ /** Parse a YYYY-MM-DDTHH:MM[:SS] string into DateTimeParts. */
117
+ export function parseDateTimeString(str) {
118
+ if (!str)
119
+ return {};
120
+ const m = str.match(/^(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2})(?::(\d{2}))?/);
121
+ if (!m)
122
+ return {};
123
+ return {
124
+ year: parseInt(m[1], 10),
125
+ month: parseInt(m[2], 10),
126
+ day: parseInt(m[3], 10),
127
+ hours: parseInt(m[4], 10),
128
+ minutes: parseInt(m[5], 10),
129
+ ...(m[6] ? { seconds: parseInt(m[6], 10) } : {})
130
+ };
131
+ }
132
+ /** Build a YYYY-MM-DDTHH:MM[:SS] string from DateTimeParts. Returns '' if incomplete. */
133
+ export function buildDateTimeValue(parts, withSeconds) {
134
+ const { year, month, day, hours, minutes, seconds } = parts;
135
+ if (year === undefined ||
136
+ month === undefined ||
137
+ day === undefined ||
138
+ hours === undefined ||
139
+ minutes === undefined)
140
+ return '';
141
+ const pad = (n, len = 2) => String(n).padStart(len, '0');
142
+ const base = `${pad(year, 4)}-${pad(month)}-${pad(day)}T${pad(hours)}:${pad(minutes)}`;
143
+ return withSeconds ? `${base}:${pad(seconds ?? 0)}` : base;
144
+ }
145
+ /** Max days in a given month/year (falls back to year 2000 if year unknown). */
146
+ export function maxDaysInMonth(month, year) {
147
+ if (!month)
148
+ return 31;
149
+ return new Date(year ?? 2000, month, 0).getDate();
150
+ }
@@ -0,0 +1,237 @@
1
+ <script lang="ts">
2
+ import { getPreset } from '../../../context';
3
+ import { cn, toClassValue } from '../../../utils';
4
+ import type { PresetModuleName } from '../../../context/preset.svelte';
5
+ import { untrack } from 'svelte';
6
+ import { InputBond } from '../bond.svelte';
7
+ import type { InputTimeControlProps, InputNumber24HourControlProps, InputNumber12HourControlProps } from '../types';
8
+ import Segment from './segment.svelte';
9
+ import {
10
+ parseTimeString, buildTimeValue, clampTimeParts, mergeParts,
11
+ displayToInternal, internalToDisplay,
12
+ type TimeParts,
13
+ } from './shared';
14
+ import { resolvePreset } from '../../atom';
15
+
16
+ const bond = InputBond.get();
17
+
18
+ let {
19
+ class: klass = '',
20
+ value = $bindable(),
21
+ date = $bindable<Date | undefined>(undefined),
22
+ hourFormat = 24,
23
+ withSeconds = false,
24
+ min = undefined,
25
+ max = undefined,
26
+ disabled = false,
27
+ readonly = false,
28
+ preset: presetKey = 'input.time',
29
+ onchange = undefined,
30
+ oninput = undefined,
31
+ ...restProps
32
+ }: InputTimeControlProps & (InputNumber24HourControlProps | InputNumber12HourControlProps) = $props();
33
+
34
+ const preset = resolvePreset(getPreset(untrack(() => presetKey) as PresetModuleName)?.apply(bond, [bond]));
35
+
36
+ // ── Parsed state ($derived — external value always wins) ──────────────
37
+ const parts = $derived(parseTimeString(value, untrack(() => date ?? undefined), hourFormat));
38
+ const { hh, mm, ss, period: p } = $derived(parts);
39
+
40
+ const displayHours = $derived(
41
+ hh === undefined || hourFormat === 24 ? hh : internalToDisplay(hh)
42
+ );
43
+
44
+ // ── Segment refs ───────────────────────────────────────────────────────
45
+ let segHours = $state<{ focus(): void }>();
46
+ let segMinutes = $state<{ focus(): void }>();
47
+ let segSeconds = $state<{ focus(): void }>();
48
+
49
+ // ── Emit ───────────────────────────────────────────────────────────────
50
+
51
+ function emit(ev: Event | undefined, override: TimeParts = {}) {
52
+ const merged: TimeParts = mergeParts(parts, override);
53
+ const clamped = clampTimeParts(merged, min, max);
54
+ const raw = buildTimeValue(clamped, withSeconds);
55
+ if (!raw) return;
56
+
57
+ // Sync date if bound
58
+ if (date && clamped.hh !== undefined && clamped.mm !== undefined) {
59
+ const nd = new Date(date);
60
+ nd.setHours(clamped.hh, clamped.mm, withSeconds ? (clamped.ss ?? 0) : 0, 0);
61
+ if (nd.getTime() !== date.getTime()) date = nd;
62
+ }
63
+
64
+ if (raw === value) return;
65
+
66
+ value = raw;
67
+ if (bond) bond.state.props.value = value;
68
+
69
+ const detail = { value: raw };
70
+ if (ev) onchange?.(ev, detail);
71
+ else oninput?.(undefined as unknown as Event, detail);
72
+ }
73
+
74
+ // ── Hours: convert display→internal before emitting ───────────────────
75
+ function handleHoursChange(displayH: number | undefined) {
76
+ if (displayH === undefined) { emit(undefined); return; }
77
+ const internal = hourFormat === 12
78
+ ? displayToInternal(displayH, p ?? 'AM')
79
+ : displayH;
80
+ emit(undefined, { hh: internal });
81
+ }
82
+
83
+ // ── Period toggle ──────────────────────────────────────────────────────
84
+ function togglePeriod() {
85
+ if (disabled || readonly || hh === undefined) return;
86
+ const newPeriod = p === 'AM' ? 'PM' : 'AM';
87
+ const newHH = displayToInternal(displayHours ?? 12, newPeriod);
88
+ emit(undefined, { hh: newHH, period: newPeriod });
89
+ }
90
+
91
+ function handlePeriodKey(ev: KeyboardEvent) {
92
+ const { key } = ev;
93
+ if (key.toLowerCase() === 'a') {
94
+ const newHH = displayToInternal(displayHours ?? 12, 'AM');
95
+ emit(undefined, { hh: newHH, period: 'AM' });
96
+ } else if (key.toLowerCase() === 'p') {
97
+ const newHH = displayToInternal(displayHours ?? 12, 'PM');
98
+ emit(undefined, { hh: newHH, period: 'PM' });
99
+ } else if (['ArrowUp', 'ArrowDown', ' ', 'Enter'].includes(key)) {
100
+ ev.preventDefault();
101
+ togglePeriod();
102
+ } else if (key === 'ArrowLeft') {
103
+ ev.preventDefault();
104
+ (withSeconds ? segSeconds : segMinutes)?.focus();
105
+ }
106
+ }
107
+
108
+ // ── Paste ──────────────────────────────────────────────────────────────
109
+ function handlePaste(ev: ClipboardEvent) {
110
+ ev.preventDefault();
111
+ const text = ev.clipboardData?.getData('text') ?? '';
112
+
113
+ const m12 = text.match(/^(\d{1,2}):(\d{2})(?::(\d{2}))?\s*(AM|PM)/i);
114
+ const m24 = text.match(/^(\d{1,2}):(\d{2})(?::(\d{2}))?/);
115
+
116
+ const override: TimeParts = {};
117
+
118
+ if (m12) {
119
+ let h = parseInt(m12[1]!, 10);
120
+ const isPM = m12[4]!.toUpperCase() === 'PM';
121
+ if (isPM && h !== 12) h += 12;
122
+ if (!isPM && h === 12) h = 0;
123
+ override.hh = Math.min(23, h);
124
+ override.mm = Math.min(59, parseInt(m12[2]!, 10));
125
+ if (withSeconds && m12[3]) override.ss = Math.min(59, parseInt(m12[3], 10));
126
+ override.period = isPM ? 'PM' : 'AM';
127
+ } else if (m24) {
128
+ const h = Math.min(23, parseInt(m24[1]!, 10));
129
+ override.hh = h;
130
+ override.mm = Math.min(59, parseInt(m24[2]!, 10));
131
+ if (withSeconds && m24[3]) override.ss = Math.min(59, parseInt(m24[3], 10));
132
+ if (hourFormat === 12) override.period = h >= 12 ? 'PM' : 'AM';
133
+ }
134
+
135
+ emit(ev, override);
136
+ }
137
+ </script>
138
+
139
+ <!-- svelte-ignore a11y_no_static_element_interactions -->
140
+ <span
141
+ class={cn(
142
+ 'inline-flex h-full flex-1 items-center gap-0 px-2 font-mono',
143
+ disabled && 'cursor-not-allowed opacity-50',
144
+ preset?.class,
145
+ toClassValue(klass, bond)
146
+ )}
147
+ onpaste={handlePaste}
148
+ {...restProps}
149
+ >
150
+ <Segment
151
+ bind:this={segHours}
152
+ value={displayHours}
153
+ min={hourFormat === 12 ? 1 : 0}
154
+ max={hourFormat === 12 ? 12 : 23}
155
+ digits={2}
156
+ placeholder="HH"
157
+ {disabled} {readonly}
158
+ onchange={handleHoursChange}
159
+ onfocusmove={(dir) => dir === 1 ? segMinutes?.focus() : undefined}
160
+ />
161
+
162
+ <span class="text-muted-foreground select-none">:</span>
163
+
164
+ <Segment
165
+ bind:this={segMinutes}
166
+ value={mm}
167
+ min={0} max={59} digits={2} placeholder="MM"
168
+ {disabled} {readonly}
169
+ onchange={(v) => { const o: TimeParts = {}; if (v !== undefined) o.mm = v; emit(undefined, o); }}
170
+ onfocusmove={(dir) => {
171
+ if (dir === 1 && withSeconds) segSeconds?.focus();
172
+ else if (dir === 1 && hourFormat === 12) { /* AM/PM next — handled by tab */ }
173
+ else if (dir === -1) segHours?.focus();
174
+ }}
175
+ onrollover={(dir) => {
176
+ if (displayHours === undefined) return;
177
+ const maxH = hourFormat === 12 ? 12 : 23;
178
+ const minH = hourFormat === 12 ? 1 : 0;
179
+ const nextDisplayH = dir === 1
180
+ ? (displayHours >= maxH ? minH : displayHours + 1)
181
+ : (displayHours <= minH ? maxH : displayHours - 1);
182
+ handleHoursChange(nextDisplayH);
183
+ }}
184
+ />
185
+
186
+ {#if withSeconds}
187
+ <span class="text-muted-foreground select-none">:</span>
188
+ <Segment
189
+ bind:this={segSeconds}
190
+ value={ss}
191
+ min={0} max={59} digits={2} placeholder="SS"
192
+ {disabled} {readonly}
193
+ onchange={(v) => { const o: TimeParts = {}; if (v !== undefined) o.ss = v; emit(undefined, o); }}
194
+ onfocusmove={(dir) => dir === -1 ? segMinutes?.focus() : undefined}
195
+ onrollover={(dir) => {
196
+ const nextMM = dir === 1
197
+ ? (mm !== undefined && mm >= 59 ? 0 : (mm ?? 0) + 1)
198
+ : (mm !== undefined && mm <= 0 ? 59 : (mm ?? 59) - 1);
199
+ const wrapsHour = (dir === 1 && nextMM === 0) || (dir === -1 && nextMM === 59);
200
+ const override: TimeParts = { mm: nextMM };
201
+ if (wrapsHour && displayHours !== undefined) {
202
+ const maxH = hourFormat === 12 ? 12 : 23;
203
+ const minH = hourFormat === 12 ? 1 : 0;
204
+ const nextDisplayH = dir === 1
205
+ ? (displayHours >= maxH ? minH : displayHours + 1)
206
+ : (displayHours <= minH ? maxH : displayHours - 1);
207
+ override.hh = hourFormat === 12
208
+ ? displayToInternal(nextDisplayH, p ?? 'AM')
209
+ : nextDisplayH;
210
+ }
211
+ emit(undefined, override);
212
+ }}
213
+ />
214
+ {/if}
215
+
216
+ {#if hourFormat === 12}
217
+ <span class="ml-1 select-none"> </span>
218
+ <span
219
+ role="spinbutton"
220
+ tabindex={disabled ? -1 : 0}
221
+ aria-label="AM/PM"
222
+ aria-valuenow={p === 'AM' ? 0 : 1}
223
+ aria-valuemin={0}
224
+ aria-valuemax={1}
225
+ aria-valuetext={p}
226
+ class={cn(
227
+ 'ml-auto inline-flex min-w-[3ch] cursor-pointer items-center justify-center px-0.5 font-sans text-sm font-medium',
228
+ 'focus:bg-foreground/10 focus:outline-none',
229
+ disabled && 'cursor-not-allowed opacity-50'
230
+ )}
231
+ onclick={togglePeriod}
232
+ onkeydown={handlePeriodKey}
233
+ >
234
+ {p ?? '--'}
235
+ </span>
236
+ {/if}
237
+ </span>
@@ -0,0 +1,3 @@
1
+ declare const TimeControl: import("svelte").Component<any, {}, "value" | "date">;
2
+ type TimeControl = ReturnType<typeof TimeControl>;
3
+ export default TimeControl;
@@ -0,0 +1,34 @@
1
+ /**
2
+ * Types for the input/time sub-module.
3
+ */
4
+ export interface SegmentProps {
5
+ value?: number | undefined;
6
+ min: number;
7
+ max: number;
8
+ digits?: number;
9
+ placeholder?: string;
10
+ disabled?: boolean;
11
+ readonly?: boolean;
12
+ class?: string;
13
+ onchange?: (value: number | undefined) => void;
14
+ onfocusmove?: (dir: -1 | 1) => void;
15
+ /** Fired when ArrowUp/Down wraps past min/max */
16
+ onrollover?: (dir: 1 | -1) => void;
17
+ }
18
+ export interface TimeParts {
19
+ hh?: number;
20
+ mm?: number;
21
+ ss?: number;
22
+ period?: 'AM' | 'PM';
23
+ }
24
+ export interface DateTimeParts {
25
+ year?: number;
26
+ month?: number;
27
+ day?: number;
28
+ hours?: number;
29
+ minutes?: number;
30
+ seconds?: number;
31
+ }
32
+ export type LooseParts<T> = {
33
+ [K in keyof T]: number | undefined;
34
+ };
@@ -0,0 +1,4 @@
1
+ /**
2
+ * Types for the input/time sub-module.
3
+ */
4
+ export {};