Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
226 KiB
astro
2.7.1
Patch Changes
-
#7490
601403744
Thanks @ematipico! - Fix the URL that belongs toentryPoints
in the hookastro:build:ssr
. The paths were created with the wrong output directory. -
#7459
869197aaf
Thanks @bluwy! - Fix missing styles for Markdoc files in development -
#7476
478cd9d8f
Thanks @hirasso! - Allow astro to be installed underneath a folder with leading slashes -
#7479
57e603038
Thanks @bluwy! - Handle esbuild 0.18 changes -
#7381
f359d77b1
Thanks @matthewp! - Prevent accidental inclusion of page CSS in dev mode -
Updated dependencies [
2b7539952
]:- @astrojs/internal-helpers@0.1.1
2.7.0
Minor Changes
-
#7353
76fcdb84d
Thanks @bholmesdev! - Remove legacy handling for MDX content collections. Ensure you are using@astrojs/mdx
v0.18 or above. -
#7385
8e2923cc6
Thanks @ematipico! -Astro.locals
is now exposed to the adapter API. Node Adapter can now pass in alocals
object in the SSR handler middleware. -
#7220
459b5bd05
Thanks @ematipico! - Shipped a new SSR build configuration mode:split
. When enabled, Astro will "split" the singleentry.mjs
file and instead emit a separate file to render each individual page during the build process.These files will be emitted inside
dist/pages
, mirroring the directory structure of your page files insrc/pages/
, for example:├── pages │ ├── blog │ │ ├── entry._slug_.astro.mjs │ │ └── entry.about.astro.mjs │ └── entry.index.astro.mjs
To enable, set
build.split: true
in your Astro config:// src/astro.config.mjs export default defineConfig({ output: 'server', adapter: node({ mode: 'standalone', }), build: { split: true, }, });
-
#7220
459b5bd05
Thanks @ematipico! - The Astro hookastro:build:ssr
now receives a new option in their payload, calledentryPoints
.entryPoints
is defined as aMap<RouteData, URL>
, whereRouteData
represents the information of a Astro route andURL
is the path to the physical file emitted at the end of the build.export function integration(): AstroIntegration { return { name: 'my-integration', hooks: { 'astro:build:ssr': ({ entryPoints }) => { // do something with `entryPoints` }, }, }; }
Patch Changes
-
#7438
30bb36371
Thanks @bluwy! - Fixastro:build:setup
hookupdateConfig
utility, where the configuration wasn't correctly updated when the hook was fired. -
#7436
3943fa390
Thanks @kossidts! - Fix an issue related to the documentation. Destructure the argument of the function to customize the Astro dev server based on the command run. -
#7424
7877a06d8
Thanks @bholmesdev! - Update internal types for more stable builds for Astro maintainers. -
#7427
e314a04bf
Thanks @ematipico! - Correctly emit the middleware code during the build phase. The file emitted is nowdist/middleware.mjs
-
#7423
33cdc8622
Thanks @bmenant! - Ensure injected/_image
endpoint for image optimization is not prerendered on hybrid output.
2.6.6
Patch Changes
-
#7418
2b34fc492
Thanks @ematipico! - Correctly type the optionserver.open
-
#7429
89a483520
Thanks @delucis! - Fix telemetry reporting for integrations that return an array
2.6.5
Patch Changes
-
#7414
bb644834e
Thanks @bluwy! - Simplify telemetry Vite version detection -
#7399
d2020c29c
Thanks @natemoo-re! - Fix edge case where injected routes would cause builds to fail in a PNPM workspace
2.6.4
Patch Changes
-
#7366
42baf62e7
Thanks @aappaapp! - FixedRedirectConfig
type definition -
#7380
1c7b63595
Thanks @bholmesdev! - Fix missing stacktraces for Zod errors
2.6.3
Patch Changes
-
#7341
491c2db42
Thanks @bholmesdev! - Improve error message for unsupported Zod transforms from the content config. -
#7352
0a8d178c9
Thanks @bholmesdev! - Raise error when multiple content collection entries have the same slug
2.6.2
Patch Changes
-
#7310
52f0480d1
Thanks @Edo-San! - Fixed a bug that threw an Exception when spreading potentially undefined values as HTML attributes -
#7339
e3271f8c1
Thanks @bholmesdev! - Add readable error message for invalid dynamic routes. -
#7316
e6bff651f
Thanks @bholmesdev! - Fix Zod errors getting flagged as configuration errors -
#7342
bbcf69e7b
Thanks @matthewp! - Fix for experimental redirects in dev mode -
#7326
1430ffb47
Thanks @calebdwilliams! - Fixes issue where Astro doesn't respect custom npm registry settings during project creation
2.6.1
Patch Changes
- #7307
8034edd9e
Thanks @bholmesdev! - Fix [Object AsyncGenerator] appearing in markup for Markdoc documents
2.6.0
Minor Changes
-
#7067
57f8d14c0
Thanks @matthewp! - Experimental redirects supportThis change adds support for the redirects RFC, currently in stage 3: https://github.com/withastro/roadmap/pull/587
Now you can specify redirects in your Astro config:
import { defineConfig } from 'astro/config'; export defineConfig({ redirects: { '/blog/old-post': '/blog/new-post' } });
You can also specify spread routes using the same syntax as in file-based routing:
import { defineConfig } from 'astro/config'; export defineConfig({ redirects: { '/blog/[...slug]': '/articles/[...slug]' } });
By default Astro will build HTML files that contain the
<meta http-equiv="refresh">
tag. Adapters can also support redirect routes and create configuration for real HTTP-level redirects in production. -
#7237
414eb19d2
Thanks @bluwy! - Remove experimental flag for custom client directives -
#7274
b5213654b
Thanks @Princesseuh! - Update basetsconfig.json
template withallowJs: true
to provide a better relaxed experience for users unfamilliar with TypeScript.allowJs
is still set tofalse
(its default value) when using thestrictest
preset. -
#7180
e3b8c6296
Thanks @lilnasy! - The Inline Stylesheets RFC is now stable!You can now control how Astro bundles your css with a configuration change:
export default defineConfig({ ... build: { inlineStylesheets: "auto" } ... })
The options:
inlineStylesheets: "never"
: This is the behavior you are familiar with. Every stylesheet is external, and added to the page via a<link>
tag. Default.inlineStylesheets: "auto"
: Small stylesheets are inlined into<style>
tags and inserted into<head>
, while larger ones remain external.inlineStylesheets: "always"
: Every style required by the page is inlined.
As always, css files in the
public
folder are not affected. -
#7260
39403c32f
Thanks @natemoo-re! - Unflags support foroutput: 'hybrid'
mode, which enables pre-rendering by default. The additionalexperimental.hybridOutput
flag can be safely removed from your configuration. -
#7109
101f03209
Thanks @ematipico! - Remove experimental flag for the middleware
Patch Changes
-
#7296
a7e2b37ff
Thanks @Princesseuh! - Fix HTML component type causing an error when imported in the editor -
#7294
dd1a6b6c9
Thanks @matthewp! - Fix cookies not being set by middleware -
#7197
d72cfa7ca
Thanks @bluwy! - Fix nested astro-island hydration race condition -
#7262
144813f73
Thanks @andremralves! - Fix injected scripts not injected to injected routes -
#7242
890a2bc98
Thanks @JerryWu1234! - remove the white space after the doctype according to the property compressHTML
2.5.7
Patch Changes
-
#7215
6e27f2f6d
Thanks @bmenant! - Node adapter fallbacks to:authority
http2 pseudo-header whenhost
is nullish. -
#7233
96ae37eb0
Thanks @bluwy! - FixgetViteConfig
and Vitest setup with content collections -
#7136
fea306936
Thanks @johannesspohr! - Render arrays of components in parallel -
#7257
5156c4f90
Thanks @thiti-y! - fix: build fail upon have 'process.env' in *.md file. -
#7268
9e7366567
Thanks @bholmesdev! - Fix: ignore.json
files within content collection directories starting with an_
underscore. -
#7185
339529fc8
Thanks @bholmesdev! - Bring back improved style and script handling across content collection files. This addresses bugs found in a previous release to@astrojs/markdoc
.
2.5.6
Patch Changes
-
#7193
8b041bf57
Thanks @ematipico! - Refactor how pages are emitted during the internal bundling. Now each page is emitted as a separate entry point. -
#7218
6c7df28ab
Thanks @bluwy! - Fix CSS deduping and missing chunks -
#7235
ee2aca80a
Thanks @MoustaphaDev! - Prioritize dynamic prerendered routes over dynamic server routes -
#7192
7851f9258
Thanks @ematipico! - Detectmdx
files using their full extension -
#7244
bef3a75db
Thanks @bholmesdev! - Remove the auto-generated$entry
variable for Markdoc entries. To access frontmatter as a variable, you can passentry.data
as a prop where you render your content:--- import { getEntry } from 'astro:content'; const entry = await getEntry('docs', 'why-markdoc'); const { Content } = await entry.render(); --- <Content frontmatter={entry.data} />
-
#7204
52af9ad18
Thanks @bluwy! - Add error message ifAstro.glob
is called outside of an Astro file -
#7246
f5063d0a0
Thanks @bholmesdev! - Fix content collection build errors for empty collections or underscore files of type.json
. -
#7062
cf621340b
Thanks @wulinsheng123! - fix miss a head when the templaterender has a promise -
#7189
2bda7fb0b
Thanks @elevatebart! - fix: add astro-static-slot to the list of inert tags in astro css -
#7219
af3c5a2e2
Thanks @bluwy! - UseAstroError
forAstro.glob
errors -
#7139
f2f18b440
Thanks @Princesseuh! - Thesrc
property returned by ESM importing images withastro:assets
is now an absolute path, unlocking support for importing images outside the project. -
Updated dependencies [
bf63f615f
]:- @astrojs/webapi@2.2.0
2.5.5
Patch Changes
-
#6832
904131aec
Thanks @wulinsheng123! - fix a bug when Fragment is as a slot -
#7178
57e65d247
Thanks @bholmesdev! - Fix: revert Markdoc asset bleed changes. Production build issues were discovered that deserve a different fix.
2.5.4
Patch Changes
-
#7125
4ce8bf7c6
Thanks @bluwy! - Make vite-plugin-content-virtual-mod rungetEntrySlug
10 at a time to preventEMFILE: too many open files
error -
#7166
626dd41d0
Thanks @ematipico! - Move generation of renderers code into their own file -
#7174
92d1f017e
Thanks @ematipico! - Remove restriction around serialisable data forAstro.locals
-
#7172
2ca94269e
Thanks @Princesseuh! - Add types forimport.meta.env.ASSETS_PREFIX
andimport.meta.env.SITE
-
#7134
5b6a0312a
Thanks @alexvuka1! - value of var can be undefined when usingdefine:vars
-
#7171
79ba74832
Thanks @bluwy! - Prevent Vite watching on Astro config load
2.5.3
Patch Changes
-
#6758
f558a9e20
Thanks @bholmesdev! - Improve style and script handling across content collection files. This addresses style bleed present in@astrojs/markdoc
v0.1.0 -
#7143
b41963b77
Thanks @johannesspohr! - Render 404 page content when aResponse
with status 404 is returned from a page
2.5.2
Patch Changes
-
#7144
ba0636240
Thanks @lilnasy! - Fixed an issue where scripts that weren't safe to inline were inlined. -
#7150
8f418d13c
Thanks @MoustaphaDev! - fix no matched path when usinggetStaticPaths
withoutprerender
export.
2.5.1
Patch Changes
-
#7128
72f686a68
Thanks @johannesspohr! - Fix routes created byinjectRoute
for SSR -
#7132
319a0a7a0
Thanks @ematipico! - Emit middleware as an entrypoint during build -
#7036
852d59a8d
Thanks @ematipico! - Emit pages as dynamic import chunks during the build -
#7126
530fb9ebe
Thanks @bluwy! - Add route information when warning ofgetStaticPaths()
ignored -
#7118
3257dd289
Thanks @Princesseuh! - Fix unnecessary warning showing on start when a collection folder was empty. The warning was also enhanced to add more information about possible causes.
2.5.0
Minor Changes
-
#7071
e186ecc5e
Thanks @johannesspohr! - Render sibling components in parallel -
#6850
c6d7ebefd
Thanks @bholmesdev! - Content collections now support data formats including JSON and YAML. You can also create relationships, or references, between collections to pull information from one collection entry into another. Learn more on our updated Content Collections docs. -
#6991
719002ca5
Thanks @MoustaphaDev! - Enable experimental support for hybrid SSR with pre-rendering enabled by defaultastro.config.mjs
import { defineConfig } from 'astro/config'; export defaultdefineConfig({ output: 'hybrid', experimental: { hybridOutput: true, }, })
Then add
export const prerender = false
to any page or endpoint you want to opt-out of pre-rendering.src/pages/contact.astro
--- export const prerender = false; if (Astro.request.method === 'POST') { // handle form submission } --- <form method="POST"> <input type="text" name="name" /> <input type="email" name="email" /> <button type="submit">Submit</button> </form>
-
#7074
73ec6f6c1
Thanks @bluwy! - Integrations can add newclient:
directives through theastro:config:setup
hook'saddClientDirective()
API. To enable this API, the user needs to setexperimental.customClientDirectives
totrue
in their config.import { defineConfig } from 'astro/config'; import onClickDirective from 'astro-click-directive'; export default defineConfig({ integrations: [onClickDirective()], experimental: { customClientDirectives: true, }, });
export default function onClickDirective() { return { hooks: { 'astro:config:setup': ({ addClientDirective }) => { addClientDirective({ name: 'click', entrypoint: 'astro-click-directive/click.js', }); }, }, }; }
<Counter client:click />
The client directive file (e.g.
astro-click-directive/click.js
) should export a function of typeClientDirective
:import type { ClientDirective } from 'astro'; const clickDirective: ClientDirective = (load, opts, el) => { window.addEventListener( 'click', async () => { const hydrate = await load(); await hydrate(); }, { once: true } ); }; export default clickDirective;
-
#6706
763ff2d1e
Thanks @wulinsheng123! - Adds an opt-in way to minify the HTML output.Using the
compressHTML
option Astro will remove whitespace from Astro components. This only applies to components written in.astro
format and happens in the compiler to maximize performance. You can enable with:import { defineConfig } from 'astro/config'; export default defineConfig({ compressHTML: true, });
Compression occurs both in development mode and in the final build.
-
#7069
c1669c001
Thanks @Princesseuh! - AddedPolymorphic
type helper toastro/types
to easily create polymorphic components:--- import { HTMLTag, Polymorphic } from 'astro/types'; type Props<Tag extends HTMLTag> = Polymorphic<{ as: Tag }>; const { as: Tag, ...props } = Astro.props; --- <Tag {...props} />
-
#7093
3d525efc9
Thanks @matthewp! - Prevent removal of nested slots within islandsThis change introduces a new flag that renderers can add called
supportsAstroStaticSlot
. What this does is let Astro know that the render is sending<astro-static-slot>
as placeholder values for static (non-hydrated) slots which Astro will then remove.This change is completely backwards compatible, but fixes bugs caused by combining ssr-only and client-side framework components like so:
<Component> <div> <Component client:load> <span>Nested</span> </Component> </div> </Component>
Patch Changes
-
#7102
4516d7b22
Thanks @Princesseuh! - Fix image services not being usable on Edge runtimes -
#7044
914c439bc
Thanks @Steffan153! - Escape closing script tag withdefine:vars
-
#6851
e9fc2c221
Thanks @timozander! - Added warning message when using unsupported file extensions in pages/ -
#7106
075eee08f
Thanks @ematipico! - Fix middleware for API endpoints that useResponse
, and log a warning for endpoints that don't useResponse
. -
#7110
fc52681ba
Thanks @delucis! - Fix formatting in theNoMatchingRenderer
error message. -
#7095
fb84622af
Thanks @bholmesdev! - Generate headingid
s and populate theheadings
property for all Markdoc files -
#7011
cada10a46
Thanks @TheOtterlord! - Throw an error when unknown experimental keys are present -
#7091
cd410c5eb
Thanks @MoustaphaDev! - Fix double prepended forward slash in SSR -
#7108
410428672
Thanks @Princesseuh! - Fix imports using ?raw and ?url not working whenexperimental.assets
is enabled -
Updated dependencies [
826e02890
]:- @astrojs/markdown-remark@2.2.1
2.4.5
Patch Changes
-
#7000
c87d42e76
Thanks @craigjennings11! - Remove 'paths' requirement for tsconfig path aliasing -
#7055
4f1073a6a
Thanks @Princesseuh! - Fix astro:assets interfering with SSR query params ending with image extensions
2.4.4
Patch Changes
-
#7047
48395c815
Thanks @Princesseuh! - Fix/_image
endpoint not being prefixed with thebase
path in build SSR -
#6916
630f8c8ef
Thanks @bholmesdev! - Add fast lookups for content collection entries when usinggetEntryBySlug()
. This generates a lookup map to ensure O(1) retrieval.
2.4.3
Patch Changes
2.4.2
Patch Changes
-
#7009
1d4db68e6
Thanks @Princesseuh! - Fix types fromastro/client
not working properly due toclient-base.d.ts
being an non-ambient declaration file -
#7010
e9f0dd9b4
Thanks @ematipico! - Callnext()
without return anything should work, with a warning
2.4.1
Patch Changes
- #6995
71332cf96
Thanks @Princesseuh! - Move sharpImageService and squooshImageService functions toastro/config
so they can be imported
2.4.0
Minor Changes
-
#6990
818252acd
Thanks @Princesseuh! - Generated optimized images are now cached inside thenode_modules/.astro/assets
folder. The cached images will be used to avoid doing extra work and speed up subsequent builds. -
#6659
80e3d4d3d
Thanks @lilnasy! - Implement Inline Stylesheets RFC as experimental -
#6771
3326492b9
Thanks @matthewp! - Implements a new class-based scoping strategyThis implements the Scoping RFC, providing a way to opt in to increased style specificity for Astro component styles.
This prevents bugs where global styles override Astro component styles due to CSS ordering and the use of element selectors.
To enable class-based scoping, you can set it in your config:
import { defineConfig } from 'astro/config'; export default defineConfig({ scopedStyleStrategy: 'class', });
Note that the 0-specificity
:where
pseudo-selector is still the default strategy. The intent is to change'class'
to be the default in 3.0. -
#6959
cac4a321e
Thanks @bluwy! - Support<Code inline />
to output inline code HTML (nopre
tag) -
#6721
831b67cdb
Thanks @ematipico! - Implements a new experimental middleware in Astro.The middleware is available under the following experimental flag:
export default defineConfig({ experimental: { middleware: true, }, });
Or via CLI, using the new argument
--experimental-middleware
.Create a file called
middleware.{js,ts}
inside thesrc
folder, and export aonRequest
function.From
astro/middleware
, use thedefineMiddleware
utility to take advantage of type-safety, and use thesequence
utility to chain multiple middleware functions.Example:
import { defineMiddleware, sequence } from 'astro/middleware'; const redirects = defineMiddleware((context, next) => { if (context.request.url.endsWith('/old-url')) { return context.redirect('/new-url'); } return next(); }); const minify = defineMiddleware(async (context, next) => { const repsonse = await next(); const minifiedHtml = await minifyHtml(response.text()); return new Response(minifiedHtml, { status: 200, headers: response.headers, }); }); export const onRequest = sequence(redirects, minify);
-
#6932
49514e4ce
Thanks @bluwy! - Upgrade shiki to v0.14.1. This updates the shiki theme colors and adds the theme name to thepre
tag, e.g.<pre class="astro-code github-dark">
.
Patch Changes
-
#6973
0883fd487
Thanks @matthewp! - Ensure multiple cookies set in dev result in multiple set-cookie headers -
Updated dependencies [
49514e4ce
]:- @astrojs/markdown-remark@2.2.0
2.3.4
Patch Changes
-
#6967
a8a319aef
Thanks @bluwy! - Fixastro-entry
error on build with multiple JSX frameworks -
#6961
a695e44ae
Thanks @Princesseuh! - Fix getImage type -
#6956
367e61776
Thanks @lilnasy! - Changed where various parts of the build pipeline look to decide if a page should be prerendered. They now exclusively consider PageBuildData, allowing integrations to participate in the decision. -
#6969
77270cc2c
Thanks @bluwy! - Avoid removing leading slash forbuild.assetsPrefix
value in the build output -
#6910
895fa07d8
Thanks @natemoo-re! - Inlineprocess.env
boolean values (0
,1
,true
,false
) during the build. This helps with DCE and allows for betterexport const prerender
detection. -
#6958
72c6bf01f
Thanks @bluwy! - Fix content render imports flow -
#6952
e5bd084c0
Thanks @Princesseuh! - Update allowed Sharp versions to support 0.32.0
2.3.3
Patch Changes
-
#6940
a98df9374
Thanks @delucis! - Support custom 404s added viainjectRoute
or assrc/pages/404.html
-
#6948
50975f2ea
Thanks @imchell! - Placeholders for slots are cleaned in HTML String that is rendered -
#6848
ebae1eaf8
Thanks @Princesseuh! - Updateexperimental.assets
'simage.service
configuration to allow for a config option in addition to an entrypoint -
#6953
dc062f669
Thanks @Princesseuh! - Updateastro check
to use version 1.0.0 of the Astro language server -
Updated dependencies [
ac57b5549
]:- @astrojs/telemetry@2.1.1
- @astrojs/webapi@2.1.1
2.3.2
Patch Changes
2.3.1
Patch Changes
-
#6859
4c7ba4da0
Thanks @andremralves! - Fix Astro.params does not contain path parameter from URL with non-English characters. -
#6872
b6154d2d5
Thanks @bluwy! - Fix hoisted scripts path for linked package Astro components -
#6862
1f2699461
Thanks @jcdogo! - Fixes bug with assetsPrefix not being prepended to component-url and renderer-url in astro islands when using SSR mode. -
#6902
0afff3274
Thanks @bluwy! - Disable Vite optimizer for sync and config loading. Improve first page load time for warm server startup.
2.3.0
Minor Changes
Patch Changes
-
#6544
a9c22994e
Thanks @wulinsheng123! - Correctly generate directories for assets when users customise the output via rollup options. -
#6825
948a6d7be
Thanks @Princesseuh! - Fix unnecessary warning when using images inside thesrc/content
folder withexperimental.assets
-
Updated dependencies [
2511d58d5
]:- @astrojs/markdown-remark@2.1.4
2.2.3
Patch Changes
-
#6765
6c09ac03b
Thanks @Princesseuh! - Properly include the needed WASM files for the Squoosh service for Netlify and Vercel in SSR -
#6817
f882bc163
Thanks @bholmesdev! - Fix sourcemap warnings when using Content Collections and MDX with thevite.build.sourcemap
option -
#6819
76dd53e3f
Thanks @MoustaphaDev! - Fix fallback content showing unexpectedly in some cases -
#6582
7653cf9e9
Thanks @bluwy! - Fix CSS chunking and deduping between multiple Astro files and framework components
2.2.2
Patch Changes
-
#6811
60c16db6f
Thanks @bluwy! - Fix check CLI fs load fallback behaviour -
#6782
c12ca5ece
Thanks @amirhhashemi! - Force error overlay direction to be LTR
2.2.1
Patch Changes
-
#6766
72fed684a
Thanks @Xetera! - Exporting the ImageFunction in astro:content and grouping it under a SchemaContext -
#6772
45bff6fcc
Thanks @natemoo-re! - Allowimport.meta.env
values of0
,1
,true
, andfalse
to be used forexport const prerender
statements -
#6770
52d7a4a01
Thanks @Princesseuh! - Updated types to match newer Vite versions -
#6774
9e88e0f23
Thanks @bholmesdev! - Fix: remove oldslug()
type fromdefineCollection()
helper -
#6775
fa84f1a7d
Thanks @matthewp! - Support streaming inside of slots -
#6779
a98f6f418
Thanks @matthewp! - Prevent body head content injection in MDX when using layout -
#6781
7f74326b7
Thanks @bholmesdev! - Fixastro:server:setup
middlewares not applying. This resolves an issue with the Partytown integration in dev.
2.2.0
Minor Changes
-
#6703
a1108e037
Thanks @Princesseuh! - Moveimage()
to come fromschema
instead to fix it not working with refine and inside complex typesMigration:
Remove the
image
import fromastro:content
, and instead use a function to generate your schema, like such:import { defineCollection, z } from 'astro:content'; defineCollection({ schema: ({ image }) => z.object({ image: image().refine((img) => img.width >= 200, { message: 'image too small', }), }), });
-
#6714
ff0430786
Thanks @bluwy! - Addbuild.assetsPrefix
option for CDN support. If set, all Astro-generated asset links will be prefixed with it. For example, setting it tohttps://cdn.example.com
would generatehttps://cdn.example.com/_astro/penguin.123456.png
links.Also adds
import.meta.env.ASSETS_PREFIX
environment variable that can be used to manually create asset links not handled by Astro.
Patch Changes
-
#6753
489dd8d69
Thanks @bluwy! - FixgetViteConfig
return type -
#6744
a1a4f45b5
Thanks @Princesseuh! - Fix remote images in Markdown throwing errors when usingexperimental.assets
-
#6762
8b88e4cf1
Thanks @Princesseuh! - Improved error message when an error was encountered while generating types -
#6719
d54cbe413
Thanks @matthewp! - Better errors for when response is already sentThis adds clearer error messaging when a Response has already been sent to the browser and the developer attempts to use:
- Astro.cookies.set
- Astro.redirect
-
#6741
4c347ab51
Thanks @Princesseuh! - Fix content-type header being wrong in dev on images fromastro:assets
-
#6739
2f2e572e9
Thanks @Princesseuh! - Added more types and utilities exports related toastro:assets
to help building custom image components and image services -
Updated dependencies [
a1a4f45b5
]:- @astrojs/markdown-remark@2.1.3
2.1.9
Patch Changes
-
#6693
c0b7864a4
Thanks @bholmesdev! - Fix: avoid callingastro:server:setup
integration hook in production -
#6676
5e33c51a9
Thanks @bholmesdev! - Fix next and previous links for index routes when using pagination -
#6717
c2d4ae1cb
Thanks @Princesseuh! - Dynamically import check command to improve startup speed and prevent Astro from crashing due to language-server stuff -
#6679
08e92f4f8
Thanks @fcFn! - Fix incorrect path to file in error overlay on Win -
#6649
f0b732d32
Thanks @Princesseuh! - Improve error handling when usingastro:assets
-
#6710
a0bdf4ce2
Thanks @Princesseuh! - Fix multiple Image / getImage calls with the same image causing multiple duplicate images to be generated -
#6711
c04ea0d43
Thanks @Princesseuh! - Fix InferGetStaticParamsType and InferGetStaticPropsType not working when getStaticPaths wasn't async -
#6701
46ecf4662
Thanks @Princesseuh! - Remove unnecessary.wasm
files inside build output when possible
2.1.8
Patch Changes
-
#6675
1f783e320
Thanks @matthewp! - Prevent frontmatter errors from crashing the dev server -
#6688
2e92e9aa9
Thanks @JohannesKlauss! - Add a additional check fornull
on thereq.body
check inNodeApp.render
. -
#6578
adecda7d6
Thanks @wulinsheng123! - add new flag with open for dev and preview -
#6680
386336441
Thanks @koriwi! - Invalidates cache when changing serviceEntryPoint -
#6653
7c439868a
Thanks @bholmesdev! - Simplify Markdoc configuration with a newmarkdoc.config.mjs
file. This lets you import Astro components directly to render as Markdoc tags and nodes, without the need for the previouscomponents
property. This new configuration also unlocks passing variables to your Markdoc from theContent
component (see the new docs).Migration
Move any existing Markdoc config from your
astro.config
to a newmarkdoc.config.mjs
file at the root of your project. This should be applied as a default export, with the optionaldefineMarkdocConfig()
helper for autocomplete in your editor.This example configures an
aside
Markdoc tag. Note that components should be imported and applied to therender
attribute directly, instead of passing the name as a string:// markdoc.config.mjs import { defineMarkdocConfig } from '@astrojs/markdoc/config'; import Aside from './src/components/Aside.astro'; export default defineMarkdocConfig({ tags: { aside: { render: Aside, }, }, });
You should also remove the
components
prop from yourContent
components. Since components are imported into your config directly, this is no longer needed.--- - import Aside from '../components/Aside.astro'; import { getEntryBySlug } from 'astro:content'; const entry = await getEntryBySlug('docs', 'why-markdoc'); const { Content } = await entry.render(); --- <Content - components={{ Aside }} />
-
#6639
25cd3e574
Thanks @tony-sull! - Fixes an attribute naming mismatch in the definition for elements in astro.JSX -
#6353
4bf87c64f
Thanks @wulinsheng123! - Throw better error when a dynamic endpoint without additional extensions is prerendered withundefined
params. -
#6643
fc0ed9c53
Thanks @Princesseuh! - Fix images not having the proper path when usingbase
2.1.7
Patch Changes
-
#6192
b7194103e
Thanks @erg208! - Updated to fix the Node SSR fails on POST with Express JSON middleware -
#6630
cfcf2e2ff
Thanks @bholmesdev! - Support automatic image optimization for Markdoc images when usingexperimental.assets
. You can follow our Assets guide to enable this feature in your project. Then, start using relative or aliased image sources in your Markdoc files for automatic optimization:<!--Relative paths--> ![The Milky Way Galaxy](../assets/galaxy.jpg) <!--Or configured aliases--> ![Houston smiling and looking cute](~/assets/houston-smiling.jpg)
-
#6638
7daef9a29
Thanks @matthewp! - Avoid implicit head injection when a head is in the tree
2.1.6
Patch Changes
-
#6633
9caf2a9cc
Thanks @bholmesdev! - Fix failedastro sync
call when runningastro check
. This change also reverts alias support in CSS styles. -
#6627
d338b6f74
Thanks @Princesseuh! - Update frontmatter assets to be relative to the current file instead ofsrc/assets
2.1.5
Patch Changes
-
#6604
7f7a8504b
Thanks @Princesseuh! - Fix using optimized images in Markdown not working -
#6617
38e6ec21e
Thanks @MoustaphaDev! - Fix tsconfig alias regression -
#6588
f42f47dc6
Thanks @bholmesdev! - Allow access to content collection entry information (including parsed frontmatter and the entry slug) from your Markdoc using the$entry
variable:--- title: Hello Markdoc! --- # {% $entry.data.title %}
-
Updated dependencies [
7f7a8504b
]:- @astrojs/markdown-remark@2.1.2
2.1.4
Patch Changes
-
#6547
04dddd783
Thanks @Princesseuh! - Fix images having the wrong width and height when using the new astro:assets features if both dimensions were provided -
#6566
ea9b3dd72
Thanks @bluwy! - Support tsconfig aliases in styles -
#6472
bf024cb34
Thanks @wulinsheng123! - don't finish the action of the copy before removing all files. -
#6556
22955b895
Thanks @Princesseuh! - Fix Invalid Input error when trying to use a custom Image Service -
#6568
f413446a8
Thanks @Princesseuh! - Fix image() type to be compatible with ImageMetadata -
#6559
90e5f87d0
Thanks @Princesseuh! - Vendorimage-size
to fix CJS-related issues -
#6576
388190102
Thanks @bluwy! - Simplify internal resolver in dev -
#6536
035c0c4df
Thanks @Princesseuh! - Fix Image component andgetImage
not handling images from public correctly -
#6601
f112c12b1
Thanks @bluwy! - Fix plugin apply args when filtering -
#6586
689884251
Thanks @solelychloe! - fix: Add missing --watch flag for astro check when running astro check --help -
#6572
fa132e35c
Thanks @MoustaphaDev! - Properly handle empty markdown files in content collections -
#6555
f5fddafc2
Thanks @Princesseuh! - Add avalidateOptions
hook to the Image Service API in order to set default options and validate the passed options -
#6605
283734525
Thanks @Princesseuh! - Update tsconfig.json templates to ignore TypeScript 5.0 deprecations for the moment -
#6583
66858f1f2
Thanks @francoromanol! - Fix overflow title in error message -
#6558
6c465e958
Thanks @bluwy! - Fix prerendered 404 page handling in SSR -
Updated dependencies [
90e5f87d0
,f5fddafc2
]:- @astrojs/markdown-remark@2.1.1
2.1.3
Patch Changes
-
#6530
acf78c5e2
Thanks @Princesseuh! - Fix various inaccuracies with types related to the new Assets features:- getConfiguredImageService wasn't present on the astro:assets types.
- ImageMetadata wasn't exported
- Fixed wrong module declaration for
avif
,heic
andheif
files. - Add missing module declaration for SVGs imports
-
#6527
04e624d06
Thanks @bluwy! - Treeshake exported client components that are not imported -
#6533
cc90d7219
Thanks @Princesseuh! - Added a warning when trying to useexperimental.assets
with a not compatible adapter -
#6483
a9a6ae298
Thanks @Princesseuh! - Fix images defined in content collections schemas not working -
#6537
6a7cf0712
Thanks @matthewp! - Prevent astro:content from depending on Node builtins -
#6488
bfd67ea74
Thanks @matthewp! - Remove use of createRequire breaking non-Node hosts. -
#6503
f6eddffa0
Thanks @bholmesdev! - Add caching togetCollection()
queries for faster SSG production builds -
#6508
c63874090
Thanks @bholmesdev! - Improve content collection error formatting:- Bold the collection and entry that failed
- Consistently list the frontmatter key at the start of every error
- Rich errors for union types
-
#6485
d637d1ea5
Thanks @bluwy! - Fix@astrojs/prism
edgecase with strict package managers -
#6532
637f9bc72
Thanks @Princesseuh! - Fixenv.d.ts
changing types wrongly on every restart whenexperimental.assets
is enabled -
#6460
77a046e88
Thanks @bluwy! - Add default.npmrc
file when adding the Lit integration throughastro add lit
and usingpnpm
.
2.1.2
Patch Changes
2.1.1
Patch Changes
-
#6454
05fc7ae54
Thanks @Princesseuh! - Add support for ESM importing SVGs when usingastro:assets
-
#6455
cf0198316
Thanks @delucis! - Documentimage.service
configuration option -
#6459
964d55246
Thanks @bluwy! - Prevent HTML-escape of raw strings in<script>
and<style>
tags of Astro JSX -
#6465
65c07ce1b
Thanks @matthewp! - Fixes ESM imported assets to be root relative
2.1.0
Minor Changes
-
#6150
b087b83fe
Thanks @morellodev! - Add getStaticPaths type helpers to infer params and props -
#6344
694918a56
Thanks @Princesseuh! - Add a new experimental flag (experimental.assets
) to enable our new core Assets story.This unlocks a few features:
- A new built-in image component and JavaScript API to transform and optimize images.
- Relative images with automatic optimization in Markdown.
- Support for validating assets using content collections.
- and more!
See Assets (Experimental) on our docs site for more information on how to use this feature!
-
#6435
a20610609
Thanks @matthewp! - Expose the manifest to plugins via the astro:ssr-manifest virtual module -
#6394
a4a74ab70
Thanks @ematipico! - Add--help
to various commands:check
,sync
,dev
,preview
, andbuild
-
#6356
75921b3cd
Thanks @ematipico! - Added a new--watch
flag to the commandastro check
-
#6213
afbbc4d5b
Thanks @Princesseuh! - Updated compilation settings to disable downlevelling for Node 14
Patch Changes
-
#6209
fec583909
Thanks @bholmesdev! - Introduce the (experimental)@astrojs/markdoc
integration. This unlocks Markdoc inside your Content Collections, bringing support for Astro and UI components in your content. This also improves Astro core internals to make Content Collections extensible to more file types in the future.You can install this integration using the
astro add
command:astro add markdoc
Read the
@astrojs/markdoc
documentation for usage instructions, and browse the newwith-markdoc
starter to try for yourself. -
Updated dependencies [
694918a56
,afbbc4d5b
]:- @astrojs/markdown-remark@2.1.0
- @astrojs/telemetry@2.1.0
- @astrojs/webapi@2.1.0
2.0.18
Patch Changes
-
#6412
cd8469947
Thanks @liruifengv! - Remove redundant comments whenastro add
updateastro.config.mjs
-
#6426
e0844852d
Thanks @MoustaphaDev! - Prevent?inline
and?raw
css query suffixes from injecting style tags in development -
Updated dependencies [
0abd1d3e4
]:- @astrojs/webapi@2.0.3
2.0.17
Patch Changes
-
#6391
45501c531
Thanks @bluwy! - Teardown compiler after Vite build to free up memory when rendering pages -
#6392
ee8b2a067
Thanks @bluwy! - Run astro sync in build mode -
#6368
02a7266e3
Thanks @userquin! - Fix regression that caused some stateful Vite plugins to assume they were running indev
mode during thebuild
and vice versa. -
#6358
95164bfdd
Thanks @Princesseuh! - Add warning when using headers and encoding in endpoints in SSR
2.0.16
Patch Changes
-
#6363
d94aae776
Thanks @matthewp! - Fixes cases where head is injected in body when using Astro.slots.render() -
Updated dependencies [
5aa6580f7
]:- @astrojs/webapi@2.0.2
- @astrojs/telemetry@2.0.1
2.0.15
Patch Changes
-
#6323
5e26bc891
Thanks @Princesseuh! - Updated Undici to 5.20.0. This fixes a security issue and handling of cookies in certain cases in dev -
#6293
a156ecbb7
Thanks @MoustaphaDev! - Warn about setting theallowJs
compiler option only when thecontent
directory exists. -
#6320
ccd72e6bb
Thanks @wulinsheng123! - fix #6020 -
#6347
504c7bacb
Thanks @natemoo-re! - Fix internalgetSetCookie
usage forundici@5.20.x
-
#6333
63dda6ded
Thanks @ematipico! - Correctly emit mode when passingnode
to the commandastro add
-
#6330
f91a7f376
Thanks @MoustaphaDev! - Ensure prefixed underscore ignores only child paths of the content directory.
2.0.14
Patch Changes
-
#6268
933c651fb
Thanks @natemoo-re! - Do not transform--camelCase
custom properties to--camel-case
when they're in astyle
attribute.This bug fix is backwards-compatible because we will emit both
--camelCase
and--camel-case
temporarily. This behavior will be removed in a future version of Astro. -
Updated dependencies [
bb1801013
]:- @astrojs/webapi@2.0.1
2.0.13
Patch Changes
-
#6248
ef5cea4dc
Thanks @wulinsheng123! - Deno SSR with prerender=true complains about invalid URL scheme -
#6257
2fec47848
Thanks @bholmesdev! - Fix: prevent dev server hanging forgetCollection()
calls within a layout when using thelayout
prop
2.0.12
Patch Changes
-
#6238
deacd5443
Thanks @bholmesdev! - Fix: run integration setup hooks duringastro sync
-
#6244
1c678f7eb
Thanks @bluwy! - Fix hydrate loading path to prevent multiple instance loaded for circular imports -
#6229
c397be324
Thanks @MoustaphaDev! - Add support for.js/.mjs
file extensions for Content Collections configuration file.
2.0.11
Patch Changes
-
#6216
79783fc01
Thanks @matthewp! - Fix head injection in body with slots.render() and head buffering -
#6218
baa2dbb3b
Thanks @bholmesdev! - Fix: internal content collection error on spaces in file name -
#6049
8b7cb64da
Thanks @natemoo-re! - Preserve--root
CLI flag when restarting dev server
2.0.10
Patch Changes
-
#6183
436bd0934
Thanks @Jutanium! - Fixes the first-page value ofurl.prev
when paginating a spread route at the root -
#6198
a9bdd9cc4
Thanks @matthewp! - Fixes usage of Code component in Vercel -
#6182
938ad514c
Thanks @matthewp! - Ensure base configuration appended to content collection styles -
#6197
c75d319ee
Thanks @BryceRussell! - Fixborder
andframe
attribute types onTableHTMLAttributes
interface -
#6180
6fa6025b3
Thanks @matthewp! - Allow binary data to be returned from api routes in SSG -
#6196
3390cb844
Thanks @matthewp! - Fix head injection misplacement with Astro.slots.render()
2.0.9
Patch Changes
-
#6176
8bbdcf17d
Thanks @matthewp! - Take dynamic import into account in CSS ordering -
#6170
ec2f2a31d
Thanks @bholmesdev! - Show content config errors in overlay, instead of stopping the dev server.
2.0.8
Patch Changes
2.0.7
Patch Changes
-
#6161
f6fc662c3
Thanks @matthewp! - Prevent ?inline and ?raw CSS from being bundled as CSS -
#6149
592386b75
Thanks @bloycey! - Moved pagination error to AstroErrorData -
#6153
1b591a143
Thanks @torchsmith! - Respectvite.build.emptyOutDir
setting duringastro build
-
#6092
bf8d7366a
Thanks @bholmesdev! - Ensure vite config (aliases, custom modules, etc) is respected when loading the content collection config -
#6111
ec38a8921
Thanks @e111077! - Implement client:only functionality in Lit and add lit to the client:only warning -
#6124
f20a85b64
Thanks @FredKSchott! - Fix outdated error message inpaginate()
function. -
#6122
9f22ac3d0
Thanks @bholmesdev! - Content collections: Fix accidental "use underscore to ignore" logs for.DS_Store
files and underscored directory names. -
#6163
cee70f5c6
Thanks @Princesseuh! - Fix returning hex / base64 images from endpoints not working in dev -
#6114
ac7fb04d6
Thanks @bluwy! - Fix sourcemap generation when scanning files -
#6152
d1f5611fe
Thanks @matthewp! - Fix MDX related head placement bugsThis fixes a variety of head content placement bugs (such as page
<link>
) related to MDX, especially when used in content collections. Issues fixed:- Head content being placed in the body instead of the head.
- Head content missing when rendering an MDX component from within a nested Astro component.
-
#6119
2189170be
Thanks @matthewp! - Fix hoisted script propagation in content collection pages -
#6117
32abe49bd
Thanks @Princesseuh! - Fix polyfills not being available in certain cases
2.0.6
Patch Changes
2.0.5
Patch Changes
-
#6052
9793f19ec
Thanks @mayank99! - Error overlay will now show the error'scause
if available. -
#6070
f91615f5c
Thanks @AirBorne04! - * safe guard against TextEncode.encode(HTMLString) [errors on vercel edge]- safe guard against html.replace when html is undefined
-
#6064
2fb72c887
Thanks @bholmesdev! - Apply MDXcomponents
export when rendering as a content collection entry
2.0.4
Patch Changes
-
#6045
41e97158b
Thanks @natemoo-re! - Improve error handling when an Astro component is rendered manually -
#6036
e779c6242
Thanks @natemoo-re! - Improve error handling when top-levelreturn
is present
2.0.3
Patch Changes
-
#6035
b4432cd6b
Thanks @bholmesdev! - Fix: Astro component scripts now load in development when using MDX + Content Collections -
#6024
98a4a914b
Thanks @MoustaphaDev! - RemoverawContent()
andcompiledContent()
from MDX import types -
#6034
071e1dee7
Thanks @matthewp! - Ensure CSS injections properly when using multiple layouts -
#5927
322e059d0
Thanks @izmttk! - Fix undefinedremarkPluginFrontmatter
after callingrender
method -
#6006
b994f6f35
Thanks @tony-sull! - Makes theAstroCookies
type available as an import from the main "astro" package -
#5998
12c68343c
Thanks @andersk! - UpdategetCollection()
filter to support type guards or unknown values
2.0.2
Patch Changes
-
#5983
b53e0717b
Thanks @natemoo-re! - Fixes a dev server edge case where prerender + getStaticPaths would not 404 on an unmatched route -
#5992
60b32d585
Thanks @HiDeoo! - FixAstro.url.protocol
when using the @astrojs/node SSR adapter with HTTPS -
#5971
883e0cc29
Thanks @JLarky! - improve error message: change @astrojs/solid to @astrojs/solid-js -
#5970
dabce6b8c
Thanks @bholmesdev! - Add type guard support to filters ongetCollection()
-
#5952
aedf23f85
Thanks @wulinsheng123! - Fix custom theme handling for<Code>
component -
Updated dependencies [
7abb1e905
]:- @astrojs/markdown-remark@2.0.1
2.0.1
Patch Changes
-
#5969
f4c71e5eb
Thanks @matthewp! - Fix usage of logger in Vercel EdgeThis protects against usage of
process
global in shimmed environments. -
#5962
46b6e1426
Thanks @MoustaphaDev! - Fix Content Collections not loading config file when there are spaces in the folder tree -
#5972
02549b8ce
Thanks @bluwy! - Correctly detect Node.js version
2.0.0
Note
This is a detailed changelog of all changes in Astro v2.
See our upgrade guide for an overview of steps needed to upgrade an existing project.
Major Changes
-
#5687
e2019be6f
Thanks @bholmesdev! - Give remark and rehype plugins access to user frontmatter via frontmatter injection. This meansdata.astro.frontmatter
is now the complete Markdown or MDX document's frontmatter, rather than an empty object.This allows plugin authors to modify existing frontmatter, or compute new properties based on other properties. For example, say you want to compute a full image URL based on an
imageSrc
slug in your document frontmatter:export function remarkInjectSocialImagePlugin() { return function (tree, file) { const { frontmatter } = file.data.astro; frontmatter.socialImageSrc = new URL(frontmatter.imageSrc, 'https://my-blog.com/').pathname; }; }
When using Content Collections, you can access this modified frontmatter using the
remarkPluginFrontmatter
property returned when rendering an entry.Migration instructions
Plugin authors should now check for user frontmatter when applying defaults.
For example, say a remark plugin wants to apply a default
title
if none is present. Add a conditional to check if the property is present, and update if none exists:export function remarkInjectTitlePlugin() { return function (tree, file) { const { frontmatter } = file.data.astro; + if (!frontmatter.title) { frontmatter.title = 'Default title'; + } } }
This differs from previous behavior, where a Markdown file's frontmatter would always override frontmatter injected via remark or reype.
-
#5891
05caf445d
Thanks @bholmesdev! - Remove deprecated Markdown APIs from Astro v0.X. This includesgetHeaders()
, the.astro
property for layouts, and therawContent()
andcompiledContent()
error messages for MDX. -
#5778
49ab4f231
Thanks @bluwy! - Remove proload to load the Astro config. It will now use NodeJS and Vite to load the config only. -
#5728
8fb28648f
Thanks @natemoo-re! - The previously experimental features--experimental-error-overlay
and--experimental-prerender
, both added in v1.7.0, are now the default.You'll notice that the error overlay during
astro dev
has a refreshed visual design and provides more context for your errors.The
prerender
feature is now enabled by default when usingoutput: 'server'
. To prerender a particular page, addexport const prerender = true
to your frontmatter.Warning
Integration authors that previously relied on the exact structure of Astro's v1.0 build output may notice some changes to our output file structure. Please test your integrations to ensure compatability. Users that have configured a custom
vite.build.rollupOptions.output.chunkFileNames
should ensure that their Astro project is configured as an ESM Node project. Either include"type": "module"
in your rootpackage.json
file or use the.mjs
extension forchunkFileNames
. -
#5782
1f92d64ea
Thanks @Princesseuh! - Remove support for Node 14. Minimum supported Node version is now >=16.12.0 -
#5771
259a539d7
Thanks @matthewp! - Removes support for astroFlavoredMarkdownIn 1.0 Astro moved the old Astro Flavored Markdown (also sometimes called Components in Markdown) to a legacy feature. This change removes the
legacy.astroFlavoredMarkdown
option completely.In 2.0 this feature will not be available in Astro at all. We recommend migration to MDX for those were still using this feature in 1.x.
-
#5941
304823811
Thanks @bholmesdev! - Content collections: Introduce a newslug
frontmatter field for overriding the generated slug. This replaces the previousslug()
collection config option from Astro 1.X and the 2.0 beta.When present in a Markdown or MDX file, this will override the generated slug for that entry.
# src/content/blog/post-1.md --- title: Post 1 + slug: post-1-custom-slug ---
Astro will respect this slug in the generated
slug
type and when using thegetEntryBySlug()
utility:--- import { getEntryBySlug } from 'astro:content'; // Retrieve `src/content/blog/post-1.md` by slug with type safety const post = await getEntryBySlug('blog', 'post-1-custom-slug'); ---
Migration
If you relied on the
slug()
config option, you will need to move all custom slugs toslug
frontmatter properties in each collection entry.Additionally, Astro no longer allows
slug
as a collection schema property. This ensures Astro can manage theslug
property for type generation and performance. Remove this property from your schema and any relevantslug()
configuration:const blog = defineCollection({ schema: z.object({ - slug: z.string().optional(), }), - slug({ defaultSlug, data }) { - return data.slug ?? defaultSlug; - }, })
-
#5753
302e0ef8f
Thanks @bluwy! - Default preview host tolocalhost
instead of127.0.0.1
. This allows the static server and integration preview servers to serve under ipv6. -
#5716
dd56c1941
Thanks @bluwy! - Remove MDX Fragment hack. This was used by@astrojs/mdx
to access theFragment
component, but isn't required anymore since@astrojs/mdx
v0.12.1. -
#5584
9963c6e4d
& #5842c4b0cb8bf
Thanks @wulinsheng123 and @natemoo-re! - Breaking Change: client assets are built to an_astro
directory in the build output directory. Previously these were built to various locations, includingassets/
,chunks/
and the root of build output.You can control this location with the new
build
configuration option namedassets
. -
#5893
be901dc98
Thanks @matthewp! - RenamegetEntry
togetEntryBySlug
This change moves
getEntry
togetEntryBySlug
and accepts a slug rather than an id.In order to improve support in
[id].astro
routes, particularly in SSR where you do not know what the id of a collection is. UsinggetEntryBySlug
instead allows you to map the[id]
param in your route to the entry. You can use it like this:--- import { getEntryBySlug } from 'astro:content'; const entry = await getEntryBySlug('docs', Astro.params.id); if (!entry) { return new Response(null, { status: 404, }); } --- <!-- You have an entry! Use it! -->
-
#5685
f6cf92b48
Thanks @bluwy! - Upgrade to Vite 4. Please see its migration guide for more information. -
#5724
16c7d0bfd
Thanks @bluwy! - Remove outdated Vue info log. RemovetoString
support forRenderTemplateResult
. -
#5684
a9c292026
& #576993e633922
Thanks @bholmesdev! - Refine Markdown and MDX configuration options for ease-of-use.-
Markdown
-
Replace the
extendDefaultPlugins
option with agfm
boolean and asmartypants
boolean. These are enabled by default, and can be disabled to remove GitHub-Flavored Markdown and SmartyPants. -
Ensure GitHub-Flavored Markdown and SmartyPants are applied whether or not custom
remarkPlugins
orrehypePlugins
are configured. If you want to apply custom plugins and remove Astro's default plugins, manually setgfm: false
andsmartypants: false
in your config.
-
-
Migrate
extendDefaultPlugins
togfm
andsmartypants
You may have disabled Astro's built-in plugins (GitHub-Flavored Markdown and Smartypants) with the
extendDefaultPlugins
option. This has now been split into 2 flags to disable each plugin individually:markdown.gfm
to disable GitHub-Flavored Markdownmarkdown.smartypants
to disable SmartyPants
// astro.config.mjs import { defineConfig } from 'astro/config'; export default defineConfig({ markdown: { - extendDefaultPlugins: false, + smartypants: false, + gfm: false, } });
Additionally, applying remark and rehype plugins no longer disables
gfm
andsmartypants
. You will need to opt-out manually by settinggfm
andsmartypants
tofalse
. -
MDX
-
Support all Markdown configuration options (except
drafts
) from your MDX integration config. This includessyntaxHighlighting
andshikiConfig
options to further customize the MDX renderer. -
Simplify
extendPlugins
to anextendMarkdownConfig
option. MDX options will default to their equivalent in your Markdown config. By settingextendMarkdownConfig
to false, you can "eject" to set your own syntax highlighting, plugins, and more.
-
-
Migrate MDX's
extendPlugins
toextendMarkdownConfig
You may have used the
extendPlugins
option to manage plugin defaults in MDX. This has been replaced by 3 flags:extendMarkdownConfig
(true
by default) to toggle Markdown config inheritance. This replaces theextendPlugins: 'markdown'
option.gfm
(true
by default) andsmartypants
(true
by default) to toggle GitHub-Flavored Markdown and SmartyPants in MDX. This replaces theextendPlugins: 'defaults'
option.
-
-
#5717
a3a7fc929
Thanks @bluwy! - Removestyle.postcss
Astro config. Refactor tailwind integration to configure throughvite
instead. Also disablesautoprefixer
in dev. -
#5825
52209ca2a
Thanks @bholmesdev! - Baseline the experimentalcontentCollections
flag. You're free to remove this from your astro config!import { defineConfig } from 'astro/config'; export default defineConfig({ - experimental: { contentCollections: true } })
-
#5707
5eba34fcc
Thanks @bluwy! - Remove deprecatedAstro
global APIs, includingAstro.resolve
,Astro.fetchContent
, andAstro.canonicalURL
.-
Astro.resolve
You can resolve asset paths using
import
instead. For example:--- import 'style.css'; import imageUrl from './image.png'; --- <img src={imageUrl} />
See the v0.25 migration guide for more information.
-
Astro.fetchContent
Use
Astro.glob
instead to fetch markdown files, or migrate to the Content Collections feature.let allPosts = await Astro.glob('./posts/*.md');
-
Astro.canonicalURL
Use
Astro.url
instead to construct the canonical URL.const canonicalURL = new URL(Astro.url.pathname, Astro.site);
-
-
#5608
899214298
Thanks @konojunya! - A trailing slash will not be automatically appended toimport.meta.env.SITE
. Instead, it will be the value of thesite
config as is. This may affect usages of${import.meta.env.SITE}image.png
, which will need to be updated accordingly. -
#5707
5eba34fcc
Thanks @bluwy! - RemovebuildConfig
option parameter from integrationastro:build:start
hook in favour of thebuild.config
option in theastro:config:setup
hook.export default function myIntegration() { return { name: 'my-integration', hooks: { 'astro:config:setup': ({ updateConfig }) => { updateConfig({ build: { client: '...', server: '...', serverEntry: '...', }, }); }, }, }; }
Minor Changes
-
#5901
a342a486c
Thanks @bluwy! - The fallback Svelte preprocessor will only be applied if a custompreprocess
option is not passed to thesvelte()
integration option, or in thesvelte.config.js
file.To support IDE autocompletion, or if you're migrating from
@astrojs/svelte
v1, you can create asvelte.config.js
file with:import { vitePreprocess } from '@astrojs/svelte'; export default { preprocess: vitePreprocess(), };
This file will also be generated by
astro add svelte
by default. -
#5786
c2180746b
Thanks @bholmesdev! - Move generated content collection types to a.astro
directory. This replaces the previously generatedsrc/content/types.generated.d.ts
file.If you're using Git for version control, we recommend ignoring this generated directory by adding
.astro
to your .gitignore.Astro will also generate the TypeScript reference path to include
.astro
types in your project. This will update your project'ssrc/env.d.ts
file, or write one if none exists. -
#5826
840412128
Thanks @bholmesdev! - Allow Zod objects, unions, discriminated unions, intersections, and transform results as content collection schemas.Migration
Astro requires a
z.object(...)
wrapper on all content collection schemas. Update your content collections config like so:// src/content/config.ts import { z, defineCollection } from 'astro:content'; const blog = defineCollection({ - schema: { + schema: z.object({ ... })
-
#5823
1f49cddf9
Thanks @delucis! - Generate content types when runningastro check
-
#5832
2303f9514
Thanks @HiDeoo! - Add support for serving well-known URIs with the @astrojs/node SSR adapter
Patch Changes
-
#5855
16dc36a87
Thanks @natemoo-re! - Remove legacy compiler error handling -
#5822
01f3f463b
Thanks @natemoo-re! - Fix edge case with bundle generation by emitting a single chunk for pages -
#5803
ae8a012a7
Thanks @bluwy! - Upgrade compiler and handle breaking changes -
#5840
cf2de5422
Thanks @chenxsan! - Persist CLI flags when restarting the dev server -
#5884
ce5c5dbd4
Thanks @MoustaphaDev! - Add a theme toggle button to the error overlay -
#5824
665a2c222
Thanks @bholmesdev! - Better handle content type generation failures:- Generate types when content directory is empty
- Log helpful error when running
astro sync
without a content directory - Avoid swallowing
config.ts
syntax errors from Vite
-
#5499
4987d6f44
Thanks @bluwy! - Handle custom injected entry files during build -
#5734
55cea0a9d
Thanks @natemoo-re! - Fixprerender
when used withgetStaticPaths
-
#5845
e818cc046
Thanks @bluwy! - Fix importing client-side components with alias -
#5849
8c100a6fe
Thanks @bluwy! - Handle server restart from Vite plugins -
#5756
116d8835c
Thanks @matthewp! - Fix for hoisted scripts in project with spaces in the file path -
#5917
7325df412
Thanks @natemoo-re! - Fix duplicate CSS in dev mode whenvite.css.devSourcemap
is provided -
#5743
2a5786419
Thanks @Princesseuh! - Add error location during build for user-generated errors -
#5761
fa8c131f8
Thanks @bholmesdev! - Add helpful error message when the MDX integration is missing. -
#5896
64b8082e7
Thanks @natemoo-re! - Update@astrojs/compiler
tov1.0.0
-
#5829
23dc9ea96
Thanks @giuseppelt! - FixCode.astro
shiki css class replace logic -
#5836
63a6ceb38
Thanks @natemoo-re! - Fix route matching when path includes special characters -
#5909
5fd9208d4
Thanks @jasikpark! - Update compiler to 1.0.1 -
#5852
3a00ecb3e
Thanks @rishi-raj-jain! - Respectvite.envPrefix
if provided -
#5872
b66d7195c
Thanks @bluwy! - EnableskipLibCheck
by default -
Updated dependencies [
93e633922
,e2019be6f
,1f92d64ea
,12f65a4d5
,46ecd5de3
,16107b6a1
,c55fbcb8e
,a9c292026
,1f92d64ea
,52209ca2a
,7572f7402
]:- @astrojs/markdown-remark@2.0.0
- @astrojs/telemetry@2.0.0
- @astrojs/webapi@2.0.0
2.0.0-beta.4
See changes in 2.0.0-beta.4
Major Changes
-
#5941
304823811
Thanks @bholmesdev! - Content collections: Introduce a newslug
frontmatter field for overriding the generated slug. This replaces the previousslug()
collection config option from Astro 1.X and the 2.0 beta.When present in a Markdown or MDX file, this will override the generated slug for that entry.
# src/content/blog/post-1.md --- title: Post 1 + slug: post-1-custom-slug ---
Astro will respect this slug in the generated
slug
type and when using thegetEntryBySlug()
utility:--- import { getEntryBySlug } from 'astro:content'; // Retrieve `src/content/blog/post-1.md` by slug with type safety const post = await getEntryBySlug('blog', 'post-1-custom-slug'); ---
Migration
If you relied on the
slug()
config option, you will need to move all custom slugs toslug
frontmatter properties in each collection entry.Additionally, Astro no longer allows
slug
as a collection schema property. This ensures Astro can manage theslug
property for type generation and performance. Remove this property from your schema and any relevantslug()
configuration:const blog = defineCollection({ schema: z.object({ - slug: z.string().optional(), }), - slug({ defaultSlug, data }) { - return data.slug ?? defaultSlug; - }, })
Patch Changes
-
#5499
4987d6f44
Thanks @bluwy! - Handle custom injected entry files during build -
#5917
7325df412
Thanks @natemoo-re! - Fix duplicate CSS in dev mode whenvite.css.devSourcemap
is provided -
#5909
5fd9208d4
Thanks @jasikpark! - Update compiler to 1.0.1 -
Updated dependencies [
46ecd5de3
]:- @astrojs/webapi@2.0.0-beta.1
2.0.0-beta.3
See changes in 2.0.0-beta.3
Major Changes
-
#5891
05caf445d
Thanks @bholmesdev! - Remove deprecated Markdown APIs from Astro v0.X. This includesgetHeaders()
, the.astro
property for layouts, and therawContent()
andcompiledContent()
error messages for MDX. -
#5893
be901dc98
Thanks @matthewp! - Move getEntry to getEntryBySlugThis change moves
getEntry
togetEntryBySlug
and accepts a slug rather than an id.In order to improve support in
[id].astro
routes, particularly in SSR where you do not know what the id of a collection is. UsinggetEntryBySlug
instead allows you to map the[id]
param in your route to the entry. You can use it like this:--- import { getEntryBySlug } from 'astro:content'; const entry = await getEntryBySlug('docs', Astro.params.id); if (!entry) { return new Response(null, { status: 404, }); } --- <!-- You have an entry! Use it! -->
-
#5608
899214298
Thanks @konojunya! - A trailing slash will not be automatically appended toimport.meta.env.SITE
. Instead, it will be the value of thesite
config as is. This may affect usages of${import.meta.env.SITE}image.png
, which will need to be updated accordingly.
Minor Changes
-
#5901
a342a486c
Thanks @bluwy! - The fallback Svelte preprocessor will only be applied if a custompreprocess
option is not passed to thesvelte()
integration option, or in thesvelte.config.js
file.To support IDE autocompletion, or if you're migrating from
@astrojs/svelte
v1, you can create asvelte.config.js
file with:import { vitePreprocess } from '@astrojs/svelte'; export default { preprocess: vitePreprocess(), };
This file will also be generated by
astro add svelte
by default.
Patch Changes
-
#5855
16dc36a87
Thanks @natemoo-re! - Remove legacy compiler error handling -
#5884
ce5c5dbd4
Thanks @MoustaphaDev! - Add a theme toggle button to the error overlay -
#5845
e818cc046
Thanks @bluwy! - Fix importing client-side components with alias -
#5849
8c100a6fe
Thanks @bluwy! - Handle server restart from Vite plugins -
#5896
64b8082e7
Thanks @natemoo-re! - Update@astrojs/compiler
tov1.0.0
-
#5852
3a00ecb3e
Thanks @rishi-raj-jain! - Respectvite.envPrefix
if provided -
#5872
b66d7195c
Thanks @bluwy! - EnableskipLibCheck
by default
2.0.0-beta.2
See changes in 2.0.0-beta.2
Major Changes
-
#5782
1f92d64ea
Thanks @Princesseuh! - Remove support for Node 14. Minimum supported Node version is now >=16.12.0 -
#5753
302e0ef8f
Thanks @bluwy! - Default preview host tolocalhost
instead of127.0.0.1
. This allows the static server and integration preview servers to serve under ipv6. -
#5842
c4b0cb8bf
Thanks @natemoo-re! - Breaking Change: client assets are built to an_astro
directory in the build output directory. Previously these were built to various locations, includingassets/
,chunks/
and the root of build output.You can control this location with the new
build
configuration option namedassets
. -
#5825
52209ca2a
Thanks @bholmesdev! - Baseline the experimentalcontentCollections
flag. You're free to remove this from your astro config!import { defineConfig } from 'astro/config'; export default defineConfig({ - experimental: { contentCollections: true } })
Minor Changes
-
#5786
c2180746b
Thanks @bholmesdev! - Move generated content collection types to a.astro
directory. This replaces the previously generatedsrc/content/types.generated.d.ts
file.If you're using Git for version control, we recommend ignoring this generated directory by adding
.astro
to your .gitignore.Astro will also generate the TypeScript reference path to include
.astro
types in your project. This will update your project'ssrc/env.d.ts
file, or write one if none exists. -
#5826
840412128
Thanks @bholmesdev! - Allow Zod objects, unions, discriminated unions, intersections, and transform results as content collection schemas.Migration
Astro requires a
z.object(...)
wrapper on all content collection schemas. Update your content collections config like so:// src/content/config.ts import { z, defineCollection } from 'astro:content'; const blog = defineCollection({ - schema: { + schema: z.object({ ... })
-
#5823
1f49cddf9
Thanks @delucis! - Generate content types when runningastro check
-
#5832
2303f9514
Thanks @HiDeoo! - Add support for serving well-known URIs with the @astrojs/node SSR adapter
Patch Changes
-
#5822
01f3f463b
Thanks @natemoo-re! - Fix edge case with bundle generation by emitting a single chunk for pages -
#5803
ae8a012a7
Thanks @bluwy! - Upgrade compiler and handle breaking changes -
#5840
cf2de5422
Thanks @chenxsan! - Persist CLI flags when restarting the dev server -
#5824
665a2c222
Thanks @bholmesdev! - Better handle content type generation failures:- Generate types when content directory is empty
- Log helpful error when running
astro sync
without a content directory - Avoid swallowing
config.ts
syntax errors from Vite
-
#5829
23dc9ea96
Thanks @giuseppelt! - FixCode.astro
shiki css class replace logic -
#5836
63a6ceb38
Thanks @natemoo-re! - Fix route matching when path includes special characters -
Updated dependencies [
1f92d64ea
,12f65a4d5
,16107b6a1
,c55fbcb8e
,1f92d64ea
,52209ca2a
,7572f7402
]:- @astrojs/telemetry@2.0.0-beta.0
- @astrojs/markdown-remark@2.0.0-beta.2
- @astrojs/webapi@2.0.0-beta.0
2.0.0-beta.1
See changes in 2.0.0-beta.1
Major Changes
-
#5778
49ab4f231
Thanks @bluwy! - Remove proload to load the Astro config. It will now use NodeJS and Vite to load the config only. -
#5771
259a539d7
Thanks @matthewp! - Removes support for astroFlavoredMarkdownIn 1.0 Astro moved the old Astro Flavored Markdown (also sometimes called Components in Markdown) to a legacy feature. This change removes the
legacy.astroFlavoredMarkdown
option completely.In 2.0 this feature will not be available in Astro at all. We recommend migration to MDX for those were still using this feature in 1.x.
-
#5717
a3a7fc929
Thanks @bluwy! - Removestyle.postcss
Astro config. Refactor tailwind integration to configure throughvite
instead. Also disablesautoprefixer
in dev.
Minor Changes
-
#5769
93e633922
Thanks @bholmesdev! - Introduce asmartypants
flag to opt-out of Astro's default SmartyPants plugin.{ markdown: { smartypants: false, } }
Migration
You may have disabled Astro's built-in plugins (GitHub-Flavored Markdown and Smartypants) with the
extendDefaultPlugins
option. This has now been split into 2 flags to disable each plugin individually:markdown.gfm
to disable GitHub-Flavored Markdownmarkdown.smartypants
to disable SmartyPants
// astro.config.mjs import { defineConfig } from 'astro/config'; export default defineConfig({ markdown: { - extendDefaultPlugins: false, + smartypants: false, + gfm: false, } });
Patch Changes
-
#5734
55cea0a9d
Thanks @natemoo-re! - Fixprerender
when used withgetStaticPaths
-
#5756
116d8835c
Thanks @matthewp! - Fix for hoisted scripts in project with spaces in the file path -
#5743
2a5786419
Thanks @Princesseuh! - Add error location during build for user-generated errors -
#5761
fa8c131f8
Thanks @bholmesdev! - Add helpful error message when the MDX integration is missing. -
Updated dependencies [
93e633922
]:- @astrojs/markdown-remark@2.0.0-beta.1
2.0.0-beta.0
See changes in 2.0.0-beta.0
Major Changes
-
#5687
e2019be6f
Thanks @bholmesdev! - Give remark and rehype plugins access to user frontmatter via frontmatter injection. This meansdata.astro.frontmatter
is now the complete Markdown or MDX document's frontmatter, rather than an empty object.This allows plugin authors to modify existing frontmatter, or compute new properties based on other properties. For example, say you want to compute a full image URL based on an
imageSrc
slug in your document frontmatter:export function remarkInjectSocialImagePlugin() { return function (tree, file) { const { frontmatter } = file.data.astro; frontmatter.socialImageSrc = new URL(frontmatter.imageSrc, 'https://my-blog.com/').pathname; }; }
Content Collections - new
remarkPluginFrontmatter
propertyWe have changed inject frontmatter to modify frontmatter in our docs to improve discoverability. This is based on support forum feedback, where "injection" is rarely the term used.
To reflect this, the
injectedFrontmatter
property has been renamed toremarkPluginFrontmatter
. This should clarify this plugin is still separate from thedata
export Content Collections expose today.Migration instructions
Plugin authors should now check for user frontmatter when applying defaults.
For example, say a remark plugin wants to apply a default
title
if none is present. Add a conditional to check if the property is present, and update if none exists:export function remarkInjectTitlePlugin() { return function (tree, file) { const { frontmatter } = file.data.astro; + if (!frontmatter.title) { frontmatter.title = 'Default title'; + } } }
This differs from previous behavior, where a Markdown file's frontmatter would always override frontmatter injected via remark or reype.
-
#5728
8fb28648f
Thanks @natemoo-re! - The previously experimental features--experimental-error-overlay
and--experimental-prerender
, both added in v1.7.0, are now the default.You'll notice that the error overlay during
astro dev
has a refreshed visual design and provides more context for your errors.The
prerender
feature is now enabled by default when usingoutput: 'server'
. To prerender a particular page, addexport const prerender = true
to your frontmatter.Warning
Integration authors that previously relied on the exact structure of Astro's v1.0 build output may notice some changes to our output file structure. Please test your integrations to ensure compatability. Users that have configured a custom
vite.build.rollupOptions.output.chunkFileNames
should ensure that their Astro project is configured as an ESM Node project. Either include"type": "module"
in your rootpackage.json
file or use the.mjs
extension forchunkFileNames
. -
#5716
dd56c1941
Thanks @bluwy! - Remove MDX Fragment hack. This was used by@astrojs/mdx
to access theFragment
component, but isn't require anymore since@astrojs/mdx
v0.12.1. -
#5685
f6cf92b48
Thanks @bluwy! - Upgrade to Vite 4. Please see its migration guide for more information. -
#5724
16c7d0bfd
Thanks @bluwy! - Remove outdated Vue info log. RemovetoString
support forRenderTemplateResult
. -
#5684
a9c292026
Thanks @bholmesdev! - Refine Markdown and MDX configuration options for ease-of-use.Markdown
- Remove
remark-smartypants
from Astro's default Markdown plugins. - Replace the
extendDefaultPlugins
option with a simplifiedgfm
boolean. This is enabled by default, and can be disabled to remove GitHub-Flavored Markdown. - Ensure GitHub-Flavored Markdown is applied whether or not custom
remarkPlugins
orrehypePlugins
are configured. If you want to apply custom plugins and remove GFM, manually setgfm: false
in your config.
MDX
- Support all Markdown configuration options (except
drafts
) from your MDX integration config. This includessyntaxHighlighting
andshikiConfig
options to further customize the MDX renderer. - Simplify
extendDefaults
to anextendMarkdownConfig
option. MDX options will default to their equivalent in your Markdown config. By settingextendMarkdownConfig
to false, you can "eject" to set your own syntax highlighting, plugins, and more.
Migration
To preserve your existing Markdown and MDX setup, you may need some configuration changes:
Smartypants manual installation
Smartypants has been removed from Astro's default setup. If you rely on this plugin, install
remark-smartypants
and apply to yourastro.config.*
:// astro.config.mjs import { defineConfig } from 'astro/config'; + import smartypants from 'remark-smartypants'; export default defineConfig({ markdown: { + remarkPlugins: [smartypants], } });
Migrate
extendDefaultPlugins
togfm
You may have disabled Astro's built-in plugins (GitHub-Flavored Markdown and Smartypants) with the
extendDefaultPlugins
option. Since Smartypants has been removed, this has been renamed togfm
.// astro.config.mjs import { defineConfig } from 'astro/config'; export default defineConfig({ markdown: { - extendDefaultPlugins: false, + gfm: false, } });
Additionally, applying remark and rehype plugins no longer disables
gfm
. You will need to opt-out manually by settinggfm
tofalse
.Migrate MDX's
extendPlugins
toextendMarkdownConfig
You may have used the
extendPlugins
option to manage plugin defaults in MDX. This has been replaced by 2 flags:extendMarkdownConfig
(true
by default) to toggle Markdown config inheritance. This replaces theextendPlugins: 'markdown'
option.gfm
(true
by default) to toggle GitHub-Flavored Markdown in MDX. This replaces theextendPlugins: 'defaults'
option.
- Remove
-
#5707
5eba34fcc
Thanks @bluwy! - Remove deprecatedAstro
global APIs, includingAstro.resolve
,Astro.fetchContent
, andAstro.canonicalURL
.Astro.resolve
You can resolve asset paths using
import
instead. For example:--- import 'style.css'; import imageUrl from './image.png'; --- <img src={imageUrl} />
See the v0.25 migration guide for more information.
Astro.fetchContent
Use
Astro.glob
instead to fetch markdown files, or migrate to the Content Collections feature.let allPosts = await Astro.glob('./posts/*.md');
Astro.canonicalURL
Use
Astro.url
instead to construct the canonical URL.const canonicalURL = new URL(Astro.url.pathname, Astro.site);
-
#5707
5eba34fcc
Thanks @bluwy! - RemovebuildConfig
option parameter from integrationastro:build:start
hook in favour of thebuild.config
option in theastro:config:setup
hook.export default function myIntegration() { return { name: 'my-integration', hooks: { 'astro:config:setup': ({ updateConfig }) => { updateConfig({ build: { client: '...', server: '...', serverEntry: '...', }, }); }, }, }; }
Patch Changes
1.9.2
Patch Changes
1.9.1
Patch Changes
1.9.0
Minor Changes
- #5666
bf210f784
Thanks @bholmesdev! - Correctly handle spaces and capitalization insrc/content/
file names. This introduces github-slugger for slug generation to ensure slugs are usable bygetStaticPaths
. Changes:- Resolve spaces and capitalization:
collection/Entry With Spaces.md
becomescollection/entry-with-spaces
. - Truncate
/index
paths to base URL:collection/index.md
becomescollection
- Resolve spaces and capitalization:
Patch Changes
-
#5720
fe316be86
Thanks @umarov! - Do not add base path to a hoisted script body -
#5706
c2844a79c
Thanks @bluwy! - Add preact and sitemap integration to config load external list -
#5700
3aa3e00a6
Thanks @bholmesdev! - Fiximport.meta.env.DEV
always being set totrue
when using Content Collections
1.8.0
Minor Changes
- #5647
d72da5290
Thanks @bholmesdev! - Addastro sync
CLI command for type generation
Patch Changes
-
#5668
9674cf56c
Thanks @bholmesdev! - Remove strayconsole.log
from content collections error message -
#5652
0b5098758
Thanks @bluwy! - Use acorn to postprocess Astro globs -
#5648
853081d1c
Thanks @bholmesdev! - Prevent relative image paths insrc/content/
-
#5678
f8f576829
Thanks @bluwy! - Fix code generation quotes handling -
#5635
376f67011
Thanks @SegaraRai! - Addserver.headers
typing -
Updated dependencies [
853081d1c
,2c65b433b
]:- @astrojs/markdown-remark@1.2.0
1.7.2
Patch Changes
-
#5641
62580ed07
Thanks @chenxsan! - Fix "Maximum call stack size exceeded" error in vite-plugin-head-propagation -
#5644
d5aff85db
Thanks @natemoo-re! - Fix static build regression where chunks would not be generated -
#5639
1ac1ed86e
Thanks @bluwy! - Fixclient:only
imports with"importsNotUsedAsValues": "error"
tsconfig
1.7.1
Patch Changes
- #5617
33dcaa05b
Thanks @bholmesdev! - Fix error message when using Content Collections and an out-of-date@astrojs/mdx
integration
1.7.0
Minor Changes
-
#5297
d2960984c
Thanks @natemoo-re! - Introduces the experimental Prerender API.Note
This API is not yet stable and is subject to possible breaking changes!
- Deploy an Astro server without sacrificing the speed or cacheability of static HTML.
- The Prerender API allows you to statically prerender specific
pages/
at build time.
Usage
- First, run
astro build --experimental-prerender
or enableexperimental: { prerender: true }
in yourastro.config.mjs
file. - Then, include
export const prerender = true
in any file in thepages/
directory that you wish to prerender.
-
#5495
31ec84797
Thanks @Princesseuh! - Add a new error overlay designed by @doodlemarks! This new overlay should be much more informative, clearer, astro-y, and prettier than the previous one. -
#5291
5ec0f6ed5
Thanks @bholmesdev! - Introduce Content Collections experimental API- Organize your Markdown and MDX content into easy-to-manage collections.
- Add type safety to your frontmatter with schemas.
- Generate landing pages, static routes, and SSR endpoints from your content using the collection query APIs.
-
#5341
6b156dd3b
Thanks @alexpdraper! - Allow setting domain when deleting cookies
Patch Changes
- #5615
d85ec7484
Thanks @natemoo-re! - Sanitize dynamically rendered tags to strip out any attributes
1.6.15
Patch Changes
-
#5572
b2f0210c4
Thanks @matthewp! - Include base in 'page' stage injected scripts -
#5554
02bb0a1cc
Thanks @natemoo-re! - Update@astrojs/compiler
to latest -
#5577
2bd23e454
Thanks @jerzakm! - Updated magic-string to 0.27.0
1.6.14
Patch Changes
-
#5545
9082a850e
Thanks @bluwy! - Exclude astro from Vite optimization -
#5446
4f7f20616
Thanks @jyasskin! - Fix redirect() typing to allow all redirection status codes. -
#5511
05915fec0
Thanks @matthewp! - Low-level head propagationThis adds low-level head propagation ability within the Astro runtime. This is not really usable within an Astro app at the moment, but provides the APIs necessary for
renderEntry
to do head propagation. -
#5553
1aeabe417
Thanks @matthewp! - Fix Astro.params not having values when using base in SSR -
#5549
795f00f73
Thanks @matthewp! - Use accumulated sort order when order production CSS -
#5539
2c836b9d1
Thanks @wulinsheng123! - Error reporting fails on undefined error index -
#5548
8f3f67c96
Thanks @ido-pluto! - Removed premature optimization
1.6.13
Patch Changes
-
#5506
f536a34e5
Thanks @bluwy! - Dedupe Astro package when resolving -
#5506
f536a34e5
Thanks @bluwy! - Refactor Astro compile flow -
#5533
58188e053
Thanks @bluwy! - Refactor and remove esbuild dependency -
#5501
3c44033e4
Thanks @Princesseuh! - Added a warning in build when trying to hydrate an Astro component
1.6.12
Patch Changes
-
#5484
731e99df8
Thanks @Pimm! - Narrow type ofParams
, as its values cannot be numbers -
#5480
c13775279
Thanks @sapphi-red! - Fix astro preview not working on Windows -
#5497
ca01a71eb
Thanks @bluwy! - Refactor internal plugins code -
#5460
57888e069
Thanks @bluwy! - Fix linked Astro library style HMR -
#5477
5e693c214
Thanks @bluwy! - Prevent inlining SCSS partials in dev -
#5498
1a3923da7
Thanks @bluwy! - Optimize JSX import source detection
1.6.11
Patch Changes
-
#5433
936c1e411
Thanks @wtchnm! - Add missingfetchpriority
attribute to img, link, script and iframe elements -
#5437
4b188132e
Thanks @bluwy! - Correctly transform third-party JSX files -
#5434
f5ed630bc
Thanks @matthewp! - Use Vite's resolve to resolve paths for client:only
1.6.10
Patch Changes
-
#5431
1ab505855
Thanks @matthewp! - Fix regression with loading .ts in .mjs config -
#5426
ff35b4759
Thanks @bluwy! - Fix JSX tagging for anonymous higher-order components default export -
#5430
b22ba1c03
Thanks @bluwy! - Fix preview --host in Node.js 18 -
#5417
a9f7ff966
Thanks @matthewp! - Prevent dev from crashing when there are errors in template
1.6.9
Patch Changes
-
#5409
9f80a4046
Thanks @matthewp! - Fix Code component usage in Vercel -
#5410
3c5cb6948
Thanks @impcyber! - Fix: https://github.com/withastro/astro/issues/5400 -
#5412
a278c7ae6
Thanks @matthewp! - Restart dev server on package.json changes -
#5377
40226dd14
Thanks @matthewp! - Uses vite to load astro.config.ts files
1.6.8
Patch Changes
-
#5375
f9104354b
Thanks @Princesseuh! - Fix regression causing nested arrays ingetStaticPaths
's return value to throw an error -
#5346
f3181b5ad
Thanks @bluwy! - Fix .html.astro file routing in dev -
#5358
9eee0f016
Thanks @matthewp! - Properly support trailingSlash: never with a base -
#5345
3ae2a961b
Thanks @bluwy! - Respect Vite user config for third-party packages config handling -
#5371
bee8c14af
Thanks @matthewp! - Prefer thebase
config rather than site config for creating URLs for links and scripts. -
#5369
e385076ef
Thanks @natemoo-re! - Upgrade@astrojs/compiler
, fixes regression withbody
handling whenhead
contains a Component node
1.6.7
Patch Changes
-
#5353
b3d936ac2
Thanks @matthewp! - Updated the CSS naming algorithm to prevent clashes -
#5294
ae41f25e1
Thanks @mrienstra! - Consistent Markdown frontmatter typing (MarkdownAstroData["frontmatter"]
in particular wasobject
before)
1.6.6
Patch Changes
-
#5316
a780f2595
Thanks @Princesseuh! - Improved error messages descriptions and hints to be more informative -
#5331
688f8e4bc
Thanks @matthewp! - Allow dynamic segments in injected routes -
#5330
7e19e8b30
Thanks @matthewp! - Prevent jsx throws from hanging server -
#5328
bcd0f8f8c
Thanks @matthewp! - 404 when not using subpath for items in public in devPreviously if using a base like
base: '/subpath/
you could load things from the root, which would break in prod. Now you must include the subpath. -
#5339
03a8f89d5
Thanks @natemoo-re! - Upgrade@astrojs/compiler
to latest -
#5327
0dcdc6fb1
Thanks @Princesseuh! - Update Astro language-server to 0.28.3
1.6.5
Patch Changes
-
#5326
88c1bbe3a
Thanks @matthewp! - Fix omitted island hydration scripts in slots -
#5301
a79a37cad
Thanks @bluwy! - Improve environment variable handling performance
1.6.4
Patch Changes
-
#5290
b2b291d29
Thanks @matthewp! - Handle base configuration in adaptersThis allows adapters to correctly handle
base
configuration. Internally Astro now matches routes when the URL includes thebase
.Adapters now also have access to the
removeBase
method which will remove thebase
from a pathname. This is useful to look up files for static assets. -
#5292
97e2b6ad7
Thanks @MontelAle! - Changes slow astro cli imports to dynamic -
#5293
4af4d8fa0
Thanks @matthewp! - Prevent overcaching .astro HMR changes -
#5314
f6add3924
Thanks @matthewp! - Fixes regression with config file restarts -
#5298
247eb7411
Thanks @wulinsheng123! - have not founded style when srcDir was root
1.6.3
Patch Changes
-
#5273
c7b9b14a1
Thanks @matthewp! - Surface astro.config errors to the user -
#5264
0d27c4a2b
Thanks @VladCuciureanu! - Fixed memleak caused by project dir names containing '.md' or '.mdx' -
#5258
74759cf78
Thanks @bluwy! - Allow 200 response for endpoints in build -
#5284
126cd8e83
Thanks @herteleo! - Include missingclass:list
withinHTMLAttributes
type -
#5236
1cc067052
Thanks @bluwy! - Refactor CSS preprocessing handling -
#5198
c77a6cbe3
Thanks @matthewp! - HMR - Improved error recoveryThis improves error recovery for HMR. Now when the dev server finds itself in an error state (because a route contained an error), it will recover from that state and refresh the page when the user has corrected the mistake.
1.6.2
Patch Changes
-
#5243
7d678c9ed
Thanks @matthewp! - Upgrade@astrojs/compiler
to 0.29.x -
Updated dependencies [
b6a478f37
]:- @astrojs/webapi@1.1.1
1.6.1
Patch Changes
-
#5233
7f8987085
Thanks @bluwy! - Support rendering@motionone/solid
components -
#5238
26ff42905
Thanks @MoustaphaDev! - Fix not included file extension inurl
metadata for newly added markdown files -
#5217
8c83359e3
Thanks @Princesseuh! - Fix missing types.d.ts in npm package -
#5206
d64d5b9b5
Thanks @Princesseuh! - Improve error messages related to CSS and compiler errors -
#5212
a609a8937
Thanks @bluwy! - Allow importing public files in SSR
1.6.0
Minor Changes
-
#5147
0bf0758fb
Thanks @natemoo-re! - Addastro/types
entrypoint. These utilities can be used for common prop type patterns.HTMLAttributes
If you would like to extend valid HTML attributes for a given HTML element, you may use the provided
HTMLAttributes
type—it accepts an element name and returns the valid HTML attributes for that element name.import { HTMLAttributes } from 'astro/types'; interface Props extends HTMLAttributes<'a'> { myProp?: string; }
-
#5164
4a8a346ca
Thanks @MoustaphaDev! - Add support for markdown files with the following extensions:.markdown
.mdown
.mkdn
.mkd
.mdwn
-
#4917
ddf2f8390
Thanks @natemoo-re! - Add support for--base
CLI argument, which will override thebase
set in yourastro.config.mjs
file.astro --site https://astro.build --base /docs
Patch Changes
1.5.3
Patch Changes
-
#5133
1c477dd8d
Thanks @bluwy! - Update@astrojs/compiler
and use the newresolvePath
option. This allows removing much of the runtime code, which should improve rendering performance for Astro and MDX pages. -
#5192
8728ee0b9
Thanks @tony-sull! -astro add
no longer automatically installs optional peer dependencies
1.5.2
Patch Changes
-
#5119
430e0346c
Thanks @bluwy! - Usefs.promises.rm
to remove node deprecation warning -
#5123
9745009ae
Thanks @matthewp! - Fixes index page with build.format=file -
#5116
500acb3c1
Thanks @matthewp! - Throws when using Response.redirect in SSG mode
1.5.1
Patch Changes
-
#5110
0edfdd325
Thanks @bluwy! - Ensure CLI flags override function-style server config -
#5106
ef0c54316
Thanks @bluwy! - Support spread parameters for server endpoints -
#5095
ddfbef5ac
Thanks @Princesseuh! - Fixastro add
trying to add lines from extended configurations when adding frameworks -
#5076
6f9a88b31
Thanks @Princesseuh! - Fix jsconfig.json aliases not working anymore after 1.5.0 -
#5080
90b715d5c
Thanks @matthewp! - Fix Astro-in-MDX dashes in slot attr -
#5098
f684e9d36
Thanks @jkjustjoshing! - Separate type definitions for built-in HTML elements and custom elements. Helpful when implementing an "as" prop similar to styled-components. -
#5108
ce01225a7
Thanks @Princesseuh! - Fix types not working properly when usingmoduleResolution: 'node16'
-
#5060
5923dd77c
Thanks @AirBorne04! - api routes: adding cookies to the response, also when returning a simple result -
#5087
49a8d18b4
Thanks @JuanM04! - Fixastro add
pnpm command
1.5.0
Minor Changes
-
#5056
e55af8a23
Thanks @matthewp! - # Adapter support forastro preview
Adapters are now about to support the
astro preview
command via a new integration option. The Node.js adapter@astrojs/node
is the first of the built-in adapters to gain support for this. What this means is that if you are using@astrojs/node
you can new preview your SSR app by running:npm run preview
Adapter API
We will be updating the other first party Astro adapters to support preview over time. Adapters can opt-in to this feature by providing the
previewEntrypoint
via thesetAdapter
function inastro:config:done
hook. The Node.js adapter's code looks like this:export default function() { return { name: '@astrojs/node', hooks: { 'astro:config:done': ({ setAdapter, config }) => { setAdapter({ name: '@astrojs/node', serverEntrypoint: '@astrojs/node/server.js', + previewEntrypoint: '@astrojs/node/preview.js', exports: ['handler'], }); // more here } } }; }
The
previewEntrypoint
is a module in the adapter's package that is a Node.js script. This script is run whenastro preview
is run and is charged with starting up the built server. See the Node.js implementation in@astrojs/node
to see how that is implemented. -
#4986
ebd364e39
Thanks @bluwy! - ## New properties for API routesIn API routes, you can now get the
site
,generator
,url
,clientAddress
,props
, andredirect
fields on the APIContext, which is the first parameter passed to an API route. This was done to make the APIContext more closely align with theAstro
global in .astro pages.For example, here's how you might use the
clientAddress
, which is the user's IP address, to selectively allow users.export function post({ clientAddress, request, redirect }) { if (!allowList.has(clientAddress)) { return redirect('/not-allowed'); } }
Check out the docs for more information on the newly available fields: https://docs.astro.build/en/core-concepts/endpoints/#server-endpoints-api-routes
-
#4959
0ea6187f9
Thanks @Princesseuh! - Added support for updating TypeScript settings automatically when usingastro add
The
astro add
command will now automatically update yourtsconfig.json
with the proper TypeScript settings needed for the chosen frameworks.For instance, typing
astro add solid
will update yourtsconfig.json
with the following settings, per Solid's TypeScript guide:{ "compilerOptions": { "jsx": "preserve", "jsxImportSource": "solid-js" } }
-
#4947
a5e3ecc80
Thanks @JuanM04! - - AddedisRestart
andaddWatchFile
to integration stepisRestart
.- Restart dev server automatically when tsconfig changes.
-
#4986
ebd364e39
Thanks @bluwy! - ## Support passing a custom status code for Astro.redirectNew in this minor is the ability to pass a status code to
Astro.redirect
. By default it uses302
but now you can pass another code as the second argument:--- // This page was moved return Astro.redirect('/posts/new-post-name', 301); ---
-
#5056
e55af8a23
Thanks @matthewp! - # New build configurationThe ability to customize SSR build configuration more granularly is now available in Astro. You can now customize the output folder for
server
(the server code for SSR),client
(your client-side JavaScript and assets), andserverEntry
(the name of the entrypoint server module). Here are the defaults:import { defineConfig } from 'astro/config'; export default defineConfig({ output: 'server', build: { server: './dist/server/', client: './dist/client/', serverEntry: 'entry.mjs', }, });
These new configuration options are only supported in SSR mode and are ignored when building to SSG (a static site).
Integration hook change
The integration hook
astro:build:start
includes a parambuildConfig
which includes all of these same options. You can continue to use this param in Astro 1.x, but it is deprecated in favor of the newbuild.config
options. All of the built-in adapters have been updated to the new format. If you have an integration that depends on this param we suggest upgrading to do this instead:export default function myIntegration() { return { name: 'my-integration', hooks: { 'astro:config:setup': ({ updateConfig }) => { updateConfig({ build: { server: '...', }, }); }, }, }; }
Patch Changes
-
#5057
baf88ee9e
Thanks @bluwy! - Skip JSX tagging for export statements with source -
#5044
44ea0c6d9
Thanks @JuanM04! - Upgrade Astro compiler to 0.27.1 -
#5059
f7fcdfe62
Thanks @bluwy! - Support strict dependency install for libraries with JSX -
#5047
1e2799243
Thanks @matthewp! - Update Astro.cookies.set types to allow booleans and numbersNote that booleans and numbers were already allowed, they just were not allowed by the type definitions.
1.4.7
Patch Changes
-
#5035
d7bfb144b
Thanks @AirBorne04! - preventing multiple doctype injection into html documents -
#5015
b1964e9e1
Thanks @matthewp! - Shared state in Preact components with signalsThis makes it possible to share client state between Preact islands via signals.
For example, you can create a signals in an Astro component and then pass it to multiple islands:
--- // Component Imports import Counter from '../components/Counter'; import { signal } from '@preact/signals'; const count = signal(0); --- <Count count={count} /> <Count count={count} />
-
#5036
38fdb4ca6
Thanks @matthewp! - New algorithm for shorter CSS bundle names
1.4.6
Patch Changes
1.4.5
Patch Changes
-
#4981
1f890b336
Thanks @matthewp! - Ensure dynamic tags have their slot instructions yielded -
#4886
61d26f335
Thanks @yuhang-dong! - Fix: import.meta.env.BASE_URL will be '/' in client loaded component on dev mode -
#4973
c733d4fb8
Thanks @bluwy! - Support Astro.slots.render for mdx -
#4918
a6bb2694b
Thanks @bluwy! - Refactor hydration path handling -
#4977
4f73b98ae
Thanks @tony-sull! - Fixes a bug that logged route cache warnings inastro dev
-
#4887
37cb2fc02
Thanks @Calvin-LL! - fix object styles not escaped -
#4990
8f9791d84
Thanks @matthewp! - Upgrade Astro compiler to 0.26.0
1.4.4
Patch Changes
-
#4967
e6a881081
Thanks @matthewp! - Final perf fix from 1.3.0 regressionA regression in rendering perf happened in 1.3.0. This is the final fix for the underlying issue.
1.4.3
Patch Changes
-
#4956
ee8dd424f
Thanks @matthewp! - Fix perf regression in SSR -
#4952
5bcd76e3a
Thanks @bluwy! - Refactor ViteConfigWithSSR type
1.4.2
Patch Changes
-
#4932
9898088c0
Thanks @matthewp! - Prevent hydration mismatch in streaming SSR -
#4939
cf2bba1e4
Thanks @natemoo-re! - Fix MDX error handling, preventing a memory leak
1.4.1
Patch Changes
- #4928
7690849a8
Thanks @Princesseuh! - Fix module definition of Markdown and MDX files not being available outside Astro files
1.4.0
Minor Changes
-
#4907
01c1aaa00
Thanks @matthewp! - Order Astro styles last, to override imported stylesThis fixes CSS ordering so that imported styles are placed higher than page/component level styles. This means that if you do:
--- import '../styles/global.css'; --- <style> body { background: limegreen; } </style>
The
<style>
defined in this component will be placed below the imported CSS. When compiled for production this will result in something like this:/* /src/styles/global.css */ body { background: blue; } /* /src/pages/index.astro */ body:where(.astro-12345) { background: limegreen; }
Given Astro's 0-specificity hashing, this change effectively makes it so that Astro styles "win" when they have the same specificity as global styles.
-
#4876
d3091f89e
Thanks @matthewp! - Adds the Astro.cookies APIAstro.cookies
is a new API for manipulating cookies in Astro components and API routes.In Astro components, the new
Astro.cookies
object is a map-like object that allows you to get, set, delete, and check for a cookie's existence (has
):--- type Prefs = { darkMode: boolean; }; Astro.cookies.set<Prefs>( 'prefs', { darkMode: true }, { expires: '1 month', } ); const prefs = Astro.cookies.get<Prefs>('prefs').json(); --- <body data-theme={prefs.darkMode ? 'dark' : 'light'}></body>
Once you've set a cookie with Astro.cookies it will automatically be included in the outgoing response.
This API is also available with the same functionality in API routes:
export function post({ cookies }) { cookies.set('loggedIn', false); return new Response(null, { status: 302, headers: { Location: '/login', }, }); }
See the RFC to learn more.
Patch Changes
-
#4892
ff7ba0ee0
Thanks @matthewp! - Prevent multiple rendering of head content -
#4842
812658ad2
Thanks @bluwy! - Add missing dependencies, support strict dependency installation (e.g. pnpm) -
#4891
87a7cf48e
Thanks @matthewp! - Hoist hydration scripts out of slot templates -
Updated dependencies [
812658ad2
,812658ad2
]:- @astrojs/markdown-remark@1.1.3
- @astrojs/telemetry@1.0.1
1.3.1
Patch Changes
-
#4861
42fe8e0c7
Thanks @rishi-raj-jain! - use const instead of let for define:vars -
#4878
90c207299
Thanks @rishi-raj-jain! - add warning for post routes called when output is not server -
#4855
49ca9e129
Thanks @matthewp! - Fix TS errors when not using skipLibCheck -
#4845
3389f0ce9
Thanks @matthewp! - Prevent the root folder from being deleted during the build -
#4841
4b092269c
Thanks @rishi-raj-jain! - copy assets even if outDir is out of process.cwd() -
#4849
ee5fdeffd
Thanks @rishi-raj-jain! - append .html to the file URL in case build.format says file -
#4867
03e8b750a
Thanks @rishi-raj-jain! - check if class:list's value is defined before converting -
#4873
83ed1cc1f
Thanks @bluwy! - Prevent /undefined catch-all routes in dev -
#4454
6a1a17dd2
Thanks @bluwy! - Allow HMR for internal e2e tests -
#4712
17dbc6701
Thanks @Lifeni! - Fix slashes for paths containing non-ASCII characters on Windows -
#4850
edb7bead6
Thanks @rishi-raj-jain! - add support for changing mode via CLI -
#4868
b99f9902b
Thanks @rishi-raj-jain! - remove all the ssr generated folders in static build if only empty -
Updated dependencies [
5e4c5252b
]:- @astrojs/webapi@1.1.0
1.3.0
Minor Changes
-
#4775
b0cc93996
Thanks @tony-sull! - Adds a new "astro:build:generated" hook that runs after SSG builds finish but before build artifacts are cleaned up. This is a very specific use case, "astro:build:done" is probably what you're looking for. -
#4669
a961aa3c2
Thanks @aggre! - astro-island now correctly passes Uint8Array/Uint16Array/Uint32Array -
#4832
73f215df7
Thanks @matthewp! - Allows Responses to be passed to set:htmlThis expands the abilities of
set:html
to ultimate service this use-case:<div set:html={fetch('/legacy-post.html')} />
This means you can take a legacy app that has been statically generated to HTML and directly consume that HTML within your templates. As is always the case with
set:html
, this should only be used on trusted content.To make this possible, you can also pass several other types into
set:html
now:Response
objects, since that is what fetch() returns:<div set:html={new Response('<span>Hello world</span>', { headers: { 'content-type': 'text/html' }, })} />
ReadableStream
s:<div set:html={new ReadableStream({ start(controller) { controller.enqueue(`<span>read me</span>`); controller.close(); }, })} />
AsyncIterable
s:<div set:html={(async function* () { for await (const num of [1, 2, 3, 4, 5]) { yield `<li>${num}</li>`; } })()} />
Iterable
s (non-async):<div set:html={(function* () { for (const num of [1, 2, 3, 4, 5]) { yield `<li>${num}</li>`; } })()} />
Patch Changes
-
#4831
29b29e6a8
Thanks @yuhang-dong! - Update vite-jsx-plugin for jsx export -
#4754
baae1b3fd
Thanks @Princesseuh! - Updateastro check
to latest version of the language server
1.2.8
Patch Changes
-
#4813
be9eaa069
Thanks @bluwy! - Allow overridevite.build.target
-
#4817
a49bc2f02
Thanks @mohammed-elhaouari! - fix parsing integration names with astro add command -
#4819
518e8f7e2
Thanks @matthewp! - Allow passing promises to set:html -
#4807
44fa37818
Thanks @lucacasonato! - Remove explicitTransfer-Encoding: chunked
header from streaming responses -
#4803
f53d97d56
Thanks @Enteleform! - replaces hard-codedminify
values withvite.build.minify
-
Updated dependencies [
df54595a8
]:- @astrojs/markdown-remark@1.1.2
1.2.7
Patch Changes
1.2.6
Patch Changes
1.2.5
Patch Changes
-
#4768
9a59e24e0
Thanks @matthewp! - nsure before-hydration is only loaded when used -
#4759
fc885eaea
Thanks @matthewp! - Read jsxImportSource from tsconfig
1.2.4
Patch Changes
-
#4736
13ca686ea
Thanks @bluwy! - Handle builds with outDir outside of current working directory -
#4748
c5e134d03
Thanks @bluwy! - Fix console.error filtering -
#4742
cf8a7e933
Thanks @matthewp! - Allow file uploads in dev server -
#4594
005d5bacd
Thanks @matthewp! - Allow custom 404 route to handle API route missing methods
1.2.3
Patch Changes
1.2.2
Patch Changes
-
#4705
5b6173fd0
Thanks @Princesseuh! - Properly show an error message when a renderer is not properly configured -
#4723
0dba3b6f3
Thanks @matthewp! - Makes the dev server more resilient to crashes
1.2.1
Patch Changes
- #4703
d28f7013c
Thanks @bholmesdev! - Fix: [astro add] Apply fetch polyfill before running
1.2.0
Minor Changes
-
#4682
d1e695914
Thanks @bholmesdev! - astro add - move configuration updates to final step -
#4549
255636cc7
Thanks @altano! - Allow specifying custom encoding when using a non-html route. Only option before was 'utf-8' and now that is just the default. -
#4578
c706d845e
Thanks @bholmesdev! - Restart dev server when config file is added, updated, or removed
Patch Changes
1.1.8
Patch Changes
-
#4675
63e49c3b6
Thanks @matthewp! - Prevent locking up when encountering invalid CSS -
#4684
919df13b9
Thanks @natemoo-re! - Fixes regression introduced in #4646 with better cyclic reference detection -
#4683
cc242d3af
Thanks @Princesseuh! - Fixtsc
compilation errors whenskipLibCheck
wasn't enabled -
#4667
9290b2414
Thanks @Holben888! - Fix framework components on Vercel Edge -
#4645
f27ca6ab3
Thanks @bholmesdev! - Fix client-side scripts reloads on dev server in windows
1.1.7
Patch Changes
-
#4646
98f242cdc
Thanks @natemoo-re! - Add cyclic ref detection when serializing props -
#4656
6d845c353
Thanks @matthewp! - Fix bug with usingassert
as import identifier -
#4403
d31e72c3b
Thanks @JohnDaly! - Fix for components, declared with JSXMemberExpression nodes, that failed to hydrate due to incomplete 'component-export' metadata
1.1.6
Patch Changes
-
#4623
eb1862b4e
Thanks @delucis! - Improve third-party Astro package support -
#4643
307b7b97c
Thanks @matthewp! - Remove regression when there is duplicate client/server CSS -
#4584
29a5fdc15
Thanks @bluwy! - Correctly escape paths in file names -
#4621
0068afb87
Thanks @AllanChain! - Ensure SSR module is loaded before testing if it's CSS in dev
1.1.5
Patch Changes
1.1.4
Patch Changes
-
#4586
16814dc71
Thanks @bluwy! - Move ast-types as dev dependency -
#4585
f018e365c
Thanks @FredKSchott! - Add docs link to "missing adapter" error msg
1.1.3
Patch Changes
- #4574
b92c24f40
Thanks @delucis! - Updateastro add
to list official integrations & adapters with same organisation we use in docs
1.1.2
Patch Changes
-
#4519
a2e8e76c3
Thanks @JuanM04! - Upgraded Shiki to v0.11.1 -
#4531
2d2e38e47
Thanks @bluwy! - Remove hardcoded Vite middleware handling -
#4553
2f05f5d30
Thanks @matthewp! - Include trailingSlash in astro:build:done hookThis change ensures that the
pages
provided in theastro:build:done
hook conform to thetrailingSlash
andbuild.format
configs. -
#4526
046bfd908
Thanks @bluwy! - Skip clean SSR output if page generation fails -
#4546
bb71be78d
Thanks @bholmesdev! - Update "Add an Adapter" help heading to "Add an SSR Adapter" -
#4548
69b640b87
Thanks @bholmesdev! - Fix "failed to load for SSR" on styles when using tailwind -
#4535
ca28d7578
Thanks @Princesseuh! - Add missingslot
attributes to SVG definitions -
#4524
d431fbe4e
- fix import in the config type declarations -
Updated dependencies [
a2e8e76c3
]:- @astrojs/markdown-remark@1.1.1
1.1.1
Patch Changes
- #4507
4e1af3f0e
Thanks @Princesseuh! - Fiximport-meta.d.ts
not being included in the npm package
1.1.0
Minor Changes
- #4352
cd154e447
Thanks @matthewp! - Make Astro.url match the build.format configuration during the build
- #4423
d4cd7a59f
Thanks @bholmesdev! - Update Markdown type signature to match new markdown plugin,and update top-level layout props for better alignment
- #4474
ac0321824
Thanks @bholmesdev! - Add "extends" to markdown plugin config to preserve Astro defaults
Patch Changes
- #4500
9874c7bf4
Thanks @Princesseuh! - Updateastro check
to use latest version of the Astro language server
- #4439
77ce6be30
Thanks @Princesseuh! - Add tsconfig templates for users to extend from
- #4499
1f42c0791
Thanks @Princesseuh! - Fixtsc
not being able to find Vite's import.meta types on Linux
-
#4497
78e06c8ec
Thanks @bholmesdev! - Production build logging - Only log[code].html
instead of[code]/index.html
for 404 and 500 routes -
Updated dependencies [
ac0321824
,839097c84
]:- @astrojs/markdown-remark@1.1.0
1.1.0-next.0
Minor Changes
- #4352
cd154e447
Thanks @matthewp! - Make Astro.url match the build.format configuration during the build
- #4423
d4cd7a59f
Thanks @bholmesdev! - Update Markdown type signature to match new markdown plugin,and update top-level layout props for better alignment
- #4474
ac0321824
Thanks @bholmesdev! - Add "extends" to markdown plugin config to preserve Astro defaults
Patch Changes
-
#4439
77ce6be30
Thanks @Princesseuh! - Add tsconfig templates for users to extend from -
Updated dependencies [
ac0321824
,839097c84
]:- @astrojs/markdown-remark@1.1.0-next.0
1.0.9
Patch Changes
- #4456
47e71ae8f
Thanks @Princesseuh! - Added an error message when the second argument of Astro.slots.render is not an array
1.0.8
Patch Changes
- #4427
b2e976f39
Thanks @cameronmcefee! - Fix config types to allow falsy values in integrations list, to match docs
- #4385
8164fa6f1
Thanks @krolebord! - Fix warning when using hooks inside the react components not exported as a function declaration
- #4445
df4e99928
Thanks @bholmesdev! - Add "waiting for X integration" log for long-running integration hooks
- #4430
dc42f2c00
Thanks @bholmesdev! - astro add - Fix third-party npm orgs, i.e.@example/integration
- #4441
ca0c7e8b8
Thanks @Princesseuh! - Allow arbitrary strings on the target attribute
-
#4446
27ac6a03a
Thanks @matthewp! - Deterministic CSS orderingThis makes our CSS link order deterministic. It uses CSS depth; that is how deeply a module import the CSS comes from, in order to determine which CSS is page-level vs. component-level CSS.
This is intended to match dev ordering where, because we do not bundle, the page-level CSS always comes after component-level.
1.0.7
Patch Changes
- #4362
aa5118e85
Thanks @joseph-lozano! - Allow user config to setmarkdown.drafts
option
- #4405
a70f69a06
Thanks @FredKSchott! - Refactor JSX build plugin, improve performance
1.0.6
Patch Changes
- #4324
45fdbc465
Thanks @BurntCaramel! - Use TextEncoder instead of Buffer.byteLength() for Deno compatibility
- #4329
0274b8d47
Thanks @tony-sull! - Updates routing logic to allow multiple routes to match the same URL in SSR
- #4347
166b3b8a5
Thanks @bholmesdev! - Fix MDXLayoutProps type signature for linting
1.0.5
Patch Changes
- #4302
1d3a0a16f
Thanks @FredKSchott! - Revert "Ensure hydration scripts inside of slots render ASAP (#4288)" to fix Svelte integration bug
- #4284
73f367c77
Thanks @FredKSchott! - Prevent preview if 'output: server' is configured
1.0.4
Patch Changes
- #4268
f7afdb889
Thanks @bholmesdev! - Align MD with MDX on layout props and "glob" import results:- Add
Content
to MDX - Add
file
andurl
to MDX frontmatter (layout import only) - Update glob types to reflect differences (lack of
rawContent
andcompiledContent
)
- Add
- #4265
8f845ca95
Thanks @matthewp! - Prevents automatic trailingSlash appending on getStaticPaths produced pages
- #4282
c0992e1fe
Thanks @natemoo-re! - Fix bug where Astro's server runtime would end up in the browser
- #4272
24d2f7a6e
Thanks @natemoo-re! - Properly handle hydration for namespaced components
- #4289
3ca905174
Thanks @bholmesdev! - [astro add] Setoutput: 'server'
when adding adapter
1.0.3
Patch Changes
- #4279
42fd6936c
Thanks @FredKSchott! - Handle "not found" imports without throwing an "Invalid URL" error
- #4273
0022f46b5
Thanks @Princesseuh! - Fix build output adding/index.html
at the end of endpoints route
- #4270
7127b1bb3
Thanks @natemoo-re! - Make third-party integration names nicer when usingastro add
1.0.2
Patch Changes
- #4240
561a34d91
Thanks @matthewp! - Properly invalidate Astro modules when a child script updates in HMR
1.0.1
Patch Changes
3a7f2385e
Thanks @FredKSchott! - Add rawContent and compiledContent to MD layout props
1.0.0
Astro v1.0 is out! Read the official announcement post.
Note
If you need help migrating an existing Astro project to the new Astro v1.0, check out our updated Migration Guide and full documentation website.
0.X
For older changelog entries -- including all v0.X, v1.0 Beta, and v1.0 Release Candidate versions -- check out the v0.X changelog.