mirror of
https://github.com/withastro/astro.git
synced 2025-01-22 10:31:53 -05:00
Remove support for Node 16 (#7780)
This commit is contained in:
parent
4d160fa1e2
commit
d0679a666f
68 changed files with 129 additions and 95 deletions
32
.changeset/afraid-dots-whisper.md
Normal file
32
.changeset/afraid-dots-whisper.md
Normal file
|
@ -0,0 +1,32 @@
|
|||
---
|
||||
'@astrojs/cloudflare': major
|
||||
'@astrojs/partytown': major
|
||||
'@astrojs/tailwind': major
|
||||
'@astrojs/netlify': major
|
||||
'@astrojs/sitemap': major
|
||||
'@astrojs/preact': major
|
||||
'@astrojs/svelte': major
|
||||
'@astrojs/vercel': major
|
||||
'@astrojs/react': major
|
||||
'@astrojs/solid-js': major
|
||||
'@astrojs/deno': major
|
||||
'@astrojs/node': major
|
||||
'@astrojs/lit': major
|
||||
'@astrojs/vue': major
|
||||
'create-astro': major
|
||||
'@astrojs/prism': major
|
||||
'@astrojs/rss': major
|
||||
'@astrojs/telemetry': major
|
||||
'@astrojs/webapi': major
|
||||
'astro': major
|
||||
'@astrojs/turbolinks': minor
|
||||
'@astrojs/alpinejs': minor
|
||||
'@astrojs/prefetch': minor
|
||||
'@astrojs/markdoc': minor
|
||||
'@astrojs/underscore-redirects': minor
|
||||
'@astrojs/image': minor
|
||||
'@astrojs/mdx': minor
|
||||
'@astrojs/internal-helpers': minor
|
||||
---
|
||||
|
||||
Remove support for Node 16. The lowest supported version by Astro and all integrations is now v18.14.1. As a reminder, Node 16 will be deprecated on the 11th September 2023.
|
2
.github/ISSUE_TEMPLATE/---01-bug-report.yml
vendored
2
.github/ISSUE_TEMPLATE/---01-bug-report.yml
vendored
|
@ -10,7 +10,7 @@ body:
|
|||
Thank you for taking the time to file a bug report! Please fill out this form as completely as possible.
|
||||
|
||||
✅ I am using the **latest version of Astro** and all plugins.
|
||||
✅ I am using a version of Node that supports ESM (`v14.18.0+`, or `v16.12.0+`)
|
||||
✅ I am using a version of Node that Astro supports (`>=18.14.1`)
|
||||
- type: input
|
||||
id: astro-version
|
||||
attributes:
|
||||
|
|
2
.github/workflows/check.yml
vendored
2
.github/workflows/check.yml
vendored
|
@ -34,7 +34,7 @@ jobs:
|
|||
- name: Setup Node
|
||||
uses: actions/setup-node@v3
|
||||
with:
|
||||
node-version: 16
|
||||
node-version: 18
|
||||
cache: "pnpm"
|
||||
|
||||
- name: Install dependencies
|
||||
|
|
14
.github/workflows/ci.yml
vendored
14
.github/workflows/ci.yml
vendored
|
@ -38,7 +38,7 @@ jobs:
|
|||
strategy:
|
||||
matrix:
|
||||
OS: [ubuntu-latest, windows-latest]
|
||||
NODE_VERSION: [16]
|
||||
NODE_VERSION: [18]
|
||||
fail-fast: true
|
||||
steps:
|
||||
# Disable crlf so all OS can share the same Turbo cache
|
||||
|
@ -85,7 +85,7 @@ jobs:
|
|||
- name: Setup Node
|
||||
uses: actions/setup-node@v3
|
||||
with:
|
||||
node-version: 16
|
||||
node-version: 18
|
||||
cache: "pnpm"
|
||||
|
||||
- name: Install dependencies
|
||||
|
@ -108,12 +108,12 @@ jobs:
|
|||
strategy:
|
||||
matrix:
|
||||
OS: [ubuntu-latest]
|
||||
NODE_VERSION: [16, 18]
|
||||
NODE_VERSION: [18, 20]
|
||||
include:
|
||||
- os: macos-latest
|
||||
NODE_VERSION: 16
|
||||
NODE_VERSION: 18
|
||||
- os: windows-latest
|
||||
NODE_VERSION: 16
|
||||
NODE_VERSION: 18
|
||||
fail-fast: false
|
||||
env:
|
||||
NODE_VERSION: ${{ matrix.NODE_VERSION }}
|
||||
|
@ -155,7 +155,7 @@ jobs:
|
|||
strategy:
|
||||
matrix:
|
||||
OS: [ubuntu-latest, windows-latest]
|
||||
NODE_VERSION: [16]
|
||||
NODE_VERSION: [18]
|
||||
fail-fast: false
|
||||
env:
|
||||
NODE_VERSION: ${{ matrix.NODE_VERSION }}
|
||||
|
@ -192,7 +192,7 @@ jobs:
|
|||
strategy:
|
||||
matrix:
|
||||
OS: [ubuntu-latest, windows-latest]
|
||||
NODE_VERSION: [16]
|
||||
NODE_VERSION: [18]
|
||||
env:
|
||||
NODE_VERSION: ${{ matrix.NODE_VERSION }}
|
||||
steps:
|
||||
|
|
2
.github/workflows/main.yml
vendored
2
.github/workflows/main.yml
vendored
|
@ -38,7 +38,7 @@ jobs:
|
|||
- name: Setup Node
|
||||
uses: actions/setup-node@v3
|
||||
with:
|
||||
node-version: 16
|
||||
node-version: 18
|
||||
cache: "pnpm"
|
||||
|
||||
- name: Install dependencies
|
||||
|
|
2
.github/workflows/release.yml
vendored
2
.github/workflows/release.yml
vendored
|
@ -30,7 +30,7 @@ jobs:
|
|||
- name: Setup Node
|
||||
uses: actions/setup-node@v3
|
||||
with:
|
||||
node-version: 16
|
||||
node-version: 18
|
||||
cache: "pnpm"
|
||||
|
||||
- name: Install dependencies
|
||||
|
|
2
.github/workflows/scripts.yml
vendored
2
.github/workflows/scripts.yml
vendored
|
@ -37,7 +37,7 @@ jobs:
|
|||
- name: Setup Node
|
||||
uses: actions/setup-node@v3
|
||||
with:
|
||||
node-version: 16
|
||||
node-version: 18
|
||||
cache: "pnpm"
|
||||
|
||||
- name: Install dependencies
|
||||
|
|
2
.github/workflows/snapshot-release.yml
vendored
2
.github/workflows/snapshot-release.yml
vendored
|
@ -58,7 +58,7 @@ jobs:
|
|||
- name: Setup Node
|
||||
uses: actions/setup-node@v3
|
||||
with:
|
||||
node-version: 16
|
||||
node-version: 18
|
||||
registry-url: "https://registry.npmjs.org"
|
||||
cache: "pnpm"
|
||||
|
||||
|
|
2
.nvmrc
2
.nvmrc
|
@ -1 +1 @@
|
|||
16.19.0
|
||||
18.14.1
|
||||
|
|
|
@ -10,7 +10,7 @@ We welcome contributions of any size and skill level. As an open source project,
|
|||
### Prerequisites
|
||||
|
||||
```shell
|
||||
node: "^>=16.12.0"
|
||||
node: "^>=18.14.1"
|
||||
pnpm: "^8.6.2"
|
||||
# otherwise, your build will fail
|
||||
```
|
||||
|
|
|
@ -3,8 +3,8 @@
|
|||
"include": ["src"],
|
||||
"compilerOptions": {
|
||||
"allowJs": true,
|
||||
"module": "ES2020",
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2020"
|
||||
"target": "ES2022"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -39,7 +39,7 @@
|
|||
"packages/*"
|
||||
],
|
||||
"engines": {
|
||||
"node": ">=16.12.0",
|
||||
"node": ">=18.14.1",
|
||||
"pnpm": ">=8.6.2"
|
||||
},
|
||||
"packageManager": "pnpm@8.6.2",
|
||||
|
@ -82,7 +82,7 @@
|
|||
"@types/node": "^18.16.18",
|
||||
"@typescript-eslint/eslint-plugin": "6.0.0",
|
||||
"@typescript-eslint/parser": "6.0.0",
|
||||
"esbuild": "^0.17.19",
|
||||
"esbuild": "^0.18.16",
|
||||
"eslint": "^8.43.0",
|
||||
"eslint-config-prettier": "^8.8.0",
|
||||
"eslint-plugin-no-only-tests": "^2.6.0",
|
||||
|
@ -93,6 +93,6 @@
|
|||
"prettier-plugin-astro": "^0.10.0",
|
||||
"tiny-glob": "^0.2.9",
|
||||
"turbo": "^1.10.3",
|
||||
"typescript": "~5.0.2"
|
||||
"typescript": "~5.1.6"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -14,7 +14,7 @@
|
|||
"homepage": "https://docs.astro.build/en/reference/api-reference/#prism-",
|
||||
"main": "dist/index.js",
|
||||
"scripts": {
|
||||
"build": "astro-scripts build \"src/**/*.ts\" && tsc",
|
||||
"build": "astro-scripts build \"src/**/*.ts\" && tsc -p ./tsconfig.json",
|
||||
"build:ci": "astro-scripts build \"src/**/*.ts\"",
|
||||
"dev": "astro-scripts dev \"src/**/*.ts\""
|
||||
},
|
||||
|
@ -39,6 +39,6 @@
|
|||
"astro-scripts": "workspace:*"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=16.12.0"
|
||||
"node": ">=18.14.1"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
"include": ["src"],
|
||||
"compilerOptions": {
|
||||
"allowJs": true,
|
||||
"target": "ES2021",
|
||||
"target": "ES2022",
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist"
|
||||
}
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021",
|
||||
"target": "ES2022",
|
||||
"strictNullChecks": true
|
||||
}
|
||||
}
|
||||
|
|
|
@ -13,8 +13,8 @@ const CI_INSTRUCTIONS = {
|
|||
};
|
||||
|
||||
// Hardcode supported Node.js version so we don't have to read differently in CJS & ESM.
|
||||
const engines = '>=16.12.0';
|
||||
const skipSemverCheckIfAbove = 16;
|
||||
const engines = '>=18.14.1';
|
||||
const skipSemverCheckIfAbove = 19;
|
||||
|
||||
/** `astro *` */
|
||||
async function main() {
|
||||
|
|
|
@ -141,8 +141,8 @@
|
|||
"devalue": "^4.3.2",
|
||||
"diff": "^5.1.0",
|
||||
"es-module-lexer": "^1.3.0",
|
||||
"esbuild": "^0.17.19",
|
||||
"estree-walker": "3.0.0",
|
||||
"esbuild": "^0.18.16",
|
||||
"estree-walker": "^3.0.3",
|
||||
"execa": "^6.1.0",
|
||||
"fast-glob": "^3.2.12",
|
||||
"github-slugger": "^2.0.0",
|
||||
|
@ -224,7 +224,7 @@
|
|||
}
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=16.12.0",
|
||||
"node": ">=18.14.1",
|
||||
"npm": ">=6.14.0"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import type { Node as ESTreeNode } from 'estree-walker';
|
||||
import type { ModuleInfo, PluginContext } from 'rollup';
|
||||
import type { Plugin as VitePlugin } from 'vite';
|
||||
import type { PluginMetadata as AstroPluginMetadata } from '../../../vite-plugin-astro/types';
|
||||
|
@ -36,7 +37,7 @@ async function doesParentImportChild(
|
|||
|
||||
const imports: Array<ImportDeclaration> = [];
|
||||
const exports: Array<ExportNamedDeclaration | ExportDefaultDeclaration> = [];
|
||||
walk(parentInfo.ast, {
|
||||
walk(parentInfo.ast as ESTreeNode, {
|
||||
enter(node) {
|
||||
if (node.type === 'ImportDeclaration') {
|
||||
imports.push(node as ImportDeclaration);
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
import { parse } from 'acorn';
|
||||
import type { Node as ESTreeNode } from 'estree-walker';
|
||||
import { walk } from 'estree-walker';
|
||||
import MagicString from 'magic-string';
|
||||
import type { Plugin } from 'vite';
|
||||
|
@ -28,7 +29,7 @@ export default function astro(): Plugin {
|
|||
sourceType: 'module',
|
||||
});
|
||||
|
||||
walk(ast, {
|
||||
walk(ast as ESTreeNode, {
|
||||
enter(node: any) {
|
||||
// Transform `Astro.glob("./pages/*.astro")` to `Astro.glob(import.meta.glob("./pages/*.astro"), () => "./pages/*.astro")`
|
||||
// Also handle for `Astro2.glob()`
|
||||
|
|
|
@ -6,7 +6,7 @@
|
|||
"declarationDir": "./dist",
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021",
|
||||
"target": "ES2022",
|
||||
"jsx": "preserve",
|
||||
"types": ["@types/dom-view-transitions", "network-information-types"]
|
||||
}
|
||||
|
|
|
@ -47,6 +47,6 @@
|
|||
"strip-json-comments": "^5.0.0"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=16.12.0"
|
||||
"node": ">=18.14.1"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
"allowJs": true,
|
||||
"emitDeclarationOnly": false,
|
||||
"noEmit": true,
|
||||
"target": "ES2021",
|
||||
"target": "ES2022",
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"declarationDir": "./dist/types"
|
||||
|
|
|
@ -5,6 +5,6 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021"
|
||||
"target": "ES2022"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -41,7 +41,7 @@
|
|||
"dependencies": {
|
||||
"@astrojs/underscore-redirects": "^0.2.0",
|
||||
"@cloudflare/workers-types": "^4.20230518.0",
|
||||
"esbuild": "^0.17.19",
|
||||
"esbuild": "^0.18.16",
|
||||
"tiny-glob": "^0.2.9"
|
||||
},
|
||||
"peerDependencies": {
|
||||
|
|
|
@ -5,6 +5,6 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021"
|
||||
"target": "ES2022"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,6 +5,8 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021"
|
||||
"target": "ES2022",
|
||||
// TODO: Due to the shim for Deno imports in `server.ts`, we can't use moduleResolution: 'bundler' or the types get very weird.
|
||||
"moduleResolution": "Node"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021",
|
||||
"target": "ES2022",
|
||||
"typeRoots": ["node_modules/@types", "node_modules/@netlify"]
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,6 +5,6 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021"
|
||||
"target": "ES2022"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -66,7 +66,7 @@
|
|||
"@astrojs/internal-helpers": "^0.1.2",
|
||||
"@astrojs/prism": "^2.1.2",
|
||||
"@markdoc/markdoc": "^0.3.0",
|
||||
"esbuild": "^0.17.19",
|
||||
"esbuild": "^0.18.16",
|
||||
"github-slugger": "^2.0.0",
|
||||
"gray-matter": "^4.0.3",
|
||||
"htmlparser2": "^9.0.0",
|
||||
|
@ -93,6 +93,6 @@
|
|||
"vite": "^4.4.6"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=16.12.0"
|
||||
"node": ">=18.14.1"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -3,14 +3,14 @@ import Markdoc from '@markdoc/markdoc';
|
|||
import type { AstroConfig, ContentEntryType } from 'astro';
|
||||
import matter from 'gray-matter';
|
||||
import fs from 'node:fs';
|
||||
import path from 'node:path';
|
||||
import { fileURLToPath } from 'node:url';
|
||||
import type * as rollup from 'rollup';
|
||||
import type { ErrorPayload as ViteErrorPayload } from 'vite';
|
||||
import type { ComponentConfig } from './config.js';
|
||||
import { MarkdocError, isComponentConfig, isValidUrl, prependForwardSlash } from './utils.js';
|
||||
// @ts-expect-error Cannot get the types here without `moduleResolution: 'nodenext'`
|
||||
import { emitESMImage } from 'astro/assets/utils';
|
||||
import path from 'node:path';
|
||||
import type * as rollup from 'rollup';
|
||||
import { htmlTokenTransform } from './html/transform/html-token-transform.js';
|
||||
import type { MarkdocConfigResult } from './load-config.js';
|
||||
import type { MarkdocIntegrationOptions } from './options.js';
|
||||
|
@ -198,8 +198,7 @@ async function emitOptimizedImages(
|
|||
const src = await emitESMImage(
|
||||
resolved.id,
|
||||
ctx.pluginContext.meta.watchMode,
|
||||
ctx.pluginContext.emitFile,
|
||||
{ config: ctx.astroConfig }
|
||||
ctx.pluginContext.emitFile
|
||||
);
|
||||
node.attributes.__optimizedSrc = src;
|
||||
} else {
|
||||
|
|
|
@ -1,8 +1,5 @@
|
|||
// leave space, so organize imports doesn't mess up comments
|
||||
// @ts-expect-error Cannot find module 'astro/runtime/server/index.js' or its corresponding type declarations.
|
||||
import { unescapeHTML } from 'astro/runtime/server/index.js';
|
||||
|
||||
import { runHighlighterWithAstro } from '@astrojs/prism/dist/highlighter';
|
||||
import { unescapeHTML } from 'astro/runtime/server/index.js';
|
||||
import { Markdoc, type AstroMarkdocConfig } from '../config.js';
|
||||
|
||||
export default function prism(): AstroMarkdocConfig {
|
||||
|
@ -16,7 +13,7 @@ export default function prism(): AstroMarkdocConfig {
|
|||
// Use `unescapeHTML` to return `HTMLString` for Astro renderer to inline as HTML
|
||||
return unescapeHTML(
|
||||
`<pre class="${classLanguage}"><code class="${classLanguage}">${html}</code></pre>`
|
||||
);
|
||||
) as any;
|
||||
},
|
||||
},
|
||||
},
|
||||
|
|
|
@ -1,9 +1,6 @@
|
|||
// leave space, so organize imports doesn't mess up comments
|
||||
// @ts-expect-error Cannot find module 'astro/runtime/server/index.js' or its corresponding type declarations.
|
||||
import { unescapeHTML } from 'astro/runtime/server/index.js';
|
||||
|
||||
import Markdoc from '@markdoc/markdoc';
|
||||
import type { ShikiConfig } from 'astro';
|
||||
import { unescapeHTML } from 'astro/runtime/server/index.js';
|
||||
import type * as shikiTypes from 'shiki';
|
||||
import { getHighlighter } from 'shiki';
|
||||
import type { AstroMarkdocConfig } from '../config.js';
|
||||
|
@ -123,7 +120,7 @@ export default async function shiki({
|
|||
}
|
||||
|
||||
// Use `unescapeHTML` to return `HTMLString` for Astro renderer to inline as HTML
|
||||
return unescapeHTML(html);
|
||||
return unescapeHTML(html) as any;
|
||||
},
|
||||
},
|
||||
},
|
||||
|
|
|
@ -6,7 +6,6 @@ import Markdoc, {
|
|||
type RenderableTreeNode,
|
||||
} from '@markdoc/markdoc';
|
||||
import type { AstroInstance } from 'astro';
|
||||
// @ts-expect-error Cannot find module 'astro/runtime/server/index.js' or its corresponding type declarations.
|
||||
import { createComponent, renderComponent } from 'astro/runtime/server/index.js';
|
||||
import type { AstroMarkdocConfig } from './config.js';
|
||||
import { setupHeadingConfig } from './heading-ids.js';
|
||||
|
@ -204,7 +203,7 @@ export function createContentComponent(
|
|||
return renderComponent(result, Renderer.name, Renderer, { stringifiedAst, config }, {});
|
||||
},
|
||||
propagation: 'self',
|
||||
});
|
||||
} as any);
|
||||
}
|
||||
|
||||
// statically define a partial MarkdocConfig which registers the required "html-tag" Markdoc tag when the "allowHTML" feature is enabled
|
||||
|
|
|
@ -3,8 +3,8 @@
|
|||
"include": ["src"],
|
||||
"compilerOptions": {
|
||||
"allowJs": true,
|
||||
"module": "ES2020",
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2020"
|
||||
"target": "ES2022"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -78,6 +78,6 @@
|
|||
"vite": "^4.4.6"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=16.12.0"
|
||||
"node": ">=18.14.1"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
import type { MarkdownVFile } from '@astrojs/markdown-remark';
|
||||
import { type Image, type Parent } from 'mdast';
|
||||
import type { Image, Parent } from 'mdast';
|
||||
import type { MdxJsxFlowElement, MdxjsEsm } from 'mdast-util-mdx';
|
||||
import { visit } from 'unist-util-visit';
|
||||
import { jsToTreeNode } from './utils.js';
|
||||
|
|
|
@ -5,6 +5,6 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021"
|
||||
"target": "ES2022"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -41,7 +41,7 @@
|
|||
"@astrojs/underscore-redirects": "^0.2.0",
|
||||
"@astrojs/webapi": "^2.2.0",
|
||||
"@netlify/functions": "^1.6.0",
|
||||
"esbuild": "^0.15.18"
|
||||
"esbuild": "^0.18.16"
|
||||
},
|
||||
"peerDependencies": {
|
||||
"astro": "workspace:^2.10.3"
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021",
|
||||
"target": "ES2022",
|
||||
"typeRoots": ["node_modules/@types", "node_modules/@netlify"],
|
||||
"allowImportingTsExtensions": true
|
||||
}
|
||||
|
|
|
@ -5,6 +5,6 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021"
|
||||
"target": "ES2022"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,6 +5,6 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021"
|
||||
"target": "ES2022"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -50,6 +50,6 @@
|
|||
"preact": "^10.6.5"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=16.12.0"
|
||||
"node": ">=18.14.1"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,6 +5,6 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021"
|
||||
"target": "ES2022"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,6 +5,6 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021"
|
||||
"target": "ES2022"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -62,6 +62,6 @@
|
|||
"react-dom": "^17.0.2 || ^18.0.0"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=16.12.0"
|
||||
"node": ">=18.14.1"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,6 +5,6 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021"
|
||||
"target": "ES2022"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,6 +5,6 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021"
|
||||
"target": "ES2022"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -47,6 +47,6 @@
|
|||
"solid-js": "^1.4.3"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=16.12.0"
|
||||
"node": ">=18.14.1"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,6 +5,6 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021"
|
||||
"target": "ES2022"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -52,6 +52,6 @@
|
|||
"svelte": "^3.55.0 || ^4.0.0"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=16.12.0"
|
||||
"node": ">=18.14.1"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,6 +5,6 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021"
|
||||
"target": "ES2022"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,6 +5,6 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021"
|
||||
"target": "ES2022"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,6 +5,6 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021"
|
||||
"target": "ES2022"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -55,7 +55,7 @@
|
|||
"@astrojs/webapi": "^2.2.0",
|
||||
"@vercel/analytics": "^0.1.11",
|
||||
"@vercel/nft": "^0.22.6",
|
||||
"esbuild": "^0.17.19",
|
||||
"esbuild": "^0.18.16",
|
||||
"fast-glob": "^3.2.12",
|
||||
"set-cookie-parser": "^2.6.0",
|
||||
"web-vitals": "^3.3.2"
|
||||
|
|
|
@ -1,5 +1,4 @@
|
|||
import type { LocalImageService } from 'astro';
|
||||
// @ts-expect-error
|
||||
import squooshService from 'astro/assets/services/squoosh';
|
||||
import { sharedValidateOptions } from './shared';
|
||||
|
||||
|
@ -14,7 +13,9 @@ const service: LocalImageService = {
|
|||
props.width = inputtedWidth;
|
||||
}
|
||||
|
||||
return squooshService.getHTMLAttributes(props, serviceOptions);
|
||||
return squooshService.getHTMLAttributes
|
||||
? squooshService.getHTMLAttributes(props, serviceOptions)
|
||||
: {};
|
||||
},
|
||||
getURL(options) {
|
||||
const fileSrc = typeof options.src === 'string' ? options.src : options.src.src;
|
||||
|
|
|
@ -5,6 +5,6 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021"
|
||||
"target": "ES2022"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -60,6 +60,6 @@
|
|||
"vue": "^3.2.30"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=16.12.0"
|
||||
"node": ">=18.14.1"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,6 +5,6 @@
|
|||
"allowJs": true,
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"target": "ES2021"
|
||||
"target": "ES2022"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
"include": ["src"],
|
||||
"compilerOptions": {
|
||||
"allowJs": true,
|
||||
"target": "ES2021",
|
||||
"target": "ES2022",
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist"
|
||||
}
|
||||
|
|
|
@ -13,7 +13,10 @@
|
|||
"bugs": "https://github.com/withastro/astro/issues",
|
||||
"homepage": "https://astro.build",
|
||||
"exports": {
|
||||
".": "./dist/index.js",
|
||||
".": {
|
||||
"types": "./dist/types/index.d.ts",
|
||||
"default": "./dist/index.js"
|
||||
},
|
||||
"./package.json": "./package.json"
|
||||
},
|
||||
"scripts": {
|
||||
|
@ -45,6 +48,6 @@
|
|||
"mocha": "^9.2.2"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=16.12.0"
|
||||
"node": ">=18.14.1"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
import dget from 'dlv';
|
||||
// @ts-expect-error `dset` is mispackaged: https://publint.dev/dset@3.1.2
|
||||
import { dset } from 'dset';
|
||||
import fs from 'node:fs';
|
||||
import os from 'node:os';
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
"include": ["src"],
|
||||
"compilerOptions": {
|
||||
"allowJs": true,
|
||||
"target": "ES2021",
|
||||
"target": "ES2022",
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist",
|
||||
"declarationDir": "./dist/types"
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
"include": ["src"],
|
||||
"compilerOptions": {
|
||||
"allowJs": true,
|
||||
"target": "ES2021",
|
||||
"target": "ES2022",
|
||||
"module": "ES2022",
|
||||
"outDir": "./dist"
|
||||
}
|
||||
|
|
|
@ -67,7 +67,7 @@
|
|||
"mocha": "^9.2.2",
|
||||
"rollup": "^2.79.1",
|
||||
"tslib": "^2.5.3",
|
||||
"typescript": "~5.0.2",
|
||||
"typescript": "~5.1.6",
|
||||
"urlpattern-polyfill": "^1.0.0-rc5"
|
||||
},
|
||||
"scripts": {
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
"include": ["src/*"],
|
||||
"exclude": ["node_modules"],
|
||||
"compilerOptions": {
|
||||
"target": "ES2021",
|
||||
"target": "ES2022",
|
||||
"module": "ES2022",
|
||||
"moduleResolution": "node",
|
||||
"esModuleInterop": true,
|
||||
|
|
|
@ -12,7 +12,7 @@ const defaultConfig = {
|
|||
minify: false,
|
||||
format: 'esm',
|
||||
platform: 'node',
|
||||
target: 'node16',
|
||||
target: 'node18',
|
||||
sourcemap: false,
|
||||
sourcesContent: false,
|
||||
};
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
"dependencies": {
|
||||
"@astrojs/webapi": "workspace:*",
|
||||
"arg": "^5.0.2",
|
||||
"esbuild": "^0.17.19",
|
||||
"esbuild": "^0.18.16",
|
||||
"globby": "^12.2.0",
|
||||
"kleur": "^4.1.4",
|
||||
"p-limit": "^4.0.0",
|
||||
|
|
|
@ -3,7 +3,8 @@
|
|||
"declaration": true,
|
||||
"emitDeclarationOnly": true,
|
||||
"strict": true,
|
||||
"moduleResolution": "node",
|
||||
// All packages are built with ESBuild, so we can use `moduleResolution: 'bundler'`
|
||||
"moduleResolution": "Bundler",
|
||||
"esModuleInterop": true,
|
||||
"skipLibCheck": true,
|
||||
"verbatimModuleSyntax": true
|
||||
|
|
Loading…
Reference in a new issue