Export defineConfig helper (#2803)

* feat: add astro/config entrypoint

* chore: update examples to use `defineConfig` util

* chore: prettier fix

* chore: add changeset
This commit is contained in:
Nate Moore 2022-03-15 15:27:17 -05:00 committed by GitHub
parent 2d95541b52
commit 2b76ee8d75
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
29 changed files with 101 additions and 205 deletions

View file

@ -0,0 +1,15 @@
---
'astro': patch
---
Add an `astro/config` entrypoint with a `defineConfig` utility.
Config files can now be easily benefit from Intellisense using the following approach:
```js
import { defineConfig } from 'astro/config';
export default defineConfig({
renderers: []
})
```

View file

@ -1,13 +1,7 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled! // https://astro.build/config
// VSCode and other TypeScript-enabled text editors will provide auto-completion, export default defineConfig({
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
// @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({
// Enable the Preact renderer to support Preact JSX components. // Enable the Preact renderer to support Preact JSX components.
renderers: ['@astrojs/renderer-preact'], renderers: ['@astrojs/renderer-preact'],
}); });

View file

@ -1,14 +1,7 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled! // https://astro.build/config
// VSCode and other TypeScript-enabled text editors will provide auto-completion, export default defineConfig({
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
// @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({
// Enable the Preact renderer to support Preact JSX components.
renderers: ['@astrojs/renderer-preact'], renderers: ['@astrojs/renderer-preact'],
buildOptions: { buildOptions: {
site: 'https://example.com/', site: 'https://example.com/',

View file

@ -1,13 +1,7 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled! // https://astro.build/config
// VSCode and other TypeScript-enabled text editors will provide auto-completion, export default defineConfig({
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
// @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({
// Comment out "renderers: []" to enable Astro's default component support. // Comment out "renderers: []" to enable Astro's default component support.
renderers: [], renderers: [],
}); });

View file

@ -1,13 +1,7 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled! // https://astro.build/config
// VSCode and other TypeScript-enabled text editors will provide auto-completion, export default defineConfig({
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
// @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({
renderers: [ renderers: [
// Enable the Preact renderer to support Preact JSX components. // Enable the Preact renderer to support Preact JSX components.
'@astrojs/renderer-preact', '@astrojs/renderer-preact',

View file

@ -1,8 +1,6 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @ts-check // https://astro.build/config
export default /** @type {import('astro').AstroUserConfig} */ ({ export default defineConfig({
// Comment out "renderers: []" to enable Astro's default component support.
renderers: [], renderers: [],
}); });

View file

@ -1,13 +1,7 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled! // https://astro.build/config
// VSCode and other TypeScript-enabled text editors will provide auto-completion, export default defineConfig({
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
// @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({
// No renderers are needed for AlpineJS support, just use Astro components! // No renderers are needed for AlpineJS support, just use Astro components!
renderers: [], renderers: [],
}); });

View file

@ -1,13 +1,7 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled! // https://astro.build/config
// VSCode and other TypeScript-enabled text editors will provide auto-completion, export default defineConfig({
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
// @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({
// Enable the lit renderer to support LitHTML components and templates. // Enable the lit renderer to support LitHTML components and templates.
renderers: ['@astrojs/renderer-lit'], renderers: ['@astrojs/renderer-lit'],
}); });

View file

@ -1,13 +1,7 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled! // https://astro.build/config
// VSCode and other TypeScript-enabled text editors will provide auto-completion, export default defineConfig({
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
// @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({
// Enable many renderers to support all different kinds of components. // Enable many renderers to support all different kinds of components.
renderers: ['@astrojs/renderer-preact', '@astrojs/renderer-react', '@astrojs/renderer-svelte', '@astrojs/renderer-vue', '@astrojs/renderer-solid'], renderers: ['@astrojs/renderer-preact', '@astrojs/renderer-react', '@astrojs/renderer-svelte', '@astrojs/renderer-vue', '@astrojs/renderer-solid'],
}); });

View file

@ -1,13 +1,7 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled! // https://astro.build/config
// VSCode and other TypeScript-enabled text editors will provide auto-completion, export default defineConfig({
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
// @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({
// Enable the Preact renderer to support Preact JSX components. // Enable the Preact renderer to support Preact JSX components.
renderers: ['@astrojs/renderer-preact'], renderers: ['@astrojs/renderer-preact'],
}); });

View file

@ -1,13 +1,7 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled! // https://astro.build/config
// VSCode and other TypeScript-enabled text editors will provide auto-completion, export default defineConfig({
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
// @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({
// Enable the React renderer to support React JSX components. // Enable the React renderer to support React JSX components.
renderers: ['@astrojs/renderer-react'], renderers: ['@astrojs/renderer-react'],
}); });

View file

@ -1,13 +1,7 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled! // https://astro.build/config
// VSCode and other TypeScript-enabled text editors will provide auto-completion, export default defineConfig({
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
// @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({
// Enable the Solid renderer to support Solid JSX components. // Enable the Solid renderer to support Solid JSX components.
renderers: ['@astrojs/renderer-solid'], renderers: ['@astrojs/renderer-solid'],
}); });

View file

@ -1,13 +1,7 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled! // https://astro.build/config
// VSCode and other TypeScript-enabled text editors will provide auto-completion, export default defineConfig({
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
// @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({
// Enable the Svelte renderer to support Svelte components. // Enable the Svelte renderer to support Svelte components.
renderers: ['@astrojs/renderer-svelte'], renderers: ['@astrojs/renderer-svelte'],
}); });

View file

@ -1,13 +1,7 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled! // https://astro.build/config
// VSCode and other TypeScript-enabled text editors will provide auto-completion, export default defineConfig({
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
// @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({
// Enable the Vue renderer to support Vue components. // Enable the Vue renderer to support Vue components.
renderers: ['@astrojs/renderer-vue'], renderers: ['@astrojs/renderer-vue'],
}); });

View file

@ -1,8 +1,7 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @ts-check // https://astro.build/config
export default /** @type {import('astro').AstroUserConfig} */ ({ export default defineConfig({
// Comment out "renderers: []" to enable Astro's default component support. // Comment out "renderers: []" to enable Astro's default component support.
renderers: [], renderers: [],
}); });

View file

@ -1,8 +1,7 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @ts-check // https://astro.build/config
export default /** @type {import('astro').AstroUserConfig} */ ({ export default defineConfig({
// Comment out "renderers: []" to enable Astro's default component support. // Comment out "renderers: []" to enable Astro's default component support.
renderers: [], renderers: [],
}); });

View file

@ -1,13 +1,7 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled! // https://astro.build/config
// VSCode and other TypeScript-enabled text editors will provide auto-completion, export default defineConfig({
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
// @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({
// Enable the Preact renderer to support Preact JSX components. // Enable the Preact renderer to support Preact JSX components.
renderers: ['@astrojs/renderer-preact'], renderers: ['@astrojs/renderer-preact'],
}); });

View file

@ -1,6 +1,6 @@
// @ts-check // @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({ export default defineConfig({
renderers: ['@astrojs/renderer-svelte'], renderers: ['@astrojs/renderer-svelte'],
vite: { vite: {
server: { server: {

View file

@ -1,13 +1,7 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled! // https://astro.build/config
// VSCode and other TypeScript-enabled text editors will provide auto-completion, export default defineConfig({
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
// @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({
// Set "renderers" to "[]" to disable all default, builtin component support. // Set "renderers" to "[]" to disable all default, builtin component support.
renderers: [], renderers: [],
}); });

View file

@ -1,13 +1,7 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled! // https://astro.build/config
// VSCode and other TypeScript-enabled text editors will provide auto-completion, export default defineConfig({
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
// @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({
// Comment out "renderers: []" to enable Astro's default component support. // Comment out "renderers: []" to enable Astro's default component support.
buildOptions: { buildOptions: {
site: 'http://example.com/blog', site: 'http://example.com/blog',

View file

@ -1,15 +1,9 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled!
// VSCode and other TypeScript-enabled text editors will provide auto-completion,
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
import astroRemark from '@astrojs/markdown-remark'; import astroRemark from '@astrojs/markdown-remark';
import addClasses from './add-classes.mjs'; import addClasses from './add-classes.mjs';
// @ts-check // https://astro.build/config
export default /** @type {import('astro').AstroUserConfig} */ ({ export default defineConfig({
// Enable Custom Markdown options, plugins, etc. // Enable Custom Markdown options, plugins, etc.
renderers: [], renderers: [],
markdownOptions: { markdownOptions: {

View file

@ -1,14 +1,8 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled!
// VSCode and other TypeScript-enabled text editors will provide auto-completion,
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
import astroRemark from '@astrojs/markdown-remark'; import astroRemark from '@astrojs/markdown-remark';
// @ts-check // https://astro.build/config
export default /** @type {import('astro').AstroUserConfig} */ ({ export default defineConfig({
// Enable Custom Markdown options, plugins, etc. // Enable Custom Markdown options, plugins, etc.
renderers: [], renderers: [],
markdownOptions: { markdownOptions: {

View file

@ -1,12 +1,6 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled! // https://astro.build/config
// VSCode and other TypeScript-enabled text editors will provide auto-completion, export default defineConfig({
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
// @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({
renderers: ['@astrojs/renderer-preact', '@astrojs/renderer-react', '@astrojs/renderer-svelte', '@astrojs/renderer-vue'], renderers: ['@astrojs/renderer-preact', '@astrojs/renderer-react', '@astrojs/renderer-svelte', '@astrojs/renderer-vue'],
}); });

View file

@ -1,13 +1,7 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled! // https://astro.build/config
// VSCode and other TypeScript-enabled text editors will provide auto-completion, export default defineConfig({
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
// @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({
// Enable many renderers to support all different kinds of components. // Enable many renderers to support all different kinds of components.
renderers: ['@astrojs/renderer-preact', '@astrojs/renderer-react', '@astrojs/renderer-svelte', '@astrojs/renderer-vue', '@astrojs/renderer-solid'], renderers: ['@astrojs/renderer-preact', '@astrojs/renderer-react', '@astrojs/renderer-svelte', '@astrojs/renderer-vue', '@astrojs/renderer-solid'],
}); });

View file

@ -1,13 +1,7 @@
// Full Astro Configuration API Documentation: import { defineConfig } from 'astro/config';
// https://docs.astro.build/reference/configuration-reference
// @type-check enabled! // https://astro.build/config
// VSCode and other TypeScript-enabled text editors will provide auto-completion, export default defineConfig({
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
// @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({
// Enable the Preact renderer to support Preact JSX components. // Enable the Preact renderer to support Preact JSX components.
renderers: ['@astrojs/renderer-preact'], renderers: ['@astrojs/renderer-preact'],
}); });

View file

@ -1,15 +1,8 @@
import { defineConfig } from 'astro/config';
import { VitePWA } from 'vite-plugin-pwa'; import { VitePWA } from 'vite-plugin-pwa';
// Full Astro Configuration API Documentation: // https://astro.build/config
// https://docs.astro.build/reference/configuration-reference export default defineConfig({
// @type-check enabled!
// VSCode and other TypeScript-enabled text editors will provide auto-completion,
// helpful tooltips, and warnings if your exported object is invalid.
// You can disable this by removing "@ts-check" and `@type` comments below.
// @ts-check
export default /** @type {import('astro').AstroUserConfig} */ ({
renderers: [], renderers: [],
vite: { vite: {
plugins: [VitePWA()], plugins: [VitePWA()],

7
packages/astro/config.d.ts vendored Normal file
View file

@ -0,0 +1,7 @@
type AstroUserConfig = import('./dist/types/@types/astro').AstroUserConfig;
/**
* See the full Astro Configuration API Documentation
* https://astro.build/config
*/
export function defineConfig(config: AstroUserConfig): AstroUserConfig;

View file

@ -0,0 +1,3 @@
export function defineConfig(config) {
return config;
}

View file

@ -16,6 +16,7 @@
"exports": { "exports": {
".": "./astro.js", ".": "./astro.js",
"./env": "./env.d.ts", "./env": "./env.d.ts",
"./config": "./config.mjs",
"./internal": "./internal.js", "./internal": "./internal.js",
"./app/node": "./dist/core/app/node.js", "./app/node": "./dist/core/app/node.js",
"./client/*": "./dist/runtime/client/*", "./client/*": "./dist/runtime/client/*",
@ -45,6 +46,8 @@
"components", "components",
"dist", "dist",
"astro.js", "astro.js",
"config.d.ts",
"config.mjs",
"env.d.ts", "env.d.ts",
"README.md", "README.md",
"vendor" "vendor"