From a862da8aaebfa087a9e064ce6f8ab2811cdf745b Mon Sep 17 00:00:00 2001
From: Erika <3019731+Princesseuh@users.noreply.github.com>
Date: Wed, 10 Aug 2022 15:30:00 -0400
Subject: [PATCH] Fix changesets destroying our Astro codeblocks in changelogs
(#4227)
---
.prettierrc.js | 32 ++++++++++
.prettierrc.json | 23 --------
packages/astro/CHANGELOG.md | 115 ++++++++++++++++++++----------------
3 files changed, 97 insertions(+), 73 deletions(-)
create mode 100644 .prettierrc.js
delete mode 100644 .prettierrc.json
diff --git a/.prettierrc.js b/.prettierrc.js
new file mode 100644
index 0000000000..d43df33f5b
--- /dev/null
+++ b/.prettierrc.js
@@ -0,0 +1,32 @@
+// Heads up: This file should be renamed to `.cjs`, however if we did that, changesets wouldn't be able to load it
+module.exports = {
+ printWidth: 100,
+ semi: true,
+ singleQuote: true,
+ tabWidth: 2,
+ trailingComma: 'es5',
+ useTabs: true,
+ plugins: ['./node_modules/prettier-plugin-astro'],
+ overrides: [
+ {
+ // Changesets run Prettier using our configuration, however it uses a very old version of Prettier that does
+ // not support our plugin and it ends up doing more harm than good. As such, we'll disable our plugin for changelogs
+ files: ['CHANGELOG.md'],
+ options: {
+ plugins: [],
+ },
+ },
+ {
+ files: ['.*', '*.json', '*.md', '*.toml', '*.yml'],
+ options: {
+ useTabs: false,
+ },
+ },
+ {
+ files: ['**/*.astro'],
+ options: {
+ parser: 'astro',
+ },
+ },
+ ],
+};
diff --git a/.prettierrc.json b/.prettierrc.json
deleted file mode 100644
index 4048bb8232..0000000000
--- a/.prettierrc.json
+++ /dev/null
@@ -1,23 +0,0 @@
-{
- "printWidth": 100,
- "semi": true,
- "singleQuote": true,
- "tabWidth": 2,
- "trailingComma": "es5",
- "useTabs": true,
- "plugins": ["./node_modules/prettier-plugin-astro"],
- "overrides": [
- {
- "files": [".*", "*.json", "*.md", "*.toml", "*.yml"],
- "options": {
- "useTabs": false
- }
- },
- {
- "files": ["**/*.astro"],
- "options": {
- "parser": "astro"
- }
- }
- ]
-}
diff --git a/packages/astro/CHANGELOG.md b/packages/astro/CHANGELOG.md
index e3907ecc3b..3603548b9c 100644
--- a/packages/astro/CHANGELOG.md
+++ b/packages/astro/CHANGELOG.md
@@ -456,7 +456,18 @@ The **Astro v1.0.0 Release Candidate** comes includes new features, tons of bug
Astro supports streaming in its templates. Any time Astro encounters an async boundary it will stream out HTML that occurs before it. For example:
```astro
+ ---
+ import LoadTodos from '../components/LoadTodos.astro';
+ ---
+
+
+ App
+
+
+
+
+
```
In this arbtrary example Astro will streaming out the `` section and everything else until it encounters `` and then stop. LoadTodos, which is also an Astro component will stream its contents as well; stopping and waiting at any other asynchronous components.
@@ -464,7 +475,15 @@ The **Astro v1.0.0 Release Candidate** comes includes new features, tons of bug
As part of this Astro also now supports async iterables within its templates. This means you can do this:
```astro
-
+
+ {(async function* () {
+ for (const number of numbers) {
+ await wait(1000);
+ yield - Number: {number}
;
+ yield '\n';
+ }
+ })()}
+
```
Which will stream out ``s one at a time, waiting a second between each.
@@ -1687,18 +1706,15 @@ The **Astro v1.0.0 Release Candidate** comes includes new features, tons of bug
```typescript
export async function getStaticPaths() {
- return [
- { params: { slug: 'thing1' }},
- { params: { slug: 'thing2' }}
- ]
+ return [{ params: { slug: 'thing1' } }, { params: { slug: 'thing2' } }];
}
export async function get(params) {
- const { slug } = params
+ const { slug } = params;
- return {
- body: // ...JSON.stringify()
- }
+ return {
+ // body: JSON.stringify(...)
+ };
}
```
@@ -1725,7 +1741,7 @@ The **Astro v1.0.0 Release Candidate** comes includes new features, tons of bug
const app = await loadApp(new URL('./dist/server/', import.meta.url));
- createServer((req, res) => {
+ createServer(async (req, res) => {
const route = app.match(req);
if (route) {
let html = await app.render(req, route);
@@ -1854,18 +1870,15 @@ The **Astro v1.0.0 Release Candidate** comes includes new features, tons of bug
```typescript
export async function getStaticPaths() {
- return [
- { params: { slug: 'thing1' }},
- { params: { slug: 'thing2' }}
- ]
+ return [{ params: { slug: 'thing1' } }, { params: { slug: 'thing2' } }];
}
export async function get(params) {
- const { slug } = params
+ const { slug } = params;
- return {
- body: // ...JSON.stringify()
- }
+ return {
+ // body: JSON.stringify(...)
+ };
}
```
@@ -1884,7 +1897,7 @@ The **Astro v1.0.0 Release Candidate** comes includes new features, tons of bug
const app = await loadApp(new URL('./dist/server/', import.meta.url));
- createServer((req, res) => {
+ createServer(async (req, res) => {
const route = app.match(req);
if (route) {
let html = await app.render(req, route);
@@ -2605,7 +2618,9 @@ For convenience, you may now also move your `astro.config.js` file to a top-leve
This change adds support for hoisted scripts, allowing you to bundle scripts together for a page and hoist them to the top (in the head):
```astro
-
+
```
- Updated dependencies [5d2ea578]
@@ -2706,22 +2721,21 @@ For convenience, you may now also move your `astro.config.js` file to a top-leve
An example usage:
- ```jsx
+ ```astro
---
import BarChart from '../components/BarChart.jsx';
---
- /**
- * If multiple renderers are included in the Astro config,
- * this will ensure that the component is hydrated with
- * the Preact renderer.
- */
+
+
- /**
- * If a custom renderer is required, use the same name
- * provided in the Astro config.
- */
+
+
```
@@ -2745,22 +2759,16 @@ For convenience, you may now also move your `astro.config.js` file to a top-leve
An example usage:
- ```jsx
+ ```astro
---
import BarChart from '../components/BarChart.jsx';
---
- /**
- * If multiple renderers are included in the Astro config,
- * this will ensure that the component is hydrated with
- * the Preact renderer.
- */
+ /** * If multiple renderers are included in the Astro config, * this will ensure that the
+ component is hydrated with * the Preact renderer. */
- /**
- * If a custom renderer is required, use the same name
- * provided in the Astro config.
- */
+ /** * If a custom renderer is required, use the same name * provided in the Astro config. */
```
@@ -2908,7 +2916,7 @@ For convenience, you may now also move your `astro.config.js` file to a top-leve
The new `client:media` hydrator allows you to define a component that should only be loaded when a media query matches. An example usage:
- ```jsx
+ ```astro
---
import Sidebar from '../components/Sidebar.jsx';
---
@@ -2930,10 +2938,13 @@ For convenience, you may now also move your `astro.config.js` file to a top-leve
**index.astro**
- ```jsx
+ ```astro
+ ---
import Sidebar from '../components/Sidebar.jsx';
import { MOBILE } from '../media.js';
- ---();
+ ---
+
+ ;
```
### Patch Changes
@@ -3057,7 +3068,7 @@ For convenience, you may now also move your `astro.config.js` file to a top-leve
The new `client:media` hydrator allows you to define a component that should only be loaded when a media query matches. An example usage:
- ```jsx
+ ```astro
---
import Sidebar from '../components/Sidebar.jsx';
---
@@ -3079,10 +3090,13 @@ For convenience, you may now also move your `astro.config.js` file to a top-leve
**index.astro**
- ```jsx
+ ```astro
+ ---
import Sidebar from '../components/Sidebar.jsx';
import { MOBILE } from '../media.js';
- ---();
+ ---
+
+
```
### Patch Changes
@@ -3250,7 +3264,7 @@ For convenience, you may now also move your `astro.config.js` file to a top-leve
Astro frontmatter scripts are TypeScript! Because of this, we can leverage TypeScript types to define the shape of your props.
- ```ts
+ ```astro
---
export interface Props {
text?: string;
@@ -3265,7 +3279,7 @@ For convenience, you may now also move your `astro.config.js` file to a top-leve
One of the great things about this change is that it's straight-forward to access _any_ props. Just use `...props`!
- ```ts
+ ```astro
---
export interface Props {
text?: string;
@@ -3279,11 +3293,12 @@ For convenience, you may now also move your `astro.config.js` file to a top-leve
We considered building prop validation into Astro, but decided to leave that implementation up to you! This way, you can use any set of tools you like.
- ```ts
+ ```astro
---
const { text = 'Hello world!' } = Astro.props;
- if (typeof text !== 'string') throw new Error(`Expected "text" to be of type "string" but recieved "${typeof string}"!`);
+ if (typeof text !== 'string')
+ throw new Error(`Expected "text" to be of type "string" but recieved "${typeof string}"!`);
---
```