@ecopages/core 0.2.0-alpha.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/CHANGELOG.md +89 -0
- package/LICENSE +21 -0
- package/README.md +32 -0
- package/package.json +279 -0
- package/src/adapters/abstract/application-adapter.d.ts +168 -0
- package/src/adapters/abstract/application-adapter.js +109 -0
- package/src/adapters/abstract/application-adapter.ts +337 -0
- package/src/adapters/abstract/router-adapter.d.ts +26 -0
- package/src/adapters/abstract/router-adapter.js +5 -0
- package/src/adapters/abstract/router-adapter.ts +30 -0
- package/src/adapters/abstract/server-adapter.d.ts +69 -0
- package/src/adapters/abstract/server-adapter.js +15 -0
- package/src/adapters/abstract/server-adapter.ts +79 -0
- package/src/adapters/bun/client-bridge.d.ts +34 -0
- package/src/adapters/bun/client-bridge.js +48 -0
- package/src/adapters/bun/client-bridge.ts +62 -0
- package/src/adapters/bun/create-app.d.ts +60 -0
- package/src/adapters/bun/create-app.js +117 -0
- package/src/adapters/bun/create-app.ts +189 -0
- package/src/adapters/bun/define-api-handler.d.ts +61 -0
- package/src/adapters/bun/define-api-handler.js +15 -0
- package/src/adapters/bun/define-api-handler.ts +114 -0
- package/src/adapters/bun/hmr-manager.d.ts +84 -0
- package/src/adapters/bun/hmr-manager.js +227 -0
- package/src/adapters/bun/hmr-manager.ts +281 -0
- package/src/adapters/bun/index.d.ts +3 -0
- package/src/adapters/bun/index.js +8 -0
- package/src/adapters/bun/index.ts +3 -0
- package/src/adapters/bun/server-adapter.d.ts +155 -0
- package/src/adapters/bun/server-adapter.js +368 -0
- package/src/adapters/bun/server-adapter.ts +492 -0
- package/src/adapters/bun/server-lifecycle.d.ts +52 -0
- package/src/adapters/bun/server-lifecycle.js +120 -0
- package/src/adapters/bun/server-lifecycle.ts +154 -0
- package/src/adapters/index.d.ts +6 -0
- package/src/adapters/index.js +14 -0
- package/src/adapters/index.ts +6 -0
- package/src/adapters/node/create-app.d.ts +21 -0
- package/src/adapters/node/create-app.js +143 -0
- package/src/adapters/node/create-app.ts +179 -0
- package/src/adapters/node/index.d.ts +4 -0
- package/src/adapters/node/index.js +8 -0
- package/src/adapters/node/index.ts +9 -0
- package/src/adapters/node/node-client-bridge.d.ts +26 -0
- package/src/adapters/node/node-client-bridge.js +66 -0
- package/src/adapters/node/node-client-bridge.ts +79 -0
- package/src/adapters/node/node-hmr-manager.d.ts +62 -0
- package/src/adapters/node/node-hmr-manager.js +221 -0
- package/src/adapters/node/node-hmr-manager.ts +271 -0
- package/src/adapters/node/server-adapter.d.ts +190 -0
- package/src/adapters/node/server-adapter.js +420 -0
- package/src/adapters/node/server-adapter.ts +561 -0
- package/src/adapters/node/static-content-server.d.ts +24 -0
- package/src/adapters/node/static-content-server.js +166 -0
- package/src/adapters/node/static-content-server.ts +203 -0
- package/src/adapters/shared/api-response.d.ts +52 -0
- package/src/adapters/shared/api-response.js +96 -0
- package/src/adapters/shared/api-response.ts +104 -0
- package/src/adapters/shared/application-adapter.d.ts +18 -0
- package/src/adapters/shared/application-adapter.js +90 -0
- package/src/adapters/shared/application-adapter.ts +199 -0
- package/src/adapters/shared/explicit-static-route-matcher.d.ts +38 -0
- package/src/adapters/shared/explicit-static-route-matcher.js +100 -0
- package/src/adapters/shared/explicit-static-route-matcher.ts +134 -0
- package/src/adapters/shared/file-route-middleware-pipeline.d.ts +65 -0
- package/src/adapters/shared/file-route-middleware-pipeline.js +98 -0
- package/src/adapters/shared/file-route-middleware-pipeline.ts +123 -0
- package/src/adapters/shared/fs-server-response-factory.d.ts +19 -0
- package/src/adapters/shared/fs-server-response-factory.js +97 -0
- package/src/adapters/shared/fs-server-response-factory.ts +118 -0
- package/src/adapters/shared/fs-server-response-matcher.d.ts +71 -0
- package/src/adapters/shared/fs-server-response-matcher.js +155 -0
- package/src/adapters/shared/fs-server-response-matcher.ts +198 -0
- package/src/adapters/shared/render-context.d.ts +14 -0
- package/src/adapters/shared/render-context.js +69 -0
- package/src/adapters/shared/render-context.ts +105 -0
- package/src/adapters/shared/server-adapter.d.ts +87 -0
- package/src/adapters/shared/server-adapter.js +353 -0
- package/src/adapters/shared/server-adapter.ts +442 -0
- package/src/adapters/shared/server-route-handler.d.ts +89 -0
- package/src/adapters/shared/server-route-handler.js +120 -0
- package/src/adapters/shared/server-route-handler.ts +166 -0
- package/src/adapters/shared/server-static-builder.d.ts +38 -0
- package/src/adapters/shared/server-static-builder.js +46 -0
- package/src/adapters/shared/server-static-builder.ts +82 -0
- package/src/build/build-adapter.d.ts +74 -0
- package/src/build/build-adapter.js +54 -0
- package/src/build/build-adapter.ts +132 -0
- package/src/build/build-types.d.ts +57 -0
- package/src/build/build-types.js +0 -0
- package/src/build/build-types.ts +83 -0
- package/src/build/esbuild-build-adapter.d.ts +69 -0
- package/src/build/esbuild-build-adapter.js +390 -0
- package/src/build/esbuild-build-adapter.ts +510 -0
- package/src/config/config-builder.d.ts +227 -0
- package/src/config/config-builder.js +392 -0
- package/src/config/config-builder.ts +474 -0
- package/src/constants.d.ts +32 -0
- package/src/constants.js +21 -0
- package/src/constants.ts +39 -0
- package/src/create-app.d.ts +17 -0
- package/src/create-app.js +66 -0
- package/src/create-app.ts +87 -0
- package/src/declarations.d.ts +26 -0
- package/src/define-api-handler.d.ts +25 -0
- package/src/define-api-handler.js +15 -0
- package/src/define-api-handler.ts +66 -0
- package/src/dev/sc-server.d.ts +30 -0
- package/src/dev/sc-server.js +111 -0
- package/src/dev/sc-server.ts +143 -0
- package/src/eco/README.md +636 -0
- package/src/eco/component-render-context.d.ts +105 -0
- package/src/eco/component-render-context.js +77 -0
- package/src/eco/component-render-context.ts +202 -0
- package/src/eco/eco.d.ts +9 -0
- package/src/eco/eco.js +110 -0
- package/src/eco/eco.ts +221 -0
- package/src/eco/eco.types.d.ts +170 -0
- package/src/eco/eco.types.js +0 -0
- package/src/eco/eco.types.ts +202 -0
- package/src/eco/eco.utils.d.ts +40 -0
- package/src/eco/eco.utils.js +40 -0
- package/src/eco/eco.utils.ts +89 -0
- package/src/eco/global-injector-map.d.ts +16 -0
- package/src/eco/global-injector-map.js +80 -0
- package/src/eco/global-injector-map.ts +112 -0
- package/src/eco/lazy-injector-map.d.ts +8 -0
- package/src/eco/lazy-injector-map.js +70 -0
- package/src/eco/lazy-injector-map.ts +120 -0
- package/src/eco/module-dependencies.d.ts +18 -0
- package/src/eco/module-dependencies.js +49 -0
- package/src/eco/module-dependencies.ts +75 -0
- package/src/env.d.ts +20 -0
- package/src/errors/http-error.d.ts +31 -0
- package/src/errors/http-error.js +50 -0
- package/src/errors/http-error.ts +72 -0
- package/src/errors/index.d.ts +2 -0
- package/src/errors/index.js +4 -0
- package/src/errors/index.ts +2 -0
- package/src/errors/locals-access-error.d.ts +4 -0
- package/src/errors/locals-access-error.js +9 -0
- package/src/errors/locals-access-error.ts +7 -0
- package/src/global/app-logger.d.ts +2 -0
- package/src/global/app-logger.js +6 -0
- package/src/global/app-logger.ts +4 -0
- package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-have-HMR-script-injected-in-page-1.png +0 -0
- package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-load-fixture-app-page-1.png +0 -0
- package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-WebSocket-Connection-should-connect-to-correct-HMR-endpoint-1.png +0 -0
- package/src/hmr/client/hmr-runtime.d.ts +10 -0
- package/src/hmr/client/hmr-runtime.js +86 -0
- package/src/hmr/client/hmr-runtime.ts +121 -0
- package/src/hmr/hmr-strategy.d.ts +159 -0
- package/src/hmr/hmr-strategy.js +29 -0
- package/src/hmr/hmr-strategy.ts +172 -0
- package/src/hmr/hmr.test.e2e.d.ts +1 -0
- package/src/hmr/hmr.test.e2e.js +50 -0
- package/src/hmr/hmr.test.e2e.ts +75 -0
- package/src/hmr/strategies/default-hmr-strategy.d.ts +43 -0
- package/src/hmr/strategies/default-hmr-strategy.js +34 -0
- package/src/hmr/strategies/default-hmr-strategy.ts +60 -0
- package/src/hmr/strategies/js-hmr-strategy.d.ts +136 -0
- package/src/hmr/strategies/js-hmr-strategy.js +179 -0
- package/src/hmr/strategies/js-hmr-strategy.ts +308 -0
- package/src/index.browser.d.ts +3 -0
- package/src/index.browser.js +4 -0
- package/src/index.browser.ts +3 -0
- package/src/index.d.ts +5 -0
- package/src/index.js +10 -0
- package/src/index.ts +5 -0
- package/src/integrations/ghtml/ghtml-renderer.d.ts +15 -0
- package/src/integrations/ghtml/ghtml-renderer.js +60 -0
- package/src/integrations/ghtml/ghtml-renderer.ts +93 -0
- package/src/integrations/ghtml/ghtml.plugin.d.ts +20 -0
- package/src/integrations/ghtml/ghtml.plugin.js +21 -0
- package/src/integrations/ghtml/ghtml.plugin.ts +32 -0
- package/src/internal-types.d.ts +200 -0
- package/src/internal-types.js +0 -0
- package/src/internal-types.ts +212 -0
- package/src/plugins/alias-resolver-plugin.d.ts +2 -0
- package/src/plugins/alias-resolver-plugin.js +39 -0
- package/src/plugins/alias-resolver-plugin.ts +45 -0
- package/src/plugins/eco-component-meta-plugin.d.ts +95 -0
- package/src/plugins/eco-component-meta-plugin.js +157 -0
- package/src/plugins/eco-component-meta-plugin.ts +474 -0
- package/src/plugins/integration-plugin.d.ts +102 -0
- package/src/plugins/integration-plugin.js +100 -0
- package/src/plugins/integration-plugin.ts +184 -0
- package/src/plugins/processor.d.ts +82 -0
- package/src/plugins/processor.js +122 -0
- package/src/plugins/processor.ts +220 -0
- package/src/public-types.d.ts +1094 -0
- package/src/public-types.js +0 -0
- package/src/public-types.ts +1255 -0
- package/src/route-renderer/GRAPH.md +387 -0
- package/src/route-renderer/README.md +135 -0
- package/src/route-renderer/component-graph-executor.d.ts +32 -0
- package/src/route-renderer/component-graph-executor.js +31 -0
- package/src/route-renderer/component-graph-executor.ts +84 -0
- package/src/route-renderer/component-graph.d.ts +42 -0
- package/src/route-renderer/component-graph.js +72 -0
- package/src/route-renderer/component-graph.ts +159 -0
- package/src/route-renderer/component-marker.d.ts +52 -0
- package/src/route-renderer/component-marker.js +46 -0
- package/src/route-renderer/component-marker.ts +117 -0
- package/src/route-renderer/dependency-resolver.d.ts +24 -0
- package/src/route-renderer/dependency-resolver.js +428 -0
- package/src/route-renderer/dependency-resolver.ts +596 -0
- package/src/route-renderer/html-post-processing.service.d.ts +40 -0
- package/src/route-renderer/html-post-processing.service.js +86 -0
- package/src/route-renderer/html-post-processing.service.ts +103 -0
- package/src/route-renderer/integration-renderer.d.ts +339 -0
- package/src/route-renderer/integration-renderer.js +526 -0
- package/src/route-renderer/integration-renderer.ts +696 -0
- package/src/route-renderer/marker-graph-resolver.d.ts +76 -0
- package/src/route-renderer/marker-graph-resolver.js +93 -0
- package/src/route-renderer/marker-graph-resolver.ts +153 -0
- package/src/route-renderer/page-module-loader.d.ts +61 -0
- package/src/route-renderer/page-module-loader.js +102 -0
- package/src/route-renderer/page-module-loader.ts +153 -0
- package/src/route-renderer/render-execution.service.d.ts +69 -0
- package/src/route-renderer/render-execution.service.js +91 -0
- package/src/route-renderer/render-execution.service.ts +158 -0
- package/src/route-renderer/render-preparation.service.d.ts +112 -0
- package/src/route-renderer/render-preparation.service.js +243 -0
- package/src/route-renderer/render-preparation.service.ts +358 -0
- package/src/route-renderer/route-renderer.d.ts +26 -0
- package/src/route-renderer/route-renderer.js +68 -0
- package/src/route-renderer/route-renderer.ts +80 -0
- package/src/router/fs-router-scanner.d.ts +41 -0
- package/src/router/fs-router-scanner.js +155 -0
- package/src/router/fs-router-scanner.ts +217 -0
- package/src/router/fs-router.d.ts +26 -0
- package/src/router/fs-router.js +100 -0
- package/src/router/fs-router.ts +122 -0
- package/src/services/asset-processing-service/asset-processing.service.d.ts +41 -0
- package/src/services/asset-processing-service/asset-processing.service.js +250 -0
- package/src/services/asset-processing-service/asset-processing.service.ts +306 -0
- package/src/services/asset-processing-service/asset.factory.d.ts +17 -0
- package/src/services/asset-processing-service/asset.factory.js +82 -0
- package/src/services/asset-processing-service/asset.factory.ts +105 -0
- package/src/services/asset-processing-service/assets.types.d.ts +88 -0
- package/src/services/asset-processing-service/assets.types.js +0 -0
- package/src/services/asset-processing-service/assets.types.ts +112 -0
- package/src/services/asset-processing-service/index.d.ts +3 -0
- package/src/services/asset-processing-service/index.js +3 -0
- package/src/services/asset-processing-service/index.ts +3 -0
- package/src/services/asset-processing-service/processor.interface.d.ts +22 -0
- package/src/services/asset-processing-service/processor.interface.js +6 -0
- package/src/services/asset-processing-service/processor.interface.ts +27 -0
- package/src/services/asset-processing-service/processor.registry.d.ts +8 -0
- package/src/services/asset-processing-service/processor.registry.js +15 -0
- package/src/services/asset-processing-service/processor.registry.ts +18 -0
- package/src/services/asset-processing-service/processors/base/base-processor.d.ts +24 -0
- package/src/services/asset-processing-service/processors/base/base-processor.js +59 -0
- package/src/services/asset-processing-service/processors/base/base-processor.ts +76 -0
- package/src/services/asset-processing-service/processors/base/base-script-processor.d.ts +16 -0
- package/src/services/asset-processing-service/processors/base/base-script-processor.js +80 -0
- package/src/services/asset-processing-service/processors/base/base-script-processor.ts +105 -0
- package/src/services/asset-processing-service/processors/index.d.ts +5 -0
- package/src/services/asset-processing-service/processors/index.js +5 -0
- package/src/services/asset-processing-service/processors/index.ts +5 -0
- package/src/services/asset-processing-service/processors/script/content-script.processor.d.ts +5 -0
- package/src/services/asset-processing-service/processors/script/content-script.processor.js +57 -0
- package/src/services/asset-processing-service/processors/script/content-script.processor.ts +66 -0
- package/src/services/asset-processing-service/processors/script/file-script.processor.d.ts +8 -0
- package/src/services/asset-processing-service/processors/script/file-script.processor.js +76 -0
- package/src/services/asset-processing-service/processors/script/file-script.processor.ts +88 -0
- package/src/services/asset-processing-service/processors/script/node-module-script.processor.d.ts +7 -0
- package/src/services/asset-processing-service/processors/script/node-module-script.processor.js +74 -0
- package/src/services/asset-processing-service/processors/script/node-module-script.processor.ts +84 -0
- package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.d.ts +5 -0
- package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +25 -0
- package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +27 -0
- package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.d.ts +9 -0
- package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.js +63 -0
- package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +77 -0
- package/src/services/cache/cache.types.d.ts +107 -0
- package/src/services/cache/cache.types.js +0 -0
- package/src/services/cache/cache.types.ts +126 -0
- package/src/services/cache/index.d.ts +7 -0
- package/src/services/cache/index.js +7 -0
- package/src/services/cache/index.ts +18 -0
- package/src/services/cache/memory-cache-store.d.ts +42 -0
- package/src/services/cache/memory-cache-store.js +98 -0
- package/src/services/cache/memory-cache-store.ts +130 -0
- package/src/services/cache/page-cache-service.d.ts +70 -0
- package/src/services/cache/page-cache-service.js +152 -0
- package/src/services/cache/page-cache-service.ts +202 -0
- package/src/services/html-transformer.service.d.ts +50 -0
- package/src/services/html-transformer.service.js +163 -0
- package/src/services/html-transformer.service.ts +217 -0
- package/src/services/page-module-import.service.d.ts +37 -0
- package/src/services/page-module-import.service.js +88 -0
- package/src/services/page-module-import.service.ts +129 -0
- package/src/services/page-request-cache-coordinator.service.d.ts +75 -0
- package/src/services/page-request-cache-coordinator.service.js +107 -0
- package/src/services/page-request-cache-coordinator.service.ts +128 -0
- package/src/services/schema-validation-service.d.ts +122 -0
- package/src/services/schema-validation-service.js +101 -0
- package/src/services/schema-validation-service.ts +204 -0
- package/src/services/validation/standard-schema.types.d.ts +65 -0
- package/src/services/validation/standard-schema.types.js +0 -0
- package/src/services/validation/standard-schema.types.ts +68 -0
- package/src/static-site-generator/static-site-generator.d.ts +57 -0
- package/src/static-site-generator/static-site-generator.js +272 -0
- package/src/static-site-generator/static-site-generator.ts +359 -0
- package/src/utils/css.d.ts +1 -0
- package/src/utils/css.js +7 -0
- package/src/utils/css.ts +5 -0
- package/src/utils/deep-merge.d.ts +14 -0
- package/src/utils/deep-merge.js +32 -0
- package/src/utils/deep-merge.ts +47 -0
- package/src/utils/hash.d.ts +1 -0
- package/src/utils/hash.js +7 -0
- package/src/utils/hash.ts +5 -0
- package/src/utils/html.d.ts +1 -0
- package/src/utils/html.js +4 -0
- package/src/utils/html.ts +1 -0
- package/src/utils/invariant.d.ts +5 -0
- package/src/utils/invariant.js +11 -0
- package/src/utils/invariant.ts +15 -0
- package/src/utils/locals-utils.d.ts +15 -0
- package/src/utils/locals-utils.js +24 -0
- package/src/utils/locals-utils.ts +37 -0
- package/src/utils/parse-cli-args.d.ts +24 -0
- package/src/utils/parse-cli-args.js +47 -0
- package/src/utils/parse-cli-args.ts +83 -0
- package/src/utils/path-utils.module.d.ts +5 -0
- package/src/utils/path-utils.module.js +14 -0
- package/src/utils/path-utils.module.ts +14 -0
- package/src/utils/runtime.d.ts +11 -0
- package/src/utils/runtime.js +40 -0
- package/src/utils/runtime.ts +44 -0
- package/src/utils/server-utils.module.d.ts +19 -0
- package/src/utils/server-utils.module.js +56 -0
- package/src/utils/server-utils.module.ts +67 -0
- package/src/watchers/project-watcher.d.ts +120 -0
- package/src/watchers/project-watcher.js +238 -0
- package/src/watchers/project-watcher.test-helpers.d.ts +4 -0
- package/src/watchers/project-watcher.test-helpers.js +51 -0
- package/src/watchers/project-watcher.test-helpers.ts +40 -0
- package/src/watchers/project-watcher.ts +306 -0
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import type { ComponentMarker, MarkerNodeId } from './component-marker.js';
|
|
2
|
+
/**
|
|
3
|
+
* Maps a parent slot reference to child marker node ids discovered in that slot.
|
|
4
|
+
*
|
|
5
|
+
* Keys are `slotRef` values emitted in marker payloads.
|
|
6
|
+
*/
|
|
7
|
+
export type SlotChildrenRegistry = Record<string, MarkerNodeId[]>;
|
|
8
|
+
/**
|
|
9
|
+
* Graph node enriched with source-order information for deterministic traversal.
|
|
10
|
+
*/
|
|
11
|
+
export type ComponentGraphNode = ComponentMarker & {
|
|
12
|
+
order: number;
|
|
13
|
+
};
|
|
14
|
+
/**
|
|
15
|
+
* Directed acyclic graph representation for component marker orchestration.
|
|
16
|
+
*
|
|
17
|
+
* `levels` are topological layers from roots to leaves.
|
|
18
|
+
*/
|
|
19
|
+
export type ComponentGraph = {
|
|
20
|
+
nodes: Map<MarkerNodeId, ComponentGraphNode>;
|
|
21
|
+
edges: Map<MarkerNodeId, Set<MarkerNodeId>>;
|
|
22
|
+
reverseEdges: Map<MarkerNodeId, Set<MarkerNodeId>>;
|
|
23
|
+
levels: MarkerNodeId[][];
|
|
24
|
+
};
|
|
25
|
+
/**
|
|
26
|
+
* Extracts marker graph metadata from rendered HTML and slot linkage data.
|
|
27
|
+
*
|
|
28
|
+
* This is the canonical graph builder used by marker execution.
|
|
29
|
+
*
|
|
30
|
+
* Algorithm summary:
|
|
31
|
+
* 1. Parse markers from HTML in source order.
|
|
32
|
+
* 2. Create nodes and derive edges from `slotChildrenRegistry`.
|
|
33
|
+
* 3. Compute deterministic topological levels.
|
|
34
|
+
*
|
|
35
|
+
* Unknown child node ids in `slotChildrenRegistry` are ignored to keep the
|
|
36
|
+
* extractor tolerant to stale references.
|
|
37
|
+
*
|
|
38
|
+
* @param html Rendered HTML containing `eco-marker` tokens.
|
|
39
|
+
* @param slotChildrenRegistry Optional slot -> child linkage map.
|
|
40
|
+
* @returns Component graph structure with levels ready for execution.
|
|
41
|
+
*/
|
|
42
|
+
export declare function extractComponentGraph(html: string, slotChildrenRegistry?: SlotChildrenRegistry): ComponentGraph;
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { parseComponentMarkers } from "./component-marker.js";
|
|
2
|
+
function ensureEdgeMaps(edges, reverseEdges, from, to) {
|
|
3
|
+
if (!edges.has(from)) {
|
|
4
|
+
edges.set(from, /* @__PURE__ */ new Set());
|
|
5
|
+
}
|
|
6
|
+
if (!reverseEdges.has(to)) {
|
|
7
|
+
reverseEdges.set(to, /* @__PURE__ */ new Set());
|
|
8
|
+
}
|
|
9
|
+
edges.get(from)?.add(to);
|
|
10
|
+
reverseEdges.get(to)?.add(from);
|
|
11
|
+
}
|
|
12
|
+
function computeLevels(nodes, edges, reverseEdges) {
|
|
13
|
+
const indegree = /* @__PURE__ */ new Map();
|
|
14
|
+
for (const nodeId of nodes.keys()) {
|
|
15
|
+
indegree.set(nodeId, reverseEdges.get(nodeId)?.size ?? 0);
|
|
16
|
+
}
|
|
17
|
+
const levels = [];
|
|
18
|
+
let frontier = [...nodes.values()].filter((node) => (indegree.get(node.nodeId) ?? 0) === 0).sort((a, b) => a.order - b.order).map((node) => node.nodeId);
|
|
19
|
+
const visited = /* @__PURE__ */ new Set();
|
|
20
|
+
while (frontier.length > 0) {
|
|
21
|
+
levels.push(frontier);
|
|
22
|
+
const next = [];
|
|
23
|
+
for (const current of frontier) {
|
|
24
|
+
visited.add(current);
|
|
25
|
+
for (const child of edges.get(current) ?? []) {
|
|
26
|
+
const nextInDegree = (indegree.get(child) ?? 0) - 1;
|
|
27
|
+
indegree.set(child, nextInDegree);
|
|
28
|
+
if (nextInDegree === 0) {
|
|
29
|
+
next.push(child);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
frontier = next.filter((nodeId, index) => next.indexOf(nodeId) === index).sort((a, b) => {
|
|
34
|
+
const orderA = nodes.get(a)?.order ?? 0;
|
|
35
|
+
const orderB = nodes.get(b)?.order ?? 0;
|
|
36
|
+
return orderA - orderB;
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
if (visited.size !== nodes.size) {
|
|
40
|
+
throw new Error("[ecopages] Component marker graph contains a cycle or unresolved dependency links.");
|
|
41
|
+
}
|
|
42
|
+
return levels;
|
|
43
|
+
}
|
|
44
|
+
function extractComponentGraph(html, slotChildrenRegistry = {}) {
|
|
45
|
+
const markers = parseComponentMarkers(html);
|
|
46
|
+
const nodes = /* @__PURE__ */ new Map();
|
|
47
|
+
const edges = /* @__PURE__ */ new Map();
|
|
48
|
+
const reverseEdges = /* @__PURE__ */ new Map();
|
|
49
|
+
markers.forEach((marker, index) => {
|
|
50
|
+
nodes.set(marker.nodeId, {
|
|
51
|
+
...marker,
|
|
52
|
+
order: index
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
for (const marker of markers) {
|
|
56
|
+
if (!marker.slotRef) {
|
|
57
|
+
continue;
|
|
58
|
+
}
|
|
59
|
+
const linkedChildren = slotChildrenRegistry[marker.slotRef] ?? [];
|
|
60
|
+
for (const childNodeId of linkedChildren) {
|
|
61
|
+
if (!nodes.has(childNodeId)) {
|
|
62
|
+
continue;
|
|
63
|
+
}
|
|
64
|
+
ensureEdgeMaps(edges, reverseEdges, marker.nodeId, childNodeId);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
const levels = computeLevels(nodes, edges, reverseEdges);
|
|
68
|
+
return { nodes, edges, reverseEdges, levels };
|
|
69
|
+
}
|
|
70
|
+
export {
|
|
71
|
+
extractComponentGraph
|
|
72
|
+
};
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
import type { ComponentMarker, MarkerNodeId } from './component-marker.ts';
|
|
2
|
+
import { parseComponentMarkers } from './component-marker.ts';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Maps a parent slot reference to child marker node ids discovered in that slot.
|
|
6
|
+
*
|
|
7
|
+
* Keys are `slotRef` values emitted in marker payloads.
|
|
8
|
+
*/
|
|
9
|
+
export type SlotChildrenRegistry = Record<string, MarkerNodeId[]>;
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* Graph node enriched with source-order information for deterministic traversal.
|
|
13
|
+
*/
|
|
14
|
+
export type ComponentGraphNode = ComponentMarker & {
|
|
15
|
+
order: number;
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* Directed acyclic graph representation for component marker orchestration.
|
|
20
|
+
*
|
|
21
|
+
* `levels` are topological layers from roots to leaves.
|
|
22
|
+
*/
|
|
23
|
+
export type ComponentGraph = {
|
|
24
|
+
nodes: Map<MarkerNodeId, ComponentGraphNode>;
|
|
25
|
+
edges: Map<MarkerNodeId, Set<MarkerNodeId>>;
|
|
26
|
+
reverseEdges: Map<MarkerNodeId, Set<MarkerNodeId>>;
|
|
27
|
+
levels: MarkerNodeId[][];
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* Ensures adjacency maps are initialized and registers one directed edge.
|
|
32
|
+
*
|
|
33
|
+
* @param edges Parent -> children adjacency map.
|
|
34
|
+
* @param reverseEdges Child -> parents adjacency map.
|
|
35
|
+
* @param from Parent node id.
|
|
36
|
+
* @param to Child node id.
|
|
37
|
+
*/
|
|
38
|
+
function ensureEdgeMaps(
|
|
39
|
+
edges: Map<MarkerNodeId, Set<MarkerNodeId>>,
|
|
40
|
+
reverseEdges: Map<MarkerNodeId, Set<MarkerNodeId>>,
|
|
41
|
+
from: MarkerNodeId,
|
|
42
|
+
to: MarkerNodeId,
|
|
43
|
+
): void {
|
|
44
|
+
if (!edges.has(from)) {
|
|
45
|
+
edges.set(from, new Set());
|
|
46
|
+
}
|
|
47
|
+
if (!reverseEdges.has(to)) {
|
|
48
|
+
reverseEdges.set(to, new Set());
|
|
49
|
+
}
|
|
50
|
+
edges.get(from)?.add(to);
|
|
51
|
+
reverseEdges.get(to)?.add(from);
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* Builds topological levels from graph adjacency maps.
|
|
56
|
+
*
|
|
57
|
+
* Levels are ordered from roots to leaves and each level preserves source order.
|
|
58
|
+
*
|
|
59
|
+
* @param nodes Graph node registry.
|
|
60
|
+
* @param edges Parent -> children adjacency map.
|
|
61
|
+
* @param reverseEdges Child -> parents adjacency map.
|
|
62
|
+
* @returns Topological levels from root level to leaf level.
|
|
63
|
+
* @throws Error when a cycle or unresolved dependency remains.
|
|
64
|
+
*/
|
|
65
|
+
function computeLevels(
|
|
66
|
+
nodes: Map<MarkerNodeId, ComponentGraphNode>,
|
|
67
|
+
edges: Map<MarkerNodeId, Set<MarkerNodeId>>,
|
|
68
|
+
reverseEdges: Map<MarkerNodeId, Set<MarkerNodeId>>,
|
|
69
|
+
): MarkerNodeId[][] {
|
|
70
|
+
const indegree = new Map<MarkerNodeId, number>();
|
|
71
|
+
for (const nodeId of nodes.keys()) {
|
|
72
|
+
indegree.set(nodeId, reverseEdges.get(nodeId)?.size ?? 0);
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
const levels: MarkerNodeId[][] = [];
|
|
76
|
+
let frontier = [...nodes.values()]
|
|
77
|
+
.filter((node) => (indegree.get(node.nodeId) ?? 0) === 0)
|
|
78
|
+
.sort((a, b) => a.order - b.order)
|
|
79
|
+
.map((node) => node.nodeId);
|
|
80
|
+
|
|
81
|
+
const visited = new Set<MarkerNodeId>();
|
|
82
|
+
|
|
83
|
+
while (frontier.length > 0) {
|
|
84
|
+
levels.push(frontier);
|
|
85
|
+
const next: MarkerNodeId[] = [];
|
|
86
|
+
|
|
87
|
+
for (const current of frontier) {
|
|
88
|
+
visited.add(current);
|
|
89
|
+
for (const child of edges.get(current) ?? []) {
|
|
90
|
+
const nextInDegree = (indegree.get(child) ?? 0) - 1;
|
|
91
|
+
indegree.set(child, nextInDegree);
|
|
92
|
+
if (nextInDegree === 0) {
|
|
93
|
+
next.push(child);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
frontier = next
|
|
99
|
+
.filter((nodeId, index) => next.indexOf(nodeId) === index)
|
|
100
|
+
.sort((a, b) => {
|
|
101
|
+
const orderA = nodes.get(a)?.order ?? 0;
|
|
102
|
+
const orderB = nodes.get(b)?.order ?? 0;
|
|
103
|
+
return orderA - orderB;
|
|
104
|
+
});
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
if (visited.size !== nodes.size) {
|
|
108
|
+
throw new Error('[ecopages] Component marker graph contains a cycle or unresolved dependency links.');
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
return levels;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
/**
|
|
115
|
+
* Extracts marker graph metadata from rendered HTML and slot linkage data.
|
|
116
|
+
*
|
|
117
|
+
* This is the canonical graph builder used by marker execution.
|
|
118
|
+
*
|
|
119
|
+
* Algorithm summary:
|
|
120
|
+
* 1. Parse markers from HTML in source order.
|
|
121
|
+
* 2. Create nodes and derive edges from `slotChildrenRegistry`.
|
|
122
|
+
* 3. Compute deterministic topological levels.
|
|
123
|
+
*
|
|
124
|
+
* Unknown child node ids in `slotChildrenRegistry` are ignored to keep the
|
|
125
|
+
* extractor tolerant to stale references.
|
|
126
|
+
*
|
|
127
|
+
* @param html Rendered HTML containing `eco-marker` tokens.
|
|
128
|
+
* @param slotChildrenRegistry Optional slot -> child linkage map.
|
|
129
|
+
* @returns Component graph structure with levels ready for execution.
|
|
130
|
+
*/
|
|
131
|
+
export function extractComponentGraph(html: string, slotChildrenRegistry: SlotChildrenRegistry = {}): ComponentGraph {
|
|
132
|
+
const markers = parseComponentMarkers(html);
|
|
133
|
+
const nodes = new Map<MarkerNodeId, ComponentGraphNode>();
|
|
134
|
+
const edges = new Map<MarkerNodeId, Set<MarkerNodeId>>();
|
|
135
|
+
const reverseEdges = new Map<MarkerNodeId, Set<MarkerNodeId>>();
|
|
136
|
+
|
|
137
|
+
markers.forEach((marker, index) => {
|
|
138
|
+
nodes.set(marker.nodeId, {
|
|
139
|
+
...marker,
|
|
140
|
+
order: index,
|
|
141
|
+
});
|
|
142
|
+
});
|
|
143
|
+
|
|
144
|
+
for (const marker of markers) {
|
|
145
|
+
if (!marker.slotRef) {
|
|
146
|
+
continue;
|
|
147
|
+
}
|
|
148
|
+
const linkedChildren = slotChildrenRegistry[marker.slotRef] ?? [];
|
|
149
|
+
for (const childNodeId of linkedChildren) {
|
|
150
|
+
if (!nodes.has(childNodeId)) {
|
|
151
|
+
continue;
|
|
152
|
+
}
|
|
153
|
+
ensureEdgeMaps(edges, reverseEdges, marker.nodeId, childNodeId);
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
const levels = computeLevels(nodes, edges, reverseEdges);
|
|
158
|
+
return { nodes, edges, reverseEdges, levels };
|
|
159
|
+
}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Stable marker node identifier used during one render graph resolution pass.
|
|
3
|
+
*
|
|
4
|
+
* @example
|
|
5
|
+
* `n_12`
|
|
6
|
+
*/
|
|
7
|
+
export type MarkerNodeId = `n_${string}`;
|
|
8
|
+
/**
|
|
9
|
+
* Marker payload used by graph extraction and execution.
|
|
10
|
+
*
|
|
11
|
+
* Each marker references:
|
|
12
|
+
* - the owning integration renderer (`integration`)
|
|
13
|
+
* - a component definition key (`componentRef`)
|
|
14
|
+
* - a serialized props key (`propsRef`)
|
|
15
|
+
* - optional child-slot linkage (`slotRef`)
|
|
16
|
+
*/
|
|
17
|
+
export type ComponentMarker = {
|
|
18
|
+
nodeId: MarkerNodeId;
|
|
19
|
+
integration: string;
|
|
20
|
+
componentRef: string;
|
|
21
|
+
propsRef: string;
|
|
22
|
+
slotRef?: string;
|
|
23
|
+
};
|
|
24
|
+
/**
|
|
25
|
+
* Input contract for marker emission.
|
|
26
|
+
*
|
|
27
|
+
* This shape is intentionally close to `ComponentMarker` to keep emission and
|
|
28
|
+
* parsing symmetric.
|
|
29
|
+
*/
|
|
30
|
+
export type MarkerRenderInput = {
|
|
31
|
+
nodeId: MarkerNodeId;
|
|
32
|
+
integration: string;
|
|
33
|
+
componentRef: string;
|
|
34
|
+
propsRef: string;
|
|
35
|
+
slotRef?: string;
|
|
36
|
+
};
|
|
37
|
+
/**
|
|
38
|
+
* Creates the canonical `<eco-marker>` token used for deferred component rendering.
|
|
39
|
+
*
|
|
40
|
+
* @param input Marker payload fields.
|
|
41
|
+
* @returns Serialized marker HTML token.
|
|
42
|
+
*/
|
|
43
|
+
export declare function createComponentMarker(input: MarkerRenderInput): string;
|
|
44
|
+
/**
|
|
45
|
+
* Parses all valid `<eco-marker>` tokens from HTML output.
|
|
46
|
+
*
|
|
47
|
+
* Invalid markers (missing required attributes) are ignored by design.
|
|
48
|
+
*
|
|
49
|
+
* @param html Rendered HTML fragment or document.
|
|
50
|
+
* @returns Parsed marker payloads in source order.
|
|
51
|
+
*/
|
|
52
|
+
export declare function parseComponentMarkers(html: string): ComponentMarker[];
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
function escapeAttribute(value) {
|
|
2
|
+
return value.replace(/&/g, "&").replace(/"/g, """).replace(/</g, "<").replace(/>/g, ">");
|
|
3
|
+
}
|
|
4
|
+
function readAttribute(tag, name) {
|
|
5
|
+
const match = tag.match(new RegExp(`${name}="([^"]*)"`));
|
|
6
|
+
return match?.[1];
|
|
7
|
+
}
|
|
8
|
+
function createComponentMarker(input) {
|
|
9
|
+
const attributes = [
|
|
10
|
+
`data-eco-node-id="${escapeAttribute(input.nodeId)}"`,
|
|
11
|
+
`data-eco-integration="${escapeAttribute(input.integration)}"`,
|
|
12
|
+
`data-eco-component-ref="${escapeAttribute(input.componentRef)}"`,
|
|
13
|
+
`data-eco-props-ref="${escapeAttribute(input.propsRef)}"`
|
|
14
|
+
];
|
|
15
|
+
if (input.slotRef) {
|
|
16
|
+
attributes.push(`data-eco-slot-ref="${escapeAttribute(input.slotRef)}"`);
|
|
17
|
+
}
|
|
18
|
+
return `<eco-marker ${attributes.join(" ")}></eco-marker>`;
|
|
19
|
+
}
|
|
20
|
+
function parseComponentMarkers(html) {
|
|
21
|
+
const markerRegex = /<eco-marker\b[^>]*><\/eco-marker>/g;
|
|
22
|
+
const results = [];
|
|
23
|
+
for (let match = markerRegex.exec(html); match; match = markerRegex.exec(html)) {
|
|
24
|
+
const tag = match[0];
|
|
25
|
+
const nodeId = readAttribute(tag, "data-eco-node-id");
|
|
26
|
+
const integration = readAttribute(tag, "data-eco-integration");
|
|
27
|
+
const componentRef = readAttribute(tag, "data-eco-component-ref");
|
|
28
|
+
const propsRef = readAttribute(tag, "data-eco-props-ref");
|
|
29
|
+
const slotRef = readAttribute(tag, "data-eco-slot-ref");
|
|
30
|
+
if (!nodeId || !integration || !componentRef || !propsRef) {
|
|
31
|
+
continue;
|
|
32
|
+
}
|
|
33
|
+
results.push({
|
|
34
|
+
nodeId,
|
|
35
|
+
integration,
|
|
36
|
+
componentRef,
|
|
37
|
+
propsRef,
|
|
38
|
+
slotRef
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
return results;
|
|
42
|
+
}
|
|
43
|
+
export {
|
|
44
|
+
createComponentMarker,
|
|
45
|
+
parseComponentMarkers
|
|
46
|
+
};
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Stable marker node identifier used during one render graph resolution pass.
|
|
3
|
+
*
|
|
4
|
+
* @example
|
|
5
|
+
* `n_12`
|
|
6
|
+
*/
|
|
7
|
+
export type MarkerNodeId = `n_${string}`;
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Marker payload used by graph extraction and execution.
|
|
11
|
+
*
|
|
12
|
+
* Each marker references:
|
|
13
|
+
* - the owning integration renderer (`integration`)
|
|
14
|
+
* - a component definition key (`componentRef`)
|
|
15
|
+
* - a serialized props key (`propsRef`)
|
|
16
|
+
* - optional child-slot linkage (`slotRef`)
|
|
17
|
+
*/
|
|
18
|
+
export type ComponentMarker = {
|
|
19
|
+
nodeId: MarkerNodeId;
|
|
20
|
+
integration: string;
|
|
21
|
+
componentRef: string;
|
|
22
|
+
propsRef: string;
|
|
23
|
+
slotRef?: string;
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* Input contract for marker emission.
|
|
28
|
+
*
|
|
29
|
+
* This shape is intentionally close to `ComponentMarker` to keep emission and
|
|
30
|
+
* parsing symmetric.
|
|
31
|
+
*/
|
|
32
|
+
export type MarkerRenderInput = {
|
|
33
|
+
nodeId: MarkerNodeId;
|
|
34
|
+
integration: string;
|
|
35
|
+
componentRef: string;
|
|
36
|
+
propsRef: string;
|
|
37
|
+
slotRef?: string;
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* Escapes marker attribute values for safe HTML output.
|
|
42
|
+
*
|
|
43
|
+
* @param value Raw attribute value.
|
|
44
|
+
* @returns HTML-escaped attribute value.
|
|
45
|
+
*/
|
|
46
|
+
function escapeAttribute(value: string): string {
|
|
47
|
+
return value.replace(/&/g, '&').replace(/"/g, '"').replace(/</g, '<').replace(/>/g, '>');
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* Reads a single attribute value from a raw marker tag.
|
|
52
|
+
*
|
|
53
|
+
* @param tag Full marker tag text.
|
|
54
|
+
* @param name Attribute name to read.
|
|
55
|
+
* @returns Attribute value when present; otherwise `undefined`.
|
|
56
|
+
*/
|
|
57
|
+
function readAttribute(tag: string, name: string): string | undefined {
|
|
58
|
+
const match = tag.match(new RegExp(`${name}="([^"]*)"`));
|
|
59
|
+
return match?.[1];
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
/**
|
|
63
|
+
* Creates the canonical `<eco-marker>` token used for deferred component rendering.
|
|
64
|
+
*
|
|
65
|
+
* @param input Marker payload fields.
|
|
66
|
+
* @returns Serialized marker HTML token.
|
|
67
|
+
*/
|
|
68
|
+
export function createComponentMarker(input: MarkerRenderInput): string {
|
|
69
|
+
const attributes = [
|
|
70
|
+
`data-eco-node-id="${escapeAttribute(input.nodeId)}"`,
|
|
71
|
+
`data-eco-integration="${escapeAttribute(input.integration)}"`,
|
|
72
|
+
`data-eco-component-ref="${escapeAttribute(input.componentRef)}"`,
|
|
73
|
+
`data-eco-props-ref="${escapeAttribute(input.propsRef)}"`,
|
|
74
|
+
];
|
|
75
|
+
|
|
76
|
+
if (input.slotRef) {
|
|
77
|
+
attributes.push(`data-eco-slot-ref="${escapeAttribute(input.slotRef)}"`);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
return `<eco-marker ${attributes.join(' ')}></eco-marker>`;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
/**
|
|
84
|
+
* Parses all valid `<eco-marker>` tokens from HTML output.
|
|
85
|
+
*
|
|
86
|
+
* Invalid markers (missing required attributes) are ignored by design.
|
|
87
|
+
*
|
|
88
|
+
* @param html Rendered HTML fragment or document.
|
|
89
|
+
* @returns Parsed marker payloads in source order.
|
|
90
|
+
*/
|
|
91
|
+
export function parseComponentMarkers(html: string): ComponentMarker[] {
|
|
92
|
+
const markerRegex = /<eco-marker\b[^>]*><\/eco-marker>/g;
|
|
93
|
+
const results: ComponentMarker[] = [];
|
|
94
|
+
|
|
95
|
+
for (let match = markerRegex.exec(html); match; match = markerRegex.exec(html)) {
|
|
96
|
+
const tag = match[0];
|
|
97
|
+
const nodeId = readAttribute(tag, 'data-eco-node-id');
|
|
98
|
+
const integration = readAttribute(tag, 'data-eco-integration');
|
|
99
|
+
const componentRef = readAttribute(tag, 'data-eco-component-ref');
|
|
100
|
+
const propsRef = readAttribute(tag, 'data-eco-props-ref');
|
|
101
|
+
const slotRef = readAttribute(tag, 'data-eco-slot-ref');
|
|
102
|
+
|
|
103
|
+
if (!nodeId || !integration || !componentRef || !propsRef) {
|
|
104
|
+
continue;
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
results.push({
|
|
108
|
+
nodeId: nodeId as MarkerNodeId,
|
|
109
|
+
integration,
|
|
110
|
+
componentRef,
|
|
111
|
+
propsRef,
|
|
112
|
+
slotRef,
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
return results;
|
|
117
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { EcoComponent } from '../public-types.js';
|
|
2
|
+
import type { EcoPagesAppConfig } from '../internal-types.js';
|
|
3
|
+
import type { AssetProcessingService, ProcessedAsset } from '../services/asset-processing-service/index.js';
|
|
4
|
+
export declare const DEPENDENCY_ERRORS: {
|
|
5
|
+
readonly INVALID_STYLESHEET_ENTRY: "Invalid stylesheet dependency entry: expected src or content";
|
|
6
|
+
readonly INVALID_SCRIPT_ENTRY: "Invalid script dependency entry: expected src or content";
|
|
7
|
+
readonly LAZY_SCRIPT_MISSING_SRC: "Lazy script dependency entry in dependencies.scripts requires a src value";
|
|
8
|
+
};
|
|
9
|
+
export declare class DependencyResolverService {
|
|
10
|
+
private appConfig;
|
|
11
|
+
private assetProcessingService;
|
|
12
|
+
constructor(appConfig: EcoPagesAppConfig, assetProcessingService: AssetProcessingService);
|
|
13
|
+
resolveDependencyPath(componentDir: string, pathUrl: string): string;
|
|
14
|
+
/**
|
|
15
|
+
* Maps lazy script source entries to deterministic fallback public URLs
|
|
16
|
+
* used when bundling output URLs are unavailable.
|
|
17
|
+
*/
|
|
18
|
+
resolveLazyScripts(componentDir: string, scripts: string[]): string;
|
|
19
|
+
/**
|
|
20
|
+
* Collects and processes component dependencies (styles, scripts, modules, lazy scripts).
|
|
21
|
+
* Lazy dependencies are always resolved into global-injector trigger maps.
|
|
22
|
+
*/
|
|
23
|
+
processComponentDependencies(components: (EcoComponent | Partial<EcoComponent>)[], integrationName: string): Promise<ProcessedAsset[]>;
|
|
24
|
+
}
|