sibujs 1.5.0 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (207) hide show
  1. package/dist/browser.cjs +238 -69
  2. package/dist/browser.d.cts +5 -0
  3. package/dist/browser.d.ts +5 -0
  4. package/dist/browser.js +6 -6
  5. package/dist/build.cjs +916 -292
  6. package/dist/build.js +15 -13
  7. package/dist/cdn.global.js +17 -16
  8. package/dist/chunk-2RA7SHDA.js +65 -0
  9. package/dist/chunk-2UPRY23K.js +80 -0
  10. package/dist/chunk-3JHCYHWN.js +125 -0
  11. package/dist/{chunk-VAPYJN4X.js → chunk-3LR7GLWQ.js} +93 -23
  12. package/dist/{chunk-RJ46C3CS.js → chunk-3NSGB5JN.js} +71 -20
  13. package/dist/{chunk-XUEEGU5O.js → chunk-52YJLLRO.js} +16 -4
  14. package/dist/{chunk-XHK6BDAJ.js → chunk-54EDRCEF.js} +25 -8
  15. package/dist/chunk-7JDB7I65.js +1327 -0
  16. package/dist/{chunk-WZSPOOER.js → chunk-CC65Y57T.js} +8 -5
  17. package/dist/{chunk-23VV7YD3.js → chunk-DFPFITST.js} +25 -30
  18. package/dist/{chunk-BGN5ZMP4.js → chunk-GTBNNBJ6.js} +14 -2
  19. package/dist/chunk-HB24TBAF.js +121 -0
  20. package/dist/{chunk-CZUGLNJS.js → chunk-ITX6OO3F.js} +3 -3
  21. package/dist/{chunk-BGTHZHJ5.js → chunk-JA6667UN.js} +188 -44
  22. package/dist/{chunk-7GRNSCFT.js → chunk-JXMMDLBY.js} +306 -183
  23. package/dist/{chunk-3X2YG6YM.js → chunk-JYD2PWXH.js} +59 -28
  24. package/dist/{chunk-SFKNRVCU.js → chunk-KLRMB5ZS.js} +135 -79
  25. package/dist/{chunk-5X6PP2UK.js → chunk-LMLD24FC.js} +2 -2
  26. package/dist/{chunk-M4NLBH4I.js → chunk-LYTCUZ7H.js} +3 -2
  27. package/dist/{chunk-BMPL52BF.js → chunk-MIUAXB7K.js} +118 -66
  28. package/dist/{chunk-JCDUJN2F.js → chunk-ND2664SF.js} +486 -153
  29. package/dist/{chunk-VQDZK23A.js → chunk-O2MNQFLP.js} +181 -66
  30. package/dist/{chunk-NHUC2QWH.js → chunk-R73P76YZ.js} +1 -1
  31. package/dist/{chunk-2BYQDGN3.js → chunk-SAHNHTFC.js} +234 -63
  32. package/dist/chunk-UCS6AMJ7.js +79 -0
  33. package/dist/{chunk-K4G4ZQNR.js → chunk-VLPPXTYG.js} +84 -38
  34. package/dist/{chunk-OUZZEE4S.js → chunk-WOMYAHHI.js} +17 -11
  35. package/dist/{customElement-BL3Uo8dL.d.cts → customElement-CPfIrbvg.d.cts} +14 -10
  36. package/dist/{customElement-BL3Uo8dL.d.ts → customElement-CPfIrbvg.d.ts} +14 -10
  37. package/dist/data.cjs +410 -99
  38. package/dist/data.d.cts +20 -2
  39. package/dist/data.d.ts +20 -2
  40. package/dist/data.js +11 -9
  41. package/dist/devtools.cjs +513 -223
  42. package/dist/devtools.d.cts +1 -1
  43. package/dist/devtools.d.ts +1 -1
  44. package/dist/devtools.js +12 -6
  45. package/dist/ecosystem.cjs +475 -144
  46. package/dist/ecosystem.d.cts +9 -7
  47. package/dist/ecosystem.d.ts +9 -7
  48. package/dist/ecosystem.js +12 -11
  49. package/dist/extras.cjs +3355 -1541
  50. package/dist/extras.d.cts +9 -9
  51. package/dist/extras.d.ts +9 -9
  52. package/dist/extras.js +58 -45
  53. package/dist/index.cjs +920 -292
  54. package/dist/index.d.cts +71 -8
  55. package/dist/index.d.ts +71 -8
  56. package/dist/index.js +28 -16
  57. package/dist/{introspect-BumjnBKr.d.cts → introspect-BWNjNw64.d.cts} +22 -2
  58. package/dist/{introspect-CZrlcaYy.d.ts → introspect-cY2pg9pW.d.ts} +22 -2
  59. package/dist/motion.cjs +77 -34
  60. package/dist/motion.js +4 -4
  61. package/dist/patterns.cjs +335 -69
  62. package/dist/patterns.d.cts +11 -12
  63. package/dist/patterns.d.ts +11 -12
  64. package/dist/patterns.js +7 -7
  65. package/dist/performance.cjs +279 -108
  66. package/dist/performance.d.cts +23 -16
  67. package/dist/performance.d.ts +23 -16
  68. package/dist/performance.js +13 -8
  69. package/dist/plugin-D30wlGW5.d.cts +71 -0
  70. package/dist/plugin-D30wlGW5.d.ts +71 -0
  71. package/dist/plugins.cjs +635 -260
  72. package/dist/plugins.d.cts +10 -3
  73. package/dist/plugins.d.ts +10 -3
  74. package/dist/plugins.js +106 -38
  75. package/dist/{ssr-Do_SiVoL.d.cts → ssr-CrVNy6Pa.d.cts} +9 -15
  76. package/dist/{ssr-Do_SiVoL.d.ts → ssr-CrVNy6Pa.d.ts} +9 -15
  77. package/dist/{ssr-4PBXAOO3.js → ssr-FXD2PPMC.js} +4 -3
  78. package/dist/ssr.cjs +642 -222
  79. package/dist/ssr.d.cts +26 -6
  80. package/dist/ssr.d.ts +26 -6
  81. package/dist/ssr.js +12 -11
  82. package/dist/{tagFactory-DaJ0YWX6.d.cts → tagFactory-S17H2qxu.d.cts} +9 -1
  83. package/dist/{tagFactory-DaJ0YWX6.d.ts → tagFactory-S17H2qxu.d.ts} +9 -1
  84. package/dist/testing.cjs +252 -63
  85. package/dist/testing.d.cts +17 -4
  86. package/dist/testing.d.ts +17 -4
  87. package/dist/testing.js +100 -44
  88. package/dist/ui.cjs +463 -137
  89. package/dist/ui.d.cts +1 -1
  90. package/dist/ui.d.ts +1 -1
  91. package/dist/ui.js +20 -17
  92. package/dist/widgets.cjs +977 -94
  93. package/dist/widgets.d.cts +104 -2
  94. package/dist/widgets.d.ts +104 -2
  95. package/dist/widgets.js +9 -7
  96. package/package.json +8 -2
  97. package/dist/chunk-32DY64NT.js +0 -282
  98. package/dist/chunk-3AIRKM3B.js +0 -1263
  99. package/dist/chunk-3ARAQO7B.js +0 -398
  100. package/dist/chunk-3CRQALYP.js +0 -877
  101. package/dist/chunk-4EI4AG32.js +0 -482
  102. package/dist/chunk-4MYMUBRS.js +0 -21
  103. package/dist/chunk-5ZYQ6KDD.js +0 -154
  104. package/dist/chunk-6BMPXPUW.js +0 -26
  105. package/dist/chunk-6HLLIF3K.js +0 -398
  106. package/dist/chunk-6LSNVCS2.js +0 -937
  107. package/dist/chunk-6SA3QQES.js +0 -61
  108. package/dist/chunk-77L6NL3X.js +0 -1097
  109. package/dist/chunk-7BF6TK55.js +0 -1097
  110. package/dist/chunk-7TQKR4PP.js +0 -294
  111. package/dist/chunk-7V26P53V.js +0 -712
  112. package/dist/chunk-AZ3ISID5.js +0 -298
  113. package/dist/chunk-B7SWRFUT.js +0 -332
  114. package/dist/chunk-BTU3TJDS.js +0 -365
  115. package/dist/chunk-BW3WT46K.js +0 -937
  116. package/dist/chunk-C6KFWOFV.js +0 -616
  117. package/dist/chunk-CHF5OHIA.js +0 -61
  118. package/dist/chunk-CHJ27IGK.js +0 -26
  119. package/dist/chunk-CMBFNA7L.js +0 -27
  120. package/dist/chunk-DAHRH4ON.js +0 -331
  121. package/dist/chunk-DKOHBI74.js +0 -924
  122. package/dist/chunk-DTCOOBMX.js +0 -725
  123. package/dist/chunk-EBGIRKQY.js +0 -616
  124. package/dist/chunk-EUZND3CB.js +0 -27
  125. package/dist/chunk-EVCZO745.js +0 -365
  126. package/dist/chunk-EWFVA3TJ.js +0 -282
  127. package/dist/chunk-F3FA4F32.js +0 -292
  128. package/dist/chunk-FGOEVHY3.js +0 -60
  129. package/dist/chunk-G3BOQPVO.js +0 -365
  130. package/dist/chunk-GCOK2LC3.js +0 -282
  131. package/dist/chunk-GJPXRJ45.js +0 -37
  132. package/dist/chunk-HGMJFBC7.js +0 -654
  133. package/dist/chunk-JAKHTMQU.js +0 -1000
  134. package/dist/chunk-JCI5M6U6.js +0 -956
  135. package/dist/chunk-K5ZUMYVS.js +0 -89
  136. package/dist/chunk-KQPDEVVS.js +0 -398
  137. package/dist/chunk-L6JRBDNS.js +0 -60
  138. package/dist/chunk-LA6KQEDU.js +0 -712
  139. package/dist/chunk-MB6QFH3I.js +0 -2776
  140. package/dist/chunk-MDVXJWFN.js +0 -304
  141. package/dist/chunk-MEZVEBPN.js +0 -2008
  142. package/dist/chunk-MK4ERFYL.js +0 -2249
  143. package/dist/chunk-MLKGABMK.js +0 -9
  144. package/dist/chunk-MQ5GOYPH.js +0 -2249
  145. package/dist/chunk-MYRV7VDM.js +0 -742
  146. package/dist/chunk-N6IZB6KJ.js +0 -567
  147. package/dist/chunk-NEKUBFPT.js +0 -60
  148. package/dist/chunk-NMRUZALC.js +0 -1097
  149. package/dist/chunk-NYVAC6P5.js +0 -37
  150. package/dist/chunk-NZIIMDWI.js +0 -84
  151. package/dist/chunk-OF7UZIVB.js +0 -725
  152. package/dist/chunk-P3XWXJZU.js +0 -282
  153. package/dist/chunk-P6W3STU4.js +0 -2249
  154. package/dist/chunk-PBHF5WKN.js +0 -616
  155. package/dist/chunk-PDZQY43A.js +0 -616
  156. package/dist/chunk-PTQJDMRT.js +0 -146
  157. package/dist/chunk-PZEGYCF5.js +0 -61
  158. package/dist/chunk-QBMDLBU2.js +0 -975
  159. package/dist/chunk-QWZG56ET.js +0 -2744
  160. package/dist/chunk-RQGQSLQK.js +0 -725
  161. package/dist/chunk-SDLZDHKP.js +0 -107
  162. package/dist/chunk-TDGZL5CU.js +0 -365
  163. package/dist/chunk-TNQWPPE6.js +0 -37
  164. package/dist/chunk-TSOKIX5Z.js +0 -654
  165. package/dist/chunk-UHNL42EF.js +0 -2730
  166. package/dist/chunk-UNXCEF6S.js +0 -21
  167. package/dist/chunk-V2XTI523.js +0 -347
  168. package/dist/chunk-VAU366PN.js +0 -2241
  169. package/dist/chunk-VMVDTCXB.js +0 -712
  170. package/dist/chunk-VQNQZCWJ.js +0 -61
  171. package/dist/chunk-VRW3FULF.js +0 -725
  172. package/dist/chunk-WADYRCO2.js +0 -304
  173. package/dist/chunk-WILQZRO4.js +0 -282
  174. package/dist/chunk-WR5D4EGH.js +0 -26
  175. package/dist/chunk-WUHJISPP.js +0 -298
  176. package/dist/chunk-XYU6TZOW.js +0 -182
  177. package/dist/chunk-Y6GP4QGG.js +0 -276
  178. package/dist/chunk-YECR7UIA.js +0 -347
  179. package/dist/chunk-YUTWTI4B.js +0 -654
  180. package/dist/chunk-Z65KYU7I.js +0 -26
  181. package/dist/chunk-Z6POF5YC.js +0 -975
  182. package/dist/chunk-ZBJP6WFL.js +0 -482
  183. package/dist/chunk-ZD6OAMTH.js +0 -277
  184. package/dist/chunk-ZWKZCBO6.js +0 -317
  185. package/dist/contracts-DDrwxvJ-.d.cts +0 -245
  186. package/dist/contracts-DDrwxvJ-.d.ts +0 -245
  187. package/dist/contracts-DOrhwbke.d.cts +0 -245
  188. package/dist/contracts-DOrhwbke.d.ts +0 -245
  189. package/dist/contracts-xo5ckdRP.d.cts +0 -240
  190. package/dist/contracts-xo5ckdRP.d.ts +0 -240
  191. package/dist/customElement-BKQfbSZQ.d.cts +0 -262
  192. package/dist/customElement-BKQfbSZQ.d.ts +0 -262
  193. package/dist/customElement-D2DJp_xn.d.cts +0 -313
  194. package/dist/customElement-D2DJp_xn.d.ts +0 -313
  195. package/dist/customElement-yz8uyk-0.d.cts +0 -308
  196. package/dist/customElement-yz8uyk-0.d.ts +0 -308
  197. package/dist/introspect-Cb0zgpi2.d.cts +0 -477
  198. package/dist/introspect-Y2xNXGSf.d.ts +0 -477
  199. package/dist/plugin-Bek4RhJY.d.cts +0 -43
  200. package/dist/plugin-Bek4RhJY.d.ts +0 -43
  201. package/dist/ssr-3RXHP5ES.js +0 -38
  202. package/dist/ssr-6GIMY5MX.js +0 -38
  203. package/dist/ssr-BA6sxxUd.d.cts +0 -135
  204. package/dist/ssr-BA6sxxUd.d.ts +0 -135
  205. package/dist/ssr-WKUPVSSK.js +0 -36
  206. package/dist/tagFactory-Dl8QCLga.d.cts +0 -23
  207. package/dist/tagFactory-Dl8QCLga.d.ts +0 -23
@@ -1,262 +0,0 @@
1
- type ValidatorFn<T = unknown> = (value: T) => string | null;
2
- interface FieldConfig<T = unknown> {
3
- initial: T;
4
- validators?: ValidatorFn<T>[];
5
- }
6
- type FormConfig<T extends Record<string, unknown>> = {
7
- [K in keyof T]: FieldConfig<T[K]>;
8
- };
9
- interface FormField<T = unknown> {
10
- value: () => T;
11
- set: (v: T) => void;
12
- error: () => string | null;
13
- touched: () => boolean;
14
- touch: () => void;
15
- reset: () => void;
16
- }
17
- interface FormReturn<T extends Record<string, unknown>> {
18
- fields: {
19
- [K in keyof T]: FormField<T[K]>;
20
- };
21
- errors: () => Partial<Record<keyof T, string | null>>;
22
- isValid: () => boolean;
23
- isDirty: () => boolean;
24
- touched: () => Partial<Record<keyof T, boolean>>;
25
- values: () => T;
26
- handleSubmit: (onSubmit: (values: T) => void | Promise<void>) => (e?: Event) => void;
27
- reset: () => void;
28
- setError: (field: keyof T, message: string) => void;
29
- }
30
- declare function required(message?: string): ValidatorFn<unknown>;
31
- declare function minLength(min: number, message?: string): ValidatorFn<string>;
32
- declare function maxLength(max: number, message?: string): ValidatorFn<string>;
33
- declare function matchesPattern(regex: RegExp, message?: string): ValidatorFn<string>;
34
- declare function email(message?: string): ValidatorFn<string>;
35
- declare function min(minVal: number, message?: string): ValidatorFn<number>;
36
- declare function max(maxVal: number, message?: string): ValidatorFn<number>;
37
- declare function custom<T>(fn: (value: T) => boolean, message: string): ValidatorFn<T>;
38
- declare function form<T extends Record<string, unknown>>(config: FormConfig<T>): FormReturn<T>;
39
-
40
- interface VirtualListProps<T> {
41
- items: () => T[];
42
- itemHeight: number;
43
- containerHeight: number;
44
- overscan?: number;
45
- renderItem: (item: T, index: number) => HTMLElement;
46
- class?: string;
47
- }
48
- /**
49
- * VirtualList renders only visible items for efficient large-list rendering.
50
- */
51
- declare function VirtualList<T>(props: VirtualListProps<T>): HTMLElement;
52
-
53
- interface IntersectionResult {
54
- isIntersecting: () => boolean;
55
- intersectionRatio: () => number;
56
- observe: (element: HTMLElement) => void;
57
- unobserve: () => void;
58
- }
59
- /**
60
- * intersection provides reactive intersection observer state.
61
- */
62
- declare function intersection(options?: IntersectionObserverInit): IntersectionResult;
63
- /**
64
- * Lazy-load utility using IntersectionObserver.
65
- * Calls the loader function when element becomes visible.
66
- */
67
- declare function lazyLoad(element: HTMLElement, loader: () => void, options?: IntersectionObserverInit): () => void;
68
-
69
- interface MaskOptions {
70
- /** Pattern: 9 = digit, A = letter, * = any, other chars are literals */
71
- pattern: string;
72
- /** Placeholder character for unfilled positions */
73
- placeholder?: string;
74
- }
75
- /**
76
- * inputMask applies a mask to an input element.
77
- * Returns reactive value and ref binding.
78
- */
79
- declare function inputMask(options: MaskOptions): {
80
- value: () => string;
81
- rawValue: () => string;
82
- bind: (input: HTMLInputElement) => void;
83
- };
84
- /** Phone number mask: (999) 999-9999 */
85
- declare function phoneMask(): MaskOptions;
86
- /** Date mask: 99/99/9999 */
87
- declare function dateMask(): MaskOptions;
88
- /** Credit card mask: 9999 9999 9999 9999 */
89
- declare function creditCardMask(): MaskOptions;
90
- /** Time mask: 99:99 */
91
- declare function timeMask(): MaskOptions;
92
- /** SSN mask: 999-99-9999 */
93
- declare function ssnMask(): MaskOptions;
94
- /** ZIP code mask: 99999 */
95
- declare function zipMask(): MaskOptions;
96
-
97
- /**
98
- * aria applies reactive ARIA attributes to an element.
99
- */
100
- declare function aria(element: HTMLElement, attrs: Record<string, string | boolean | (() => string | boolean)>): void;
101
- /**
102
- * focus manages focus state for an element.
103
- */
104
- declare function focus(): {
105
- isFocused: () => boolean;
106
- focus: () => void;
107
- blur: () => void;
108
- bind: (element: HTMLElement) => void;
109
- };
110
- /**
111
- * FocusTrap traps focus within a container element.
112
- * Tab cycling stays inside the container.
113
- */
114
- declare function FocusTrap(nodes: HTMLElement, options?: {
115
- autoFocus?: boolean;
116
- restoreFocus?: boolean;
117
- }): HTMLElement;
118
- /**
119
- * hotkey registers a keyboard shortcut handler.
120
- * Returns a cleanup function.
121
- */
122
- declare function hotkey(key: string, handler: (e: KeyboardEvent) => void, options?: {
123
- ctrl?: boolean;
124
- shift?: boolean;
125
- alt?: boolean;
126
- meta?: boolean;
127
- global?: boolean;
128
- }): () => void;
129
- /**
130
- * announce creates a screen reader announcement using ARIA live regions.
131
- */
132
- declare function announce(message: string, priority?: "polite" | "assertive"): void;
133
-
134
- /**
135
- * scopedStyle creates component-scoped CSS by generating a unique scope ID
136
- * and prefixing all selectors.
137
- * Returns the scope attribute name and injects the CSS into the document.
138
- */
139
- declare function scopedStyle(css: string): {
140
- scope: string;
141
- attr: string;
142
- };
143
- /**
144
- * withScopedStyle wraps a component function to auto-apply scoped styles.
145
- * The component and all its children get the scope attribute.
146
- */
147
- declare function withScopedStyle<P>(css: string, component: (props: P) => HTMLElement): (props: P) => HTMLElement;
148
- /**
149
- * Removes a scoped style by its scope ID.
150
- */
151
- declare function removeScopedStyle(scopeId: string): void;
152
-
153
- /**
154
- * Bind multiple reactive attributes to an element.
155
- * Each attribute value can be a static value or a reactive getter.
156
- * Returns a single teardown function that stops all bindings.
157
- */
158
- declare function bindAttrs(el: HTMLElement, attrs: Record<string, string | number | boolean | (() => string | number | boolean)>): () => void;
159
- /**
160
- * Reactively toggle a boolean attribute (like disabled, readonly, hidden).
161
- * When the value is truthy the attribute is present (set to ""),
162
- * when falsy the attribute is removed entirely.
163
- * Returns a teardown function to stop reactive tracking.
164
- */
165
- declare function bindBoolAttr(el: HTMLElement, attr: string, getter: boolean | (() => boolean)): () => void;
166
- /**
167
- * Bind a data-* attribute reactively.
168
- * Shorthand for `bindAttribute(el, "data-<key>", getter)`.
169
- * Returns a teardown function to stop reactive tracking.
170
- */
171
- declare function bindData(el: HTMLElement, key: string, getter: string | (() => string)): () => void;
172
-
173
- /**
174
- * dialog provides reactive dialog state management with escape-to-close support.
175
- */
176
- declare function dialog(): {
177
- open: () => void;
178
- close: () => void;
179
- isOpen: () => boolean;
180
- toggle: () => void;
181
- };
182
-
183
- /**
184
- * Toast notification system with auto-dismiss and max toast limits.
185
- */
186
- interface Toast {
187
- id: string;
188
- message: string;
189
- type?: "info" | "success" | "error" | "warning";
190
- }
191
- declare function toast(options?: {
192
- duration?: number;
193
- maxToasts?: number;
194
- }): {
195
- toasts: () => Toast[];
196
- show: (message: string, type?: Toast["type"]) => string;
197
- dismiss: (id: string) => void;
198
- dismissAll: () => void;
199
- };
200
-
201
- /**
202
- * infiniteScroll combines IntersectionObserver with a data-fetching trigger
203
- * to implement infinite scroll behavior.
204
- */
205
- declare function infiniteScroll(options: {
206
- onLoadMore: () => Promise<void>;
207
- hasMore: () => boolean;
208
- threshold?: number;
209
- }): {
210
- sentinelRef: {
211
- current: HTMLElement | null;
212
- };
213
- loading: () => boolean;
214
- dispose: () => void;
215
- };
216
-
217
- /**
218
- * pagination provides reactive pagination state and controls.
219
- */
220
- declare function pagination(options: {
221
- totalItems: () => number;
222
- pageSize?: number;
223
- initialPage?: number;
224
- }): {
225
- page: () => number;
226
- pageSize: () => number;
227
- totalPages: () => number;
228
- next: () => void;
229
- prev: () => void;
230
- goTo: (page: number) => void;
231
- startIndex: () => number;
232
- endIndex: () => number;
233
- };
234
-
235
- /**
236
- * eventBus creates a typed publish/subscribe event system.
237
- * No reactive state needed -- pure event dispatching.
238
- */
239
- declare function eventBus<T extends Record<string, unknown>>(): {
240
- on: <K extends keyof T>(event: K, handler: (data: T[K]) => void) => () => void;
241
- emit: <K extends keyof T>(event: K, data: T[K]) => void;
242
- off: <K extends keyof T>(event: K, handler: (data: T[K]) => void) => void;
243
- clear: () => void;
244
- };
245
-
246
- interface CustomElementOptions {
247
- shadow?: boolean;
248
- mode?: "open" | "closed";
249
- styles?: string;
250
- observedAttributes?: string[];
251
- extends?: string;
252
- }
253
- /**
254
- * defineElement creates a Web Component wrapping a SibuJS component function.
255
- */
256
- declare function defineElement(name: string, component: (props: Record<string, unknown>, element: HTMLElement) => HTMLElement, options?: CustomElementOptions): void;
257
- /**
258
- * Creates an SVG element with proper namespace.
259
- */
260
- declare function svgElement(tag: string, props?: Record<string, unknown>, ...nodes: (SVGElement | string)[]): SVGElement;
261
-
262
- export { max as A, maxLength as B, type CustomElementOptions as C, min as D, minLength as E, type FieldConfig as F, pagination as G, phoneMask as H, type IntersectionResult as I, removeScopedStyle as J, required as K, scopedStyle as L, type MaskOptions as M, ssnMask as N, svgElement as O, timeMask as P, toast as Q, withScopedStyle as R, zipMask as S, type Toast as T, type ValidatorFn as V, FocusTrap as a, type FormConfig as b, type FormField as c, type FormReturn as d, VirtualList as e, type VirtualListProps as f, announce as g, aria as h, bindAttrs as i, bindBoolAttr as j, bindData as k, creditCardMask as l, custom as m, dateMask as n, defineElement as o, dialog as p, email as q, eventBus as r, focus as s, form as t, hotkey as u, infiniteScroll as v, inputMask as w, intersection as x, lazyLoad as y, matchesPattern as z };
@@ -1,262 +0,0 @@
1
- type ValidatorFn<T = unknown> = (value: T) => string | null;
2
- interface FieldConfig<T = unknown> {
3
- initial: T;
4
- validators?: ValidatorFn<T>[];
5
- }
6
- type FormConfig<T extends Record<string, unknown>> = {
7
- [K in keyof T]: FieldConfig<T[K]>;
8
- };
9
- interface FormField<T = unknown> {
10
- value: () => T;
11
- set: (v: T) => void;
12
- error: () => string | null;
13
- touched: () => boolean;
14
- touch: () => void;
15
- reset: () => void;
16
- }
17
- interface FormReturn<T extends Record<string, unknown>> {
18
- fields: {
19
- [K in keyof T]: FormField<T[K]>;
20
- };
21
- errors: () => Partial<Record<keyof T, string | null>>;
22
- isValid: () => boolean;
23
- isDirty: () => boolean;
24
- touched: () => Partial<Record<keyof T, boolean>>;
25
- values: () => T;
26
- handleSubmit: (onSubmit: (values: T) => void | Promise<void>) => (e?: Event) => void;
27
- reset: () => void;
28
- setError: (field: keyof T, message: string) => void;
29
- }
30
- declare function required(message?: string): ValidatorFn<unknown>;
31
- declare function minLength(min: number, message?: string): ValidatorFn<string>;
32
- declare function maxLength(max: number, message?: string): ValidatorFn<string>;
33
- declare function matchesPattern(regex: RegExp, message?: string): ValidatorFn<string>;
34
- declare function email(message?: string): ValidatorFn<string>;
35
- declare function min(minVal: number, message?: string): ValidatorFn<number>;
36
- declare function max(maxVal: number, message?: string): ValidatorFn<number>;
37
- declare function custom<T>(fn: (value: T) => boolean, message: string): ValidatorFn<T>;
38
- declare function form<T extends Record<string, unknown>>(config: FormConfig<T>): FormReturn<T>;
39
-
40
- interface VirtualListProps<T> {
41
- items: () => T[];
42
- itemHeight: number;
43
- containerHeight: number;
44
- overscan?: number;
45
- renderItem: (item: T, index: number) => HTMLElement;
46
- class?: string;
47
- }
48
- /**
49
- * VirtualList renders only visible items for efficient large-list rendering.
50
- */
51
- declare function VirtualList<T>(props: VirtualListProps<T>): HTMLElement;
52
-
53
- interface IntersectionResult {
54
- isIntersecting: () => boolean;
55
- intersectionRatio: () => number;
56
- observe: (element: HTMLElement) => void;
57
- unobserve: () => void;
58
- }
59
- /**
60
- * intersection provides reactive intersection observer state.
61
- */
62
- declare function intersection(options?: IntersectionObserverInit): IntersectionResult;
63
- /**
64
- * Lazy-load utility using IntersectionObserver.
65
- * Calls the loader function when element becomes visible.
66
- */
67
- declare function lazyLoad(element: HTMLElement, loader: () => void, options?: IntersectionObserverInit): () => void;
68
-
69
- interface MaskOptions {
70
- /** Pattern: 9 = digit, A = letter, * = any, other chars are literals */
71
- pattern: string;
72
- /** Placeholder character for unfilled positions */
73
- placeholder?: string;
74
- }
75
- /**
76
- * inputMask applies a mask to an input element.
77
- * Returns reactive value and ref binding.
78
- */
79
- declare function inputMask(options: MaskOptions): {
80
- value: () => string;
81
- rawValue: () => string;
82
- bind: (input: HTMLInputElement) => void;
83
- };
84
- /** Phone number mask: (999) 999-9999 */
85
- declare function phoneMask(): MaskOptions;
86
- /** Date mask: 99/99/9999 */
87
- declare function dateMask(): MaskOptions;
88
- /** Credit card mask: 9999 9999 9999 9999 */
89
- declare function creditCardMask(): MaskOptions;
90
- /** Time mask: 99:99 */
91
- declare function timeMask(): MaskOptions;
92
- /** SSN mask: 999-99-9999 */
93
- declare function ssnMask(): MaskOptions;
94
- /** ZIP code mask: 99999 */
95
- declare function zipMask(): MaskOptions;
96
-
97
- /**
98
- * aria applies reactive ARIA attributes to an element.
99
- */
100
- declare function aria(element: HTMLElement, attrs: Record<string, string | boolean | (() => string | boolean)>): void;
101
- /**
102
- * focus manages focus state for an element.
103
- */
104
- declare function focus(): {
105
- isFocused: () => boolean;
106
- focus: () => void;
107
- blur: () => void;
108
- bind: (element: HTMLElement) => void;
109
- };
110
- /**
111
- * FocusTrap traps focus within a container element.
112
- * Tab cycling stays inside the container.
113
- */
114
- declare function FocusTrap(nodes: HTMLElement, options?: {
115
- autoFocus?: boolean;
116
- restoreFocus?: boolean;
117
- }): HTMLElement;
118
- /**
119
- * hotkey registers a keyboard shortcut handler.
120
- * Returns a cleanup function.
121
- */
122
- declare function hotkey(key: string, handler: (e: KeyboardEvent) => void, options?: {
123
- ctrl?: boolean;
124
- shift?: boolean;
125
- alt?: boolean;
126
- meta?: boolean;
127
- global?: boolean;
128
- }): () => void;
129
- /**
130
- * announce creates a screen reader announcement using ARIA live regions.
131
- */
132
- declare function announce(message: string, priority?: "polite" | "assertive"): void;
133
-
134
- /**
135
- * scopedStyle creates component-scoped CSS by generating a unique scope ID
136
- * and prefixing all selectors.
137
- * Returns the scope attribute name and injects the CSS into the document.
138
- */
139
- declare function scopedStyle(css: string): {
140
- scope: string;
141
- attr: string;
142
- };
143
- /**
144
- * withScopedStyle wraps a component function to auto-apply scoped styles.
145
- * The component and all its children get the scope attribute.
146
- */
147
- declare function withScopedStyle<P>(css: string, component: (props: P) => HTMLElement): (props: P) => HTMLElement;
148
- /**
149
- * Removes a scoped style by its scope ID.
150
- */
151
- declare function removeScopedStyle(scopeId: string): void;
152
-
153
- /**
154
- * Bind multiple reactive attributes to an element.
155
- * Each attribute value can be a static value or a reactive getter.
156
- * Returns a single teardown function that stops all bindings.
157
- */
158
- declare function bindAttrs(el: HTMLElement, attrs: Record<string, string | number | boolean | (() => string | number | boolean)>): () => void;
159
- /**
160
- * Reactively toggle a boolean attribute (like disabled, readonly, hidden).
161
- * When the value is truthy the attribute is present (set to ""),
162
- * when falsy the attribute is removed entirely.
163
- * Returns a teardown function to stop reactive tracking.
164
- */
165
- declare function bindBoolAttr(el: HTMLElement, attr: string, getter: boolean | (() => boolean)): () => void;
166
- /**
167
- * Bind a data-* attribute reactively.
168
- * Shorthand for `bindAttribute(el, "data-<key>", getter)`.
169
- * Returns a teardown function to stop reactive tracking.
170
- */
171
- declare function bindData(el: HTMLElement, key: string, getter: string | (() => string)): () => void;
172
-
173
- /**
174
- * dialog provides reactive dialog state management with escape-to-close support.
175
- */
176
- declare function dialog(): {
177
- open: () => void;
178
- close: () => void;
179
- isOpen: () => boolean;
180
- toggle: () => void;
181
- };
182
-
183
- /**
184
- * Toast notification system with auto-dismiss and max toast limits.
185
- */
186
- interface Toast {
187
- id: string;
188
- message: string;
189
- type?: "info" | "success" | "error" | "warning";
190
- }
191
- declare function toast(options?: {
192
- duration?: number;
193
- maxToasts?: number;
194
- }): {
195
- toasts: () => Toast[];
196
- show: (message: string, type?: Toast["type"]) => string;
197
- dismiss: (id: string) => void;
198
- dismissAll: () => void;
199
- };
200
-
201
- /**
202
- * infiniteScroll combines IntersectionObserver with a data-fetching trigger
203
- * to implement infinite scroll behavior.
204
- */
205
- declare function infiniteScroll(options: {
206
- onLoadMore: () => Promise<void>;
207
- hasMore: () => boolean;
208
- threshold?: number;
209
- }): {
210
- sentinelRef: {
211
- current: HTMLElement | null;
212
- };
213
- loading: () => boolean;
214
- dispose: () => void;
215
- };
216
-
217
- /**
218
- * pagination provides reactive pagination state and controls.
219
- */
220
- declare function pagination(options: {
221
- totalItems: () => number;
222
- pageSize?: number;
223
- initialPage?: number;
224
- }): {
225
- page: () => number;
226
- pageSize: () => number;
227
- totalPages: () => number;
228
- next: () => void;
229
- prev: () => void;
230
- goTo: (page: number) => void;
231
- startIndex: () => number;
232
- endIndex: () => number;
233
- };
234
-
235
- /**
236
- * eventBus creates a typed publish/subscribe event system.
237
- * No reactive state needed -- pure event dispatching.
238
- */
239
- declare function eventBus<T extends Record<string, unknown>>(): {
240
- on: <K extends keyof T>(event: K, handler: (data: T[K]) => void) => () => void;
241
- emit: <K extends keyof T>(event: K, data: T[K]) => void;
242
- off: <K extends keyof T>(event: K, handler: (data: T[K]) => void) => void;
243
- clear: () => void;
244
- };
245
-
246
- interface CustomElementOptions {
247
- shadow?: boolean;
248
- mode?: "open" | "closed";
249
- styles?: string;
250
- observedAttributes?: string[];
251
- extends?: string;
252
- }
253
- /**
254
- * defineElement creates a Web Component wrapping a SibuJS component function.
255
- */
256
- declare function defineElement(name: string, component: (props: Record<string, unknown>, element: HTMLElement) => HTMLElement, options?: CustomElementOptions): void;
257
- /**
258
- * Creates an SVG element with proper namespace.
259
- */
260
- declare function svgElement(tag: string, props?: Record<string, unknown>, ...nodes: (SVGElement | string)[]): SVGElement;
261
-
262
- export { max as A, maxLength as B, type CustomElementOptions as C, min as D, minLength as E, type FieldConfig as F, pagination as G, phoneMask as H, type IntersectionResult as I, removeScopedStyle as J, required as K, scopedStyle as L, type MaskOptions as M, ssnMask as N, svgElement as O, timeMask as P, toast as Q, withScopedStyle as R, zipMask as S, type Toast as T, type ValidatorFn as V, FocusTrap as a, type FormConfig as b, type FormField as c, type FormReturn as d, VirtualList as e, type VirtualListProps as f, announce as g, aria as h, bindAttrs as i, bindBoolAttr as j, bindData as k, creditCardMask as l, custom as m, dateMask as n, defineElement as o, dialog as p, email as q, eventBus as r, focus as s, form as t, hotkey as u, infiniteScroll as v, inputMask as w, intersection as x, lazyLoad as y, matchesPattern as z };