@absolutejs/absolute 0.19.0-beta.1031 → 0.19.0-beta.1032

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 (74) hide show
  1. package/dist/angular/browser.js +18 -16
  2. package/dist/angular/browser.js.map +5 -5
  3. package/dist/angular/components/core/streamingSlotRegistrar.js +1 -1
  4. package/dist/angular/components/core/streamingSlotRegistry.js +2 -2
  5. package/dist/angular/hmrPreserveCore.ts +83 -118
  6. package/dist/angular/index.js +49 -49
  7. package/dist/angular/index.js.map +12 -12
  8. package/dist/angular/server.js +34 -34
  9. package/dist/angular/server.js.map +10 -10
  10. package/dist/build.js +135 -135
  11. package/dist/build.js.map +26 -26
  12. package/dist/cli/config/client.js +1 -1
  13. package/dist/cli/config/server.js +43 -43
  14. package/dist/cli/index.js +23 -13
  15. package/dist/client/index.js +9 -9
  16. package/dist/client/index.js.map +8 -8
  17. package/dist/dev/client/errorOverlay.ts +4 -4
  18. package/dist/dev/client/handlers/angularHmrShim.ts +17 -17
  19. package/dist/dev/client/handlers/angularRemount.ts +6 -4
  20. package/dist/dev/client/handlers/angularRemountWiring.ts +1 -1
  21. package/dist/dev/client/hmrToast.ts +18 -18
  22. package/dist/index.js +149 -150
  23. package/dist/index.js.map +31 -31
  24. package/dist/islands/browser.js.map +1 -1
  25. package/dist/islands/index.js +5 -5
  26. package/dist/islands/index.js.map +6 -6
  27. package/dist/react/browser.js.map +1 -1
  28. package/dist/react/components/index.js +2 -2
  29. package/dist/react/components/index.js.map +3 -3
  30. package/dist/react/hooks/index.js.map +1 -1
  31. package/dist/react/index.js +21 -21
  32. package/dist/react/index.js.map +9 -9
  33. package/dist/react/server.js +17 -17
  34. package/dist/react/server.js.map +5 -5
  35. package/dist/src/angular/hmrPreserveCore.d.ts +5 -18
  36. package/dist/src/angular/islands.d.ts +1 -1
  37. package/dist/src/cli/config/packageJson/editPackageJson.d.ts +2 -2
  38. package/dist/src/cli/config/schema/fromJsonSchema.d.ts +1 -1
  39. package/dist/src/client/hydrators/react.d.ts +1 -1
  40. package/dist/src/client/hydrators/svelte.d.ts +1 -1
  41. package/dist/src/client/hydrators/vue.d.ts +1 -1
  42. package/dist/src/client/islandStore.d.ts +3 -3
  43. package/dist/src/core/devRouteRegistrationCallsite.d.ts +1 -5
  44. package/dist/src/dev/angular/fastHmrCompiler.d.ts +2 -2
  45. package/dist/src/dev/angular/hmrCompiler.d.ts +1 -1
  46. package/dist/src/dev/angular/resolveOwningComponents.d.ts +1 -1
  47. package/dist/src/svelte/router/hashMode.d.ts +1 -6
  48. package/dist/src/svelte/router/matchPath.d.ts +2 -22
  49. package/dist/src/svelte/router/page.svelte.d.ts +1 -10
  50. package/dist/src/svelte/router/prefetchCache.d.ts +2 -6
  51. package/dist/src/utils/generatedDir.d.ts +1 -1
  52. package/dist/src/utils/inlinePageCss.d.ts +1 -3
  53. package/dist/src/utils/jsonLd.d.ts +1 -1
  54. package/dist/src/utils/loadConfig.d.ts +2 -3
  55. package/dist/src/utils/resolveConvention.d.ts +1 -1
  56. package/dist/src/utils/runtimeMode.d.ts +1 -1
  57. package/dist/src/vue/defineVuePage.d.ts +1 -11
  58. package/dist/svelte/browser.js.map +1 -1
  59. package/dist/svelte/index.js +26 -26
  60. package/dist/svelte/index.js.map +9 -9
  61. package/dist/svelte/router/hashMode.ts +6 -12
  62. package/dist/svelte/router/matchPath.ts +23 -45
  63. package/dist/svelte/router/page.d.ts +1 -10
  64. package/dist/svelte/router/page.js +6 -6
  65. package/dist/svelte/router/prefetchCache.ts +12 -20
  66. package/dist/svelte/server.js +22 -22
  67. package/dist/svelte/server.js.map +5 -5
  68. package/dist/vue/browser.js +2 -2
  69. package/dist/vue/browser.js.map +4 -4
  70. package/dist/vue/index.js +29 -29
  71. package/dist/vue/index.js.map +11 -11
  72. package/dist/vue/server.js +24 -24
  73. package/dist/vue/server.js.map +6 -6
  74. package/package.json +38 -38
@@ -31414,7 +31414,7 @@ var VIRTUAL_NAME = "__absolute_type_introspect__.ts", MAX_DEPTH2 = 6, isFramewor
31414
31414
  resolve6(cwd, "package.json")
31415
31415
  ]) {
31416
31416
  try {
31417
- const version3 = JSON.parse(readFileSync9(candidate, "utf-8")).version;
31417
+ const { version: version3 } = JSON.parse(readFileSync9(candidate, "utf-8"));
31418
31418
  if (typeof version3 === "string")
31419
31419
  return version3;
31420
31420
  } catch {}
@@ -31806,7 +31806,7 @@ var lineStartOffset = (text, position) => {
31806
31806
  writeFileSync5(configPath, text.slice(0, start) + valueText + text.slice(end), "utf-8");
31807
31807
  return { message: `Updated ${request.name}`, ok: true };
31808
31808
  }
31809
- const properties = object.properties;
31809
+ const { properties } = object;
31810
31810
  const entry = `${request.name}: ${valueText}`;
31811
31811
  if (properties.length > 0) {
31812
31812
  const last = properties[properties.length - 1];
@@ -31855,7 +31855,18 @@ var detectFormatting3 = (text) => {
31855
31855
  return { insertSpaces: false, tabSize: 1 };
31856
31856
  }
31857
31857
  return { insertSpaces: true, tabSize: indent.length };
31858
- }, setPath = (text, path, value) => applyEdits(text, modify(text, path, value, { formattingOptions: detectFormatting3(text) })), applyScriptEdit = (configPath, edit) => {
31858
+ }, setPath = (text, path, value) => applyEdits(text, modify(text, path, value, { formattingOptions: detectFormatting3(text) })), applyFieldEdit = (configPath, edit) => {
31859
+ try {
31860
+ const text = readFileSync12(configPath, "utf-8");
31861
+ writeFileSync6(configPath, setPath(text, [edit.name], edit.remove ? undefined : edit.value), "utf-8");
31862
+ return {
31863
+ message: edit.remove ? `Removed ${edit.name}` : `Updated ${edit.name}`,
31864
+ ok: true
31865
+ };
31866
+ } catch (error) {
31867
+ return { message: String(error), ok: false };
31868
+ }
31869
+ }, applyScriptEdit = (configPath, edit) => {
31859
31870
  try {
31860
31871
  let text = readFileSync12(configPath, "utf-8");
31861
31872
  if (edit.remove) {
@@ -31875,17 +31886,6 @@ var detectFormatting3 = (text) => {
31875
31886
  } catch (error) {
31876
31887
  return { message: String(error), ok: false };
31877
31888
  }
31878
- }, applyFieldEdit = (configPath, edit) => {
31879
- try {
31880
- const text = readFileSync12(configPath, "utf-8");
31881
- writeFileSync6(configPath, setPath(text, [edit.name], edit.remove ? undefined : edit.value), "utf-8");
31882
- return {
31883
- message: edit.remove ? `Removed ${edit.name}` : `Updated ${edit.name}`,
31884
- ok: true
31885
- };
31886
- } catch (error) {
31887
- return { message: String(error), ok: false };
31888
- }
31889
31889
  };
31890
31890
  var init_editPackageJson = __esm(() => {
31891
31891
  init_main();
@@ -32292,6 +32292,22 @@ var FieldEditor = (props) => {
32292
32292
  // src/cli/config/schema/fromJsonSchema.ts
32293
32293
  var MAX_DEPTH = 6;
32294
32294
  var opaque = () => ({ kind: "opaque", typeText: "json" });
32295
+ var eslintOptionsSchema = (metaSchema) => {
32296
+ if (Array.isArray(metaSchema)) {
32297
+ if (metaSchema.length === 0)
32298
+ return { kind: "opaque", typeText: "options" };
32299
+ return {
32300
+ items: metaSchema.map((entry) => fromJsonSchema(entry)),
32301
+ kind: "tuple"
32302
+ };
32303
+ }
32304
+ if (isRecord(metaSchema)) {
32305
+ if (metaSchema.type === "array")
32306
+ return fromJsonSchema(metaSchema);
32307
+ return { items: [fromJsonSchema(metaSchema)], kind: "tuple" };
32308
+ }
32309
+ return { kind: "opaque", typeText: "options" };
32310
+ };
32295
32311
  var fromJsonSchema = (schema, depth = 0) => {
32296
32312
  if (depth > MAX_DEPTH || !isRecord(schema))
32297
32313
  return opaque();
@@ -32316,7 +32332,7 @@ var fromJsonSchema = (schema, depth = 0) => {
32316
32332
  if (type === "boolean")
32317
32333
  return { kind: "boolean" };
32318
32334
  if (type === "array") {
32319
- const items = schema.items;
32335
+ const { items } = schema;
32320
32336
  if (Array.isArray(items)) {
32321
32337
  return {
32322
32338
  items: items.map((item) => fromJsonSchema(item, depth + 1)),
@@ -32353,22 +32369,6 @@ var fromJsonSchema = (schema, depth = 0) => {
32353
32369
  }
32354
32370
  return opaque();
32355
32371
  };
32356
- var eslintOptionsSchema = (metaSchema) => {
32357
- if (Array.isArray(metaSchema)) {
32358
- if (metaSchema.length === 0)
32359
- return { kind: "opaque", typeText: "options" };
32360
- return {
32361
- items: metaSchema.map((entry) => fromJsonSchema(entry)),
32362
- kind: "tuple"
32363
- };
32364
- }
32365
- if (isRecord(metaSchema)) {
32366
- if (metaSchema.type === "array")
32367
- return fromJsonSchema(metaSchema);
32368
- return { items: [fromJsonSchema(metaSchema)], kind: "tuple" };
32369
- }
32370
- return { kind: "opaque", typeText: "options" };
32371
- };
32372
32372
 
32373
32373
  // src/cli/config/eslint/EslintPanel.tsx
32374
32374
  var jsx_dev_runtime2 = __toESM(require_jsx_dev_runtime(), 1);
@@ -33579,7 +33579,7 @@ var Control2 = ({ busy, isSet, onSave, option, value }) => {
33579
33579
  }, undefined, false, undefined, this);
33580
33580
  };
33581
33581
  var OptionRow2 = ({ busy, current, onSave, option }) => {
33582
- const name = option.name;
33582
+ const { name } = option;
33583
33583
  if (name === undefined)
33584
33584
  return null;
33585
33585
  const isSet = Object.prototype.hasOwnProperty.call(current, name);
@@ -36498,6 +36498,14 @@ var getMap = () => {
36498
36498
  return empty;
36499
36499
  };
36500
36500
  var normalizeConventionPageName = (name) => toPascal(name).replace(/\d+$/, "");
36501
+ var hasErrorConvention = (framework) => {
36502
+ const conventions = getMap()[framework];
36503
+ if (!conventions)
36504
+ return false;
36505
+ if (conventions.defaults?.error)
36506
+ return true;
36507
+ return Object.values(conventions.pages ?? {}).some((page) => Boolean(page.error));
36508
+ };
36501
36509
  var resolveErrorConventionPath = (framework, pageName) => {
36502
36510
  const conventions = getMap()[framework];
36503
36511
  if (!conventions)
@@ -36513,14 +36521,6 @@ var resolveErrorConventionPath = (framework, pageName) => {
36513
36521
  }
36514
36522
  return conventions.defaults?.error;
36515
36523
  };
36516
- var hasErrorConvention = (framework) => {
36517
- const conventions = getMap()[framework];
36518
- if (!conventions)
36519
- return false;
36520
- if (conventions.defaults?.error)
36521
- return true;
36522
- return Object.values(conventions.pages ?? {}).some((page) => Boolean(page.error));
36523
- };
36524
36524
  var isDev = () => true;
36525
36525
  var buildErrorProps = (error) => {
36526
36526
  if (error instanceof Error) {
@@ -36530,7 +36530,7 @@ var buildErrorProps = (error) => {
36530
36530
  ...isDev() && error.stack ? { stack: error.stack } : {}
36531
36531
  };
36532
36532
  }
36533
- return { name: "Error", message: String(error) };
36533
+ return { message: String(error), name: "Error" };
36534
36534
  };
36535
36535
  var renderReactError = async (conventionPath, errorProps) => {
36536
36536
  const { createElement } = await Promise.resolve().then(() => __toESM(require_react(), 1));
@@ -36678,7 +36678,7 @@ var buildRefreshSetup = () => {
36678
36678
  return "window.__REFRESH_BUFFER__=[];" + "window.$RefreshReg$=function(t,i){window.__REFRESH_BUFFER__.push([t,i])};" + "window.$RefreshSig$=function(){return function(t){return t}};";
36679
36679
  };
36680
36680
  var handleReactPageRequest = async (input) => {
36681
- const Page = input.Page;
36681
+ const { Page } = input;
36682
36682
  const resolvedIndex = input.index;
36683
36683
  const options = input;
36684
36684
  const userProps = input.props;
@@ -36872,8 +36872,8 @@ var getClientBundle = async () => {
36872
36872
  return cachedClientBundle;
36873
36873
  };
36874
36874
  var renderShell = (panel) => handleReactPageRequest({
36875
- Page: ConfigShell,
36876
36875
  index: CLIENT_ROUTE,
36876
+ Page: ConfigShell,
36877
36877
  props: { panel }
36878
36878
  });
36879
36879
  var isSeverity = (value) => value === "off" || value === "warn" || value === "error";
package/dist/cli/index.js CHANGED
@@ -316,7 +316,7 @@ var heldLocks, HELD_LOCKS_ENV = "ABSOLUTE_HELD_BUILD_DIRECTORY_LOCKS", exitHandl
316
316
  process.kill(pid, 0);
317
317
  return true;
318
318
  } catch (err) {
319
- const code = err.code;
319
+ const { code } = err;
320
320
  if (code === "ESRCH")
321
321
  return false;
322
322
  if (code === "EPERM")
@@ -172056,13 +172056,13 @@ var cliTag4 = (color, message) => `\x1B[2m${formatTimestamp()}\x1B[0m ${color}[c
172056
172056
  const destDir = join13(outdir, "node_modules", ...specifier.split("/"));
172057
172057
  rmSync4(destDir, { force: true, recursive: true });
172058
172058
  cpSync(srcDir, destDir, {
172059
+ force: true,
172060
+ recursive: true,
172059
172061
  filter(source) {
172060
172062
  const rel = relative3(srcDir, source);
172061
172063
  const [firstSegment] = rel.split(/[\\/]/);
172062
172064
  return firstSegment !== "node_modules" && firstSegment !== ".git";
172063
- },
172064
- force: true,
172065
- recursive: true
172065
+ }
172066
172066
  });
172067
172067
  const deps = {
172068
172068
  ...pkg.dependencies ?? {},
@@ -172649,15 +172649,25 @@ console.log(\`
172649
172649
  return;
172650
172650
  });
172651
172651
  }
172652
- }), FRAMEWORK_EXTERNALS, resolveServerBundleExternals = (buildConfig) => FRAMEWORK_EXTERNALS.filter((specifier) => {
172653
- if (buildConfig.reactDirectory && (specifier === "react" || specifier.startsWith("react/") || specifier.startsWith("react-dom")))
172654
- return false;
172655
- if (buildConfig.vueDirectory && (specifier === "vue" || specifier.startsWith("vue/") || specifier === "@vue/server-renderer"))
172656
- return false;
172657
- if (buildConfig.svelteDirectory && (specifier === "svelte" || specifier.startsWith("svelte/")))
172658
- return false;
172659
- return true;
172660
- }), compile = async (serverEntry, outdir, outfile, configPath2) => {
172652
+ }), FRAMEWORK_EXTERNALS, collectUserServerExternals = (buildConfig) => {
172653
+ const bunBuild = buildConfig.bunBuild;
172654
+ if (!bunBuild)
172655
+ return [];
172656
+ const override = Array.isArray(bunBuild.external) ? bunBuild.external : [];
172657
+ const fromDefault = Array.isArray(bunBuild.default?.external) ? bunBuild.default.external : [];
172658
+ return [...override, ...fromDefault];
172659
+ }, resolveServerBundleExternals = (buildConfig) => [
172660
+ ...FRAMEWORK_EXTERNALS.filter((specifier) => {
172661
+ if (buildConfig.reactDirectory && (specifier === "react" || specifier.startsWith("react/") || specifier.startsWith("react-dom")))
172662
+ return false;
172663
+ if (buildConfig.vueDirectory && (specifier === "vue" || specifier.startsWith("vue/") || specifier === "@vue/server-renderer"))
172664
+ return false;
172665
+ if (buildConfig.svelteDirectory && (specifier === "svelte" || specifier.startsWith("svelte/")))
172666
+ return false;
172667
+ return true;
172668
+ }),
172669
+ ...collectUserServerExternals(buildConfig)
172670
+ ], compile = async (serverEntry, outdir, outfile, configPath2) => {
172661
172671
  const resolvedOutdir = resolve12(outdir ?? "dist");
172662
172672
  await withBuildDirectoryLock(resolvedOutdir, () => compileUnlocked(serverEntry, resolvedOutdir, outfile, configPath2));
172663
172673
  }, compileUnlocked = async (serverEntry, resolvedOutdir, outfile, configPath2) => {
@@ -266,7 +266,7 @@ var reactIslandRoots, isPropsRecord = (value) => typeof value === "object" && va
266
266
  continue;
267
267
  Reflect.deleteProperty(element, key);
268
268
  }
269
- }, isReactComponent = (value) => typeof value === "function", hydrateReactIsland = (component, element, props) => {
269
+ }, hydrateReactIsland = (component, element, props) => {
270
270
  const existingRoot = reactIslandRoots.get(element);
271
271
  if (existingRoot) {
272
272
  existingRoot.render(isPropsRecord(props) ? createElement(component, props) : createElement(component));
@@ -278,7 +278,7 @@ var reactIslandRoots, isPropsRecord = (value) => typeof value === "object" && va
278
278
  return;
279
279
  }
280
280
  reactIslandRoots.set(element, hydrateRoot(element, createElement(component, props)));
281
- };
281
+ }, isReactComponent = (value) => typeof value === "function";
282
282
  var init_react = __esm(() => {
283
283
  reactIslandRoots = new WeakMap;
284
284
  HOST_REACT_EXPANDO_PREFIXES = [
@@ -298,12 +298,12 @@ __export(exports_svelte, {
298
298
  hydrateSvelteIsland: () => hydrateSvelteIsland
299
299
  });
300
300
  import { hydrate as hydrateSvelte } from "svelte";
301
- var isPropsRecord2 = (value) => typeof value === "object" && value !== null, isSvelteComponent = (value) => typeof value === "function", hydrateSvelteIsland = (component, element, props) => {
301
+ var isPropsRecord2 = (value) => typeof value === "object" && value !== null, hydrateSvelteIsland = (component, element, props) => {
302
302
  hydrateSvelte(component, {
303
303
  props: isPropsRecord2(props) ? props : undefined,
304
304
  target: element
305
305
  });
306
- };
306
+ }, isSvelteComponent = (value) => typeof value === "function";
307
307
  var init_svelte = () => {};
308
308
 
309
309
  // src/client/hydrators/vue.ts
@@ -313,7 +313,7 @@ __export(exports_vue, {
313
313
  hydrateVueIsland: () => hydrateVueIsland
314
314
  });
315
315
  import { createSSRApp, h } from "vue";
316
- var vueIslandApps, isPropsRecord3 = (value) => typeof value === "object" && value !== null, isVueComponent = (value) => typeof value === "function" || isPropsRecord3(value), hydrateVueIsland = (component, element, props) => {
316
+ var vueIslandApps, isPropsRecord3 = (value) => typeof value === "object" && value !== null, hydrateVueIsland = (component, element, props) => {
317
317
  if (vueIslandApps.has(element)) {
318
318
  return;
319
319
  }
@@ -322,7 +322,7 @@ var vueIslandApps, isPropsRecord3 = (value) => typeof value === "object" && valu
322
322
  });
323
323
  app.mount(element);
324
324
  vueIslandApps.set(element, app);
325
- };
325
+ }, isVueComponent = (value) => typeof value === "function" || isPropsRecord3(value);
326
326
  var init_vue = __esm(() => {
327
327
  vueIslandApps = new WeakMap;
328
328
  });
@@ -369,7 +369,7 @@ var resolveAngularPackageDir = (specifier) => {
369
369
  var init_resolveAngularPackage = () => {};
370
370
 
371
371
  // src/utils/runtimeMode.ts
372
- var ENV_VAR = "NODE_ENV", isProductionRuntime = () => process.env[ENV_VAR] === "production", isDevelopmentRuntime = () => process.env[ENV_VAR] === "development";
372
+ var ENV_VAR = "NODE_ENV", isDevelopmentRuntime = () => process.env[ENV_VAR] === "development", isProductionRuntime = () => process.env[ENV_VAR] === "production";
373
373
 
374
374
  // src/angular/angularPatch.ts
375
375
  var exports_angularPatch = {};
@@ -747,7 +747,7 @@ __export(exports_islands, {
747
747
  isAngularComponent: () => isAngularComponent,
748
748
  getAngularIslandSelector: () => getAngularIslandSelector
749
749
  });
750
- var angularIslandSelector = "abs-angular-island", isAngularComponent = (value) => typeof value === "function", getAngularIslandSelector = (_islandId) => angularIslandSelector, getSelectorFromRenderedIsland = (rootElement) => {
750
+ var angularIslandSelector = "abs-angular-island", getAngularIslandSelector = (_islandId) => angularIslandSelector, isAngularComponent = (value) => typeof value === "function", getSelectorFromRenderedIsland = (rootElement) => {
751
751
  const firstChild = rootElement.firstElementChild;
752
752
  if (!(firstChild instanceof HTMLElement)) {
753
753
  return null;
@@ -1256,5 +1256,5 @@ export {
1256
1256
  createIslandManifestResolver
1257
1257
  };
1258
1258
 
1259
- //# debugId=07B15BB8DBC2C0A764756E2164756E21
1259
+ //# debugId=734277CC6480B23564756E2164756E21
1260
1260
  //# sourceMappingURL=index.js.map