remove details tags from integration READMEs (#4198)

This commit is contained in:
Sarah Rainsberger 2022-08-08 14:07:38 -03:00 committed by GitHub
parent 2c71a99202
commit 9894b3dcde
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
9 changed files with 165 additions and 263 deletions

View file

@ -77,55 +77,51 @@ export default defineConfig({
}); });
``` ```
<details> ### start
<summary><strong>start</strong></summary>
This adapter automatically starts a server when it is imported. You can turn this off with the `start` option: This adapter automatically starts a server when it is imported. You can turn this off with the `start` option:
```js ```js
import { defineConfig } from 'astro/config'; import { defineConfig } from 'astro/config';
import deno from '@astrojs/deno'; import deno from '@astrojs/deno';
export default defineConfig({ export default defineConfig({
output: 'server', output: 'server',
adapter: deno({ adapter: deno({
start: false start: false
}) })
}); });
``` ```
If you disable this, you need to write your own Deno web server. Import and call `handle` from the generated entry script to render requests: If you disable this, you need to write your own Deno web server. Import and call `handle` from the generated entry script to render requests:
```ts ```ts
import { serve } from "https://deno.land/std@0.132.0/http/server.ts"; import { serve } from "https://deno.land/std@0.132.0/http/server.ts";
import { handle } from './dist/entry.mjs'; import { handle } from './dist/entry.mjs';
serve((req: Request) => { serve((req: Request) => {
// Check the request, maybe do static file handling here. // Check the request, maybe do static file handling here.
return handle(req); return handle(req);
}); });
``` ```
</details>
### port and hostname
<details>
<summary><strong>port</strong> and <strong>hostname</strong></summary> You can set the port (default: `8085`) and hostname (default: `0.0.0.0`) for the deno server to use. If `start` is false, this has no effect; your own server must configure the port and hostname.
You can set the port (default: `8085`) and hostname (default: `0.0.0.0`) for the deno server to use. If `start` is false, this has no effect; your own server must configure the port and hostname. ```js
import { defineConfig } from 'astro/config';
```js import deno from '@astrojs/deno';
import { defineConfig } from 'astro/config';
import deno from '@astrojs/deno'; export default defineConfig({
output: 'server',
export default defineConfig({ adapter: deno({
output: 'server', port: 8081,
adapter: deno({ hostname: 'myhost'
port: 8081, })
hostname: 'myhost' });
})
});
``` ```
</details>
## Examples ## Examples

View file

@ -21,27 +21,25 @@ This integration provides `<Image />` and `<Picture>` components as well as a ba
## Installation ## Installation
<details>
<summary>Quick Install</summary> ### Quick Install
The `astro add` command-line tool automates the installation for you. Run one of the following commands in a new terminal window. (If you aren't sure which package manager you're using, run the first command.) Then, follow the prompts, and type "y" in the terminal (meaning "yes") for each one. The `astro add` command-line tool automates the installation for you. Run one of the following commands in a new terminal window. (If you aren't sure which package manager you're using, run the first command.) Then, follow the prompts, and type "y" in the terminal (meaning "yes") for each one.
```sh ```sh
# Using NPM # Using NPM
npx astro add image npx astro add image
# Using Yarn # Using Yarn
yarn astro add image yarn astro add image
# Using PNPM # Using PNPM
pnpx astro add image pnpx astro add image
``` ```
Then, restart the dev server by typing `CTRL-C` and then `npm run astro dev` in the terminal window that was running Astro. Then, restart the dev server by typing `CTRL-C` and then `npm run astro dev` in the terminal window that was running Astro.
Because this command is new, it might not properly set things up. If that happens, [feel free to log an issue on our GitHub](https://github.com/withastro/astro/issues) and try the manual installation steps below. Because this command is new, it might not properly set things up. If that happens, [feel free to log an issue on our GitHub](https://github.com/withastro/astro/issues) and try the manual installation steps below.
</details>
<details> ### Manual Install
<summary>Manual Install</summary>
First, install the `@astrojs/image` package using your package manager. If you're using npm or aren't sure, run this in the terminal: First, install the `@astrojs/image` package using your package manager. If you're using npm or aren't sure, run this in the terminal:
```sh ```sh
@ -58,10 +56,8 @@ export default {
// ... // ...
integrations: [image()], integrations: [image()],
} }
``` ```
Then, restart the dev server. Then, restart the dev server.
</details>
### Update `tsconfig.json` ### Update `tsconfig.json`
@ -269,10 +265,10 @@ The intergration can be configured to run with a different image service, either
There are currently no other configuration options for the `@astrojs/image` integration. Please [open an issue](https://github.com/withastro/astro/issues/new/choose) if you have a compelling use case to share. There are currently no other configuration options for the `@astrojs/image` integration. Please [open an issue](https://github.com/withastro/astro/issues/new/choose) if you have a compelling use case to share.
<details>
<summary><strong>config.serviceEntryPoint</strong></summary> ### config.serviceEntryPoint
The `serviceEntryPoint` should resolve to the image service installed from NPM. The default entry point is `@astrojs/image/sharp`, which resolves to the entry point exported from this integration's `package.json`. The `serviceEntryPoint` should resolve to the image service installed from NPM. The default entry point is `@astrojs/image/sharp`, which resolves to the entry point exported from this integration's `package.json`.
```js ```js
// astro.config.mjs // astro.config.mjs
@ -285,14 +281,12 @@ export default {
})], })],
} }
``` ```
</details>
## Examples ## Examples
<details> ### Local images
<summary><strong>Local images</strong></summary>
Image files in your project's `src` directory can be imported in frontmatter and passed directly to the `<Image />` component. All other properties are optional and will default to the original image file's properties if not provided. Image files in your project's `src` directory can be imported in frontmatter and passed directly to the `<Image />` component. All other properties are optional and will default to the original image file's properties if not provided.
```astro ```astro
--- ---
@ -315,12 +309,10 @@ import heroImage from '../assets/hero.png';
// image imports can also be inlined directly // image imports can also be inlined directly
<Image src={import('../assets/hero.png')} /> <Image src={import('../assets/hero.png')} />
``` ```
</details>
<details> ### Remote images
<summary><strong>Remote images</strong></summary>
Remote images can be transformed with the `<Image />` component. The `<Image />` component needs to know the final dimensions for the `<img />` element to avoid content layout shifts. For remote images, this means you must either provide `width` and `height`, or one of the dimensions plus the required `aspectRatio`. Remote images can be transformed with the `<Image />` component. The `<Image />` component needs to know the final dimensions for the `<img />` element to avoid content layout shifts. For remote images, this means you must either provide `width` and `height`, or one of the dimensions plus the required `aspectRatio`.
```astro ```astro
--- ---
@ -338,16 +330,14 @@ const imageUrl = 'https://www.google.com/images/branding/googlelogo/2x/googlelog
// cropping to a specific height and aspect ratio and converting to an avif format // cropping to a specific height and aspect ratio and converting to an avif format
<Image src={imageUrl} height={200} aspectRatio="16:9" format="avif" /> <Image src={imageUrl} height={200} aspectRatio="16:9" format="avif" />
``` ```
</details>
<details> ### Responsive pictures</strong></summary>
<summary><strong>Responsive pictures</strong></summary>
The `<Picture />` component can be used to automatically build a `<picture>` with multiple sizes and formats. Check out [MDN](https://developer.mozilla.org/en-US/docs/Learn/HTML/Multimedia_and_embedding/Responsive_images#art_direction) for a deep dive into responsive images and art direction. The `<Picture />` component can be used to automatically build a `<picture>` with multiple sizes and formats. Check out [MDN](https://developer.mozilla.org/en-US/docs/Learn/HTML/Multimedia_and_embedding/Responsive_images#art_direction) for a deep dive into responsive images and art direction.
By default, the picture will include formats for `avif` and `webp` in addition to the image's original format. By default, the picture will include formats for `avif` and `webp` in addition to the image's original format.
For remote images, an `aspectRatio` is required to ensure the correct `height` can be calculated at build time. For remote images, an `aspectRatio` is required to ensure the correct `height` can be calculated at build time.
```astro ```astro
--- ---
@ -367,8 +357,6 @@ const imageUrl = 'https://www.google.com/images/branding/googlelogo/2x/googlelog
<Picture src={import("../assets/hero.png")} widths={[200, 400, 800]} sizes="(max-width: 800px) 100vw, 800px" alt="My hero image" /> <Picture src={import("../assets/hero.png")} widths={[200, 400, 800]} sizes="(max-width: 800px) 100vw, 800px" alt="My hero image" />
``` ```
</details>
## Troubleshooting ## Troubleshooting
- If your installation doesn't seem to be working, make sure to restart the dev server. - If your installation doesn't seem to be working, make sure to restart the dev server.
- If you edit and save a file and don't see your site update accordingly, try refreshing the page. - If you edit and save a file and don't see your site update accordingly, try refreshing the page.

View file

@ -20,33 +20,30 @@ Check out [“What is MDX?”](https://mdxjs.com/docs/what-is-mdx/), a deep-dive
## Installation ## Installation
<details> ### Quick Install
<summary>Quick Install</summary>
The `astro add` command-line tool automates the installation for you. Run one of the following commands in a new terminal window. (If you aren't sure which package manager you're using, run the first command.) Then, follow the prompts, and type "y" in the terminal (meaning "yes") for each one. The `astro add` command-line tool automates the installation for you. Run one of the following commands in a new terminal window. (If you aren't sure which package manager you're using, run the first command.) Then, follow the prompts, and type "y" in the terminal (meaning "yes") for each one.
```sh ```sh
# Using NPM # Using NPM
npx astro add mdx npx astro add mdx
# Using Yarn # Using Yarn
yarn astro add mdx yarn astro add mdx
# Using PNPM # Using PNPM
pnpx astro add mdx pnpx astro add mdx
``` ```
Then, restart the dev server by typing `CTRL-C` and then `npm run astro dev` in the terminal window that was running Astro. Then, restart the dev server by typing `CTRL-C` and then `npm run astro dev` in the terminal window that was running Astro.
Because this command is new, it might not properly set things up. If that happens, [feel free to log an issue on our GitHub](https://github.com/withastro/astro/issues) and try the manual installation steps below. Because this command is new, it might not properly set things up. If that happens, [feel free to log an issue on our GitHub](https://github.com/withastro/astro/issues) and try the manual installation steps below.
</details>
<details> ### Manual Install
<summary>Manual Install</summary>
First, install the `@astrojs/mdx` package using your package manager. If you're using npm or aren't sure, run this in the terminal: First, install the `@astrojs/mdx` package using your package manager. If you're using npm or aren't sure, run this in the terminal:
```sh ```sh
npm install @astrojs/mdx npm install @astrojs/mdx
``` ```
Then, apply this integration to your `astro.config.*` file using the `integrations` property: Then, apply this integration to your `astro.config.*` file using the `integrations` property:
@ -63,11 +60,14 @@ export default defineConfig({
``` ```
Finally, restart the dev server. Finally, restart the dev server.
</details>
## Usage ## Usage
To write your first MDX page in Astro, head to our [UI framework documentation][astro-ui-frameworks]. You'll explore: You can [add MDX pages to your project](https://docs.astro.build/en/guides/markdown-content/#markdown-and-mdx-pages) by adding `.mdx` files within your `src/pages/` directory.
### Components
To use components in your MDX pages in Astro, head to our [UI framework documentation][astro-ui-frameworks]. You'll explore:
- 📦 how framework components are loaded, - 📦 how framework components are loaded,
- 💧 client-side hydration options, and - 💧 client-side hydration options, and
- 🪆 opportunities to mix and nest frameworks together - 🪆 opportunities to mix and nest frameworks together
@ -76,8 +76,6 @@ To write your first MDX page in Astro, head to our [UI framework documentation][
> **Note**: `.mdx` files adhere to strict JSX syntax rather than Astro's HTML-like syntax. > **Note**: `.mdx` files adhere to strict JSX syntax rather than Astro's HTML-like syntax.
Also check our [Astro Integration Documentation][astro-integration] for more on integrations.
### Variables ### Variables
MDX supports `export` statements to add variables to your templates. These variables are accessible both from the template itself _and_ as named properties when importing the template somewhere else. MDX supports `export` statements to add variables to your templates. These variables are accessible both from the template itself _and_ as named properties when importing the template somewhere else.
@ -255,8 +253,7 @@ This applies a minimal Prism renderer with added support for `astro` code blocks
## Configuration ## Configuration
<details> ### remarkPlugins
<summary><strong>remarkPlugins</strong></summary>
**Default plugins:** [remark-gfm](https://github.com/remarkjs/remark-gfm), [remark-smartypants](https://github.com/silvenon/remark-smartypants) **Default plugins:** [remark-gfm](https://github.com/remarkjs/remark-gfm), [remark-smartypants](https://github.com/silvenon/remark-smartypants)
@ -292,10 +289,7 @@ export default {
} }
``` ```
</details> ### rehypePlugins</strong>
<details>
<summary><strong>rehypePlugins</strong></summary>
[Rehype plugins](https://github.com/rehypejs/rehype/blob/main/doc/plugins.md) allow you to transform the HTML that your Markdown generates. We recommend checking the [Remark plugin](https://github.com/remarkjs/remark/blob/main/doc/plugins.md) catalog first _before_ considering rehype plugins, since most users want to transform their Markdown syntax instead. If HTML transforms are what you need, we encourage you to browse [awesome-rehype](https://github.com/rehypejs/awesome-rehype) for a full curated list of plugins! [Rehype plugins](https://github.com/rehypejs/rehype/blob/main/doc/plugins.md) allow you to transform the HTML that your Markdown generates. We recommend checking the [Remark plugin](https://github.com/remarkjs/remark/blob/main/doc/plugins.md) catalog first _before_ considering rehype plugins, since most users want to transform their Markdown syntax instead. If HTML transforms are what you need, we encourage you to browse [awesome-rehype](https://github.com/rehypejs/awesome-rehype) for a full curated list of plugins!
@ -313,10 +307,8 @@ export default {
})], })],
} }
``` ```
</details>
<details> ### frontmatterOptions
<summary><strong>frontmatterOptions</strong></summary>
**Default:** `{ name: 'frontmatter' }` **Default:** `{ name: 'frontmatter' }`
@ -344,7 +336,6 @@ title: I'm just a variable now!
``` ```
See the [remark-mdx-frontmatter README](https://github.com/remcohaszing/remark-mdx-frontmatter#options) for a complete list of options. See the [remark-mdx-frontmatter README](https://github.com/remcohaszing/remark-mdx-frontmatter#options) for a complete list of options.
</details>
## Examples ## Examples

View file

@ -75,8 +75,7 @@ The [Netlify Blog post on Astro](https://www.netlify.com/blog/how-to-deploy-astr
To configure this adapter, pass an object to the `netlify()` function call in `astro.config.mjs` - there's only one possible configuration option: To configure this adapter, pass an object to the `netlify()` function call in `astro.config.mjs` - there's only one possible configuration option:
<details> ### dist
<summary><strong>dist</strong></summary>
We build to the `dist` directory at the base of your project. To change this, use the `dist` option: We build to the `dist` directory at the base of your project. To change this, use the `dist` option:
@ -99,12 +98,7 @@ And then point to the dist in your `netlify.toml`:
directory = "dist/functions" directory = "dist/functions"
``` ```
</details> ### binaryMediaTypes
<details>
<summary>
<strong>binaryMediaTypes</strong>
</summary>
> This option is only needed for the Functions adapter and is not needed for Edge Functions. > This option is only needed for the Functions adapter and is not needed for Edge Functions.
@ -127,7 +121,6 @@ export function get() {
}); });
} }
``` ```
</details>
## Examples ## Examples

View file

@ -22,27 +22,24 @@ The Astro Partytown integration installs Partytown for you and makes sure it's e
## Installation ## Installation
<details> ### Quick Install
<summary>Quick Install</summary>
The `astro add` command-line tool automates the installation for you. Run one of the following commands in a new terminal window. (If you aren't sure which package manager you're using, run the first command.) Then, follow the prompts, and type "y" in the terminal (meaning "yes") for each one. The `astro add` command-line tool automates the installation for you. Run one of the following commands in a new terminal window. (If you aren't sure which package manager you're using, run the first command.) Then, follow the prompts, and type "y" in the terminal (meaning "yes") for each one.
```sh ```sh
# Using NPM # Using NPM
npx astro add partytown npx astro add partytown
# Using Yarn # Using Yarn
yarn astro add partytown yarn astro add partytown
# Using PNPM # Using PNPM
pnpx astro add partytown pnpx astro add partytown
``` ```
Then, restart the dev server by typing `CTRL-C` and then `npm run astro dev` in the terminal window that was running Astro. Then, restart the dev server by typing `CTRL-C` and then `npm run astro dev` in the terminal window that was running Astro.
Because this command is new, it might not properly set things up. If that happens, [feel free to log an issue on our GitHub](https://github.com/withastro/astro/issues) and try the manual installation steps below. Because this command is new, it might not properly set things up. If that happens, [feel free to log an issue on our GitHub](https://github.com/withastro/astro/issues) and try the manual installation steps below.
</details>
<details> ### Manual Install
<summary>Manual Install</summary>
First, install the `@astrojs/partytown` package using your package manager. If you're using npm or aren't sure, run this in the terminal: First, install the `@astrojs/partytown` package using your package manager. If you're using npm or aren't sure, run this in the terminal:
```sh ```sh
@ -63,7 +60,6 @@ export default defineConfig({
``` ```
Then, restart the dev server. Then, restart the dev server.
</details>
## Usage ## Usage
@ -94,12 +90,11 @@ export default defineConfig({
This mirrors the [Partytown config object](https://partytown.builder.io/configuration), but only `debug` and `forward` are exposed by this integration. This mirrors the [Partytown config object](https://partytown.builder.io/configuration), but only `debug` and `forward` are exposed by this integration.
<details> ### config.debug
<summary><strong>config.debug</strong></summary>
Partytown ships with a `debug` mode; enable or disable it by passing `true` or `false` to `config.debug`. If [`debug` mode](https://partytown.builder.io/debugging) is enabled, it will output detailed logs to the browser console. Partytown ships with a `debug` mode; enable or disable it by passing `true` or `false` to `config.debug`. If [`debug` mode](https://partytown.builder.io/debugging) is enabled, it will output detailed logs to the browser console.
If this option isn't set, `debug` mode will be on by default in [dev](https://docs.astro.build/en/reference/cli-reference/#astro-dev) or [preview](https://docs.astro.build/en/reference/cli-reference/#astro-preview) mode. If this option isn't set, `debug` mode will be on by default in [dev](https://docs.astro.build/en/reference/cli-reference/#astro-dev) or [preview](https://docs.astro.build/en/reference/cli-reference/#astro-preview) mode.
__`astro.config.mjs`__ __`astro.config.mjs`__
@ -111,10 +106,8 @@ export default defineConfig({
}) })
``` ```
</details>
<details> ### config.forward
<summary><strong>config.forward</strong></summary>
Third-party scripts typically add variables to the `window` object so that you can communicate with them throughout your site. But when a script is loaded in a web-worker, it doesn't have access to that global `window` object. Third-party scripts typically add variables to the `window` object so that you can communicate with them throughout your site. But when a script is loaded in a web-worker, it doesn't have access to that global `window` object.
@ -135,12 +128,9 @@ export default defineConfig ({
})], })],
}) })
``` ```
</details>
## Examples ## Examples
- The [integrations playground template](https://github.com/withastro/astro/tree/latest/examples/integrations-playground?on=github) comes with Astro Partytown installed, with a demo script that shows how Partytown moves intensive operations off of the main thread.
- [Browse projects with Astro Partytown on GitHub](https://github.com/search?q=%22@astrojs/partytown%22+filename:package.json&type=Code) for more examples! - [Browse projects with Astro Partytown on GitHub](https://github.com/search?q=%22@astrojs/partytown%22+filename:package.json&type=Code) for more examples!
## Troubleshooting ## Troubleshooting

View file

@ -22,39 +22,36 @@ Check out [“Learn Preact in 10 minutes”](https://preactjs.com/tutorial), an
## Installation ## Installation
<details> ### Quick Install
<summary>Quick Install</summary>
The `astro add` command-line tool automates the installation for you. Run one of the following commands in a new terminal window. (If you aren't sure which package manager you're using, run the first command.) Then, follow the prompts, and type "y" in the terminal (meaning "yes") for each one. The `astro add` command-line tool automates the installation for you. Run one of the following commands in a new terminal window. (If you aren't sure which package manager you're using, run the first command.) Then, follow the prompts, and type "y" in the terminal (meaning "yes") for each one.
```sh ```sh
# Using NPM # Using NPM
npx astro add preact npx astro add preact
# Using Yarn # Using Yarn
yarn astro add preact yarn astro add preact
# Using PNPM # Using PNPM
pnpx astro add preact pnpx astro add preact
``` ```
Then, restart the dev server by typing `CTRL-C` and then `npm run astro dev` in the terminal window that was running Astro. Then, restart the dev server by typing `CTRL-C` and then `npm run astro dev` in the terminal window that was running Astro.
Because this command is new, it might not properly set things up. If that happens, [feel free to log an issue on our GitHub](https://github.com/withastro/astro/issues) and try the manual installation steps below. Because this command is new, it might not properly set things up. If that happens, [feel free to log an issue on our GitHub](https://github.com/withastro/astro/issues) and try the manual installation steps below.
</details>
<details> ### Manual Install
<summary>Manual Install</summary>
First, install the `@astrojs/preact` package using your package manager. If you're using npm or aren't sure, run this in the terminal: First, install the `@astrojs/preact` package using your package manager. If you're using npm or aren't sure, run this in the terminal:
``` ```
npm install @astrojs/preact npm install @astrojs/preact
``` ```
Most package managers will install associated peer dependencies as well. Still, if you see a "Cannot find package 'preact'" (or similar) warning when you start up Astro, you'll need to install Preact: Most package managers will install associated peer dependencies as well. Still, if you see a "Cannot find package 'preact'" (or similar) warning when you start up Astro, you'll need to install Preact:
```sh ```sh
npm install preact npm install preact
``` ```
Then, apply this integration to your `astro.config.*` file using the `integrations` property: Then, apply this integration to your `astro.config.*` file using the `integrations` property:
@ -71,7 +68,6 @@ export default defineConfig({
``` ```
Finally, restart the dev server. Finally, restart the dev server.
</details>
## Usage ## Usage
@ -88,8 +84,7 @@ The Astro Preact integration handles how Preact components are rendered and it h
For basic usage, you do not need to configure the Preact integration. For basic usage, you do not need to configure the Preact integration.
<details> ### compat
<summary><strong>compat</strong></summary>
You can enable `preact/compat`, Preacts compatibility layer for rendering React components without needing to install or ship Reacts larger libraries to your users web browsers. You can enable `preact/compat`, Preacts compatibility layer for rendering React components without needing to install or ship Reacts larger libraries to your users web browsers.
@ -108,7 +103,7 @@ export default defineConfig({
``` ```
With the `compat` option enabled, the Preact integration will render React components as well as Preact components in your project and also allow you to import React components inside Preact components. Read more in [“Switching to Preact (from React)”](https://preactjs.com/guide/v10/switching-to-preact) on the Preact website. With the `compat` option enabled, the Preact integration will render React components as well as Preact components in your project and also allow you to import React components inside Preact components. Read more in [“Switching to Preact (from React)”](https://preactjs.com/guide/v10/switching-to-preact) on the Preact website.
</details>
## Examples ## Examples

View file

@ -16,27 +16,24 @@ To further improve the experience, especially on similar pages, stylesheets are
## Installation ## Installation
<details> ### Quick Install
<summary>Quick Install</summary>
The `astro add` command-line tool automates the installation for you. Run one of the following commands in a new terminal window. (If you aren't sure which package manager you're using, run the first command.) Then, follow the prompts, and type "y" in the terminal (meaning "yes") for each one. The `astro add` command-line tool automates the installation for you. Run one of the following commands in a new terminal window. (If you aren't sure which package manager you're using, run the first command.) Then, follow the prompts, and type "y" in the terminal (meaning "yes") for each one.
```sh ```sh
# Using NPM # Using NPM
npx astro add prefetch npx astro add prefetch
# Using Yarn # Using Yarn
yarn astro add prefetch yarn astro add prefetch
# Using PNPM # Using PNPM
pnpx astro add prefetch pnpx astro add prefetch
``` ```
Then, restart the dev server by typing `CTRL-C` and then `npm run astro dev` in the terminal window that was running Astro. Then, restart the dev server by typing `CTRL-C` and then `npm run astro dev` in the terminal window that was running Astro.
Because this command is new, it might not properly set things up. If that happens, [feel free to log an issue on our GitHub](https://github.com/withastro/astro/issues) and try the manual installation steps below. Because this command is new, it might not properly set things up. If that happens, [feel free to log an issue on our GitHub](https://github.com/withastro/astro/issues) and try the manual installation steps below.
</details>
<details> ### Manual Install
<summary>Manual Install</summary>
First, install the `@astrojs/prefetch` package using your package manager. If you're using npm or aren't sure, run this in the terminal: First, install the `@astrojs/prefetch` package using your package manager. If you're using npm or aren't sure, run this in the terminal:
```sh ```sh
@ -56,7 +53,6 @@ export default {
``` ```
Then, restart the dev server. Then, restart the dev server.
</details>
## Usage ## Usage
@ -66,8 +62,7 @@ When you install the integration, the prefetch script is automatically added to
The Astro Prefetch integration handles which links on the site are prefetched and it has its own options. Change these in the `astro.config.mjs` file which is where your project's integration settings live. The Astro Prefetch integration handles which links on the site are prefetched and it has its own options. Change these in the `astro.config.mjs` file which is where your project's integration settings live.
<details> ### config.selector
<summary><strong>config.selector</strong></summary>
By default the prefetch script searches the page for any links that include a `rel="prefetch"` attribute, ex: `<a rel="prefetch" />` or `<a rel="nofollow prefetch" />`. This behavior can be changed in your `astro.config.*` file to use a custom query selector when finding prefetch links. By default the prefetch script searches the page for any links that include a `rel="prefetch"` attribute, ex: `<a rel="prefetch" />` or `<a rel="nofollow prefetch" />`. This behavior can be changed in your `astro.config.*` file to use a custom query selector when finding prefetch links.
@ -82,10 +77,7 @@ export default {
})], })],
} }
``` ```
</details> ### config.throttle
<details>
<summary><strong>config.throttle</strong></summary>
By default the prefetch script will only prefetch one link at a time. This behavior can be changed in your `astro.config.*` file to increase the limit for concurrent downloads. By default the prefetch script will only prefetch one link at a time. This behavior can be changed in your `astro.config.*` file to increase the limit for concurrent downloads.
@ -100,7 +92,6 @@ export default {
})], })],
} }
``` ```
</details>
## Troubleshooting ## Troubleshooting
- If your installation doesn't seem to be working, make sure to restart the dev server. - If your installation doesn't seem to be working, make sure to restart the dev server.

View file

@ -22,27 +22,24 @@ With Astro Sitemap, you don't have to worry about creating this file: build your
## Installation ## Installation
<details> ### Quick Install
<summary>Quick Install</summary>
The `astro add` command-line tool automates the installation for you. Run one of the following commands in a new terminal window. (If you aren't sure which package manager you're using, run the first command.) Then, follow the prompts, and type "y" in the terminal (meaning "yes") for each one. The `astro add` command-line tool automates the installation for you. Run one of the following commands in a new terminal window. (If you aren't sure which package manager you're using, run the first command.) Then, follow the prompts, and type "y" in the terminal (meaning "yes") for each one.
```sh ```sh
# Using NPM # Using NPM
npx astro add sitemap npx astro add sitemap
# Using Yarn # Using Yarn
yarn astro add sitemap yarn astro add sitemap
# Using PNPM # Using PNPM
pnpx astro add sitemap pnpx astro add sitemap
``` ```
Then, restart the dev server by typing `CTRL-C` and then `npm run astro dev` in the terminal window that was running Astro. Then, restart the dev server by typing `CTRL-C` and then `npm run astro dev` in the terminal window that was running Astro.
Because this command is new, it might not properly set things up. If that happens, [feel free to log an issue on our GitHub](https://github.com/withastro/astro/issues) and try the manual installation steps below. Because this command is new, it might not properly set things up. If that happens, [feel free to log an issue on our GitHub](https://github.com/withastro/astro/issues) and try the manual installation steps below.
</details>
<details> ### Manual Install
<summary>Manual Install</summary>
First, install the `@astrojs/sitemap` package using your package manager. If you're using npm or aren't sure, run this in the terminal: First, install the `@astrojs/sitemap` package using your package manager. If you're using npm or aren't sure, run this in the terminal:
```sh ```sh
@ -63,7 +60,6 @@ export default defineConfig({
``` ```
Then, restart the dev server. Then, restart the dev server.
</details>
## Usage ## Usage
@ -89,8 +85,7 @@ Now, [build your site for production](https://docs.astro.build/en/reference/cli-
> **Warning** > **Warning**
> If you forget to add a `site`, you'll get a friendly warning when you build, and the `sitemap-index.xml` file won't be generated. > If you forget to add a `site`, you'll get a friendly warning when you build, and the `sitemap-index.xml` file won't be generated.
<details> ### Example of generated files for a two-page website
<summary>Example of generated files for a two-page website</summary>
**`sitemap-index.xml`** **`sitemap-index.xml`**
@ -116,10 +111,6 @@ Now, [build your site for production](https://docs.astro.build/en/reference/cli-
</url> </url>
</urlset> </urlset>
``` ```
</details>
## Configuration ## Configuration
@ -135,10 +126,9 @@ export default defineConfig({
}); });
``` ```
<details> ### filter
<summary><strong>filter</strong></summary>
All pages are included in your sitemap by default. By adding a custom `filter` function, you can filter included pages by URL. All pages are included in your sitemap by default. By adding a custom `filter` function, you can filter included pages by URL.
__`astro.config.mjs`__ __`astro.config.mjs`__
@ -151,13 +141,9 @@ __`astro.config.mjs`__
The function will be called for every page on your site. The `page` function parameter is the full URL of the page currently under considering, including your `site` domain. Return `true` to include the page in your sitemap, and `false` to leave it out. The function will be called for every page on your site. The `page` function parameter is the full URL of the page currently under considering, including your `site` domain. Return `true` to include the page in your sitemap, and `false` to leave it out.
</details> ### customPages
<details>
<summary><strong>customPages</strong></summary>
In some cases, a page might be part of your deployed site but not part of your Astro project. In some cases, a page might be part of your deployed site but not part of your Astro project. If you'd like to include a page in your sitemap that _isn't_ created by Astro, you can use this option.
If you'd like to include a page in your sitemap that _isn't_ created by Astro, you can use this option.
__`astro.config.mjs`__ __`astro.config.mjs`__
@ -167,10 +153,7 @@ __`astro.config.mjs`__
customPages: ['https://stargazers.club/external-page', 'https://stargazers.club/external-page2'] customPages: ['https://stargazers.club/external-page', 'https://stargazers.club/external-page2']
}), }),
``` ```
</details> ### entryLimit
<details>
<summary><strong>entryLimit</strong></summary>
The maximum number entries per sitemap file. The default value is 45000. A sitemap index and multiple sitemaps are created if you have more entries. See this [explanation of splitting up a large sitemap](https://developers.google.com/search/docs/advanced/sitemaps/large-sitemaps). The maximum number entries per sitemap file. The default value is 45000. A sitemap index and multiple sitemaps are created if you have more entries. See this [explanation of splitting up a large sitemap](https://developers.google.com/search/docs/advanced/sitemaps/large-sitemaps).
@ -188,11 +171,8 @@ export default {
], ],
} }
``` ```
</details>
### changefreq, lastmod, and priority
<details>
<summary><strong>changefreq</strong>, <strong>lastmod</strong>, and <strong>priority</strong></summary>
These options correspond to the `<changefreq>`, `<lastmod>`, and `<priortity>` tags in the [Sitemap XML specification.](https://www.sitemaps.org/protocol.html) These options correspond to the `<changefreq>`, `<lastmod>`, and `<priortity>` tags in the [Sitemap XML specification.](https://www.sitemaps.org/protocol.html)
@ -218,12 +198,7 @@ export default {
} }
``` ```
</details> ### serialize
<details>
<summary>
<strong>serialize</strong>
</summary>
A function called for each sitemap entry just before writing to a disk. This function can be asynchronous. A function called for each sitemap entry just before writing to a disk. This function can be asynchronous.
@ -267,13 +242,7 @@ export default {
} }
``` ```
### i18n
</details>
<details>
<summary>
<strong>i18n</strong>
</summary>
To localize a sitemap, pass an object to this `i18n` option. To localize a sitemap, pass an object to this `i18n` option.
@ -308,8 +277,7 @@ export default {
}; };
``` ```
<details> The resulting sitemap looks like this:
<summary>The resulting sitemap looks like this</summary>
```xml ```xml
... ...
@ -340,9 +308,6 @@ export default {
... ...
``` ```
</details>
</details>
## Examples ## Examples
- The official Astro website uses Astro Sitemap to generate [its sitemap](https://astro.build/sitemap-index.xml). - The official Astro website uses Astro Sitemap to generate [its sitemap](https://astro.build/sitemap-index.xml).
- The [integrations playground template](https://github.com/withastro/astro/tree/latest/examples/integrations-playground?on=github) comes with Astro Sitemap installed. Try adding a route and building the project! - The [integrations playground template](https://github.com/withastro/astro/tree/latest/examples/integrations-playground?on=github) comes with Astro Sitemap installed. Try adding a route and building the project!

View file

@ -25,27 +25,24 @@ Note: it's generally discouraged to use both Tailwind and another styling method
https://user-images.githubusercontent.com/4033662/169920154-4b42fc52-e2b5-4ca4-b7d2-d9057ab42ddf.mp4 https://user-images.githubusercontent.com/4033662/169920154-4b42fc52-e2b5-4ca4-b7d2-d9057ab42ddf.mp4
<details> ### Quick Install
<summary>Quick Install</summary>
The `astro add` command-line tool automates the installation for you. Run one of the following commands in a new terminal window. (If you aren't sure which package manager you're using, run the first command.) Then, follow the prompts, and type "y" in the terminal (meaning "yes") for each one. The `astro add` command-line tool automates the installation for you. Run one of the following commands in a new terminal window. (If you aren't sure which package manager you're using, run the first command.) Then, follow the prompts, and type "y" in the terminal (meaning "yes") for each one.
```sh ```sh
# Using NPM # Using NPM
npx astro add tailwind npx astro add tailwind
# Using Yarn # Using Yarn
yarn astro add tailwind yarn astro add tailwind
# Using PNPM # Using PNPM
pnpx astro add tailwind pnpx astro add tailwind
``` ```
Then, restart the dev server by typing `CTRL-C` and then `npm run astro dev` in the terminal window that was running Astro. Then, restart the dev server by typing `CTRL-C` and then `npm run astro dev` in the terminal window that was running Astro.
Because this command is new, it might not properly set things up. If that happens, [feel free to log an issue on our GitHub](https://github.com/withastro/astro/issues) and try the manual installation steps below. Because this command is new, it might not properly set things up. If that happens, [feel free to log an issue on our GitHub](https://github.com/withastro/astro/issues) and try the manual installation steps below.
</details>
<details> ### Manual Install
<summary>Manual Install</summary>
First, install the `@astrojs/tailwind` package using your package manager. If you're using npm or aren't sure, run this in the terminal: First, install the `@astrojs/tailwind` package using your package manager. If you're using npm or aren't sure, run this in the terminal:
```sh ```sh
@ -65,7 +62,7 @@ export default {
``` ```
Then, restart the dev server. Then, restart the dev server.
</details>
## Usage ## Usage
@ -85,8 +82,7 @@ If it isn't there, you add your own `tailwind.config.(js|cjs|mjs)` file to the r
The Astro Tailwind integration handles the communication between Astro and Tailwind and it has its own options. Change these in the `astro.config.mjs` file (_not_ the Tailwind configuration file) which is where your project's integration settings live. The Astro Tailwind integration handles the communication between Astro and Tailwind and it has its own options. Change these in the `astro.config.mjs` file (_not_ the Tailwind configuration file) which is where your project's integration settings live.
<details> #### config.path
<summary><strong>config.path</strong></summary>
If you want to use a different Tailwind configuration file instead of the default `tailwind.config.(js|cjs|mjs)`, specify that file's location using this integration's `config.path` option. If `config.path` is relative, it will be resolved relative to the root. If you want to use a different Tailwind configuration file instead of the default `tailwind.config.(js|cjs|mjs)`, specify that file's location using this integration's `config.path` option. If `config.path` is relative, it will be resolved relative to the root.
@ -104,10 +100,8 @@ export default {
})], })],
} }
``` ```
</details>
<details> #### config.applyBaseStyles
<summary><strong>config.applyBaseStyles</strong></summary>
By default, the integration imports a basic `base.css` file on every page of your project. This basic CSS file includes the three main `@tailwind` directives: By default, the integration imports a basic `base.css` file on every page of your project. This basic CSS file includes the three main `@tailwind` directives:
@ -132,7 +126,6 @@ export default {
``` ```
You can now [import your own `base.css` as a local stylesheet](https://docs.astro.build/en/guides/styling/#import-a-local-stylesheet). You can now [import your own `base.css` as a local stylesheet](https://docs.astro.build/en/guides/styling/#import-a-local-stylesheet).
</details>
## Examples ## Examples