diff --git a/.github/labeler.yml b/.github/labeler.yml index e743b95f79..e6ec992060 100644 --- a/.github/labeler.yml +++ b/.github/labeler.yml @@ -19,22 +19,22 @@ markdown: - packages/markdown/** renderer: -- packages/renderers/** +- packages/integrations/** framework-lit: -- packages/renderers/renderer-lit/** +- packages/integrations/lit/** framework-preact: -- packages/renderers/renderer-preact/** +- packages/integrations/preact/** framework-react: -- packages/renderers/renderer-react/** +- packages/integrations/react/** framework-solid: -- packages/renderers/renderer-solid/** +- packages/integrations/solid/** framework-svelte: -- packages/renderers/renderer-svelte/** +- packages/integrations/svelte/** framework-vue: -- packages/renderers/renderer-vue/** +- packages/integrations/vue/** diff --git a/package.json b/package.json index 3a57447a47..c32437d67a 100644 --- a/package.json +++ b/package.json @@ -25,7 +25,6 @@ "workspaces": [ "compiled/*", "packages/markdown/*", - "packages/renderers/*", "packages/integrations/*", "packages/*", "examples/*", diff --git a/packages/astro/test/fixtures/astro-jsx/package.json b/packages/astro/test/fixtures/astro-jsx/package.json index 726667aa70..a41012546c 100644 --- a/packages/astro/test/fixtures/astro-jsx/package.json +++ b/packages/astro/test/fixtures/astro-jsx/package.json @@ -3,7 +3,6 @@ "version": "0.0.0", "private": true, "dependencies": { - "astro": "workspace:*", - "@astrojs/renderer-solid": "workspace:*" + "astro": "workspace:*" } } diff --git a/packages/renderers/README.md b/packages/renderers/README.md deleted file mode 100644 index fb0fb82709..0000000000 --- a/packages/renderers/README.md +++ /dev/null @@ -1,11 +0,0 @@ -# Astro Renderers - -Astro is designed to support your favorite UI frameworks. [React][react], [Svelte][svelte], [Vue][vue], and [Preact][preact] are all built-in to Astro and supported out of the box. No configuration is needed to enable these. - -For adding additional frameworks (or your own custom one), please refer to [the full documentation][renderer-docs]. - -[preact]: https://npm.im/@astrojs/renderer-preact -[react]: https://npm.im/@astrojs/renderer-react -[renderer-docs]: https://docs.astro.build/reference/renderer-reference -[svelte]: https://npm.im/@astrojs/renderer-svelte -[vue]: https://npm.im/@astrojs/renderer-vue diff --git a/packages/renderers/renderer-lit/.gitignore b/packages/renderers/renderer-lit/.gitignore deleted file mode 100644 index 40b878db5b..0000000000 --- a/packages/renderers/renderer-lit/.gitignore +++ /dev/null @@ -1 +0,0 @@ -node_modules/ \ No newline at end of file diff --git a/packages/renderers/renderer-lit/CHANGELOG.md b/packages/renderers/renderer-lit/CHANGELOG.md deleted file mode 100644 index 6918ff8b61..0000000000 --- a/packages/renderers/renderer-lit/CHANGELOG.md +++ /dev/null @@ -1,55 +0,0 @@ -# @astrojs/renderer-lit - -## 0.4.0 - -### Minor Changes - -- [#2563](https://github.com/withastro/astro/pull/2563) [`a907a73b`](https://github.com/withastro/astro/commit/a907a73b8cd14726d158ea460932f9cd8891923a) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Upgrade renderer dependencies for `vite@2.8.x` - -## 0.4.0-next.0 - -### Minor Changes - -- [#2563](https://github.com/withastro/astro/pull/2563) [`a907a73b`](https://github.com/withastro/astro/commit/a907a73b8cd14726d158ea460932f9cd8891923a) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Upgrade renderer dependencies for `vite@2.8.x` - -## 0.3.1 - -### Patch Changes - -- [#2370](https://github.com/withastro/astro/pull/2370) [`a7967530`](https://github.com/withastro/astro/commit/a7967530dfe9cfab5d6d866c8d2bcba9c47de39c) Thanks [@matthewp](https://github.com/matthewp)! - Makes the renderer compatible with the static build - -## 0.3.0 - -### Minor Changes - -- [#2202](https://github.com/withastro/astro/pull/2202) [`45cea6ae`](https://github.com/withastro/astro/commit/45cea6aec5a310fed4cb8da0d96670d6b99a2539) Thanks [@jonathantneal](https://github.com/jonathantneal)! - Officially drop support for Node v12. The minimum supported version is now Node v14.15+, - -## 0.2.1 - -### Patch Changes - -- ec01d1b4: renderer-lit will bind to properties rather than attributes fixing certain binding issues - -## 0.2.0 - -### Minor Changes - -- e6aaeff5: Updated framework renderers for the v0.21.0 release of Astro. Assorted changes and a new renderer interface are included in this release. - -## 0.2.0-next.0 - -### Minor Changes - -- d84bfe71: Updates the renderers to confirm to the new renderer API. - -## 0.1.2 - -### Patch Changes - -- 806dcd8d: Update Lit renderer to use v2 release - -## 0.1.1 - -### Patch Changes - -- 97d37f8f: Update READMEs for all renderers diff --git a/packages/renderers/renderer-lit/client-shim.js b/packages/renderers/renderer-lit/client-shim.js deleted file mode 100644 index e9cf1aecf1..0000000000 --- a/packages/renderers/renderer-lit/client-shim.js +++ /dev/null @@ -1,16 +0,0 @@ -async function polyfill() { - const { hydrateShadowRoots } = await import( - '@webcomponents/template-shadowroot/template-shadowroot.js' - ); - hydrateShadowRoots(document.body); -} - -const polyfillCheckEl = new DOMParser() - .parseFromString(`

`, 'text/html', { - includeShadowRoots: true, - }) - .querySelector('p'); - -if (!polyfillCheckEl || !polyfillCheckEl.shadowRoot) { - polyfill(); -} diff --git a/packages/renderers/renderer-lit/hydration-support.js b/packages/renderers/renderer-lit/hydration-support.js deleted file mode 100644 index 0c21646fbb..0000000000 --- a/packages/renderers/renderer-lit/hydration-support.js +++ /dev/null @@ -1 +0,0 @@ -import 'lit/experimental-hydrate-support.js'; diff --git a/packages/renderers/renderer-lit/index.js b/packages/renderers/renderer-lit/index.js deleted file mode 100644 index b051bc3a57..0000000000 --- a/packages/renderers/renderer-lit/index.js +++ /dev/null @@ -1,37 +0,0 @@ -// NOTE: @lit-labs/ssr uses syntax incompatible with anything < Node v13.9.0. -// Throw an error if using that Node version. - -const NODE_VERSION = parseFloat(process.versions.node); -if (NODE_VERSION < 13.9) { - throw new Error( - `Package @lit-labs/ssr requires Node version v13.9 or higher. Please update Node to use @astrojs/renderer-lit` - ); -} - -export default { - name: '@astrojs/renderer-lit', - server: './server.js', - polyfills: ['./client-shim.js'], - hydrationPolyfills: ['./hydration-support.js'], - viteConfig() { - return { - optimizeDeps: { - include: [ - '@astrojs/renderer-lit/client-shim.js', - '@astrojs/renderer-lit/hydration-support.js', - '@webcomponents/template-shadowroot/template-shadowroot.js', - 'lit/experimental-hydrate-support.js', - ], - exclude: ['@astrojs/renderer-lit/server.js'], - }, - ssr: { - external: [ - 'lit-element/lit-element.js', - '@lit-labs/ssr/lib/install-global-dom-shim.js', - '@lit-labs/ssr/lib/render-lit-html.js', - '@lit-labs/ssr/lib/lit-element-renderer.js', - ], - }, - }; - }, -}; diff --git a/packages/renderers/renderer-lit/package.json b/packages/renderers/renderer-lit/package.json deleted file mode 100644 index 8f11c603f5..0000000000 --- a/packages/renderers/renderer-lit/package.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "name": "@astrojs/renderer-lit", - "version": "0.4.0", - "description": "Use Lit components within Astro", - "type": "module", - "author": "withastro", - "license": "MIT", - "repository": { - "type": "git", - "url": "https://github.com/withastro/astro.git", - "directory": "packages/renderers/renderer-lit" - }, - "bugs": "https://github.com/withastro/astro/issues", - "homepage": "https://astro.build", - "exports": { - ".": "./index.js", - "./*": "./*", - "./server.js": "./server.js", - "./client-shim.js": "./client-shim.js", - "./package.json": "./package.json" - }, - "dependencies": { - "@lit-labs/ssr": "^2.1.0", - "@webcomponents/template-shadowroot": "^0.1.0", - "lit": "^2.2.2" - } -} diff --git a/packages/renderers/renderer-lit/readme.md b/packages/renderers/renderer-lit/readme.md deleted file mode 100644 index 9696959055..0000000000 --- a/packages/renderers/renderer-lit/readme.md +++ /dev/null @@ -1,87 +0,0 @@ -# Astro Lit Renderer - -This is a plugin for [Astro](https://astro.build/) apps that enables server-side rendering of custom elements build with [Lit](https://lit.dev/). - -Server-side rendering uses [Declarative Shadow DOM](https://web.dev/declarative-shadow-dom/), a new web technology that allows custom elements to be rendered to HTML with __0 JavaScript__. - -## Installation - -Install `@astrojs/renderer-lit` and then add it to your `astro.config.mjs` in the `renderers` property: - -``` -npm install @astrojs/renderer-lit -``` - -__astro.config.mjs__ - -```js -export default { - // ... - - renderers: [ - // ... - '@astrojs/renderer-lit' - ] -} -``` - -## Usage - -If you're familiar with Astro then you already know that you can import components into your templates and use them. What's different about custom elements is you can use the *tag name* directly. - -Astro needs to know which tag is associated with which component script. We expose this through exporting a `tagName` variable from the component script. It looks like this: - -__src/components/my-element.js__ - -```js -import { LitElement, html } from 'lit'; - -export const tagName = 'my-element'; - -class MyElement extends LitElement { - render() { - return html`

Hello world! From my-element

`; - } -} - -customElements.define(tagName, MyElement); -``` - -> Note that exporting the `tagName` is __required__ if you want to use the tag name in your templates. Otherwise you can export and use the constructor, like with non custom element frameworks. - -In your Astro template import this component as a side-effect and use the element. - -__src/pages/index.astro__ - -```astro ---- -import '../components/my-element.js'; ---- - - -``` - -> Note that Lit requires browser globals such as `HTMLElement` and `customElements` to be present. For this reason the Lit renderer shims the server with these globals so Lit can run. You *might* run into libraries that work incorrectly because of this. - -### Polyfills & Hydration - -The renderer automatically handles adding appropriate polyfills for support in browsers that don't have Declarative Shadow DOM. The polyfill is about *1.5kB*. If the browser does support Declarative Shadow DOM then less than 250 bytes are loaded (to feature detect support). - -Hydration is also handled automatically. You can use the same hydration directives such as `client:load`, `client:idle` and `client:visible` as you can with other libraries that Astro supports. - -```astro ---- -import '../components/my-element.js'; ---- - - -``` - -The above will only load the element's JavaScript when the user has scrolled it into view. Since it is server rendered they will not see any jank; it will load and hydrate transparently. - -## More Documentation - -[Astro Renderer Documentation][renderer-docs] - -[astro]: https://astro.build -[renderer-docs]: https://docs.astro.build/reference/renderer-reference diff --git a/packages/renderers/renderer-lit/server-shim.js b/packages/renderers/renderer-lit/server-shim.js deleted file mode 100644 index 0546795920..0000000000 --- a/packages/renderers/renderer-lit/server-shim.js +++ /dev/null @@ -1,5 +0,0 @@ -import { installWindowOnGlobal } from '@lit-labs/ssr/lib/dom-shim.js'; -installWindowOnGlobal(); - -window.global = window; -document.getElementsByTagName = () => []; diff --git a/packages/renderers/renderer-lit/server.js b/packages/renderers/renderer-lit/server.js deleted file mode 100644 index 1622ef6194..0000000000 --- a/packages/renderers/renderer-lit/server.js +++ /dev/null @@ -1,72 +0,0 @@ -import './server-shim.js'; -import '@lit-labs/ssr/lib/render-lit-html.js'; -import { LitElementRenderer } from '@lit-labs/ssr/lib/lit-element-renderer.js'; - -function isCustomElementTag(name) { - return typeof name === 'string' && /-/.test(name); -} - -function getCustomElementConstructor(name) { - if (typeof customElements !== 'undefined' && isCustomElementTag(name)) { - return customElements.get(name) || null; - } - return null; -} - -async function isLitElement(Component) { - const Ctr = getCustomElementConstructor(Component); - return !!(Ctr && Ctr._$litElement$); -} - -async function check(Component, _props, _children) { - // Lit doesn't support getting a tagName from a Constructor at this time. - // So this must be a string at the moment. - return !!(await isLitElement(Component)); -} - -function* render(tagName, attrs, children) { - const instance = new LitElementRenderer(tagName); - - // LitElementRenderer creates a new element instance, so copy over. - const Ctr = getCustomElementConstructor(tagName); - for (let [name, value] of Object.entries(attrs)) { - // check if this is a reactive property - if (name in Ctr.prototype) { - instance.setProperty(name, value); - } else { - instance.setAttribute(name, value); - } - } - - instance.connectedCallback(); - - yield `<${tagName}`; - yield* instance.renderAttributes(); - yield `>`; - const shadowContents = instance.renderShadow({}); - if (shadowContents !== undefined) { - yield ''; - } - yield children || ''; // don’t print “undefined” as string - yield ``; -} - -async function renderToStaticMarkup(Component, props, children) { - let tagName = Component; - - let out = ''; - for (let chunk of render(tagName, props, children)) { - out += chunk; - } - - return { - html: out, - }; -} - -export default { - check, - renderToStaticMarkup, -}; diff --git a/packages/renderers/renderer-preact/CHANGELOG.md b/packages/renderers/renderer-preact/CHANGELOG.md deleted file mode 100644 index 39179799ac..0000000000 --- a/packages/renderers/renderer-preact/CHANGELOG.md +++ /dev/null @@ -1,119 +0,0 @@ -# @astrojs/renderer-preact - -## 0.5.0 - -### Minor Changes - -- [#2563](https://github.com/withastro/astro/pull/2563) [`a907a73b`](https://github.com/withastro/astro/commit/a907a73b8cd14726d158ea460932f9cd8891923a) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Upgrade renderer dependencies for `vite@2.8.x` - -## 0.5.0-next.0 - -### Minor Changes - -- [#2563](https://github.com/withastro/astro/pull/2563) [`a907a73b`](https://github.com/withastro/astro/commit/a907a73b8cd14726d158ea460932f9cd8891923a) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Upgrade renderer dependencies for `vite@2.8.x` - -## 0.4.0 - -### Minor Changes - -- [#2202](https://github.com/withastro/astro/pull/2202) [`45cea6ae`](https://github.com/withastro/astro/commit/45cea6aec5a310fed4cb8da0d96670d6b99a2539) Thanks [@jonathantneal](https://github.com/jonathantneal)! - Officially drop support for Node v12. The minimum supported version is now Node v14.15+, - -## 0.3.2 - -### Patch Changes - -- [#2170](https://github.com/withastro/astro/pull/2170) [`5af24efb`](https://github.com/withastro/astro/commit/5af24efb3493b8f5b6a8f980c792455c7dc34eb5) Thanks [@FredKSchott](https://github.com/FredKSchott)! - Fix preact 10.6 regression by pinning to preact 10.5 - -## 0.3.1 - -### Patch Changes - -- [#2078](https://github.com/withastro/astro/pull/2078) [`ac3e8702`](https://github.com/withastro/astro/commit/ac3e870280e983a7977da79b6eec0568d38d8420) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Fix behavior of renderers when no children are passed in - -## 0.3.0 - -### Minor Changes - -- e6aaeff5: Updated framework renderers for the v0.21.0 release of Astro. Assorted changes and a new renderer interface are included in this release. - -## 0.3.0-next.1 - -### Patch Changes - -- 3cd1458a: Bugfix: Bundled CSS missing files on Windows - -## 0.3.0-next.0 - -### Minor Changes - -- d84bfe71: Updates the renderers to confirm to the new renderer API. - -## 0.2.2 - -### Patch Changes - -- 97d37f8f: Update READMEs for all renderers - -## 0.2.1 - -### Patch Changes - -- f7e86150: Fix an issue where preact component UI wouldn't update on hydrate - -## 0.2.0 - -### Minor Changes - -- bd18e14: Switches to [the new JSX Transform](https://reactjs.org/blog/2020/09/22/introducing-the-new-jsx-transform.html) originally introduced for React v17. This also leverages the new `jsxTransformOptions` options for renderers. - - This change also removes the need for importing your Framework's `jsxFactory` directly, which means you can wave goodbye to `import React from "react";` and `import { h } from "preact";`. - - > **If you are using mutliple frameworks** and a file doesn't reference `react` or `preact`, Astro might not be able to locate the correct renderer! You can add a pragma comment like `/** @jsxImportSource preact */` to the top of your file. Alternatively, just import the JSX pragma as you traditionally would have. - -### Patch Changes - -- bd18e14: Update `check` logic to exclude false-positives from SolidJS - -## 0.2.0-next.0 - -### Minor Changes - -- bd18e14: Switches to [the new JSX Transform](https://reactjs.org/blog/2020/09/22/introducing-the-new-jsx-transform.html) originally introduced for React v17. This also leverages the new `jsxTransformOptions` options for renderers. - - This change also removes the need for importing your Framework's `jsxFactory` directly, which means you can wave goodbye to `import React from "react";` and `import { h } from "preact";`. - - > **If you are using mutliple frameworks** and a file doesn't reference `react` or `preact`, Astro might not be able to locate the correct renderer! You can add a pragma comment like `/** @jsxImportSource preact */` to the top of your file. Alternatively, just import the JSX pragma as you traditionally would have. - -### Patch Changes - -- bd18e14: Update `check` logic to exclude false-positives from SolidJS - -## 0.1.3 - -### Patch Changes - -- 0abd251: Allows renderers to provide knownEntrypoint config values - -## 0.1.2 - -### Patch Changes - -- 9d4a40f: Fixes bug with using arrow function components - -## 0.1.1 - -### Patch Changes - -- ab2972b: Update package.json engines for esm support - -## 0.1.0 - -### Minor Changes - -- 643c880: Initial release - -## 0.1.0-next.0 - -### Minor Changes - -- 643c880: Initial release diff --git a/packages/renderers/renderer-preact/README.md b/packages/renderers/renderer-preact/README.md deleted file mode 100644 index eba2e0db88..0000000000 --- a/packages/renderers/renderer-preact/README.md +++ /dev/null @@ -1,31 +0,0 @@ -# @astrojs/renderer-preact - -This is a plugin for [Astro][astro] apps that enables server-side rendering of Preact components. - -## Installation - -Install `@astrojs/renderer-preact` and then add it to your `astro.config.mjs` in the `renderers` property: - -``` -npm install @astrojs/renderer-preact -``` - -__astro.config.mjs__ - -```js -export default { - // ... - - renderers: [ - // ... - '@astrojs/renderer-preact' - ] -} -``` - -## Documentation - -[Astro Renderer Documentation][renderer-docs] - -[astro]: https://astro.build -[renderer-docs]: https://docs.astro.build/reference/renderer-reference diff --git a/packages/renderers/renderer-preact/client.js b/packages/renderers/renderer-preact/client.js deleted file mode 100644 index 5ece5ddb2b..0000000000 --- a/packages/renderers/renderer-preact/client.js +++ /dev/null @@ -1,8 +0,0 @@ -import { h, render } from 'preact'; -import StaticHtml from './static-html.js'; - -export default (element) => (Component, props, children) => - render( - h(Component, props, children != null ? h(StaticHtml, { value: children }) : children), - element - ); diff --git a/packages/renderers/renderer-preact/compat/index.js b/packages/renderers/renderer-preact/compat/index.js deleted file mode 100644 index a5580f04d7..0000000000 --- a/packages/renderers/renderer-preact/compat/index.js +++ /dev/null @@ -1,36 +0,0 @@ -export default { - name: '@astrojs/renderer-preact/compat', - client: '../client.js', - server: '../server.js', - jsxImportSource: 'react', - jsxTransformOptions: async () => { - const { - default: { default: jsx }, - } = await import('@babel/plugin-transform-react-jsx'); - return { - plugins: [jsx({}, { runtime: 'automatic', importSource: 'preact/compat' })], - }; - }, - viteConfig() { - return { - alias: { - react: 'preact/compat', - 'react-dom': 'preact/compat', - }, - resolve: { - dedupe: ['react', 'react-dom'], - }, - optimizeDeps: { - include: [ - '@astrojs/renderer-preact/client.js', - 'preact/compat', - 'preact/compat/jsx-runtime', - 'preact-render-to-string', - ], - }, - ssr: { - external: ['preact-render-to-string'], - }, - }; - }, -}; diff --git a/packages/renderers/renderer-preact/index.js b/packages/renderers/renderer-preact/index.js deleted file mode 100644 index fe0a245287..0000000000 --- a/packages/renderers/renderer-preact/index.js +++ /dev/null @@ -1,30 +0,0 @@ -export default { - name: '@astrojs/renderer-preact', - client: './client.js', - server: './server.js', - jsxImportSource: 'preact', - jsxTransformOptions: async () => { - const { - default: { default: jsx }, - } = await import('@babel/plugin-transform-react-jsx'); - return { - plugins: [jsx({}, { runtime: 'automatic', importSource: 'preact' })], - }; - }, - viteConfig() { - return { - optimizeDeps: { - include: [ - '@astrojs/renderer-preact/client.js', - 'preact', - 'preact/jsx-runtime', - 'preact-render-to-string', - ], - exclude: ['@astrojs/renderer-preact/server.js'], - }, - ssr: { - external: ['preact-render-to-string'], - }, - }; - }, -}; diff --git a/packages/renderers/renderer-preact/package.json b/packages/renderers/renderer-preact/package.json deleted file mode 100644 index 81dea572b3..0000000000 --- a/packages/renderers/renderer-preact/package.json +++ /dev/null @@ -1,31 +0,0 @@ -{ - "name": "@astrojs/renderer-preact", - "description": "Use Preact components within Astro", - "version": "0.5.0", - "type": "module", - "author": "withastro", - "license": "MIT", - "repository": { - "type": "git", - "url": "https://github.com/withastro/astro.git", - "directory": "packages/renderers/renderer-preact" - }, - "bugs": "https://github.com/withastro/astro/issues", - "homepage": "https://astro.build", - "exports": { - ".": "./index.js", - "./*": "./*", - "./compat": "./compat/index.js", - "./client.js": "./client.js", - "./server.js": "./server.js", - "./package.json": "./package.json" - }, - "dependencies": { - "@babel/plugin-transform-react-jsx": "^7.17.3", - "preact": "^10.7.1", - "preact-render-to-string": "^5.1.21" - }, - "engines": { - "node": "^14.15.0 || >=16.0.0" - } -} diff --git a/packages/renderers/renderer-preact/server.js b/packages/renderers/renderer-preact/server.js deleted file mode 100644 index 0729f42e92..0000000000 --- a/packages/renderers/renderer-preact/server.js +++ /dev/null @@ -1,37 +0,0 @@ -import { h, Component as BaseComponent } from 'preact'; -import render from 'preact-render-to-string'; -import StaticHtml from './static-html.js'; - -function check(Component, props, children) { - if (typeof Component !== 'function') return false; - - if (Component.prototype != null && typeof Component.prototype.render === 'function') { - return BaseComponent.isPrototypeOf(Component); - } - - try { - const { html } = renderToStaticMarkup(Component, props, children); - if (typeof html !== 'string') { - return false; - } - - // There are edge cases (SolidJS) where Preact *might* render a string, - // but components would be - - return !/\/.test(html); - } catch (err) { - return false; - } -} - -function renderToStaticMarkup(Component, props, children) { - const html = render( - h(Component, props, children != null ? h(StaticHtml, { value: children }) : children) - ); - return { html }; -} - -export default { - check, - renderToStaticMarkup, -}; diff --git a/packages/renderers/renderer-preact/static-html.js b/packages/renderers/renderer-preact/static-html.js deleted file mode 100644 index 9af8002a77..0000000000 --- a/packages/renderers/renderer-preact/static-html.js +++ /dev/null @@ -1,24 +0,0 @@ -import { h } from 'preact'; - -/** - * Astro passes `children` as a string of HTML, so we need - * a wrapper `div` to render that content as VNodes. - * - * As a bonus, we can signal to Preact that this subtree is - * entirely static and will never change via `shouldComponentUpdate`. - */ -const StaticHtml = ({ value }) => { - if (!value) return null; - return h('astro-fragment', { dangerouslySetInnerHTML: { __html: value } }); -}; - -/** - * This tells Preact to opt-out of re-rendering this subtree, - * In addition to being a performance optimization, - * this also allows other frameworks to attach to `children`. - * - * See https://preactjs.com/guide/v8/external-dom-mutations - */ -StaticHtml.shouldComponentUpdate = () => false; - -export default StaticHtml; diff --git a/packages/renderers/renderer-react/CHANGELOG.md b/packages/renderers/renderer-react/CHANGELOG.md deleted file mode 100644 index 199740b382..0000000000 --- a/packages/renderers/renderer-react/CHANGELOG.md +++ /dev/null @@ -1,123 +0,0 @@ -# @astrojs/renderer-react - -## 0.5.0 - -### Minor Changes - -- [#2563](https://github.com/withastro/astro/pull/2563) [`a907a73b`](https://github.com/withastro/astro/commit/a907a73b8cd14726d158ea460932f9cd8891923a) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Upgrade renderer dependencies for `vite@2.8.x` - -## 0.5.0-next.0 - -### Minor Changes - -- [#2563](https://github.com/withastro/astro/pull/2563) [`a907a73b`](https://github.com/withastro/astro/commit/a907a73b8cd14726d158ea460932f9cd8891923a) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Upgrade renderer dependencies for `vite@2.8.x` - -## 0.4.1 - -### Patch Changes - -- [#2369](https://github.com/withastro/astro/pull/2369) [`20eaddb2`](https://github.com/withastro/astro/commit/20eaddb2a723253c7fbde3e56955a549bdf3f342) Thanks [@matthewp](https://github.com/matthewp)! - Fix for using the React renderer with the static build - -## 0.4.0 - -### Minor Changes - -- [#2202](https://github.com/withastro/astro/pull/2202) [`45cea6ae`](https://github.com/withastro/astro/commit/45cea6aec5a310fed4cb8da0d96670d6b99a2539) Thanks [@jonathantneal](https://github.com/jonathantneal)! - Officially drop support for Node v12. The minimum supported version is now Node v14.15+, - -## 0.3.1 - -### Patch Changes - -- [#2078](https://github.com/withastro/astro/pull/2078) [`ac3e8702`](https://github.com/withastro/astro/commit/ac3e870280e983a7977da79b6eec0568d38d8420) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Fix behavior of renderers when no children are passed in - -## 0.3.0 - -### Minor Changes - -- e6aaeff5: Updated framework renderers for the v0.21.0 release of Astro. Assorted changes and a new renderer interface are included in this release. - -## 0.3.0-next.1 - -### Patch Changes - -- 3cd1458a: Bugfix: Bundled CSS missing files on Windows - -## 0.3.0-next.0 - -### Minor Changes - -- d84bfe71: Updates the renderers to confirm to the new renderer API. - -## 0.2.2 - -### Patch Changes - -- 756e3769: Fixes detect to allow rendering React.PureComponents - -## 0.2.1 - -### Patch Changes - -- 97d37f8f: Update READMEs for all renderers - -## 0.2.0 - -### Minor Changes - -- bd18e14: Switches to [the new JSX Transform](https://reactjs.org/blog/2020/09/22/introducing-the-new-jsx-transform.html) originally introduced for React v17. This also leverages the new `jsxTransformOptions` options for renderers. - - This change also removes the need for importing your Framework's `jsxFactory` directly, which means you can wave goodbye to `import React from "react";` and `import { h } from "preact";`. - - > **If you are using mutliple frameworks** and a file doesn't reference `react` or `preact`, Astro might not be able to locate the correct renderer! You can add a pragma comment like `/** @jsxImportSource preact */` to the top of your file. Alternatively, just import the JSX pragma as you traditionally would have. - -## 0.2.0-next.0 - -### Minor Changes - -- bd18e14: Switches to [the new JSX Transform](https://reactjs.org/blog/2020/09/22/introducing-the-new-jsx-transform.html) originally introduced for React v17. This also leverages the new `jsxTransformOptions` options for renderers. - - This change also removes the need for importing your Framework's `jsxFactory` directly, which means you can wave goodbye to `import React from "react";` and `import { h } from "preact";`. - - > **If you are using mutliple frameworks** and a file doesn't reference `react` or `preact`, Astro might not be able to locate the correct renderer! You can add a pragma comment like `/** @jsxImportSource preact */` to the top of your file. Alternatively, just import the JSX pragma as you traditionally would have. - -## 0.1.5 - -### Patch Changes - -- 1e01251: Fixes bug with React renderer that would not hydrate correctly - -## 0.1.4 - -### Patch Changes - -- 21dc28c: Add react-dom as a knownEntrypoint (speeds up astro startup) - -## 0.1.3 - -### Patch Changes - -- 0abd251: Allows renderers to provide knownEntrypoint config values - -## 0.1.2 - -### Patch Changes - -- 9d4a40f: Fixes bug with using arrow function components - -## 0.1.1 - -### Patch Changes - -- ab2972b: Update package.json engines for esm support - -## 0.1.0 - -### Minor Changes - -- 643c880: Initial release - -## 0.1.0-next.0 - -### Minor Changes - -- 643c880: Initial release diff --git a/packages/renderers/renderer-react/README.md b/packages/renderers/renderer-react/README.md deleted file mode 100644 index cc36073f19..0000000000 --- a/packages/renderers/renderer-react/README.md +++ /dev/null @@ -1,31 +0,0 @@ -# @astrojs/renderer-react - -This is a plugin for [Astro][astro] apps that enables server-side rendering of React components. - -## Installation - -Install `@astrojs/renderer-react` and then add it to your `astro.config.mjs` in the `renderers` property: - -``` -npm install @astrojs/renderer-react -``` - -__astro.config.mjs__ - -```js -export default { - // ... - - renderers: [ - // ... - '@astrojs/renderer-react' - ] -} -``` - -## Documentation - -[Astro Renderer Documentation][renderer-docs] - -[astro]: https://astro.build -[renderer-docs]: https://docs.astro.build/reference/renderer-reference diff --git a/packages/renderers/renderer-react/client.js b/packages/renderers/renderer-react/client.js deleted file mode 100644 index 64284a0b01..0000000000 --- a/packages/renderers/renderer-react/client.js +++ /dev/null @@ -1,15 +0,0 @@ -import { createElement } from 'react'; -import { hydrate } from 'react-dom'; -import StaticHtml from './static-html.js'; - -export default (element) => (Component, props, children) => - hydrate( - createElement( - Component, - { ...props, suppressHydrationWarning: true }, - children != null - ? createElement(StaticHtml, { value: children, suppressHydrationWarning: true }) - : children - ), - element - ); diff --git a/packages/renderers/renderer-react/index.js b/packages/renderers/renderer-react/index.js deleted file mode 100644 index 698f2a13c7..0000000000 --- a/packages/renderers/renderer-react/index.js +++ /dev/null @@ -1,42 +0,0 @@ -export default { - name: '@astrojs/renderer-react', - client: './client.js', - server: './server.js', - jsxImportSource: 'react', - jsxTransformOptions: async () => { - const { - default: { default: jsx }, - } = await import('@babel/plugin-transform-react-jsx'); - return { - plugins: [ - jsx( - {}, - { - runtime: 'automatic', - importSource: '@astrojs/renderer-react', - } - ), - ], - }; - }, - viteConfig() { - return { - optimizeDeps: { - include: [ - '@astrojs/renderer-react/client.js', - 'react', - 'react/jsx-runtime', - 'react/jsx-dev-runtime', - 'react-dom', - ], - exclude: ['@astrojs/renderer-react/server.js'], - }, - resolve: { - dedupe: ['react', 'react-dom'], - }, - ssr: { - external: ['react-dom/server.js'], - }, - }; - }, -}; diff --git a/packages/renderers/renderer-react/jsx-runtime.js b/packages/renderers/renderer-react/jsx-runtime.js deleted file mode 100644 index d86f698b9c..0000000000 --- a/packages/renderers/renderer-react/jsx-runtime.js +++ /dev/null @@ -1,8 +0,0 @@ -// This module is a simple wrapper around react/jsx-runtime so that -// it can run in Node ESM. 'react' doesn't declare this module as an export map -// So we have to use the .js. The .js is not added via the babel automatic JSX transform -// hence this module as a workaround. -import jsxr from 'react/jsx-runtime.js'; -const { jsx, jsxs, Fragment } = jsxr; - -export { jsx, jsxs, Fragment }; diff --git a/packages/renderers/renderer-react/package.json b/packages/renderers/renderer-react/package.json deleted file mode 100644 index ba35445e7f..0000000000 --- a/packages/renderers/renderer-react/package.json +++ /dev/null @@ -1,31 +0,0 @@ -{ - "name": "@astrojs/renderer-react", - "description": "Use React components within Astro", - "version": "0.5.0", - "type": "module", - "author": "withastro", - "license": "MIT", - "repository": { - "type": "git", - "url": "https://github.com/withastro/astro.git", - "directory": "packages/renderers/renderer-react" - }, - "bugs": "https://github.com/withastro/astro/issues", - "homepage": "https://astro.build", - "exports": { - ".": "./index.js", - "./*": "./*", - "./client.js": "./client.js", - "./server.js": "./server.js", - "./package.json": "./package.json", - "./jsx-runtime": "./jsx-runtime.js" - }, - "dependencies": { - "@babel/plugin-transform-react-jsx": "^7.17.3", - "react": "^18.0.0", - "react-dom": "^18.0.0" - }, - "engines": { - "node": "^14.15.0 || >=16.0.0" - } -} diff --git a/packages/renderers/renderer-react/server.js b/packages/renderers/renderer-react/server.js deleted file mode 100644 index b48d7b6f48..0000000000 --- a/packages/renderers/renderer-react/server.js +++ /dev/null @@ -1,71 +0,0 @@ -import React from 'react'; -import ReactDOM from 'react-dom/server.js'; -import StaticHtml from './static-html.js'; - -const reactTypeof = Symbol.for('react.element'); - -function errorIsComingFromPreactComponent(err) { - return ( - err.message && - (err.message.startsWith("Cannot read property '__H'") || - err.message.includes("(reading '__H')")) - ); -} - -function check(Component, props, children) { - // Note: there are packages that do some unholy things to create "components". - // Checking the $$typeof property catches most of these patterns. - if (typeof Component === 'object') { - const $$typeof = Component['$$typeof']; - return $$typeof && $$typeof.toString().slice('Symbol('.length).startsWith('react'); - } - if (typeof Component !== 'function') return false; - - if (Component.prototype != null && typeof Component.prototype.render === 'function') { - return React.Component.isPrototypeOf(Component) || React.PureComponent.isPrototypeOf(Component); - } - - let error = null; - let isReactComponent = false; - function Tester(...args) { - try { - const vnode = Component(...args); - if (vnode && vnode['$$typeof'] === reactTypeof) { - isReactComponent = true; - } - } catch (err) { - if (!errorIsComingFromPreactComponent(err)) { - error = err; - } - } - - return React.createElement('div'); - } - - renderToStaticMarkup(Tester, props, children, {}); - - if (error) { - throw error; - } - return isReactComponent; -} - -function renderToStaticMarkup(Component, props, children, metadata) { - delete props['class']; - const vnode = React.createElement(Component, { - ...props, - children: children != null ? React.createElement(StaticHtml, { value: children }) : undefined, - }); - let html; - if (metadata && metadata.hydrate) { - html = ReactDOM.renderToString(vnode); - } else { - html = ReactDOM.renderToStaticMarkup(vnode); - } - return { html }; -} - -export default { - check, - renderToStaticMarkup, -}; diff --git a/packages/renderers/renderer-react/static-html.js b/packages/renderers/renderer-react/static-html.js deleted file mode 100644 index ecd76ae9bf..0000000000 --- a/packages/renderers/renderer-react/static-html.js +++ /dev/null @@ -1,27 +0,0 @@ -import { createElement as h } from 'react'; - -/** - * Astro passes `children` as a string of HTML, so we need - * a wrapper `div` to render that content as VNodes. - * - * As a bonus, we can signal to React that this subtree is - * entirely static and will never change via `shouldComponentUpdate`. - */ -const StaticHtml = ({ value }) => { - if (!value) return null; - return h('astro-fragment', { - suppressHydrationWarning: true, - dangerouslySetInnerHTML: { __html: value }, - }); -}; - -/** - * This tells React to opt-out of re-rendering this subtree, - * In addition to being a performance optimization, - * this also allows other frameworks to attach to `children`. - * - * See https://preactjs.com/guide/v8/external-dom-mutations - */ -StaticHtml.shouldComponentUpdate = () => false; - -export default StaticHtml; diff --git a/packages/renderers/renderer-solid/CHANGELOG.md b/packages/renderers/renderer-solid/CHANGELOG.md deleted file mode 100644 index a1365f1500..0000000000 --- a/packages/renderers/renderer-solid/CHANGELOG.md +++ /dev/null @@ -1,95 +0,0 @@ -# @astrojs/renderer-solid - -## 0.4.2 - -### Patch Changes - -- [`815d62f1`](https://github.com/withastro/astro/commit/815d62f151a36fef7d09590d4962ca71bda61b32) Thanks [@FredKSchott](https://github.com/FredKSchott)! - no changes. - -## 0.4.1 - -### Patch Changes - -- [#3003](https://github.com/withastro/astro/pull/3003) [`13b782f4`](https://github.com/withastro/astro/commit/13b782f421871af36978f29154c715c66739d475) Thanks [@ryansolid](https://github.com/ryansolid)! - Improve nested hydration with Solid - -## 0.4.1-beta.0 - -### Patch Changes - -- [#3003](https://github.com/withastro/astro/pull/3003) [`13b782f4`](https://github.com/withastro/astro/commit/13b782f421871af36978f29154c715c66739d475) Thanks [@ryansolid](https://github.com/ryansolid)! - Improve nested hydration with Solid - -## 0.4.0 - -### Minor Changes - -- [#2563](https://github.com/withastro/astro/pull/2563) [`a907a73b`](https://github.com/withastro/astro/commit/a907a73b8cd14726d158ea460932f9cd8891923a) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Upgrade renderer dependencies for `vite@2.8.x` - -## 0.4.0-next.0 - -### Minor Changes - -- [#2563](https://github.com/withastro/astro/pull/2563) [`a907a73b`](https://github.com/withastro/astro/commit/a907a73b8cd14726d158ea460932f9cd8891923a) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Upgrade renderer dependencies for `vite@2.8.x` - -## 0.3.1 - -### Patch Changes - -- [#2359](https://github.com/withastro/astro/pull/2359) [`f482c626`](https://github.com/withastro/astro/commit/f482c626a6e3472052d13cb0d348323ef4e822a8) Thanks [@toSayNothing](https://github.com/toSayNothing)! - fix renderer-solid - -## 0.3.0 - -### Minor Changes - -- [#2202](https://github.com/withastro/astro/pull/2202) [`45cea6ae`](https://github.com/withastro/astro/commit/45cea6aec5a310fed4cb8da0d96670d6b99a2539) Thanks [@jonathantneal](https://github.com/jonathantneal)! - Officially drop support for Node v12. The minimum supported version is now Node v14.15+, - -## 0.2.1 - -### Patch Changes - -- [#2078](https://github.com/withastro/astro/pull/2078) [`ac3e8702`](https://github.com/withastro/astro/commit/ac3e870280e983a7977da79b6eec0568d38d8420) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Fix behavior of renderers when no children are passed in - -## 0.2.0 - -### Minor Changes - -- e6aaeff5: Updated framework renderers for the v0.21.0 release of Astro. Assorted changes and a new renderer interface are included in this release. - -## 0.2.0-next.1 - -### Patch Changes - -- 3cd1458a: Bugfix: Bundled CSS missing files on Windows - -## 0.2.0-next.0 - -### Minor Changes - -- d84bfe71: Updates the renderers to confirm to the new renderer API. - -## 0.1.1 - -### Patch Changes - -- 97d37f8f: Update READMEs for all renderers - -## 0.1.0 - -### Minor Changes - -- bd18e14: Initial release - -### Patch Changes - -- bef5103: Uses Solid's `render` function to render our components on the client. - -## 0.1.0-next.1 - -### Patch Changes - -- bef5103: Uses Solid's `render` function to render our components on the client. - -## 0.1.0-next.0 - -### Minor Changes - -- bd18e14: Initial release diff --git a/packages/renderers/renderer-solid/README.md b/packages/renderers/renderer-solid/README.md deleted file mode 100644 index f2ca3c8801..0000000000 --- a/packages/renderers/renderer-solid/README.md +++ /dev/null @@ -1,31 +0,0 @@ -# @astrojs/renderer-solid - -This is a plugin for [Astro][astro] apps that enables server-side rendering of SolidJS components. - -## Installation - -Install `@astrojs/renderer-solid` and then add it to your `astro.config.mjs` in the `renderers` property: - -``` -npm install @astrojs/renderer-solid -``` - -__astro.config.mjs__ - -```js -export default { - // ... - - renderers: [ - // ... - '@astrojs/renderer-solid' - ] -} -``` - -## Documentation - -[Astro Renderer Documentation][renderer-docs] - -[astro]: https://astro.build -[renderer-docs]: https://docs.astro.build/reference/renderer-reference diff --git a/packages/renderers/renderer-solid/client.js b/packages/renderers/renderer-solid/client.js deleted file mode 100644 index 4424e9b985..0000000000 --- a/packages/renderers/renderer-solid/client.js +++ /dev/null @@ -1,25 +0,0 @@ -import { sharedConfig } from 'solid-js'; -import { hydrate, createComponent } from 'solid-js/web'; - -export default (element) => (Component, props, childHTML) => { - let children; - hydrate( - () => - createComponent(Component, { - ...props, - get children() { - if (childHTML != null) { - // hydrating - if (sharedConfig.context) children = element.querySelector('astro-fragment'); - - if (children == null) { - children = document.createElement('astro-fragment'); - children.innerHTML = childHTML; - } - } - return children; - }, - }), - element - ); -}; diff --git a/packages/renderers/renderer-solid/index.js b/packages/renderers/renderer-solid/index.js deleted file mode 100644 index 42715ffe66..0000000000 --- a/packages/renderers/renderer-solid/index.js +++ /dev/null @@ -1,49 +0,0 @@ -export default { - name: '@astrojs/renderer-solid', - client: './client.js', - server: './server.js', - jsxImportSource: 'solid-js', - jsxTransformOptions: async ({ ssr }) => { - const [{ default: solid }] = await Promise.all([import('babel-preset-solid')]); - const options = { - presets: [solid({}, { generate: ssr ? 'ssr' : 'dom', hydratable: true })], - plugins: [], - }; - - return options; - }, - viteConfig(options) { - // https://github.com/solidjs/vite-plugin-solid - - // We inject the dev mode only if the user explicitely wants it or if we are in dev (serve) mode - const replaceDev = options.mode === 'development' || options.command === 'serve'; - - const nestedDeps = [ - 'solid-js', - 'solid-js/web', - 'solid-js/store', - 'solid-js/html', - 'solid-js/h', - ]; - - return { - /** - * We only need esbuild on .ts or .js files. - * .tsx & .jsx files are handled by us - */ - esbuild: { include: /\.ts$/ }, - resolve: { - conditions: ['solid', ...(replaceDev ? ['development'] : [])], - dedupe: nestedDeps, - alias: [{ find: /^solid-refresh$/, replacement: '/@solid-refresh' }], - }, - optimizeDeps: { - include: nestedDeps, - exclude: ['@astrojs/renderer-solid/server.js'], - }, - ssr: { - external: ['babel-preset-solid'], - }, - }; - }, -}; diff --git a/packages/renderers/renderer-solid/package.json b/packages/renderers/renderer-solid/package.json deleted file mode 100644 index ba6773e731..0000000000 --- a/packages/renderers/renderer-solid/package.json +++ /dev/null @@ -1,29 +0,0 @@ -{ - "name": "@astrojs/renderer-solid", - "version": "0.4.2", - "description": "Use Solid components within Astro", - "type": "module", - "author": "withastro", - "license": "MIT", - "repository": { - "type": "git", - "url": "https://github.com/withastro/astro.git", - "directory": "packages/renderers/renderer-solid" - }, - "bugs": "https://github.com/withastro/astro/issues", - "homepage": "https://astro.build", - "exports": { - ".": "./index.js", - "./*": "./*", - "./client.js": "./client.js", - "./server.js": "./server.js", - "./package.json": "./package.json" - }, - "dependencies": { - "babel-preset-solid": "^1.3.13", - "solid-js": "^1.3.14" - }, - "engines": { - "node": "^14.15.0 || >=16.0.0" - } -} diff --git a/packages/renderers/renderer-solid/server.js b/packages/renderers/renderer-solid/server.js deleted file mode 100644 index ccee482eaa..0000000000 --- a/packages/renderers/renderer-solid/server.js +++ /dev/null @@ -1,30 +0,0 @@ -import { renderToString, ssr, createComponent } from 'solid-js/web'; - -function check(Component, props, children) { - if (typeof Component !== 'function') return false; - try { - const { html } = renderToStaticMarkup(Component, props, children); - return typeof html === 'string'; - } catch (err) { - return false; - } -} - -function renderToStaticMarkup(Component, props, children) { - const html = renderToString(() => - createComponent(Component, { - ...props, - // In Solid SSR mode, `ssr` creates the expected structure for `children`. - // In Solid client mode, `ssr` is just a stub. - children: children != null ? ssr(`${children}`) : children, - }) - ); - return { - html: html + ``, - }; -} - -export default { - check, - renderToStaticMarkup, -}; diff --git a/packages/renderers/renderer-solid/static-html.js b/packages/renderers/renderer-solid/static-html.js deleted file mode 100644 index 9f969eac90..0000000000 --- a/packages/renderers/renderer-solid/static-html.js +++ /dev/null @@ -1,12 +0,0 @@ -import { ssr } from 'solid-js/web'; - -/** - * Astro passes `children` as a string of HTML, so we need - * a wrapper `astro-fragment` to render that content as VNodes. - */ -const StaticHtml = ({ innerHTML }) => { - if (!innerHTML) return null; - return ssr(`${innerHTML}`); -}; - -export default StaticHtml; diff --git a/packages/renderers/renderer-svelte/CHANGELOG.md b/packages/renderers/renderer-svelte/CHANGELOG.md deleted file mode 100644 index 2ca67ddac4..0000000000 --- a/packages/renderers/renderer-svelte/CHANGELOG.md +++ /dev/null @@ -1,109 +0,0 @@ -# @astrojs/renderer-svelte - -## 0.5.2 - -### Patch Changes - -- [#2807](https://github.com/withastro/astro/pull/2807) [`79282163`](https://github.com/withastro/astro/commit/79282163e229bfe332b1221be3099f751b05807b) Thanks [@bholmesdev](https://github.com/bholmesdev)! - Remove "PostCSS configuration was not passed or is invalid" error when using the Svelte renderer - -## 0.5.1 - -### Patch Changes - -- [#2722](https://github.com/withastro/astro/pull/2722) [`0d37f8e0`](https://github.com/withastro/astro/commit/0d37f8e0a51ac7bcf9e108151828b733bbba6e94) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Temporarily revert [#2715](https://github.com/withastro/astro/pull/2715) to fix `.svelte` files breaking in the static build. - -## 0.5.0 - -### Minor Changes - -- [#2715](https://github.com/withastro/astro/pull/2715) [`5f91e007`](https://github.com/withastro/astro/commit/5f91e007cbbb3a5ff7322964d811844b0921db61) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Internally, we'll now use Vite to preprocess assets rather than pulling in `svelte-preprocess`. - - > This removes the default warnings about missing `postcss-load-config` - -## 0.4.0 - -### Minor Changes - -- [#2563](https://github.com/withastro/astro/pull/2563) [`a907a73b`](https://github.com/withastro/astro/commit/a907a73b8cd14726d158ea460932f9cd8891923a) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Upgrade renderer dependencies for `vite@2.8.x` - -## 0.4.0-next.0 - -### Minor Changes - -- [#2563](https://github.com/withastro/astro/pull/2563) [`a907a73b`](https://github.com/withastro/astro/commit/a907a73b8cd14726d158ea460932f9cd8891923a) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Upgrade renderer dependencies for `vite@2.8.x` - -## 0.3.1 - -### Patch Changes - -- [#2300](https://github.com/withastro/astro/pull/2300) [`34486676`](https://github.com/withastro/astro/commit/344866762c3a96b92bd754cf3706db73e2d74647) Thanks [@moritzlaube](https://github.com/moritzlaube)! - Update Svelte to 3.44.3 to get rid of console warning that component receives an unexpected slot "default". - -## 0.3.0 - -### Minor Changes - -- [#2202](https://github.com/withastro/astro/pull/2202) [`45cea6ae`](https://github.com/withastro/astro/commit/45cea6aec5a310fed4cb8da0d96670d6b99a2539) Thanks [@jonathantneal](https://github.com/jonathantneal)! - Officially drop support for Node v12. The minimum supported version is now Node v14.15+, - -## 0.2.3 - -### Patch Changes - -- [#2216](https://github.com/withastro/astro/pull/2216) [`b8c821a0`](https://github.com/withastro/astro/commit/b8c821a0743ed004691eae0eea471a368d2fa35f) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Pin `@sveltejs/vite-plugin-svelte` to `1.0.0-next.30` for now - -## 0.2.2 - -### Patch Changes - -- [#2078](https://github.com/withastro/astro/pull/2078) [`ac3e8702`](https://github.com/withastro/astro/commit/ac3e870280e983a7977da79b6eec0568d38d8420) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Fix behavior of renderers when no children are passed in - -## 0.2.1 - -### Patch Changes - -- 4cec1256: Add TypeScript, Sass support to Svelte - -## 0.2.0 - -### Minor Changes - -- e6aaeff5: Updated framework renderers for the v0.21.0 release of Astro. Assorted changes and a new renderer interface are included in this release. - -## 0.2.0-next.1 - -### Patch Changes - -- 3cd1458a: Bugfix: Bundled CSS missing files on Windows - -## 0.2.0-next.0 - -### Minor Changes - -- d84bfe71: Updates the renderers to confirm to the new renderer API. - -## 0.1.2 - -### Patch Changes - -- 97d37f8f: Update READMEs for all renderers - -## 0.1.1 - -### Patch Changes - -- ab2972b: Update package.json engines for esm support - -## 0.1.0 - -### Minor Changes - -- 643c880: Initial release - -### Patch Changes - -- c9d833e: Fixed a bug that was preventing SSR from working - -## 0.1.0-next.0 - -### Minor Changes - -- 643c880: Initial release diff --git a/packages/renderers/renderer-svelte/README.md b/packages/renderers/renderer-svelte/README.md deleted file mode 100644 index 4333780679..0000000000 --- a/packages/renderers/renderer-svelte/README.md +++ /dev/null @@ -1,31 +0,0 @@ -# @astrojs/renderer-svelte - -This is a plugin for [Astro][astro] apps that enables server-side rendering of Svelte components. - -## Installation - -Install `@astrojs/renderer-svelte` and then add it to your `astro.config.mjs` in the `renderers` property: - -``` -npm install @astrojs/renderer-svelte -``` - -__astro.config.mjs__ - -```js -export default { - // ... - - renderers: [ - // ... - '@astrojs/renderer-svelte' - ] -} -``` - -## Documentation - -[Astro Renderer Documentation][renderer-docs] - -[astro]: https://astro.build -[renderer-docs]: https://docs.astro.build/reference/renderer-reference diff --git a/packages/renderers/renderer-svelte/Wrapper.svelte b/packages/renderers/renderer-svelte/Wrapper.svelte deleted file mode 100644 index c1ee77d918..0000000000 --- a/packages/renderers/renderer-svelte/Wrapper.svelte +++ /dev/null @@ -1,21 +0,0 @@ - - - - {#if __astro_children != null} - - {@html __astro_children} - - {/if} - diff --git a/packages/renderers/renderer-svelte/Wrapper.svelte.ssr.js b/packages/renderers/renderer-svelte/Wrapper.svelte.ssr.js deleted file mode 100644 index e6a4781a74..0000000000 --- a/packages/renderers/renderer-svelte/Wrapper.svelte.ssr.js +++ /dev/null @@ -1,19 +0,0 @@ -/* App.svelte generated by Svelte v3.38.2 */ -import { create_ssr_component, missing_component, validate_component } from 'svelte/internal'; - -const App = create_ssr_component(($$result, $$props, $$bindings, slots) => { - const { __astro_component: Component, __astro_children, ...props } = $$props; - const children = {}; - if (__astro_children != null) { - children.default = () => `${__astro_children}`; - } - - return `${validate_component(Component || missing_component, 'svelte:component').$$render( - $$result, - Object.assign(props), - {}, - children - )}`; -}); - -export default App; diff --git a/packages/renderers/renderer-svelte/client.js b/packages/renderers/renderer-svelte/client.js deleted file mode 100644 index c10c7afa01..0000000000 --- a/packages/renderers/renderer-svelte/client.js +++ /dev/null @@ -1,14 +0,0 @@ -import SvelteWrapper from './Wrapper.svelte'; - -export default (target) => { - return (component, props, children) => { - delete props['class']; - try { - new SvelteWrapper({ - target, - props: { __astro_component: component, __astro_children: children, ...props }, - hydrate: true, - }); - } catch (e) {} - }; -}; diff --git a/packages/renderers/renderer-svelte/index.js b/packages/renderers/renderer-svelte/index.js deleted file mode 100644 index 0b849ba9d4..0000000000 --- a/packages/renderers/renderer-svelte/index.js +++ /dev/null @@ -1,31 +0,0 @@ -import { svelte } from '@sveltejs/vite-plugin-svelte'; -import preprocess from 'svelte-preprocess'; - -export default { - name: '@astrojs/renderer-svelte', - client: './client.js', - server: './server.js', - viteConfig({ mode }) { - return { - optimizeDeps: { - include: ['@astrojs/renderer-svelte/client.js', 'svelte', 'svelte/internal'], - exclude: ['@astrojs/renderer-svelte/server.js'], - }, - plugins: [ - svelte({ - emitCss: true, - compilerOptions: { dev: mode === 'development', hydratable: true }, - preprocess: [ - preprocess({ - less: true, - sass: { renderSync: true }, - scss: { renderSync: true }, - stylus: true, - typescript: true, - }), - ], - }), - ], - }; - }, -}; diff --git a/packages/renderers/renderer-svelte/package.json b/packages/renderers/renderer-svelte/package.json deleted file mode 100644 index 62323cfce9..0000000000 --- a/packages/renderers/renderer-svelte/package.json +++ /dev/null @@ -1,31 +0,0 @@ -{ - "name": "@astrojs/renderer-svelte", - "version": "0.5.2", - "description": "Use Svelte components within Astro", - "type": "module", - "author": "withastro", - "license": "MIT", - "repository": { - "type": "git", - "url": "https://github.com/withastro/astro.git", - "directory": "packages/renderers/renderer-svelte" - }, - "bugs": "https://github.com/withastro/astro/issues", - "homepage": "https://astro.build", - "exports": { - ".": "./index.js", - "./*": "./*", - "./client.js": "./client.js", - "./server.js": "./server.js", - "./package.json": "./package.json" - }, - "dependencies": { - "@sveltejs/vite-plugin-svelte": "^1.0.0-next.41", - "svelte": "^3.47.0", - "svelte-preprocess": "^4.10.5", - "vite": "^2.9.1" - }, - "engines": { - "node": "^14.15.0 || >=16.0.0" - } -} diff --git a/packages/renderers/renderer-svelte/server.js b/packages/renderers/renderer-svelte/server.js deleted file mode 100644 index 3c989cd5a9..0000000000 --- a/packages/renderers/renderer-svelte/server.js +++ /dev/null @@ -1,19 +0,0 @@ -import SvelteWrapper from './Wrapper.svelte.ssr.js'; - -function check(Component) { - return Component['render'] && Component['$$render']; -} - -async function renderToStaticMarkup(Component, props, children) { - const { html } = SvelteWrapper.render({ - __astro_component: Component, - __astro_children: children, - ...props, - }); - return { html }; -} - -export default { - check, - renderToStaticMarkup, -}; diff --git a/packages/renderers/renderer-vue/CHANGELOG.md b/packages/renderers/renderer-vue/CHANGELOG.md deleted file mode 100644 index 96639066e4..0000000000 --- a/packages/renderers/renderer-vue/CHANGELOG.md +++ /dev/null @@ -1,121 +0,0 @@ -# @astrojs/renderer-vue - -## 0.4.0 - -### Minor Changes - -- [#2563](https://github.com/withastro/astro/pull/2563) [`a907a73b`](https://github.com/withastro/astro/commit/a907a73b8cd14726d158ea460932f9cd8891923a) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Upgrade renderer dependencies for `vite@2.8.x` - -## 0.4.0-next.0 - -### Minor Changes - -- [#2563](https://github.com/withastro/astro/pull/2563) [`a907a73b`](https://github.com/withastro/astro/commit/a907a73b8cd14726d158ea460932f9cd8891923a) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Upgrade renderer dependencies for `vite@2.8.x` - -## 0.3.0 - -### Minor Changes - -- [#2202](https://github.com/withastro/astro/pull/2202) [`45cea6ae`](https://github.com/withastro/astro/commit/45cea6aec5a310fed4cb8da0d96670d6b99a2539) Thanks [@jonathantneal](https://github.com/jonathantneal)! - Officially drop support for Node v12. The minimum supported version is now Node v14.15+, - -## 0.2.1 - -### Patch Changes - -- [#2078](https://github.com/withastro/astro/pull/2078) [`ac3e8702`](https://github.com/withastro/astro/commit/ac3e870280e983a7977da79b6eec0568d38d8420) Thanks [@natemoo-re](https://github.com/natemoo-re)! - Fix behavior of renderers when no children are passed in - -## 0.2.0 - -### Minor Changes - -- e6aaeff5: Updated framework renderers for the v0.21.0 release of Astro. Assorted changes and a new renderer interface are included in this release. - -## 0.2.0-next.2 - -### Patch Changes - -- 8986d33b: Improve error display - -## 0.2.0-next.1 - -### Patch Changes - -- 3cd1458a: Bugfix: Bundled CSS missing files on Windows - -## 0.2.0-next.0 - -### Minor Changes - -- d84bfe71: Updates the renderers to confirm to the new renderer API. - -## 0.1.9 - -### Patch Changes - -- 31d06880: Expose name on host component for Vue devtools - -## 0.1.8 - -### Patch Changes - -- 97d37f8f: Update READMEs for all renderers - -## 0.1.7 - -### Patch Changes - -- 1339d5e3: Bump Vue version to latest stable - -## 0.1.6 - -### Patch Changes - -- a1491cc6: Fix Vue components nesting - -## 0.1.5 - -### Patch Changes - -- fdb1c15: Revert #858 - -## 0.1.4 - -### Patch Changes - -- 1f79144: Exclude @vue/runtime-core from processing to fix Vue SSR for nested components - -## 0.1.4-next.0 - -### Patch Changes - -- 1f79144: Exclude @vue/runtime-core from processing to fix Vue SSR for nested components - -## 0.1.3 - -### Patch Changes - -- 0abd251: Allows renderers to provide knownEntrypoint config values - -## 0.1.2 - -### Patch Changes - -- ab2972b: Update package.json engines for esm support - -## 0.1.1 - -### Patch Changes - -- b1364af: Updates logging to display messages from Snowpack - -## 0.1.0 - -### Minor Changes - -- 643c880: Initial release - -## 0.1.0-next.0 - -### Minor Changes - -- 643c880: Initial release diff --git a/packages/renderers/renderer-vue/README.md b/packages/renderers/renderer-vue/README.md deleted file mode 100644 index fb41460614..0000000000 --- a/packages/renderers/renderer-vue/README.md +++ /dev/null @@ -1,31 +0,0 @@ -# @astrojs/renderer-vue - -This is a plugin for [Astro][astro] apps that enables server-side rendering of Vue 3.x components. - -## Installation - -Install `@astrojs/renderer-vue` and then add it to your `astro.config.mjs` in the `renderers` property: - -``` -npm install @astrojs/renderer-vue -``` - -__astro.config.mjs__ - -```js -export default { - // ... - - renderers: [ - // ... - '@astrojs/renderer-vue' - ] -} -``` - -## Documentation - -[Astro Renderer Documentation][renderer-docs] - -[astro]: https://astro.build -[renderer-docs]: https://docs.astro.build/reference/renderer-reference diff --git a/packages/renderers/renderer-vue/client.js b/packages/renderers/renderer-vue/client.js deleted file mode 100644 index 0ba4e81063..0000000000 --- a/packages/renderers/renderer-vue/client.js +++ /dev/null @@ -1,14 +0,0 @@ -import { h, createSSRApp } from 'vue'; -import StaticHtml from './static-html.js'; - -export default (element) => (Component, props, children) => { - delete props['class']; - // Expose name on host component for Vue devtools - const name = Component.name ? `${Component.name} Host` : undefined; - const slots = {}; - if (children != null) { - slots.default = () => h(StaticHtml, { value: children }); - } - const app = createSSRApp({ name, render: () => h(Component, props, slots) }); - app.mount(element, true); -}; diff --git a/packages/renderers/renderer-vue/index.js b/packages/renderers/renderer-vue/index.js deleted file mode 100644 index 51c880c4ab..0000000000 --- a/packages/renderers/renderer-vue/index.js +++ /dev/null @@ -1,19 +0,0 @@ -import vue from '@vitejs/plugin-vue'; - -export default { - name: '@astrojs/renderer-vue', - client: './client.js', - server: './server.js', - viteConfig() { - return { - optimizeDeps: { - include: ['@astrojs/renderer-vue/client.js', 'vue'], - exclude: ['@astrojs/renderer-vue/server.js'], - }, - plugins: [vue()], - ssr: { - external: ['@vue/server-renderer'], - }, - }; - }, -}; diff --git a/packages/renderers/renderer-vue/package.json b/packages/renderers/renderer-vue/package.json deleted file mode 100644 index 84eb4b5221..0000000000 --- a/packages/renderers/renderer-vue/package.json +++ /dev/null @@ -1,30 +0,0 @@ -{ - "name": "@astrojs/renderer-vue", - "version": "0.4.0", - "description": "Use Vue components within Astro", - "type": "module", - "author": "withastro", - "license": "MIT", - "repository": { - "type": "git", - "url": "https://github.com/withastro/astro.git", - "directory": "packages/renderers/renderer-vue" - }, - "bugs": "https://github.com/withastro/astro/issues", - "homepage": "https://astro.build", - "exports": { - ".": "./index.js", - "./*": "./*", - "./client.js": "./client.js", - "./server.js": "./server.js", - "./package.json": "./package.json" - }, - "dependencies": { - "@vitejs/plugin-vue": "^2.3.1", - "vite": "^2.9.1", - "vue": "^3.2.31" - }, - "engines": { - "node": "^14.15.0 || >=16.0.0" - } -} diff --git a/packages/renderers/renderer-vue/server.js b/packages/renderers/renderer-vue/server.js deleted file mode 100644 index 1ae2b757bb..0000000000 --- a/packages/renderers/renderer-vue/server.js +++ /dev/null @@ -1,22 +0,0 @@ -import { h, createSSRApp } from 'vue'; -import { renderToString } from 'vue/server-renderer'; -import StaticHtml from './static-html.js'; - -function check(Component) { - return !!Component['ssrRender']; -} - -async function renderToStaticMarkup(Component, props, children) { - const slots = {}; - if (children != null) { - slots.default = () => h(StaticHtml, { value: children }); - } - const app = createSSRApp({ render: () => h(Component, props, slots) }); - const html = await renderToString(app); - return { html }; -} - -export default { - check, - renderToStaticMarkup, -}; diff --git a/packages/renderers/renderer-vue/static-html.js b/packages/renderers/renderer-vue/static-html.js deleted file mode 100644 index ff1459b6f4..0000000000 --- a/packages/renderers/renderer-vue/static-html.js +++ /dev/null @@ -1,27 +0,0 @@ -import { h, defineComponent } from 'vue'; - -/** - * Astro passes `children` as a string of HTML, so we need - * a wrapper `div` to render that content as VNodes. - * - * This is the Vue + JSX equivalent of using `
` - */ -const StaticHtml = defineComponent({ - props: { - value: String, - }, - setup({ value }) { - if (!value) return () => null; - return () => h('astro-fragment', { innerHTML: value }); - }, -}); - -/** - * Other frameworks have `shouldComponentUpdate` in order to signal - * that this subtree is entirely static and will not be updated - * - * Fortunately, Vue is smart enough to figure that out without any - * help from us, so this just works out of the box! - */ - -export default StaticHtml; diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 0d954b9781..545c451887 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -779,10 +779,8 @@ importers: packages/astro/test/fixtures/astro-jsx: specifiers: - '@astrojs/renderer-solid': workspace:* astro: workspace:* dependencies: - '@astrojs/renderer-solid': link:../../../../renderers/renderer-solid astro: link:../../.. packages/astro/test/fixtures/astro-markdown: @@ -1460,66 +1458,6 @@ importers: '@types/prismjs': 1.26.0 astro-scripts: link:../../../scripts - packages/renderers/renderer-lit: - specifiers: - '@lit-labs/ssr': ^2.1.0 - '@webcomponents/template-shadowroot': ^0.1.0 - lit: ^2.2.2 - dependencies: - '@lit-labs/ssr': 2.1.0 - '@webcomponents/template-shadowroot': 0.1.0 - lit: 2.2.2 - - packages/renderers/renderer-preact: - specifiers: - '@babel/plugin-transform-react-jsx': ^7.17.3 - preact: ^10.7.1 - preact-render-to-string: ^5.1.21 - dependencies: - '@babel/plugin-transform-react-jsx': 7.17.3 - preact: 10.7.1 - preact-render-to-string: 5.1.21_preact@10.7.1 - - packages/renderers/renderer-react: - specifiers: - '@babel/plugin-transform-react-jsx': ^7.17.3 - react: ^18.0.0 - react-dom: ^18.0.0 - dependencies: - '@babel/plugin-transform-react-jsx': 7.17.3 - react: 18.0.0 - react-dom: 18.0.0_react@18.0.0 - - packages/renderers/renderer-solid: - specifiers: - babel-preset-solid: ^1.3.13 - solid-js: ^1.3.14 - dependencies: - babel-preset-solid: 1.3.13 - solid-js: 1.3.14 - - packages/renderers/renderer-svelte: - specifiers: - '@sveltejs/vite-plugin-svelte': ^1.0.0-next.41 - svelte: ^3.47.0 - svelte-preprocess: ^4.10.5 - vite: ^2.9.1 - dependencies: - '@sveltejs/vite-plugin-svelte': 1.0.0-next.41_svelte@3.47.0+vite@2.9.1 - svelte: 3.47.0 - svelte-preprocess: 4.10.5_svelte@3.47.0+typescript@4.6.3 - vite: 2.9.1 - - packages/renderers/renderer-vue: - specifiers: - '@vitejs/plugin-vue': ^2.3.1 - vite: ^2.9.1 - vue: ^3.2.31 - dependencies: - '@vitejs/plugin-vue': 2.3.1_vite@2.9.1+vue@3.2.31 - vite: 2.9.1 - vue: 3.2.31 - packages/webapi: specifiers: '@rollup/plugin-alias': ^3.1.9 @@ -1568,10 +1506,6 @@ importers: scripts: specifiers: - '@astrojs/renderer-preact': workspace:* - '@astrojs/renderer-react': workspace:* - '@astrojs/renderer-svelte': workspace:* - '@astrojs/renderer-vue': workspace:* '@astrojs/webapi': workspace:* adm-zip: ^0.5.9 arg: ^5.0.1 @@ -1581,10 +1515,6 @@ importers: svelte: ^3.47.0 tar: ^6.1.11 dependencies: - '@astrojs/renderer-preact': link:../packages/renderers/renderer-preact - '@astrojs/renderer-react': link:../packages/renderers/renderer-react - '@astrojs/renderer-svelte': link:../packages/renderers/renderer-svelte - '@astrojs/renderer-vue': link:../packages/renderers/renderer-vue '@astrojs/webapi': link:../packages/webapi adm-zip: 0.5.9 arg: 5.0.1 @@ -3815,30 +3745,6 @@ packages: - supports-color dev: false - /@sveltejs/vite-plugin-svelte/1.0.0-next.41_svelte@3.47.0+vite@2.9.1: - resolution: {integrity: sha512-2kZ49mpi/YW1PIPvKaJNSSwIFgmw9QUf1+yaNa4U8yJD6AsfSHXAU3goscWbi1jfWnSg2PhvwAf+bvLCdp2F9g==} - engines: {node: ^14.13.1 || >= 16} - peerDependencies: - diff-match-patch: ^1.0.5 - svelte: ^3.44.0 - vite: ^2.9.0 - peerDependenciesMeta: - diff-match-patch: - optional: true - vite: - optional: true - dependencies: - '@rollup/pluginutils': 4.2.0 - debug: 4.3.4 - kleur: 4.1.4 - magic-string: 0.26.1 - svelte: 3.47.0 - svelte-hmr: 0.14.11_svelte@3.47.0 - vite: 2.9.1 - transitivePeerDependencies: - - supports-color - dev: false - /@tootallnate/once/1.1.2: resolution: {integrity: sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==} engines: {node: '>= 6'} @@ -4343,20 +4249,6 @@ packages: '@unocss/scope': 0.15.6 dev: true - /@vitejs/plugin-vue/2.3.1_vite@2.9.1+vue@3.2.31: - resolution: {integrity: sha512-YNzBt8+jt6bSwpt7LP890U1UcTOIZZxfpE5WOJ638PNxSEKOqAi0+FSKS0nVeukfdZ0Ai/H7AFd6k3hayfGZqQ==} - engines: {node: '>=12.0.0'} - peerDependencies: - vite: ^2.5.10 - vue: ^3.2.25 - peerDependenciesMeta: - vite: - optional: true - dependencies: - vite: 2.9.1 - vue: 3.2.31 - dev: false - /@vitejs/plugin-vue/2.3.1_vue@3.2.31: resolution: {integrity: sha512-YNzBt8+jt6bSwpt7LP890U1UcTOIZZxfpE5WOJ638PNxSEKOqAi0+FSKS0nVeukfdZ0Ai/H7AFd6k3hayfGZqQ==} engines: {node: '>=12.0.0'} @@ -9677,57 +9569,6 @@ packages: typescript: 4.6.3 dev: false - /svelte-preprocess/4.10.5_svelte@3.47.0+typescript@4.6.3: - resolution: {integrity: sha512-VKXPRScCzAZqeBZOGq4LLwtNrAu++mVn7XvQox3eFDV7Ciq0Lg70Q8QWjH9iXF7J+pMlXhPsSFwpCb2E+hoeyA==} - engines: {node: '>= 9.11.2'} - requiresBuild: true - peerDependencies: - '@babel/core': ^7.10.2 - coffeescript: ^2.5.1 - less: ^3.11.3 || ^4.0.0 - node-sass: '*' - postcss: ^7 || ^8 - postcss-load-config: ^2.1.0 || ^3.0.0 - pug: ^3.0.0 - sass: ^1.26.8 - stylus: ^0.55.0 - sugarss: ^2.0.0 - svelte: ^3.23.0 - typescript: ^3.9.5 || ^4.0.0 - peerDependenciesMeta: - '@babel/core': - optional: true - coffeescript: - optional: true - less: - optional: true - node-sass: - optional: true - postcss: - optional: true - postcss-load-config: - optional: true - pug: - optional: true - sass: - optional: true - stylus: - optional: true - sugarss: - optional: true - typescript: - optional: true - dependencies: - '@types/pug': 2.0.6 - '@types/sass': 1.43.1 - detect-indent: 6.1.0 - magic-string: 0.25.9 - sorcery: 0.10.0 - strip-indent: 3.0.0 - svelte: 3.47.0 - typescript: 4.6.3 - dev: false - /svelte/3.47.0: resolution: {integrity: sha512-4JaJp3HEoTCGARRWZQIZDUanhYv0iyoHikklVHVLH9xFE9db22g4TDv7CPeNA8HD1JgjXI1vlhR1JZvvhaTu2Q==} engines: {node: '>= 8'} @@ -10422,30 +10263,6 @@ packages: - supports-color dev: true - /vite/2.9.1: - resolution: {integrity: sha512-vSlsSdOYGcYEJfkQ/NeLXgnRv5zZfpAsdztkIrs7AZHV8RCMZQkwjo4DS5BnrYTqoWqLoUe1Cah4aVO4oNNqCQ==} - engines: {node: '>=12.2.0'} - hasBin: true - peerDependencies: - less: '*' - sass: '*' - stylus: '*' - peerDependenciesMeta: - less: - optional: true - sass: - optional: true - stylus: - optional: true - dependencies: - esbuild: 0.14.34 - postcss: 8.4.12 - resolve: 1.22.0 - rollup: 2.70.1 - optionalDependencies: - fsevents: 2.3.2 - dev: false - /vite/2.9.1_sass@1.50.0: resolution: {integrity: sha512-vSlsSdOYGcYEJfkQ/NeLXgnRv5zZfpAsdztkIrs7AZHV8RCMZQkwjo4DS5BnrYTqoWqLoUe1Cah4aVO4oNNqCQ==} engines: {node: '>=12.2.0'} diff --git a/scripts/package.json b/scripts/package.json index 9d75c44dd2..72b6672918 100644 --- a/scripts/package.json +++ b/scripts/package.json @@ -8,10 +8,6 @@ "astro-scripts": "./index.js" }, "dependencies": { - "@astrojs/renderer-preact": "workspace:*", - "@astrojs/renderer-react": "workspace:*", - "@astrojs/renderer-svelte": "workspace:*", - "@astrojs/renderer-vue": "workspace:*", "@astrojs/webapi": "workspace:*", "adm-zip": "^0.5.9", "arg": "^5.0.1",