kiru 0.44.4 → 0.45.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 (310) hide show
  1. package/README.md +3 -3
  2. package/dist/appContext.d.ts +38 -0
  3. package/dist/appContext.d.ts.map +1 -0
  4. package/dist/appContext.js +143 -0
  5. package/dist/appContext.js.map +1 -0
  6. package/dist/cloneVNode.d.ts +2 -0
  7. package/dist/cloneVNode.d.ts.map +1 -0
  8. package/dist/cloneVNode.js +14 -0
  9. package/dist/cloneVNode.js.map +1 -0
  10. package/dist/constants.d.ts +31 -0
  11. package/dist/constants.d.ts.map +1 -0
  12. package/dist/constants.js +127 -0
  13. package/dist/constants.js.map +1 -0
  14. package/dist/context.d.ts +3 -0
  15. package/dist/context.d.ts.map +1 -0
  16. package/dist/context.js +50 -0
  17. package/dist/context.js.map +1 -0
  18. package/dist/dom.d.ts +8 -0
  19. package/dist/dom.d.ts.map +1 -0
  20. package/dist/dom.js +582 -0
  21. package/dist/dom.js.map +1 -0
  22. package/dist/element.d.ts +6 -0
  23. package/dist/element.d.ts.map +1 -0
  24. package/dist/element.js +41 -0
  25. package/dist/element.js.map +1 -0
  26. package/dist/env.d.ts +2 -0
  27. package/dist/env.d.ts.map +1 -0
  28. package/dist/env.js +6 -0
  29. package/dist/env.js.map +1 -0
  30. package/dist/error.d.ts +19 -0
  31. package/dist/error.d.ts.map +1 -0
  32. package/dist/error.js +63 -0
  33. package/dist/error.js.map +1 -0
  34. package/dist/flags.d.ts +6 -0
  35. package/dist/flags.d.ts.map +1 -0
  36. package/dist/flags.js +16 -0
  37. package/dist/flags.js.map +1 -0
  38. package/dist/form/index.d.ts +4 -0
  39. package/dist/form/index.d.ts.map +1 -0
  40. package/dist/form/index.js +509 -0
  41. package/dist/form/index.js.map +1 -0
  42. package/dist/form/types.d.ts +121 -0
  43. package/dist/form/types.d.ts.map +1 -0
  44. package/dist/form/types.js +2 -0
  45. package/dist/form/types.js.map +1 -0
  46. package/dist/form/utils.d.ts +3 -0
  47. package/dist/form/utils.d.ts.map +1 -0
  48. package/dist/form/utils.js +16 -0
  49. package/dist/form/utils.js.map +1 -0
  50. package/dist/generateId.d.ts +8 -0
  51. package/dist/generateId.d.ts.map +1 -0
  52. package/dist/generateId.js +15 -0
  53. package/dist/generateId.js.map +1 -0
  54. package/dist/globalContext.d.ts +37 -0
  55. package/dist/globalContext.d.ts.map +1 -0
  56. package/dist/globalContext.js +85 -0
  57. package/dist/globalContext.js.map +1 -0
  58. package/dist/globals.d.ts +16 -0
  59. package/dist/globals.d.ts.map +1 -0
  60. package/dist/globals.js +15 -0
  61. package/dist/globals.js.map +1 -0
  62. package/dist/hmr.d.ts +32 -0
  63. package/dist/hmr.d.ts.map +1 -0
  64. package/dist/hmr.js +125 -0
  65. package/dist/hmr.js.map +1 -0
  66. package/dist/hooks/index.d.ts +15 -0
  67. package/dist/hooks/index.d.ts.map +1 -0
  68. package/dist/hooks/index.js +15 -0
  69. package/dist/hooks/index.js.map +1 -0
  70. package/dist/hooks/useAsync.d.ts +29 -0
  71. package/dist/hooks/useAsync.d.ts.map +1 -0
  72. package/dist/hooks/useAsync.js +96 -0
  73. package/dist/hooks/useAsync.js.map +1 -0
  74. package/dist/hooks/useCallback.d.ts +7 -0
  75. package/dist/hooks/useCallback.d.ts.map +1 -0
  76. package/dist/hooks/useCallback.js +29 -0
  77. package/dist/hooks/useCallback.js.map +1 -0
  78. package/dist/hooks/useContext.d.ts +7 -0
  79. package/dist/hooks/useContext.d.ts.map +1 -0
  80. package/dist/hooks/useContext.js +59 -0
  81. package/dist/hooks/useContext.js.map +1 -0
  82. package/dist/hooks/useEffect.d.ts +8 -0
  83. package/dist/hooks/useEffect.d.ts.map +1 -0
  84. package/dist/hooks/useEffect.js +33 -0
  85. package/dist/hooks/useEffect.js.map +1 -0
  86. package/dist/hooks/useEffectEvent.d.ts +8 -0
  87. package/dist/hooks/useEffectEvent.d.ts.map +1 -0
  88. package/dist/hooks/useEffectEvent.js +22 -0
  89. package/dist/hooks/useEffectEvent.js.map +1 -0
  90. package/dist/hooks/useId.d.ts +8 -0
  91. package/dist/hooks/useId.d.ts.map +1 -0
  92. package/dist/hooks/useId.js +35 -0
  93. package/dist/hooks/useId.js.map +1 -0
  94. package/dist/hooks/useLayoutEffect.d.ts +8 -0
  95. package/dist/hooks/useLayoutEffect.d.ts.map +1 -0
  96. package/dist/hooks/useLayoutEffect.js +33 -0
  97. package/dist/hooks/useLayoutEffect.js.map +1 -0
  98. package/dist/hooks/useMemo.d.ts +8 -0
  99. package/dist/hooks/useMemo.d.ts.map +1 -0
  100. package/dist/hooks/useMemo.js +30 -0
  101. package/dist/hooks/useMemo.js.map +1 -0
  102. package/dist/hooks/useReducer.d.ts +7 -0
  103. package/dist/hooks/useReducer.d.ts.map +1 -0
  104. package/dist/hooks/useReducer.js +44 -0
  105. package/dist/hooks/useReducer.js.map +1 -0
  106. package/dist/hooks/useRef.d.ts +10 -0
  107. package/dist/hooks/useRef.d.ts.map +1 -0
  108. package/dist/hooks/useRef.js +28 -0
  109. package/dist/hooks/useRef.js.map +1 -0
  110. package/dist/hooks/useState.d.ts +7 -0
  111. package/dist/hooks/useState.d.ts.map +1 -0
  112. package/dist/hooks/useState.js +54 -0
  113. package/dist/hooks/useState.js.map +1 -0
  114. package/dist/hooks/useSyncExternalStore.d.ts +8 -0
  115. package/dist/hooks/useSyncExternalStore.d.ts.map +1 -0
  116. package/dist/hooks/useSyncExternalStore.js +50 -0
  117. package/dist/hooks/useSyncExternalStore.js.map +1 -0
  118. package/dist/hooks/useViewTransition.d.ts +10 -0
  119. package/dist/hooks/useViewTransition.d.ts.map +1 -0
  120. package/dist/hooks/useViewTransition.js +28 -0
  121. package/dist/hooks/useViewTransition.js.map +1 -0
  122. package/dist/hooks/utils.d.ts +69 -0
  123. package/dist/hooks/utils.d.ts.map +1 -0
  124. package/dist/hooks/utils.js +163 -0
  125. package/dist/hooks/utils.js.map +1 -0
  126. package/dist/hydration.d.ts +17 -0
  127. package/dist/hydration.d.ts.map +1 -0
  128. package/dist/hydration.js +59 -0
  129. package/dist/hydration.js.map +1 -0
  130. package/dist/index.d.ts +17 -0
  131. package/dist/index.d.ts.map +1 -0
  132. package/dist/index.js +40 -0
  133. package/dist/index.js.map +1 -0
  134. package/dist/jsx.d.ts +6 -0
  135. package/dist/jsx.d.ts.map +1 -0
  136. package/dist/jsx.js +8 -0
  137. package/dist/jsx.js.map +1 -0
  138. package/dist/lazy.d.ts +11 -0
  139. package/dist/lazy.d.ts.map +1 -0
  140. package/dist/lazy.js +177 -0
  141. package/dist/lazy.js.map +1 -0
  142. package/dist/memo.d.ts +9 -0
  143. package/dist/memo.d.ts.map +1 -0
  144. package/dist/memo.js +25 -0
  145. package/dist/memo.js.map +1 -0
  146. package/dist/portal.d.ts +10 -0
  147. package/dist/portal.d.ts.map +1 -0
  148. package/dist/portal.js +34 -0
  149. package/dist/portal.js.map +1 -0
  150. package/dist/profiling.d.ts +26 -0
  151. package/dist/profiling.d.ts.map +1 -0
  152. package/dist/profiling.js +83 -0
  153. package/dist/profiling.js.map +1 -0
  154. package/dist/props.d.ts +4 -0
  155. package/dist/props.d.ts.map +1 -0
  156. package/dist/props.js +27 -0
  157. package/dist/props.js.map +1 -0
  158. package/dist/reconciler.d.ts +4 -0
  159. package/dist/reconciler.d.ts.map +1 -0
  160. package/dist/reconciler.js +466 -0
  161. package/dist/reconciler.js.map +1 -0
  162. package/dist/renderToString.d.ts +2 -0
  163. package/dist/renderToString.d.ts.map +1 -0
  164. package/dist/renderToString.js +74 -0
  165. package/dist/renderToString.js.map +1 -0
  166. package/dist/router/index.d.ts +3 -0
  167. package/dist/router/index.d.ts.map +1 -0
  168. package/dist/router/index.js +3 -0
  169. package/dist/router/index.js.map +1 -0
  170. package/dist/router/route.d.ts +46 -0
  171. package/dist/router/route.d.ts.map +1 -0
  172. package/dist/router/route.js +8 -0
  173. package/dist/router/route.js.map +1 -0
  174. package/dist/router/router.d.ts +62 -0
  175. package/dist/router/router.d.ts.map +1 -0
  176. package/dist/router/router.js +178 -0
  177. package/dist/router/router.js.map +1 -0
  178. package/dist/router/routerUtils.d.ts +5 -0
  179. package/dist/router/routerUtils.d.ts.map +1 -0
  180. package/dist/router/routerUtils.js +39 -0
  181. package/dist/router/routerUtils.js.map +1 -0
  182. package/dist/scheduler.d.ts +14 -0
  183. package/dist/scheduler.d.ts.map +1 -0
  184. package/dist/scheduler.js +457 -0
  185. package/dist/scheduler.js.map +1 -0
  186. package/dist/signals/base.d.ts +36 -0
  187. package/dist/signals/base.d.ts.map +1 -0
  188. package/dist/signals/base.js +205 -0
  189. package/dist/signals/base.js.map +1 -0
  190. package/dist/signals/computed.d.ts +16 -0
  191. package/dist/signals/computed.d.ts.map +1 -0
  192. package/dist/signals/computed.js +116 -0
  193. package/dist/signals/computed.js.map +1 -0
  194. package/dist/signals/effect.d.ts +18 -0
  195. package/dist/signals/effect.d.ts.map +1 -0
  196. package/dist/signals/effect.js +43 -0
  197. package/dist/signals/effect.js.map +1 -0
  198. package/dist/signals/globals.d.ts +9 -0
  199. package/dist/signals/globals.d.ts.map +1 -0
  200. package/dist/signals/globals.js +9 -0
  201. package/dist/signals/globals.js.map +1 -0
  202. package/dist/signals/index.d.ts +12 -0
  203. package/dist/signals/index.d.ts.map +1 -0
  204. package/dist/signals/index.js +12 -0
  205. package/dist/signals/index.js.map +1 -0
  206. package/dist/signals/jsx.d.ts +16 -0
  207. package/dist/signals/jsx.d.ts.map +1 -0
  208. package/dist/signals/jsx.js +11 -0
  209. package/dist/signals/jsx.js.map +1 -0
  210. package/dist/signals/types.d.ts +9 -0
  211. package/dist/signals/types.d.ts.map +1 -0
  212. package/dist/signals/types.js +2 -0
  213. package/dist/signals/types.js.map +1 -0
  214. package/dist/signals/utils.d.ts +4 -0
  215. package/dist/signals/utils.d.ts.map +1 -0
  216. package/dist/signals/utils.js +12 -0
  217. package/dist/signals/utils.js.map +1 -0
  218. package/dist/signals/watch.d.ts +24 -0
  219. package/dist/signals/watch.d.ts.map +1 -0
  220. package/dist/signals/watch.js +104 -0
  221. package/dist/signals/watch.js.map +1 -0
  222. package/dist/ssr/client.d.ts +4 -0
  223. package/dist/ssr/client.d.ts.map +1 -0
  224. package/dist/ssr/client.js +12 -0
  225. package/dist/ssr/client.js.map +1 -0
  226. package/dist/ssr/hydrationBoundary.d.ts +27 -0
  227. package/dist/ssr/hydrationBoundary.d.ts.map +1 -0
  228. package/dist/ssr/hydrationBoundary.js +30 -0
  229. package/dist/ssr/hydrationBoundary.js.map +1 -0
  230. package/dist/ssr/index.d.ts +2 -0
  231. package/dist/ssr/index.d.ts.map +1 -0
  232. package/dist/ssr/index.js +2 -0
  233. package/dist/ssr/index.js.map +1 -0
  234. package/dist/ssr/server.d.ts +3 -0
  235. package/dist/ssr/server.d.ts.map +1 -0
  236. package/dist/ssr/server.js +101 -0
  237. package/dist/ssr/server.js.map +1 -0
  238. package/dist/store.d.ts +28 -0
  239. package/dist/store.d.ts.map +1 -0
  240. package/dist/store.js +166 -0
  241. package/dist/store.js.map +1 -0
  242. package/dist/swr.d.ts +74 -0
  243. package/dist/swr.d.ts.map +1 -0
  244. package/dist/swr.js +228 -0
  245. package/dist/swr.js.map +1 -0
  246. package/dist/transition.d.ts +18 -0
  247. package/dist/transition.d.ts.map +1 -0
  248. package/dist/transition.js +48 -0
  249. package/dist/transition.js.map +1 -0
  250. package/dist/types.d.ts +143 -0
  251. package/dist/types.d.ts.map +1 -0
  252. package/dist/types.dom.d.ts +920 -0
  253. package/dist/types.dom.d.ts.map +1 -0
  254. package/dist/types.dom.js +2 -0
  255. package/dist/types.dom.js.map +1 -0
  256. package/dist/types.js +2 -0
  257. package/dist/types.js.map +1 -0
  258. package/dist/types.utils.d.ts +41 -0
  259. package/dist/types.utils.d.ts.map +1 -0
  260. package/dist/types.utils.js +2 -0
  261. package/dist/types.utils.js.map +1 -0
  262. package/dist/utils.d.ts +61 -0
  263. package/dist/utils.d.ts.map +1 -0
  264. package/dist/utils.js +478 -0
  265. package/dist/utils.js.map +1 -0
  266. package/dist/warning.d.ts +2 -0
  267. package/dist/warning.d.ts.map +1 -0
  268. package/dist/warning.js +4 -0
  269. package/dist/warning.js.map +1 -0
  270. package/package.json +1 -1
  271. package/src/appContext.ts +7 -7
  272. package/src/cloneVNode.ts +1 -1
  273. package/src/constants.ts +9 -9
  274. package/src/context.ts +7 -7
  275. package/src/dom.ts +13 -15
  276. package/src/element.ts +4 -4
  277. package/src/error.ts +11 -13
  278. package/src/globalContext.ts +6 -10
  279. package/src/globals.ts +3 -3
  280. package/src/hmr.ts +4 -4
  281. package/src/hooks/useContext.ts +5 -5
  282. package/src/hooks/useId.ts +1 -1
  283. package/src/hooks/useReducer.ts +1 -1
  284. package/src/hooks/useRef.ts +4 -4
  285. package/src/hooks/useState.ts +4 -4
  286. package/src/hooks/useSyncExternalStore.ts +2 -2
  287. package/src/hooks/utils.ts +7 -9
  288. package/src/index.ts +4 -4
  289. package/src/jsx.ts +2 -2
  290. package/src/lazy.ts +11 -11
  291. package/src/memo.ts +1 -1
  292. package/src/portal.ts +4 -4
  293. package/src/props.ts +5 -7
  294. package/src/reconciler.ts +6 -6
  295. package/src/renderToString.ts +1 -1
  296. package/src/router/route.ts +1 -1
  297. package/src/router/router.ts +4 -4
  298. package/src/scheduler.ts +14 -14
  299. package/src/signals/base.ts +1 -1
  300. package/src/signals/types.ts +1 -1
  301. package/src/signals/watch.ts +2 -2
  302. package/src/ssr/hydrationBoundary.ts +1 -1
  303. package/src/ssr/server.ts +1 -1
  304. package/src/store.ts +7 -7
  305. package/src/swr.ts +2 -2
  306. package/src/types.dom.ts +1 -1
  307. package/src/types.ts +13 -13
  308. package/src/types.utils.ts +5 -5
  309. package/src/utils.ts +7 -10
  310. package/src/warning.ts +1 -1
@@ -0,0 +1,28 @@
1
+ import { __DEV__ } from "../env.js";
2
+ import { sideEffectsEnabled, useHook } from "./utils.js";
3
+ export function useRef(initialValue) {
4
+ if (!sideEffectsEnabled())
5
+ return { current: initialValue };
6
+ return useHook("useRef", { ref: { current: initialValue } }, ({ hook, isInit, isHMR }) => {
7
+ if (__DEV__) {
8
+ if (isInit) {
9
+ hook.dev = {
10
+ devtools: {
11
+ get: () => ({ value: hook.ref.current }),
12
+ set: ({ value }) => (hook.ref.current = value),
13
+ },
14
+ initialArgs: [hook.ref.current],
15
+ };
16
+ }
17
+ if (isHMR) {
18
+ const [v] = hook.dev.initialArgs;
19
+ if (v !== initialValue) {
20
+ hook.ref = { current: initialValue };
21
+ hook.dev.initialArgs = [initialValue];
22
+ }
23
+ }
24
+ }
25
+ return hook.ref;
26
+ });
27
+ }
28
+ //# sourceMappingURL=useRef.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useRef.js","sourceRoot":"","sources":["../../src/hooks/useRef.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AACnC,OAAO,EAAE,kBAAkB,EAAE,OAAO,EAAE,MAAM,YAAY,CAAA;AAWxD,MAAM,UAAU,MAAM,CAAI,YAAuB;IAC/C,IAAI,CAAC,kBAAkB,EAAE;QAAE,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,CAAA;IAC3D,OAAO,OAAO,CACZ,QAAQ,EACR,EAAE,GAAG,EAAE,EAAE,OAAO,EAAE,YAAY,EAAE,EAAE,EAClC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,EAAE;QAC1B,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,MAAM,EAAE,CAAC;gBACX,IAAI,CAAC,GAAG,GAAG;oBACT,QAAQ,EAAE;wBACR,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,OAAQ,EAAE,CAAC;wBACzC,GAAG,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,GAAG,KAAK,CAAC;qBACK;oBACrD,WAAW,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC;iBAChC,CAAA;YACH,CAAC;YACD,IAAI,KAAK,EAAE,CAAC;gBACV,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAI,CAAC,WAAW,CAAA;gBACjC,IAAI,CAAC,KAAK,YAAY,EAAE,CAAC;oBACvB,IAAI,CAAC,GAAG,GAAG,EAAE,OAAO,EAAE,YAAY,EAAE,CAAA;oBACpC,IAAI,CAAC,GAAI,CAAC,WAAW,GAAG,CAAC,YAAY,CAAC,CAAA;gBACxC,CAAC;YACH,CAAC;QACH,CAAC;QACD,OAAO,IAAI,CAAC,GAAG,CAAA;IACjB,CAAC,CACF,CAAA;AACH,CAAC"}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Creates a stateful value, and returns the current value and a function to update it.
3
+ *
4
+ * @see https://kaioken.dev/docs/hooks/useState
5
+ */
6
+ export declare function useState<T>(initial: T | (() => T)): readonly [T, (value: Kiru.StateSetter<T>) => void];
7
+ //# sourceMappingURL=useState.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useState.d.ts","sourceRoot":"","sources":["../../src/hooks/useState.ts"],"names":[],"mappings":"AAIA;;;;GAIG;AACH,wBAAgB,QAAQ,CAAC,CAAC,EACxB,OAAO,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,GACrB,SAAS,CAAC,CAAC,EAAE,CAAC,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAkDpD"}
@@ -0,0 +1,54 @@
1
+ import { __DEV__ } from "../env.js";
2
+ import { noop } from "../utils.js";
3
+ import { sideEffectsEnabled, useHook } from "./utils.js";
4
+ /**
5
+ * Creates a stateful value, and returns the current value and a function to update it.
6
+ *
7
+ * @see https://kaioken.dev/docs/hooks/useState
8
+ */
9
+ export function useState(initial) {
10
+ if (!sideEffectsEnabled()) {
11
+ return [
12
+ typeof initial === "function" ? initial() : initial,
13
+ noop,
14
+ ];
15
+ }
16
+ return useHook("useState", {
17
+ state: undefined,
18
+ dispatch: noop,
19
+ }, ({ hook, isInit, update, isHMR }) => {
20
+ if (__DEV__) {
21
+ if (isInit) {
22
+ hook.dev = {
23
+ devtools: {
24
+ get: () => ({ value: hook.state }),
25
+ set: ({ value }) => (hook.state = value),
26
+ },
27
+ initialArgs: [initial],
28
+ };
29
+ }
30
+ if (isHMR) {
31
+ const [v] = hook.dev.initialArgs;
32
+ if (v !== initial) {
33
+ isInit = true;
34
+ hook.dev.initialArgs = [initial];
35
+ }
36
+ }
37
+ }
38
+ if (isInit) {
39
+ hook.state =
40
+ typeof initial === "function" ? initial() : initial;
41
+ hook.dispatch = (setter) => {
42
+ const newState = typeof setter === "function"
43
+ ? setter(hook.state)
44
+ : setter;
45
+ if (Object.is(hook.state, newState))
46
+ return;
47
+ hook.state = newState;
48
+ update();
49
+ };
50
+ }
51
+ return [hook.state, hook.dispatch];
52
+ });
53
+ }
54
+ //# sourceMappingURL=useState.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useState.js","sourceRoot":"","sources":["../../src/hooks/useState.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AACnC,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAClC,OAAO,EAAE,kBAAkB,EAAE,OAAO,EAAE,MAAM,YAAY,CAAA;AAExD;;;;GAIG;AACH,MAAM,UAAU,QAAQ,CACtB,OAAsB;IAEtB,IAAI,CAAC,kBAAkB,EAAE,EAAE,CAAC;QAC1B,OAAO;YACL,OAAO,OAAO,KAAK,UAAU,CAAC,CAAC,CAAE,OAAoB,EAAE,CAAC,CAAC,CAAC,OAAO;YACjE,IAAI;SACL,CAAA;IACH,CAAC;IACD,OAAO,OAAO,CACZ,UAAU,EACV;QACE,KAAK,EAAE,SAAc;QACrB,QAAQ,EAAE,IAA4C;KACvD,EACD,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,EAAE;QAClC,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,MAAM,EAAE,CAAC;gBACX,IAAI,CAAC,GAAG,GAAG;oBACT,QAAQ,EAAE;wBACR,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC;wBAClC,GAAG,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;qBACW;oBACrD,WAAW,EAAE,CAAC,OAAO,CAAC;iBACvB,CAAA;YACH,CAAC;YACD,IAAI,KAAK,EAAE,CAAC;gBACV,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAI,CAAC,WAAW,CAAA;gBACjC,IAAI,CAAC,KAAK,OAAO,EAAE,CAAC;oBAClB,MAAM,GAAG,IAAI,CAAA;oBACb,IAAI,CAAC,GAAI,CAAC,WAAW,GAAG,CAAC,OAAO,CAAC,CAAA;gBACnC,CAAC;YACH,CAAC;QACH,CAAC;QAED,IAAI,MAAM,EAAE,CAAC;YACX,IAAI,CAAC,KAAK;gBACR,OAAO,OAAO,KAAK,UAAU,CAAC,CAAC,CAAE,OAAoB,EAAE,CAAC,CAAC,CAAC,OAAO,CAAA;YACnE,IAAI,CAAC,QAAQ,GAAG,CAAC,MAA2B,EAAE,EAAE;gBAC9C,MAAM,QAAQ,GACZ,OAAO,MAAM,KAAK,UAAU;oBAC1B,CAAC,CAAE,MAAmB,CAAC,IAAI,CAAC,KAAK,CAAC;oBAClC,CAAC,CAAC,MAAM,CAAA;gBACZ,IAAI,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC;oBAAE,OAAM;gBAC3C,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAA;gBACrB,MAAM,EAAE,CAAA;YACV,CAAC,CAAA;QACH,CAAC;QAED,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAU,CAAA;IAC7C,CAAC,CACF,CAAA;AACH,CAAC"}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Allows you to use a generic external store as long as it provides
3
+ * a subscribe function and a way to get its current state.
4
+ *
5
+ * @see https://kaioken.dev/docs/hooks/useSyncExternalStore
6
+ */
7
+ export declare function useSyncExternalStore<T>(subscribe: (callback: () => void) => () => void, getState: () => T, getServerState?: () => T): T;
8
+ //# sourceMappingURL=useSyncExternalStore.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useSyncExternalStore.d.ts","sourceRoot":"","sources":["../../src/hooks/useSyncExternalStore.ts"],"names":[],"mappings":"AAMA;;;;;GAKG;AACH,wBAAgB,oBAAoB,CAAC,CAAC,EACpC,SAAS,EAAE,CAAC,QAAQ,EAAE,MAAM,IAAI,KAAK,MAAM,IAAI,EAC/C,QAAQ,EAAE,MAAM,CAAC,EACjB,cAAc,CAAC,EAAE,MAAM,CAAC,GACvB,CAAC,CA0CH"}
@@ -0,0 +1,50 @@
1
+ import { node } from "../globals.js";
2
+ import { KiruError } from "../error.js";
3
+ import { noop } from "../utils.js";
4
+ import { sideEffectsEnabled, useHook } from "./utils.js";
5
+ import { __DEV__ } from "../env.js";
6
+ /**
7
+ * Allows you to use a generic external store as long as it provides
8
+ * a subscribe function and a way to get its current state.
9
+ *
10
+ * @see https://kaioken.dev/docs/hooks/useSyncExternalStore
11
+ */
12
+ export function useSyncExternalStore(subscribe, getState, getServerState) {
13
+ if (!sideEffectsEnabled()) {
14
+ if (getServerState === undefined) {
15
+ throw new KiruError({
16
+ message: "useSyncExternalStore must receive a getServerSnapshot function if the component is rendered on the server.",
17
+ vNode: node.current,
18
+ });
19
+ }
20
+ return getServerState();
21
+ }
22
+ return useHook("useSyncExternalStore", {
23
+ state: null,
24
+ unsubscribe: noop,
25
+ subscribe,
26
+ }, ({ hook, isInit, update }) => {
27
+ if (__DEV__) {
28
+ hook.dev = {
29
+ devtools: { get: () => ({ value: hook.state }) },
30
+ };
31
+ }
32
+ if (isInit || hook.subscribe !== subscribe) {
33
+ hook.state = getState();
34
+ hook.subscribe = subscribe;
35
+ hook.unsubscribe = subscribe(() => {
36
+ const newState = getState();
37
+ if (Object.is(hook.state, newState))
38
+ return;
39
+ hook.state = newState;
40
+ update();
41
+ });
42
+ hook.cleanup = () => {
43
+ hook.unsubscribe();
44
+ hook.unsubscribe = noop;
45
+ };
46
+ }
47
+ return hook.state;
48
+ });
49
+ }
50
+ //# sourceMappingURL=useSyncExternalStore.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useSyncExternalStore.js","sourceRoot":"","sources":["../../src/hooks/useSyncExternalStore.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,eAAe,CAAA;AACpC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AACvC,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAClC,OAAO,EAAE,kBAAkB,EAAE,OAAO,EAAE,MAAM,YAAY,CAAA;AACxD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAEnC;;;;;GAKG;AACH,MAAM,UAAU,oBAAoB,CAClC,SAA+C,EAC/C,QAAiB,EACjB,cAAwB;IAExB,IAAI,CAAC,kBAAkB,EAAE,EAAE,CAAC;QAC1B,IAAI,cAAc,KAAK,SAAS,EAAE,CAAC;YACjC,MAAM,IAAI,SAAS,CAAC;gBAClB,OAAO,EACL,4GAA4G;gBAC9G,KAAK,EAAE,IAAI,CAAC,OAAQ;aACrB,CAAC,CAAA;QACJ,CAAC;QACD,OAAO,cAAc,EAAE,CAAA;IACzB,CAAC;IAED,OAAO,OAAO,CACZ,sBAAsB,EACtB;QACE,KAAK,EAAE,IAAS;QAChB,WAAW,EAAE,IAAkB;QAC/B,SAAS;KACV,EACD,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE;QAC3B,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,CAAC,GAAG,GAAG;gBACT,QAAQ,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,EAAE;aACjD,CAAA;QACH,CAAC;QACD,IAAI,MAAM,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;YAC3C,IAAI,CAAC,KAAK,GAAG,QAAQ,EAAE,CAAA;YACvB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAA;YAC1B,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC,GAAG,EAAE;gBAChC,MAAM,QAAQ,GAAG,QAAQ,EAAE,CAAA;gBAC3B,IAAI,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC;oBAAE,OAAM;gBAC3C,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAA;gBACrB,MAAM,EAAE,CAAA;YACV,CAAC,CAAC,CAAA;YACF,IAAI,CAAC,OAAO,GAAG,GAAG,EAAE;gBAClB,IAAI,CAAC,WAAW,EAAE,CAAA;gBAClB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAA;YACzB,CAAC,CAAA;QACH,CAAC;QACD,OAAO,IAAI,CAAC,KAAK,CAAA;IACnB,CAAC,CACF,CAAA;AACH,CAAC"}
@@ -0,0 +1,10 @@
1
+ /**
2
+ * Allows you to easily use the [View Transition API](https://developer.mozilla.org/en-US/docs/Web/API/Document/startViewTransition)
3
+ * by wrapping the `callback` in a `document.startViewTransition` call.
4
+ *
5
+ * Falls back to the regular `callback` if not supported.
6
+ *
7
+ * @see https://kaioken.dev/docs/hooks/useViewTransition
8
+ */
9
+ export declare function useViewTransition(): (callback: () => void) => void;
10
+ //# sourceMappingURL=useViewTransition.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useViewTransition.d.ts","sourceRoot":"","sources":["../../src/hooks/useViewTransition.ts"],"names":[],"mappings":"AAIA;;;;;;;GAOG;AACH,wBAAgB,iBAAiB,eAGb,MAAM,IAAI,UAU7B"}
@@ -0,0 +1,28 @@
1
+ import { ctx, node } from "../globals.js";
2
+ import { noop } from "../utils.js";
3
+ import { sideEffectsEnabled } from "./utils.js";
4
+ /**
5
+ * Allows you to easily use the [View Transition API](https://developer.mozilla.org/en-US/docs/Web/API/Document/startViewTransition)
6
+ * by wrapping the `callback` in a `document.startViewTransition` call.
7
+ *
8
+ * Falls back to the regular `callback` if not supported.
9
+ *
10
+ * @see https://kaioken.dev/docs/hooks/useViewTransition
11
+ */
12
+ export function useViewTransition() {
13
+ if (!sideEffectsEnabled())
14
+ return noop;
15
+ const appCtx = ctx.current;
16
+ return (callback) => {
17
+ if (node.current) {
18
+ throw new Error("useViewTransition can't be called during rendering.");
19
+ }
20
+ if (!document.startViewTransition)
21
+ return callback();
22
+ document.startViewTransition(() => {
23
+ callback();
24
+ appCtx.flushSync();
25
+ });
26
+ };
27
+ }
28
+ //# sourceMappingURL=useViewTransition.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useViewTransition.js","sourceRoot":"","sources":["../../src/hooks/useViewTransition.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,eAAe,CAAA;AACzC,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAClC,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAA;AAE/C;;;;;;;GAOG;AACH,MAAM,UAAU,iBAAiB;IAC/B,IAAI,CAAC,kBAAkB,EAAE;QAAE,OAAO,IAAI,CAAA;IACtC,MAAM,MAAM,GAAG,GAAG,CAAC,OAAO,CAAA;IAC1B,OAAO,CAAC,QAAoB,EAAE,EAAE;QAC9B,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,qDAAqD,CAAC,CAAA;QACxE,CAAC;QACD,IAAI,CAAC,QAAQ,CAAC,mBAAmB;YAAE,OAAO,QAAQ,EAAE,CAAA;QACpD,QAAQ,CAAC,mBAAmB,CAAC,GAAG,EAAE;YAChC,QAAQ,EAAE,CAAA;YACV,MAAM,CAAC,SAAS,EAAE,CAAA;QACpB,CAAC,CAAC,CAAA;IACJ,CAAC,CAAA;AACH,CAAC"}
@@ -0,0 +1,69 @@
1
+ export { sideEffectsEnabled } from "../utils.js";
2
+ export { cleanupHook, depsRequireChange, useHook, useVNode, useAppContext, useHookDebugGroup, useRequestUpdate, HookDebugGroupAction, type HookState, type HookCallback, type HookCallbackContext as HookCallbackState, };
3
+ type HookState<T> = Kiru.Hook<T>;
4
+ declare enum HookDebugGroupAction {
5
+ Start = "start",
6
+ End = "end"
7
+ }
8
+ /**
9
+ * **dev only - this is a no-op in production.**
10
+ *
11
+ * Used to create 'groups' of hooks in the devtools.
12
+ * Useful for debugging and profiling.
13
+ */
14
+ declare const useHookDebugGroup: (name: string, action: HookDebugGroupAction) => void;
15
+ /**
16
+ * Used obtain an 'requestUpdate' function for the current component.
17
+ */
18
+ declare const useRequestUpdate: () => () => void;
19
+ /**
20
+ * Used to obtain the 'AppContext' for the current component.
21
+ */
22
+ declare const useAppContext: () => import("../appContext.js").AppContext<any>;
23
+ /**
24
+ * Used to obtain the 'VNode' for the current component.
25
+ */
26
+ declare const useVNode: () => Kiru.VNode;
27
+ type HookCallbackContext<T> = {
28
+ /**
29
+ * The current state of the hook
30
+ */
31
+ hook: HookState<T>;
32
+ /**
33
+ * Indicates if this is the first time the hook has been initialized
34
+ */
35
+ isInit: boolean;
36
+ /**
37
+ * Dev mode only - indicates if the hook is being run as a result of a HMR update.
38
+ * This is the time to clean up the previous version of the hook if necessary, ie. initial arguments changed.
39
+ */
40
+ isHMR?: boolean;
41
+ /**
42
+ * Queues the current component to be re-rendered
43
+ */
44
+ update: () => void;
45
+ /**
46
+ * Queues an effect to be run, either immediately or on the next render
47
+ */
48
+ queueEffect: (callback: Function, opts?: {
49
+ immediate?: boolean;
50
+ }) => void;
51
+ /**
52
+ * The VNode associated with the current component
53
+ */
54
+ vNode: Kiru.VNode;
55
+ /**
56
+ * The index of the current hook.
57
+ * You can count on this being stable across renders,
58
+ * and unique across separate hooks in the same component.
59
+ */
60
+ index: number;
61
+ };
62
+ type HookCallback<T> = (state: HookCallbackContext<T>) => any;
63
+ declare function useHook<T extends () => Record<string, unknown>, U extends HookCallback<ReturnType<T>>>(hookName: string, hookInitializer: T, callback: U): ReturnType<U>;
64
+ declare function useHook<T extends Record<string, unknown>, U extends HookCallback<T>>(hookName: string, hookData: T, callback: U): ReturnType<U>;
65
+ declare function cleanupHook(hook: {
66
+ cleanup?: () => void;
67
+ }): void;
68
+ declare function depsRequireChange(a?: unknown[], b?: unknown[]): boolean;
69
+ //# sourceMappingURL=utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/hooks/utils.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAA;AAChD,OAAO,EACL,WAAW,EACX,iBAAiB,EACjB,OAAO,EACP,QAAQ,EACR,aAAa,EACb,iBAAiB,EACjB,gBAAgB,EAChB,oBAAoB,EACpB,KAAK,SAAS,EACd,KAAK,YAAY,EACjB,KAAK,mBAAmB,IAAI,iBAAiB,GAC9C,CAAA;AAED,KAAK,SAAS,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;AAEhC,aAAK,oBAAoB;IACvB,KAAK,UAAU;IACf,GAAG,QAAQ;CACZ;AAED;;;;;GAKG;AACH,QAAA,MAAM,iBAAiB,GAAI,MAAM,MAAM,EAAE,QAAQ,oBAAoB,SAQpE,CAAA;AAED;;GAEG;AACH,QAAA,MAAM,gBAAgB,kBAKrB,CAAA;AAED;;GAEG;AACH,QAAA,MAAM,aAAa,kDAMlB,CAAA;AAED;;GAEG;AACH,QAAA,MAAM,QAAQ,kBAIb,CAAA;AAED,KAAK,mBAAmB,CAAC,CAAC,IAAI;IAC5B;;OAEG;IACH,IAAI,EAAE,SAAS,CAAC,CAAC,CAAC,CAAA;IAClB;;OAEG;IACH,MAAM,EAAE,OAAO,CAAA;IACf;;;OAGG;IACH,KAAK,CAAC,EAAE,OAAO,CAAA;IACf;;OAEG;IACH,MAAM,EAAE,MAAM,IAAI,CAAA;IAClB;;OAEG;IACH,WAAW,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,CAAC,EAAE;QAAE,SAAS,CAAC,EAAE,OAAO,CAAA;KAAE,KAAK,IAAI,CAAA;IACzE;;OAEG;IACH,KAAK,EAAE,IAAI,CAAC,KAAK,CAAA;IACjB;;;;OAIG;IACH,KAAK,EAAE,MAAM,CAAA;CACd,CAAA;AACD,KAAK,YAAY,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,mBAAmB,CAAC,CAAC,CAAC,KAAK,GAAG,CAAA;AAK7D,iBAAS,OAAO,CACd,CAAC,SAAS,MAAM,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACvC,CAAC,SAAS,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EACrC,QAAQ,EAAE,MAAM,EAAE,eAAe,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAA;AAEnE,iBAAS,OAAO,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC,SAAS,YAAY,CAAC,CAAC,CAAC,EAC3E,QAAQ,EAAE,MAAM,EAChB,QAAQ,EAAE,CAAC,EACX,QAAQ,EAAE,CAAC,GACV,UAAU,CAAC,CAAC,CAAC,CAAA;AA2HhB,iBAAS,WAAW,CAAC,IAAI,EAAE;IAAE,OAAO,CAAC,EAAE,MAAM,IAAI,CAAA;CAAE,QAKlD;AAED,iBAAS,iBAAiB,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,EAAE,CAAC,CAAC,EAAE,OAAO,EAAE,WAOtD"}
@@ -0,0 +1,163 @@
1
+ import { KiruError } from "../error.js";
2
+ import { __DEV__ } from "../env.js";
3
+ import { ctx, hookIndex, node, nodeToCtxMap } from "../globals.js";
4
+ import { getVNodeAppContext, noop } from "../utils.js";
5
+ export { sideEffectsEnabled } from "../utils.js";
6
+ export { cleanupHook, depsRequireChange, useHook, useVNode, useAppContext, useHookDebugGroup, useRequestUpdate, HookDebugGroupAction, };
7
+ var HookDebugGroupAction;
8
+ (function (HookDebugGroupAction) {
9
+ HookDebugGroupAction["Start"] = "start";
10
+ HookDebugGroupAction["End"] = "end";
11
+ })(HookDebugGroupAction || (HookDebugGroupAction = {}));
12
+ /**
13
+ * **dev only - this is a no-op in production.**
14
+ *
15
+ * Used to create 'groups' of hooks in the devtools.
16
+ * Useful for debugging and profiling.
17
+ */
18
+ const useHookDebugGroup = (name, action) => {
19
+ if (__DEV__) {
20
+ return useHook("devtools:useHookDebugGroup", { displayName: name, action }, noop);
21
+ }
22
+ };
23
+ /**
24
+ * Used obtain an 'requestUpdate' function for the current component.
25
+ */
26
+ const useRequestUpdate = () => {
27
+ const n = node.current;
28
+ if (!n)
29
+ error_hookMustBeCalledTopLevel("useRequestUpdate");
30
+ const ctx = getVNodeAppContext(n);
31
+ return () => ctx.requestUpdate(n);
32
+ };
33
+ /**
34
+ * Used to obtain the 'AppContext' for the current component.
35
+ */
36
+ const useAppContext = () => {
37
+ if (!node.current)
38
+ error_hookMustBeCalledTopLevel("useAppContext");
39
+ const ctx = nodeToCtxMap.get(node.current);
40
+ if (!ctx)
41
+ error_hookMustBeCalledTopLevel("[kiru]: unable to find node's AppContext");
42
+ return ctx;
43
+ };
44
+ /**
45
+ * Used to obtain the 'VNode' for the current component.
46
+ */
47
+ const useVNode = () => {
48
+ const n = node.current;
49
+ if (!n)
50
+ error_hookMustBeCalledTopLevel("useVNode");
51
+ return n;
52
+ };
53
+ let currentHookName = null;
54
+ const nestedHookWarnings = new Set();
55
+ function useHook(hookName, hookDataOrInitializer, callback) {
56
+ const vNode = node.current;
57
+ if (!vNode)
58
+ error_hookMustBeCalledTopLevel(hookName);
59
+ if (__DEV__) {
60
+ if (currentHookName !== null &&
61
+ !nestedHookWarnings.has(hookName + currentHookName)) {
62
+ nestedHookWarnings.add(hookName + currentHookName);
63
+ throw new KiruError({
64
+ message: `Nested primitive "useHook" calls are not supported. "${hookName}" was called inside "${currentHookName}". Strange will most certainly happen.`,
65
+ vNode,
66
+ });
67
+ }
68
+ }
69
+ const queueEffect = (callback, opts) => {
70
+ if (opts?.immediate) {
71
+ ;
72
+ (vNode.immediateEffects ?? (vNode.immediateEffects = [])).push(callback);
73
+ return;
74
+ }
75
+ ;
76
+ (vNode.effects ?? (vNode.effects = [])).push(callback);
77
+ };
78
+ const appCtx = ctx.current;
79
+ const index = hookIndex.current++;
80
+ let oldHook = (vNode.prev ? vNode.prev.hooks?.at(index) : vNode.hooks?.at(index));
81
+ if (__DEV__) {
82
+ currentHookName = hookName;
83
+ vNode.hooks ?? (vNode.hooks = []);
84
+ vNode.hookSig ?? (vNode.hookSig = []);
85
+ if (!vNode.hookSig[index]) {
86
+ vNode.hookSig[index] = hookName;
87
+ }
88
+ else {
89
+ if (vNode.hookSig[index] !== hookName) {
90
+ console.warn(`[kiru]: hooks must be called in the same order. Hook "${hookName}" was called in place of "${vNode.hookSig[index]}". Strange things may happen.`);
91
+ vNode.hooks.length = index;
92
+ vNode.hookSig.length = index;
93
+ oldHook = undefined;
94
+ }
95
+ }
96
+ let hook;
97
+ if (!oldHook) {
98
+ hook =
99
+ typeof hookDataOrInitializer === "function"
100
+ ? hookDataOrInitializer()
101
+ : { ...hookDataOrInitializer };
102
+ hook.name = hookName;
103
+ }
104
+ else {
105
+ hook = oldHook;
106
+ }
107
+ vNode.hooks[index] = hook;
108
+ try {
109
+ const res = callback({
110
+ hook,
111
+ isInit: !oldHook,
112
+ isHMR: vNode.hmrUpdated,
113
+ update: () => appCtx.requestUpdate(vNode),
114
+ queueEffect,
115
+ vNode,
116
+ index,
117
+ });
118
+ return res;
119
+ }
120
+ catch (error) {
121
+ throw error;
122
+ }
123
+ finally {
124
+ currentHookName = null;
125
+ }
126
+ }
127
+ try {
128
+ const hook = oldHook ??
129
+ (typeof hookDataOrInitializer === "function"
130
+ ? hookDataOrInitializer()
131
+ : { ...hookDataOrInitializer });
132
+ vNode.hooks ?? (vNode.hooks = []);
133
+ vNode.hooks[index] = hook;
134
+ const res = callback({
135
+ hook,
136
+ isInit: !oldHook,
137
+ update: () => appCtx.requestUpdate(vNode),
138
+ queueEffect,
139
+ vNode,
140
+ index,
141
+ });
142
+ return res;
143
+ }
144
+ catch (error) {
145
+ throw error;
146
+ }
147
+ }
148
+ function error_hookMustBeCalledTopLevel(hookName) {
149
+ throw new KiruError(`Hook "${hookName}" must be used at the top level of a component or inside another composite hook.`);
150
+ }
151
+ function cleanupHook(hook) {
152
+ if (hook.cleanup) {
153
+ hook.cleanup();
154
+ hook.cleanup = undefined;
155
+ }
156
+ }
157
+ function depsRequireChange(a, b) {
158
+ return (a === undefined ||
159
+ b === undefined ||
160
+ a.length !== b.length ||
161
+ (a.length > 0 && b.some((dep, i) => !Object.is(dep, a[i]))));
162
+ }
163
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/hooks/utils.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ import type { MaybeDom, SomeDom } from "./types.utils";
2
+ export declare const hydrationStack: {
3
+ parentStack: Array<SomeDom>;
4
+ childIdxStack: Array<number>;
5
+ eventDeferrals: Map<Element, (() => void)[]>;
6
+ parent: () => SomeDom;
7
+ clear: () => void;
8
+ pop: () => void;
9
+ push: (el: SomeDom) => void;
10
+ currentChild: () => ChildNode;
11
+ nextChild: () => MaybeDom;
12
+ bumpChildIndex: () => void;
13
+ captureEvents: (element: Element) => void;
14
+ resetEvents: (element: Element) => void;
15
+ releaseEvents: (element: Element) => void;
16
+ };
17
+ //# sourceMappingURL=hydration.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hydration.d.ts","sourceRoot":"","sources":["../src/hydration.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;AAEtD,eAAO,MAAM,cAAc;iBACN,KAAK,CAAC,OAAO,CAAC;mBACZ,KAAK,CAAC,MAAM,CAAC;wCACW,IAAI;;;;eAY7B,OAAO;;qBAYpB,QAAQ;;6BAKmB,OAAO;2BAIT,OAAO;6BAGL,OAAO;CAK1C,CAAA"}
@@ -0,0 +1,59 @@
1
+ export const hydrationStack = {
2
+ parentStack: [],
3
+ childIdxStack: [],
4
+ eventDeferrals: new Map(),
5
+ parent: function () {
6
+ return this.parentStack[this.parentStack.length - 1];
7
+ },
8
+ clear: function () {
9
+ this.parentStack.length = 0;
10
+ this.childIdxStack.length = 0;
11
+ },
12
+ pop: function () {
13
+ this.parentStack.pop();
14
+ this.childIdxStack.pop();
15
+ },
16
+ push: function (el) {
17
+ this.parentStack.push(el);
18
+ this.childIdxStack.push(0);
19
+ },
20
+ currentChild: function () {
21
+ return this.parentStack[this.parentStack.length - 1].childNodes[this.childIdxStack[this.childIdxStack.length - 1]];
22
+ },
23
+ nextChild: function () {
24
+ return this.parentStack[this.parentStack.length - 1].childNodes[this.childIdxStack[this.childIdxStack.length - 1]++];
25
+ },
26
+ bumpChildIndex: function () {
27
+ this.childIdxStack[this.childIdxStack.length - 1]++;
28
+ },
29
+ captureEvents: function (element) {
30
+ toggleEvtListeners(element, true);
31
+ this.eventDeferrals.set(element, []);
32
+ },
33
+ resetEvents: function (element) {
34
+ this.eventDeferrals.delete(element);
35
+ },
36
+ releaseEvents: function (element) {
37
+ toggleEvtListeners(element, false);
38
+ const events = this.eventDeferrals.get(element);
39
+ while (events?.length)
40
+ events.shift()();
41
+ },
42
+ };
43
+ const captureEvent = (e) => {
44
+ const t = e.target;
45
+ if (!e.isTrusted || !t)
46
+ return;
47
+ hydrationStack.eventDeferrals
48
+ .get(t)
49
+ ?.push(() => t.dispatchEvent(e));
50
+ };
51
+ const toggleEvtListeners = (element, value) => {
52
+ for (const key in element) {
53
+ if (key.startsWith("on")) {
54
+ const eventType = key.substring(2);
55
+ element[value ? "addEventListener" : "removeEventListener"](eventType, captureEvent, { passive: true });
56
+ }
57
+ }
58
+ };
59
+ //# sourceMappingURL=hydration.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hydration.js","sourceRoot":"","sources":["../src/hydration.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ import { type AppContext, type AppContextOptions } from "./appContext.js";
2
+ export type * from "./types";
3
+ export * from "./appContext.js";
4
+ export * from "./context.js";
5
+ export * from "./cloneVNode.js";
6
+ export * from "./element.js";
7
+ export * from "./hooks/index.js";
8
+ export * from "./lazy.js";
9
+ export { memo } from "./memo.js";
10
+ export * from "./portal.js";
11
+ export * from "./renderToString.js";
12
+ export * from "./signals/index.js";
13
+ export * from "./store.js";
14
+ export * from "./transition.js";
15
+ export declare function mount<T extends Record<string, unknown>>(appFunc: (props: T) => JSX.Element, options: AppContextOptions, appProps?: T): Promise<AppContext<T>>;
16
+ export declare function mount<T extends Record<string, unknown>>(appFunc: (props: T) => JSX.Element, root: HTMLElement, appProps?: T): Promise<AppContext<T>>;
17
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,KAAK,UAAU,EACf,KAAK,iBAAiB,EACvB,MAAM,iBAAiB,CAAA;AAMxB,mBAAmB,SAAS,CAAA;AAC5B,cAAc,iBAAiB,CAAA;AAC/B,cAAc,cAAc,CAAA;AAC5B,cAAc,iBAAiB,CAAA;AAC/B,cAAc,cAAc,CAAA;AAC5B,cAAc,kBAAkB,CAAA;AAChC,cAAc,WAAW,CAAA;AACzB,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAA;AAChC,cAAc,aAAa,CAAA;AAC3B,cAAc,qBAAqB,CAAA;AACnC,cAAc,oBAAoB,CAAA;AAClC,cAAc,YAAY,CAAA;AAC1B,cAAc,iBAAiB,CAAA;AAM/B,wBAAgB,KAAK,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACrD,OAAO,EAAE,CAAC,KAAK,EAAE,CAAC,KAAK,GAAG,CAAC,OAAO,EAClC,OAAO,EAAE,iBAAiB,EAC1B,QAAQ,CAAC,EAAE,CAAC,GACX,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAA;AAEzB,wBAAgB,KAAK,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACrD,OAAO,EAAE,CAAC,KAAK,EAAE,CAAC,KAAK,GAAG,CAAC,OAAO,EAClC,IAAI,EAAE,WAAW,EACjB,QAAQ,CAAC,EAAE,CAAC,GACX,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAA"}
package/dist/index.js ADDED
@@ -0,0 +1,40 @@
1
+ var _a;
2
+ import { createAppContext, } from "./appContext.js";
3
+ import { ctx } from "./globals.js";
4
+ import { createKiruGlobalContext } from "./globalContext.js";
5
+ import { __DEV__ } from "./env.js";
6
+ import { KiruError } from "./error.js";
7
+ export * from "./appContext.js";
8
+ export * from "./context.js";
9
+ export * from "./cloneVNode.js";
10
+ export * from "./element.js";
11
+ export * from "./hooks/index.js";
12
+ export * from "./lazy.js";
13
+ export { memo } from "./memo.js";
14
+ export * from "./portal.js";
15
+ export * from "./renderToString.js";
16
+ export * from "./signals/index.js";
17
+ export * from "./store.js";
18
+ export * from "./transition.js";
19
+ if ("window" in globalThis) {
20
+ (_a = globalThis.window).__kiru ?? (_a.__kiru = createKiruGlobalContext());
21
+ }
22
+ export function mount(appFunc, optionsOrRoot, appProps = {}) {
23
+ let root, opts;
24
+ if (optionsOrRoot instanceof HTMLElement) {
25
+ root = optionsOrRoot;
26
+ opts = { root };
27
+ }
28
+ else {
29
+ opts = optionsOrRoot;
30
+ root = optionsOrRoot.root;
31
+ if (__DEV__) {
32
+ if (!(root instanceof HTMLElement)) {
33
+ throw new KiruError("Root node must be an HTMLElement");
34
+ }
35
+ }
36
+ }
37
+ ctx.current = createAppContext(appFunc, appProps, opts);
38
+ return ctx.current.mount();
39
+ }
40
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,gBAAgB,GAGjB,MAAM,iBAAiB,CAAA;AACxB,OAAO,EAAE,GAAG,EAAE,MAAM,cAAc,CAAA;AAClC,OAAO,EAAE,uBAAuB,EAAE,MAAM,oBAAoB,CAAA;AAC5D,OAAO,EAAE,OAAO,EAAE,MAAM,UAAU,CAAA;AAClC,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAA;AAGtC,cAAc,iBAAiB,CAAA;AAC/B,cAAc,cAAc,CAAA;AAC5B,cAAc,iBAAiB,CAAA;AAC/B,cAAc,cAAc,CAAA;AAC5B,cAAc,kBAAkB,CAAA;AAChC,cAAc,WAAW,CAAA;AACzB,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAA;AAChC,cAAc,aAAa,CAAA;AAC3B,cAAc,qBAAqB,CAAA;AACnC,cAAc,oBAAoB,CAAA;AAClC,cAAc,YAAY,CAAA;AAC1B,cAAc,iBAAiB,CAAA;AAE/B,IAAI,QAAQ,IAAI,UAAU,EAAE,CAAC;IAC3B,MAAA,UAAU,CAAC,MAAM,EAAC,MAAM,QAAN,MAAM,GAAK,uBAAuB,EAAE,EAAA;AACxD,CAAC;AAcD,MAAM,UAAU,KAAK,CACnB,OAAkC,EAClC,aAA8C,EAC9C,WAAW,EAAO;IAElB,IAAI,IAAiB,EAAE,IAAmC,CAAA;IAC1D,IAAI,aAAa,YAAY,WAAW,EAAE,CAAC;QACzC,IAAI,GAAG,aAAa,CAAA;QACpB,IAAI,GAAG,EAAE,IAAI,EAAE,CAAA;IACjB,CAAC;SAAM,CAAC;QACN,IAAI,GAAG,aAAa,CAAA;QACpB,IAAI,GAAG,aAAa,CAAC,IAAK,CAAA;QAC1B,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,CAAC,CAAC,IAAI,YAAY,WAAW,CAAC,EAAE,CAAC;gBACnC,MAAM,IAAI,SAAS,CAAC,kCAAkC,CAAC,CAAA;YACzD,CAAC;QACH,CAAC;IACH,CAAC;IACD,GAAG,CAAC,OAAO,GAAG,gBAAgB,CAAI,OAAO,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAA;IAC1D,OAAO,GAAG,CAAC,OAAO,CAAC,KAAK,EAAE,CAAA;AAC5B,CAAC"}
package/dist/jsx.d.ts ADDED
@@ -0,0 +1,6 @@
1
+ import { Fragment } from "./element.js";
2
+ export { jsx, jsx as jsxs, jsx as jsxDEV, Fragment };
3
+ declare function jsx(type: Kiru.VNode["type"], { children, ...props }?: {
4
+ children?: Kiru.VNode[];
5
+ }): Kiru.VNode;
6
+ //# sourceMappingURL=jsx.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jsx.d.ts","sourceRoot":"","sources":["../src/jsx.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiB,QAAQ,EAAE,MAAM,cAAc,CAAA;AAEtD,OAAO,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,EAAE,GAAG,IAAI,MAAM,EAAE,QAAQ,EAAE,CAAA;AAEpD,iBAAS,GAAG,CACV,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,EACxB,EAAE,QAAQ,EAAE,GAAG,KAAK,EAAE;eAAsB,IAAI,CAAC,KAAK,EAAE;CAAE,cAI3D"}