kiru 0.54.3 → 1.0.1
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/dist/{appContext.d.ts → appHandle.d.ts} +4 -4
- package/dist/appHandle.d.ts.map +1 -0
- package/dist/{appContext.js → appHandle.js} +12 -9
- package/dist/appHandle.js.map +1 -0
- package/dist/components/derive.d.ts +10 -8
- package/dist/components/derive.d.ts.map +1 -1
- package/dist/components/derive.js +50 -47
- package/dist/components/derive.js.map +1 -1
- package/dist/components/index.d.ts +0 -1
- package/dist/components/index.d.ts.map +1 -1
- package/dist/components/index.js +0 -1
- package/dist/components/index.js.map +1 -1
- package/dist/components/lazy.d.ts.map +1 -1
- package/dist/components/lazy.js +5 -4
- package/dist/components/lazy.js.map +1 -1
- package/dist/components/portal.d.ts.map +1 -1
- package/dist/components/portal.js +2 -3
- package/dist/components/portal.js.map +1 -1
- package/dist/components/transition.d.ts +3 -2
- package/dist/components/transition.d.ts.map +1 -1
- package/dist/components/transition.js +29 -26
- package/dist/components/transition.js.map +1 -1
- package/dist/constants.d.ts +1 -5
- package/dist/constants.d.ts.map +1 -1
- package/dist/constants.js +1 -5
- package/dist/constants.js.map +1 -1
- package/dist/context.d.ts +1 -1
- package/dist/context.d.ts.map +1 -1
- package/dist/context.js +25 -19
- package/dist/context.js.map +1 -1
- package/dist/devtools.d.ts +7 -0
- package/dist/devtools.d.ts.map +1 -0
- package/dist/devtools.js +15 -0
- package/dist/devtools.js.map +1 -0
- package/dist/dom.d.ts.map +1 -1
- package/dist/dom.js +25 -58
- package/dist/dom.js.map +1 -1
- package/dist/globalContext.d.ts +15 -16
- package/dist/globalContext.d.ts.map +1 -1
- package/dist/globalContext.js +36 -46
- package/dist/globalContext.js.map +1 -1
- package/dist/globals.d.ts +1 -4
- package/dist/globals.d.ts.map +1 -1
- package/dist/globals.js +1 -4
- package/dist/globals.js.map +1 -1
- package/dist/headlessRender.d.ts +6 -0
- package/dist/headlessRender.d.ts.map +1 -0
- package/dist/{recursiveRender.js → headlessRender.js} +17 -16
- package/dist/headlessRender.js.map +1 -0
- package/dist/hmr.d.ts +5 -7
- package/dist/hmr.d.ts.map +1 -1
- package/dist/hmr.js +27 -32
- package/dist/hmr.js.map +1 -1
- package/dist/hooks/index.d.ts +3 -14
- package/dist/hooks/index.d.ts.map +1 -1
- package/dist/hooks/index.js +3 -14
- package/dist/hooks/index.js.map +1 -1
- package/dist/hooks/onBeforeMount.d.ts +9 -0
- package/dist/hooks/onBeforeMount.d.ts.map +1 -0
- package/dist/hooks/onBeforeMount.js +12 -0
- package/dist/hooks/onBeforeMount.js.map +1 -0
- package/dist/hooks/onCleanup.d.ts +8 -0
- package/dist/hooks/onCleanup.d.ts.map +1 -0
- package/dist/hooks/onCleanup.js +15 -0
- package/dist/hooks/onCleanup.js.map +1 -0
- package/dist/hooks/onMount.d.ts +9 -0
- package/dist/hooks/onMount.d.ts.map +1 -0
- package/dist/hooks/onMount.js +12 -0
- package/dist/hooks/onMount.js.map +1 -0
- package/dist/hooks/utils.d.ts +2 -62
- package/dist/hooks/utils.d.ts.map +1 -1
- package/dist/hooks/utils.js +22 -144
- package/dist/hooks/utils.js.map +1 -1
- package/dist/index.d.ts +8 -4
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +8 -6
- package/dist/index.js.map +1 -1
- package/dist/profiling.d.ts +15 -14
- package/dist/profiling.d.ts.map +1 -1
- package/dist/profiling.js +9 -4
- package/dist/profiling.js.map +1 -1
- package/dist/reconciler.d.ts.map +1 -1
- package/dist/reconciler.js +12 -25
- package/dist/reconciler.js.map +1 -1
- package/dist/ref.d.ts +4 -0
- package/dist/ref.d.ts.map +1 -0
- package/dist/ref.js +4 -0
- package/dist/ref.js.map +1 -0
- package/dist/renderToString.js +1 -1
- package/dist/renderToString.js.map +1 -1
- package/dist/router/context.d.ts.map +1 -1
- package/dist/router/context.js +1 -2
- package/dist/router/context.js.map +1 -1
- package/dist/router/fileRouter.d.ts +1 -1
- package/dist/router/fileRouter.d.ts.map +1 -1
- package/dist/router/fileRouter.js +17 -11
- package/dist/router/fileRouter.js.map +1 -1
- package/dist/router/fileRouterController.d.ts.map +1 -1
- package/dist/router/fileRouterController.js +68 -55
- package/dist/router/fileRouterController.js.map +1 -1
- package/dist/router/link.d.ts.map +1 -1
- package/dist/router/link.js +19 -23
- package/dist/router/link.js.map +1 -1
- package/dist/router/server/index.d.ts.map +1 -1
- package/dist/router/server/index.js +14 -11
- package/dist/router/server/index.js.map +1 -1
- package/dist/router/types.d.ts +11 -6
- package/dist/router/types.d.ts.map +1 -1
- package/dist/scheduler.d.ts +1 -0
- package/dist/scheduler.d.ts.map +1 -1
- package/dist/scheduler.js +65 -52
- package/dist/scheduler.js.map +1 -1
- package/dist/signals/base.d.ts +0 -1
- package/dist/signals/base.d.ts.map +1 -1
- package/dist/signals/base.js +13 -36
- package/dist/signals/base.js.map +1 -1
- package/dist/signals/computed.d.ts +0 -2
- package/dist/signals/computed.d.ts.map +1 -1
- package/dist/signals/computed.js +1 -40
- package/dist/signals/computed.js.map +1 -1
- package/dist/signals/effect.d.ts +15 -14
- package/dist/signals/effect.d.ts.map +1 -1
- package/dist/signals/effect.js +65 -37
- package/dist/signals/effect.js.map +1 -1
- package/dist/signals/globals.d.ts +0 -5
- package/dist/signals/globals.d.ts.map +1 -1
- package/dist/signals/globals.js +0 -6
- package/dist/signals/globals.js.map +1 -1
- package/dist/signals/index.d.ts +4 -4
- package/dist/signals/index.d.ts.map +1 -1
- package/dist/signals/index.js +4 -4
- package/dist/signals/index.js.map +1 -1
- package/dist/signals/{for.d.ts → jsx.d.ts} +8 -1
- package/dist/signals/jsx.d.ts.map +1 -0
- package/dist/signals/{for.js → jsx.js} +4 -1
- package/dist/signals/jsx.js.map +1 -0
- package/dist/signals/tracking.d.ts +23 -0
- package/dist/signals/tracking.d.ts.map +1 -0
- package/dist/signals/tracking.js +51 -0
- package/dist/signals/tracking.js.map +1 -0
- package/dist/signals/types.d.ts +1 -1
- package/dist/signals/types.d.ts.map +1 -1
- package/dist/signals/utils.d.ts +2 -1
- package/dist/signals/utils.d.ts.map +1 -1
- package/dist/signals/utils.js +9 -2
- package/dist/signals/utils.js.map +1 -1
- package/dist/ssr/client.d.ts +3 -3
- package/dist/ssr/client.d.ts.map +1 -1
- package/dist/ssr/client.js.map +1 -1
- package/dist/ssr/server.js +1 -1
- package/dist/ssr/server.js.map +1 -1
- package/dist/statefulPromise.d.ts +22 -0
- package/dist/statefulPromise.d.ts.map +1 -0
- package/dist/statefulPromise.js +94 -0
- package/dist/statefulPromise.js.map +1 -0
- package/dist/types.d.ts +36 -50
- package/dist/types.d.ts.map +1 -1
- package/dist/types.dom.d.ts +4 -7
- package/dist/types.dom.d.ts.map +1 -1
- package/dist/types.utils.d.ts +3 -4
- package/dist/types.utils.d.ts.map +1 -1
- package/dist/utils/vdom.d.ts +8 -6
- package/dist/utils/vdom.d.ts.map +1 -1
- package/dist/utils/vdom.js +32 -9
- package/dist/utils/vdom.js.map +1 -1
- package/dist/viewTransitions.d.ts +7 -0
- package/dist/viewTransitions.d.ts.map +1 -0
- package/dist/viewTransitions.js +71 -0
- package/dist/viewTransitions.js.map +1 -0
- package/package.json +1 -1
- package/src/{appContext.ts → appHandle.ts} +21 -16
- package/src/components/derive.ts +74 -69
- package/src/components/index.ts +0 -1
- package/src/components/lazy.ts +5 -4
- package/src/components/portal.ts +2 -3
- package/src/components/transition.ts +33 -35
- package/src/constants.ts +0 -8
- package/src/context.ts +30 -23
- package/src/devtools.ts +16 -0
- package/src/dom.ts +29 -63
- package/src/globalContext.ts +57 -74
- package/src/globals.ts +1 -5
- package/src/{recursiveRender.ts → headlessRender.ts} +18 -18
- package/src/hmr.ts +29 -38
- package/src/hooks/index.ts +3 -14
- package/src/hooks/onBeforeMount.ts +12 -0
- package/src/hooks/onCleanup.ts +15 -0
- package/src/hooks/onMount.ts +12 -0
- package/src/hooks/utils.ts +28 -238
- package/src/index.ts +14 -6
- package/src/profiling.ts +22 -20
- package/src/reconciler.ts +18 -30
- package/src/ref.ts +6 -0
- package/src/renderToString.ts +1 -1
- package/src/router/context.ts +1 -2
- package/src/router/fileRouter.ts +23 -13
- package/src/router/fileRouterController.ts +72 -64
- package/src/router/link.ts +11 -25
- package/src/router/server/index.ts +24 -13
- package/src/router/types.ts +15 -8
- package/src/scheduler.ts +74 -71
- package/src/signals/base.ts +12 -41
- package/src/signals/computed.ts +1 -62
- package/src/signals/effect.ts +95 -48
- package/src/signals/globals.ts +0 -7
- package/src/signals/index.ts +4 -4
- package/src/signals/{for.ts → jsx.ts} +10 -0
- package/src/signals/tracking.ts +69 -0
- package/src/signals/types.ts +1 -1
- package/src/signals/utils.ts +9 -1
- package/src/ssr/client.ts +4 -4
- package/src/ssr/server.ts +2 -2
- package/src/statefulPromise.ts +136 -0
- package/src/types.dom.ts +4 -8
- package/src/types.ts +45 -58
- package/src/types.utils.ts +3 -4
- package/src/utils/vdom.ts +44 -15
- package/src/viewTransitions.ts +88 -0
- package/dist/appContext.d.ts.map +0 -1
- package/dist/appContext.js.map +0 -1
- package/dist/components/memo.d.ts +0 -10
- package/dist/components/memo.d.ts.map +0 -1
- package/dist/components/memo.js +0 -23
- package/dist/components/memo.js.map +0 -1
- package/dist/form/index.d.ts +0 -4
- package/dist/form/index.d.ts.map +0 -1
- package/dist/form/index.js +0 -518
- package/dist/form/index.js.map +0 -1
- package/dist/form/types.d.ts +0 -122
- package/dist/form/types.d.ts.map +0 -1
- package/dist/form/types.js +0 -2
- package/dist/form/types.js.map +0 -1
- package/dist/form/utils.d.ts +0 -3
- package/dist/form/utils.d.ts.map +0 -1
- package/dist/form/utils.js +0 -16
- package/dist/form/utils.js.map +0 -1
- package/dist/hooks/useAsync.d.ts +0 -18
- package/dist/hooks/useAsync.d.ts.map +0 -1
- package/dist/hooks/useAsync.js +0 -96
- package/dist/hooks/useAsync.js.map +0 -1
- package/dist/hooks/useCallback.d.ts +0 -7
- package/dist/hooks/useCallback.d.ts.map +0 -1
- package/dist/hooks/useCallback.js +0 -30
- package/dist/hooks/useCallback.js.map +0 -1
- package/dist/hooks/useContext.d.ts +0 -7
- package/dist/hooks/useContext.d.ts.map +0 -1
- package/dist/hooks/useContext.js +0 -59
- package/dist/hooks/useContext.js.map +0 -1
- package/dist/hooks/useEffect.d.ts +0 -8
- package/dist/hooks/useEffect.d.ts.map +0 -1
- package/dist/hooks/useEffect.js +0 -34
- package/dist/hooks/useEffect.js.map +0 -1
- package/dist/hooks/useEffectEvent.d.ts +0 -8
- package/dist/hooks/useEffectEvent.d.ts.map +0 -1
- package/dist/hooks/useEffectEvent.js +0 -23
- package/dist/hooks/useEffectEvent.js.map +0 -1
- package/dist/hooks/useId.d.ts +0 -8
- package/dist/hooks/useId.d.ts.map +0 -1
- package/dist/hooks/useId.js +0 -35
- package/dist/hooks/useId.js.map +0 -1
- package/dist/hooks/useLayoutEffect.d.ts +0 -8
- package/dist/hooks/useLayoutEffect.d.ts.map +0 -1
- package/dist/hooks/useLayoutEffect.js +0 -34
- package/dist/hooks/useLayoutEffect.js.map +0 -1
- package/dist/hooks/useMemo.d.ts +0 -8
- package/dist/hooks/useMemo.d.ts.map +0 -1
- package/dist/hooks/useMemo.js +0 -31
- package/dist/hooks/useMemo.js.map +0 -1
- package/dist/hooks/usePromise.d.ts +0 -8
- package/dist/hooks/usePromise.d.ts.map +0 -1
- package/dist/hooks/usePromise.js +0 -90
- package/dist/hooks/usePromise.js.map +0 -1
- package/dist/hooks/useReducer.d.ts +0 -7
- package/dist/hooks/useReducer.d.ts.map +0 -1
- package/dist/hooks/useReducer.js +0 -44
- package/dist/hooks/useReducer.js.map +0 -1
- package/dist/hooks/useRef.d.ts +0 -10
- package/dist/hooks/useRef.d.ts.map +0 -1
- package/dist/hooks/useRef.js +0 -29
- package/dist/hooks/useRef.js.map +0 -1
- package/dist/hooks/useState.d.ts +0 -7
- package/dist/hooks/useState.d.ts.map +0 -1
- package/dist/hooks/useState.js +0 -54
- package/dist/hooks/useState.js.map +0 -1
- package/dist/hooks/useSyncExternalStore.d.ts +0 -8
- package/dist/hooks/useSyncExternalStore.d.ts.map +0 -1
- package/dist/hooks/useSyncExternalStore.js +0 -50
- package/dist/hooks/useSyncExternalStore.js.map +0 -1
- package/dist/hooks/useViewTransition.d.ts +0 -10
- package/dist/hooks/useViewTransition.d.ts.map +0 -1
- package/dist/hooks/useViewTransition.js +0 -27
- package/dist/hooks/useViewTransition.js.map +0 -1
- package/dist/recursiveRender.d.ts +0 -7
- package/dist/recursiveRender.d.ts.map +0 -1
- package/dist/recursiveRender.js.map +0 -1
- package/dist/signals/for.d.ts.map +0 -1
- package/dist/signals/for.js.map +0 -1
- package/dist/signals/watch.d.ts +0 -21
- package/dist/signals/watch.d.ts.map +0 -1
- package/dist/signals/watch.js +0 -86
- package/dist/signals/watch.js.map +0 -1
- package/dist/store.d.ts +0 -28
- package/dist/store.d.ts.map +0 -1
- package/dist/store.js +0 -166
- package/dist/store.js.map +0 -1
- package/dist/swr.d.ts +0 -63
- package/dist/swr.d.ts.map +0 -1
- package/dist/swr.js +0 -236
- package/dist/swr.js.map +0 -1
- package/dist/utils/promise.d.ts +0 -16
- package/dist/utils/promise.d.ts.map +0 -1
- package/dist/utils/promise.js +0 -14
- package/dist/utils/promise.js.map +0 -1
- package/src/components/memo.ts +0 -39
- package/src/form/index.ts +0 -676
- package/src/form/types.ts +0 -262
- package/src/form/utils.ts +0 -19
- package/src/hooks/useAsync.ts +0 -121
- package/src/hooks/useCallback.ts +0 -32
- package/src/hooks/useContext.ts +0 -79
- package/src/hooks/useEffect.ts +0 -40
- package/src/hooks/useEffectEvent.ts +0 -24
- package/src/hooks/useId.ts +0 -42
- package/src/hooks/useLayoutEffect.ts +0 -43
- package/src/hooks/useMemo.ts +0 -34
- package/src/hooks/usePromise.ts +0 -126
- package/src/hooks/useReducer.ts +0 -50
- package/src/hooks/useRef.ts +0 -41
- package/src/hooks/useState.ts +0 -62
- package/src/hooks/useSyncExternalStore.ts +0 -59
- package/src/hooks/useViewTransition.ts +0 -25
- package/src/signals/watch.ts +0 -139
- package/src/store.ts +0 -245
- package/src/swr.ts +0 -351
- package/src/utils/promise.ts +0 -26
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { flushSync } from "./scheduler.js";
|
|
2
|
+
export var ViewTransitions;
|
|
3
|
+
(function (ViewTransitions) {
|
|
4
|
+
const jobs = [];
|
|
5
|
+
let running = false;
|
|
6
|
+
let scheduled = false;
|
|
7
|
+
let transition = null;
|
|
8
|
+
const supported = "window" in globalThis && typeof document.startViewTransition === "function";
|
|
9
|
+
function run(callback, options) {
|
|
10
|
+
const signal = options?.signal;
|
|
11
|
+
return new Promise((resolve) => {
|
|
12
|
+
const job = async () => {
|
|
13
|
+
const result = await callback();
|
|
14
|
+
resolve(result);
|
|
15
|
+
};
|
|
16
|
+
jobs.push(job);
|
|
17
|
+
signal?.addEventListener("abort", () => {
|
|
18
|
+
const i = jobs.indexOf(job);
|
|
19
|
+
if (i !== -1) {
|
|
20
|
+
jobs.splice(i, 1);
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
transition?.skipTransition();
|
|
24
|
+
}
|
|
25
|
+
}, { once: true });
|
|
26
|
+
schedule();
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
ViewTransitions.run = run;
|
|
30
|
+
function stop() {
|
|
31
|
+
transition?.skipTransition();
|
|
32
|
+
transition = null;
|
|
33
|
+
jobs.length = 0;
|
|
34
|
+
running = false;
|
|
35
|
+
scheduled = false;
|
|
36
|
+
}
|
|
37
|
+
ViewTransitions.stop = stop;
|
|
38
|
+
function schedule() {
|
|
39
|
+
if (scheduled)
|
|
40
|
+
return;
|
|
41
|
+
scheduled = true;
|
|
42
|
+
queueMicrotask(() => {
|
|
43
|
+
scheduled = false;
|
|
44
|
+
runJobs();
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
async function runJobs() {
|
|
48
|
+
if (running || jobs.length === 0)
|
|
49
|
+
return;
|
|
50
|
+
running = true;
|
|
51
|
+
const __jobs = [...jobs];
|
|
52
|
+
jobs.length = 0;
|
|
53
|
+
const runJobs = async () => {
|
|
54
|
+
await Promise.all(__jobs.map((j) => j()));
|
|
55
|
+
flushSync();
|
|
56
|
+
};
|
|
57
|
+
if (!supported) {
|
|
58
|
+
await runJobs();
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
transition = document.startViewTransition(runJobs);
|
|
62
|
+
await transition.finished;
|
|
63
|
+
}
|
|
64
|
+
transition = null;
|
|
65
|
+
running = false;
|
|
66
|
+
if (jobs.length > 0) {
|
|
67
|
+
schedule();
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
})(ViewTransitions || (ViewTransitions = {}));
|
|
71
|
+
//# sourceMappingURL=viewTransitions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"viewTransitions.js","sourceRoot":"","sources":["../src/viewTransitions.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -2,17 +2,18 @@ import { FLAG_STATIC_DOM } from "./constants.js"
|
|
|
2
2
|
import { __DEV__ } from "./env.js"
|
|
3
3
|
import { renderRootSync, requestUpdate } from "./scheduler.js"
|
|
4
4
|
import { createVNode } from "./vNode.js"
|
|
5
|
+
import type { SomeDom } from "./types.utils.js"
|
|
5
6
|
|
|
6
7
|
type VNode = Kiru.VNode
|
|
7
8
|
|
|
8
|
-
export interface
|
|
9
|
+
export interface AppHandleOptions {
|
|
9
10
|
/**
|
|
10
11
|
* App name - shown in devtools
|
|
11
12
|
*/
|
|
12
13
|
name?: string
|
|
13
14
|
}
|
|
14
15
|
|
|
15
|
-
export interface
|
|
16
|
+
export interface AppHandle {
|
|
16
17
|
id: number
|
|
17
18
|
name: string
|
|
18
19
|
rootNode: VNode
|
|
@@ -24,9 +25,9 @@ let appId = 0
|
|
|
24
25
|
|
|
25
26
|
export function mount(
|
|
26
27
|
children: JSX.Element,
|
|
27
|
-
container:
|
|
28
|
-
options?:
|
|
29
|
-
):
|
|
28
|
+
container: Kiru.ContainerElement,
|
|
29
|
+
options?: AppHandleOptions
|
|
30
|
+
): AppHandle {
|
|
30
31
|
if (__DEV__) {
|
|
31
32
|
if (container.__kiruNode) {
|
|
32
33
|
throw new Error(
|
|
@@ -36,7 +37,7 @@ export function mount(
|
|
|
36
37
|
}
|
|
37
38
|
const rootNode = createRootNode(container)
|
|
38
39
|
const id = appId++
|
|
39
|
-
const
|
|
40
|
+
const app: AppHandle = {
|
|
40
41
|
id,
|
|
41
42
|
name: options?.name ?? `App-${id}`,
|
|
42
43
|
rootNode,
|
|
@@ -45,39 +46,43 @@ export function mount(
|
|
|
45
46
|
}
|
|
46
47
|
|
|
47
48
|
function render(children: JSX.Element) {
|
|
48
|
-
rootNode.props
|
|
49
|
+
rootNode.props = { children }
|
|
49
50
|
renderRootSync(rootNode)
|
|
50
51
|
}
|
|
51
52
|
|
|
52
53
|
function unmount() {
|
|
53
|
-
rootNode.props
|
|
54
|
+
rootNode.props = { children: null }
|
|
54
55
|
renderRootSync(rootNode)
|
|
55
56
|
if (__DEV__) {
|
|
56
|
-
delete container.__kiruNode
|
|
57
|
+
delete (container as HTMLElement).__kiruNode
|
|
57
58
|
delete rootNode.app
|
|
58
59
|
}
|
|
59
|
-
window.__kiru.emit("unmount",
|
|
60
|
+
window.__kiru.emit("unmount", app)
|
|
60
61
|
}
|
|
61
62
|
|
|
62
63
|
if (__DEV__) {
|
|
63
|
-
rootNode.app =
|
|
64
|
+
rootNode.app = app
|
|
64
65
|
}
|
|
65
66
|
|
|
66
67
|
render(children)
|
|
67
|
-
window.__kiru.emit("mount",
|
|
68
|
-
|
|
68
|
+
window.__kiru.emit("mount", app, requestUpdate)
|
|
69
|
+
// @ts-expect-error
|
|
70
|
+
if (__DEV__ && !globalThis.__KIRU_READY__) {
|
|
71
|
+
// @ts-expect-error
|
|
72
|
+
globalThis.__KIRU_READY__ = true
|
|
73
|
+
|
|
69
74
|
queueMicrotask(() => {
|
|
70
75
|
window.dispatchEvent(new Event("kiru:ready"))
|
|
71
76
|
})
|
|
72
77
|
}
|
|
73
78
|
|
|
74
|
-
return
|
|
79
|
+
return app
|
|
75
80
|
}
|
|
76
81
|
|
|
77
|
-
function createRootNode(container:
|
|
82
|
+
function createRootNode(container: Kiru.ContainerElement): Kiru.VNode {
|
|
78
83
|
const node = createVNode(container.nodeName.toLowerCase())
|
|
79
84
|
node.flags |= FLAG_STATIC_DOM
|
|
80
|
-
node.dom = container
|
|
85
|
+
node.dom = container as SomeDom
|
|
81
86
|
if (__DEV__) {
|
|
82
87
|
container.__kiruNode = node
|
|
83
88
|
}
|
package/src/components/derive.ts
CHANGED
|
@@ -1,32 +1,33 @@
|
|
|
1
1
|
import { node } from "../globals.js"
|
|
2
2
|
import { $STREAM_DATA } from "../constants.js"
|
|
3
3
|
import { requestUpdate } from "../scheduler.js"
|
|
4
|
-
import { useRef } from "../hooks/index.js"
|
|
5
4
|
import { Signal } from "../signals/index.js"
|
|
6
5
|
import { sideEffectsEnabled } from "../utils/index.js"
|
|
7
6
|
import type { RecordHas } from "../types.utils"
|
|
8
|
-
import { isStatefulPromise, StreamDataThrowValue } from "../
|
|
7
|
+
import { isStatefulPromise, StreamDataThrowValue } from "../statefulPromise.js"
|
|
8
|
+
import { ref } from "../ref.js"
|
|
9
9
|
|
|
10
10
|
export type Derivable =
|
|
11
11
|
| Kiru.Signal<unknown>
|
|
12
|
-
| Kiru.
|
|
13
|
-
| Record<string, Kiru.Signal<unknown> | Kiru.
|
|
12
|
+
| Kiru.StatefulPromiseBase<unknown>
|
|
13
|
+
| Record<string, Kiru.Signal<unknown> | Kiru.StatefulPromiseBase<unknown>>
|
|
14
14
|
|
|
15
|
-
type InnerOf<T> =
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
15
|
+
type InnerOf<T> =
|
|
16
|
+
T extends Kiru.Signal<infer V>
|
|
17
|
+
? V
|
|
18
|
+
: T extends Kiru.StatefulPromiseBase<infer P>
|
|
19
|
+
? P
|
|
20
|
+
: never
|
|
20
21
|
|
|
21
22
|
type UnwrapDerive<T extends Derivable> = T extends
|
|
22
23
|
| Kiru.Signal<unknown>
|
|
23
|
-
| Kiru.
|
|
24
|
+
| Kiru.StatefulPromiseBase<any>
|
|
24
25
|
? InnerOf<T>
|
|
25
26
|
: { [K in keyof T]: InnerOf<T[K]> }
|
|
26
27
|
|
|
27
28
|
type RecordHasPromise<T extends Record<string, any>> = RecordHas<
|
|
28
29
|
T,
|
|
29
|
-
Kiru.
|
|
30
|
+
Kiru.StatefulPromiseBase<any>
|
|
30
31
|
>
|
|
31
32
|
|
|
32
33
|
type ChildFn<T> = (value: T) => JSX.Children
|
|
@@ -36,86 +37,90 @@ export type DeriveFallbackMode = "swr" | "fallback"
|
|
|
36
37
|
|
|
37
38
|
export interface DeriveProps<
|
|
38
39
|
T extends Derivable,
|
|
39
|
-
Mode extends DeriveFallbackMode = "fallback"
|
|
40
|
+
Mode extends DeriveFallbackMode = "fallback",
|
|
40
41
|
> {
|
|
41
42
|
from: T
|
|
42
43
|
mode?: Mode
|
|
43
|
-
children: T extends Kiru.
|
|
44
|
+
children: T extends Kiru.StatefulPromiseBase<infer U>
|
|
44
45
|
? Mode extends "swr"
|
|
45
46
|
? ChildFnWithStale<U>
|
|
46
47
|
: ChildFn<U>
|
|
47
48
|
: T extends Record<string, any>
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
49
|
+
? RecordHasPromise<T> extends true
|
|
50
|
+
? Mode extends "swr"
|
|
51
|
+
? ChildFnWithStale<UnwrapDerive<T>>
|
|
52
|
+
: ChildFn<UnwrapDerive<T>>
|
|
51
53
|
: ChildFn<UnwrapDerive<T>>
|
|
52
54
|
: ChildFn<UnwrapDerive<T>>
|
|
53
|
-
|
|
54
|
-
fallback?: T extends Kiru.StatefulPromise<any>
|
|
55
|
+
fallback?: T extends Kiru.StatefulPromiseBase<any>
|
|
55
56
|
? JSX.Element
|
|
56
57
|
: T extends Record<string, any>
|
|
57
|
-
|
|
58
|
-
|
|
58
|
+
? RecordHasPromise<T> extends true
|
|
59
|
+
? JSX.Element
|
|
60
|
+
: never
|
|
59
61
|
: never
|
|
60
|
-
: never
|
|
61
62
|
}
|
|
62
63
|
|
|
63
|
-
|
|
64
|
-
T extends Derivable,
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
const prevSuccess = useRef<UnwrapDerive<T> | null>(null)
|
|
64
|
+
type Derive = {
|
|
65
|
+
<T extends Derivable, U extends DeriveFallbackMode = "swr">(
|
|
66
|
+
props: DeriveProps<T, U>
|
|
67
|
+
): (props: DeriveProps<T, U>) => JSX.Element
|
|
68
|
+
}
|
|
69
69
|
|
|
70
|
-
|
|
71
|
-
|
|
70
|
+
export const Derive: Derive = () => {
|
|
71
|
+
return (props) => {
|
|
72
|
+
const { from, children, fallback, mode } = props
|
|
73
|
+
const prevSuccess = ref<unknown>(null)
|
|
72
74
|
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
value = from.value as UnwrapDerive<T>
|
|
76
|
-
} else if (Signal.isSignal(from)) {
|
|
77
|
-
value = from.value as UnwrapDerive<T>
|
|
78
|
-
} else {
|
|
79
|
-
const out: Record<string, any> = {}
|
|
80
|
-
for (const key in from) {
|
|
81
|
-
const v = from[key]
|
|
82
|
-
if (isStatefulPromise(v)) promises.add(v)
|
|
83
|
-
out[key] = (v as Signal<unknown> | Kiru.StatefulPromise<unknown>).value
|
|
84
|
-
}
|
|
85
|
-
value = out as UnwrapDerive<T>
|
|
86
|
-
}
|
|
75
|
+
const promises = new Set<Kiru.StatefulPromiseBase<any>>()
|
|
76
|
+
let value: unknown
|
|
87
77
|
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
78
|
+
if (isStatefulPromise(from)) {
|
|
79
|
+
promises.add(from)
|
|
80
|
+
value = from.value as unknown
|
|
81
|
+
} else if (Signal.isSignal(from)) {
|
|
82
|
+
value = from.value as unknown
|
|
83
|
+
} else {
|
|
84
|
+
const out: Record<string, any> = {}
|
|
85
|
+
for (const key in from) {
|
|
86
|
+
const v = from[key]
|
|
87
|
+
if (isStatefulPromise(v)) promises.add(v)
|
|
88
|
+
out[key] = (
|
|
89
|
+
v as Signal<unknown> | Kiru.StatefulPromiseBase<unknown>
|
|
90
|
+
).value
|
|
91
|
+
}
|
|
92
|
+
value = out as unknown
|
|
93
|
+
}
|
|
91
94
|
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
fallback,
|
|
96
|
-
data: Array.from(promises),
|
|
97
|
-
},
|
|
98
|
-
} satisfies StreamDataThrowValue
|
|
99
|
-
}
|
|
95
|
+
if (promises.size === 0) {
|
|
96
|
+
return (children as ChildFn<unknown>)(value)
|
|
97
|
+
}
|
|
100
98
|
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
99
|
+
if (!sideEffectsEnabled()) {
|
|
100
|
+
throw {
|
|
101
|
+
[$STREAM_DATA]: {
|
|
102
|
+
fallback,
|
|
103
|
+
data: Array.from(promises),
|
|
104
|
+
},
|
|
105
|
+
} satisfies StreamDataThrowValue
|
|
104
106
|
}
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
107
|
+
for (const p of promises) {
|
|
108
|
+
if (p.state === "rejected") {
|
|
109
|
+
throw p.error
|
|
110
|
+
}
|
|
111
|
+
if (p.state === "pending") {
|
|
112
|
+
const nodeRef = node.current!
|
|
113
|
+
Promise.allSettled(promises).then(() => requestUpdate(nodeRef))
|
|
108
114
|
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
115
|
+
const prev = prevSuccess.current!
|
|
116
|
+
if (mode !== "fallback" && prev) {
|
|
117
|
+
return (children as ChildFnWithStale<unknown>)(prev, true)
|
|
118
|
+
}
|
|
119
|
+
return fallback
|
|
114
120
|
}
|
|
115
|
-
return fallback
|
|
116
121
|
}
|
|
117
|
-
}
|
|
118
122
|
|
|
119
|
-
|
|
120
|
-
|
|
123
|
+
prevSuccess.current = value
|
|
124
|
+
return (children as ChildFnWithStale<unknown>)(value, false)
|
|
125
|
+
}
|
|
121
126
|
}
|
package/src/components/index.ts
CHANGED
package/src/components/lazy.ts
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { createElement } from "../element.js"
|
|
2
2
|
import { __DEV__ } from "../env.js"
|
|
3
|
-
import { useRequestUpdate } from "../hooks/utils.js"
|
|
4
3
|
import { sideEffectsEnabled } from "../utils/runtime.js"
|
|
4
|
+
import { node } from "../globals.js"
|
|
5
|
+
import { requestUpdate } from "../scheduler.js"
|
|
5
6
|
|
|
6
7
|
interface FCModule {
|
|
7
8
|
default: Kiru.FC<any>
|
|
@@ -33,7 +34,7 @@ export function lazy<T extends LazyImportValue>(
|
|
|
33
34
|
): Kiru.FC<LazyComponentProps<T>> {
|
|
34
35
|
function LazyWrapper(props: LazyComponentProps<T>) {
|
|
35
36
|
const { fallback = null, ...rest } = props
|
|
36
|
-
const
|
|
37
|
+
const nodeRef = node.current!
|
|
37
38
|
if (!sideEffectsEnabled()) {
|
|
38
39
|
return fallback
|
|
39
40
|
}
|
|
@@ -53,13 +54,13 @@ export function lazy<T extends LazyImportValue>(
|
|
|
53
54
|
typeof componentOrModule === "function"
|
|
54
55
|
? componentOrModule
|
|
55
56
|
: componentOrModule.default
|
|
56
|
-
requestUpdate()
|
|
57
|
+
requestUpdate(nodeRef)
|
|
57
58
|
})
|
|
58
59
|
return fallback
|
|
59
60
|
}
|
|
60
61
|
|
|
61
62
|
if (cachedState.result === null) {
|
|
62
|
-
cachedState.promise.then(requestUpdate)
|
|
63
|
+
cachedState.promise.then(() => requestUpdate(nodeRef))
|
|
63
64
|
return fallback
|
|
64
65
|
}
|
|
65
66
|
|
package/src/components/portal.ts
CHANGED
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
import { FLAG_STATIC_DOM } from "../constants.js"
|
|
2
2
|
import { __DEV__ } from "../env.js"
|
|
3
3
|
import { KiruError } from "../error.js"
|
|
4
|
-
import { renderMode } from "../globals.js"
|
|
5
|
-
import { useVNode } from "../hooks/utils.js"
|
|
4
|
+
import { node, renderMode } from "../globals.js"
|
|
6
5
|
import { nextIdle, requestUpdate } from "../scheduler.js"
|
|
7
6
|
|
|
8
7
|
interface PortalProps {
|
|
@@ -11,7 +10,7 @@ interface PortalProps {
|
|
|
11
10
|
}
|
|
12
11
|
|
|
13
12
|
export function Portal({ children, container }: PortalProps) {
|
|
14
|
-
const vNode =
|
|
13
|
+
const vNode = node.current!
|
|
15
14
|
if (!vNode.dom) {
|
|
16
15
|
vNode.flags |= FLAG_STATIC_DOM
|
|
17
16
|
switch (renderMode.current) {
|
|
@@ -1,12 +1,11 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import { useState } from "../hooks/useState.js"
|
|
1
|
+
import { onCleanup } from "../hooks/onCleanup.js"
|
|
2
|
+
import { signal, Signal } from "../signals/base.js"
|
|
3
|
+
import { effect } from "../signals/effect.js"
|
|
4
|
+
import { unwrap } from "../signals/utils.js"
|
|
6
5
|
|
|
7
6
|
export type TransitionState = "entering" | "entered" | "exiting" | "exited"
|
|
8
7
|
interface TransitionProps {
|
|
9
|
-
in: boolean
|
|
8
|
+
in: boolean | Signal<boolean>
|
|
10
9
|
/**
|
|
11
10
|
* Initial state of the transition
|
|
12
11
|
* @default "exited"
|
|
@@ -22,43 +21,42 @@ interface TransitionProps {
|
|
|
22
21
|
onTransitionEnd?: (state: "entered" | "exited") => void
|
|
23
22
|
}
|
|
24
23
|
|
|
25
|
-
export
|
|
26
|
-
const
|
|
27
|
-
|
|
28
|
-
)
|
|
29
|
-
const timeoutRef = useRef<number | null>(null)
|
|
24
|
+
export const Transition: Kiru.FC<TransitionProps> = (props) => {
|
|
25
|
+
const tState = signal<TransitionState>(props.initialState || "exited")
|
|
26
|
+
let timeoutRef: number | null = null
|
|
30
27
|
|
|
31
|
-
|
|
32
|
-
|
|
28
|
+
const setTransitionState = (transitionState: TransitionState) => {
|
|
29
|
+
clearTimeout(timeoutRef)
|
|
30
|
+
tState.value = transitionState
|
|
31
|
+
if (transitionState === "entered" || transitionState === "exited") {
|
|
32
|
+
if (props.onTransitionEnd) props.onTransitionEnd(transitionState)
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
const queueStateChange = (transitionState: "entered" | "exited") => {
|
|
37
|
+
timeoutRef = window.setTimeout(
|
|
38
|
+
() => setTransitionState(transitionState),
|
|
39
|
+
getTiming(transitionState, props.duration)
|
|
40
|
+
)
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
effect(() => {
|
|
44
|
+
const newIn = unwrap(props.in, true)
|
|
45
|
+
const current = tState.peek()
|
|
46
|
+
if (newIn && current !== "entered" && current !== "entering") {
|
|
33
47
|
setTransitionState("entering")
|
|
34
48
|
queueStateChange("entered")
|
|
35
|
-
} else if (!
|
|
49
|
+
} else if (!newIn && current !== "exited" && current !== "exiting") {
|
|
36
50
|
setTransitionState("exiting")
|
|
37
51
|
queueStateChange("exited")
|
|
38
52
|
}
|
|
39
|
-
}
|
|
53
|
+
})
|
|
40
54
|
|
|
41
|
-
|
|
55
|
+
onCleanup(() => clearTimeout(timeoutRef))
|
|
42
56
|
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
if (transitionState === "entered" || transitionState === "exited") {
|
|
47
|
-
if (props.onTransitionEnd) props.onTransitionEnd(transitionState)
|
|
48
|
-
}
|
|
49
|
-
}, [])
|
|
50
|
-
|
|
51
|
-
const queueStateChange = useCallback(
|
|
52
|
-
(transitionState: "entered" | "exited") => {
|
|
53
|
-
timeoutRef.current = window.setTimeout(
|
|
54
|
-
() => setTransitionState(transitionState),
|
|
55
|
-
getTiming(transitionState, props.duration)
|
|
56
|
-
)
|
|
57
|
-
},
|
|
58
|
-
[props.duration]
|
|
59
|
-
)
|
|
60
|
-
|
|
61
|
-
return props.element(tState)
|
|
57
|
+
return (newProps: TransitionProps) => {
|
|
58
|
+
return newProps.element(tState.value)
|
|
59
|
+
}
|
|
62
60
|
}
|
|
63
61
|
|
|
64
62
|
const defaultDuration = 150
|
package/src/constants.ts
CHANGED
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
export {
|
|
2
2
|
$SIGNAL,
|
|
3
3
|
$CONTEXT,
|
|
4
|
-
$CONTEXT_PROVIDER,
|
|
5
4
|
$FRAGMENT,
|
|
6
5
|
$KIRU_ERROR,
|
|
7
6
|
$HMR_ACCEPT,
|
|
8
|
-
$MEMO,
|
|
9
7
|
$ERROR_BOUNDARY,
|
|
10
8
|
$STREAM_DATA,
|
|
11
9
|
$DEV_FILE_LINK,
|
|
@@ -16,8 +14,6 @@ export {
|
|
|
16
14
|
FLAG_PLACEMENT,
|
|
17
15
|
FLAG_DELETION,
|
|
18
16
|
FLAG_STATIC_DOM,
|
|
19
|
-
FLAG_MEMO,
|
|
20
|
-
FLAG_NOOP,
|
|
21
17
|
FLAG_DIRTY,
|
|
22
18
|
}
|
|
23
19
|
|
|
@@ -25,11 +21,9 @@ export { voidElements, svgTags, booleanAttributes, snakeCaseAttributes }
|
|
|
25
21
|
|
|
26
22
|
const $SIGNAL = Symbol.for("kiru.signal")
|
|
27
23
|
const $CONTEXT = Symbol.for("kiru.context")
|
|
28
|
-
const $CONTEXT_PROVIDER = Symbol.for("kiru.contextProvider")
|
|
29
24
|
const $FRAGMENT = Symbol.for("kiru.fragment")
|
|
30
25
|
const $KIRU_ERROR = Symbol.for("kiru.error")
|
|
31
26
|
const $HMR_ACCEPT = Symbol.for("kiru.hmrAccept")
|
|
32
|
-
const $MEMO = Symbol.for("kiru.memo")
|
|
33
27
|
const $ERROR_BOUNDARY = Symbol.for("kiru.errorBoundary")
|
|
34
28
|
const $STREAM_DATA = Symbol.for("kiru.streamData")
|
|
35
29
|
const $DEV_FILE_LINK = Symbol.for("kiru.devFileLink")
|
|
@@ -41,8 +35,6 @@ const FLAG_UPDATE = 1 << 1
|
|
|
41
35
|
const FLAG_PLACEMENT = 1 << 2
|
|
42
36
|
const FLAG_DELETION = 1 << 3
|
|
43
37
|
const FLAG_STATIC_DOM = 1 << 4
|
|
44
|
-
const FLAG_MEMO = 1 << 5
|
|
45
|
-
const FLAG_NOOP = 1 << 6
|
|
46
38
|
const FLAG_DIRTY = 1 << 7
|
|
47
39
|
|
|
48
40
|
const EVENT_PREFIX_REGEX = /^on:?/
|
package/src/context.ts
CHANGED
|
@@ -1,30 +1,37 @@
|
|
|
1
|
-
import { $CONTEXT
|
|
1
|
+
import { $CONTEXT } from "./constants.js"
|
|
2
2
|
import { createElement } from "./element.js"
|
|
3
|
-
import {
|
|
3
|
+
import type { ContextNode } from "./types.utils.js"
|
|
4
|
+
import { node } from "./globals.js"
|
|
4
5
|
|
|
5
6
|
export function createContext<T>(defaultValue: T): Kiru.Context<T> {
|
|
6
|
-
const
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
)
|
|
15
|
-
},
|
|
16
|
-
default: () => defaultValue,
|
|
17
|
-
set displayName(name: string) {
|
|
18
|
-
this.Provider.displayName = name
|
|
19
|
-
},
|
|
20
|
-
get displayName() {
|
|
21
|
-
return this.Provider.displayName || "Anonymous Context"
|
|
22
|
-
},
|
|
23
|
-
}
|
|
7
|
+
const Context: Kiru.Context<T> = Object.assign(
|
|
8
|
+
({ value, children }: Kiru.ContextProps<T>) =>
|
|
9
|
+
createElement($CONTEXT, { value, ctx: Context }, children),
|
|
10
|
+
{ [$CONTEXT]: () => defaultValue }
|
|
11
|
+
)
|
|
12
|
+
Context.displayName = "Anonymous Context"
|
|
13
|
+
return Context
|
|
14
|
+
}
|
|
24
15
|
|
|
25
|
-
|
|
16
|
+
function getContextValue<T>(vNode: Kiru.VNode, context: Kiru.Context<T>): T {
|
|
17
|
+
let n = vNode.parent
|
|
18
|
+
while (n) {
|
|
19
|
+
if (n.type === $CONTEXT) {
|
|
20
|
+
const provider = n as ContextNode<unknown>
|
|
21
|
+
const { ctx, value } = provider.props
|
|
22
|
+
if (ctx === context) {
|
|
23
|
+
return value as T
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
n = n.parent
|
|
27
|
+
}
|
|
28
|
+
return context[$CONTEXT]()
|
|
26
29
|
}
|
|
27
30
|
|
|
28
|
-
export function
|
|
29
|
-
|
|
31
|
+
export function useContext<T>(context: Kiru.Context<T>): T {
|
|
32
|
+
const n = node.current
|
|
33
|
+
if (!n) {
|
|
34
|
+
throw new Error("useContext must be called inside a Kiru component")
|
|
35
|
+
}
|
|
36
|
+
return getContextValue(n, context)
|
|
30
37
|
}
|
package/src/devtools.ts
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { DebuggerEntry } from "./globalContext"
|
|
2
|
+
|
|
3
|
+
export namespace DevTools {
|
|
4
|
+
export const track = (signal: Kiru.Signal<unknown>, label?: string) => {
|
|
5
|
+
window.__kiru.devtools?.track(signal, label)
|
|
6
|
+
}
|
|
7
|
+
export const untrack = (signal: Kiru.Signal<unknown>) => {
|
|
8
|
+
window.__kiru.devtools?.untrack(signal)
|
|
9
|
+
}
|
|
10
|
+
export const subscribe = (
|
|
11
|
+
callback: (entries: Set<DebuggerEntry>) => void
|
|
12
|
+
) => {
|
|
13
|
+
if (!window.__kiru.devtools) return () => {}
|
|
14
|
+
return window.__kiru.devtools?.subscribe(callback)
|
|
15
|
+
}
|
|
16
|
+
}
|