@useavalon/avalon 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.
Files changed (159) hide show
  1. package/README.md +54 -0
  2. package/mod.ts +301 -0
  3. package/package.json +85 -0
  4. package/src/build/README.md +310 -0
  5. package/src/build/integration-bundler-plugin.ts +116 -0
  6. package/src/build/integration-config.ts +168 -0
  7. package/src/build/integration-detection-plugin.ts +117 -0
  8. package/src/build/integration-resolver-plugin.ts +90 -0
  9. package/src/build/island-manifest.ts +269 -0
  10. package/src/build/island-types-generator.ts +476 -0
  11. package/src/build/mdx-island-transform.ts +464 -0
  12. package/src/build/mdx-plugin.ts +98 -0
  13. package/src/build/page-island-transform.ts +598 -0
  14. package/src/build/prop-extractors/index.ts +21 -0
  15. package/src/build/prop-extractors/lit.ts +140 -0
  16. package/src/build/prop-extractors/qwik.ts +16 -0
  17. package/src/build/prop-extractors/solid.ts +125 -0
  18. package/src/build/prop-extractors/svelte.ts +194 -0
  19. package/src/build/prop-extractors/vue.ts +111 -0
  20. package/src/build/sidecar-file-manager.ts +104 -0
  21. package/src/build/sidecar-renderer.ts +30 -0
  22. package/src/client/adapters/index.ts +13 -0
  23. package/src/client/adapters/lit-adapter.ts +654 -0
  24. package/src/client/adapters/preact-adapter.ts +331 -0
  25. package/src/client/adapters/qwik-adapter.ts +345 -0
  26. package/src/client/adapters/react-adapter.ts +353 -0
  27. package/src/client/adapters/solid-adapter.ts +451 -0
  28. package/src/client/adapters/svelte-adapter.ts +524 -0
  29. package/src/client/adapters/vue-adapter.ts +467 -0
  30. package/src/client/components.ts +35 -0
  31. package/src/client/css-hmr-handler.ts +344 -0
  32. package/src/client/framework-adapter.ts +462 -0
  33. package/src/client/hmr-coordinator.ts +396 -0
  34. package/src/client/hmr-error-overlay.js +533 -0
  35. package/src/client/main.js +816 -0
  36. package/src/client/tests/css-hmr-handler.test.ts +360 -0
  37. package/src/client/tests/framework-adapter.test.ts +519 -0
  38. package/src/client/tests/hmr-coordinator.test.ts +176 -0
  39. package/src/client/tests/hydration-option-parsing.test.ts +107 -0
  40. package/src/client/tests/lit-adapter.test.ts +427 -0
  41. package/src/client/tests/preact-adapter.test.ts +353 -0
  42. package/src/client/tests/qwik-adapter.test.ts +343 -0
  43. package/src/client/tests/react-adapter.test.ts +317 -0
  44. package/src/client/tests/solid-adapter.test.ts +396 -0
  45. package/src/client/tests/svelte-adapter.test.ts +387 -0
  46. package/src/client/tests/vue-adapter.test.ts +407 -0
  47. package/src/client/types/framework-runtime.d.ts +68 -0
  48. package/src/client/types/vite-hmr.d.ts +46 -0
  49. package/src/client/types/vite-virtual-modules.d.ts +60 -0
  50. package/src/components/Image.tsx +123 -0
  51. package/src/components/IslandErrorBoundary.tsx +145 -0
  52. package/src/components/LayoutDataErrorBoundary.tsx +141 -0
  53. package/src/components/LayoutErrorBoundary.tsx +127 -0
  54. package/src/components/PersistentIsland.tsx +52 -0
  55. package/src/components/StreamingErrorBoundary.tsx +233 -0
  56. package/src/components/StreamingLayout.tsx +538 -0
  57. package/src/components/tests/component-analyzer.test.ts +96 -0
  58. package/src/components/tests/component-detection.test.ts +347 -0
  59. package/src/components/tests/persistent-islands.test.ts +398 -0
  60. package/src/core/components/component-analyzer.ts +192 -0
  61. package/src/core/components/component-detection.ts +508 -0
  62. package/src/core/components/enhanced-framework-detector.ts +500 -0
  63. package/src/core/components/framework-registry.ts +563 -0
  64. package/src/core/components/tests/enhanced-framework-detector.test.ts +577 -0
  65. package/src/core/components/tests/framework-registry.test.ts +465 -0
  66. package/src/core/content/mdx-processor.ts +46 -0
  67. package/src/core/integrations/README.md +282 -0
  68. package/src/core/integrations/index.ts +19 -0
  69. package/src/core/integrations/loader.ts +125 -0
  70. package/src/core/integrations/registry.ts +195 -0
  71. package/src/core/islands/island-persistence.ts +325 -0
  72. package/src/core/islands/island-state-serializer.ts +258 -0
  73. package/src/core/islands/persistent-island-context.tsx +80 -0
  74. package/src/core/islands/use-persistent-state.ts +68 -0
  75. package/src/core/layout/enhanced-layout-resolver.ts +322 -0
  76. package/src/core/layout/layout-cache-manager.ts +485 -0
  77. package/src/core/layout/layout-composer.ts +357 -0
  78. package/src/core/layout/layout-data-loader.ts +516 -0
  79. package/src/core/layout/layout-discovery.ts +243 -0
  80. package/src/core/layout/layout-matcher.ts +299 -0
  81. package/src/core/layout/layout-types.ts +110 -0
  82. package/src/core/layout/tests/enhanced-layout-resolver.test.ts +477 -0
  83. package/src/core/layout/tests/layout-cache-optimization.test.ts +149 -0
  84. package/src/core/layout/tests/layout-composer.test.ts +486 -0
  85. package/src/core/layout/tests/layout-data-loader.test.ts +443 -0
  86. package/src/core/layout/tests/layout-discovery.test.ts +253 -0
  87. package/src/core/layout/tests/layout-matcher.test.ts +480 -0
  88. package/src/core/modules/framework-module-resolver.ts +273 -0
  89. package/src/core/modules/tests/framework-module-resolver.test.ts +263 -0
  90. package/src/core/modules/tests/module-resolution-integration.test.ts +117 -0
  91. package/src/islands/component-analysis.ts +213 -0
  92. package/src/islands/css-utils.ts +565 -0
  93. package/src/islands/discovery/index.ts +80 -0
  94. package/src/islands/discovery/registry.ts +340 -0
  95. package/src/islands/discovery/resolver.ts +477 -0
  96. package/src/islands/discovery/scanner.ts +386 -0
  97. package/src/islands/discovery/tests/island-discovery.test.ts +881 -0
  98. package/src/islands/discovery/types.ts +117 -0
  99. package/src/islands/discovery/validator.ts +544 -0
  100. package/src/islands/discovery/watcher.ts +368 -0
  101. package/src/islands/framework-detection.ts +428 -0
  102. package/src/islands/integration-loader.ts +490 -0
  103. package/src/islands/island.tsx +565 -0
  104. package/src/islands/render-cache.ts +550 -0
  105. package/src/islands/types.ts +80 -0
  106. package/src/islands/universal-css-collector.ts +157 -0
  107. package/src/islands/universal-head-collector.ts +137 -0
  108. package/src/layout-system.d.ts +592 -0
  109. package/src/layout-system.ts +218 -0
  110. package/src/middleware/__tests__/discovery.test.ts +107 -0
  111. package/src/middleware/discovery.ts +268 -0
  112. package/src/middleware/executor.ts +315 -0
  113. package/src/middleware/index.ts +76 -0
  114. package/src/middleware/types.ts +99 -0
  115. package/src/nitro/build-config.ts +576 -0
  116. package/src/nitro/config.ts +483 -0
  117. package/src/nitro/error-handler.ts +636 -0
  118. package/src/nitro/index.ts +173 -0
  119. package/src/nitro/island-manifest.ts +584 -0
  120. package/src/nitro/middleware-adapter.ts +260 -0
  121. package/src/nitro/renderer.ts +1458 -0
  122. package/src/nitro/route-discovery.ts +439 -0
  123. package/src/nitro/types.ts +321 -0
  124. package/src/render/collect-css.ts +198 -0
  125. package/src/render/error-pages.ts +79 -0
  126. package/src/render/isolated-ssr-renderer.ts +654 -0
  127. package/src/render/ssr.ts +1030 -0
  128. package/src/schemas/api.ts +30 -0
  129. package/src/schemas/core.ts +64 -0
  130. package/src/schemas/index.ts +212 -0
  131. package/src/schemas/layout.ts +279 -0
  132. package/src/schemas/routing/index.ts +38 -0
  133. package/src/schemas/routing.ts +376 -0
  134. package/src/types/as-island.ts +20 -0
  135. package/src/types/image.d.ts +106 -0
  136. package/src/types/index.d.ts +22 -0
  137. package/src/types/island-jsx.d.ts +33 -0
  138. package/src/types/island-prop.d.ts +20 -0
  139. package/src/types/layout.ts +285 -0
  140. package/src/types/mdx.d.ts +6 -0
  141. package/src/types/routing.ts +555 -0
  142. package/src/types/tests/layout-types.test.ts +197 -0
  143. package/src/types/types.ts +5 -0
  144. package/src/types/urlpattern.d.ts +49 -0
  145. package/src/types/vite-env.d.ts +11 -0
  146. package/src/utils/dev-logger.ts +299 -0
  147. package/src/utils/fs.ts +151 -0
  148. package/src/vite-plugin/auto-discover.ts +551 -0
  149. package/src/vite-plugin/config.ts +266 -0
  150. package/src/vite-plugin/errors.ts +127 -0
  151. package/src/vite-plugin/image-optimization.ts +151 -0
  152. package/src/vite-plugin/integration-activator.ts +126 -0
  153. package/src/vite-plugin/island-sidecar-plugin.ts +176 -0
  154. package/src/vite-plugin/module-discovery.ts +189 -0
  155. package/src/vite-plugin/nitro-integration.ts +1334 -0
  156. package/src/vite-plugin/plugin.ts +329 -0
  157. package/src/vite-plugin/tests/image-optimization.test.ts +54 -0
  158. package/src/vite-plugin/types.ts +327 -0
  159. package/src/vite-plugin/validation.ts +228 -0
@@ -0,0 +1,157 @@
1
+ /**
2
+ * Universal CSS Collector
3
+ *
4
+ * Collects and manages CSS from all framework integrations (Vue, Svelte, Solid, Preact)
5
+ * during SSR rendering. Provides a unified interface for CSS injection into the document head.
6
+ */
7
+
8
+ declare global {
9
+ var __universalSSRCSS: Map<string, UniversalCSSEntry> | undefined;
10
+ }
11
+
12
+ export interface UniversalCSSEntry {
13
+ css: string;
14
+ scopeId: string;
15
+ src: string;
16
+ framework: string;
17
+ timestamp: number;
18
+ }
19
+
20
+ // Initialize global CSS collector
21
+ if (typeof globalThis !== "undefined" && !globalThis.__universalSSRCSS) {
22
+ globalThis.__universalSSRCSS = new Map();
23
+ }
24
+
25
+ /**
26
+ * Add CSS from any framework integration to the global collection
27
+ */
28
+ export function addUniversalCSS(
29
+ css: string,
30
+ src: string,
31
+ framework: string,
32
+ scopeId?: string,
33
+ ): void {
34
+ if (!css || !css.trim()) {
35
+ return;
36
+ }
37
+
38
+ if (!globalThis.__universalSSRCSS) {
39
+ globalThis.__universalSSRCSS = new Map();
40
+ }
41
+
42
+ // Generate a unique key for this CSS entry
43
+ const key = scopeId || `${framework}-${src}`;
44
+
45
+ const entry: UniversalCSSEntry = {
46
+ css: css.trim(),
47
+ scopeId: key,
48
+ src,
49
+ framework,
50
+ timestamp: Date.now(),
51
+ };
52
+
53
+ globalThis.__universalSSRCSS.set(key, entry);
54
+ }
55
+
56
+ /**
57
+ * Get all collected CSS from all frameworks
58
+ */
59
+ export function getUniversalCSS(clear = false): string {
60
+ if (!globalThis.__universalSSRCSS || globalThis.__universalSSRCSS.size === 0) {
61
+ return "";
62
+ }
63
+
64
+ const entries = Array.from(globalThis.__universalSSRCSS.values());
65
+
66
+ // Sort by timestamp to maintain render order
67
+ entries.sort((a, b) => a.timestamp - b.timestamp);
68
+
69
+ // Group by framework for better organization
70
+ const cssByFramework = entries.reduce((acc, entry) => {
71
+ if (!acc[entry.framework]) {
72
+ acc[entry.framework] = [];
73
+ }
74
+ acc[entry.framework].push(entry);
75
+ return acc;
76
+ }, {} as Record<string, UniversalCSSEntry[]>);
77
+
78
+ // Build CSS string with framework sections
79
+ const cssBlocks: string[] = [];
80
+
81
+ for (const [framework, frameworkEntries] of Object.entries(cssByFramework)) {
82
+ const frameworkCSS = frameworkEntries.map((entry) => {
83
+ const comment = `/* ${framework}: ${entry.src} (${entry.scopeId}) */`;
84
+ return `${comment}\n${entry.css}`;
85
+ }).join("\n\n");
86
+
87
+ cssBlocks.push(frameworkCSS);
88
+ }
89
+
90
+ const combinedCSS = cssBlocks.join("\n\n");
91
+
92
+ if (clear) {
93
+ globalThis.__universalSSRCSS.clear();
94
+ }
95
+
96
+ return combinedCSS;
97
+ }
98
+
99
+ /**
100
+ * Get CSS formatted for document head injection
101
+ */
102
+ export function getUniversalCSSForHead(clear = false): string {
103
+ const css = getUniversalCSS(clear);
104
+
105
+ if (!css.trim()) {
106
+ return "";
107
+ }
108
+
109
+ const timestamp = new Date().toISOString();
110
+ const styleTag =
111
+ `<style data-universal-ssr="true" data-generated="${timestamp}">\n${css}\n</style>`;
112
+
113
+ return styleTag;
114
+ }
115
+
116
+ /**
117
+ * Clear all collected CSS
118
+ */
119
+ export function clearUniversalCSS(): void {
120
+ if (globalThis.__universalSSRCSS) {
121
+ globalThis.__universalSSRCSS.clear();
122
+ }
123
+ }
124
+
125
+ /**
126
+ * Get CSS statistics
127
+ */
128
+ export function getUniversalCSSStats(): {
129
+ totalComponents: number;
130
+ byFramework: Record<string, number>;
131
+ totalCSSSize: number;
132
+ averageCSSSize: number;
133
+ } {
134
+ if (!globalThis.__universalSSRCSS || globalThis.__universalSSRCSS.size === 0) {
135
+ return {
136
+ totalComponents: 0,
137
+ byFramework: {},
138
+ totalCSSSize: 0,
139
+ averageCSSSize: 0,
140
+ };
141
+ }
142
+
143
+ const entries = Array.from(globalThis.__universalSSRCSS.values());
144
+ const byFramework = entries.reduce((acc, entry) => {
145
+ acc[entry.framework] = (acc[entry.framework] || 0) + 1;
146
+ return acc;
147
+ }, {} as Record<string, number>);
148
+
149
+ const totalCSSSize = entries.reduce((sum, entry) => sum + entry.css.length, 0);
150
+
151
+ return {
152
+ totalComponents: entries.length,
153
+ byFramework,
154
+ totalCSSSize,
155
+ averageCSSSize: entries.length > 0 ? Math.round(totalCSSSize / entries.length) : 0,
156
+ };
157
+ }
@@ -0,0 +1,137 @@
1
+ /**
2
+ * Universal Head Content Collector for SSR
3
+ *
4
+ * Collects head content (scripts, meta tags, etc.) from framework integrations
5
+ * during SSR and injects them into the HTML head.
6
+ *
7
+ * Similar to universal-css-collector.ts but for head content.
8
+ */
9
+
10
+ interface HeadEntry {
11
+ content: string;
12
+ src: string;
13
+ framework: string;
14
+ type: 'script' | 'meta' | 'link' | 'other';
15
+ }
16
+
17
+ declare global {
18
+ var __universalSSRHead: Map<string, HeadEntry>;
19
+ }
20
+
21
+ /**
22
+ * Initialize the global head collector if it doesn't exist
23
+ */
24
+ function initHeadCollector(): Map<string, HeadEntry> {
25
+ if (!globalThis.__universalSSRHead) {
26
+ globalThis.__universalSSRHead = new Map();
27
+ }
28
+ return globalThis.__universalSSRHead;
29
+ }
30
+
31
+ /**
32
+ * Add head content to the universal collector
33
+ *
34
+ * @param content - The head content (script, meta tag, etc.)
35
+ * @param src - Source component path
36
+ * @param framework - Framework name
37
+ * @param type - Type of head content
38
+ */
39
+ export function addUniversalHead(
40
+ content: string,
41
+ src: string,
42
+ framework: string,
43
+ type: 'script' | 'meta' | 'link' | 'other' = 'other'
44
+ ): void {
45
+ const collector = initHeadCollector();
46
+
47
+ // Generate a unique key for this head entry
48
+ const key = `${framework}-${src}-${type}`;
49
+
50
+ collector.set(key, {
51
+ content,
52
+ src,
53
+ framework,
54
+ type,
55
+ });
56
+ }
57
+
58
+ /**
59
+ * Get all collected head content formatted for injection into HTML head
60
+ *
61
+ * @param clear - Whether to clear the collector after getting content
62
+ * @returns Formatted head content string
63
+ */
64
+ export function getUniversalHeadForInjection(clear = false): string {
65
+ const collector = initHeadCollector();
66
+
67
+ if (collector.size === 0) {
68
+ return '';
69
+ }
70
+
71
+ const entries = Array.from(collector.values());
72
+
73
+ // Group by type for better organization
74
+ const scripts = entries.filter(e => e.type === 'script');
75
+ const metas = entries.filter(e => e.type === 'meta');
76
+ const links = entries.filter(e => e.type === 'link');
77
+ const others = entries.filter(e => e.type === 'other');
78
+
79
+ const parts: string[] = [];
80
+
81
+ // Add meta tags first
82
+ if (metas.length > 0) {
83
+ parts.push('<!-- Framework Meta Tags -->');
84
+ parts.push(...metas.map(e => e.content));
85
+ }
86
+
87
+ // Add links
88
+ if (links.length > 0) {
89
+ parts.push('<!-- Framework Links -->');
90
+ parts.push(...links.map(e => e.content));
91
+ }
92
+
93
+ // Add scripts
94
+ if (scripts.length > 0) {
95
+ parts.push('<!-- Framework Hydration Scripts -->');
96
+ // Wrap script content in <script> tags if not already wrapped
97
+ parts.push(...scripts.map(e => {
98
+ const content = e.content.trim();
99
+ // Check if already wrapped in script tags
100
+ if (content.startsWith('<script')) {
101
+ return content;
102
+ }
103
+ // Wrap in script tags
104
+ return `<script>${content}</script>`;
105
+ }));
106
+ }
107
+
108
+ // Add other content
109
+ if (others.length > 0) {
110
+ parts.push('<!-- Framework Head Content -->');
111
+ parts.push(...others.map(e => e.content));
112
+ }
113
+
114
+ const result = parts.join('\n ');
115
+
116
+ if (clear) {
117
+ collector.clear();
118
+ }
119
+
120
+ return result;
121
+ }
122
+
123
+ /**
124
+ * Clear all collected head content
125
+ */
126
+ export function clearUniversalHead(): void {
127
+ const collector = initHeadCollector();
128
+ collector.clear();
129
+ }
130
+
131
+ /**
132
+ * Get the current size of the head collector
133
+ */
134
+ export function getHeadCollectorSize(): number {
135
+ const collector = initHeadCollector();
136
+ return collector.size;
137
+ }