mirror of
https://github.com/withastro/astro.git
synced 2024-12-16 21:46:22 -05:00
feat: add preact-ssr-prepass (#9524)
* feat: add preact-ssr-prepass * added more info to changelog * fix example in changelog * fix changelog description * fix tab in code of changelog * Update .changeset/blue-bobcats-remain.md --------- Co-authored-by: Florian Lefebvre <contact@florian-lefebvre.dev>
This commit is contained in:
parent
a1b324b31b
commit
0903ef9049
18 changed files with 287 additions and 71 deletions
21
.changeset/blue-bobcats-remain.md
Normal file
21
.changeset/blue-bobcats-remain.md
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
---
|
||||||
|
"@astrojs/preact": minor
|
||||||
|
---
|
||||||
|
|
||||||
|
Allows rendering lazy components.
|
||||||
|
|
||||||
|
You can now use [lazy components](https://preactjs.com/guide/v10/switching-to-preact/#suspense-experimental) with Suspense:
|
||||||
|
|
||||||
|
``` jsx
|
||||||
|
import { lazy, Suspense } from 'preact/compat';
|
||||||
|
|
||||||
|
const HeavyComponent= lazy(() => import('./HeavyComponent'));
|
||||||
|
|
||||||
|
const Component = () => {
|
||||||
|
return (
|
||||||
|
<Suspense fallback={<p>Loading...</p>}>
|
||||||
|
<HeavyComponent foo="bar" />
|
||||||
|
</Suspense>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
```
|
|
@ -5,7 +5,3 @@
|
||||||
margin-top: 2em;
|
margin-top: 2em;
|
||||||
place-items: center;
|
place-items: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
.counter-message {
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,6 +1,10 @@
|
||||||
import { h, Fragment } from 'preact';
|
import { h, Fragment } from 'preact';
|
||||||
|
import { lazy, Suspense } from 'preact/compat';
|
||||||
import './Counter.css';
|
import './Counter.css';
|
||||||
|
|
||||||
|
const Message = lazy(async () => import('./Message'));
|
||||||
|
const Fallback = () => <p>Loading...</p>;
|
||||||
|
|
||||||
export default function Counter({ children, count }) {
|
export default function Counter({ children, count }) {
|
||||||
const add = () => count.value++;
|
const add = () => count.value++;
|
||||||
const subtract = () => count.value--;
|
const subtract = () => count.value--;
|
||||||
|
@ -12,7 +16,9 @@ export default function Counter({ children, count }) {
|
||||||
<pre>{count}</pre>
|
<pre>{count}</pre>
|
||||||
<button onClick={add}>+</button>
|
<button onClick={add}>+</button>
|
||||||
</div>
|
</div>
|
||||||
<div class="counter-message">{children}</div>
|
<Suspense fallback={Fallback}>
|
||||||
|
<Message>{children}</Message>
|
||||||
|
</Suspense>
|
||||||
</>
|
</>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
3
examples/framework-preact/src/components/Message.css
Normal file
3
examples/framework-preact/src/components/Message.css
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
.message {
|
||||||
|
text-align: center;
|
||||||
|
}
|
5
examples/framework-preact/src/components/Message.tsx
Normal file
5
examples/framework-preact/src/components/Message.tsx
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
import './Message.css';
|
||||||
|
|
||||||
|
export default function Message({ children }) {
|
||||||
|
return <div class="message">{children}</div>;
|
||||||
|
}
|
|
@ -0,0 +1,8 @@
|
||||||
|
import { defineConfig } from 'astro/config';
|
||||||
|
import preact from '@astrojs/preact';
|
||||||
|
import mdx from '@astrojs/mdx';
|
||||||
|
|
||||||
|
// https://astro.build/config
|
||||||
|
export default defineConfig({
|
||||||
|
integrations: [preact(), mdx()],
|
||||||
|
});
|
|
@ -0,0 +1,11 @@
|
||||||
|
{
|
||||||
|
"name": "@e2e/preact-lazy-component",
|
||||||
|
"version": "0.0.0",
|
||||||
|
"private": true,
|
||||||
|
"dependencies": {
|
||||||
|
"@astrojs/mdx": "workspace:*",
|
||||||
|
"@astrojs/preact": "workspace:*",
|
||||||
|
"astro": "workspace:*",
|
||||||
|
"preact": "^10.15.1"
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,11 @@
|
||||||
|
.counter {
|
||||||
|
display: grid;
|
||||||
|
font-size: 2em;
|
||||||
|
grid-template-columns: repeat(3, minmax(0, 1fr));
|
||||||
|
margin-top: 2em;
|
||||||
|
place-items: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.counter-message {
|
||||||
|
text-align: center;
|
||||||
|
}
|
|
@ -0,0 +1,25 @@
|
||||||
|
import { h, Fragment } from 'preact';
|
||||||
|
import { useState } from 'preact/hooks';
|
||||||
|
import { Suspense, lazy } from 'preact/compat';
|
||||||
|
import './Counter.css';
|
||||||
|
|
||||||
|
const LazyCounterMessage = lazy(() => import('./CounterMessage'))
|
||||||
|
|
||||||
|
export default function Counter({ children, count: initialCount, id }) {
|
||||||
|
const [count, setCount] = useState(initialCount);
|
||||||
|
const add = () => setCount((i) => i + 1);
|
||||||
|
const subtract = () => setCount((i) => i - 1);
|
||||||
|
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
<div id={id} className="counter">
|
||||||
|
<button className="decrement" onClick={subtract}>-</button>
|
||||||
|
<pre>{count}</pre>
|
||||||
|
<button className="increment" onClick={add}>+</button>
|
||||||
|
</div>
|
||||||
|
<Suspense fallback={<p>Load message...</p>}>
|
||||||
|
<LazyCounterMessage className="counter-message">{children}</LazyCounterMessage>
|
||||||
|
</Suspense>
|
||||||
|
</>
|
||||||
|
);
|
||||||
|
}
|
|
@ -0,0 +1,5 @@
|
||||||
|
const CounterMessage = (props) => {
|
||||||
|
return <div className={props.className}>{props.children}</div>
|
||||||
|
}
|
||||||
|
|
||||||
|
export default CounterMessage
|
|
@ -0,0 +1,5 @@
|
||||||
|
import { h } from 'preact';
|
||||||
|
|
||||||
|
export default function({ id }) {
|
||||||
|
return <div id={id}>Framework client:only component</div>
|
||||||
|
}
|
|
@ -0,0 +1,4 @@
|
||||||
|
<html>
|
||||||
|
<head><title>Preact component</title></head>
|
||||||
|
<body><slot></slot></body>
|
||||||
|
</html>
|
|
@ -0,0 +1,37 @@
|
||||||
|
---
|
||||||
|
import Counter from '../components/Counter.jsx';
|
||||||
|
import PreactComponent from '../components/JSXComponent.jsx';
|
||||||
|
|
||||||
|
const someProps = {
|
||||||
|
count: 0,
|
||||||
|
};
|
||||||
|
---
|
||||||
|
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<!-- Head Stuff -->
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<Counter id="server-only" {...someProps}>
|
||||||
|
<h1>Hello, server!</h1>
|
||||||
|
</Counter>
|
||||||
|
|
||||||
|
<Counter id="client-idle" {...someProps} client:idle>
|
||||||
|
<h1>Hello, client:idle!</h1>
|
||||||
|
</Counter>
|
||||||
|
|
||||||
|
<Counter id="client-load" {...someProps} client:load>
|
||||||
|
<h1>Hello, client:load!</h1>
|
||||||
|
</Counter>
|
||||||
|
|
||||||
|
<Counter id="client-visible" {...someProps} client:visible>
|
||||||
|
<h1>Hello, client:visible!</h1>
|
||||||
|
</Counter>
|
||||||
|
|
||||||
|
<Counter id="client-media" {...someProps} client:media="(max-width: 50em)">
|
||||||
|
<h1>Hello, client:media!</h1>
|
||||||
|
</Counter>
|
||||||
|
|
||||||
|
<PreactComponent id="client-only" client:only="preact" />
|
||||||
|
</body>
|
||||||
|
</html>
|
|
@ -0,0 +1,29 @@
|
||||||
|
export { default } from '../components/Layout.astro';
|
||||||
|
import Counter from '../components/Counter.jsx';
|
||||||
|
import PreactComponent from '../components/JSXComponent.jsx';
|
||||||
|
|
||||||
|
export const someProps = {
|
||||||
|
count: 0,
|
||||||
|
};
|
||||||
|
|
||||||
|
<Counter id="server-only" {...someProps}>
|
||||||
|
# Hello, server!
|
||||||
|
</Counter>
|
||||||
|
|
||||||
|
<Counter id="client-idle" {...someProps} client:idle>
|
||||||
|
# Hello, client:idle!
|
||||||
|
</Counter>
|
||||||
|
|
||||||
|
<Counter id="client-load" {...someProps} client:load>
|
||||||
|
# Hello, client:load!
|
||||||
|
</Counter>
|
||||||
|
|
||||||
|
<Counter id="client-visible" {...someProps} client:visible>
|
||||||
|
# Hello, client:visible!
|
||||||
|
</Counter>
|
||||||
|
|
||||||
|
<Counter id="client-media" {...someProps} client:media="(max-width: 50em)">
|
||||||
|
# Hello, client:media!
|
||||||
|
</Counter>
|
||||||
|
|
||||||
|
<PreactComponent id="client-only" client:only="preact" />
|
24
packages/astro/e2e/preact-lazy-component.test.js
Normal file
24
packages/astro/e2e/preact-lazy-component.test.js
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
import { prepareTestFactory } from './shared-component-tests.js';
|
||||||
|
|
||||||
|
const { test, createTests } = prepareTestFactory({ root: './fixtures/preact-lazy-component/' });
|
||||||
|
|
||||||
|
const config = {
|
||||||
|
counterComponentFilePath: './src/components/Counter.jsx',
|
||||||
|
componentFilePath: './src/components/JSXComponent.jsx',
|
||||||
|
};
|
||||||
|
|
||||||
|
test.describe('Preact lazy components in Astro files', () => {
|
||||||
|
createTests({
|
||||||
|
...config,
|
||||||
|
pageUrl: '/',
|
||||||
|
pageSourceFilePath: './src/pages/index.astro',
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
test.describe('Preact lazy components in MDX files', () => {
|
||||||
|
createTests({
|
||||||
|
...config,
|
||||||
|
pageUrl: '/mdx/',
|
||||||
|
pageSourceFilePath: './src/pages/mdx.mdx',
|
||||||
|
});
|
||||||
|
});
|
|
@ -40,7 +40,8 @@
|
||||||
"@preact/preset-vite": "^2.7.0",
|
"@preact/preset-vite": "^2.7.0",
|
||||||
"@preact/signals": "^1.2.1",
|
"@preact/signals": "^1.2.1",
|
||||||
"babel-plugin-transform-hook-names": "^1.0.2",
|
"babel-plugin-transform-hook-names": "^1.0.2",
|
||||||
"preact-render-to-string": "^6.3.1"
|
"preact-render-to-string": "^6.3.1",
|
||||||
|
"preact-ssr-prepass": "^1.2.1"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"astro": "workspace:*",
|
"astro": "workspace:*",
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
import type { AstroComponentMetadata } from 'astro';
|
import type { AstroComponentMetadata } from 'astro';
|
||||||
import { Component as BaseComponent, h, type VNode } from 'preact';
|
import { Component as BaseComponent, h, type VNode } from 'preact';
|
||||||
|
import prepass from "preact-ssr-prepass";
|
||||||
import { render } from 'preact-render-to-string';
|
import { render } from 'preact-render-to-string';
|
||||||
import { getContext } from './context.js';
|
import { getContext } from './context.js';
|
||||||
import { restoreSignalsOnProps, serializeSignals } from './signals.js';
|
import { restoreSignalsOnProps, serializeSignals } from './signals.js';
|
||||||
|
@ -11,7 +12,7 @@ const slotName = (str: string) => str.trim().replace(/[-_]([a-z])/g, (_, w) => w
|
||||||
let originalConsoleError: typeof console.error;
|
let originalConsoleError: typeof console.error;
|
||||||
let consoleFilterRefs = 0;
|
let consoleFilterRefs = 0;
|
||||||
|
|
||||||
function check(this: RendererContext, Component: any, props: Record<string, any>, children: any) {
|
async function check(this: RendererContext, Component: any, props: Record<string, any>, children: any) {
|
||||||
if (typeof Component !== 'function') return false;
|
if (typeof Component !== 'function') return false;
|
||||||
if (Component.name === 'QwikComponent') return false;
|
if (Component.name === 'QwikComponent') return false;
|
||||||
|
|
||||||
|
@ -23,7 +24,7 @@ function check(this: RendererContext, Component: any, props: Record<string, any>
|
||||||
|
|
||||||
try {
|
try {
|
||||||
try {
|
try {
|
||||||
const { html } = renderToStaticMarkup.call(this, Component, props, children, undefined);
|
const { html } = await renderToStaticMarkup.call(this, Component, props, children, undefined);
|
||||||
if (typeof html !== 'string') {
|
if (typeof html !== 'string') {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -45,7 +46,7 @@ function shouldHydrate(metadata: AstroComponentMetadata | undefined) {
|
||||||
return metadata?.astroStaticSlot ? !!metadata.hydrate : true;
|
return metadata?.astroStaticSlot ? !!metadata.hydrate : true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function renderToStaticMarkup(
|
async function renderToStaticMarkup(
|
||||||
this: RendererContext,
|
this: RendererContext,
|
||||||
Component: any,
|
Component: any,
|
||||||
props: Record<string, any>,
|
props: Record<string, any>,
|
||||||
|
@ -72,22 +73,20 @@ function renderToStaticMarkup(
|
||||||
const attrs: AstroPreactAttrs = {};
|
const attrs: AstroPreactAttrs = {};
|
||||||
serializeSignals(ctx, props, attrs, propsMap);
|
serializeSignals(ctx, props, attrs, propsMap);
|
||||||
|
|
||||||
const html = render(
|
const vNode: VNode<any> = h(
|
||||||
h(
|
Component,
|
||||||
Component,
|
newProps,
|
||||||
newProps,
|
children != null
|
||||||
children != null
|
? h(StaticHtml, {
|
||||||
? h(StaticHtml, {
|
hydrate: shouldHydrate(metadata),
|
||||||
hydrate: shouldHydrate(metadata),
|
value: children,
|
||||||
value: children,
|
})
|
||||||
})
|
: children
|
||||||
: children
|
)
|
||||||
) as VNode<any>
|
|
||||||
);
|
await prepass(vNode)
|
||||||
return {
|
const html = render(vNode);
|
||||||
attrs,
|
return { attrs, html };
|
||||||
html,
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
118
pnpm-lock.yaml
118
pnpm-lock.yaml
|
@ -32,10 +32,10 @@ importers:
|
||||||
version: 18.19.4
|
version: 18.19.4
|
||||||
'@typescript-eslint/eslint-plugin':
|
'@typescript-eslint/eslint-plugin':
|
||||||
specifier: ^6.11.0
|
specifier: ^6.11.0
|
||||||
version: 6.16.0(@typescript-eslint/parser@6.16.0)(eslint@8.56.0)(typescript@5.2.2)
|
version: 6.17.0(@typescript-eslint/parser@6.17.0)(eslint@8.56.0)(typescript@5.2.2)
|
||||||
'@typescript-eslint/parser':
|
'@typescript-eslint/parser':
|
||||||
specifier: ^6.11.0
|
specifier: ^6.11.0
|
||||||
version: 6.16.0(eslint@8.56.0)(typescript@5.2.2)
|
version: 6.17.0(eslint@8.56.0)(typescript@5.2.2)
|
||||||
esbuild:
|
esbuild:
|
||||||
specifier: ^0.19.6
|
specifier: ^0.19.6
|
||||||
version: 0.19.11
|
version: 0.19.11
|
||||||
|
@ -1430,6 +1430,21 @@ importers:
|
||||||
specifier: ^10.19.2
|
specifier: ^10.19.2
|
||||||
version: 10.19.3
|
version: 10.19.3
|
||||||
|
|
||||||
|
packages/astro/e2e/fixtures/preact-lazy-component:
|
||||||
|
dependencies:
|
||||||
|
'@astrojs/mdx':
|
||||||
|
specifier: workspace:*
|
||||||
|
version: link:../../../../integrations/mdx
|
||||||
|
'@astrojs/preact':
|
||||||
|
specifier: workspace:*
|
||||||
|
version: link:../../../../integrations/preact
|
||||||
|
astro:
|
||||||
|
specifier: workspace:*
|
||||||
|
version: link:../../..
|
||||||
|
preact:
|
||||||
|
specifier: ^10.15.1
|
||||||
|
version: 10.19.3
|
||||||
|
|
||||||
packages/astro/e2e/fixtures/prefetch:
|
packages/astro/e2e/fixtures/prefetch:
|
||||||
dependencies:
|
dependencies:
|
||||||
astro:
|
astro:
|
||||||
|
@ -3859,7 +3874,7 @@ importers:
|
||||||
version: 4.3.2
|
version: 4.3.2
|
||||||
linkedom:
|
linkedom:
|
||||||
specifier: ^0.16.4
|
specifier: ^0.16.4
|
||||||
version: 0.16.5
|
version: 0.16.6
|
||||||
mocha:
|
mocha:
|
||||||
specifier: ^10.2.0
|
specifier: ^10.2.0
|
||||||
version: 10.2.0
|
version: 10.2.0
|
||||||
|
@ -4061,7 +4076,7 @@ importers:
|
||||||
version: 1.0.0-rc.12
|
version: 1.0.0-rc.12
|
||||||
linkedom:
|
linkedom:
|
||||||
specifier: ^0.16.4
|
specifier: ^0.16.4
|
||||||
version: 0.16.5
|
version: 0.16.6
|
||||||
mdast-util-mdx:
|
mdast-util-mdx:
|
||||||
specifier: ^3.0.0
|
specifier: ^3.0.0
|
||||||
version: 3.0.0
|
version: 3.0.0
|
||||||
|
@ -4414,6 +4429,9 @@ importers:
|
||||||
preact-render-to-string:
|
preact-render-to-string:
|
||||||
specifier: ^6.3.1
|
specifier: ^6.3.1
|
||||||
version: 6.3.1(preact@10.19.3)
|
version: 6.3.1(preact@10.19.3)
|
||||||
|
preact-ssr-prepass:
|
||||||
|
specifier: ^1.2.1
|
||||||
|
version: 1.2.1(preact@10.19.3)
|
||||||
devDependencies:
|
devDependencies:
|
||||||
astro:
|
astro:
|
||||||
specifier: workspace:*
|
specifier: workspace:*
|
||||||
|
@ -4853,7 +4871,7 @@ importers:
|
||||||
version: 1.0.0-rc.12
|
version: 1.0.0-rc.12
|
||||||
linkedom:
|
linkedom:
|
||||||
specifier: ^0.16.4
|
specifier: ^0.16.4
|
||||||
version: 0.16.5
|
version: 0.16.6
|
||||||
mocha:
|
mocha:
|
||||||
specifier: ^10.2.0
|
specifier: ^10.2.0
|
||||||
version: 10.2.0
|
version: 10.2.0
|
||||||
|
@ -7684,8 +7702,8 @@ packages:
|
||||||
resolution: {integrity: sha512-I4q9QU9MQv4oEOz4tAHJtNz1cwuLxn2F3xcc2iV5WdqLPpUnj30aUuxt1mAxYTG+oe8CZMV/+6rU4S4gRDzqtQ==}
|
resolution: {integrity: sha512-I4q9QU9MQv4oEOz4tAHJtNz1cwuLxn2F3xcc2iV5WdqLPpUnj30aUuxt1mAxYTG+oe8CZMV/+6rU4S4gRDzqtQ==}
|
||||||
dev: true
|
dev: true
|
||||||
|
|
||||||
/@typescript-eslint/eslint-plugin@6.16.0(@typescript-eslint/parser@6.16.0)(eslint@8.56.0)(typescript@5.2.2):
|
/@typescript-eslint/eslint-plugin@6.17.0(@typescript-eslint/parser@6.17.0)(eslint@8.56.0)(typescript@5.2.2):
|
||||||
resolution: {integrity: sha512-O5f7Kv5o4dLWQtPX4ywPPa+v9G+1q1x8mz0Kr0pXUtKsevo+gIJHLkGc8RxaZWtP8RrhwhSNIWThnW42K9/0rQ==}
|
resolution: {integrity: sha512-Vih/4xLXmY7V490dGwBQJTpIZxH4ZFH6eCVmQ4RFkB+wmaCTDAx4dtgoWwMNGKLkqRY1L6rPqzEbjorRnDo4rQ==}
|
||||||
engines: {node: ^16.0.0 || >=18.0.0}
|
engines: {node: ^16.0.0 || >=18.0.0}
|
||||||
peerDependencies:
|
peerDependencies:
|
||||||
'@typescript-eslint/parser': ^6.0.0 || ^6.0.0-alpha
|
'@typescript-eslint/parser': ^6.0.0 || ^6.0.0-alpha
|
||||||
|
@ -7696,11 +7714,11 @@ packages:
|
||||||
optional: true
|
optional: true
|
||||||
dependencies:
|
dependencies:
|
||||||
'@eslint-community/regexpp': 4.10.0
|
'@eslint-community/regexpp': 4.10.0
|
||||||
'@typescript-eslint/parser': 6.16.0(eslint@8.56.0)(typescript@5.2.2)
|
'@typescript-eslint/parser': 6.17.0(eslint@8.56.0)(typescript@5.2.2)
|
||||||
'@typescript-eslint/scope-manager': 6.16.0
|
'@typescript-eslint/scope-manager': 6.17.0
|
||||||
'@typescript-eslint/type-utils': 6.16.0(eslint@8.56.0)(typescript@5.2.2)
|
'@typescript-eslint/type-utils': 6.17.0(eslint@8.56.0)(typescript@5.2.2)
|
||||||
'@typescript-eslint/utils': 6.16.0(eslint@8.56.0)(typescript@5.2.2)
|
'@typescript-eslint/utils': 6.17.0(eslint@8.56.0)(typescript@5.2.2)
|
||||||
'@typescript-eslint/visitor-keys': 6.16.0
|
'@typescript-eslint/visitor-keys': 6.17.0
|
||||||
debug: 4.3.4(supports-color@8.1.1)
|
debug: 4.3.4(supports-color@8.1.1)
|
||||||
eslint: 8.56.0
|
eslint: 8.56.0
|
||||||
graphemer: 1.4.0
|
graphemer: 1.4.0
|
||||||
|
@ -7713,8 +7731,8 @@ packages:
|
||||||
- supports-color
|
- supports-color
|
||||||
dev: true
|
dev: true
|
||||||
|
|
||||||
/@typescript-eslint/parser@6.16.0(eslint@8.56.0)(typescript@5.2.2):
|
/@typescript-eslint/parser@6.17.0(eslint@8.56.0)(typescript@5.2.2):
|
||||||
resolution: {integrity: sha512-H2GM3eUo12HpKZU9njig3DF5zJ58ja6ahj1GoHEHOgQvYxzoFJJEvC1MQ7T2l9Ha+69ZSOn7RTxOdpC/y3ikMw==}
|
resolution: {integrity: sha512-C4bBaX2orvhK+LlwrY8oWGmSl4WolCfYm513gEccdWZj0CwGadbIADb0FtVEcI+WzUyjyoBj2JRP8g25E6IB8A==}
|
||||||
engines: {node: ^16.0.0 || >=18.0.0}
|
engines: {node: ^16.0.0 || >=18.0.0}
|
||||||
peerDependencies:
|
peerDependencies:
|
||||||
eslint: ^7.0.0 || ^8.0.0
|
eslint: ^7.0.0 || ^8.0.0
|
||||||
|
@ -7723,10 +7741,10 @@ packages:
|
||||||
typescript:
|
typescript:
|
||||||
optional: true
|
optional: true
|
||||||
dependencies:
|
dependencies:
|
||||||
'@typescript-eslint/scope-manager': 6.16.0
|
'@typescript-eslint/scope-manager': 6.17.0
|
||||||
'@typescript-eslint/types': 6.16.0
|
'@typescript-eslint/types': 6.17.0
|
||||||
'@typescript-eslint/typescript-estree': 6.16.0(typescript@5.2.2)
|
'@typescript-eslint/typescript-estree': 6.17.0(typescript@5.2.2)
|
||||||
'@typescript-eslint/visitor-keys': 6.16.0
|
'@typescript-eslint/visitor-keys': 6.17.0
|
||||||
debug: 4.3.4(supports-color@8.1.1)
|
debug: 4.3.4(supports-color@8.1.1)
|
||||||
eslint: 8.56.0
|
eslint: 8.56.0
|
||||||
typescript: 5.2.2
|
typescript: 5.2.2
|
||||||
|
@ -7734,16 +7752,16 @@ packages:
|
||||||
- supports-color
|
- supports-color
|
||||||
dev: true
|
dev: true
|
||||||
|
|
||||||
/@typescript-eslint/scope-manager@6.16.0:
|
/@typescript-eslint/scope-manager@6.17.0:
|
||||||
resolution: {integrity: sha512-0N7Y9DSPdaBQ3sqSCwlrm9zJwkpOuc6HYm7LpzLAPqBL7dmzAUimr4M29dMkOP/tEwvOCC/Cxo//yOfJD3HUiw==}
|
resolution: {integrity: sha512-RX7a8lwgOi7am0k17NUO0+ZmMOX4PpjLtLRgLmT1d3lBYdWH4ssBUbwdmc5pdRX8rXon8v9x8vaoOSpkHfcXGA==}
|
||||||
engines: {node: ^16.0.0 || >=18.0.0}
|
engines: {node: ^16.0.0 || >=18.0.0}
|
||||||
dependencies:
|
dependencies:
|
||||||
'@typescript-eslint/types': 6.16.0
|
'@typescript-eslint/types': 6.17.0
|
||||||
'@typescript-eslint/visitor-keys': 6.16.0
|
'@typescript-eslint/visitor-keys': 6.17.0
|
||||||
dev: true
|
dev: true
|
||||||
|
|
||||||
/@typescript-eslint/type-utils@6.16.0(eslint@8.56.0)(typescript@5.2.2):
|
/@typescript-eslint/type-utils@6.17.0(eslint@8.56.0)(typescript@5.2.2):
|
||||||
resolution: {integrity: sha512-ThmrEOcARmOnoyQfYkHw/DX2SEYBalVECmoldVuH6qagKROp/jMnfXpAU/pAIWub9c4YTxga+XwgAkoA0pxfmg==}
|
resolution: {integrity: sha512-hDXcWmnbtn4P2B37ka3nil3yi3VCQO2QEB9gBiHJmQp5wmyQWqnjA85+ZcE8c4FqnaB6lBwMrPkgd4aBYz3iNg==}
|
||||||
engines: {node: ^16.0.0 || >=18.0.0}
|
engines: {node: ^16.0.0 || >=18.0.0}
|
||||||
peerDependencies:
|
peerDependencies:
|
||||||
eslint: ^7.0.0 || ^8.0.0
|
eslint: ^7.0.0 || ^8.0.0
|
||||||
|
@ -7752,8 +7770,8 @@ packages:
|
||||||
typescript:
|
typescript:
|
||||||
optional: true
|
optional: true
|
||||||
dependencies:
|
dependencies:
|
||||||
'@typescript-eslint/typescript-estree': 6.16.0(typescript@5.2.2)
|
'@typescript-eslint/typescript-estree': 6.17.0(typescript@5.2.2)
|
||||||
'@typescript-eslint/utils': 6.16.0(eslint@8.56.0)(typescript@5.2.2)
|
'@typescript-eslint/utils': 6.17.0(eslint@8.56.0)(typescript@5.2.2)
|
||||||
debug: 4.3.4(supports-color@8.1.1)
|
debug: 4.3.4(supports-color@8.1.1)
|
||||||
eslint: 8.56.0
|
eslint: 8.56.0
|
||||||
ts-api-utils: 1.0.3(typescript@5.2.2)
|
ts-api-utils: 1.0.3(typescript@5.2.2)
|
||||||
|
@ -7762,13 +7780,13 @@ packages:
|
||||||
- supports-color
|
- supports-color
|
||||||
dev: true
|
dev: true
|
||||||
|
|
||||||
/@typescript-eslint/types@6.16.0:
|
/@typescript-eslint/types@6.17.0:
|
||||||
resolution: {integrity: sha512-hvDFpLEvTJoHutVl87+MG/c5C8I6LOgEx05zExTSJDEVU7hhR3jhV8M5zuggbdFCw98+HhZWPHZeKS97kS3JoQ==}
|
resolution: {integrity: sha512-qRKs9tvc3a4RBcL/9PXtKSehI/q8wuU9xYJxe97WFxnzH8NWWtcW3ffNS+EWg8uPvIerhjsEZ+rHtDqOCiH57A==}
|
||||||
engines: {node: ^16.0.0 || >=18.0.0}
|
engines: {node: ^16.0.0 || >=18.0.0}
|
||||||
dev: true
|
dev: true
|
||||||
|
|
||||||
/@typescript-eslint/typescript-estree@6.16.0(typescript@5.2.2):
|
/@typescript-eslint/typescript-estree@6.17.0(typescript@5.2.2):
|
||||||
resolution: {integrity: sha512-VTWZuixh/vr7nih6CfrdpmFNLEnoVBF1skfjdyGnNwXOH1SLeHItGdZDHhhAIzd3ACazyY2Fg76zuzOVTaknGA==}
|
resolution: {integrity: sha512-gVQe+SLdNPfjlJn5VNGhlOhrXz4cajwFd5kAgWtZ9dCZf4XJf8xmgCTLIqec7aha3JwgLI2CK6GY1043FRxZwg==}
|
||||||
engines: {node: ^16.0.0 || >=18.0.0}
|
engines: {node: ^16.0.0 || >=18.0.0}
|
||||||
peerDependencies:
|
peerDependencies:
|
||||||
typescript: '*'
|
typescript: '*'
|
||||||
|
@ -7776,8 +7794,8 @@ packages:
|
||||||
typescript:
|
typescript:
|
||||||
optional: true
|
optional: true
|
||||||
dependencies:
|
dependencies:
|
||||||
'@typescript-eslint/types': 6.16.0
|
'@typescript-eslint/types': 6.17.0
|
||||||
'@typescript-eslint/visitor-keys': 6.16.0
|
'@typescript-eslint/visitor-keys': 6.17.0
|
||||||
debug: 4.3.4(supports-color@8.1.1)
|
debug: 4.3.4(supports-color@8.1.1)
|
||||||
globby: 11.1.0
|
globby: 11.1.0
|
||||||
is-glob: 4.0.3
|
is-glob: 4.0.3
|
||||||
|
@ -7789,8 +7807,8 @@ packages:
|
||||||
- supports-color
|
- supports-color
|
||||||
dev: true
|
dev: true
|
||||||
|
|
||||||
/@typescript-eslint/utils@6.16.0(eslint@8.56.0)(typescript@5.2.2):
|
/@typescript-eslint/utils@6.17.0(eslint@8.56.0)(typescript@5.2.2):
|
||||||
resolution: {integrity: sha512-T83QPKrBm6n//q9mv7oiSvy/Xq/7Hyw9SzSEhMHJwznEmQayfBM87+oAlkNAMEO7/MjIwKyOHgBJbxB0s7gx2A==}
|
resolution: {integrity: sha512-LofsSPjN/ITNkzV47hxas2JCsNCEnGhVvocfyOcLzT9c/tSZE7SfhS/iWtzP1lKNOEfLhRTZz6xqI8N2RzweSQ==}
|
||||||
engines: {node: ^16.0.0 || >=18.0.0}
|
engines: {node: ^16.0.0 || >=18.0.0}
|
||||||
peerDependencies:
|
peerDependencies:
|
||||||
eslint: ^7.0.0 || ^8.0.0
|
eslint: ^7.0.0 || ^8.0.0
|
||||||
|
@ -7798,9 +7816,9 @@ packages:
|
||||||
'@eslint-community/eslint-utils': 4.4.0(eslint@8.56.0)
|
'@eslint-community/eslint-utils': 4.4.0(eslint@8.56.0)
|
||||||
'@types/json-schema': 7.0.15
|
'@types/json-schema': 7.0.15
|
||||||
'@types/semver': 7.5.6
|
'@types/semver': 7.5.6
|
||||||
'@typescript-eslint/scope-manager': 6.16.0
|
'@typescript-eslint/scope-manager': 6.17.0
|
||||||
'@typescript-eslint/types': 6.16.0
|
'@typescript-eslint/types': 6.17.0
|
||||||
'@typescript-eslint/typescript-estree': 6.16.0(typescript@5.2.2)
|
'@typescript-eslint/typescript-estree': 6.17.0(typescript@5.2.2)
|
||||||
eslint: 8.56.0
|
eslint: 8.56.0
|
||||||
semver: 7.5.4
|
semver: 7.5.4
|
||||||
transitivePeerDependencies:
|
transitivePeerDependencies:
|
||||||
|
@ -7808,11 +7826,11 @@ packages:
|
||||||
- typescript
|
- typescript
|
||||||
dev: true
|
dev: true
|
||||||
|
|
||||||
/@typescript-eslint/visitor-keys@6.16.0:
|
/@typescript-eslint/visitor-keys@6.17.0:
|
||||||
resolution: {integrity: sha512-QSFQLruk7fhs91a/Ep/LqRdbJCZ1Rq03rqBdKT5Ky17Sz8zRLUksqIe9DW0pKtg/Z35/ztbLQ6qpOCN6rOC11A==}
|
resolution: {integrity: sha512-H6VwB/k3IuIeQOyYczyyKN8wH6ed8EwliaYHLxOIhyF0dYEIsN8+Bk3GE19qafeMKyZJJHP8+O1HiFhFLUNKSg==}
|
||||||
engines: {node: ^16.0.0 || >=18.0.0}
|
engines: {node: ^16.0.0 || >=18.0.0}
|
||||||
dependencies:
|
dependencies:
|
||||||
'@typescript-eslint/types': 6.16.0
|
'@typescript-eslint/types': 6.17.0
|
||||||
eslint-visitor-keys: 3.4.3
|
eslint-visitor-keys: 3.4.3
|
||||||
dev: true
|
dev: true
|
||||||
|
|
||||||
|
@ -11442,8 +11460,8 @@ packages:
|
||||||
/lines-and-columns@1.2.4:
|
/lines-and-columns@1.2.4:
|
||||||
resolution: {integrity: sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==}
|
resolution: {integrity: sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==}
|
||||||
|
|
||||||
/linkedom@0.16.5:
|
/linkedom@0.16.6:
|
||||||
resolution: {integrity: sha512-FtcuLuxDtlKWWilm5Z0HgmrfMwO0tOfC6tu47fRXj2/KGEeDSh4ihiDwFKZSbJj6zh520r8XZjZ7v2Jb30HAQA==}
|
resolution: {integrity: sha512-vJ8oadtJe3DM4FNW15Fj5NLIJlJk+AOypoRxzq9prLx+gAKvHYcTfV98pzOoRkwx4ZvvYzqT1bcDKluHH72apg==}
|
||||||
dependencies:
|
dependencies:
|
||||||
css-select: 5.1.0
|
css-select: 5.1.0
|
||||||
cssom: 0.5.0
|
cssom: 0.5.0
|
||||||
|
@ -13530,6 +13548,14 @@ packages:
|
||||||
pretty-format: 3.8.0
|
pretty-format: 3.8.0
|
||||||
dev: false
|
dev: false
|
||||||
|
|
||||||
|
/preact-ssr-prepass@1.2.1(preact@10.19.3):
|
||||||
|
resolution: {integrity: sha512-bLgbUfy8nL+PZghAPpyk9MF+cmXjdwEnxYPaJBmwbzFQqzIz8dQVBqjwB60RqZ9So/vIf6BRfHCiwFGuMCyfbQ==}
|
||||||
|
peerDependencies:
|
||||||
|
preact: '>=10 || ^10.0.0-beta.0 || ^10.0.0-alpha.0'
|
||||||
|
dependencies:
|
||||||
|
preact: 10.19.3
|
||||||
|
dev: false
|
||||||
|
|
||||||
/preact@10.19.3:
|
/preact@10.19.3:
|
||||||
resolution: {integrity: sha512-nHHTeFVBTHRGxJXKkKu5hT8C/YWBkPso4/Gad6xuj5dbptt9iF9NZr9pHbPhBrnT2klheu7mHTxTZ/LjwJiEiQ==}
|
resolution: {integrity: sha512-nHHTeFVBTHRGxJXKkKu5hT8C/YWBkPso4/Gad6xuj5dbptt9iF9NZr9pHbPhBrnT2klheu7mHTxTZ/LjwJiEiQ==}
|
||||||
|
|
||||||
|
@ -14914,8 +14940,8 @@ packages:
|
||||||
resolution: {integrity: sha512-ovssysQTa+luh7A5Weu3Rta6FJlFBBbInjOh722LIt6klpU2/HtdUbszju/G4devcvk8PGt7FCLv5wftu3THUA==}
|
resolution: {integrity: sha512-ovssysQTa+luh7A5Weu3Rta6FJlFBBbInjOh722LIt6klpU2/HtdUbszju/G4devcvk8PGt7FCLv5wftu3THUA==}
|
||||||
dev: false
|
dev: false
|
||||||
|
|
||||||
/svgo@3.1.0:
|
/svgo@3.2.0:
|
||||||
resolution: {integrity: sha512-R5SnNA89w1dYgNv570591F66v34b3eQShpIBcQtZtM5trJwm1VvxbIoMpRYY3ybTAutcKTLEmTsdnaknOHbiQA==}
|
resolution: {integrity: sha512-4PP6CMW/V7l/GmKRKzsLR8xxjdHTV4IMvhTnpuHwwBazSIlw5W/5SmPjN8Dwyt7lKbSJrRDgp4t9ph0HgChFBQ==}
|
||||||
engines: {node: '>=14.0.0'}
|
engines: {node: '>=14.0.0'}
|
||||||
hasBin: true
|
hasBin: true
|
||||||
dependencies:
|
dependencies:
|
||||||
|
@ -15757,7 +15783,7 @@ packages:
|
||||||
optional: true
|
optional: true
|
||||||
dependencies:
|
dependencies:
|
||||||
'@vue/compiler-sfc': 3.4.3
|
'@vue/compiler-sfc': 3.4.3
|
||||||
svgo: 3.1.0
|
svgo: 3.2.0
|
||||||
dev: false
|
dev: false
|
||||||
|
|
||||||
/vite-svg-loader@5.0.1:
|
/vite-svg-loader@5.0.1:
|
||||||
|
@ -15768,7 +15794,7 @@ packages:
|
||||||
vue:
|
vue:
|
||||||
optional: true
|
optional: true
|
||||||
dependencies:
|
dependencies:
|
||||||
svgo: 3.1.0
|
svgo: 3.2.0
|
||||||
dev: false
|
dev: false
|
||||||
|
|
||||||
/vite@5.0.10(@types/node@18.19.4)(sass@1.69.6):
|
/vite@5.0.10(@types/node@18.19.4)(sass@1.69.6):
|
||||||
|
|
Loading…
Reference in a new issue