elements-kit 0.0.9 → 0.0.11
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.
- package/README.md +3 -4
- package/dist/builder/dom.d.mts +1 -1
- package/dist/builder/index.d.mts +87 -1
- package/dist/builder/index.mjs +1 -1
- package/dist/{element-Ddk9YaoE.mjs → element-MXzFk4G2.mjs} +1 -1
- package/dist/{index-BtqiEEfc.d.mts → index-Cvdhuy6Y.d.mts} +8 -4
- package/dist/index.d.mts +1 -1
- package/dist/index.mjs +3 -3
- package/dist/{signals/lib → integrations}/react.d.mts +2 -2
- package/dist/{signals/lib → integrations}/react.mjs +2 -2
- package/dist/jsx-runtime/index.d.mts +2 -2
- package/dist/jsx-runtime/index.mjs +3 -3
- package/dist/lib-BYJ5jPTG.d.mts +4 -0
- package/dist/polyfill-DR5XVnh_.d.mts +9 -0
- package/dist/signals/index.d.mts +2 -2
- package/dist/signals/index.mjs +2 -2
- package/dist/{signals-CLAPw8kk.mjs → signals-DcgXhkU2.mjs} +41 -9
- package/dist/slot.d.mts +1 -2
- package/dist/{test.BmQO5GaM-CR2qjV1t.mjs → test.BmQO5GaM-ANkhHvbr.mjs} +1 -1
- package/dist/utilities/active-element.d.mts +6 -0
- package/dist/utilities/active-element.mjs +13 -0
- package/dist/utilities/active-element.test.mjs +24 -0
- package/dist/{signals/lib → utilities}/debounced.d.mts +3 -3
- package/dist/{signals/lib → utilities}/debounced.mjs +7 -6
- package/dist/{signals/lib → utilities}/debounced.test.mjs +3 -3
- package/dist/{signals/lib → utilities}/element-rect.d.mts +3 -3
- package/dist/{signals/lib → utilities}/element-rect.mjs +7 -7
- package/dist/{signals/lib → utilities}/element-rect.test.mjs +3 -3
- package/dist/utilities/element-scroll.d.mts +16 -0
- package/dist/utilities/element-scroll.mjs +52 -0
- package/dist/utilities/element-scroll.test.mjs +25 -0
- package/dist/utilities/event-driven.d.mts +47 -0
- package/dist/utilities/event-driven.mjs +38 -0
- package/dist/utilities/event-listener.d.mts +16 -0
- package/dist/{signals/lib → utilities}/event-listener.mjs +4 -4
- package/dist/{signals/lib → utilities}/event-listener.test.mjs +8 -8
- package/dist/utilities/focus-within.d.mts +10 -0
- package/dist/utilities/focus-within.mjs +20 -0
- package/dist/{signals/lib/is-focus-within.test.mjs → utilities/focus-within.test.mjs} +10 -11
- package/dist/utilities/hover.d.mts +11 -0
- package/dist/utilities/hover.mjs +20 -0
- package/dist/{signals/lib → utilities}/hover.test.mjs +5 -16
- package/dist/utilities/intersection-observer.d.mts +8 -0
- package/dist/{signals/lib → utilities}/intersection-observer.mjs +3 -4
- package/dist/{signals/lib → utilities}/intersection-observer.test.mjs +3 -3
- package/dist/{signals/lib → utilities}/interval.d.mts +2 -2
- package/dist/{signals/lib → utilities}/interval.mjs +6 -5
- package/dist/{signals/lib → utilities}/interval.test.mjs +3 -3
- package/dist/utilities/location.d.mts +24 -0
- package/dist/utilities/location.mjs +54 -0
- package/dist/utilities/location.test.mjs +60 -0
- package/dist/utilities/long-press.d.mts +10 -0
- package/dist/utilities/long-press.mjs +27 -0
- package/dist/{signals/lib → utilities}/long-press.test.mjs +3 -3
- package/dist/{signals/lib → utilities}/media-devices.d.mts +3 -3
- package/dist/{signals/lib → utilities}/media-devices.mjs +5 -5
- package/dist/{signals/lib → utilities}/media-devices.test.mjs +6 -8
- package/dist/utilities/media-player.d.mts +22 -0
- package/dist/utilities/media-player.mjs +36 -0
- package/dist/utilities/media-player.test.mjs +100 -0
- package/dist/{signals/lib/media.d.mts → utilities/media-query.d.mts} +4 -4
- package/dist/utilities/media-query.mjs +19 -0
- package/dist/utilities/mutation-observer.d.mts +8 -0
- package/dist/{signals/lib → utilities}/mutation-observer.mjs +3 -3
- package/dist/{signals/lib → utilities}/mutation-observer.test.mjs +3 -3
- package/dist/{signals/lib → utilities}/on-click-outside.d.mts +3 -3
- package/dist/utilities/on-click-outside.mjs +17 -0
- package/dist/{signals/lib → utilities}/on-click-outside.test.mjs +7 -18
- package/dist/utilities/orientation.d.mts +10 -0
- package/dist/utilities/orientation.mjs +21 -0
- package/dist/utilities/previous.d.mts +12 -0
- package/dist/utilities/previous.mjs +24 -0
- package/dist/utilities/previous.test.mjs +88 -0
- package/dist/utilities/resize-observer.d.mts +8 -0
- package/dist/{signals/lib → utilities}/resize-observer.mjs +4 -5
- package/dist/utilities/routing.d.mts +59 -0
- package/dist/utilities/routing.mjs +89 -0
- package/dist/utilities/routing.test.mjs +128 -0
- package/dist/utilities/search-params.d.mts +13 -0
- package/dist/utilities/search-params.mjs +23 -0
- package/dist/utilities/search-params.test.mjs +35 -0
- package/dist/utilities/storage.d.mts +22 -0
- package/dist/utilities/storage.mjs +65 -0
- package/dist/utilities/storage.test.mjs +137 -0
- package/dist/{signals/lib → utilities}/throttled.d.mts +2 -2
- package/dist/utilities/throttled.mjs +36 -0
- package/dist/{signals/lib → utilities}/throttled.test.mjs +3 -3
- package/dist/{signals/lib → utilities}/timeout.d.mts +6 -5
- package/dist/utilities/timeout.mjs +42 -0
- package/dist/{signals/lib → utilities}/timeout.test.mjs +7 -7
- package/dist/utilities/window-size.d.mts +10 -0
- package/dist/utilities/window-size.mjs +22 -0
- package/dist/utilities/window-size.test.mjs +42 -0
- package/package.json +11 -6
- package/dist/index-CKjDUp1B.d.mts +0 -89
- package/dist/polyfill-AFIi9kAN.d.mts +0 -14
- package/dist/signals/lib/active-element.d.mts +0 -10
- package/dist/signals/lib/active-element.mjs +0 -20
- package/dist/signals/lib/active-element.test.mjs +0 -39
- package/dist/signals/lib/animation-frames.d.mts +0 -18
- package/dist/signals/lib/animation-frames.mjs +0 -48
- package/dist/signals/lib/animation-frames.test.mjs +0 -52
- package/dist/signals/lib/async-retry.d.mts +0 -21
- package/dist/signals/lib/async-retry.mjs +0 -57
- package/dist/signals/lib/async-retry.test.mjs +0 -57
- package/dist/signals/lib/audio.d.mts +0 -26
- package/dist/signals/lib/audio.mjs +0 -60
- package/dist/signals/lib/audio.test.mjs +0 -54
- package/dist/signals/lib/battery.d.mts +0 -17
- package/dist/signals/lib/battery.mjs +0 -45
- package/dist/signals/lib/battery.test.mjs +0 -38
- package/dist/signals/lib/before-unload.d.mts +0 -11
- package/dist/signals/lib/before-unload.mjs +0 -20
- package/dist/signals/lib/before-unload.test.mjs +0 -29
- package/dist/signals/lib/clipboard.d.mts +0 -15
- package/dist/signals/lib/clipboard.mjs +0 -25
- package/dist/signals/lib/clipboard.test.mjs +0 -53
- package/dist/signals/lib/counter.d.mts +0 -18
- package/dist/signals/lib/counter.mjs +0 -21
- package/dist/signals/lib/counter.test.d.mts +0 -1
- package/dist/signals/lib/counter.test.mjs +0 -74
- package/dist/signals/lib/document-title.d.mts +0 -10
- package/dist/signals/lib/document-title.mjs +0 -15
- package/dist/signals/lib/document-title.test.d.mts +0 -1
- package/dist/signals/lib/document-title.test.mjs +0 -33
- package/dist/signals/lib/element-size.d.mts +0 -16
- package/dist/signals/lib/element-size.mjs +0 -32
- package/dist/signals/lib/element-size.test.d.mts +0 -1
- package/dist/signals/lib/element-size.test.mjs +0 -86
- package/dist/signals/lib/event-listener.d.mts +0 -14
- package/dist/signals/lib/favicon.d.mts +0 -10
- package/dist/signals/lib/favicon.mjs +0 -24
- package/dist/signals/lib/favicon.test.d.mts +0 -1
- package/dist/signals/lib/favicon.test.mjs +0 -28
- package/dist/signals/lib/finite-state-machine.d.mts +0 -22
- package/dist/signals/lib/finite-state-machine.mjs +0 -26
- package/dist/signals/lib/finite-state-machine.test.d.mts +0 -1
- package/dist/signals/lib/finite-state-machine.test.mjs +0 -66
- package/dist/signals/lib/fullscreen.d.mts +0 -15
- package/dist/signals/lib/fullscreen.mjs +0 -26
- package/dist/signals/lib/fullscreen.test.d.mts +0 -1
- package/dist/signals/lib/fullscreen.test.mjs +0 -56
- package/dist/signals/lib/geolocation.d.mts +0 -15
- package/dist/signals/lib/geolocation.mjs +0 -30
- package/dist/signals/lib/geolocation.test.d.mts +0 -1
- package/dist/signals/lib/geolocation.test.mjs +0 -37
- package/dist/signals/lib/hash.d.mts +0 -10
- package/dist/signals/lib/hash.mjs +0 -20
- package/dist/signals/lib/hash.test.d.mts +0 -1
- package/dist/signals/lib/hash.test.mjs +0 -47
- package/dist/signals/lib/hover.d.mts +0 -11
- package/dist/signals/lib/hover.mjs +0 -23
- package/dist/signals/lib/intersection-observer.d.mts +0 -8
- package/dist/signals/lib/is-document-visible.d.mts +0 -11
- package/dist/signals/lib/is-document-visible.mjs +0 -19
- package/dist/signals/lib/is-document-visible.test.d.mts +0 -1
- package/dist/signals/lib/is-document-visible.test.mjs +0 -58
- package/dist/signals/lib/is-focus-within.d.mts +0 -10
- package/dist/signals/lib/is-focus-within.mjs +0 -28
- package/dist/signals/lib/is-focus-within.test.d.mts +0 -1
- package/dist/signals/lib/is-idle.d.mts +0 -10
- package/dist/signals/lib/is-idle.mjs +0 -37
- package/dist/signals/lib/is-idle.test.d.mts +0 -1
- package/dist/signals/lib/is-idle.test.mjs +0 -50
- package/dist/signals/lib/is-in-viewport.d.mts +0 -10
- package/dist/signals/lib/is-in-viewport.mjs +0 -16
- package/dist/signals/lib/is-in-viewport.test.d.mts +0 -1
- package/dist/signals/lib/is-in-viewport.test.mjs +0 -74
- package/dist/signals/lib/key-press.d.mts +0 -13
- package/dist/signals/lib/key-press.mjs +0 -25
- package/dist/signals/lib/key-press.test.d.mts +0 -1
- package/dist/signals/lib/key-press.test.mjs +0 -52
- package/dist/signals/lib/list.d.mts +0 -19
- package/dist/signals/lib/list.mjs +0 -36
- package/dist/signals/lib/list.test.d.mts +0 -1
- package/dist/signals/lib/list.test.mjs +0 -104
- package/dist/signals/lib/lock-body-scroll.d.mts +0 -8
- package/dist/signals/lib/lock-body-scroll.mjs +0 -17
- package/dist/signals/lib/lock-body-scroll.test.d.mts +0 -1
- package/dist/signals/lib/lock-body-scroll.test.mjs +0 -37
- package/dist/signals/lib/long-press.d.mts +0 -10
- package/dist/signals/lib/long-press.mjs +0 -29
- package/dist/signals/lib/map.d.mts +0 -18
- package/dist/signals/lib/map.mjs +0 -33
- package/dist/signals/lib/map.test.d.mts +0 -1
- package/dist/signals/lib/map.test.mjs +0 -60
- package/dist/signals/lib/media.mjs +0 -26
- package/dist/signals/lib/motion.d.mts +0 -15
- package/dist/signals/lib/motion.mjs +0 -27
- package/dist/signals/lib/motion.test.d.mts +0 -1
- package/dist/signals/lib/motion.test.mjs +0 -51
- package/dist/signals/lib/mouse-position.d.mts +0 -14
- package/dist/signals/lib/mouse-position.mjs +0 -22
- package/dist/signals/lib/mouse-position.test.d.mts +0 -1
- package/dist/signals/lib/mouse-position.test.mjs +0 -44
- package/dist/signals/lib/mouse-wheel.d.mts +0 -10
- package/dist/signals/lib/mouse-wheel.mjs +0 -17
- package/dist/signals/lib/mouse-wheel.test.d.mts +0 -1
- package/dist/signals/lib/mouse-wheel.test.mjs +0 -38
- package/dist/signals/lib/mutation-observer.d.mts +0 -8
- package/dist/signals/lib/network-state.d.mts +0 -17
- package/dist/signals/lib/network-state.mjs +0 -34
- package/dist/signals/lib/network-state.test.d.mts +0 -1
- package/dist/signals/lib/network-state.test.mjs +0 -61
- package/dist/signals/lib/on-click-outside.mjs +0 -20
- package/dist/signals/lib/orientation.d.mts +0 -13
- package/dist/signals/lib/orientation.mjs +0 -21
- package/dist/signals/lib/orientation.test.d.mts +0 -1
- package/dist/signals/lib/orientation.test.mjs +0 -43
- package/dist/signals/lib/page-leave.d.mts +0 -8
- package/dist/signals/lib/page-leave.mjs +0 -12
- package/dist/signals/lib/page-leave.test.d.mts +0 -1
- package/dist/signals/lib/page-leave.test.mjs +0 -29
- package/dist/signals/lib/permission.d.mts +0 -14
- package/dist/signals/lib/permission.mjs +0 -26
- package/dist/signals/lib/permission.test.d.mts +0 -1
- package/dist/signals/lib/permission.test.mjs +0 -50
- package/dist/signals/lib/persisted-state.d.mts +0 -11
- package/dist/signals/lib/persisted-state.mjs +0 -25
- package/dist/signals/lib/persisted-state.test.d.mts +0 -1
- package/dist/signals/lib/persisted-state.test.mjs +0 -70
- package/dist/signals/lib/pressed-keys.d.mts +0 -10
- package/dist/signals/lib/pressed-keys.mjs +0 -32
- package/dist/signals/lib/pressed-keys.test.d.mts +0 -1
- package/dist/signals/lib/pressed-keys.test.mjs +0 -54
- package/dist/signals/lib/previous-distinct.d.mts +0 -10
- package/dist/signals/lib/previous-distinct.mjs +0 -22
- package/dist/signals/lib/previous-distinct.test.d.mts +0 -1
- package/dist/signals/lib/previous-distinct.test.mjs +0 -50
- package/dist/signals/lib/previous.d.mts +0 -10
- package/dist/signals/lib/previous.mjs +0 -18
- package/dist/signals/lib/previous.test.mjs +0 -47
- package/dist/signals/lib/queue.d.mts +0 -17
- package/dist/signals/lib/queue.mjs +0 -28
- package/dist/signals/lib/queue.test.d.mts +0 -1
- package/dist/signals/lib/queue.test.mjs +0 -61
- package/dist/signals/lib/raf.d.mts +0 -17
- package/dist/signals/lib/raf.mjs +0 -38
- package/dist/signals/lib/raf.test.d.mts +0 -1
- package/dist/signals/lib/raf.test.mjs +0 -58
- package/dist/signals/lib/resize-observer.d.mts +0 -8
- package/dist/signals/lib/resize-observer.test.d.mts +0 -1
- package/dist/signals/lib/resize-observer.test.mjs +0 -44
- package/dist/signals/lib/resource.d.mts +0 -23
- package/dist/signals/lib/resource.mjs +0 -43
- package/dist/signals/lib/resource.test.d.mts +0 -1
- package/dist/signals/lib/resource.test.mjs +0 -56
- package/dist/signals/lib/scroll-state.d.mts +0 -19
- package/dist/signals/lib/scroll-state.mjs +0 -46
- package/dist/signals/lib/scroll-state.test.d.mts +0 -1
- package/dist/signals/lib/scroll-state.test.mjs +0 -94
- package/dist/signals/lib/scrolling.d.mts +0 -12
- package/dist/signals/lib/scrolling.mjs +0 -26
- package/dist/signals/lib/scrolling.test.d.mts +0 -1
- package/dist/signals/lib/scrolling.test.mjs +0 -57
- package/dist/signals/lib/search-params.d.mts +0 -16
- package/dist/signals/lib/search-params.mjs +0 -37
- package/dist/signals/lib/search-params.test.mjs +0 -56
- package/dist/signals/lib/set.d.mts +0 -18
- package/dist/signals/lib/set.mjs +0 -38
- package/dist/signals/lib/set.test.d.mts +0 -1
- package/dist/signals/lib/set.test.mjs +0 -70
- package/dist/signals/lib/start-typing.d.mts +0 -9
- package/dist/signals/lib/start-typing.mjs +0 -39
- package/dist/signals/lib/start-typing.test.d.mts +0 -1
- package/dist/signals/lib/start-typing.test.mjs +0 -64
- package/dist/signals/lib/state-history.d.mts +0 -21
- package/dist/signals/lib/state-history.mjs +0 -61
- package/dist/signals/lib/state-history.test.d.mts +0 -1
- package/dist/signals/lib/state-history.test.mjs +0 -106
- package/dist/signals/lib/state-validator.d.mts +0 -16
- package/dist/signals/lib/state-validator.mjs +0 -21
- package/dist/signals/lib/state-validator.test.d.mts +0 -1
- package/dist/signals/lib/state-validator.test.mjs +0 -41
- package/dist/signals/lib/throttled.mjs +0 -45
- package/dist/signals/lib/timeout.mjs +0 -39
- package/dist/signals/lib/toggle.d.mts +0 -12
- package/dist/signals/lib/toggle.mjs +0 -12
- package/dist/signals/lib/toggle.test.d.mts +0 -1
- package/dist/signals/lib/toggle.test.mjs +0 -43
- package/dist/signals/lib/video.d.mts +0 -25
- package/dist/signals/lib/video.mjs +0 -59
- package/dist/signals/lib/video.test.d.mts +0 -1
- package/dist/signals/lib/video.test.mjs +0 -51
- package/dist/signals/lib/watch.d.mts +0 -16
- package/dist/signals/lib/watch.mjs +0 -31
- package/dist/signals/lib/watch.test.d.mts +0 -1
- package/dist/signals/lib/watch.test.mjs +0 -51
- package/dist/signals/lib/window-size.d.mts +0 -14
- package/dist/signals/lib/window-size.mjs +0 -22
- package/dist/signals/lib/window-size.test.mjs +0 -50
- /package/dist/{signals/lib → utilities}/active-element.test.d.mts +0 -0
- /package/dist/{signals/lib → utilities}/debounced.test.d.mts +0 -0
- /package/dist/{signals/lib → utilities}/element-rect.test.d.mts +0 -0
- /package/dist/{signals/lib/animation-frames.test.d.mts → utilities/element-scroll.test.d.mts} +0 -0
- /package/dist/{signals/lib → utilities}/event-listener.test.d.mts +0 -0
- /package/dist/{signals/lib/async-retry.test.d.mts → utilities/focus-within.test.d.mts} +0 -0
- /package/dist/{signals/lib → utilities}/hover.test.d.mts +0 -0
- /package/dist/{signals/lib → utilities}/intersection-observer.test.d.mts +0 -0
- /package/dist/{signals/lib → utilities}/interval.test.d.mts +0 -0
- /package/dist/{signals/lib/audio.test.d.mts → utilities/location.test.d.mts} +0 -0
- /package/dist/{signals/lib → utilities}/long-press.test.d.mts +0 -0
- /package/dist/{signals/lib → utilities}/media-devices.test.d.mts +0 -0
- /package/dist/{signals/lib/battery.test.d.mts → utilities/media-player.test.d.mts} +0 -0
- /package/dist/{signals/lib → utilities}/mutation-observer.test.d.mts +0 -0
- /package/dist/{signals/lib → utilities}/on-click-outside.test.d.mts +0 -0
- /package/dist/{signals/lib → utilities}/previous.test.d.mts +0 -0
- /package/dist/{signals/lib/before-unload.test.d.mts → utilities/routing.test.d.mts} +0 -0
- /package/dist/{signals/lib → utilities}/search-params.test.d.mts +0 -0
- /package/dist/{signals/lib/clipboard.test.d.mts → utilities/storage.test.d.mts} +0 -0
- /package/dist/{signals/lib → utilities}/throttled.test.d.mts +0 -0
- /package/dist/{signals/lib → utilities}/timeout.test.d.mts +0 -0
- /package/dist/{signals/lib → utilities}/window-size.test.d.mts +0 -0
|
@@ -1,20 +1,20 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { s as effectScope } from "../signals-DcgXhkU2.mjs";
|
|
2
|
+
import { n as vi, o as describe, r as afterEach, s as it, t as globalExpect } from "../test.BmQO5GaM-ANkhHvbr.mjs";
|
|
3
3
|
import { createTimeout } from "./timeout.mjs";
|
|
4
|
-
//#region src/
|
|
4
|
+
//#region src/utilities/timeout.test.ts
|
|
5
5
|
afterEach(() => {
|
|
6
6
|
document.body.innerHTML = "";
|
|
7
7
|
vi.useRealTimers();
|
|
8
8
|
});
|
|
9
9
|
describe("createTimeout", () => {
|
|
10
|
-
it("starts as
|
|
10
|
+
it("starts as running", () => {
|
|
11
11
|
vi.useFakeTimers();
|
|
12
12
|
let t;
|
|
13
13
|
const cb = vi.fn();
|
|
14
14
|
effectScope(() => {
|
|
15
15
|
t = createTimeout(cb, 500);
|
|
16
16
|
});
|
|
17
|
-
globalExpect(t.
|
|
17
|
+
globalExpect(t.isRunning()).toBe(true);
|
|
18
18
|
});
|
|
19
19
|
it("fires callback after delay", () => {
|
|
20
20
|
vi.useFakeTimers();
|
|
@@ -25,14 +25,14 @@ describe("createTimeout", () => {
|
|
|
25
25
|
vi.advanceTimersByTime(600);
|
|
26
26
|
globalExpect(cb).toHaveBeenCalledOnce();
|
|
27
27
|
});
|
|
28
|
-
it("
|
|
28
|
+
it("isRunning becomes false after firing", () => {
|
|
29
29
|
vi.useFakeTimers();
|
|
30
30
|
let t;
|
|
31
31
|
effectScope(() => {
|
|
32
32
|
t = createTimeout(vi.fn(), 200);
|
|
33
33
|
});
|
|
34
34
|
vi.advanceTimersByTime(300);
|
|
35
|
-
globalExpect(t.
|
|
35
|
+
globalExpect(t.isRunning()).toBe(false);
|
|
36
36
|
});
|
|
37
37
|
it("stop() cancels the timeout", () => {
|
|
38
38
|
vi.useFakeTimers();
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { t as Computed } from "../index-Cvdhuy6Y.mjs";
|
|
2
|
+
|
|
3
|
+
//#region src/utilities/window-size.d.ts
|
|
4
|
+
type WindowSizeResult = {
|
|
5
|
+
width: Computed<number>;
|
|
6
|
+
height: Computed<number>;
|
|
7
|
+
} & Disposable;
|
|
8
|
+
declare const windowSize: WindowSizeResult;
|
|
9
|
+
//#endregion
|
|
10
|
+
export { windowSize };
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { a as computed } from "../signals-DcgXhkU2.mjs";
|
|
2
|
+
import { fromEvent, sync } from "./event-driven.mjs";
|
|
3
|
+
//#region src/utilities/window-size.ts
|
|
4
|
+
/**
|
|
5
|
+
* Returns reactive `width` and `height` signals tracking the browser window
|
|
6
|
+
* inner dimensions.
|
|
7
|
+
*/
|
|
8
|
+
function createWindowSize() {
|
|
9
|
+
const isBrowser = typeof window !== "undefined";
|
|
10
|
+
const [size, stop] = sync(fromEvent(window, "resize"), () => ({
|
|
11
|
+
w: isBrowser ? window.innerWidth : 0,
|
|
12
|
+
h: isBrowser ? window.innerHeight : 0
|
|
13
|
+
}));
|
|
14
|
+
return {
|
|
15
|
+
width: computed(() => size().w),
|
|
16
|
+
height: computed(() => size().h),
|
|
17
|
+
[Symbol.dispose]: stop
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
const windowSize = createWindowSize();
|
|
21
|
+
//#endregion
|
|
22
|
+
export { windowSize };
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { o as describe, s as it, t as globalExpect } from "../test.BmQO5GaM-ANkhHvbr.mjs";
|
|
2
|
+
import { windowSize } from "./window-size.mjs";
|
|
3
|
+
//#region src/utilities/window-size.test.ts
|
|
4
|
+
describe("windowSize (singleton)", () => {
|
|
5
|
+
it("starts with current window dimensions", () => {
|
|
6
|
+
globalExpect(windowSize.width()).toBe(window.innerWidth);
|
|
7
|
+
globalExpect(windowSize.height()).toBe(window.innerHeight);
|
|
8
|
+
});
|
|
9
|
+
it("updates on resize event", () => {
|
|
10
|
+
const origWidth = window.innerWidth;
|
|
11
|
+
const origHeight = window.innerHeight;
|
|
12
|
+
Object.defineProperty(window, "innerWidth", {
|
|
13
|
+
value: 1234,
|
|
14
|
+
configurable: true
|
|
15
|
+
});
|
|
16
|
+
Object.defineProperty(window, "innerHeight", {
|
|
17
|
+
value: 5678,
|
|
18
|
+
configurable: true
|
|
19
|
+
});
|
|
20
|
+
window.dispatchEvent(new Event("resize"));
|
|
21
|
+
globalExpect(windowSize.width()).toBe(1234);
|
|
22
|
+
globalExpect(windowSize.height()).toBe(5678);
|
|
23
|
+
Object.defineProperty(window, "innerWidth", {
|
|
24
|
+
value: origWidth,
|
|
25
|
+
configurable: true
|
|
26
|
+
});
|
|
27
|
+
Object.defineProperty(window, "innerHeight", {
|
|
28
|
+
value: origHeight,
|
|
29
|
+
configurable: true
|
|
30
|
+
});
|
|
31
|
+
});
|
|
32
|
+
it("remains reactive after Symbol.dispose", () => {
|
|
33
|
+
Object.defineProperty(window, "innerWidth", {
|
|
34
|
+
value: 42,
|
|
35
|
+
configurable: true
|
|
36
|
+
});
|
|
37
|
+
window.dispatchEvent(new Event("resize"));
|
|
38
|
+
globalExpect(windowSize.width()).toBe(42);
|
|
39
|
+
});
|
|
40
|
+
});
|
|
41
|
+
//#endregion
|
|
42
|
+
export {};
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "elements-kit",
|
|
3
3
|
"type": "module",
|
|
4
|
-
"version": "0.0.
|
|
4
|
+
"version": "0.0.11",
|
|
5
5
|
"description": "A lightweight reactive UI library that transforms native HTMLElements into reactive components with signals. Ideal for framework-agnostic applications and web components.",
|
|
6
6
|
"keywords": [
|
|
7
7
|
"webcomponents",
|
|
@@ -33,11 +33,6 @@
|
|
|
33
33
|
"import": "./dist/signals/index.mjs",
|
|
34
34
|
"types": "./dist/signals/index.d.ts"
|
|
35
35
|
},
|
|
36
|
-
"./signals/*": {
|
|
37
|
-
"source": "./src/signals/lib/*.ts",
|
|
38
|
-
"import": "./dist/signals/lib/*.mjs",
|
|
39
|
-
"types": "./dist/signals/lib/*.d.ts"
|
|
40
|
-
},
|
|
41
36
|
"./slot": {
|
|
42
37
|
"source": "./src/slot.ts",
|
|
43
38
|
"import": "./dist/slot.mjs",
|
|
@@ -67,6 +62,16 @@
|
|
|
67
62
|
"source": "./src/jsx-runtime/index.ts",
|
|
68
63
|
"import": "./dist/jsx-runtime/index.mjs",
|
|
69
64
|
"types": "./dist/jsx-runtime/index.d.ts"
|
|
65
|
+
},
|
|
66
|
+
"./integrations/*": {
|
|
67
|
+
"source": "./src/integrations/*.ts",
|
|
68
|
+
"import": "./dist/integrations/*.mjs",
|
|
69
|
+
"types": "./dist/integrations/*.d.ts"
|
|
70
|
+
},
|
|
71
|
+
"./utilities/*": {
|
|
72
|
+
"source": "./src/utilities/*.ts",
|
|
73
|
+
"import": "./dist/utilities/*.mjs",
|
|
74
|
+
"types": "./dist/utilities/*.d.ts"
|
|
70
75
|
}
|
|
71
76
|
},
|
|
72
77
|
"scripts": {
|
|
@@ -1,89 +0,0 @@
|
|
|
1
|
-
import { t as PrimitiveNodeType } from "./polyfill-AFIi9kAN.mjs";
|
|
2
|
-
|
|
3
|
-
//#region src/builder/index.d.ts
|
|
4
|
-
declare const DISPOSABLES: unique symbol;
|
|
5
|
-
declare const DISPOSE: symbol;
|
|
6
|
-
declare const VALUE: unique symbol;
|
|
7
|
-
declare const EFFECT: unique symbol;
|
|
8
|
-
declare class ElementBuilder<T extends Element = Element> {
|
|
9
|
-
/** Dispose the reactive element and run all cleanup functions */
|
|
10
|
-
[DISPOSE]: () => void;
|
|
11
|
-
/** The underlying DOM element */
|
|
12
|
-
private [VALUE];
|
|
13
|
-
/** A set of cleanup functions to run when disposing the element */
|
|
14
|
-
private [DISPOSABLES];
|
|
15
|
-
[EFFECT](fn: () => void): this;
|
|
16
|
-
private constructor();
|
|
17
|
-
static create<T extends Element>(el: T): ReactiveElement<T>;
|
|
18
|
-
children(...children: ValueOrReactive<ElementBuilder | Node | string | number>[]): T;
|
|
19
|
-
ref(): T;
|
|
20
|
-
ref(apply: (ref: T) => void | (() => void)): this;
|
|
21
|
-
on<K extends keyof HTMLElementEventMap>(eventType: K, listener: (ev: HTMLElementEventMap[K]) => void, options?: boolean | AddEventListenerOptions): this;
|
|
22
|
-
}
|
|
23
|
-
declare function toNode(c: ElementBuilder | PrimitiveNodeType): Node;
|
|
24
|
-
declare function builder<T extends Element>(el: T): ReactiveElementOf<T>;
|
|
25
|
-
/**
|
|
26
|
-
* Callable overloads matching the Proxy apply trap → ref() behavior.
|
|
27
|
-
* Calling a reactive element as a function delegates to ref():
|
|
28
|
-
* el() → returns the raw DOM element
|
|
29
|
-
* el((ref) => {}) → applies a side-effect, returns the builder for chaining
|
|
30
|
-
*/
|
|
31
|
-
interface RefCallable<T extends Element> {
|
|
32
|
-
(): T;
|
|
33
|
-
(apply: (ref: T) => void | (() => void)): this;
|
|
34
|
-
}
|
|
35
|
-
type ReactiveElement<T extends Element> = ElementBuilder<T> & RefCallable<T>;
|
|
36
|
-
type ValueOrReactive<T> = (() => T) | T;
|
|
37
|
-
type ValueOrReactiveArray<T extends any[]> = { [K in keyof T]: ValueOrReactive<T[K]> | T[K] };
|
|
38
|
-
/**
|
|
39
|
-
* Filter keys that are writable (exclude readonly and getter-only).
|
|
40
|
-
*/
|
|
41
|
-
type WritableKeys<T> = { [K in keyof T]: (<U>() => U extends { [Q in K]: T[K] } ? 1 : 2) extends (<U>() => U extends { readonly [Q in K]: T[K] } ? 1 : 2) ? never : K }[keyof T];
|
|
42
|
-
/**
|
|
43
|
-
* Extracts the object chaining part of ReactiveBuilder.
|
|
44
|
-
* Used for properties like `style` where you can do both:
|
|
45
|
-
* .style("padding: 20px;") // setter
|
|
46
|
-
* .style.padding("20px") // sub-property chaining
|
|
47
|
-
*/
|
|
48
|
-
type Chain<R, T> = T extends object ? { [K in WritableKeys<T>]: Builder<R, T[K]> } : {};
|
|
49
|
-
type Builder<R, T = R> = T extends ((...args: infer U) => unknown) ? (...value: ValueOrReactiveArray<U>) => R : (value?: ValueOrReactive<T>) => R;
|
|
50
|
-
/**
|
|
51
|
-
* Types eligible for sub-property chaining (e.g., `.style.padding("20px")`).
|
|
52
|
-
*/
|
|
53
|
-
type ChainableType = CSSStyleDeclaration | DOMTokenList | DOMStringMap | StylePropertyMap;
|
|
54
|
-
/**
|
|
55
|
-
* Filters keys to only writable data properties.
|
|
56
|
-
* Excludes methods (function-valued properties) and event handlers (`on*`).
|
|
57
|
-
*/
|
|
58
|
-
type DataPropertyKeys<T> = { [K in keyof T]: K extends `on${string}` ? never : T[K] extends ((...args: any[]) => any) ? never : K }[keyof T];
|
|
59
|
-
/**
|
|
60
|
-
* Reactive setter for a single property.
|
|
61
|
-
* Chainable types (CSSStyleDeclaration, DOMTokenList, etc.) get both
|
|
62
|
-
* sub-property chaining and direct setter support.
|
|
63
|
-
*/
|
|
64
|
-
type ReactiveSetter<R, T> = T extends ChainableType ? Chain<R, T> & ((value: ValueOrReactive<T>) => R) : (value: ValueOrReactive<T>) => R;
|
|
65
|
-
/**
|
|
66
|
-
* A fully-typed reactive element builder for any Element type.
|
|
67
|
-
* Automatically maps all writable data properties into reactive setters.
|
|
68
|
-
*
|
|
69
|
-
* Use this for custom elements instead of needing generated builder interfaces.
|
|
70
|
-
*
|
|
71
|
-
* @example
|
|
72
|
-
* ```ts
|
|
73
|
-
* import { reactive, type ReactiveElementOf } from "elements-kit";
|
|
74
|
-
*
|
|
75
|
-
* class MyElement extends HTMLElement {
|
|
76
|
-
* greeting = "hello";
|
|
77
|
-
* }
|
|
78
|
-
* customElements.define("my-element", MyElement);
|
|
79
|
-
*
|
|
80
|
-
* const myEl = () =>
|
|
81
|
-
* reactive(document.createElement("my-element") as MyElement);
|
|
82
|
-
*
|
|
83
|
-
* // Full type support for both own and inherited properties:
|
|
84
|
-
* myEl().greeting("world").style.padding("20px").id("main");
|
|
85
|
-
* ```
|
|
86
|
-
*/
|
|
87
|
-
type ReactiveElementOf<T extends Element> = ElementBuilder<T> & { [K in WritableKeys<T> & DataPropertyKeys<T> & keyof T]: ReactiveSetter<ReactiveElementOf<T>, T[K]> };
|
|
88
|
-
//#endregion
|
|
89
|
-
export { EFFECT as a, ReactiveElementOf as c, builder as d, toNode as f, DISPOSE as i, VALUE as l, Chain as n, ElementBuilder as o, DISPOSABLES as r, ReactiveElement as s, Builder as t, ValueOrReactive as u };
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
//#region src/lib.d.ts
|
|
2
|
-
type PrimitiveNodeType = Node | string | boolean | number | bigint | symbol | Date | RegExp | null | undefined;
|
|
3
|
-
//#endregion
|
|
4
|
-
//#region src/polyfill.d.ts
|
|
5
|
-
declare global {
|
|
6
|
-
interface SymbolConstructor {
|
|
7
|
-
readonly dispose: symbol;
|
|
8
|
-
}
|
|
9
|
-
interface Disposable {
|
|
10
|
-
[Symbol.dispose](): void;
|
|
11
|
-
}
|
|
12
|
-
}
|
|
13
|
-
//#endregion
|
|
14
|
-
export { PrimitiveNodeType as t };
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { t as Computed } from "../../index-BtqiEEfc.mjs";
|
|
2
|
-
|
|
3
|
-
//#region src/signals/lib/active-element.d.ts
|
|
4
|
-
/**
|
|
5
|
-
* Returns a `Computed` that tracks `document.activeElement`.
|
|
6
|
-
* Updates on every `focusin` / `focusout` event bubbling through the document.
|
|
7
|
-
*/
|
|
8
|
-
declare function createActiveElement(): Computed<Element | null> & Disposable;
|
|
9
|
-
//#endregion
|
|
10
|
-
export { createActiveElement };
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import { f as signal } from "../../signals-CLAPw8kk.mjs";
|
|
2
|
-
import { createEventListener } from "./event-listener.mjs";
|
|
3
|
-
//#region src/signals/lib/active-element.ts
|
|
4
|
-
/**
|
|
5
|
-
* Returns a `Computed` that tracks `document.activeElement`.
|
|
6
|
-
* Updates on every `focusin` / `focusout` event bubbling through the document.
|
|
7
|
-
*/
|
|
8
|
-
function createActiveElement() {
|
|
9
|
-
const active = signal(typeof document !== "undefined" ? document.activeElement : null);
|
|
10
|
-
const update = () => active(document.activeElement);
|
|
11
|
-
const r1 = createEventListener(document, "focusin", update);
|
|
12
|
-
const r2 = createEventListener(document, "focusout", update);
|
|
13
|
-
const cleanup = () => {
|
|
14
|
-
r1();
|
|
15
|
-
r2();
|
|
16
|
-
};
|
|
17
|
-
return Object.assign(active, { [Symbol.dispose]: cleanup });
|
|
18
|
-
}
|
|
19
|
-
//#endregion
|
|
20
|
-
export { createActiveElement };
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
import { o as effectScope } from "../../signals-CLAPw8kk.mjs";
|
|
2
|
-
import { a as describe, o as it, r as afterEach, t as globalExpect } from "../../test.BmQO5GaM-CR2qjV1t.mjs";
|
|
3
|
-
import { createActiveElement } from "./active-element.mjs";
|
|
4
|
-
//#region src/signals/lib/active-element.test.ts
|
|
5
|
-
afterEach(() => {
|
|
6
|
-
document.body.innerHTML = "";
|
|
7
|
-
});
|
|
8
|
-
describe("createActiveElement", () => {
|
|
9
|
-
it("returns a computed that reads the current activeElement", () => {
|
|
10
|
-
let active;
|
|
11
|
-
effectScope(() => {
|
|
12
|
-
active = createActiveElement();
|
|
13
|
-
});
|
|
14
|
-
globalExpect(active()).toBe(document.activeElement);
|
|
15
|
-
});
|
|
16
|
-
it("updates when focus changes", () => {
|
|
17
|
-
const input = document.createElement("input");
|
|
18
|
-
document.body.appendChild(input);
|
|
19
|
-
let active;
|
|
20
|
-
effectScope(() => {
|
|
21
|
-
active = createActiveElement();
|
|
22
|
-
});
|
|
23
|
-
document.dispatchEvent(new FocusEvent("focusin", { relatedTarget: input }));
|
|
24
|
-
globalExpect(active()).toBe(document.activeElement);
|
|
25
|
-
});
|
|
26
|
-
it("stops updating after Symbol.dispose", () => {
|
|
27
|
-
let active;
|
|
28
|
-
effectScope(() => {
|
|
29
|
-
active = createActiveElement();
|
|
30
|
-
});
|
|
31
|
-
active[Symbol.dispose]();
|
|
32
|
-
const input = document.createElement("input");
|
|
33
|
-
document.body.appendChild(input);
|
|
34
|
-
input.focus();
|
|
35
|
-
globalExpect(typeof active()).not.toBe("undefined");
|
|
36
|
-
});
|
|
37
|
-
});
|
|
38
|
-
//#endregion
|
|
39
|
-
export {};
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { t as Computed } from "../../index-BtqiEEfc.mjs";
|
|
2
|
-
|
|
3
|
-
//#region src/signals/lib/animation-frames.d.ts
|
|
4
|
-
type AnimationFramesResult = {
|
|
5
|
-
isRunning: Computed<boolean>;
|
|
6
|
-
delta: Computed<number>;
|
|
7
|
-
elapsed: Computed<number>;
|
|
8
|
-
start(): void;
|
|
9
|
-
stop(): void;
|
|
10
|
-
} & Disposable;
|
|
11
|
-
/**
|
|
12
|
-
* RAF loop with pause/resume, delta time, and elapsed time tracking.
|
|
13
|
-
*
|
|
14
|
-
* Starts paused — call `start()` to begin.
|
|
15
|
-
*/
|
|
16
|
-
declare function createAnimationFrames(): AnimationFramesResult;
|
|
17
|
-
//#endregion
|
|
18
|
-
export { createAnimationFrames };
|
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
import { d as onCleanup, f as signal } from "../../signals-CLAPw8kk.mjs";
|
|
2
|
-
//#region src/signals/lib/animation-frames.ts
|
|
3
|
-
/**
|
|
4
|
-
* RAF loop with pause/resume, delta time, and elapsed time tracking.
|
|
5
|
-
*
|
|
6
|
-
* Starts paused — call `start()` to begin.
|
|
7
|
-
*/
|
|
8
|
-
function createAnimationFrames() {
|
|
9
|
-
const isRunning = signal(false);
|
|
10
|
-
const delta = signal(0);
|
|
11
|
-
const elapsed = signal(0);
|
|
12
|
-
let rafId;
|
|
13
|
-
let lastTime;
|
|
14
|
-
const loop = (time) => {
|
|
15
|
-
if (lastTime !== void 0) {
|
|
16
|
-
const d = time - lastTime;
|
|
17
|
-
delta(d);
|
|
18
|
-
elapsed(elapsed() + d);
|
|
19
|
-
}
|
|
20
|
-
lastTime = time;
|
|
21
|
-
rafId = requestAnimationFrame(loop);
|
|
22
|
-
};
|
|
23
|
-
const start = () => {
|
|
24
|
-
if (isRunning()) return;
|
|
25
|
-
lastTime = void 0;
|
|
26
|
-
isRunning(true);
|
|
27
|
-
rafId = requestAnimationFrame(loop);
|
|
28
|
-
};
|
|
29
|
-
const stop = () => {
|
|
30
|
-
if (rafId !== void 0) {
|
|
31
|
-
cancelAnimationFrame(rafId);
|
|
32
|
-
rafId = void 0;
|
|
33
|
-
}
|
|
34
|
-
lastTime = void 0;
|
|
35
|
-
isRunning(false);
|
|
36
|
-
};
|
|
37
|
-
const cleanup = () => stop();
|
|
38
|
-
onCleanup(cleanup);
|
|
39
|
-
return Object.assign({
|
|
40
|
-
isRunning,
|
|
41
|
-
delta,
|
|
42
|
-
elapsed,
|
|
43
|
-
start,
|
|
44
|
-
stop
|
|
45
|
-
}, { [Symbol.dispose]: cleanup });
|
|
46
|
-
}
|
|
47
|
-
//#endregion
|
|
48
|
-
export { createAnimationFrames };
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
import { o as effectScope } from "../../signals-CLAPw8kk.mjs";
|
|
2
|
-
import { a as describe, n as vi, o as it, r as afterEach, t as globalExpect } from "../../test.BmQO5GaM-CR2qjV1t.mjs";
|
|
3
|
-
import { createAnimationFrames } from "./animation-frames.mjs";
|
|
4
|
-
//#region src/signals/lib/animation-frames.test.ts
|
|
5
|
-
afterEach(() => {
|
|
6
|
-
document.body.innerHTML = "";
|
|
7
|
-
vi.unstubAllGlobals();
|
|
8
|
-
});
|
|
9
|
-
describe("createAnimationFrames", () => {
|
|
10
|
-
it("starts paused", () => {
|
|
11
|
-
let af;
|
|
12
|
-
effectScope(() => {
|
|
13
|
-
af = createAnimationFrames();
|
|
14
|
-
});
|
|
15
|
-
globalExpect(af.isRunning()).toBe(false);
|
|
16
|
-
});
|
|
17
|
-
it("start() sets isRunning to true", () => {
|
|
18
|
-
vi.stubGlobal("requestAnimationFrame", vi.fn().mockReturnValue(1));
|
|
19
|
-
vi.stubGlobal("cancelAnimationFrame", vi.fn());
|
|
20
|
-
let af;
|
|
21
|
-
effectScope(() => {
|
|
22
|
-
af = createAnimationFrames();
|
|
23
|
-
});
|
|
24
|
-
af.start();
|
|
25
|
-
globalExpect(af.isRunning()).toBe(true);
|
|
26
|
-
});
|
|
27
|
-
it("stop() sets isRunning to false", () => {
|
|
28
|
-
vi.stubGlobal("requestAnimationFrame", vi.fn().mockReturnValue(1));
|
|
29
|
-
vi.stubGlobal("cancelAnimationFrame", vi.fn());
|
|
30
|
-
let af;
|
|
31
|
-
effectScope(() => {
|
|
32
|
-
af = createAnimationFrames();
|
|
33
|
-
});
|
|
34
|
-
af.start();
|
|
35
|
-
af.stop();
|
|
36
|
-
globalExpect(af.isRunning()).toBe(false);
|
|
37
|
-
});
|
|
38
|
-
it("Symbol.dispose stops the loop", () => {
|
|
39
|
-
const cancel = vi.fn();
|
|
40
|
-
vi.stubGlobal("requestAnimationFrame", vi.fn().mockReturnValue(1));
|
|
41
|
-
vi.stubGlobal("cancelAnimationFrame", cancel);
|
|
42
|
-
let af;
|
|
43
|
-
effectScope(() => {
|
|
44
|
-
af = createAnimationFrames();
|
|
45
|
-
});
|
|
46
|
-
af.start();
|
|
47
|
-
af[Symbol.dispose]();
|
|
48
|
-
globalExpect(cancel).toHaveBeenCalled();
|
|
49
|
-
});
|
|
50
|
-
});
|
|
51
|
-
//#endregion
|
|
52
|
-
export {};
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { t as Computed } from "../../index-BtqiEEfc.mjs";
|
|
2
|
-
|
|
3
|
-
//#region src/signals/lib/async-retry.d.ts
|
|
4
|
-
type AsyncRetryResult<T> = {
|
|
5
|
-
data: Computed<T | undefined>;
|
|
6
|
-
loading: Computed<boolean>;
|
|
7
|
-
error: Computed<unknown>;
|
|
8
|
-
retry(): void;
|
|
9
|
-
attempt: Computed<number>;
|
|
10
|
-
};
|
|
11
|
-
/**
|
|
12
|
-
* Like `createResource` but automatically retries on failure up to
|
|
13
|
-
* `maxRetries` times with an exponential-back-off delay.
|
|
14
|
-
*/
|
|
15
|
-
declare function createAsyncRetry<S, T>(source: () => S, fetcher: (source: S, signal: AbortSignal) => Promise<T>, options?: {
|
|
16
|
-
initialValue?: T;
|
|
17
|
-
maxRetries?: number;
|
|
18
|
-
delay?: number;
|
|
19
|
-
}): AsyncRetryResult<T>;
|
|
20
|
-
//#endregion
|
|
21
|
-
export { createAsyncRetry };
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
import { a as effect, d as onCleanup, f as signal } from "../../signals-CLAPw8kk.mjs";
|
|
2
|
-
//#region src/signals/lib/async-retry.ts
|
|
3
|
-
/**
|
|
4
|
-
* Like `createResource` but automatically retries on failure up to
|
|
5
|
-
* `maxRetries` times with an exponential-back-off delay.
|
|
6
|
-
*/
|
|
7
|
-
function createAsyncRetry(source, fetcher, options) {
|
|
8
|
-
const { maxRetries = 3, delay = 1e3 } = options ?? {};
|
|
9
|
-
const data = signal(options?.initialValue);
|
|
10
|
-
const loading = signal(false);
|
|
11
|
-
const error = signal(void 0);
|
|
12
|
-
const attempt = signal(0);
|
|
13
|
-
const tick = signal(0);
|
|
14
|
-
effect(() => {
|
|
15
|
-
tick();
|
|
16
|
-
const src = source();
|
|
17
|
-
const controller = new AbortController();
|
|
18
|
-
loading(true);
|
|
19
|
-
error(void 0);
|
|
20
|
-
attempt(0);
|
|
21
|
-
let currentAttempt = 0;
|
|
22
|
-
const run = () => {
|
|
23
|
-
fetcher(src, controller.signal).then((result) => {
|
|
24
|
-
data(result);
|
|
25
|
-
loading(false);
|
|
26
|
-
}, (err) => {
|
|
27
|
-
if (err.name === "AbortError") return;
|
|
28
|
-
if (currentAttempt < maxRetries) {
|
|
29
|
-
currentAttempt++;
|
|
30
|
-
attempt(currentAttempt);
|
|
31
|
-
const retryTimer = setTimeout(run, delay * 2 ** (currentAttempt - 1));
|
|
32
|
-
const orig = cleanup;
|
|
33
|
-
cleanup = () => {
|
|
34
|
-
clearTimeout(retryTimer);
|
|
35
|
-
orig();
|
|
36
|
-
};
|
|
37
|
-
} else {
|
|
38
|
-
error(err);
|
|
39
|
-
loading(false);
|
|
40
|
-
}
|
|
41
|
-
});
|
|
42
|
-
};
|
|
43
|
-
let cleanup = () => controller.abort();
|
|
44
|
-
run();
|
|
45
|
-
onCleanup(() => cleanup());
|
|
46
|
-
});
|
|
47
|
-
const retry = () => tick(tick() + 1);
|
|
48
|
-
return {
|
|
49
|
-
data,
|
|
50
|
-
loading,
|
|
51
|
-
error,
|
|
52
|
-
attempt,
|
|
53
|
-
retry
|
|
54
|
-
};
|
|
55
|
-
}
|
|
56
|
-
//#endregion
|
|
57
|
-
export { createAsyncRetry };
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
import { o as effectScope } from "../../signals-CLAPw8kk.mjs";
|
|
2
|
-
import { a as describe, n as vi, o as it, r as afterEach, t as globalExpect } from "../../test.BmQO5GaM-CR2qjV1t.mjs";
|
|
3
|
-
import { createAsyncRetry } from "./async-retry.mjs";
|
|
4
|
-
//#region src/signals/lib/async-retry.test.ts
|
|
5
|
-
afterEach(() => {
|
|
6
|
-
document.body.innerHTML = "";
|
|
7
|
-
vi.useRealTimers();
|
|
8
|
-
});
|
|
9
|
-
describe("createAsyncRetry", () => {
|
|
10
|
-
it("resolves successfully on first try", async () => {
|
|
11
|
-
const src = () => "url";
|
|
12
|
-
let r;
|
|
13
|
-
effectScope(() => {
|
|
14
|
-
r = createAsyncRetry(src, async () => "ok");
|
|
15
|
-
});
|
|
16
|
-
await new Promise((res) => setTimeout(res, 0));
|
|
17
|
-
globalExpect(r.data()).toBe("ok");
|
|
18
|
-
globalExpect(r.loading()).toBe(false);
|
|
19
|
-
});
|
|
20
|
-
it("retries on failure and eventually resolves", async () => {
|
|
21
|
-
vi.useFakeTimers();
|
|
22
|
-
let calls = 0;
|
|
23
|
-
const src = () => "url";
|
|
24
|
-
let r;
|
|
25
|
-
effectScope(() => {
|
|
26
|
-
r = createAsyncRetry(src, async () => {
|
|
27
|
-
calls++;
|
|
28
|
-
if (calls < 3) throw new Error("fail");
|
|
29
|
-
return "success";
|
|
30
|
-
}, {
|
|
31
|
-
maxRetries: 3,
|
|
32
|
-
delay: 100
|
|
33
|
-
});
|
|
34
|
-
});
|
|
35
|
-
await vi.runAllTicks();
|
|
36
|
-
await vi.runAllTimersAsync();
|
|
37
|
-
globalExpect(r.data()).toBe("success");
|
|
38
|
-
}, 1e4);
|
|
39
|
-
it("sets error after exhausting retries", async () => {
|
|
40
|
-
vi.useFakeTimers();
|
|
41
|
-
const src = () => "url";
|
|
42
|
-
let r;
|
|
43
|
-
effectScope(() => {
|
|
44
|
-
r = createAsyncRetry(src, async () => {
|
|
45
|
-
throw new Error("persistent");
|
|
46
|
-
}, {
|
|
47
|
-
maxRetries: 2,
|
|
48
|
-
delay: 50
|
|
49
|
-
});
|
|
50
|
-
});
|
|
51
|
-
await vi.runAllTimersAsync();
|
|
52
|
-
globalExpect(r.error()).toBeInstanceOf(Error);
|
|
53
|
-
globalExpect(r.loading()).toBe(false);
|
|
54
|
-
}, 1e4);
|
|
55
|
-
});
|
|
56
|
-
//#endregion
|
|
57
|
-
export {};
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { t as Computed } from "../../index-BtqiEEfc.mjs";
|
|
2
|
-
|
|
3
|
-
//#region src/signals/lib/audio.d.ts
|
|
4
|
-
type AudioResult = {
|
|
5
|
-
element: HTMLAudioElement;
|
|
6
|
-
playing: Computed<boolean>;
|
|
7
|
-
muted: Computed<boolean>;
|
|
8
|
-
volume: Computed<number>;
|
|
9
|
-
duration: Computed<number>;
|
|
10
|
-
time: Computed<number>;
|
|
11
|
-
ended: Computed<boolean>;
|
|
12
|
-
play(): void;
|
|
13
|
-
pause(): void;
|
|
14
|
-
toggle(): void;
|
|
15
|
-
setVolume(v: number): void;
|
|
16
|
-
setTime(t: number): void;
|
|
17
|
-
mute(): void;
|
|
18
|
-
unmute(): void;
|
|
19
|
-
} & Disposable;
|
|
20
|
-
/**
|
|
21
|
-
* Wraps an `HTMLAudioElement` with reactive state and playback controls.
|
|
22
|
-
* Pass a `src` string to create a new element, or pass an existing element.
|
|
23
|
-
*/
|
|
24
|
-
declare function createAudio(src: string | HTMLAudioElement): AudioResult;
|
|
25
|
-
//#endregion
|
|
26
|
-
export { createAudio };
|