sibujs 1.5.0 → 2.1.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 (208) hide show
  1. package/dist/browser.cjs +332 -121
  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 +1049 -344
  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-BMPL52BF.js → chunk-3DZP6OIT.js} +118 -66
  11. package/dist/chunk-3JHCYHWN.js +125 -0
  12. package/dist/{chunk-CZUGLNJS.js → chunk-45YP72ZQ.js} +3 -3
  13. package/dist/{chunk-JCDUJN2F.js → chunk-AMK2TYNW.js} +490 -153
  14. package/dist/{chunk-NHUC2QWH.js → chunk-CWBVQML6.js} +1 -1
  15. package/dist/{chunk-XHK6BDAJ.js → chunk-DRUZZAK4.js} +25 -8
  16. package/dist/{chunk-RJ46C3CS.js → chunk-GWWURC5M.js} +71 -20
  17. package/dist/{chunk-3X2YG6YM.js → chunk-JYD2PWXH.js} +59 -28
  18. package/dist/{chunk-2BYQDGN3.js → chunk-KGYT6UO6.js} +234 -63
  19. package/dist/{chunk-5X6PP2UK.js → chunk-LMLD24FC.js} +2 -2
  20. package/dist/{chunk-M4NLBH4I.js → chunk-LYTCUZ7H.js} +3 -2
  21. package/dist/{chunk-XUEEGU5O.js → chunk-NASX6ST2.js} +16 -4
  22. package/dist/{chunk-VQDZK23A.js → chunk-O6EFQ3KT.js} +181 -66
  23. package/dist/{chunk-BGN5ZMP4.js → chunk-OJ3P4ECI.js} +14 -2
  24. package/dist/chunk-ON5MMR2J.js +1327 -0
  25. package/dist/{chunk-SFKNRVCU.js → chunk-P2HSJDDN.js} +135 -79
  26. package/dist/chunk-QO3WC6FS.js +384 -0
  27. package/dist/{chunk-WZSPOOER.js → chunk-RDTDJCAB.js} +8 -5
  28. package/dist/{chunk-7GRNSCFT.js → chunk-TH2ILCYW.js} +312 -185
  29. package/dist/chunk-UCS6AMJ7.js +79 -0
  30. package/dist/{chunk-VAPYJN4X.js → chunk-V6C4FADE.js} +93 -23
  31. package/dist/{chunk-OUZZEE4S.js → chunk-WANSMF2L.js} +17 -11
  32. package/dist/{chunk-23VV7YD3.js → chunk-WIPZPFBQ.js} +25 -30
  33. package/dist/chunk-WZA53FXU.js +149 -0
  34. package/dist/{chunk-BGTHZHJ5.js → chunk-ZAQSMOED.js} +188 -44
  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 +536 -151
  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 +613 -266
  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 +602 -197
  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 +3500 -1608
  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 +1055 -344
  54. package/dist/index.d.cts +85 -8
  55. package/dist/index.d.ts +85 -8
  56. package/dist/index.js +32 -16
  57. package/dist/{introspect-BumjnBKr.d.cts → introspect-2TOlQ7oa.d.cts} +25 -3
  58. package/dist/{introspect-CZrlcaYy.d.ts → introspect-DnIpHQQz.d.ts} +25 -3
  59. package/dist/motion.cjs +122 -63
  60. package/dist/motion.js +4 -4
  61. package/dist/patterns.cjs +450 -110
  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 +373 -149
  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 +729 -301
  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 +736 -274
  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 +303 -76
  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 +589 -178
  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 +1103 -146
  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-K4G4ZQNR.js +0 -286
  136. package/dist/chunk-K5ZUMYVS.js +0 -89
  137. package/dist/chunk-KQPDEVVS.js +0 -398
  138. package/dist/chunk-L6JRBDNS.js +0 -60
  139. package/dist/chunk-LA6KQEDU.js +0 -712
  140. package/dist/chunk-MB6QFH3I.js +0 -2776
  141. package/dist/chunk-MDVXJWFN.js +0 -304
  142. package/dist/chunk-MEZVEBPN.js +0 -2008
  143. package/dist/chunk-MK4ERFYL.js +0 -2249
  144. package/dist/chunk-MLKGABMK.js +0 -9
  145. package/dist/chunk-MQ5GOYPH.js +0 -2249
  146. package/dist/chunk-MYRV7VDM.js +0 -742
  147. package/dist/chunk-N6IZB6KJ.js +0 -567
  148. package/dist/chunk-NEKUBFPT.js +0 -60
  149. package/dist/chunk-NMRUZALC.js +0 -1097
  150. package/dist/chunk-NYVAC6P5.js +0 -37
  151. package/dist/chunk-NZIIMDWI.js +0 -84
  152. package/dist/chunk-OF7UZIVB.js +0 -725
  153. package/dist/chunk-P3XWXJZU.js +0 -282
  154. package/dist/chunk-P6W3STU4.js +0 -2249
  155. package/dist/chunk-PBHF5WKN.js +0 -616
  156. package/dist/chunk-PDZQY43A.js +0 -616
  157. package/dist/chunk-PTQJDMRT.js +0 -146
  158. package/dist/chunk-PZEGYCF5.js +0 -61
  159. package/dist/chunk-QBMDLBU2.js +0 -975
  160. package/dist/chunk-QWZG56ET.js +0 -2744
  161. package/dist/chunk-RQGQSLQK.js +0 -725
  162. package/dist/chunk-SDLZDHKP.js +0 -107
  163. package/dist/chunk-TDGZL5CU.js +0 -365
  164. package/dist/chunk-TNQWPPE6.js +0 -37
  165. package/dist/chunk-TSOKIX5Z.js +0 -654
  166. package/dist/chunk-UHNL42EF.js +0 -2730
  167. package/dist/chunk-UNXCEF6S.js +0 -21
  168. package/dist/chunk-V2XTI523.js +0 -347
  169. package/dist/chunk-VAU366PN.js +0 -2241
  170. package/dist/chunk-VMVDTCXB.js +0 -712
  171. package/dist/chunk-VQNQZCWJ.js +0 -61
  172. package/dist/chunk-VRW3FULF.js +0 -725
  173. package/dist/chunk-WADYRCO2.js +0 -304
  174. package/dist/chunk-WILQZRO4.js +0 -282
  175. package/dist/chunk-WR5D4EGH.js +0 -26
  176. package/dist/chunk-WUHJISPP.js +0 -298
  177. package/dist/chunk-XYU6TZOW.js +0 -182
  178. package/dist/chunk-Y6GP4QGG.js +0 -276
  179. package/dist/chunk-YECR7UIA.js +0 -347
  180. package/dist/chunk-YUTWTI4B.js +0 -654
  181. package/dist/chunk-Z65KYU7I.js +0 -26
  182. package/dist/chunk-Z6POF5YC.js +0 -975
  183. package/dist/chunk-ZBJP6WFL.js +0 -482
  184. package/dist/chunk-ZD6OAMTH.js +0 -277
  185. package/dist/chunk-ZWKZCBO6.js +0 -317
  186. package/dist/contracts-DDrwxvJ-.d.cts +0 -245
  187. package/dist/contracts-DDrwxvJ-.d.ts +0 -245
  188. package/dist/contracts-DOrhwbke.d.cts +0 -245
  189. package/dist/contracts-DOrhwbke.d.ts +0 -245
  190. package/dist/contracts-xo5ckdRP.d.cts +0 -240
  191. package/dist/contracts-xo5ckdRP.d.ts +0 -240
  192. package/dist/customElement-BKQfbSZQ.d.cts +0 -262
  193. package/dist/customElement-BKQfbSZQ.d.ts +0 -262
  194. package/dist/customElement-D2DJp_xn.d.cts +0 -313
  195. package/dist/customElement-D2DJp_xn.d.ts +0 -313
  196. package/dist/customElement-yz8uyk-0.d.cts +0 -308
  197. package/dist/customElement-yz8uyk-0.d.ts +0 -308
  198. package/dist/introspect-Cb0zgpi2.d.cts +0 -477
  199. package/dist/introspect-Y2xNXGSf.d.ts +0 -477
  200. package/dist/plugin-Bek4RhJY.d.cts +0 -43
  201. package/dist/plugin-Bek4RhJY.d.ts +0 -43
  202. package/dist/ssr-3RXHP5ES.js +0 -38
  203. package/dist/ssr-6GIMY5MX.js +0 -38
  204. package/dist/ssr-BA6sxxUd.d.cts +0 -135
  205. package/dist/ssr-BA6sxxUd.d.ts +0 -135
  206. package/dist/ssr-WKUPVSSK.js +0 -36
  207. package/dist/tagFactory-Dl8QCLga.d.cts +0 -23
  208. 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 };