sibujs 2.1.0 → 3.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 (62) hide show
  1. package/dist/browser.cjs +324 -273
  2. package/dist/browser.js +4 -4
  3. package/dist/build.cjs +363 -330
  4. package/dist/build.js +10 -10
  5. package/dist/cdn.global.js +8 -8
  6. package/dist/{chunk-ZAQSMOED.js → chunk-2JQUV4Y3.js} +4 -4
  7. package/dist/{chunk-GWWURC5M.js → chunk-2KM2724A.js} +2 -2
  8. package/dist/{chunk-NASX6ST2.js → chunk-4YTVESDX.js} +1 -1
  9. package/dist/chunk-5WD7BYTZ.js +152 -0
  10. package/dist/{chunk-RDTDJCAB.js → chunk-6QZO7MMG.js} +48 -16
  11. package/dist/{chunk-DRUZZAK4.js → chunk-DF3GTP4Q.js} +7 -2
  12. package/dist/{chunk-AMK2TYNW.js → chunk-INBOWHQ3.js} +14 -11
  13. package/dist/{chunk-O6EFQ3KT.js → chunk-KH4OE6WY.js} +5 -5
  14. package/dist/{chunk-V6C4FADE.js → chunk-KZA7ANXP.js} +3 -3
  15. package/dist/chunk-L4DAT4WU.js +400 -0
  16. package/dist/{chunk-WANSMF2L.js → chunk-L52H775O.js} +4 -4
  17. package/dist/{chunk-45YP72ZQ.js → chunk-NEWH4O5U.js} +1 -1
  18. package/dist/{chunk-ON5MMR2J.js → chunk-RJIRT46U.js} +4 -4
  19. package/dist/{chunk-P2HSJDDN.js → chunk-STFTTMO2.js} +2 -2
  20. package/dist/{chunk-WIPZPFBQ.js → chunk-UKMXT5T6.js} +1 -1
  21. package/dist/{chunk-KGYT6UO6.js → chunk-V65KTDZW.js} +3 -3
  22. package/dist/{chunk-CWBVQML6.js → chunk-VSNLICTS.js} +1 -1
  23. package/dist/{chunk-3DZP6OIT.js → chunk-XDKP4T7G.js} +2 -2
  24. package/dist/{chunk-TH2ILCYW.js → chunk-XVYB3J6C.js} +27 -33
  25. package/dist/{chunk-OJ3P4ECI.js → chunk-YMOIAHWA.js} +1 -1
  26. package/dist/data.cjs +332 -298
  27. package/dist/data.js +6 -6
  28. package/dist/devtools.cjs +353 -296
  29. package/dist/devtools.d.cts +1 -1
  30. package/dist/devtools.d.ts +1 -1
  31. package/dist/devtools.js +4 -4
  32. package/dist/ecosystem.cjs +332 -298
  33. package/dist/ecosystem.js +7 -7
  34. package/dist/extras.cjs +372 -328
  35. package/dist/extras.d.cts +1 -1
  36. package/dist/extras.d.ts +1 -1
  37. package/dist/extras.js +19 -19
  38. package/dist/index.cjs +363 -330
  39. package/dist/index.d.cts +26 -36
  40. package/dist/index.d.ts +26 -36
  41. package/dist/index.js +10 -10
  42. package/dist/{introspect-DnIpHQQz.d.ts → introspect-BZWKvQUZ.d.ts} +2 -3
  43. package/dist/{introspect-2TOlQ7oa.d.cts → introspect-DsJlDD2T.d.cts} +2 -3
  44. package/dist/motion.cjs +147 -123
  45. package/dist/motion.js +3 -3
  46. package/dist/patterns.cjs +332 -298
  47. package/dist/patterns.js +5 -5
  48. package/dist/performance.cjs +315 -268
  49. package/dist/performance.js +4 -4
  50. package/dist/plugins.cjs +332 -266
  51. package/dist/plugins.js +6 -6
  52. package/dist/ssr.cjs +340 -270
  53. package/dist/ssr.js +7 -7
  54. package/dist/testing.cjs +167 -146
  55. package/dist/testing.js +2 -2
  56. package/dist/ui.cjs +324 -294
  57. package/dist/ui.js +6 -6
  58. package/dist/widgets.cjs +332 -298
  59. package/dist/widgets.js +6 -6
  60. package/package.json +1 -1
  61. package/dist/chunk-QO3WC6FS.js +0 -384
  62. package/dist/chunk-WZA53FXU.js +0 -149
package/dist/widgets.js CHANGED
@@ -8,14 +8,14 @@ import {
8
8
  select,
9
9
  tabs,
10
10
  tooltip
11
- } from "./chunk-ON5MMR2J.js";
12
- import "./chunk-45YP72ZQ.js";
13
- import "./chunk-DRUZZAK4.js";
11
+ } from "./chunk-RJIRT46U.js";
12
+ import "./chunk-NEWH4O5U.js";
13
+ import "./chunk-DF3GTP4Q.js";
14
14
  import "./chunk-UCS6AMJ7.js";
15
- import "./chunk-WZA53FXU.js";
15
+ import "./chunk-5WD7BYTZ.js";
16
16
  import "./chunk-2RA7SHDA.js";
17
- import "./chunk-RDTDJCAB.js";
18
- import "./chunk-QO3WC6FS.js";
17
+ import "./chunk-6QZO7MMG.js";
18
+ import "./chunk-L4DAT4WU.js";
19
19
  import "./chunk-LMLD24FC.js";
20
20
  export {
21
21
  accordion,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "sibujs",
3
- "version": "2.1.0",
3
+ "version": "3.0.0",
4
4
  "description": "A lightweight, function-based frontend framework that combines the best of React, Svelte, and Vue — with zero VDOM and maximum simplicity. Designed for developers who want fine-grained reactivity and full control without compilation or magic.",
5
5
  "keywords": [
6
6
  "frontend",
@@ -1,384 +0,0 @@
1
- import {
2
- devWarn,
3
- isDev
4
- } from "./chunk-LMLD24FC.js";
5
-
6
- // src/reactivity/track.ts
7
- var _isDev = isDev();
8
- var STACK_INITIAL = 32;
9
- var STACK_SHRINK_THRESHOLD = 128;
10
- var subscriberStack = new Array(STACK_INITIAL);
11
- var stackCapacity = STACK_INITIAL;
12
- var stackTop = -1;
13
- var currentSubscriber = null;
14
- var SUBS = "__s";
15
- function syncFastPath(signal, subs) {
16
- const size = subs.size;
17
- if (size === 0) {
18
- signal.__f = void 0;
19
- delete signal[SUBS];
20
- } else if (size === 1) {
21
- signal.__f = subs.values().next().value;
22
- } else {
23
- signal.__f = void 0;
24
- }
25
- }
26
- var notifyDepth = 0;
27
- var pendingQueue = [];
28
- var pendingSet = /* @__PURE__ */ new Set();
29
- var propagateStack = [];
30
- function safeInvoke(sub) {
31
- try {
32
- sub();
33
- } catch (err) {
34
- if (_isDev) devWarn(`Subscriber threw during notification: ${err instanceof Error ? err.message : String(err)}`);
35
- }
36
- }
37
- var suspendDepth = 0;
38
- var trackingSuspended = false;
39
- var subscriberEpochCounter = 0;
40
- function retrack(effectFn, subscriber) {
41
- const prev = currentSubscriber;
42
- currentSubscriber = subscriber;
43
- const sub = subscriber;
44
- const epoch = ++subscriberEpochCounter;
45
- sub._epoch = epoch;
46
- try {
47
- effectFn();
48
- } finally {
49
- currentSubscriber = prev;
50
- pruneStaleDeps(sub, epoch);
51
- }
52
- }
53
- function pruneStaleDeps(sub, currentEpoch) {
54
- if (sub._dep !== void 0) {
55
- if (sub._depEpoch !== currentEpoch) {
56
- const sig = sub._dep;
57
- const subs = sig[SUBS];
58
- if (subs?.delete(sub)) syncFastPath(sig, subs);
59
- sub._dep = void 0;
60
- sub._depEpoch = void 0;
61
- }
62
- return;
63
- }
64
- const deps = sub._deps;
65
- if (!deps || deps.size === 0) return;
66
- let stales;
67
- for (const [signal, epoch] of deps) {
68
- if (epoch !== currentEpoch) {
69
- (stales ?? (stales = [])).push(signal);
70
- }
71
- }
72
- if (!stales) return;
73
- for (const signal of stales) {
74
- deps.delete(signal);
75
- const sig = signal;
76
- const subs = sig[SUBS];
77
- if (subs?.delete(sub)) syncFastPath(sig, subs);
78
- }
79
- }
80
- function track(effectFn, subscriber) {
81
- if (!subscriber) subscriber = effectFn;
82
- cleanup(subscriber);
83
- ++stackTop;
84
- if (stackTop >= stackCapacity) {
85
- stackCapacity *= 2;
86
- subscriberStack.length = stackCapacity;
87
- }
88
- subscriberStack[stackTop] = subscriber;
89
- currentSubscriber = subscriber;
90
- try {
91
- effectFn();
92
- } finally {
93
- stackTop--;
94
- currentSubscriber = stackTop >= 0 ? subscriberStack[stackTop] : null;
95
- if (stackTop < 0 && stackCapacity > STACK_SHRINK_THRESHOLD) {
96
- stackCapacity = Math.max(STACK_INITIAL, stackCapacity >>> 1);
97
- subscriberStack.length = stackCapacity;
98
- }
99
- }
100
- return () => cleanup(subscriber);
101
- }
102
- function suspendTracking() {
103
- if (suspendDepth === 0) {
104
- ++stackTop;
105
- if (stackTop >= stackCapacity) {
106
- stackCapacity *= 2;
107
- subscriberStack.length = stackCapacity;
108
- }
109
- subscriberStack[stackTop] = null;
110
- currentSubscriber = null;
111
- trackingSuspended = true;
112
- }
113
- suspendDepth++;
114
- }
115
- function resumeTracking() {
116
- suspendDepth--;
117
- if (suspendDepth === 0) {
118
- stackTop--;
119
- currentSubscriber = stackTop >= 0 ? subscriberStack[stackTop] : null;
120
- trackingSuspended = false;
121
- }
122
- }
123
- function untracked(fn) {
124
- suspendTracking();
125
- try {
126
- return fn();
127
- } finally {
128
- resumeTracking();
129
- }
130
- }
131
- function recordDependency(signal) {
132
- if (!currentSubscriber) return;
133
- const sub = currentSubscriber;
134
- const epoch = sub._epoch;
135
- if (sub._dep === signal) {
136
- sub._depEpoch = epoch;
137
- return;
138
- }
139
- const deps = sub._deps;
140
- if (deps) {
141
- deps.set(signal, epoch);
142
- } else if (sub._dep !== void 0) {
143
- const map = /* @__PURE__ */ new Map();
144
- map.set(sub._dep, sub._depEpoch);
145
- map.set(signal, epoch);
146
- sub._deps = map;
147
- sub._dep = void 0;
148
- sub._depEpoch = void 0;
149
- } else {
150
- sub._dep = signal;
151
- sub._depEpoch = epoch;
152
- }
153
- const sig = signal;
154
- let subs = sig[SUBS];
155
- if (!subs) {
156
- subs = /* @__PURE__ */ new Set();
157
- sig[SUBS] = subs;
158
- }
159
- const prevSize = subs.size;
160
- subs.add(currentSubscriber);
161
- if (subs.size !== prevSize) {
162
- if (subs.size === 1) {
163
- sig.__f = currentSubscriber;
164
- } else if (sig.__f !== void 0) {
165
- sig.__f = void 0;
166
- }
167
- }
168
- }
169
- function queueSignalNotification(signal) {
170
- const subs = signal[SUBS];
171
- if (!subs) return;
172
- for (const sub of subs) {
173
- if (sub._c) {
174
- propagateDirty(sub);
175
- } else if (!pendingSet.has(sub)) {
176
- pendingSet.add(sub);
177
- pendingQueue.push(sub);
178
- }
179
- }
180
- }
181
- var maxSubscriberRepeats = 50;
182
- var maxDrainIterations = 1e6;
183
- var drainEpoch = 0;
184
- function setMaxDrainIterations(n) {
185
- const prev = maxDrainIterations;
186
- if (Number.isFinite(n) && n > 0) maxDrainIterations = Math.floor(n);
187
- return prev;
188
- }
189
- function tickRepeat(sub) {
190
- const s = sub;
191
- if (s._runEpoch !== drainEpoch) {
192
- s._runEpoch = drainEpoch;
193
- s._runs = 1;
194
- return false;
195
- }
196
- return ++s._runs > maxSubscriberRepeats;
197
- }
198
- function cycleError(sub) {
199
- if (typeof console !== "undefined") {
200
- const name = sub.__name ?? "<unnamed>";
201
- console.error(
202
- `[SibuJS] subscriber "${name}" fired more than ${maxSubscriberRepeats} times \u2014 likely a write-reads-self cycle between effects/signals. Breaking to prevent infinite loop.`
203
- );
204
- }
205
- }
206
- function absoluteDrainError() {
207
- if (typeof console !== "undefined") {
208
- console.error(
209
- `[SibuJS] Notification drain exceeded ${maxDrainIterations} iterations \u2014 absolute safety net tripped. Breaking to prevent infinite loop.`
210
- );
211
- }
212
- }
213
- function drainQueue() {
214
- let i = 0;
215
- while (i < pendingQueue.length) {
216
- if (i >= maxDrainIterations) {
217
- absoluteDrainError();
218
- break;
219
- }
220
- const sub = pendingQueue[i++];
221
- if (tickRepeat(sub)) {
222
- cycleError(sub);
223
- break;
224
- }
225
- pendingSet.delete(sub);
226
- safeInvoke(sub);
227
- }
228
- }
229
- function drainNotificationQueue() {
230
- if (notifyDepth > 0) return;
231
- notifyDepth++;
232
- drainEpoch++;
233
- try {
234
- drainQueue();
235
- } finally {
236
- notifyDepth--;
237
- if (notifyDepth === 0) {
238
- pendingQueue.length = 0;
239
- pendingSet.clear();
240
- }
241
- }
242
- }
243
- function propagateDirty(sub) {
244
- sub();
245
- const rootSig = sub._sig;
246
- if (!rootSig) return;
247
- const stack = propagateStack;
248
- const baseLen = stack.length;
249
- stack.push(rootSig);
250
- while (stack.length > baseLen) {
251
- const sig = stack.pop();
252
- const first = sig.__f;
253
- if (first) {
254
- if (first._c) {
255
- const nSig = first._sig;
256
- if (!nSig._d) {
257
- nSig._d = true;
258
- stack.push(nSig);
259
- }
260
- } else if (!pendingSet.has(first)) {
261
- pendingSet.add(first);
262
- pendingQueue.push(first);
263
- }
264
- continue;
265
- }
266
- const subs = sig[SUBS];
267
- if (!subs) continue;
268
- for (const s of subs) {
269
- if (s._c) {
270
- const nSig = s._sig;
271
- if (nSig && !nSig._d) {
272
- nSig._d = true;
273
- stack.push(nSig);
274
- } else if (!nSig) {
275
- s();
276
- }
277
- } else if (!pendingSet.has(s)) {
278
- pendingSet.add(s);
279
- pendingQueue.push(s);
280
- }
281
- }
282
- }
283
- }
284
- function notifySubscribers(signal) {
285
- const first = signal.__f;
286
- if (first) {
287
- if (notifyDepth > 0) {
288
- if (first._c) {
289
- propagateDirty(first);
290
- } else if (!pendingSet.has(first)) {
291
- pendingSet.add(first);
292
- pendingQueue.push(first);
293
- }
294
- return;
295
- }
296
- notifyDepth++;
297
- drainEpoch++;
298
- try {
299
- if (first._c) {
300
- propagateDirty(first);
301
- } else if (tickRepeat(first)) {
302
- cycleError(first);
303
- } else {
304
- safeInvoke(first);
305
- }
306
- drainQueue();
307
- } finally {
308
- notifyDepth--;
309
- if (notifyDepth === 0) {
310
- pendingQueue.length = 0;
311
- pendingSet.clear();
312
- }
313
- }
314
- return;
315
- }
316
- const subs = signal[SUBS];
317
- if (!subs || subs.size === 0) return;
318
- if (notifyDepth > 0) {
319
- for (const sub of subs) {
320
- if (sub._c) {
321
- propagateDirty(sub);
322
- } else if (!pendingSet.has(sub)) {
323
- pendingSet.add(sub);
324
- pendingQueue.push(sub);
325
- }
326
- }
327
- return;
328
- }
329
- notifyDepth++;
330
- drainEpoch++;
331
- try {
332
- for (const sub of subs) {
333
- if (sub._c) {
334
- propagateDirty(sub);
335
- } else if (!pendingSet.has(sub)) {
336
- pendingSet.add(sub);
337
- pendingQueue.push(sub);
338
- }
339
- }
340
- drainQueue();
341
- } finally {
342
- notifyDepth--;
343
- if (notifyDepth === 0) {
344
- pendingQueue.length = 0;
345
- pendingSet.clear();
346
- }
347
- }
348
- }
349
- function cleanup(subscriber) {
350
- const sub = subscriber;
351
- const singleDep = sub._dep;
352
- if (singleDep !== void 0) {
353
- const sig = singleDep;
354
- const subs = sig[SUBS];
355
- if (subs?.delete(subscriber)) {
356
- syncFastPath(sig, subs);
357
- }
358
- sub._dep = void 0;
359
- sub._depEpoch = void 0;
360
- return;
361
- }
362
- const deps = sub._deps;
363
- if (!deps || deps.size === 0) return;
364
- for (const signal of deps.keys()) {
365
- const sig = signal;
366
- const subs = sig[SUBS];
367
- if (subs?.delete(subscriber)) {
368
- syncFastPath(sig, subs);
369
- }
370
- }
371
- deps.clear();
372
- }
373
-
374
- export {
375
- trackingSuspended,
376
- retrack,
377
- track,
378
- untracked,
379
- recordDependency,
380
- queueSignalNotification,
381
- setMaxDrainIterations,
382
- drainNotificationQueue,
383
- notifySubscribers
384
- };
@@ -1,149 +0,0 @@
1
- import {
2
- isSSR
3
- } from "./chunk-2RA7SHDA.js";
4
- import {
5
- track,
6
- untracked
7
- } from "./chunk-QO3WC6FS.js";
8
- import {
9
- devAssert
10
- } from "./chunk-LMLD24FC.js";
11
-
12
- // src/core/signals/effect.ts
13
- var _g = globalThis;
14
- function on(deps, handler) {
15
- let prev;
16
- let first = true;
17
- return () => {
18
- const value = deps();
19
- if (first) {
20
- first = false;
21
- prev = value;
22
- untracked(() => handler(value, void 0));
23
- } else {
24
- const p = prev;
25
- prev = value;
26
- untracked(() => handler(value, p));
27
- }
28
- };
29
- }
30
- function effect(effectFn, options) {
31
- devAssert(typeof effectFn === "function", "effect: argument must be a function.");
32
- if (isSSR()) return () => {
33
- };
34
- const onError = options?.onError;
35
- let userCleanups = [];
36
- const onCleanup = (fn) => {
37
- userCleanups.push(fn);
38
- };
39
- const runUserCleanups = () => {
40
- if (userCleanups.length === 0) return;
41
- const list = userCleanups;
42
- userCleanups = [];
43
- for (let i = list.length - 1; i >= 0; i--) {
44
- try {
45
- list[i]();
46
- } catch (err) {
47
- if (typeof console !== "undefined") {
48
- console.warn("[SibuJS effect] onCleanup threw:", err);
49
- }
50
- }
51
- }
52
- };
53
- const invokeBody = () => effectFn(onCleanup);
54
- const wrappedFn = onError ? () => {
55
- try {
56
- invokeBody();
57
- } catch (err) {
58
- onError(err);
59
- }
60
- } : invokeBody;
61
- let cleanupHandle = () => {
62
- };
63
- let running = false;
64
- let rerunPending = false;
65
- const MAX_RERUNS = 100;
66
- const subscriber = () => {
67
- if (running) {
68
- rerunPending = true;
69
- return;
70
- }
71
- running = true;
72
- try {
73
- let reruns = 0;
74
- do {
75
- rerunPending = false;
76
- runUserCleanups();
77
- cleanupHandle();
78
- cleanupHandle = track(wrappedFn, subscriber);
79
- if (++reruns > MAX_RERUNS) {
80
- if (_g.__SIBU_DEV_WARN__ !== false && typeof console !== "undefined") {
81
- console.error(
82
- `[SibuJS] effect re-requested itself ${MAX_RERUNS}+ times \u2014 likely a write-reads-self cycle. Breaking to prevent infinite loop.`
83
- );
84
- }
85
- rerunPending = false;
86
- break;
87
- }
88
- } while (rerunPending);
89
- } finally {
90
- running = false;
91
- rerunPending = false;
92
- }
93
- };
94
- running = true;
95
- try {
96
- let reruns = 0;
97
- do {
98
- rerunPending = false;
99
- runUserCleanups();
100
- cleanupHandle();
101
- cleanupHandle = track(wrappedFn, subscriber);
102
- if (++reruns > MAX_RERUNS) {
103
- if (_g.__SIBU_DEV_WARN__ !== false && typeof console !== "undefined") {
104
- console.error(
105
- `[SibuJS] effect re-requested itself ${MAX_RERUNS}+ times on initial run \u2014 likely a write-reads-self cycle. Breaking to prevent infinite loop.`
106
- );
107
- }
108
- rerunPending = false;
109
- break;
110
- }
111
- } while (rerunPending);
112
- } finally {
113
- running = false;
114
- rerunPending = false;
115
- }
116
- const hook = _g.__SIBU_DEVTOOLS_GLOBAL_HOOK__;
117
- if (hook) hook.emit("effect:create", { effectFn });
118
- let disposed = false;
119
- return () => {
120
- if (disposed) return;
121
- disposed = true;
122
- const h = _g.__SIBU_DEVTOOLS_GLOBAL_HOOK__;
123
- if (h) {
124
- try {
125
- h.emit("effect:destroy", { effectFn });
126
- } catch {
127
- }
128
- }
129
- try {
130
- runUserCleanups();
131
- } catch (err) {
132
- if (typeof console !== "undefined") {
133
- console.warn("[SibuJS effect] onCleanup threw during dispose:", err);
134
- }
135
- }
136
- try {
137
- cleanupHandle();
138
- } catch (err) {
139
- if (typeof console !== "undefined") {
140
- console.warn("[SibuJS effect] dispose threw:", err);
141
- }
142
- }
143
- };
144
- }
145
-
146
- export {
147
- on,
148
- effect
149
- };