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,482 +0,0 @@
1
- import {
2
- effect
3
- } from "./chunk-PZEGYCF5.js";
4
- import {
5
- batch,
6
- signal
7
- } from "./chunk-YECR7UIA.js";
8
-
9
- // src/browser/media.ts
10
- function media(query) {
11
- if (typeof window === "undefined" || typeof window.matchMedia !== "function") {
12
- const [matches2] = signal(false);
13
- return { matches: matches2, dispose: () => {
14
- } };
15
- }
16
- const mql = window.matchMedia(query);
17
- const [matches, setMatches] = signal(mql.matches);
18
- const handler = (event) => {
19
- setMatches(event.matches);
20
- };
21
- mql.addEventListener("change", handler);
22
- function dispose() {
23
- mql.removeEventListener("change", handler);
24
- }
25
- return { matches, dispose };
26
- }
27
-
28
- // src/browser/resize.ts
29
- function resolveTarget(target) {
30
- return typeof target === "function" ? target : () => target.current;
31
- }
32
- function resize(target) {
33
- const [width, setWidth] = signal(0);
34
- const [height, setHeight] = signal(0);
35
- let observer = null;
36
- if (typeof window === "undefined" || typeof ResizeObserver === "undefined") {
37
- return { width, height, dispose: () => {
38
- } };
39
- }
40
- const getter = resolveTarget(target);
41
- const cleanup = effect(() => {
42
- const el = getter();
43
- if (observer) {
44
- observer.disconnect();
45
- observer = null;
46
- }
47
- if (!el) return;
48
- observer = new ResizeObserver((entries) => {
49
- const entry = entries[0];
50
- if (entry) {
51
- batch(() => {
52
- setWidth(entry.contentRect.width);
53
- setHeight(entry.contentRect.height);
54
- });
55
- }
56
- });
57
- observer.observe(el);
58
- });
59
- function dispose() {
60
- cleanup();
61
- if (observer) {
62
- observer.disconnect();
63
- observer = null;
64
- }
65
- }
66
- return { width, height, dispose };
67
- }
68
-
69
- // src/browser/scroll.ts
70
- function scroll(target) {
71
- const [x, setX] = signal(0);
72
- const [y, setY] = signal(0);
73
- const [isScrolling, setIsScrolling] = signal(false);
74
- let scrollTimer = null;
75
- if (typeof window === "undefined") {
76
- return { x, y, isScrolling, dispose: () => {
77
- } };
78
- }
79
- const handler = () => {
80
- const el = target ? target() : null;
81
- batch(() => {
82
- if (el) {
83
- setX(el.scrollLeft);
84
- setY(el.scrollTop);
85
- } else {
86
- setX(window.scrollX ?? window.pageXOffset ?? 0);
87
- setY(window.scrollY ?? window.pageYOffset ?? 0);
88
- }
89
- setIsScrolling(true);
90
- });
91
- if (scrollTimer !== null) clearTimeout(scrollTimer);
92
- scrollTimer = setTimeout(() => {
93
- setIsScrolling(false);
94
- scrollTimer = null;
95
- }, 150);
96
- };
97
- const scrollTarget = target ? target() : null;
98
- const eventTarget = scrollTarget || window;
99
- eventTarget.addEventListener("scroll", handler, { passive: true });
100
- function dispose() {
101
- eventTarget.removeEventListener("scroll", handler);
102
- if (scrollTimer !== null) {
103
- clearTimeout(scrollTimer);
104
- scrollTimer = null;
105
- }
106
- }
107
- return { x, y, isScrolling, dispose };
108
- }
109
-
110
- // src/browser/online.ts
111
- function online() {
112
- if (typeof window === "undefined" || typeof navigator === "undefined") {
113
- const [online3] = signal(true);
114
- return { online: online3, dispose: () => {
115
- } };
116
- }
117
- const [online2, setOnline] = signal(navigator.onLine);
118
- const onOnline = () => setOnline(true);
119
- const onOffline = () => setOnline(false);
120
- window.addEventListener("online", onOnline);
121
- window.addEventListener("offline", onOffline);
122
- function dispose() {
123
- window.removeEventListener("online", onOnline);
124
- window.removeEventListener("offline", onOffline);
125
- }
126
- return { online: online2, dispose };
127
- }
128
-
129
- // src/browser/geo.ts
130
- function geo(options) {
131
- const [latitude, setLatitude] = signal(null);
132
- const [longitude, setLongitude] = signal(null);
133
- const [accuracy, setAccuracy] = signal(null);
134
- const [error, setError] = signal(null);
135
- let watchId = null;
136
- if (typeof navigator !== "undefined" && navigator.geolocation) {
137
- watchId = navigator.geolocation.watchPosition(
138
- (position) => {
139
- batch(() => {
140
- setLatitude(position.coords.latitude);
141
- setLongitude(position.coords.longitude);
142
- setAccuracy(position.coords.accuracy);
143
- setError(null);
144
- });
145
- },
146
- (err) => {
147
- setError(err);
148
- },
149
- options
150
- );
151
- }
152
- function dispose() {
153
- if (watchId !== null && typeof navigator !== "undefined" && navigator.geolocation) {
154
- navigator.geolocation.clearWatch(watchId);
155
- watchId = null;
156
- }
157
- }
158
- return { latitude, longitude, accuracy, error, dispose };
159
- }
160
-
161
- // src/browser/battery.ts
162
- function battery() {
163
- const [level, setLevel] = signal(null);
164
- const [charging, setCharging] = signal(null);
165
- const [chargingTime, setChargingTime] = signal(null);
166
- const [dischargingTime, setDischargingTime] = signal(null);
167
- const [supported, setSupported] = signal(false);
168
- let battery2 = null;
169
- let onLevelChange = null;
170
- let onChargingChange = null;
171
- let onChargingTimeChange = null;
172
- let onDischargingTimeChange = null;
173
- let disposed = false;
174
- if (typeof navigator !== "undefined" && "getBattery" in navigator) {
175
- setSupported(true);
176
- navigator.getBattery().then((bm) => {
177
- if (disposed) return;
178
- battery2 = bm;
179
- batch(() => {
180
- setLevel(bm.level);
181
- setCharging(bm.charging);
182
- setChargingTime(bm.chargingTime);
183
- setDischargingTime(bm.dischargingTime);
184
- });
185
- onLevelChange = () => setLevel(bm.level);
186
- onChargingChange = () => setCharging(bm.charging);
187
- onChargingTimeChange = () => setChargingTime(bm.chargingTime);
188
- onDischargingTimeChange = () => setDischargingTime(bm.dischargingTime);
189
- bm.addEventListener("levelchange", onLevelChange);
190
- bm.addEventListener("chargingchange", onChargingChange);
191
- bm.addEventListener("chargingtimechange", onChargingTimeChange);
192
- bm.addEventListener("dischargingtimechange", onDischargingTimeChange);
193
- });
194
- }
195
- function dispose() {
196
- disposed = true;
197
- if (battery2) {
198
- if (onLevelChange) battery2.removeEventListener("levelchange", onLevelChange);
199
- if (onChargingChange) battery2.removeEventListener("chargingchange", onChargingChange);
200
- if (onChargingTimeChange) battery2.removeEventListener("chargingtimechange", onChargingTimeChange);
201
- if (onDischargingTimeChange) battery2.removeEventListener("dischargingtimechange", onDischargingTimeChange);
202
- battery2 = null;
203
- }
204
- }
205
- return { level, charging, chargingTime, dischargingTime, supported, dispose };
206
- }
207
-
208
- // src/browser/idle.ts
209
- var ACTIVITY_EVENTS = ["mousemove", "mousedown", "keydown", "touchstart", "scroll"];
210
- function idle(timeout = 6e4) {
211
- const [idle2, setIdle] = signal(false);
212
- if (typeof window === "undefined" || typeof document === "undefined") {
213
- return { idle: idle2, dispose: () => {
214
- } };
215
- }
216
- let timer = null;
217
- function resetTimer() {
218
- setIdle(false);
219
- if (timer !== null) clearTimeout(timer);
220
- timer = setTimeout(() => {
221
- setIdle(true);
222
- }, timeout);
223
- }
224
- for (const event of ACTIVITY_EVENTS) {
225
- document.addEventListener(event, resetTimer, { passive: true });
226
- }
227
- resetTimer();
228
- function dispose() {
229
- if (timer !== null) {
230
- clearTimeout(timer);
231
- timer = null;
232
- }
233
- for (const event of ACTIVITY_EVENTS) {
234
- document.removeEventListener(event, resetTimer);
235
- }
236
- }
237
- return { idle: idle2, dispose };
238
- }
239
-
240
- // src/browser/permissions.ts
241
- function permissions(name) {
242
- const [state, setState] = signal("prompt");
243
- let permissionStatus = null;
244
- let onChange = null;
245
- let disposed = false;
246
- if (typeof navigator === "undefined" || !navigator.permissions) {
247
- setState("unsupported");
248
- return { state, dispose: () => {
249
- } };
250
- }
251
- navigator.permissions.query({ name }).then((status) => {
252
- if (disposed) return;
253
- permissionStatus = status;
254
- setState(status.state);
255
- onChange = () => {
256
- setState(status.state);
257
- };
258
- status.addEventListener("change", onChange);
259
- }).catch(() => {
260
- setState("unsupported");
261
- });
262
- function dispose() {
263
- disposed = true;
264
- if (permissionStatus && onChange) {
265
- permissionStatus.removeEventListener("change", onChange);
266
- permissionStatus = null;
267
- onChange = null;
268
- }
269
- }
270
- return { state, dispose };
271
- }
272
-
273
- // src/browser/clipboard.ts
274
- function clipboard() {
275
- const [text, setText] = signal("");
276
- const [copied, setCopied] = signal(false);
277
- let copiedTimer = null;
278
- async function copy(value) {
279
- if (typeof navigator === "undefined" || !navigator.clipboard) {
280
- return;
281
- }
282
- await navigator.clipboard.writeText(value);
283
- setText(value);
284
- setCopied(true);
285
- if (copiedTimer !== null) clearTimeout(copiedTimer);
286
- copiedTimer = setTimeout(() => {
287
- setCopied(false);
288
- copiedTimer = null;
289
- }, 2e3);
290
- }
291
- function dispose() {
292
- if (copiedTimer !== null) {
293
- clearTimeout(copiedTimer);
294
- copiedTimer = null;
295
- }
296
- }
297
- return { text, copy, copied, dispose };
298
- }
299
-
300
- // src/browser/dragDrop.ts
301
- function resolveTarget2(target) {
302
- return typeof target === "function" ? target : () => target.current;
303
- }
304
- function draggable(element, data) {
305
- const [isDragging, setIsDragging] = signal(false);
306
- if (typeof window === "undefined") {
307
- return { isDragging, dispose: () => {
308
- } };
309
- }
310
- let currentEl = null;
311
- let onDragStart = null;
312
- let onDragEnd = null;
313
- const getter = resolveTarget2(element);
314
- const cleanup = effect(() => {
315
- if (currentEl && onDragStart && onDragEnd) {
316
- currentEl.removeEventListener("dragstart", onDragStart);
317
- currentEl.removeEventListener("dragend", onDragEnd);
318
- }
319
- const el = getter();
320
- currentEl = el;
321
- if (!el) return;
322
- el.draggable = true;
323
- onDragStart = (e) => {
324
- setIsDragging(true);
325
- if (e.dataTransfer && data !== void 0) {
326
- e.dataTransfer.setData("application/json", JSON.stringify(data));
327
- }
328
- };
329
- onDragEnd = () => {
330
- setIsDragging(false);
331
- };
332
- el.addEventListener("dragstart", onDragStart);
333
- el.addEventListener("dragend", onDragEnd);
334
- });
335
- function dispose() {
336
- cleanup();
337
- if (currentEl && onDragStart && onDragEnd) {
338
- currentEl.removeEventListener("dragstart", onDragStart);
339
- currentEl.removeEventListener("dragend", onDragEnd);
340
- currentEl = null;
341
- }
342
- }
343
- return { isDragging, dispose };
344
- }
345
- function dropZone(element, options) {
346
- const [isOver, setIsOver] = signal(false);
347
- if (typeof window === "undefined") {
348
- return { isOver, dispose: () => {
349
- } };
350
- }
351
- let currentEl = null;
352
- let onDragOver = null;
353
- let onDragEnter = null;
354
- let onDragLeave = null;
355
- let onDrop = null;
356
- const getter = resolveTarget2(element);
357
- const cleanup = effect(() => {
358
- if (currentEl && onDragOver && onDragEnter && onDragLeave && onDrop) {
359
- currentEl.removeEventListener("dragover", onDragOver);
360
- currentEl.removeEventListener("dragenter", onDragEnter);
361
- currentEl.removeEventListener("dragleave", onDragLeave);
362
- currentEl.removeEventListener("drop", onDrop);
363
- }
364
- const el = getter();
365
- currentEl = el;
366
- if (!el) return;
367
- onDragOver = (e) => {
368
- e.preventDefault();
369
- };
370
- onDragEnter = (e) => {
371
- e.preventDefault();
372
- setIsOver(true);
373
- };
374
- onDragLeave = () => {
375
- setIsOver(false);
376
- };
377
- onDrop = (e) => {
378
- e.preventDefault();
379
- setIsOver(false);
380
- let transferData = null;
381
- if (e.dataTransfer) {
382
- const raw = e.dataTransfer.getData("application/json");
383
- if (raw) {
384
- try {
385
- transferData = JSON.parse(raw);
386
- } catch {
387
- transferData = raw;
388
- }
389
- }
390
- }
391
- options.onDrop(transferData, e);
392
- };
393
- el.addEventListener("dragover", onDragOver);
394
- el.addEventListener("dragenter", onDragEnter);
395
- el.addEventListener("dragleave", onDragLeave);
396
- el.addEventListener("drop", onDrop);
397
- });
398
- function dispose() {
399
- cleanup();
400
- if (currentEl && onDragOver && onDragEnter && onDragLeave && onDrop) {
401
- currentEl.removeEventListener("dragover", onDragOver);
402
- currentEl.removeEventListener("dragenter", onDragEnter);
403
- currentEl.removeEventListener("dragleave", onDragLeave);
404
- currentEl.removeEventListener("drop", onDrop);
405
- currentEl = null;
406
- }
407
- }
408
- return { isOver, dispose };
409
- }
410
-
411
- // src/browser/title.ts
412
- function title(value) {
413
- if (typeof document === "undefined") {
414
- return () => {
415
- };
416
- }
417
- const previousTitle = document.title;
418
- if (typeof value === "function") {
419
- const cleanup = effect(() => {
420
- document.title = value();
421
- });
422
- return () => {
423
- cleanup();
424
- document.title = previousTitle;
425
- };
426
- }
427
- document.title = value;
428
- return () => {
429
- document.title = previousTitle;
430
- };
431
- }
432
-
433
- // src/browser/colorScheme.ts
434
- function colorScheme() {
435
- if (typeof window === "undefined" || typeof window.matchMedia !== "function") {
436
- const [scheme2] = signal("light");
437
- return { scheme: scheme2, dispose: () => {
438
- } };
439
- }
440
- const mql = window.matchMedia("(prefers-color-scheme: dark)");
441
- const [scheme, setScheme] = signal(mql.matches ? "dark" : "light");
442
- const handler = (event) => {
443
- setScheme(event.matches ? "dark" : "light");
444
- };
445
- mql.addEventListener("change", handler);
446
- function dispose() {
447
- mql.removeEventListener("change", handler);
448
- }
449
- return { scheme, dispose };
450
- }
451
-
452
- // src/browser/format.ts
453
- function formatNumber(value, options) {
454
- const { locale, ...formatOptions } = options ?? {};
455
- return new Intl.NumberFormat(locale, formatOptions).format(value);
456
- }
457
- function formatCurrency(value, currency, options) {
458
- const { locale, ...formatOptions } = options ?? {};
459
- return new Intl.NumberFormat(locale, {
460
- style: "currency",
461
- currency,
462
- ...formatOptions
463
- }).format(value);
464
- }
465
-
466
- export {
467
- media,
468
- resize,
469
- scroll,
470
- online,
471
- geo,
472
- battery,
473
- idle,
474
- permissions,
475
- clipboard,
476
- draggable,
477
- dropZone,
478
- title,
479
- colorScheme,
480
- formatNumber,
481
- formatCurrency
482
- };
@@ -1,21 +0,0 @@
1
- // src/core/dev.ts
2
- function isDev() {
3
- return typeof globalThis.__SIBU_DEV__ !== "undefined" ? !!globalThis.__SIBU_DEV__ : typeof __SIBU_DEV__ !== "undefined" ? __SIBU_DEV__ : true;
4
- }
5
- var _isDev = isDev();
6
- function devAssert(condition, message) {
7
- if (_isDev && !condition) {
8
- throw new Error(`[Sibu] ${message}`);
9
- }
10
- }
11
- function devWarn(message) {
12
- if (_isDev) {
13
- console.warn(`[Sibu] ${message}`);
14
- }
15
- }
16
-
17
- export {
18
- isDev,
19
- devAssert,
20
- devWarn
21
- };
@@ -1,154 +0,0 @@
1
- import {
2
- isUrlAttribute,
3
- sanitizeUrl
4
- } from "./chunk-CMBFNA7L.js";
5
- import {
6
- track
7
- } from "./chunk-K4G4ZQNR.js";
8
- import {
9
- devWarn,
10
- isDev
11
- } from "./chunk-5X6PP2UK.js";
12
-
13
- // src/reactivity/bindAttribute.ts
14
- var _isDev = isDev();
15
- function isEventHandlerAttr(name) {
16
- if (name.length < 3) return false;
17
- const lower = name.toLowerCase();
18
- return lower[0] === "o" && lower[1] === "n" && lower.charCodeAt(2) >= 97 && lower.charCodeAt(2) <= 122;
19
- }
20
- function bindAttribute(el, attr, getter) {
21
- if (isEventHandlerAttr(attr)) {
22
- if (_isDev)
23
- devWarn(
24
- `bindAttribute: refusing to bind event-handler attribute "${attr}". Use on:{ ${attr.slice(2)}: fn } instead.`
25
- );
26
- return () => {
27
- };
28
- }
29
- function commit() {
30
- let value;
31
- try {
32
- value = getter();
33
- } catch (err) {
34
- if (_isDev)
35
- devWarn(`bindAttribute: getter for "${attr}" threw: ${err instanceof Error ? err.message : String(err)}`);
36
- return;
37
- }
38
- if (typeof value === "boolean") {
39
- if (attr in el && (attr === "checked" || attr === "disabled" || attr === "selected")) {
40
- el[attr] = value;
41
- } else if (value) {
42
- el.setAttribute(attr, "");
43
- } else {
44
- el.removeAttribute(attr);
45
- }
46
- return;
47
- }
48
- const str = String(value);
49
- if ((attr === "value" || attr === "checked") && attr in el) {
50
- el[attr] = attr === "checked" ? Boolean(value) : str;
51
- } else {
52
- el.setAttribute(attr, isUrlAttribute(attr) ? sanitizeUrl(str) : str);
53
- }
54
- }
55
- const teardown = track(commit);
56
- return teardown;
57
- }
58
- function bindDynamic(el, nameGetter, valueGetter) {
59
- let prevName = null;
60
- function commit() {
61
- let name;
62
- try {
63
- name = typeof nameGetter === "function" ? nameGetter() : nameGetter;
64
- } catch (err) {
65
- if (_isDev) devWarn(`bindDynamic: name getter threw: ${err instanceof Error ? err.message : String(err)}`);
66
- return;
67
- }
68
- let value;
69
- try {
70
- value = typeof valueGetter === "function" ? valueGetter() : valueGetter;
71
- } catch (err) {
72
- if (_isDev) devWarn(`bindDynamic: value getter threw: ${err instanceof Error ? err.message : String(err)}`);
73
- return;
74
- }
75
- if ((name[0] === "o" || name[0] === "O") && (name[1] === "n" || name[1] === "N")) return;
76
- if (prevName !== null && prevName !== name) {
77
- el.removeAttribute(prevName);
78
- }
79
- const str = String(value);
80
- if ((name === "value" || name === "checked") && name in el) {
81
- el[name] = name === "checked" ? Boolean(value) : str;
82
- } else {
83
- el.setAttribute(name, isUrlAttribute(name) ? sanitizeUrl(str) : str);
84
- }
85
- prevName = name;
86
- }
87
- const teardown = track(commit);
88
- return () => {
89
- teardown();
90
- if (prevName !== null) {
91
- el.removeAttribute(prevName);
92
- }
93
- };
94
- }
95
-
96
- // src/core/rendering/dispose.ts
97
- var elementDisposers = /* @__PURE__ */ new WeakMap();
98
- var _isDev2 = isDev();
99
- var activeBindingCount = 0;
100
- function registerDisposer(node, teardown) {
101
- let disposers = elementDisposers.get(node);
102
- if (!disposers) {
103
- disposers = [];
104
- elementDisposers.set(node, disposers);
105
- }
106
- disposers.push(teardown);
107
- if (_isDev2) activeBindingCount++;
108
- }
109
- function dispose(node) {
110
- const stack = [node];
111
- const order = [];
112
- while (stack.length > 0) {
113
- const current = stack.pop();
114
- order.push(current);
115
- const children = current.childNodes;
116
- for (let i = 0; i < children.length; i++) {
117
- stack.push(children[i]);
118
- }
119
- }
120
- for (let i = order.length - 1; i >= 0; i--) {
121
- const current = order[i];
122
- const disposers = elementDisposers.get(current);
123
- if (disposers) {
124
- if (_isDev2) activeBindingCount -= disposers.length;
125
- for (const d of disposers) {
126
- try {
127
- d();
128
- } catch (err) {
129
- if (_isDev2 && typeof console !== "undefined") {
130
- console.warn("[SibuJS] Disposer threw during cleanup:", err);
131
- }
132
- }
133
- }
134
- elementDisposers.delete(current);
135
- }
136
- }
137
- }
138
- function checkLeaks(warnThreshold = 0) {
139
- if (!_isDev2) return 0;
140
- if (warnThreshold > 0 && activeBindingCount > warnThreshold) {
141
- devWarn(
142
- `checkLeaks: ${activeBindingCount} active DOM bindings detected. Expected \u2264${warnThreshold}. This may indicate a component was removed from the DOM without calling dispose().`
143
- );
144
- }
145
- return activeBindingCount;
146
- }
147
-
148
- export {
149
- bindAttribute,
150
- bindDynamic,
151
- registerDisposer,
152
- dispose,
153
- checkLeaks
154
- };
@@ -1,26 +0,0 @@
1
- import {
2
- signal
3
- } from "./chunk-NZIIMDWI.js";
4
-
5
- // src/core/rendering/context.ts
6
- function context(defaultValue) {
7
- const [getValue, setValue] = signal(defaultValue);
8
- return {
9
- provide(value) {
10
- setValue(value);
11
- },
12
- use() {
13
- return getValue;
14
- },
15
- get() {
16
- return getValue();
17
- },
18
- set(value) {
19
- setValue(value);
20
- }
21
- };
22
- }
23
-
24
- export {
25
- context
26
- };