@absolutejs/absolute 0.19.0-beta.786 → 0.19.0-beta.789

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 (53) hide show
  1. package/dist/angular/index.js +5 -5
  2. package/dist/angular/server.js +5 -5
  3. package/dist/build.js +6 -6
  4. package/dist/{chunk-4bq79t8v.js → chunk-0867j0r0.js} +3 -3
  5. package/dist/{chunk-xpkjbmd3.js → chunk-2j2cvn7e.js} +4 -4
  6. package/dist/{chunk-vvz7dcvq.js → chunk-3qswe70c.js} +244 -6
  7. package/dist/chunk-3qswe70c.js.map +15 -0
  8. package/dist/{chunk-xrmjy8kk.js → chunk-5f67rsed.js} +16 -4
  9. package/dist/chunk-5f67rsed.js.map +10 -0
  10. package/dist/{chunk-gq0zxpm0.js → chunk-7mtstdqn.js} +2 -2
  11. package/dist/{chunk-4m75s5xf.js → chunk-8cyvzcmc.js} +2 -2
  12. package/dist/{chunk-g3j22qf6.js → chunk-9939da67.js} +7 -7
  13. package/dist/{chunk-dr9yqsdb.js → chunk-9ve9jq72.js} +2 -2
  14. package/dist/{chunk-kndkjsya.js → chunk-d7mwkzry.js} +2 -2
  15. package/dist/{chunk-nhzf4az4.js → chunk-e3r9fxaa.js} +2 -2
  16. package/dist/{chunk-hep68ja7.js → chunk-rmc1aqky.js} +51 -145
  17. package/dist/{chunk-hep68ja7.js.map → chunk-rmc1aqky.js.map} +4 -5
  18. package/dist/{chunk-yfqhr31t.js → chunk-tjr0kcev.js} +6 -4
  19. package/dist/{chunk-yfqhr31t.js.map → chunk-tjr0kcev.js.map} +1 -1
  20. package/dist/{chunk-smgj0epn.js → chunk-txhm2vb5.js} +3 -3
  21. package/dist/{chunk-qk8kd3hr.js → chunk-v5vmsxmy.js} +3 -3
  22. package/dist/{chunk-qk8kd3hr.js.map → chunk-v5vmsxmy.js.map} +1 -1
  23. package/dist/{chunk-xzvy9hr4.js → chunk-x09cskqd.js} +2 -2
  24. package/dist/{chunk-6fkgm9s5.js → chunk-xnt8c6h2.js} +10 -3
  25. package/dist/{chunk-6fkgm9s5.js.map → chunk-xnt8c6h2.js.map} +3 -3
  26. package/dist/{chunk-9a307ca6.js → chunk-ynb0qx79.js} +2 -2
  27. package/dist/{chunk-3c7mpj3m.js → chunk-zrg9d4zw.js} +2 -2
  28. package/dist/index.js +62 -14
  29. package/dist/index.js.map +4 -3
  30. package/dist/islands/index.js +3 -3
  31. package/dist/react/index.js +5 -5
  32. package/dist/react/server.js +2 -2
  33. package/dist/src/build/stylePreprocessor.d.ts +1 -0
  34. package/dist/src/core/index.d.ts +2 -0
  35. package/dist/svelte/index.js +5 -5
  36. package/dist/svelte/server.js +4 -4
  37. package/dist/vue/index.js +5 -5
  38. package/dist/vue/server.js +2 -2
  39. package/package.json +1 -1
  40. package/dist/chunk-vvz7dcvq.js.map +0 -13
  41. package/dist/chunk-xrmjy8kk.js.map +0 -10
  42. /package/dist/{chunk-4bq79t8v.js.map → chunk-0867j0r0.js.map} +0 -0
  43. /package/dist/{chunk-xpkjbmd3.js.map → chunk-2j2cvn7e.js.map} +0 -0
  44. /package/dist/{chunk-gq0zxpm0.js.map → chunk-7mtstdqn.js.map} +0 -0
  45. /package/dist/{chunk-4m75s5xf.js.map → chunk-8cyvzcmc.js.map} +0 -0
  46. /package/dist/{chunk-g3j22qf6.js.map → chunk-9939da67.js.map} +0 -0
  47. /package/dist/{chunk-dr9yqsdb.js.map → chunk-9ve9jq72.js.map} +0 -0
  48. /package/dist/{chunk-kndkjsya.js.map → chunk-d7mwkzry.js.map} +0 -0
  49. /package/dist/{chunk-nhzf4az4.js.map → chunk-e3r9fxaa.js.map} +0 -0
  50. /package/dist/{chunk-smgj0epn.js.map → chunk-txhm2vb5.js.map} +0 -0
  51. /package/dist/{chunk-xzvy9hr4.js.map → chunk-x09cskqd.js.map} +0 -0
  52. /package/dist/{chunk-9a307ca6.js.map → chunk-ynb0qx79.js.map} +0 -0
  53. /package/dist/{chunk-3c7mpj3m.js.map → chunk-zrg9d4zw.js.map} +0 -0
@@ -6,10 +6,10 @@ import {
6
6
  } from "../chunk-5fhp1jap.js";
7
7
  import {
8
8
  handleAngularPageRequest
9
- } from "../chunk-xpkjbmd3.js";
9
+ } from "../chunk-2j2cvn7e.js";
10
10
  import"../chunk-gd6wmknh.js";
11
11
  import"../chunk-mtgf69xn.js";
12
- import"../chunk-qk8kd3hr.js";
12
+ import"../chunk-v5vmsxmy.js";
13
13
  import"../chunk-c1jfjnka.js";
14
14
  import"../chunk-d9c0am65.js";
15
15
  import"../chunk-cbkrwmvh.js";
@@ -45,11 +45,11 @@ import {
45
45
  } from "../chunk-25v9t56f.js";
46
46
  import {
47
47
  renderIslandMarkup
48
- } from "../chunk-4m75s5xf.js";
49
- import"../chunk-dr9yqsdb.js";
48
+ } from "../chunk-8cyvzcmc.js";
49
+ import"../chunk-9ve9jq72.js";
50
50
  import"../chunk-7fw6x3js.js";
51
51
  import"../chunk-mbazhahf.js";
52
- import"../chunk-6fkgm9s5.js";
52
+ import"../chunk-xnt8c6h2.js";
53
53
  import"../chunk-qh75agse.js";
54
54
  import"../chunk-2f21eenc.js";
55
55
  import"../chunk-fygx2ymm.js";
@@ -1,10 +1,10 @@
1
1
  // @bun
2
2
  import {
3
3
  handleAngularPageRequest
4
- } from "../chunk-xpkjbmd3.js";
4
+ } from "../chunk-2j2cvn7e.js";
5
5
  import"../chunk-gd6wmknh.js";
6
6
  import"../chunk-mtgf69xn.js";
7
- import"../chunk-qk8kd3hr.js";
7
+ import"../chunk-v5vmsxmy.js";
8
8
  import"../chunk-c1jfjnka.js";
9
9
  import"../chunk-d9c0am65.js";
10
10
  import"../chunk-cbkrwmvh.js";
@@ -34,11 +34,11 @@ import {
34
34
  RESPONSE_INIT,
35
35
  buildAbsoluteHttpTransferCacheOptions
36
36
  } from "../chunk-25v9t56f.js";
37
- import"../chunk-4m75s5xf.js";
38
- import"../chunk-dr9yqsdb.js";
37
+ import"../chunk-8cyvzcmc.js";
38
+ import"../chunk-9ve9jq72.js";
39
39
  import"../chunk-7fw6x3js.js";
40
40
  import"../chunk-mbazhahf.js";
41
- import"../chunk-6fkgm9s5.js";
41
+ import"../chunk-xnt8c6h2.js";
42
42
  import"../chunk-qh75agse.js";
43
43
  import"../chunk-2f21eenc.js";
44
44
  import"../chunk-8kcfffry.js";
package/dist/build.js CHANGED
@@ -2,7 +2,7 @@
2
2
  import {
3
3
  build,
4
4
  devBuild
5
- } from "./chunk-hep68ja7.js";
5
+ } from "./chunk-rmc1aqky.js";
6
6
  import"./chunk-vkrpm7kc.js";
7
7
  import"./chunk-cg95827x.js";
8
8
  import"./chunk-hcsmxw1v.js";
@@ -20,8 +20,8 @@ import"./chunk-1e9vsfyh.js";
20
20
  import"./chunk-hyjs4bqs.js";
21
21
  import"./chunk-t81a331y.js";
22
22
  import"./chunk-85n68sy6.js";
23
- import"./chunk-vvz7dcvq.js";
24
- import"./chunk-kndkjsya.js";
23
+ import"./chunk-3qswe70c.js";
24
+ import"./chunk-d7mwkzry.js";
25
25
  import"./chunk-h5bbfn3n.js";
26
26
  import"./chunk-11zpfqz6.js";
27
27
  import"./chunk-a9mvyp04.js";
@@ -34,11 +34,11 @@ import"./chunk-gf0ygptk.js";
34
34
  import"./chunk-851whwc7.js";
35
35
  import"./chunk-s6defjk2.js";
36
36
  import"./chunk-p5504p14.js";
37
- import"./chunk-4m75s5xf.js";
38
- import"./chunk-dr9yqsdb.js";
37
+ import"./chunk-8cyvzcmc.js";
38
+ import"./chunk-9ve9jq72.js";
39
39
  import"./chunk-7fw6x3js.js";
40
40
  import"./chunk-mbazhahf.js";
41
- import"./chunk-6fkgm9s5.js";
41
+ import"./chunk-xnt8c6h2.js";
42
42
  import"./chunk-qh75agse.js";
43
43
  import"./chunk-2f21eenc.js";
44
44
  import"./chunk-8kcfffry.js";
@@ -12,13 +12,13 @@ import {
12
12
  injectIslandPageContextStream,
13
13
  renderConventionError,
14
14
  withRegisteredStreamingSlots
15
- } from "./chunk-qk8kd3hr.js";
15
+ } from "./chunk-v5vmsxmy.js";
16
16
  import {
17
17
  isSsrCacheDirty
18
18
  } from "./chunk-d9c0am65.js";
19
19
  import {
20
20
  compileSvelteServerModule
21
- } from "./chunk-dr9yqsdb.js";
21
+ } from "./chunk-9ve9jq72.js";
22
22
  import {
23
23
  __require
24
24
  } from "./chunk-bmgqm774.js";
@@ -133,4 +133,4 @@ var handleSveltePageRequest = async (input) => {
133
133
  export { handleSveltePageRequest };
134
134
 
135
135
  //# debugId=CE7F9382EA2F47FE64756E2164756E21
136
- //# sourceMappingURL=chunk-4bq79t8v.js.map
136
+ //# sourceMappingURL=chunk-0867j0r0.js.map
@@ -12,7 +12,7 @@ import {
12
12
  injectIslandPageContext,
13
13
  renderConventionError,
14
14
  withRegisteredStreamingSlots
15
- } from "./chunk-qk8kd3hr.js";
15
+ } from "./chunk-v5vmsxmy.js";
16
16
  import {
17
17
  isSsrCacheDirty
18
18
  } from "./chunk-d9c0am65.js";
@@ -39,7 +39,7 @@ import {
39
39
  } from "./chunk-pnscgw95.js";
40
40
  import {
41
41
  renderIslandMarkup
42
- } from "./chunk-4m75s5xf.js";
42
+ } from "./chunk-8cyvzcmc.js";
43
43
  import {
44
44
  BASE_36_RADIX,
45
45
  RANDOM_ID_END_INDEX
@@ -315,7 +315,7 @@ var resolveRuntimeAngularModulePath = async (pagePath) => {
315
315
  }
316
316
  const outDir = resolveAngularSsrOutDir();
317
317
  await ensureAngularSsrNodeModules(outDir);
318
- const { compileAngularFileJIT } = await import("./chunk-9a307ca6.js");
318
+ const { compileAngularFileJIT } = await import("./chunk-ynb0qx79.js");
319
319
  const outputs = await compileAngularFileJIT(pagePath, outDir, process.cwd());
320
320
  const expectedFileName = basename(pagePath).replace(/\.ts$/, ".js");
321
321
  return outputs.find((output) => output.endsWith(`/${expectedFileName}`)) ?? outputs.find((output) => output.endsWith(`\\${expectedFileName}`)) ?? outputs[0] ?? pagePath;
@@ -425,4 +425,4 @@ var handleAngularPageRequest = async (input) => {
425
425
  export { handleAngularPageRequest };
426
426
 
427
427
  //# debugId=87D8B92F7C4AD73964756E2164756E21
428
- //# sourceMappingURL=chunk-xpkjbmd3.js.map
428
+ //# sourceMappingURL=chunk-2j2cvn7e.js.map
@@ -1,16 +1,25 @@
1
1
  // @bun
2
2
  import {
3
3
  incrementalTailwindBuild
4
- } from "./chunk-kndkjsya.js";
4
+ } from "./chunk-d7mwkzry.js";
5
5
  import {
6
6
  scanEntryPoints
7
7
  } from "./chunk-11zpfqz6.js";
8
8
  import {
9
9
  extractIslandUsagesFromSource
10
10
  } from "./chunk-a9mvyp04.js";
11
+ import {
12
+ requireCurrentIslandRegistry
13
+ } from "./chunk-5003emhv.js";
14
+ import {
15
+ renderStreamingSlotPlaceholder
16
+ } from "./chunk-sd39p726.js";
11
17
  import {
12
18
  getDurationString
13
19
  } from "./chunk-gf0ygptk.js";
20
+ import {
21
+ renderIslandMarkup
22
+ } from "./chunk-8cyvzcmc.js";
14
23
  import {
15
24
  getIslandBuildReference
16
25
  } from "./chunk-8kcfffry.js";
@@ -353,8 +362,237 @@ var loadIslandRegistryBuildInfo = async (registryPath) => {
353
362
  };
354
363
  };
355
364
 
365
+ // src/core/staticStreaming.ts
366
+ var STATIC_SLOT_TAG_RE = /<abs-stream-slot\b([^>]*?)(?:\/>|>([\s\S]*?)<\/abs-stream-slot>)/gi;
367
+ var ATTRIBUTE_RE = /([A-Za-z_:][-A-Za-z0-9_:.]*)\s*=\s*(?:"([^"]*)"|'([^']*)')/g;
368
+ var parseAttributes = (attributeString) => {
369
+ const attributes = new Map;
370
+ const setAttributeFromMatch = (matchParts) => {
371
+ const [, key, doubleQuotedValue, singleQuotedValue] = matchParts;
372
+ if (!key) {
373
+ return;
374
+ }
375
+ attributes.set(key, doubleQuotedValue ?? singleQuotedValue ?? "");
376
+ };
377
+ let match = ATTRIBUTE_RE.exec(attributeString);
378
+ while (match) {
379
+ setAttributeFromMatch(match);
380
+ match = ATTRIBUTE_RE.exec(attributeString);
381
+ }
382
+ ATTRIBUTE_RE.lastIndex = 0;
383
+ return attributes;
384
+ };
385
+ var parseTimeout = (value) => {
386
+ if (!value)
387
+ return;
388
+ const parsed = Number(value);
389
+ if (!Number.isFinite(parsed) || parsed < 0) {
390
+ throw new Error(`Invalid <abs-stream-slot timeout-ms="${value}">. Expected a non-negative number.`);
391
+ }
392
+ return parsed;
393
+ };
394
+ var parseStaticStreamingTag = (attributeString, innerHtml) => {
395
+ const attributes = parseAttributes(attributeString);
396
+ const resolver = attributes.get("resolver");
397
+ if (!resolver) {
398
+ throw new Error('Static <abs-stream-slot> requires a "resolver" attribute.');
399
+ }
400
+ const id = attributes.get("id") ?? resolver;
401
+ return {
402
+ errorHtml: attributes.get("error-html") ?? undefined,
403
+ fallbackHtml: innerHtml?.trim() ?? attributes.get("fallback-html") ?? "",
404
+ id,
405
+ resolver,
406
+ timeoutMs: parseTimeout(attributes.get("timeout-ms") ?? undefined)
407
+ };
408
+ };
409
+ var extractStaticStreamingTags = (html) => {
410
+ const tagRe = new RegExp(STATIC_SLOT_TAG_RE);
411
+ const tags = [];
412
+ let match = tagRe.exec(html);
413
+ while (match) {
414
+ const [, rawAttributeString, innerHtml] = match;
415
+ tags.push(parseStaticStreamingTag(rawAttributeString ?? "", innerHtml));
416
+ match = tagRe.exec(html);
417
+ }
418
+ return tags;
419
+ };
420
+
421
+ // src/build/staticIslandPages.ts
422
+ import { readFileSync, writeFileSync as writeFileSync2 } from "fs";
423
+ var ISLAND_TAG_RE_SOURCE = "<(?:absolute-island|island)\\b([^>]*?)(?:\\/\\>|>(?:[\\s\\S]*?)<\\/(?:absolute-island|island)>)";
424
+ var ATTRIBUTE_RE_SOURCE = `([A-Za-z_:][-A-Za-z0-9_:.]*)\\s*=\\s*(?:"([^"]*)"|'([^']*)')`;
425
+ var islandFrameworks = [
426
+ "react",
427
+ "svelte",
428
+ "vue",
429
+ "angular"
430
+ ];
431
+ var islandHydrationModes = ["load", "idle", "visible", "none"];
432
+ var isRecord2 = (value) => typeof value === "object" && value !== null;
433
+ var isIslandFramework = (value) => islandFrameworks.some((framework) => framework === value);
434
+ var isIslandHydrationMode = (value) => islandHydrationModes.some((mode) => mode === value);
435
+ var parseHtmlAttributes = (attributeString) => {
436
+ const attributeRe = new RegExp(ATTRIBUTE_RE_SOURCE, "g");
437
+ const attributes = new Map;
438
+ let match = attributeRe.exec(attributeString);
439
+ while (match) {
440
+ const [, key, doubleQuotedValue, singleQuotedValue] = match;
441
+ match = attributeRe.exec(attributeString);
442
+ if (!key)
443
+ continue;
444
+ const value = doubleQuotedValue ?? singleQuotedValue ?? "";
445
+ attributes.set(key, value);
446
+ }
447
+ return attributes;
448
+ };
449
+ var parseIslandTag = (attributeString) => {
450
+ const attributes = parseHtmlAttributes(attributeString);
451
+ const framework = attributes.get("framework");
452
+ const component = attributes.get("component");
453
+ const hydrate = attributes.get("hydrate") ?? "load";
454
+ const propsSource = attributes.get("props") ?? "{}";
455
+ if (!framework || !component) {
456
+ return null;
457
+ }
458
+ if (!isIslandFramework(framework)) {
459
+ throw new Error(`Unsupported static island framework "${framework}".`);
460
+ }
461
+ if (!isIslandHydrationMode(hydrate)) {
462
+ throw new Error(`Unsupported static island hydrate mode "${hydrate}".`);
463
+ }
464
+ let parsedProps;
465
+ try {
466
+ const candidate = JSON.parse(propsSource);
467
+ parsedProps = isRecord2(candidate) ? candidate : {};
468
+ } catch (error) {
469
+ throw new Error(`Failed to parse static island props JSON for ${framework}:${component}: ${error instanceof Error ? error.message : String(error)}`, { cause: error });
470
+ }
471
+ return {
472
+ component,
473
+ framework,
474
+ hydrate,
475
+ props: parsedProps
476
+ };
477
+ };
478
+ var transformStaticPageHtml = async (originalHtml, registry) => {
479
+ const islandTagRe = new RegExp(ISLAND_TAG_RE_SOURCE, "gi");
480
+ if (!islandTagRe.test(originalHtml)) {
481
+ return originalHtml;
482
+ }
483
+ islandTagRe.lastIndex = 0;
484
+ const segments = [];
485
+ let lastIndex = 0;
486
+ let match = islandTagRe.exec(originalHtml);
487
+ while (match) {
488
+ const [fullMatch, rawAttributeString] = match;
489
+ const attributeString = rawAttributeString ?? "";
490
+ segments.push({
491
+ before: originalHtml.slice(lastIndex, match.index),
492
+ fullMatch,
493
+ props: parseIslandTag(attributeString)
494
+ });
495
+ lastIndex = match.index + fullMatch.length;
496
+ match = islandTagRe.exec(originalHtml);
497
+ }
498
+ const renderedSegments = await Promise.all(segments.map(async (segment) => segment.before + (segment.props ? await renderIslandMarkup(registry, segment.props) : segment.fullMatch)));
499
+ return renderedSegments.join("") + originalHtml.slice(lastIndex);
500
+ };
501
+ var HTMX_STREAM_SLOT_TAG_RE = /<abs-htmx-stream-slot\b([^>]*?)(?:\/>|>([\s\S]*?)<\/abs-htmx-stream-slot>)/gi;
502
+ var requireAttribute = (attributes, name) => {
503
+ const value = attributes.get(name)?.trim();
504
+ if (!value) {
505
+ throw new Error(`Static <abs-htmx-stream-slot> requires a "${name}" attribute.`);
506
+ }
507
+ return value;
508
+ };
509
+ var injectAttributesIntoSingleRootElement = (fallbackHtml, attributes) => {
510
+ const trimmed = fallbackHtml.trim();
511
+ if (!trimmed) {
512
+ throw new Error("Static <abs-htmx-stream-slot> requires fallback HTML inside the element body.");
513
+ }
514
+ const openingTagMatch = trimmed.match(/^<([A-Za-z][\w:-]*)([^>]*)>/);
515
+ if (!openingTagMatch) {
516
+ throw new Error("Static <abs-htmx-stream-slot> fallback must start with a single root HTML element.");
517
+ }
518
+ const attributeSource = [...attributes.entries()].map(([key, value]) => `${key}="${value}"`).join(" ");
519
+ if (!attributeSource) {
520
+ return trimmed;
521
+ }
522
+ const [openingTag, tagName, rawExistingAttributes = ""] = openingTagMatch;
523
+ const existingAttributes = rawExistingAttributes.trim();
524
+ const mergedAttributes = existingAttributes ? `${existingAttributes} ${attributeSource}` : attributeSource;
525
+ return trimmed.replace(openingTag, `<${tagName} ${mergedAttributes}>`);
526
+ };
527
+ var transformStaticHTMXStreamSlotHtml = (originalHtml) => {
528
+ let nextIndex = 0;
529
+ let result = "";
530
+ let match = HTMX_STREAM_SLOT_TAG_RE.exec(originalHtml);
531
+ while (match) {
532
+ const [fullMatch, rawAttributeString = "", innerHtml = ""] = match;
533
+ const attributes = parseHtmlAttributes(rawAttributeString);
534
+ const loweredAttributes = new Map([
535
+ ["hx-get", requireAttribute(attributes, "src")],
536
+ ["hx-trigger", attributes.get("trigger") ?? "load"],
537
+ ["hx-swap", attributes.get("swap") ?? "outerHTML"],
538
+ ["hx-target", attributes.get("target") ?? "this"]
539
+ ]);
540
+ result += originalHtml.slice(nextIndex, match.index);
541
+ result += injectAttributesIntoSingleRootElement(innerHtml, loweredAttributes);
542
+ nextIndex = match.index + fullMatch.length;
543
+ match = HTMX_STREAM_SLOT_TAG_RE.exec(originalHtml);
544
+ }
545
+ return result + originalHtml.slice(nextIndex);
546
+ };
547
+ var transformStaticStreamingSlotHtml = (originalHtml) => {
548
+ const slotDefinitions = extractStaticStreamingTags(originalHtml);
549
+ if (slotDefinitions.length === 0) {
550
+ return originalHtml;
551
+ }
552
+ const tagRe = /<abs-stream-slot\b([^>]*?)(?:\/>|>([\s\S]*?)<\/abs-stream-slot>)/gi;
553
+ let nextIndex = 0;
554
+ let slotIndex = 0;
555
+ let result = "";
556
+ let match = tagRe.exec(originalHtml);
557
+ while (match) {
558
+ const [fullMatch] = match;
559
+ const tag = slotDefinitions[slotIndex++];
560
+ if (!tag) {
561
+ throw new Error("Static streaming slot transform lost sync with parsed slot definitions.");
562
+ }
563
+ result += originalHtml.slice(nextIndex, match.index);
564
+ result += renderStreamingSlotPlaceholder(tag.id, tag.fallbackHtml);
565
+ nextIndex = match.index + fullMatch.length;
566
+ match = tagRe.exec(originalHtml);
567
+ }
568
+ return result + originalHtml.slice(nextIndex);
569
+ };
570
+ var transformStaticPage = async (pagePath, registry) => {
571
+ const originalHtml = readFileSync(pagePath, "utf-8");
572
+ const transformedHtml = await transformStaticPageHtml(originalHtml, registry);
573
+ if (transformedHtml !== originalHtml) {
574
+ writeFileSync2(pagePath, transformedHtml);
575
+ }
576
+ };
577
+ var transformCurrentStaticPageHtml = async (html, options = {}) => {
578
+ const transformedHTMXStreamingHtml = options.enableHTMXStreaming === false ? html : transformStaticHTMXStreamSlotHtml(html);
579
+ const transformedStreamingHtml = options.enableStaticStreaming === false ? transformedHTMXStreamingHtml : transformStaticStreamingSlotHtml(transformedHTMXStreamingHtml);
580
+ const islandTagRe = new RegExp(ISLAND_TAG_RE_SOURCE, "i");
581
+ if (!islandTagRe.test(transformedStreamingHtml)) {
582
+ return transformedStreamingHtml;
583
+ }
584
+ return transformStaticPageHtml(transformedStreamingHtml, requireCurrentIslandRegistry());
585
+ };
586
+ var transformStaticPagesWithIslands = async (registryPath, pagePaths) => {
587
+ if (!registryPath || pagePaths.length === 0) {
588
+ return;
589
+ }
590
+ const { registry } = await loadIslandRegistryBuildInfo(registryPath);
591
+ await Promise.all(pagePaths.map((pagePath) => transformStaticPage(pagePath, registry)));
592
+ };
593
+
356
594
  // src/islands/pageMetadata.ts
357
- import { readFileSync } from "fs";
595
+ import { readFileSync as readFileSync2 } from "fs";
358
596
  import { dirname as dirname3, resolve as resolve2 } from "path";
359
597
  var pagePatterns = {
360
598
  angular: "pages/**/*.{ts,js}",
@@ -410,7 +648,7 @@ var loadPageIslandFiles = async (entry, islandSourceLookup, pageMetadata) => {
410
648
  return;
411
649
  const files = await scanEntryPoints(resolve2(entry.dir), pattern);
412
650
  for (const filePath of files) {
413
- const source = readFileSync(filePath, "utf-8");
651
+ const source = readFileSync2(filePath, "utf-8");
414
652
  const islands = extractIslandUsagesFromSource(source);
415
653
  pageMetadata.set(resolve2(filePath), {
416
654
  islands: resolveIslandUsages(islands, islandSourceLookup),
@@ -428,7 +666,7 @@ var setCurrentPageIslandMetadata = (metadata) => {
428
666
  globalThis.__absolutePageIslandMetadata = metadata;
429
667
  };
430
668
 
431
- export { isTailwindCandidate, compileTailwind, compileTailwindConfig, collectIslandFrameworkSources, generateIslandEntryPoints, loadIslandRegistryBuildInfo, getPagesUsingIslandSource, loadPageIslandMetadata, setCurrentPageIslandMetadata, logStartupTimingBlock };
669
+ export { isTailwindCandidate, compileTailwind, compileTailwindConfig, collectIslandFrameworkSources, generateIslandEntryPoints, loadIslandRegistryBuildInfo, extractStaticStreamingTags, transformCurrentStaticPageHtml, transformStaticPagesWithIslands, getPagesUsingIslandSource, loadPageIslandMetadata, setCurrentPageIslandMetadata, logStartupTimingBlock };
432
670
 
433
- //# debugId=4479D65CB77F51F464756E2164756E21
434
- //# sourceMappingURL=chunk-vvz7dcvq.js.map
671
+ //# debugId=EA2793B90D7FF16C64756E2164756E21
672
+ //# sourceMappingURL=chunk-3qswe70c.js.map
@@ -0,0 +1,15 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/build/compileTailwind.ts", "../src/utils/startupTimings.ts", "../src/build/islandEntries.ts", "../src/core/staticStreaming.ts", "../src/build/staticIslandPages.ts", "../src/islands/pageMetadata.ts"],
4
+ "sourcesContent": [
5
+ "import { mkdir } from 'node:fs/promises';\nimport { dirname, join } from 'node:path';\nimport type {\n\tStylePreprocessorConfig,\n\tTailwindConfig\n} from '../../types/build';\nimport { incrementalTailwindBuild } from './tailwindCompiler';\n\n/* Files Tailwind v4 may scan for candidate utility classes via the `@source`\n directive. When any of these change in dev, the Tailwind output must be\n regenerated so newly referenced utilities show up in the CSS — otherwise\n classes appear in markup with no rules behind them. */\nconst TAILWIND_CANDIDATE_EXTENSION_PATTERN =\n\t/\\.(html?|m?[jt]sx?|cjs|vue|svelte|astro|mdx?|css|s[ac]ss|less|styl(?:us)?)$/i;\n\nexport const isTailwindCandidate = (filePath: string) =>\n\tTAILWIND_CANDIDATE_EXTENSION_PATTERN.test(filePath);\n\n/* Production / cold-start build of the Tailwind output CSS.\n\n Uses the same persistent-compiler path as HMR — calling\n `incrementalTailwindBuild` with no changed-file hint forces a fresh\n compile + full source scan. The compiler instance is then cached for\n the remainder of the process, so subsequent rebuilds (HMR ticks during\n `absolute dev`) get the per-candidate cache for free.\n\n This replaces the old `bun.build` + `bun-plugin-tailwind` pipeline:\n the bundler was being spun up just to drive Tailwind, which made every\n call pay bundler-init cost and discarded Tailwind's internal caches\n between calls. Going directly through `tailwindcss`'s own `compile()`\n API drops both costs and brings the production build into the same\n fast path as dev. */\nexport const compileTailwind = async (\n\tinput: string,\n\toutput: string,\n\tbuildPath: string,\n\tstyleTransformConfig?: StylePreprocessorConfig\n) => {\n\tconst outputPath = join(buildPath, output);\n\tawait mkdir(dirname(outputPath), { recursive: true });\n\tawait incrementalTailwindBuild(\n\t\t{ input, output },\n\t\tbuildPath,\n\t\t[],\n\t\tstyleTransformConfig\n\t);\n};\n\nexport const compileTailwindConfig = async (\n\ttailwind: TailwindConfig,\n\tbuildPath: string,\n\tstyleTransformConfig?: StylePreprocessorConfig\n) =>\n\tcompileTailwind(\n\t\ttailwind.input,\n\t\ttailwind.output,\n\t\tbuildPath,\n\t\tstyleTransformConfig\n\t);\n",
6
+ "import { getDurationString } from './getDurationString';\n\nexport type StartupTimingStep = {\n\tlabel: string;\n\tdurationMs: number;\n};\n\nexport const startupTimingsEnabled =\n\tprocess.env.ABSOLUTE_STARTUP_TIMINGS === '1' ||\n\tprocess.env.ABSOLUTE_STARTUP_TIMINGS === 'true';\n\nexport const formatStartupTimingBlock = (\n\ttitle: string,\n\tsteps: StartupTimingStep[]\n) => {\n\tconst totalDuration = steps.reduce((sum, step) => sum + step.durationMs, 0);\n\n\treturn [\n\t\ttitle,\n\t\t...steps.map(\n\t\t\t(step) => ` - ${step.label}: ${getDurationString(step.durationMs)}`\n\t\t),\n\t\t` Total: ${getDurationString(totalDuration)}`\n\t].join('\\n');\n};\n\nexport const logStartupTimingBlock = (\n\ttitle: string,\n\tsteps: StartupTimingStep[]\n) => {\n\tif (!startupTimingsEnabled || steps.length === 0) {\n\t\treturn;\n\t}\n\n\tconsole.log(formatStartupTimingBlock(title, steps));\n};\n",
7
+ "import { mkdirSync, rmSync, writeFileSync } from 'node:fs';\nimport { dirname, extname, join, relative, resolve } from 'node:path';\nimport ts from 'typescript';\nimport type { IslandFramework, IslandRegistryInput } from '../../types/island';\nimport { getIslandBuildReference } from '../core/islands';\n\ntype RegistryModuleExport = {\n\tdefault?: unknown;\n\tislandRegistry?: unknown;\n};\n\ntype IslandBuildEntry = {\n\tcomponent: string;\n\tentryPath: string;\n\tframework: IslandFramework;\n};\n\ntype IslandDefinition = {\n\tbuildReference: {\n\t\texport?: string;\n\t\tsource: string;\n\t} | null;\n\tcomponent: string;\n\tframework: IslandFramework;\n};\n\ntype IslandRegistryBuildInfo = {\n\tdefinitions: IslandDefinition[];\n\thasNamedExport: boolean;\n\tregistry: IslandRegistryInput;\n\tresolvedRegistryPath: string;\n};\n\ntype ParsedImportReference = {\n\texport?: string;\n\tsource: string;\n};\n\ntype ParsedRegistryBuildInfo = {\n\tdefinitions: IslandDefinition[];\n\thasNamedExport: boolean;\n\tregistry: IslandRegistryInput;\n};\n\ntype IslandEntryPathMaps = Partial<\n\tRecord<IslandFramework, Map<string, string>>\n>;\n\nconst frameworks: IslandFramework[] = ['react', 'svelte', 'vue', 'angular'];\n\nconst isRecord = (value: unknown): value is Record<string, unknown> =>\n\ttypeof value === 'object' && value !== null;\n\nconst resolveRegistryExport = (mod: RegistryModuleExport) => {\n\tif (isRecord(mod.islandRegistry)) return mod.islandRegistry;\n\tif (isRecord(mod.default)) return mod.default;\n\n\tthrow new Error(\n\t\t'Island registry module must export `islandRegistry` or a default registry object.'\n\t);\n};\n\nconst hasSvelteImport = (source: string) =>\n\t/from\\s+['\"][^'\"]+\\.svelte['\"]/.test(source);\n\nconst normalizeImportPath = (wrapperPath: string, targetPath: string) => {\n\tconst importPath = relative(dirname(wrapperPath), targetPath).replace(\n\t\t/\\\\/g,\n\t\t'/'\n\t);\n\n\treturn importPath.startsWith('.') ? importPath : `./${importPath}`;\n};\n\nconst isIdentifier = (value: string) =>\n\t/^[A-Za-z_$][A-Za-z0-9_$]*$/.test(value);\n\nconst resolveIslandSourcePath = (registryPath: string, sourcePath: string) => {\n\tif (sourcePath.startsWith('file://')) {\n\t\treturn new URL(sourcePath).pathname;\n\t}\n\n\treturn resolve(dirname(registryPath), sourcePath);\n};\n\nconst getObjectPropertyName = (name: ts.PropertyName) => {\n\tif (ts.isIdentifier(name) || ts.isStringLiteral(name)) {\n\t\treturn name.text;\n\t}\n\n\treturn null;\n};\n\nconst collectDefaultImport = (\n\timports: Map<string, ParsedImportReference>,\n\timportClause: ts.ImportClause,\n\tsource: string\n) => {\n\tif (!importClause.name) return;\n\n\timports.set(importClause.name.text, {\n\t\texport: 'default',\n\t\tsource\n\t});\n};\n\nconst collectNamedImports = (\n\timports: Map<string, ParsedImportReference>,\n\timportClause: ts.ImportClause,\n\tsource: string\n) => {\n\tconst bindings = importClause.namedBindings;\n\tif (!bindings || !ts.isNamedImports(bindings)) return;\n\n\tfor (const element of bindings.elements) {\n\t\timports.set(element.name.text, {\n\t\t\texport: element.propertyName?.text ?? element.name.text,\n\t\t\tsource\n\t\t});\n\t}\n};\n\nconst isIslandRegistryHelperImport = (source: string) =>\n\tsource === '@absolutejs/absolute/islands' ||\n\tsource.endsWith('/islands') ||\n\tsource.endsWith('/core/islands');\n\nconst collectRegistryHelperImports = (\n\timportClause: ts.ImportClause,\n\tsource: string,\n\tregistryFactoryNames: Set<string>,\n\tregistryNamespaceNames: Set<string>\n) => {\n\tif (!isIslandRegistryHelperImport(source)) return;\n\n\tconst bindings = importClause.namedBindings;\n\tif (!bindings) return;\n\n\tif (ts.isNamespaceImport(bindings)) {\n\t\tregistryNamespaceNames.add(bindings.name.text);\n\n\t\treturn;\n\t}\n\n\tfor (const element of bindings.elements) {\n\t\tconst importedName = element.propertyName?.text ?? element.name.text;\n\t\tif (importedName === 'defineIslandRegistry') {\n\t\t\tregistryFactoryNames.add(element.name.text);\n\t\t}\n\t}\n};\n\nconst createRegistryEntryValue = (reference: ParsedImportReference) => ({\n\tcomponent: reference.source,\n\texport: reference.export,\n\tsource: reference.source\n});\n\nconst addRegistryEntries = (\n\tframeworkNode: ts.ObjectLiteralExpression,\n\tframework: IslandFramework,\n\timports: Map<string, ParsedImportReference>,\n\tdefinitions: IslandDefinition[],\n\tregistry: IslandRegistryInput\n) => {\n\tconst frameworkRegistry = registry[framework] ?? {};\n\tregistry[framework] = frameworkRegistry;\n\n\tfor (const property of frameworkNode.properties) {\n\t\tif (\n\t\t\t!ts.isPropertyAssignment(property) &&\n\t\t\t!ts.isShorthandPropertyAssignment(property)\n\t\t)\n\t\t\tcontinue;\n\n\t\tconst componentName = getObjectPropertyName(property.name);\n\t\tif (!componentName) continue;\n\n\t\tconst initializer = ts.isPropertyAssignment(property)\n\t\t\t? property.initializer\n\t\t\t: property.name;\n\t\tif (!ts.isIdentifier(initializer)) continue;\n\n\t\tconst reference = imports.get(initializer.text);\n\t\tif (!reference) continue;\n\n\t\tframeworkRegistry[componentName] = createRegistryEntryValue(reference);\n\t\tdefinitions.push({\n\t\t\tbuildReference: reference,\n\t\t\tcomponent: componentName,\n\t\t\tframework\n\t\t});\n\t}\n};\n\nconst processDefineIslandRegistry = (\n\tnode: ts.CallExpression,\n\timports: Map<string, ParsedImportReference>,\n\tdefinitions: IslandDefinition[],\n\tregistry: IslandRegistryInput\n) => {\n\tconst [firstArg] = node.arguments;\n\tif (!firstArg || !ts.isObjectLiteralExpression(firstArg)) return;\n\n\tconst validFrameworks: IslandFramework[] = [\n\t\t'react',\n\t\t'svelte',\n\t\t'vue',\n\t\t'angular'\n\t];\n\tfor (const property of firstArg.properties) {\n\t\tif (!ts.isPropertyAssignment(property)) continue;\n\t\tconst frameworkName = getObjectPropertyName(property.name);\n\t\tif (!frameworkName) continue;\n\t\tconst framework = validFrameworks.find((f) => f === frameworkName);\n\t\tif (!framework) continue;\n\t\tif (!ts.isObjectLiteralExpression(property.initializer)) continue;\n\n\t\taddRegistryEntries(\n\t\t\tproperty.initializer,\n\t\t\tframework,\n\t\t\timports,\n\t\t\tdefinitions,\n\t\t\tregistry\n\t\t);\n\t}\n};\n\nconst walkRegistryNode = (\n\tnode: ts.Node,\n\timports: Map<string, ParsedImportReference>,\n\tregistryFactoryNames: Set<string>,\n\tregistryNamespaceNames: Set<string>,\n\tdefinitions: IslandDefinition[],\n\tregistry: IslandRegistryInput\n) => {\n\tif (\n\t\tts.isCallExpression(node) &&\n\t\tisDefineIslandRegistryCall(\n\t\t\tnode.expression,\n\t\t\tregistryFactoryNames,\n\t\t\tregistryNamespaceNames\n\t\t)\n\t) {\n\t\tprocessDefineIslandRegistry(node, imports, definitions, registry);\n\t}\n\n\tts.forEachChild(node, (child) =>\n\t\twalkRegistryNode(\n\t\t\tchild,\n\t\t\timports,\n\t\t\tregistryFactoryNames,\n\t\t\tregistryNamespaceNames,\n\t\t\tdefinitions,\n\t\t\tregistry\n\t\t)\n\t);\n};\n\nconst isDefineIslandRegistryCall = (\n\texpression: ts.Expression,\n\tregistryFactoryNames: Set<string>,\n\tregistryNamespaceNames: Set<string>\n) => {\n\tif (ts.isIdentifier(expression)) {\n\t\treturn registryFactoryNames.has(expression.text);\n\t}\n\n\treturn (\n\t\tts.isPropertyAccessExpression(expression) &&\n\t\texpression.name.text === 'defineIslandRegistry' &&\n\t\tts.isIdentifier(expression.expression) &&\n\t\tregistryNamespaceNames.has(expression.expression.text)\n\t);\n};\n\nconst hasIslandRegistryNamedExport = (sourceFile: ts.SourceFile) => {\n\tfor (const statement of sourceFile.statements) {\n\t\tif (\n\t\t\tts.isVariableStatement(statement) &&\n\t\t\tstatement.modifiers?.some(\n\t\t\t\t(modifier) => modifier.kind === ts.SyntaxKind.ExportKeyword\n\t\t\t) &&\n\t\t\tstatement.declarationList.declarations.some(\n\t\t\t\t(declaration) =>\n\t\t\t\t\tts.isIdentifier(declaration.name) &&\n\t\t\t\t\tdeclaration.name.text === 'islandRegistry'\n\t\t\t)\n\t\t) {\n\t\t\treturn true;\n\t\t}\n\n\t\tif (!ts.isExportDeclaration(statement) || !statement.exportClause)\n\t\t\tcontinue;\n\t\tif (!ts.isNamedExports(statement.exportClause)) continue;\n\n\t\tif (\n\t\t\tstatement.exportClause.elements.some(\n\t\t\t\t(element) => element.name.text === 'islandRegistry'\n\t\t\t)\n\t\t) {\n\t\t\treturn true;\n\t\t}\n\t}\n\n\treturn false;\n};\n\nconst collectImportDeclarations = (\n\tsourceFile: ts.SourceFile,\n\tregistryPath: string,\n\timports: Map<string, ParsedImportReference>,\n\tregistryFactoryNames: Set<string>,\n\tregistryNamespaceNames: Set<string>\n) => {\n\tfor (const statement of sourceFile.statements) {\n\t\tif (\n\t\t\t!ts.isImportDeclaration(statement) ||\n\t\t\t!ts.isStringLiteral(statement.moduleSpecifier)\n\t\t)\n\t\t\tcontinue;\n\n\t\tconst { importClause } = statement;\n\t\tif (!importClause) continue;\n\n\t\tconst source = resolveIslandSourcePath(\n\t\t\tregistryPath,\n\t\t\tstatement.moduleSpecifier.text\n\t\t);\n\n\t\tcollectDefaultImport(imports, importClause, source);\n\t\tcollectNamedImports(imports, importClause, source);\n\t\tcollectRegistryHelperImports(\n\t\t\timportClause,\n\t\t\tstatement.moduleSpecifier.text,\n\t\t\tregistryFactoryNames,\n\t\t\tregistryNamespaceNames\n\t\t);\n\t}\n};\n\nconst parseIslandRegistryBuildInfo = (\n\tregistrySource: string,\n\tregistryPath: string\n): ParsedRegistryBuildInfo => {\n\tconst sourceFile = ts.createSourceFile(\n\t\tregistryPath,\n\t\tregistrySource,\n\t\tts.ScriptTarget.Latest,\n\t\ttrue,\n\t\tts.ScriptKind.TS\n\t);\n\tconst imports = new Map<string, ParsedImportReference>();\n\tconst registryFactoryNames = new Set<string>(['defineIslandRegistry']);\n\tconst registryNamespaceNames = new Set<string>();\n\tconst definitions: IslandDefinition[] = [];\n\tconst registry: IslandRegistryInput = {};\n\n\tcollectImportDeclarations(\n\t\tsourceFile,\n\t\tregistryPath,\n\t\timports,\n\t\tregistryFactoryNames,\n\t\tregistryNamespaceNames\n\t);\n\twalkRegistryNode(\n\t\tsourceFile,\n\t\timports,\n\t\tregistryFactoryNames,\n\t\tregistryNamespaceNames,\n\t\tdefinitions,\n\t\tregistry\n\t);\n\n\treturn {\n\t\tdefinitions,\n\t\thasNamedExport: hasIslandRegistryNamedExport(sourceFile),\n\t\tregistry\n\t};\n};\n\nconst loadDynamicIslandRegistryBuildInfo = async (\n\tresolvedRegistryPath: string\n) => {\n\tconst registryModule: RegistryModuleExport = await import(\n\t\tresolvedRegistryPath\n\t);\n\tconst registry: IslandRegistryInput = resolveRegistryExport(registryModule);\n\tconst definitions = frameworks.flatMap((framework) => {\n\t\tconst frameworkRegistry = registry[framework];\n\t\tif (!isRecord(frameworkRegistry)) return [];\n\n\t\treturn Object.entries(frameworkRegistry).map(([component, value]) => ({\n\t\t\tbuildReference: getIslandBuildReference(value),\n\t\t\tcomponent,\n\t\t\tframework\n\t\t}));\n\t});\n\n\treturn {\n\t\tdefinitions,\n\t\thasNamedExport: isRecord(registryModule.islandRegistry),\n\t\tregistry\n\t};\n};\n\nconst createRegistryImportCode = (\n\twrapperPath: string,\n\tregistryPath: string,\n\thasNamedExport: boolean\n) => {\n\tconst normalizedPath = normalizeImportPath(wrapperPath, registryPath);\n\n\tif (hasNamedExport) {\n\t\treturn {\n\t\t\timportStatement: `import { islandRegistry as __absoluteIslandRegistry } from ${JSON.stringify(normalizedPath)};`,\n\t\t\tregistryReference: '__absoluteIslandRegistry'\n\t\t};\n\t}\n\n\treturn {\n\t\timportStatement: `import __absoluteIslandRegistry from ${JSON.stringify(normalizedPath)};`,\n\t\tregistryReference: '__absoluteIslandRegistry'\n\t};\n};\n\nconst createDirectEntrySource = (\n\twrapperPath: string,\n\timportPath: string,\n\texportName?: string\n) => {\n\tconst normalizedImportPath = normalizeImportPath(wrapperPath, importPath);\n\tif (!exportName || exportName === 'default') {\n\t\treturn `export { default } from ${JSON.stringify(normalizedImportPath)};\\n`;\n\t}\n\n\treturn `export { ${exportName} as default } from ${JSON.stringify(normalizedImportPath)};\\n`;\n};\n\nconst createRegistryEntrySource = (\n\twrapperPath: string,\n\tregistryPath: string,\n\thasNamedExport: boolean,\n\tframework: IslandFramework,\n\tcomponent: string\n) => {\n\tconst { importStatement, registryReference } = createRegistryImportCode(\n\t\twrapperPath,\n\t\tregistryPath,\n\t\thasNamedExport\n\t);\n\tconst frameworkAccess = isIdentifier(framework)\n\t\t? `${registryReference}.${framework}`\n\t\t: `${registryReference}[${JSON.stringify(framework)}]`;\n\tconst componentAccess = isIdentifier(component)\n\t\t? `${frameworkAccess}.${component}`\n\t\t: `${frameworkAccess}[${JSON.stringify(component)}]`;\n\n\treturn `${importStatement}\n\nconst component = ${componentAccess};\n\nexport default component;\n`;\n};\n\nconst shouldUseCompiledClientPath = (\n\tframework: IslandFramework,\n\tsourcePath: string\n) => {\n\tif (framework === 'svelte') {\n\t\treturn /\\.svelte(?:\\.(?:ts|js))?$/.test(sourcePath);\n\t}\n\n\tif (framework === 'vue') {\n\t\treturn extname(sourcePath) === '.vue';\n\t}\n\n\tif (framework === 'angular') {\n\t\treturn /\\.(?:ts|js|tsx|jsx|mjs|cjs)$/.test(sourcePath);\n\t}\n\n\treturn false;\n};\n\nexport const collectIslandFrameworkSources = (\n\tbuildInfo: IslandRegistryBuildInfo\n) => {\n\tconst sources: Partial<Record<IslandFramework, string[]>> = {};\n\n\tfor (const definition of buildInfo.definitions) {\n\t\tconst { buildReference } = definition;\n\t\tif (!buildReference) continue;\n\n\t\tconst resolvedSourcePath = resolveIslandSourcePath(\n\t\t\tbuildInfo.resolvedRegistryPath,\n\t\t\tbuildReference.source\n\t\t);\n\t\tif (\n\t\t\t!shouldUseCompiledClientPath(\n\t\t\t\tdefinition.framework,\n\t\t\t\tresolvedSourcePath\n\t\t\t)\n\t\t)\n\t\t\tcontinue;\n\n\t\tconst frameworkSources = sources[definition.framework] ?? [];\n\t\tif (frameworkSources.includes(resolvedSourcePath)) continue;\n\n\t\tframeworkSources.push(resolvedSourcePath);\n\t\tsources[definition.framework] = frameworkSources;\n\t}\n\n\treturn sources;\n};\nexport const generateIslandEntryPoints = async ({\n\tbuildInfo,\n\tbuildPath,\n\tclientPathMaps = {}\n}: {\n\tbuildInfo: IslandRegistryBuildInfo;\n\tbuildPath: string;\n\tclientPathMaps?: IslandEntryPathMaps;\n}) => {\n\tconst generatedRoot = join(buildPath, '_island_entries');\n\n\trmSync(generatedRoot, { force: true, recursive: true });\n\n\tconst entries: IslandBuildEntry[] = [];\n\n\tfor (const definition of buildInfo.definitions) {\n\t\tconst entryPath = join(\n\t\t\tgeneratedRoot,\n\t\t\t'islands',\n\t\t\tdefinition.framework,\n\t\t\t`${definition.component}.ts`\n\t\t);\n\t\tconst { buildReference } = definition;\n\t\tconst source = buildReference\n\t\t\t? resolveIslandSourcePath(\n\t\t\t\t\tbuildInfo.resolvedRegistryPath,\n\t\t\t\t\tbuildReference.source\n\t\t\t\t)\n\t\t\t: null;\n\t\tconst compiledSourcePath =\n\t\t\tsource && shouldUseCompiledClientPath(definition.framework, source)\n\t\t\t\t? clientPathMaps[definition.framework]?.get(source)\n\t\t\t\t: undefined;\n\t\tconst entrySource =\n\t\t\tsource &&\n\t\t\t(compiledSourcePath ||\n\t\t\t\t!shouldUseCompiledClientPath(definition.framework, source))\n\t\t\t\t? createDirectEntrySource(\n\t\t\t\t\t\tentryPath,\n\t\t\t\t\t\tcompiledSourcePath ?? source,\n\t\t\t\t\t\tcompiledSourcePath ? undefined : buildReference?.export\n\t\t\t\t\t)\n\t\t\t\t: createRegistryEntrySource(\n\t\t\t\t\t\tentryPath,\n\t\t\t\t\t\tbuildInfo.resolvedRegistryPath,\n\t\t\t\t\t\tbuildInfo.hasNamedExport,\n\t\t\t\t\t\tdefinition.framework,\n\t\t\t\t\t\tdefinition.component\n\t\t\t\t\t);\n\n\t\tmkdirSync(dirname(entryPath), { recursive: true });\n\t\twriteFileSync(entryPath, entrySource);\n\t\tentries.push({\n\t\t\tcomponent: definition.component,\n\t\t\tentryPath,\n\t\t\tframework: definition.framework\n\t\t});\n\t}\n\n\treturn {\n\t\tentries,\n\t\tgeneratedRoot\n\t};\n};\nexport const loadIslandRegistryBuildInfo = async (\n\tregistryPath: string\n): Promise<IslandRegistryBuildInfo> => {\n\tconst resolvedRegistryPath = resolve(registryPath);\n\tconst registrySource = Bun.file(resolvedRegistryPath);\n\tconst registrySourceText = await registrySource.text();\n\tconst parsedInfo = parseIslandRegistryBuildInfo(\n\t\tregistrySourceText,\n\t\tresolvedRegistryPath\n\t);\n\tif (parsedInfo.definitions.length > 0) {\n\t\treturn {\n\t\t\tdefinitions: parsedInfo.definitions,\n\t\t\thasNamedExport: parsedInfo.hasNamedExport,\n\t\t\tregistry: parsedInfo.registry,\n\t\t\tresolvedRegistryPath\n\t\t};\n\t}\n\tif (hasSvelteImport(registrySourceText)) {\n\t\tthrow new Error(\n\t\t\t'Unable to statically analyze the island registry. Registries that import .svelte files must use defineIslandRegistry({ ... }) with direct imported component references.'\n\t\t);\n\t}\n\n\tconst dynamicInfo =\n\t\tawait loadDynamicIslandRegistryBuildInfo(resolvedRegistryPath);\n\n\treturn {\n\t\tdefinitions: dynamicInfo.definitions,\n\t\thasNamedExport: dynamicInfo.hasNamedExport,\n\t\tregistry: dynamicInfo.registry,\n\t\tresolvedRegistryPath\n\t};\n};\n",
8
+ "import { statSync } from 'node:fs';\nimport { extname } from 'node:path';\nimport { pathToFileURL } from 'node:url';\nimport type {\n\tStreamingSlot,\n\tStreamingSlotPatchPayload\n} from '../utils/streamingSlots';\n\nexport type StaticStreamingSlotResolver = () =>\n\t| Promise<StreamingSlotPatchPayload>\n\t| StreamingSlotPatchPayload;\n\nexport type StaticStreamingSlotDefinition = {\n\tresolve: StaticStreamingSlotResolver;\n\ttimeoutMs?: number;\n\terrorHtml?: string;\n};\n\nexport type StaticStreamingSlotDefinitions = Record<\n\tstring,\n\tStaticStreamingSlotResolver | StaticStreamingSlotDefinition\n>;\n\nexport const defineStaticStreamingSlots = <\n\tconst T extends StaticStreamingSlotDefinitions\n>(\n\tslots: T\n) => slots;\n\nconst STATIC_SLOT_TAG_RE =\n\t/<abs-stream-slot\\b([^>]*?)(?:\\/>|>([\\s\\S]*?)<\\/abs-stream-slot>)/gi;\nconst ATTRIBUTE_RE =\n\t/([A-Za-z_:][-A-Za-z0-9_:.]*)\\s*=\\s*(?:\"([^\"]*)\"|'([^']*)')/g;\n\ntype StaticStreamingTagDefinition = {\n\terrorHtml?: string;\n\tfallbackHtml: string;\n\tid: string;\n\tresolver: string;\n\ttimeoutMs?: number;\n};\n\nconst parseAttributes = (attributeString: string) => {\n\tconst attributes = new Map<string, string>();\n\tconst setAttributeFromMatch = (matchParts: RegExpExecArray) => {\n\t\tconst [, key, doubleQuotedValue, singleQuotedValue] = matchParts;\n\t\tif (!key) {\n\t\t\treturn;\n\t\t}\n\n\t\tattributes.set(key, doubleQuotedValue ?? singleQuotedValue ?? '');\n\t};\n\n\tlet match = ATTRIBUTE_RE.exec(attributeString);\n\twhile (match) {\n\t\tsetAttributeFromMatch(match);\n\t\tmatch = ATTRIBUTE_RE.exec(attributeString);\n\t}\n\n\tATTRIBUTE_RE.lastIndex = 0;\n\n\treturn attributes;\n};\n\nconst parseTimeout = (value: string | undefined) => {\n\tif (!value) return undefined;\n\tconst parsed = Number(value);\n\tif (!Number.isFinite(parsed) || parsed < 0) {\n\t\tthrow new Error(\n\t\t\t`Invalid <abs-stream-slot timeout-ms=\"${value}\">. Expected a non-negative number.`\n\t\t);\n\t}\n\n\treturn parsed;\n};\n\nconst parseStaticStreamingTag = (\n\tattributeString: string,\n\tinnerHtml: string | undefined\n): StaticStreamingTagDefinition => {\n\tconst attributes = parseAttributes(attributeString);\n\tconst resolver = attributes.get('resolver');\n\tif (!resolver) {\n\t\tthrow new Error(\n\t\t\t'Static <abs-stream-slot> requires a \"resolver\" attribute.'\n\t\t);\n\t}\n\n\tconst id = attributes.get('id') ?? resolver;\n\n\treturn {\n\t\terrorHtml: attributes.get('error-html') ?? undefined,\n\t\tfallbackHtml:\n\t\t\tinnerHtml?.trim() ?? attributes.get('fallback-html') ?? '',\n\t\tid,\n\t\tresolver,\n\t\ttimeoutMs: parseTimeout(attributes.get('timeout-ms') ?? undefined)\n\t};\n};\n\nexport const extractStaticStreamingTags = (html: string) => {\n\tconst tagRe = new RegExp(STATIC_SLOT_TAG_RE);\n\tconst tags: StaticStreamingTagDefinition[] = [];\n\tlet match = tagRe.exec(html);\n\n\twhile (match) {\n\t\tconst [, rawAttributeString, innerHtml] = match;\n\t\ttags.push(parseStaticStreamingTag(rawAttributeString ?? '', innerHtml));\n\t\tmatch = tagRe.exec(html);\n\t}\n\n\treturn tags;\n};\n\nconst toStaticStreamingSlotDefinition = (\n\tvalue: StaticStreamingSlotResolver | StaticStreamingSlotDefinition\n) => (typeof value === 'function' ? { resolve: value } : value);\n\nconst isObjectRecord = (value: unknown): value is Record<string, unknown> =>\n\ttypeof value === 'object' && value !== null;\n\nconst toStaticStreamingDefinitionEntry = (\n\tentry: unknown\n): StaticStreamingSlotDefinition | StaticStreamingSlotResolver | null => {\n\tif (typeof entry === 'function') {\n\t\treturn () => entry();\n\t}\n\n\tif (!isObjectRecord(entry) || typeof entry.resolve !== 'function') {\n\t\treturn null;\n\t}\n\tconst { resolve } = entry;\n\n\treturn {\n\t\terrorHtml:\n\t\t\ttypeof entry.errorHtml === 'string' ? entry.errorHtml : undefined,\n\t\ttimeoutMs:\n\t\t\ttypeof entry.timeoutMs === 'number' ? entry.timeoutMs : undefined,\n\t\tresolve: () => resolve()\n\t};\n};\n\nconst toStaticStreamingSlotDefinitions = (value: unknown) => {\n\tif (!isObjectRecord(value)) {\n\t\treturn null;\n\t}\n\n\tconst definitions: StaticStreamingSlotDefinitions = {};\n\tfor (const [key, entry] of Object.entries(value)) {\n\t\tconst definition = toStaticStreamingDefinitionEntry(entry);\n\t\tif (!definition) {\n\t\t\treturn null;\n\t\t}\n\n\t\tdefinitions[key] = definition;\n\t}\n\n\treturn definitions;\n};\n\ntype StaticStreamingModuleExports = {\n\tdefault?: unknown;\n\tstreamingSlots?: unknown;\n};\n\nconst resolveStaticStreamingDefinitions = (\n\tmoduleExports: StaticStreamingModuleExports\n) =>\n\ttoStaticStreamingSlotDefinitions(moduleExports.streamingSlots) ??\n\ttoStaticStreamingSlotDefinitions(moduleExports.default);\n\nconst serverModuleExtensions = [\n\t'.server.ts',\n\t'.server.js',\n\t'.server.mjs',\n\t'.slots.ts',\n\t'.slots.js',\n\t'.slots.mjs'\n] as const;\n\nconst resolveSidecarCandidates = (pagePath: string) => {\n\tconst pageExt = extname(pagePath);\n\tif (!pageExt) return [];\n\n\tconst pageStem = pagePath.slice(0, -pageExt.length);\n\n\treturn serverModuleExtensions.map((extension) => `${pageStem}${extension}`);\n};\n\nconst fileExists = async (path: string) => Bun.file(path).exists();\n\nconst loadStaticStreamingModule = async (pagePath: string) => {\n\tconst loadCandidate = async (candidates: string[]) => {\n\t\tconst [candidate, ...remaining] = candidates;\n\t\tif (!candidate) {\n\t\t\treturn null;\n\t\t}\n\t\tif (!(await fileExists(candidate))) {\n\t\t\treturn loadCandidate(remaining);\n\t\t}\n\n\t\tconst version = statSync(candidate).mtimeMs;\n\t\tconst moduleUrl = new URL(pathToFileURL(candidate).href);\n\t\tmoduleUrl.searchParams.set('t', String(version));\n\n\t\tconst moduleExports: StaticStreamingModuleExports = await import(\n\t\t\tmoduleUrl.href\n\t\t);\n\t\tconst definitions = resolveStaticStreamingDefinitions(moduleExports);\n\t\tif (!definitions) {\n\t\t\tthrow new Error(\n\t\t\t\t`Static streaming module \"${candidate}\" must export a default value or named \"streamingSlots\" object.`\n\t\t\t);\n\t\t}\n\n\t\treturn definitions;\n\t};\n\n\treturn loadCandidate(resolveSidecarCandidates(pagePath));\n};\n\nexport const loadStaticStreamingSlots = async (\n\tpagePath: string,\n\thtml: string\n) => {\n\tconst tagDefinitions = extractStaticStreamingTags(html);\n\tif (tagDefinitions.length === 0) {\n\t\treturn [];\n\t}\n\n\tconst definitions = await loadStaticStreamingModule(pagePath);\n\tif (!definitions) {\n\t\tthrow new Error(\n\t\t\t`Static page \"${pagePath}\" uses <abs-stream-slot> but no page-adjacent server module was found. Create a sibling \".server.ts\" file that exports defineStaticStreamingSlots({...}).`\n\t\t);\n\t}\n\n\treturn tagDefinitions.map((tag) => {\n\t\tconst entry = definitions[tag.resolver];\n\t\tif (!entry) {\n\t\t\tthrow new Error(\n\t\t\t\t`Static streaming resolver \"${tag.resolver}\" was not found for \"${pagePath}\".`\n\t\t\t);\n\t\t}\n\n\t\tconst definition = toStaticStreamingSlotDefinition(entry);\n\n\t\treturn {\n\t\t\terrorHtml: tag.errorHtml ?? definition.errorHtml,\n\t\t\tfallbackHtml: tag.fallbackHtml,\n\t\t\tid: tag.id,\n\t\t\tresolve: definition.resolve,\n\t\t\ttimeoutMs: tag.timeoutMs ?? definition.timeoutMs\n\t\t} satisfies StreamingSlot;\n\t});\n};\n",
9
+ "import { readFileSync, writeFileSync } from 'node:fs';\nimport type {\n\tIslandFramework,\n\tIslandHydrate,\n\tIslandRegistryInput,\n\tRuntimeIslandRenderProps\n} from '../../types/island';\nimport { renderStreamingSlotPlaceholder } from '../utils/streamingSlots';\nimport { renderIslandMarkup } from '../core/renderIslandMarkup';\nimport { loadIslandRegistryBuildInfo } from './islandEntries';\nimport { requireCurrentIslandRegistry } from '../core/currentIslandRegistry';\nimport { extractStaticStreamingTags } from '../core/staticStreaming';\n\nconst ISLAND_TAG_RE_SOURCE =\n\t'<(?:absolute-island|island)\\\\b([^>]*?)(?:\\\\/\\\\>|>(?:[\\\\s\\\\S]*?)<\\\\/(?:absolute-island|island)>)';\nconst ATTRIBUTE_RE_SOURCE =\n\t'([A-Za-z_:][-A-Za-z0-9_:.]*)\\\\s*=\\\\s*(?:\"([^\"]*)\"|\\'([^\\']*)\\')';\n\nconst islandFrameworks: IslandFramework[] = [\n\t'react',\n\t'svelte',\n\t'vue',\n\t'angular'\n];\n\nconst islandHydrationModes = ['load', 'idle', 'visible', 'none'] as const;\n\nconst isRecord = (value: unknown): value is Record<string, unknown> =>\n\ttypeof value === 'object' && value !== null;\n\nconst isIslandFramework = (value: string): value is IslandFramework =>\n\tislandFrameworks.some((framework) => framework === value);\n\nconst isIslandHydrationMode = (\n\tvalue: string\n): value is IslandHydrate =>\n\tislandHydrationModes.some((mode) => mode === value);\n\ntype HTMLAttributeMap = Map<string, string>;\n\nconst parseHtmlAttributes = (attributeString: string): HTMLAttributeMap => {\n\tconst attributeRe = new RegExp(ATTRIBUTE_RE_SOURCE, 'g');\n\tconst attributes = new Map<string, string>();\n\tlet match = attributeRe.exec(attributeString);\n\n\twhile (match) {\n\t\tconst [, key, doubleQuotedValue, singleQuotedValue] = match;\n\t\tmatch = attributeRe.exec(attributeString);\n\t\tif (!key) continue;\n\n\t\tconst value = doubleQuotedValue ?? singleQuotedValue ?? '';\n\t\tattributes.set(key, value);\n\t}\n\n\treturn attributes;\n};\n\nconst parseIslandTag = (\n\tattributeString: string\n): RuntimeIslandRenderProps | null => {\n\tconst attributes = parseHtmlAttributes(attributeString);\n\tconst framework = attributes.get('framework');\n\tconst component = attributes.get('component');\n\tconst hydrate = attributes.get('hydrate') ?? 'load';\n\tconst propsSource = attributes.get('props') ?? '{}';\n\n\tif (!framework || !component) {\n\t\treturn null;\n\t}\n\n\tif (!isIslandFramework(framework)) {\n\t\tthrow new Error(`Unsupported static island framework \"${framework}\".`);\n\t}\n\n\tif (!isIslandHydrationMode(hydrate)) {\n\t\tthrow new Error(`Unsupported static island hydrate mode \"${hydrate}\".`);\n\t}\n\n\tlet parsedProps: Record<string, unknown>;\n\ttry {\n\t\tconst candidate: unknown = JSON.parse(propsSource);\n\t\tparsedProps = isRecord(candidate) ? candidate : {};\n\t} catch (error) {\n\t\tthrow new Error(\n\t\t\t`Failed to parse static island props JSON for ${framework}:${component}: ${\n\t\t\t\terror instanceof Error ? error.message : String(error)\n\t\t\t}`,\n\t\t\t{ cause: error }\n\t\t);\n\t}\n\n\treturn {\n\t\tcomponent,\n\t\tframework,\n\t\thydrate,\n\t\tprops: parsedProps\n\t};\n};\n\nexport const transformStaticPageHtml = async (\n\toriginalHtml: string,\n\tregistry: IslandRegistryInput\n) => {\n\tconst islandTagRe = new RegExp(ISLAND_TAG_RE_SOURCE, 'gi');\n\tif (!islandTagRe.test(originalHtml)) {\n\t\treturn originalHtml;\n\t}\n\n\tislandTagRe.lastIndex = 0;\n\n\tconst segments: { before: string; props: ReturnType<typeof parseIslandTag>; fullMatch: string }[] = [];\n\tlet lastIndex = 0;\n\tlet match = islandTagRe.exec(originalHtml);\n\n\twhile (match) {\n\t\tconst [fullMatch, rawAttributeString] = match;\n\t\tconst attributeString = rawAttributeString ?? '';\n\t\tsegments.push({\n\t\t\tbefore: originalHtml.slice(lastIndex, match.index),\n\t\t\tfullMatch,\n\t\t\tprops: parseIslandTag(attributeString)\n\t\t});\n\t\tlastIndex = match.index + fullMatch.length;\n\t\tmatch = islandTagRe.exec(originalHtml);\n\t}\n\n\tconst renderedSegments = await Promise.all(\n\t\tsegments.map(async (segment) =>\n\t\t\tsegment.before + (segment.props ? await renderIslandMarkup(registry, segment.props) : segment.fullMatch)\n\t\t)\n\t);\n\n\treturn renderedSegments.join('') + originalHtml.slice(lastIndex);\n};\n\nconst HTMX_STREAM_SLOT_TAG_RE =\n\t/<abs-htmx-stream-slot\\b([^>]*?)(?:\\/>|>([\\s\\S]*?)<\\/abs-htmx-stream-slot>)/gi;\n\nconst requireAttribute = (\n\tattributes: HTMLAttributeMap,\n\tname: string\n) => {\n\tconst value = attributes.get(name)?.trim();\n\tif (!value) {\n\t\tthrow new Error(\n\t\t\t`Static <abs-htmx-stream-slot> requires a \"${name}\" attribute.`\n\t\t);\n\t}\n\n\treturn value;\n};\n\nconst injectAttributesIntoSingleRootElement = (\n\tfallbackHtml: string,\n\tattributes: HTMLAttributeMap\n) => {\n\tconst trimmed = fallbackHtml.trim();\n\tif (!trimmed) {\n\t\tthrow new Error(\n\t\t\t'Static <abs-htmx-stream-slot> requires fallback HTML inside the element body.'\n\t\t);\n\t}\n\n\tconst openingTagMatch = trimmed.match(/^<([A-Za-z][\\w:-]*)([^>]*)>/);\n\tif (!openingTagMatch) {\n\t\tthrow new Error(\n\t\t\t'Static <abs-htmx-stream-slot> fallback must start with a single root HTML element.'\n\t\t);\n\t}\n\n\tconst attributeSource = [...attributes.entries()]\n\t\t.map(([key, value]) => `${key}=\"${value}\"`)\n\t\t.join(' ');\n\tif (!attributeSource) {\n\t\treturn trimmed;\n\t}\n\n\tconst [openingTag, tagName, rawExistingAttributes = ''] = openingTagMatch;\n\tconst existingAttributes = rawExistingAttributes.trim();\n\tconst mergedAttributes = existingAttributes\n\t\t? `${existingAttributes} ${attributeSource}`\n\t\t: attributeSource;\n\n\treturn trimmed.replace(openingTag, `<${tagName} ${mergedAttributes}>`);\n};\n\nexport const transformStaticHTMXStreamSlotHtml = (originalHtml: string) => {\n\tlet nextIndex = 0;\n\tlet result = '';\n\tlet match = HTMX_STREAM_SLOT_TAG_RE.exec(originalHtml);\n\n\twhile (match) {\n\t\tconst [fullMatch, rawAttributeString = '', innerHtml = ''] = match;\n\t\tconst attributes = parseHtmlAttributes(rawAttributeString);\n\t\tconst loweredAttributes = new Map<string, string>([\n\t\t\t['hx-get', requireAttribute(attributes, 'src')],\n\t\t\t['hx-trigger', attributes.get('trigger') ?? 'load'],\n\t\t\t['hx-swap', attributes.get('swap') ?? 'outerHTML'],\n\t\t\t['hx-target', attributes.get('target') ?? 'this']\n\t\t]);\n\n\t\tresult += originalHtml.slice(nextIndex, match.index);\n\t\tresult += injectAttributesIntoSingleRootElement(innerHtml, loweredAttributes);\n\t\tnextIndex = match.index + fullMatch.length;\n\t\tmatch = HTMX_STREAM_SLOT_TAG_RE.exec(originalHtml);\n\t}\n\n\treturn result + originalHtml.slice(nextIndex);\n};\n\nexport const transformStaticStreamingSlotHtml = (originalHtml: string) => {\n\tconst slotDefinitions = extractStaticStreamingTags(originalHtml);\n\tif (slotDefinitions.length === 0) {\n\t\treturn originalHtml;\n\t}\n\n\tconst tagRe =\n\t\t/<abs-stream-slot\\b([^>]*?)(?:\\/>|>([\\s\\S]*?)<\\/abs-stream-slot>)/gi;\n\tlet nextIndex = 0;\n\tlet slotIndex = 0;\n\tlet result = '';\n\tlet match = tagRe.exec(originalHtml);\n\n\twhile (match) {\n\t\tconst [fullMatch] = match;\n\t\tconst tag = slotDefinitions[slotIndex++];\n\t\tif (!tag) {\n\t\t\tthrow new Error(\n\t\t\t\t'Static streaming slot transform lost sync with parsed slot definitions.'\n\t\t\t);\n\t\t}\n\t\tresult += originalHtml.slice(nextIndex, match.index);\n\t\tresult += renderStreamingSlotPlaceholder(tag.id, tag.fallbackHtml);\n\t\tnextIndex = match.index + fullMatch.length;\n\t\tmatch = tagRe.exec(originalHtml);\n\t}\n\n\treturn result + originalHtml.slice(nextIndex);\n};\n\nconst transformStaticPage = async (\n\tpagePath: string,\n\tregistry: IslandRegistryInput\n) => {\n\tconst originalHtml = readFileSync(pagePath, 'utf-8');\n\tconst transformedHtml = await transformStaticPageHtml(\n\t\toriginalHtml,\n\t\tregistry\n\t);\n\n\tif (transformedHtml !== originalHtml) {\n\t\twriteFileSync(pagePath, transformedHtml);\n\t}\n};\n\nexport const transformCurrentStaticPageHtml = async (\n\thtml: string,\n\toptions: {\n\t\tenableHTMXStreaming?: boolean;\n\t\tenableStaticStreaming?: boolean;\n\t} = {}\n) => {\n\tconst transformedHTMXStreamingHtml =\n\t\toptions.enableHTMXStreaming === false\n\t\t\t? html\n\t\t\t: transformStaticHTMXStreamSlotHtml(html);\n\tconst transformedStreamingHtml =\n\t\toptions.enableStaticStreaming === false\n\t\t\t? transformedHTMXStreamingHtml\n\t\t\t: transformStaticStreamingSlotHtml(transformedHTMXStreamingHtml);\n\tconst islandTagRe = new RegExp(ISLAND_TAG_RE_SOURCE, 'i');\n\tif (!islandTagRe.test(transformedStreamingHtml)) {\n\t\treturn transformedStreamingHtml;\n\t}\n\n\treturn transformStaticPageHtml(\n\t\ttransformedStreamingHtml,\n\t\trequireCurrentIslandRegistry()\n\t);\n};\nexport const transformStaticPagesWithIslands = async (\n\tregistryPath: string | undefined,\n\tpagePaths: string[]\n) => {\n\tif (!registryPath || pagePaths.length === 0) {\n\t\treturn;\n\t}\n\n\tconst { registry } = await loadIslandRegistryBuildInfo(registryPath);\n\n\tawait Promise.all(\n\t\tpagePaths.map((pagePath) => transformStaticPage(pagePath, registry))\n\t);\n};\n",
10
+ "import { readFileSync } from 'node:fs';\nimport { dirname, resolve } from 'node:path';\nimport type { BuildConfig } from '../../types/build';\nimport type { IslandFramework } from '../../types/island';\nimport { loadIslandRegistryBuildInfo } from '../build/islandEntries';\nimport { scanEntryPoints } from '../build/scanEntryPoints';\nimport {\n\textractIslandUsagesFromSource,\n\ttype PageIslandUsage\n} from './sourceMetadata';\n\nexport type PageIslandMetadata = {\n\tislands: PageIslandUsage[];\n\tpagePath: string;\n};\n\ndeclare global {\n\tvar __absolutePageIslandMetadata:\n\t\t| Map<string, PageIslandMetadata>\n\t\t| undefined;\n}\n\nconst pagePatterns: Partial<Record<IslandFramework | 'html' | 'htmx', string>> =\n\t{\n\t\tangular: 'pages/**/*.{ts,js}',\n\t\thtml: 'pages/**/*.html',\n\t\thtmx: 'pages/**/*.html',\n\t\treact: 'pages/**/*.{ts,tsx,js,jsx}',\n\t\tsvelte: 'pages/**/*.svelte',\n\t\tvue: 'pages/**/*.vue'\n\t};\n\ntype PageDirectoryEntry = {\n\tdir: string;\n\tframework: keyof typeof pagePatterns;\n};\n\nconst getPageDirs = (config: BuildConfig) =>\n\t(\n\t\t[\n\t\t\t{ dir: config.angularDirectory, framework: 'angular' },\n\t\t\t{ dir: config.reactDirectory, framework: 'react' },\n\t\t\t{ dir: config.svelteDirectory, framework: 'svelte' },\n\t\t\t{ dir: config.vueDirectory, framework: 'vue' },\n\t\t\t{ dir: config.htmlDirectory, framework: 'html' },\n\t\t\t{ dir: config.htmxDirectory, framework: 'htmx' }\n\t\t] satisfies Array<{\n\t\t\tdir: string | undefined;\n\t\t\tframework: keyof typeof pagePatterns;\n\t\t}>\n\t).filter(\n\t\t(entry): entry is PageDirectoryEntry =>\n\t\t\ttypeof entry.dir === 'string' && entry.dir.length > 0\n\t);\n\nconst buildIslandSourceLookup = async (config: BuildConfig) => {\n\tconst registryPath = config.islands?.registry;\n\tif (!registryPath) {\n\t\treturn new Map<string, string>();\n\t}\n\n\tconst buildInfo = await loadIslandRegistryBuildInfo(registryPath);\n\tconst lookup = new Map<string, string>();\n\n\tfor (const definition of buildInfo.definitions) {\n\t\tconst source = definition.buildReference?.source;\n\t\tif (!source) continue;\n\n\t\tconst resolvedSource = source.startsWith('file://')\n\t\t\t? new URL(source).pathname\n\t\t\t: resolve(dirname(buildInfo.resolvedRegistryPath), source);\n\n\t\tlookup.set(\n\t\t\t`${definition.framework}:${definition.component}`,\n\t\t\tresolve(resolvedSource)\n\t\t);\n\t}\n\n\treturn lookup;\n};\n\nexport const getCurrentPageIslandMetadata = () =>\n\tglobalThis.__absolutePageIslandMetadata ??\n\tnew Map<string, PageIslandMetadata>();\nconst metadataUsesSource = (metadata: PageIslandMetadata, target: string) =>\n\tmetadata.islands.some((usage) => {\n\t\tconst candidate = usage.source;\n\n\t\treturn candidate ? resolve(candidate) === target : false;\n\t});\n\nexport const getPagesUsingIslandSource = (sourcePath: string) => {\n\tconst target = resolve(sourcePath);\n\n\treturn [...getCurrentPageIslandMetadata().values()]\n\t\t.filter((metadata) => metadataUsesSource(metadata, target))\n\t\t.map((metadata) => metadata.pagePath);\n};\nconst resolveIslandUsages = (\n\tislands: PageIslandUsage[],\n\tislandSourceLookup: Map<string, string>\n) =>\n\tislands.map((usage) => {\n\t\tconst sourcePath = islandSourceLookup.get(\n\t\t\t`${usage.framework}:${usage.component}`\n\t\t);\n\n\t\treturn sourcePath\n\t\t\t? {\n\t\t\t\t\t...usage,\n\t\t\t\t\tsource: sourcePath\n\t\t\t\t}\n\t\t\t: usage;\n\t});\n\nconst loadPageIslandFiles = async (\n\tentry: PageDirectoryEntry,\n\tislandSourceLookup: Map<string, string>,\n\tpageMetadata: Map<string, PageIslandMetadata>\n) => {\n\tconst pattern = pagePatterns[entry.framework];\n\tif (!pattern) return;\n\n\tconst files = await scanEntryPoints(resolve(entry.dir), pattern);\n\tfor (const filePath of files) {\n\t\tconst source = readFileSync(filePath, 'utf-8');\n\t\tconst islands = extractIslandUsagesFromSource(source);\n\t\tpageMetadata.set(resolve(filePath), {\n\t\t\tislands: resolveIslandUsages(islands, islandSourceLookup),\n\t\t\tpagePath: resolve(filePath)\n\t\t});\n\t}\n};\n\nexport const loadPageIslandMetadata = async (config: BuildConfig) => {\n\tconst pageMetadata = new Map<string, PageIslandMetadata>();\n\tconst islandSourceLookup = await buildIslandSourceLookup(config);\n\n\tawait Promise.all(\n\t\tgetPageDirs(config).map((entry) =>\n\t\t\tloadPageIslandFiles(entry, islandSourceLookup, pageMetadata)\n\t\t)\n\t);\n\n\treturn pageMetadata;\n};\nexport const setCurrentPageIslandMetadata = (\n\tmetadata: Map<string, PageIslandMetadata>\n) => {\n\tglobalThis.__absolutePageIslandMetadata = metadata;\n};\n"
11
+ ],
12
+ "mappings": "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",
13
+ "debugId": "EA2793B90D7FF16C64756E2164756E21",
14
+ "names": []
15
+ }
@@ -9,9 +9,10 @@ import {
9
9
  resolvePackageImport
10
10
  } from "./chunk-mbazhahf.js";
11
11
  import {
12
+ addStyleImporter,
12
13
  compileStyleSource,
13
14
  isStylePath
14
- } from "./chunk-6fkgm9s5.js";
15
+ } from "./chunk-xnt8c6h2.js";
15
16
  import {
16
17
  BASE_36_RADIX
17
18
  } from "./chunk-qh75agse.js";
@@ -22,7 +23,14 @@ import {
22
23
  // src/build/compileVue.ts
23
24
  import { existsSync } from "fs";
24
25
  import { mkdir } from "fs/promises";
25
- import { basename, dirname, join, relative, resolve } from "path";
26
+ import {
27
+ basename,
28
+ dirname,
29
+ isAbsolute,
30
+ join,
31
+ relative,
32
+ resolve
33
+ } from "path";
26
34
  var {file, write, Transpiler } = globalThis.Bun;
27
35
  var resolveDevClientDir = () => {
28
36
  const projectRoot = process.cwd();
@@ -156,6 +164,10 @@ var compileVueFile = async (sourceFilePath, outputDirs, cacheMap, isEntryPoint,
156
164
  const childComponentPaths = importPaths.filter((path) => path.startsWith(".") && path.endsWith(".vue"));
157
165
  const packageComponentPaths = Array.from(resolvedPackageVueImports.entries());
158
166
  const helperModulePaths = importPaths.filter((path) => path.startsWith(".") && !path.endsWith(".vue") && !isStylePath(path));
167
+ const stylePathsImported = importPaths.filter((path) => (path.startsWith(".") || isAbsolute(path)) && isStylePath(path)).map((path) => isAbsolute(path) ? path : resolve(dirname(sourceFilePath), path));
168
+ for (const stylePath of stylePathsImported) {
169
+ addStyleImporter(sourceFilePath, stylePath);
170
+ }
159
171
  const childBuildResults = await Promise.all([
160
172
  ...childComponentPaths.map((relativeChildPath) => compileVueFile(resolve(dirname(sourceFilePath), relativeChildPath), outputDirs, cacheMap, false, vueRootDir, compiler, stylePreprocessors)),
161
173
  ...packageComponentPaths.map(([, absolutePath]) => compileVueFile(absolutePath, outputDirs, cacheMap, false, vueRootDir, compiler, stylePreprocessors))
@@ -450,5 +462,5 @@ export {
450
462
  clearVueHmrCaches
451
463
  };
452
464
 
453
- //# debugId=12EDE19C68C85FED64756E2164756E21
454
- //# sourceMappingURL=chunk-xrmjy8kk.js.map
465
+ //# debugId=09DC66352653B6F864756E2164756E21
466
+ //# sourceMappingURL=chunk-5f67rsed.js.map