@v-ibe/core 0.1.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.
- package/LICENSE +21 -0
- package/README.md +40 -0
- package/dist/DI/__tests__/scoped-container-dependencies.test.d.ts +1 -0
- package/dist/DI/bootstrap.d.ts +18 -0
- package/dist/DI/decorators/inject.d.ts +37 -0
- package/dist/DI/decorators/inject.js +45 -0
- package/dist/DI/decorators/service.d.ts +24 -0
- package/dist/DI/decorators/service.js +13 -0
- package/dist/DI/di-container.d.ts +53 -0
- package/dist/DI/di-container.js +158 -0
- package/dist/DI/lifecycle.d.ts +37 -0
- package/dist/DI/lifecycle.js +6 -0
- package/dist/DI/scoped-container.d.ts +68 -0
- package/dist/DI/scoped-container.js +193 -0
- package/dist/DI/service-metadata.d.ts +32 -0
- package/dist/DI/service-metadata.js +31 -0
- package/dist/DI/types.d.ts +4 -0
- package/dist/behaviors/__tests__/behavior-system.test.d.ts +1 -0
- package/dist/behaviors/behavior-manager.d.ts +60 -0
- package/dist/behaviors/behavior-manager.js +131 -0
- package/dist/behaviors/behavior-registry.d.ts +68 -0
- package/dist/behaviors/behavior-registry.js +105 -0
- package/dist/behaviors/constants.d.ts +16 -0
- package/dist/behaviors/constants.js +8 -0
- package/dist/behaviors/decorators.d.ts +87 -0
- package/dist/behaviors/decorators.js +46 -0
- package/dist/behaviors/index.d.ts +4 -0
- package/dist/components/__tests__/host.test.d.ts +1 -0
- package/dist/components/app-tree.d.ts +49 -0
- package/dist/components/app-tree.js +122 -0
- package/dist/components/base-component.d.ts +85 -0
- package/dist/components/base-component.js +438 -0
- package/dist/components/decorators/component.d.ts +27 -0
- package/dist/components/decorators/component.js +47 -0
- package/dist/components/decorators/prop.d.ts +14 -0
- package/dist/components/decorators/prop.js +37 -0
- package/dist/components/types.d.ts +26 -0
- package/dist/core.d.ts +23 -0
- package/dist/core.js +8 -0
- package/dist/custom-components/__tests__/for.test.d.ts +1 -0
- package/dist/custom-components/__tests__/show.test.d.ts +1 -0
- package/dist/custom-components/for.d.ts +58 -0
- package/dist/custom-components/for.js +313 -0
- package/dist/custom-components/index.d.ts +2 -0
- package/dist/custom-components/show.d.ts +78 -0
- package/dist/custom-components/show.js +88 -0
- package/dist/data-management/cache/cache-invalidate.decorator.d.ts +35 -0
- package/dist/data-management/cache/cache-invalidate.decorator.js +21 -0
- package/dist/data-management/cache/cache-metadata.d.ts +15 -0
- package/dist/data-management/cache/cache-provider.interface.d.ts +67 -0
- package/dist/data-management/cache/cache-tags.decorator.d.ts +52 -0
- package/dist/data-management/cache/cache-tags.decorator.js +13 -0
- package/dist/data-management/cache/cache-update.decorator.d.ts +28 -0
- package/dist/data-management/cache/cache-update.decorator.js +21 -0
- package/dist/data-management/cache/cache.decorator.d.ts +28 -0
- package/dist/data-management/cache/cache.decorator.js +13 -0
- package/dist/data-management/cache/index.d.ts +11 -0
- package/dist/data-management/cache/local-storage-cache.d.ts +40 -0
- package/dist/data-management/cache/local-storage-cache.js +268 -0
- package/dist/data-management/cache/memory-cache.d.ts +37 -0
- package/dist/data-management/cache/memory-cache.js +149 -0
- package/dist/data-management/cache/session-storage-cache.d.ts +35 -0
- package/dist/data-management/cache/session-storage-cache.js +242 -0
- package/dist/data-management/cache/ttl.decorator.d.ts +31 -0
- package/dist/data-management/cache/ttl.decorator.js +34 -0
- package/dist/data-management/decorators/consume.d.ts +29 -0
- package/dist/data-management/decorators/consume.js +28 -0
- package/dist/data-management/decorators/id.d.ts +28 -0
- package/dist/data-management/decorators/id.js +19 -0
- package/dist/data-management/decorators/model.d.ts +48 -0
- package/dist/data-management/decorators/model.js +24 -0
- package/dist/data-management/decorators/prop.d.ts +43 -0
- package/dist/data-management/decorators/prop.js +32 -0
- package/dist/data-management/index.d.ts +13 -0
- package/dist/data-management/store/json-to-model.d.ts +45 -0
- package/dist/data-management/store/json-to-model.js +36 -0
- package/dist/data-management/store/store.d.ts +108 -0
- package/dist/data-management/store/store.js +207 -0
- package/dist/data-management/store/types.d.ts +53 -0
- package/dist/events-handler/decorators/emit.d.ts +29 -0
- package/dist/events-handler/decorators/emit.js +51 -0
- package/dist/events-handler/event-decorators.d.ts +1 -0
- package/dist/events-handler/event-emitter.service.d.ts +21 -0
- package/dist/events-handler/event-emitter.service.js +85 -0
- package/dist/events-handler/event-types.d.ts +12 -0
- package/dist/index.d.ts +55 -0
- package/dist/index.js +121 -0
- package/dist/jsx/dynamic/__tests__/granular-array-renderer.test.d.ts +1 -0
- package/dist/jsx/dynamic/__tests__/jsx-array-rendering.test.d.ts +1 -0
- package/dist/jsx/dynamic/array-renderer.d.ts +2 -0
- package/dist/jsx/dynamic/array-renderer.js +133 -0
- package/dist/jsx/dynamic/child-renderer.d.ts +1 -0
- package/dist/jsx/dynamic/child-renderer.js +180 -0
- package/dist/jsx/dynamic/dom-utils.d.ts +5 -0
- package/dist/jsx/dynamic/dom-utils.js +22 -0
- package/dist/jsx/dynamic/granular-array-renderer.d.ts +16 -0
- package/dist/jsx/dynamic/granular-array-renderer.js +153 -0
- package/dist/jsx/dynamic/node-renderer.d.ts +2 -0
- package/dist/jsx/dynamic/props-handler.d.ts +3 -0
- package/dist/jsx/dynamic/props-handler.js +281 -0
- package/dist/jsx/dynamic/text-renderer.d.ts +2 -0
- package/dist/jsx/jsx-dev-runtime.d.ts +2 -0
- package/dist/jsx/jsx-runtime.d.ts +3 -0
- package/dist/jsx/types.d.ts +35 -0
- package/dist/jsx/types.js +4 -0
- package/dist/jsx-dev-runtime.d.ts +2 -0
- package/dist/jsx-dev-runtime.js +8 -0
- package/dist/jsx-runtime.d.ts +2 -0
- package/dist/jsx-runtime.js +11 -0
- package/dist/reactivity/__tests__/context-stack.test.d.ts +1 -0
- package/dist/reactivity/__tests__/nested-effects-untrack.test.d.ts +22 -0
- package/dist/reactivity/context-scope.d.ts +57 -0
- package/dist/reactivity/context-scope.js +35 -0
- package/dist/reactivity/decorators/__tests__/ctx-integration.test.d.ts +5 -0
- package/dist/reactivity/decorators/__tests__/ctx-loop.test.d.ts +10 -0
- package/dist/reactivity/decorators/__tests__/state-intelligent.test.d.ts +1 -0
- package/dist/reactivity/decorators/computed.d.ts +6 -0
- package/dist/reactivity/decorators/computed.js +17 -0
- package/dist/reactivity/decorators/create-event-decorator.d.ts +5 -0
- package/dist/reactivity/decorators/create-event-decorator.js +28 -0
- package/dist/reactivity/decorators/ctx.d.ts +9 -0
- package/dist/reactivity/decorators/ctx.js +91 -0
- package/dist/reactivity/decorators/effect.d.ts +9 -0
- package/dist/reactivity/decorators/effect.js +24 -0
- package/dist/reactivity/decorators/resource.d.ts +48 -0
- package/dist/reactivity/decorators/resource.js +20 -0
- package/dist/reactivity/decorators/state.d.ts +8 -0
- package/dist/reactivity/decorators/state.js +68 -0
- package/dist/reactivity/decorators/store.d.ts +6 -0
- package/dist/reactivity/decorators/store.js +25 -0
- package/dist/reactivity/phase-scheduler.d.ts +81 -0
- package/dist/reactivity/phase-scheduler.js +88 -0
- package/dist/reactivity/phase-scheduler.test.d.ts +1 -0
- package/dist/reactivity/reactive-cache.d.ts +21 -0
- package/dist/reactivity/reactive-cache.js +31 -0
- package/dist/reactivity/reactive-cache.test.d.ts +1 -0
- package/dist/reactivity/reactive-context.d.ts +152 -0
- package/dist/reactivity/reactive-context.js +184 -0
- package/dist/reactivity/signals/__tests__/composicion-automatica.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/composite/nivel-1-estructura-basica.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/composite/nivel-2-registro-subscribers.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/composite/nivel-3-notificaciones-basicas.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/composite/nivel-4-comparacion-valores.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/composite/nivel-5-tracking-automatico.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/composite/nivel-6-anti-glitch.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/composite/nivel-7-objetos-anidados.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/composite/nivel-8-observable-array-support.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/composite-shallow-tracking.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/effect.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/reactive-array/nivel-1-estructura-basica.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/reactive-array/nivel-2-metodos-mutadores.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/reactive-array/nivel-3-tracking-por-indice.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/reactive-array/nivel-4-tracking-length.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/reactive-array/nivel-5-tracking-mutation.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/reactive-array/nivel-6-metodos-no-mutadores.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/reactive-array/nivel-7-composicion-bidireccional.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/reactive-array/nivel-8-proxies.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/reactive-array/nivel-9-derived-cache-optimization.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/resource.test.d.ts +1 -0
- package/dist/reactivity/signals/__tests__/signal.test.d.ts +1 -0
- package/dist/reactivity/signals/array-strategies.d.ts +120 -0
- package/dist/reactivity/signals/array-strategies.js +261 -0
- package/dist/reactivity/signals/composite.d.ts +89 -0
- package/dist/reactivity/signals/composite.js +145 -0
- package/dist/reactivity/signals/computed.d.ts +61 -0
- package/dist/reactivity/signals/computed.js +107 -0
- package/dist/reactivity/signals/computed.test.d.ts +1 -0
- package/dist/reactivity/signals/derived.d.ts +10 -0
- package/dist/reactivity/signals/derived.js +24 -0
- package/dist/reactivity/signals/effect.d.ts +27 -0
- package/dist/reactivity/signals/effect.js +46 -0
- package/dist/reactivity/signals/event.d.ts +9 -0
- package/dist/reactivity/signals/event.js +15 -0
- package/dist/reactivity/signals/reactive-array.d.ts +133 -0
- package/dist/reactivity/signals/reactive-array.js +490 -0
- package/dist/reactivity/signals/reactive-proxy.d.ts +54 -0
- package/dist/reactivity/signals/reactive-proxy.js +299 -0
- package/dist/reactivity/signals/reactive-tracking.test.d.ts +1 -0
- package/dist/reactivity/signals/resource.d.ts +9 -0
- package/dist/reactivity/signals/resource.js +58 -0
- package/dist/reactivity/signals/signal.d.ts +39 -0
- package/dist/reactivity/signals/signal.js +56 -0
- package/dist/reactivity/signals/subscription-management.test.d.ts +1 -0
- package/dist/reactivity/types.d.ts +12 -0
- package/dist/router/__tests__/link-behavior-active-class.test.d.ts +1 -0
- package/dist/router/__tests__/loop-detector.test.d.ts +1 -0
- package/dist/router/__tests__/params-container-resolution.test.d.ts +1 -0
- package/dist/router/__tests__/router-generated-routes.test.d.ts +1 -0
- package/dist/router/__tests__/router-params-granular.test.d.ts +1 -0
- package/dist/router/__tests__/router-params-simple.test.d.ts +1 -0
- package/dist/router/__tests__/router-query-params.test.d.ts +1 -0
- package/dist/router/__tests__/router-route-candidates.test.d.ts +1 -0
- package/dist/router/__tests__/routeview-app-articles.test.d.ts +1 -0
- package/dist/router/__tests__/routeview-debug.test.d.ts +1 -0
- package/dist/router/__tests__/routeview-integration.test.d.ts +1 -0
- package/dist/router/__tests__/routeview-this.test.d.ts +1 -0
- package/dist/router/decorators/base-policy.d.ts +141 -0
- package/dist/router/decorators/base-policy.js +63 -0
- package/dist/router/decorators/index.d.ts +6 -0
- package/dist/router/decorators/params.d.ts +31 -0
- package/dist/router/decorators/params.js +97 -0
- package/dist/router/decorators/route-metadata.d.ts +11 -0
- package/dist/router/decorators/route-metadata.js +23 -0
- package/dist/router/decorators/route.d.ts +39 -0
- package/dist/router/decorators/route.js +7 -0
- package/dist/router/link.behavior.d.ts +87 -0
- package/dist/router/link.behavior.js +227 -0
- package/dist/router/policy-evaluator.d.ts +81 -0
- package/dist/router/policy-evaluator.js +209 -0
- package/dist/router/route-view.d.ts +56 -0
- package/dist/router/route-view.js +156 -0
- package/dist/router/router.d.ts +67 -0
- package/dist/router/router.js +308 -0
- package/dist/router/static-analysis/index.d.ts +37 -0
- package/dist/router/static-analysis/parser.d.ts +14 -0
- package/dist/router/static-analysis/parser.js +147 -0
- package/dist/router/static-analysis/scanner.d.ts +27 -0
- package/dist/router/static-analysis/scanner.js +91 -0
- package/dist/router/trie.d.ts +14 -0
- package/dist/router/trie.js +126 -0
- package/dist/router/trie.types.d.ts +36 -0
- package/dist/styles/base-style-sheet.d.ts +96 -0
- package/dist/styles/base-style-sheet.js +149 -0
- package/dist/styles/decorators/factories.d.ts +76 -0
- package/dist/styles/decorators/factories.js +11 -0
- package/dist/styles/decorators/keyframes.d.ts +238 -0
- package/dist/styles/decorators/keyframes.js +79 -0
- package/dist/styles/decorators/rule.d.ts +177 -0
- package/dist/styles/decorators/rule.js +72 -0
- package/dist/styles/decorators/scope.d.ts +66 -0
- package/dist/styles/decorators/scope.js +17 -0
- package/dist/styles/decorators/style.d.ts +1 -0
- package/dist/styles/decorators/style.js +20 -0
- package/dist/styles/decorators/useStyles.d.ts +5 -0
- package/dist/styles/decorators/useStyles.js +29 -0
- package/dist/styles/global-styles-registry.d.ts +72 -0
- package/dist/styles/global-styles-registry.js +155 -0
- package/dist/types.d.ts +1 -0
- package/dist/vite-plugins/__tests__/jsx-control-flow-transform.test.d.ts +1 -0
- package/dist/vite-plugins/index.d.ts +4 -0
- package/dist/vite-plugins/index.js +10 -0
- package/dist/vite-plugins/jsx-contextual.d.ts +7 -0
- package/dist/vite-plugins/jsx-contextual.js +53 -0
- package/dist/vite-plugins/jsx-control-flow-transform.d.ts +60 -0
- package/dist/vite-plugins/jsx-control-flow-transform.js +180 -0
- package/dist/vite-plugins/jsx-signals.d.ts +2 -0
- package/dist/vite-plugins/jsx-signals.js +124 -0
- package/dist/vite-plugins/router/route-generator-plugin.d.ts +63 -0
- package/dist/vite-plugins/router/route-generator-plugin.js +310 -0
- package/package.json +85 -0
package/dist/index.js
ADDED
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import { BaseComponent } from "./components/base-component.js";
|
|
2
|
+
import { Component } from "./components/decorators/component.js";
|
|
3
|
+
import { Prop } from "./components/decorators/prop.js";
|
|
4
|
+
import { Route } from "./router/decorators/route.js";
|
|
5
|
+
import { Param, Params, Query, QueryParams } from "./router/decorators/params.js";
|
|
6
|
+
import { Allow, Block, Redirect, Skip, getPolicyRules } from "./router/decorators/base-policy.js";
|
|
7
|
+
import { State } from "./reactivity/decorators/state.js";
|
|
8
|
+
import { Effect } from "./reactivity/decorators/effect.js";
|
|
9
|
+
import { Computed } from "./reactivity/decorators/computed.js";
|
|
10
|
+
import { Resource } from "./reactivity/decorators/resource.js";
|
|
11
|
+
import { Store } from "./reactivity/decorators/store.js";
|
|
12
|
+
import { RouteMetadata } from "./router/decorators/route-metadata.js";
|
|
13
|
+
import { Ctx } from "./reactivity/decorators/ctx.js";
|
|
14
|
+
import { ReactiveArray, collection, isCollection, isObservableArray, isReactiveArrayLike, unwrapReactiveArray } from "./reactivity/signals/reactive-array.js";
|
|
15
|
+
import { Emit } from "./events-handler/decorators/emit.js";
|
|
16
|
+
import { BaseStyleSheet } from "./styles/base-style-sheet.js";
|
|
17
|
+
import { Style } from "./styles/decorators/style.js";
|
|
18
|
+
import { Service } from "./DI/decorators/service.js";
|
|
19
|
+
import { Inject } from "./DI/decorators/inject.js";
|
|
20
|
+
import { DIContainer } from "./DI/di-container.js";
|
|
21
|
+
import { ScopedContainer } from "./DI/scoped-container.js";
|
|
22
|
+
import { clearServiceMetadata, getAllServiceMetadata, getServiceMetadata, registerServiceMetadata } from "./DI/service-metadata.js";
|
|
23
|
+
import { core } from "./core.js";
|
|
24
|
+
import { Rule } from "./styles/decorators/rule.js";
|
|
25
|
+
import { UseStyles } from "./styles/decorators/useStyles.js";
|
|
26
|
+
import { Behavior, ComponentHost, Host } from "./behaviors/decorators.js";
|
|
27
|
+
import "./behaviors/behavior-registry.js";
|
|
28
|
+
import { MediaQuery } from "./styles/decorators/factories.js";
|
|
29
|
+
import { ForDocument, Shared } from "./styles/decorators/scope.js";
|
|
30
|
+
import { Keyframes } from "./styles/decorators/keyframes.js";
|
|
31
|
+
import { jsxContextualPlugin } from "./vite-plugins/jsx-contextual.js";
|
|
32
|
+
import { jsxSignalsPlugin } from "./vite-plugins/jsx-signals.js";
|
|
33
|
+
import { Router } from "./router/router.js";
|
|
34
|
+
import { Trie } from "./router/trie.js";
|
|
35
|
+
import { RouteView } from "./router/route-view.js";
|
|
36
|
+
import { Link } from "./router/link.behavior.js";
|
|
37
|
+
import { EntityStore } from "./data-management/store/store.js";
|
|
38
|
+
import { Model } from "./data-management/decorators/model.js";
|
|
39
|
+
import { Id } from "./data-management/decorators/id.js";
|
|
40
|
+
import { Prop as Prop2 } from "./data-management/decorators/prop.js";
|
|
41
|
+
import { Consume } from "./data-management/decorators/consume.js";
|
|
42
|
+
import { MemoryCache } from "./data-management/cache/memory-cache.js";
|
|
43
|
+
import { LocalStorageCache } from "./data-management/cache/local-storage-cache.js";
|
|
44
|
+
import { SessionStorageCache } from "./data-management/cache/session-storage-cache.js";
|
|
45
|
+
import { Cache } from "./data-management/cache/cache.decorator.js";
|
|
46
|
+
import { TTL } from "./data-management/cache/ttl.decorator.js";
|
|
47
|
+
import { CacheTags } from "./data-management/cache/cache-tags.decorator.js";
|
|
48
|
+
import { CacheUpdate } from "./data-management/cache/cache-update.decorator.js";
|
|
49
|
+
import { CacheInvalidate } from "./data-management/cache/cache-invalidate.decorator.js";
|
|
50
|
+
import { For } from "./custom-components/for.js";
|
|
51
|
+
import { Show } from "./custom-components/show.js";
|
|
52
|
+
export {
|
|
53
|
+
Allow,
|
|
54
|
+
BaseComponent,
|
|
55
|
+
BaseStyleSheet,
|
|
56
|
+
Behavior,
|
|
57
|
+
Block,
|
|
58
|
+
Cache,
|
|
59
|
+
CacheInvalidate,
|
|
60
|
+
CacheTags,
|
|
61
|
+
CacheUpdate,
|
|
62
|
+
Component,
|
|
63
|
+
ComponentHost,
|
|
64
|
+
Computed,
|
|
65
|
+
Consume,
|
|
66
|
+
Ctx,
|
|
67
|
+
DIContainer,
|
|
68
|
+
Effect,
|
|
69
|
+
Emit,
|
|
70
|
+
EntityStore,
|
|
71
|
+
Prop2 as Field,
|
|
72
|
+
For,
|
|
73
|
+
ForDocument,
|
|
74
|
+
Host,
|
|
75
|
+
Id,
|
|
76
|
+
Inject,
|
|
77
|
+
Keyframes,
|
|
78
|
+
Link,
|
|
79
|
+
LocalStorageCache,
|
|
80
|
+
MediaQuery,
|
|
81
|
+
MemoryCache,
|
|
82
|
+
Model,
|
|
83
|
+
Param,
|
|
84
|
+
Params,
|
|
85
|
+
Prop,
|
|
86
|
+
Query,
|
|
87
|
+
QueryParams,
|
|
88
|
+
ReactiveArray,
|
|
89
|
+
Redirect,
|
|
90
|
+
Resource,
|
|
91
|
+
Route,
|
|
92
|
+
RouteMetadata,
|
|
93
|
+
RouteView,
|
|
94
|
+
Router,
|
|
95
|
+
Rule,
|
|
96
|
+
ScopedContainer,
|
|
97
|
+
Service,
|
|
98
|
+
SessionStorageCache,
|
|
99
|
+
Shared,
|
|
100
|
+
Show,
|
|
101
|
+
Skip,
|
|
102
|
+
State,
|
|
103
|
+
Store,
|
|
104
|
+
Style,
|
|
105
|
+
TTL,
|
|
106
|
+
Trie,
|
|
107
|
+
UseStyles,
|
|
108
|
+
clearServiceMetadata,
|
|
109
|
+
collection,
|
|
110
|
+
core,
|
|
111
|
+
getAllServiceMetadata,
|
|
112
|
+
getPolicyRules,
|
|
113
|
+
getServiceMetadata,
|
|
114
|
+
isCollection,
|
|
115
|
+
isObservableArray,
|
|
116
|
+
isReactiveArrayLike,
|
|
117
|
+
jsxContextualPlugin,
|
|
118
|
+
jsxSignalsPlugin,
|
|
119
|
+
registerServiceMetadata,
|
|
120
|
+
unwrapReactiveArray
|
|
121
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
import { effect } from "../../reactivity/signals/effect.js";
|
|
2
|
+
import { isDOMNode, replaceNode } from "./dom-utils.js";
|
|
3
|
+
function renderArrayChild(parent, children) {
|
|
4
|
+
const anchor = document.createComment("array-child");
|
|
5
|
+
parent.appendChild(anchor);
|
|
6
|
+
const getter = typeof children === "function" ? children : () => children;
|
|
7
|
+
let arrayState = {
|
|
8
|
+
keyMap: /* @__PURE__ */ new Map(),
|
|
9
|
+
nodeOrder: [],
|
|
10
|
+
reactiveEntries: /* @__PURE__ */ new Map()
|
|
11
|
+
};
|
|
12
|
+
effect(
|
|
13
|
+
() => {
|
|
14
|
+
const items = getter();
|
|
15
|
+
if (!items || typeof items[Symbol.iterator] !== "function") return;
|
|
16
|
+
const newNodeOrder = [];
|
|
17
|
+
const usedNodes = /* @__PURE__ */ new Set();
|
|
18
|
+
let index = 0;
|
|
19
|
+
for (const item of items) {
|
|
20
|
+
if (item == null || typeof item === "boolean") {
|
|
21
|
+
index++;
|
|
22
|
+
continue;
|
|
23
|
+
}
|
|
24
|
+
const key = extractKey(item, index);
|
|
25
|
+
newNodeOrder.push(key);
|
|
26
|
+
const node = reuseOrCreateNode(parent, arrayState, key, item);
|
|
27
|
+
usedNodes.add(node);
|
|
28
|
+
index++;
|
|
29
|
+
}
|
|
30
|
+
removeUnusedNodes(arrayState, usedNodes);
|
|
31
|
+
reorderNodes(anchor, arrayState.keyMap, newNodeOrder);
|
|
32
|
+
arrayState.nodeOrder = newNodeOrder;
|
|
33
|
+
}
|
|
34
|
+
);
|
|
35
|
+
}
|
|
36
|
+
function extractKey(item, index) {
|
|
37
|
+
if (item?.getAttribute?.("key")) {
|
|
38
|
+
return String(item.getAttribute("key"));
|
|
39
|
+
}
|
|
40
|
+
if (item?.props?.key != null) {
|
|
41
|
+
return String(item.props.key);
|
|
42
|
+
}
|
|
43
|
+
if (item?.key != null) {
|
|
44
|
+
return String(item.key);
|
|
45
|
+
}
|
|
46
|
+
return `__index_${index}`;
|
|
47
|
+
}
|
|
48
|
+
function reuseOrCreateNode(parent, arrayState, key, item) {
|
|
49
|
+
const { keyMap } = arrayState;
|
|
50
|
+
if (typeof item === "function") {
|
|
51
|
+
return reuseOrCreateReactiveNode(parent, arrayState, key, item);
|
|
52
|
+
}
|
|
53
|
+
if (keyMap.has(key)) {
|
|
54
|
+
const existingNode = keyMap.get(key);
|
|
55
|
+
if (isDOMNode(item) && existingNode !== item) {
|
|
56
|
+
const newNode = item;
|
|
57
|
+
existingNode.parentNode?.replaceChild(newNode, existingNode);
|
|
58
|
+
keyMap.set(key, newNode);
|
|
59
|
+
return newNode;
|
|
60
|
+
}
|
|
61
|
+
return existingNode;
|
|
62
|
+
}
|
|
63
|
+
const node = isDOMNode(item) ? item : document.createTextNode(String(item));
|
|
64
|
+
keyMap.set(key, node);
|
|
65
|
+
return node;
|
|
66
|
+
}
|
|
67
|
+
function reuseOrCreateReactiveNode(parent, arrayState, key, fn) {
|
|
68
|
+
const { keyMap, reactiveEntries } = arrayState;
|
|
69
|
+
if (reactiveEntries.has(key)) {
|
|
70
|
+
const entry2 = reactiveEntries.get(key);
|
|
71
|
+
return entry2.anchor;
|
|
72
|
+
}
|
|
73
|
+
const anchor = document.createComment(`reactive-array-child-${key}`);
|
|
74
|
+
const entry = { anchor, currentNode: null };
|
|
75
|
+
reactiveEntries.set(key, entry);
|
|
76
|
+
keyMap.set(key, anchor);
|
|
77
|
+
effect(() => {
|
|
78
|
+
const value = fn();
|
|
79
|
+
if (value == null || typeof value === "boolean") {
|
|
80
|
+
if (entry.currentNode) {
|
|
81
|
+
entry.currentNode.parentNode?.removeChild(entry.currentNode);
|
|
82
|
+
entry.currentNode = null;
|
|
83
|
+
}
|
|
84
|
+
return;
|
|
85
|
+
}
|
|
86
|
+
if (isDOMNode(value)) {
|
|
87
|
+
const newNode = value;
|
|
88
|
+
if (entry.currentNode !== newNode) {
|
|
89
|
+
replaceNode(anchor, entry.currentNode, newNode);
|
|
90
|
+
entry.currentNode = newNode;
|
|
91
|
+
}
|
|
92
|
+
return;
|
|
93
|
+
}
|
|
94
|
+
const text = String(value);
|
|
95
|
+
if (entry.currentNode && entry.currentNode.nodeType === Node.TEXT_NODE) {
|
|
96
|
+
entry.currentNode.nodeValue = text;
|
|
97
|
+
} else {
|
|
98
|
+
const newNode = document.createTextNode(text);
|
|
99
|
+
replaceNode(anchor, entry.currentNode, newNode);
|
|
100
|
+
entry.currentNode = newNode;
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
return anchor;
|
|
104
|
+
}
|
|
105
|
+
function removeUnusedNodes(arrayState, usedNodes) {
|
|
106
|
+
const { keyMap, reactiveEntries } = arrayState;
|
|
107
|
+
for (const [key, node] of keyMap.entries()) {
|
|
108
|
+
if (!usedNodes.has(node)) {
|
|
109
|
+
node.parentNode?.removeChild(node);
|
|
110
|
+
keyMap.delete(key);
|
|
111
|
+
if (reactiveEntries.has(key)) {
|
|
112
|
+
const entry = reactiveEntries.get(key);
|
|
113
|
+
if (entry.currentNode) {
|
|
114
|
+
entry.currentNode.parentNode?.removeChild(entry.currentNode);
|
|
115
|
+
}
|
|
116
|
+
reactiveEntries.delete(key);
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
function reorderNodes(anchor, keyMap, newOrder) {
|
|
122
|
+
let previousNode = anchor;
|
|
123
|
+
newOrder.forEach((key) => {
|
|
124
|
+
const node = keyMap.get(key);
|
|
125
|
+
if (previousNode.nextSibling !== node) {
|
|
126
|
+
previousNode.parentNode?.insertBefore(node, previousNode.nextSibling);
|
|
127
|
+
}
|
|
128
|
+
previousNode = node;
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
export {
|
|
132
|
+
renderArrayChild
|
|
133
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function renderChild(parent: Element | ShadowRoot, child: any): void;
|
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
import { isSignal } from "../../reactivity/signals/signal.js";
|
|
2
|
+
import { effect } from "../../reactivity/signals/effect.js";
|
|
3
|
+
import { isValidChild, isDOMNode, replaceNode } from "./dom-utils.js";
|
|
4
|
+
import { renderArrayChild } from "./array-renderer.js";
|
|
5
|
+
import { isReactiveArrayLike } from "../../reactivity/signals/reactive-array.js";
|
|
6
|
+
import { renderArrayChildGranular } from "./granular-array-renderer.js";
|
|
7
|
+
function isIterable(value) {
|
|
8
|
+
if (!value || typeof value !== "object") return false;
|
|
9
|
+
return typeof value[Symbol.iterator] === "function" && typeof value.length === "number";
|
|
10
|
+
}
|
|
11
|
+
function renderChild(parent, child) {
|
|
12
|
+
if (!isValidChild(child)) return;
|
|
13
|
+
if (isReactiveArrayLike(child)) {
|
|
14
|
+
renderArrayChildGranular(parent, child);
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
if (isIterable(child)) {
|
|
18
|
+
renderArrayChild(parent, child);
|
|
19
|
+
} else if (isDOMNode(child)) {
|
|
20
|
+
parent.appendChild(child);
|
|
21
|
+
} else if (isSignal(child)) {
|
|
22
|
+
renderSignalChild(parent, child);
|
|
23
|
+
} else if (typeof child === "function") {
|
|
24
|
+
renderReactiveChild(parent, child);
|
|
25
|
+
} else {
|
|
26
|
+
const textNode = document.createTextNode(String(child));
|
|
27
|
+
parent.appendChild(textNode);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
function renderSignalChild(parent, signal) {
|
|
31
|
+
const anchor = document.createComment("signal-child");
|
|
32
|
+
parent.appendChild(anchor);
|
|
33
|
+
let currentNode = null;
|
|
34
|
+
effect(
|
|
35
|
+
() => {
|
|
36
|
+
const value = signal.get();
|
|
37
|
+
if (value == null || typeof value === "boolean") {
|
|
38
|
+
if (currentNode) {
|
|
39
|
+
currentNode.parentNode?.removeChild(currentNode);
|
|
40
|
+
currentNode = null;
|
|
41
|
+
}
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
const text = String(value);
|
|
45
|
+
if (currentNode && currentNode.nodeType === Node.TEXT_NODE) {
|
|
46
|
+
currentNode.nodeValue = text;
|
|
47
|
+
} else {
|
|
48
|
+
const newNode = document.createTextNode(text);
|
|
49
|
+
replaceNode(anchor, currentNode, newNode);
|
|
50
|
+
currentNode = newNode;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
);
|
|
54
|
+
}
|
|
55
|
+
function renderReactiveChild(parent, child) {
|
|
56
|
+
const anchor = document.createComment("reactive-child");
|
|
57
|
+
parent.appendChild(anchor);
|
|
58
|
+
let currentNode = null;
|
|
59
|
+
let currentType = "empty";
|
|
60
|
+
Math.random().toString(36).substring(7);
|
|
61
|
+
let executionCount = 0;
|
|
62
|
+
effect(() => {
|
|
63
|
+
executionCount++;
|
|
64
|
+
const value = child();
|
|
65
|
+
if (value == null || typeof value === "boolean") {
|
|
66
|
+
if (currentNode) {
|
|
67
|
+
currentNode.parentNode?.removeChild(currentNode);
|
|
68
|
+
currentNode = null;
|
|
69
|
+
currentType = "empty";
|
|
70
|
+
}
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
if (isIterable(value)) {
|
|
74
|
+
if (currentType !== "array" && currentNode) {
|
|
75
|
+
currentNode.parentNode?.removeChild(currentNode);
|
|
76
|
+
currentNode = null;
|
|
77
|
+
}
|
|
78
|
+
reconcileArrayNodes(anchor, value);
|
|
79
|
+
currentType = "array";
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
if (typeof value === "function") {
|
|
83
|
+
const result = value();
|
|
84
|
+
if (isDOMNode(result)) {
|
|
85
|
+
const newNode = result;
|
|
86
|
+
if (currentType !== "node" || currentNode !== newNode) {
|
|
87
|
+
replaceNode(anchor, currentNode, newNode);
|
|
88
|
+
currentNode = newNode;
|
|
89
|
+
currentType = "node";
|
|
90
|
+
}
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
if (typeof result === "function") {
|
|
94
|
+
const finalResult = result();
|
|
95
|
+
if (isDOMNode(finalResult)) {
|
|
96
|
+
const newNode = finalResult;
|
|
97
|
+
if (currentType !== "node" || currentNode !== newNode) {
|
|
98
|
+
replaceNode(anchor, currentNode, newNode);
|
|
99
|
+
currentNode = newNode;
|
|
100
|
+
currentType = "node";
|
|
101
|
+
}
|
|
102
|
+
return;
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
if (isDOMNode(value)) {
|
|
107
|
+
const newNode = value;
|
|
108
|
+
if (currentType !== "node" || currentNode !== newNode) {
|
|
109
|
+
replaceNode(anchor, currentNode, newNode);
|
|
110
|
+
currentNode = newNode;
|
|
111
|
+
currentType = "node";
|
|
112
|
+
}
|
|
113
|
+
return;
|
|
114
|
+
}
|
|
115
|
+
const text = String(value);
|
|
116
|
+
if (currentType === "text" && currentNode) {
|
|
117
|
+
currentNode.nodeValue = text;
|
|
118
|
+
} else {
|
|
119
|
+
const newNode = document.createTextNode(text);
|
|
120
|
+
replaceNode(anchor, currentNode, newNode);
|
|
121
|
+
currentNode = newNode;
|
|
122
|
+
currentType = "text";
|
|
123
|
+
}
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
const arrayEndMarkers = /* @__PURE__ */ new WeakMap();
|
|
127
|
+
function reconcileArrayNodes(anchor, items) {
|
|
128
|
+
const parent = anchor.parentNode;
|
|
129
|
+
if (!parent) return;
|
|
130
|
+
let endMarker = arrayEndMarkers.get(anchor);
|
|
131
|
+
if (!endMarker) {
|
|
132
|
+
endMarker = document.createComment("array-end");
|
|
133
|
+
parent.insertBefore(endMarker, anchor.nextSibling);
|
|
134
|
+
arrayEndMarkers.set(anchor, endMarker);
|
|
135
|
+
}
|
|
136
|
+
const existingNodes = [];
|
|
137
|
+
let node = anchor.nextSibling;
|
|
138
|
+
while (node && node !== endMarker) {
|
|
139
|
+
existingNodes.push(node);
|
|
140
|
+
node = node.nextSibling;
|
|
141
|
+
}
|
|
142
|
+
const newNodes = [];
|
|
143
|
+
for (const item of items) {
|
|
144
|
+
if (item == null || typeof item === "boolean") {
|
|
145
|
+
continue;
|
|
146
|
+
}
|
|
147
|
+
if (isDOMNode(item)) {
|
|
148
|
+
newNodes.push(item);
|
|
149
|
+
} else if (typeof item === "function") {
|
|
150
|
+
const result = item();
|
|
151
|
+
if (result != null && typeof result !== "boolean") {
|
|
152
|
+
if (isDOMNode(result)) {
|
|
153
|
+
newNodes.push(result);
|
|
154
|
+
} else {
|
|
155
|
+
newNodes.push(document.createTextNode(String(result)));
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
} else {
|
|
159
|
+
newNodes.push(document.createTextNode(String(item)));
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
const maxLen = Math.max(existingNodes.length, newNodes.length);
|
|
163
|
+
for (let i = 0; i < maxLen; i++) {
|
|
164
|
+
const existingNode = existingNodes[i];
|
|
165
|
+
const newNode = newNodes[i];
|
|
166
|
+
if (i < existingNodes.length && i < newNodes.length) {
|
|
167
|
+
if (existingNode === newNode) ;
|
|
168
|
+
else {
|
|
169
|
+
parent.replaceChild(newNode, existingNode);
|
|
170
|
+
}
|
|
171
|
+
} else if (i >= existingNodes.length) {
|
|
172
|
+
parent.insertBefore(newNode, endMarker);
|
|
173
|
+
} else {
|
|
174
|
+
parent.removeChild(existingNode);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
export {
|
|
179
|
+
renderChild
|
|
180
|
+
};
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { ChildValue } from '../types';
|
|
2
|
+
export declare function isCustomElement(el: Element): boolean;
|
|
3
|
+
export declare function isValidChild(child: any): child is ChildValue;
|
|
4
|
+
export declare function isDOMNode(value: any): value is Node;
|
|
5
|
+
export declare function replaceNode(anchor: Comment, oldNode: Node | null, newNode: Node): void;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
function isCustomElement(el) {
|
|
2
|
+
return el.tagName.includes("-");
|
|
3
|
+
}
|
|
4
|
+
function isValidChild(child) {
|
|
5
|
+
return child != null && typeof child !== "boolean";
|
|
6
|
+
}
|
|
7
|
+
function isDOMNode(value) {
|
|
8
|
+
return value && value.nodeType;
|
|
9
|
+
}
|
|
10
|
+
function replaceNode(anchor, oldNode, newNode) {
|
|
11
|
+
if (oldNode) {
|
|
12
|
+
oldNode.parentNode?.replaceChild(newNode, oldNode);
|
|
13
|
+
} else {
|
|
14
|
+
anchor.parentNode?.insertBefore(newNode, anchor.nextSibling);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
export {
|
|
18
|
+
isCustomElement,
|
|
19
|
+
isDOMNode,
|
|
20
|
+
isValidChild,
|
|
21
|
+
replaceNode
|
|
22
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* GRANULAR ARRAY RENDERER - Acceso por índice en lugar de iteración
|
|
3
|
+
*
|
|
4
|
+
* La clave es NO iterar con for...of sino acceder a elementos por índice.
|
|
5
|
+
* Esto permite que cada elemento tenga su propio effect que solo se suscribe
|
|
6
|
+
* a cambios en ese índice específico.
|
|
7
|
+
*
|
|
8
|
+
* Reconciliación:
|
|
9
|
+
* 1. Leer length (se suscribe a cambios de longitud)
|
|
10
|
+
* 2. Para cada índice 0..length-1, crear/reutilizar un effect individual
|
|
11
|
+
* 3. Cada effect accede a array.at(i), suscribiéndose solo a ese índice
|
|
12
|
+
* 4. Cuando array[i] cambia, solo ese effect se re-ejecuta
|
|
13
|
+
*
|
|
14
|
+
* IMPORTANTE: Requiere que el array sea un ReactiveArray real, no un array plano.
|
|
15
|
+
*/
|
|
16
|
+
export declare function renderArrayChildGranular(parent: Element | ShadowRoot, arrayLike: any): void;
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
import { effect } from "../../reactivity/signals/effect.js";
|
|
2
|
+
import { isDOMNode, replaceNode } from "./dom-utils.js";
|
|
3
|
+
import { unwrapReactiveArray } from "../../reactivity/signals/reactive-array.js";
|
|
4
|
+
import { CompositeSignal } from "../../reactivity/signals/composite.js";
|
|
5
|
+
function renderArrayChildGranular(parent, arrayLike) {
|
|
6
|
+
const anchor = document.createComment("array-child-granular");
|
|
7
|
+
parent.appendChild(anchor);
|
|
8
|
+
const reactiveArray = unwrapReactiveArray(arrayLike);
|
|
9
|
+
if (!reactiveArray) {
|
|
10
|
+
console.warn("[Granular Renderer] Value is not a ReactiveArray, cannot use granular rendering");
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
let arrayState = {
|
|
14
|
+
keyMap: /* @__PURE__ */ new Map(),
|
|
15
|
+
nodeOrder: [],
|
|
16
|
+
reactiveEntries: /* @__PURE__ */ new Map()
|
|
17
|
+
};
|
|
18
|
+
const effectCleanups = /* @__PURE__ */ new Map();
|
|
19
|
+
effect(
|
|
20
|
+
() => {
|
|
21
|
+
const currentLength = reactiveArray.length;
|
|
22
|
+
const newNodeOrder = [];
|
|
23
|
+
const keysToCreate = /* @__PURE__ */ new Set();
|
|
24
|
+
const existingKeys = new Set(arrayState.nodeOrder);
|
|
25
|
+
for (let i = 0; i < currentLength; i++) {
|
|
26
|
+
const key = `__index_${i}`;
|
|
27
|
+
newNodeOrder.push(key);
|
|
28
|
+
if (!existingKeys.has(key)) {
|
|
29
|
+
keysToCreate.add(key);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
for (const oldKey of existingKeys) {
|
|
33
|
+
if (!newNodeOrder.includes(oldKey)) {
|
|
34
|
+
removeKey(arrayState, effectCleanups, oldKey);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
for (const key of keysToCreate) {
|
|
38
|
+
const index = newNodeOrder.indexOf(key);
|
|
39
|
+
if (!arrayState.reactiveEntries.has(key)) {
|
|
40
|
+
createKeyEffect(
|
|
41
|
+
parent,
|
|
42
|
+
arrayState,
|
|
43
|
+
effectCleanups,
|
|
44
|
+
key,
|
|
45
|
+
index,
|
|
46
|
+
reactiveArray
|
|
47
|
+
);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
reorderNodes(anchor, arrayState.keyMap, newNodeOrder);
|
|
51
|
+
arrayState.nodeOrder = newNodeOrder;
|
|
52
|
+
}
|
|
53
|
+
);
|
|
54
|
+
}
|
|
55
|
+
function createKeyEffect(parent, arrayState, effectCleanups, key, index, reactiveArray) {
|
|
56
|
+
const anchor = document.createComment(`reactive-array-child-${key}`);
|
|
57
|
+
parent.appendChild(anchor);
|
|
58
|
+
const entry = { anchor, currentNode: null };
|
|
59
|
+
arrayState.reactiveEntries.set(key, entry);
|
|
60
|
+
arrayState.keyMap.set(key, anchor);
|
|
61
|
+
const effectHandle = effect(() => {
|
|
62
|
+
let item = reactiveArray.at(index);
|
|
63
|
+
if (item instanceof CompositeSignal) {
|
|
64
|
+
const plainValue = item.getPlainValue();
|
|
65
|
+
if (isDOMNode(plainValue)) {
|
|
66
|
+
item = plainValue;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
if (item == null || typeof item === "boolean") {
|
|
70
|
+
if (entry.currentNode) {
|
|
71
|
+
entry.currentNode.parentNode?.removeChild(entry.currentNode);
|
|
72
|
+
entry.currentNode = null;
|
|
73
|
+
}
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
if (typeof item === "function") {
|
|
77
|
+
const value = item();
|
|
78
|
+
if (value == null || typeof value === "boolean") {
|
|
79
|
+
if (entry.currentNode) {
|
|
80
|
+
entry.currentNode.parentNode?.removeChild(entry.currentNode);
|
|
81
|
+
entry.currentNode = null;
|
|
82
|
+
}
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
if (isDOMNode(value)) {
|
|
86
|
+
const newNode = value;
|
|
87
|
+
if (entry.currentNode !== newNode) {
|
|
88
|
+
replaceNode(anchor, entry.currentNode, newNode);
|
|
89
|
+
entry.currentNode = newNode;
|
|
90
|
+
}
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
const text2 = String(value);
|
|
94
|
+
if (entry.currentNode && entry.currentNode.nodeType === Node.TEXT_NODE) {
|
|
95
|
+
entry.currentNode.nodeValue = text2;
|
|
96
|
+
} else {
|
|
97
|
+
const newNode = document.createTextNode(text2);
|
|
98
|
+
replaceNode(anchor, entry.currentNode, newNode);
|
|
99
|
+
entry.currentNode = newNode;
|
|
100
|
+
}
|
|
101
|
+
return;
|
|
102
|
+
}
|
|
103
|
+
if (isDOMNode(item)) {
|
|
104
|
+
const newNode = item;
|
|
105
|
+
if (entry.currentNode !== newNode) {
|
|
106
|
+
replaceNode(anchor, entry.currentNode, newNode);
|
|
107
|
+
entry.currentNode = newNode;
|
|
108
|
+
}
|
|
109
|
+
return;
|
|
110
|
+
}
|
|
111
|
+
const text = String(item);
|
|
112
|
+
if (entry.currentNode && entry.currentNode.nodeType === Node.TEXT_NODE) {
|
|
113
|
+
entry.currentNode.nodeValue = text;
|
|
114
|
+
} else {
|
|
115
|
+
const newNode = document.createTextNode(text);
|
|
116
|
+
replaceNode(anchor, entry.currentNode, newNode);
|
|
117
|
+
entry.currentNode = newNode;
|
|
118
|
+
}
|
|
119
|
+
});
|
|
120
|
+
effectCleanups.set(key, effectHandle.dispose);
|
|
121
|
+
}
|
|
122
|
+
function removeKey(arrayState, effectCleanups, key) {
|
|
123
|
+
const cleanup = effectCleanups.get(key);
|
|
124
|
+
if (cleanup) {
|
|
125
|
+
cleanup();
|
|
126
|
+
effectCleanups.delete(key);
|
|
127
|
+
}
|
|
128
|
+
const entry = arrayState.reactiveEntries.get(key);
|
|
129
|
+
if (entry) {
|
|
130
|
+
if (entry.currentNode) {
|
|
131
|
+
entry.currentNode.parentNode?.removeChild(entry.currentNode);
|
|
132
|
+
}
|
|
133
|
+
if (entry.anchor && entry.anchor.parentNode) {
|
|
134
|
+
entry.anchor.parentNode.removeChild(entry.anchor);
|
|
135
|
+
}
|
|
136
|
+
arrayState.reactiveEntries.delete(key);
|
|
137
|
+
}
|
|
138
|
+
arrayState.keyMap.delete(key);
|
|
139
|
+
}
|
|
140
|
+
function reorderNodes(anchor, keyMap, newOrder) {
|
|
141
|
+
let previousNode = anchor;
|
|
142
|
+
newOrder.forEach((key) => {
|
|
143
|
+
const node = keyMap.get(key);
|
|
144
|
+
if (!node) return;
|
|
145
|
+
if (previousNode.nextSibling !== node) {
|
|
146
|
+
previousNode.parentNode?.insertBefore(node, previousNode.nextSibling);
|
|
147
|
+
}
|
|
148
|
+
previousNode = node;
|
|
149
|
+
});
|
|
150
|
+
}
|
|
151
|
+
export {
|
|
152
|
+
renderArrayChildGranular
|
|
153
|
+
};
|