From aa72edac8e67c19285eee89bdc6ae0a3a2289fc0 Mon Sep 17 00:00:00 2001
From: Bryan Thomas <49354825+bryanjtc@users.noreply.github.com>
Date: Wed, 23 Oct 2024 11:50:08 -0500
Subject: [PATCH 01/15] docs: Add react router 6 example
---
examples/react-router-6-app/.gitignore | 24 +++++
examples/react-router-6-app/index.html | 13 +++
examples/react-router-6-app/package.json | 35 ++++++
examples/react-router-6-app/public/vite.svg | 1 +
examples/react-router-6-app/src/App.css | 41 +++++++
examples/react-router-6-app/src/App.tsx | 100 ++++++++++++++++++
.../src/ClientFetchWrapper.tsx | 11 ++
.../react-router-6-app/src/assets/react.svg | 1 +
examples/react-router-6-app/src/axios.ts | 6 ++
examples/react-router-6-app/src/index.css | 87 +++++++++++++++
examples/react-router-6-app/src/main.tsx | 29 +++++
.../react-router-6-app/src/queryClient.tsx | 3 +
examples/react-router-6-app/src/vite-env.d.ts | 1 +
examples/react-router-6-app/tsconfig.json | 25 +++++
.../react-router-6-app/tsconfig.node.json | 9 ++
examples/react-router-6-app/vite.config.ts | 7 ++
16 files changed, 393 insertions(+)
create mode 100644 examples/react-router-6-app/.gitignore
create mode 100644 examples/react-router-6-app/index.html
create mode 100644 examples/react-router-6-app/package.json
create mode 100644 examples/react-router-6-app/public/vite.svg
create mode 100644 examples/react-router-6-app/src/App.css
create mode 100644 examples/react-router-6-app/src/App.tsx
create mode 100644 examples/react-router-6-app/src/ClientFetchWrapper.tsx
create mode 100644 examples/react-router-6-app/src/assets/react.svg
create mode 100644 examples/react-router-6-app/src/axios.ts
create mode 100644 examples/react-router-6-app/src/index.css
create mode 100644 examples/react-router-6-app/src/main.tsx
create mode 100644 examples/react-router-6-app/src/queryClient.tsx
create mode 100644 examples/react-router-6-app/src/vite-env.d.ts
create mode 100644 examples/react-router-6-app/tsconfig.json
create mode 100644 examples/react-router-6-app/tsconfig.node.json
create mode 100644 examples/react-router-6-app/vite.config.ts
diff --git a/examples/react-router-6-app/.gitignore b/examples/react-router-6-app/.gitignore
new file mode 100644
index 0000000..a547bf3
--- /dev/null
+++ b/examples/react-router-6-app/.gitignore
@@ -0,0 +1,24 @@
+# Logs
+logs
+*.log
+npm-debug.log*
+yarn-debug.log*
+yarn-error.log*
+pnpm-debug.log*
+lerna-debug.log*
+
+node_modules
+dist
+dist-ssr
+*.local
+
+# Editor directories and files
+.vscode/*
+!.vscode/extensions.json
+.idea
+.DS_Store
+*.suo
+*.ntvs*
+*.njsproj
+*.sln
+*.sw?
diff --git a/examples/react-router-6-app/index.html b/examples/react-router-6-app/index.html
new file mode 100644
index 0000000..e0d1c84
--- /dev/null
+++ b/examples/react-router-6-app/index.html
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+ Vite + React + TS
+
+
+
+
+
+
diff --git a/examples/react-router-6-app/package.json b/examples/react-router-6-app/package.json
new file mode 100644
index 0000000..800f835
--- /dev/null
+++ b/examples/react-router-6-app/package.json
@@ -0,0 +1,35 @@
+{
+ "name": "@7nohe/react-router-6-app",
+ "private": true,
+ "version": "0.0.0",
+ "type": "module",
+ "scripts": {
+ "dev": "run-p dev:mock dev:client",
+ "dev:client": "vite --clearScreen=false",
+ "dev:mock": "prism mock ../petstore.yaml --dynamic",
+ "build": "tsc && vite build",
+ "preview": "vite preview",
+ "generate:api": "rimraf ./openapi && node ../../dist/cli.mjs -i ../petstore.yaml --format=biome --lint=biome -c @hey-api/client-axios",
+ "test:generated": "tsc -p ./tsconfig.json --noEmit"
+ },
+ "dependencies": {
+ "@hey-api/client-axios": "^0.2.7",
+ "@tanstack/react-query": "^5.59.13",
+ "@tanstack/react-query-devtools": "^5.32.1",
+ "axios": "^1.7.7",
+ "form-data": "~4.0.0",
+ "react": "^18.3.1",
+ "react-dom": "^18.3.1",
+ "react-router-dom": "^6.27.0"
+ },
+ "devDependencies": {
+ "@biomejs/biome": "^1.7.2",
+ "@stoplight/prism-cli": "^5.5.2",
+ "@types/react": "^18.3.1",
+ "@types/react-dom": "^18.2.18",
+ "@vitejs/plugin-react": "^4.2.1",
+ "npm-run-all": "^4.1.5",
+ "typescript": "^5.4.5",
+ "vite": "^5.0.12"
+ }
+}
diff --git a/examples/react-router-6-app/public/vite.svg b/examples/react-router-6-app/public/vite.svg
new file mode 100644
index 0000000..e7b8dfb
--- /dev/null
+++ b/examples/react-router-6-app/public/vite.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/examples/react-router-6-app/src/App.css b/examples/react-router-6-app/src/App.css
new file mode 100644
index 0000000..2c5e2ef
--- /dev/null
+++ b/examples/react-router-6-app/src/App.css
@@ -0,0 +1,41 @@
+#root {
+ max-width: 1280px;
+ margin: 0 auto;
+ padding: 2rem;
+ text-align: center;
+}
+
+.logo {
+ height: 6em;
+ padding: 1.5em;
+ will-change: filter;
+}
+.logo:hover {
+ filter: drop-shadow(0 0 2em #646cffaa);
+}
+.logo.react:hover {
+ filter: drop-shadow(0 0 2em #61dafbaa);
+}
+
+@keyframes logo-spin {
+ from {
+ transform: rotate(0deg);
+ }
+ to {
+ transform: rotate(360deg);
+ }
+}
+
+@media (prefers-reduced-motion: no-preference) {
+ a:nth-of-type(2) .logo {
+ animation: logo-spin infinite 20s linear;
+ }
+}
+
+.card {
+ padding: 2em;
+}
+
+.read-the-docs {
+ color: #888;
+}
diff --git a/examples/react-router-6-app/src/App.tsx b/examples/react-router-6-app/src/App.tsx
new file mode 100644
index 0000000..8720410
--- /dev/null
+++ b/examples/react-router-6-app/src/App.tsx
@@ -0,0 +1,100 @@
+import "./App.css";
+import { useState } from "react";
+
+import {
+ UseFindPetsKeyFn,
+ useAddPet,
+} from "../openapi/queries";
+import { ensureUseFindPetsData } from "../openapi/queries/ensureQueryData";
+import { queryClient } from "./queryClient";
+import type { QueryClient } from "@tanstack/react-query";
+import { type LoaderFunctionArgs, useLoaderData } from "react-router-dom";
+import type { FindPetsData } from "../openapi/requests/types.gen";
+import type { Options } from "@hey-api/client-axios";
+import { useFindPetsSuspense } from "../openapi/queries/suspense";
+
+export const loader =
+ (queryClient: QueryClient) =>
+ async (_: LoaderFunctionArgs) => {
+ const queryParameters: Options = {
+ query: { tags: [], limit: 10 },
+ };
+
+ await ensureUseFindPetsData(queryClient, queryParameters);
+ return queryParameters;
+ };
+
+export function Compoment() {
+ const queryParameters = useLoaderData() as Awaited<
+ ReturnType>
+>;
+
+ const { data, error, refetch } = useFindPetsSuspense(queryParameters);
+
+ const { mutate: addPet, isError } = useAddPet();
+
+ const [text, setText] = useState("");
+ const [errorText, setErrorText] = useState();
+
+ if (error)
+ return (
+
+
Failed to fetch pets
+
+
+ );
+
+ return (
+
+
Pet List
+
setText(e.target.value)}
+ />
+
+ {isError && (
+
+ {errorText}
+
+ )}
+
+ {Array.isArray(data) &&
+ data?.map((pet, index) => (
+ - {pet.name}
+ ))}
+
+
+ );
+}
+
diff --git a/examples/react-router-6-app/src/ClientFetchWrapper.tsx b/examples/react-router-6-app/src/ClientFetchWrapper.tsx
new file mode 100644
index 0000000..2a30ee7
--- /dev/null
+++ b/examples/react-router-6-app/src/ClientFetchWrapper.tsx
@@ -0,0 +1,11 @@
+import { createClient } from "@hey-api/client-fetch";
+
+export function ClientFetchWrapper({
+ children,
+}: {
+ children: React.ReactNode;
+}) {
+ createClient({ baseUrl: "http://localhost:4010" });
+
+ return <>{children}>;
+}
diff --git a/examples/react-router-6-app/src/assets/react.svg b/examples/react-router-6-app/src/assets/react.svg
new file mode 100644
index 0000000..6c87de9
--- /dev/null
+++ b/examples/react-router-6-app/src/assets/react.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/examples/react-router-6-app/src/axios.ts b/examples/react-router-6-app/src/axios.ts
new file mode 100644
index 0000000..22aaac4
--- /dev/null
+++ b/examples/react-router-6-app/src/axios.ts
@@ -0,0 +1,6 @@
+import { client } from "../openapi/requests/services.gen";
+
+client.setConfig({
+ baseURL: "http://localhost:4010",
+ throwOnError: true,
+});
diff --git a/examples/react-router-6-app/src/index.css b/examples/react-router-6-app/src/index.css
new file mode 100644
index 0000000..fe79a7d
--- /dev/null
+++ b/examples/react-router-6-app/src/index.css
@@ -0,0 +1,87 @@
+:root {
+ font-family: Inter, Avenir, Helvetica, Arial, sans-serif;
+ font-size: 16px;
+ line-height: 24px;
+ font-weight: 400;
+
+ color-scheme: light dark;
+ color: rgba(255, 255, 255, 0.87);
+ background-color: #242424;
+
+ font-synthesis: none;
+ text-rendering: optimizeLegibility;
+ -webkit-font-smoothing: antialiased;
+ -moz-osx-font-smoothing: grayscale;
+ -webkit-text-size-adjust: 100%;
+}
+
+a {
+ font-weight: 500;
+ color: #646cff;
+ text-decoration: inherit;
+}
+a:hover {
+ color: #535bf2;
+}
+
+body {
+ margin: 0;
+ display: flex;
+ place-items: center;
+ min-width: 320px;
+ min-height: 100vh;
+}
+
+h1 {
+ font-size: 3.2em;
+ line-height: 1.1;
+}
+
+button {
+ border-radius: 8px;
+ border: 1px solid transparent;
+ padding: 0.6em 1.2em;
+ font-size: 1em;
+ font-weight: 500;
+ font-family: inherit;
+ background-color: #1a1a1a;
+ cursor: pointer;
+ transition: border-color 0.25s;
+}
+button:hover {
+ border-color: #646cff;
+}
+button:focus,
+button:focus-visible {
+ outline: 4px auto -webkit-focus-ring-color;
+}
+
+@media (prefers-color-scheme: light) {
+ :root {
+ color: #213547;
+ background-color: #ffffff;
+ }
+ a:hover {
+ color: #747bff;
+ }
+ button {
+ background-color: #f9f9f9;
+ }
+}
+
+input {
+ border-radius: 8px;
+ border: 1px solid #ccc;
+ padding: 0.5em;
+ font-size: 1em;
+ font-family: inherit;
+ background-color: #fff;
+ color: #000;
+ transition: border-color 0.25s;
+ margin: 1em;
+}
+
+input:focus {
+ border-color: #646cff;
+ outline: none;
+}
diff --git a/examples/react-router-6-app/src/main.tsx b/examples/react-router-6-app/src/main.tsx
new file mode 100644
index 0000000..1848446
--- /dev/null
+++ b/examples/react-router-6-app/src/main.tsx
@@ -0,0 +1,29 @@
+import React from "react";
+import ReactDOM from "react-dom/client";
+import { Compoment, loader } from "./App";
+import "./index.css";
+import { QueryClientProvider } from "@tanstack/react-query";
+import { ReactQueryDevtools } from "@tanstack/react-query-devtools";
+import { queryClient } from "./queryClient";
+import "./axios";
+import { createBrowserRouter, RouterProvider } from "react-router-dom";
+import { ClientFetchWrapper } from "./ClientFetchWrapper";
+
+const router = createBrowserRouter([
+ {
+ path: "/",
+ element: ,
+ loader: loader(queryClient),
+ },
+]);
+
+ReactDOM.createRoot(document.getElementById("root") as HTMLElement).render(
+
+
+
+
+
+
+
+
+);
diff --git a/examples/react-router-6-app/src/queryClient.tsx b/examples/react-router-6-app/src/queryClient.tsx
new file mode 100644
index 0000000..6c7b9de
--- /dev/null
+++ b/examples/react-router-6-app/src/queryClient.tsx
@@ -0,0 +1,3 @@
+import { QueryClient } from "@tanstack/react-query";
+
+export const queryClient = new QueryClient();
diff --git a/examples/react-router-6-app/src/vite-env.d.ts b/examples/react-router-6-app/src/vite-env.d.ts
new file mode 100644
index 0000000..11f02fe
--- /dev/null
+++ b/examples/react-router-6-app/src/vite-env.d.ts
@@ -0,0 +1 @@
+///
diff --git a/examples/react-router-6-app/tsconfig.json b/examples/react-router-6-app/tsconfig.json
new file mode 100644
index 0000000..4e730f0
--- /dev/null
+++ b/examples/react-router-6-app/tsconfig.json
@@ -0,0 +1,25 @@
+{
+ "compilerOptions": {
+ "target": "ESNext",
+ "useDefineForClassFields": true,
+ "lib": ["DOM", "DOM.Iterable", "ESNext"],
+ "allowJs": false,
+ "skipLibCheck": true,
+ "esModuleInterop": false,
+ "allowSyntheticDefaultImports": true,
+ "strict": true,
+ "forceConsistentCasingInFileNames": true,
+ "module": "ESNext",
+ "moduleResolution": "Bundler",
+ "resolveJsonModule": true,
+ "isolatedModules": true,
+ "noEmit": true,
+ "jsx": "react-jsx"
+ },
+ "include": ["src"],
+ "references": [
+ {
+ "path": "./tsconfig.node.json"
+ }
+ ]
+}
diff --git a/examples/react-router-6-app/tsconfig.node.json b/examples/react-router-6-app/tsconfig.node.json
new file mode 100644
index 0000000..9d31e2a
--- /dev/null
+++ b/examples/react-router-6-app/tsconfig.node.json
@@ -0,0 +1,9 @@
+{
+ "compilerOptions": {
+ "composite": true,
+ "module": "ESNext",
+ "moduleResolution": "Node",
+ "allowSyntheticDefaultImports": true
+ },
+ "include": ["vite.config.ts"]
+}
diff --git a/examples/react-router-6-app/vite.config.ts b/examples/react-router-6-app/vite.config.ts
new file mode 100644
index 0000000..1ff0da0
--- /dev/null
+++ b/examples/react-router-6-app/vite.config.ts
@@ -0,0 +1,7 @@
+import react from "@vitejs/plugin-react";
+import { defineConfig } from "vite";
+
+// https://vitejs.dev/config/
+export default defineConfig({
+ plugins: [react()],
+});
From a724121e34c517a3a27948cb7627c3b8fe84e758 Mon Sep 17 00:00:00 2001
From: Bryan Thomas <49354825+bryanjtc@users.noreply.github.com>
Date: Wed, 23 Oct 2024 11:51:08 -0500
Subject: [PATCH 02/15] lint: Format code
---
examples/react-router-6-app/src/App.tsx | 33 ++++++++++--------------
examples/react-router-6-app/src/main.tsx | 4 +--
2 files changed, 16 insertions(+), 21 deletions(-)
diff --git a/examples/react-router-6-app/src/App.tsx b/examples/react-router-6-app/src/App.tsx
index 8720410..00e63d8 100644
--- a/examples/react-router-6-app/src/App.tsx
+++ b/examples/react-router-6-app/src/App.tsx
@@ -1,33 +1,29 @@
import "./App.css";
import { useState } from "react";
-import {
- UseFindPetsKeyFn,
- useAddPet,
-} from "../openapi/queries";
-import { ensureUseFindPetsData } from "../openapi/queries/ensureQueryData";
-import { queryClient } from "./queryClient";
+import type { Options } from "@hey-api/client-axios";
import type { QueryClient } from "@tanstack/react-query";
import { type LoaderFunctionArgs, useLoaderData } from "react-router-dom";
-import type { FindPetsData } from "../openapi/requests/types.gen";
-import type { Options } from "@hey-api/client-axios";
+import { UseFindPetsKeyFn, useAddPet } from "../openapi/queries";
+import { ensureUseFindPetsData } from "../openapi/queries/ensureQueryData";
import { useFindPetsSuspense } from "../openapi/queries/suspense";
+import type { FindPetsData } from "../openapi/requests/types.gen";
+import { queryClient } from "./queryClient";
export const loader =
- (queryClient: QueryClient) =>
- async (_: LoaderFunctionArgs) => {
- const queryParameters: Options = {
- query: { tags: [], limit: 10 },
- };
-
- await ensureUseFindPetsData(queryClient, queryParameters);
- return queryParameters;
+ (queryClient: QueryClient) => async (_: LoaderFunctionArgs) => {
+ const queryParameters: Options = {
+ query: { tags: [], limit: 10 },
};
+ await ensureUseFindPetsData(queryClient, queryParameters);
+ return queryParameters;
+ };
+
export function Compoment() {
const queryParameters = useLoaderData() as Awaited<
- ReturnType>
->;
+ ReturnType>
+ >;
const { data, error, refetch } = useFindPetsSuspense(queryParameters);
@@ -97,4 +93,3 @@ export function Compoment() {
);
}
-
diff --git a/examples/react-router-6-app/src/main.tsx b/examples/react-router-6-app/src/main.tsx
index 1848446..1637108 100644
--- a/examples/react-router-6-app/src/main.tsx
+++ b/examples/react-router-6-app/src/main.tsx
@@ -6,7 +6,7 @@ import { QueryClientProvider } from "@tanstack/react-query";
import { ReactQueryDevtools } from "@tanstack/react-query-devtools";
import { queryClient } from "./queryClient";
import "./axios";
-import { createBrowserRouter, RouterProvider } from "react-router-dom";
+import { RouterProvider, createBrowserRouter } from "react-router-dom";
import { ClientFetchWrapper } from "./ClientFetchWrapper";
const router = createBrowserRouter([
@@ -25,5 +25,5 @@ ReactDOM.createRoot(document.getElementById("root") as HTMLElement).render(
-
+ ,
);
From 5d2902a79f6e8ddb253ef15bbc3c612e677c1ee6 Mon Sep 17 00:00:00 2001
From: Bryan Thomas <49354825+bryanjtc@users.noreply.github.com>
Date: Wed, 23 Oct 2024 11:52:29 -0500
Subject: [PATCH 03/15] docs: Add react router 7 example
---
examples/react-router-7-app/.gitignore | 24 +
.../react-router-7-app/app/entry.client.tsx | 12 +
examples/react-router-7-app/app/index.css | 87 +
examples/react-router-7-app/app/root.tsx | 22 +
examples/react-router-7-app/app/routes.ts | 4 +
.../app/routes/_index/App.css | 41 +
.../app/routes/_index/route.tsx | 109 ++
examples/react-router-7-app/assets/react.svg | 1 +
examples/react-router-7-app/fetchClient.ts | 6 +
examples/react-router-7-app/package.json | 39 +
examples/react-router-7-app/providers.tsx | 13 +
.../react-router-7-app/public/favicon.ico | Bin 0 -> 4286 bytes
examples/react-router-7-app/public/vite.svg | 1 +
examples/react-router-7-app/queryClient.tsx | 3 +
examples/react-router-7-app/tsconfig.json | 35 +
.../react-router-7-app/tsconfig.node.json | 9 +
examples/react-router-7-app/vite-env.d.ts | 1 +
examples/react-router-7-app/vite.config.ts | 11 +
pnpm-lock.yaml | 1432 ++++++++++++++++-
19 files changed, 1840 insertions(+), 10 deletions(-)
create mode 100644 examples/react-router-7-app/.gitignore
create mode 100644 examples/react-router-7-app/app/entry.client.tsx
create mode 100644 examples/react-router-7-app/app/index.css
create mode 100644 examples/react-router-7-app/app/root.tsx
create mode 100644 examples/react-router-7-app/app/routes.ts
create mode 100644 examples/react-router-7-app/app/routes/_index/App.css
create mode 100644 examples/react-router-7-app/app/routes/_index/route.tsx
create mode 100644 examples/react-router-7-app/assets/react.svg
create mode 100644 examples/react-router-7-app/fetchClient.ts
create mode 100644 examples/react-router-7-app/package.json
create mode 100644 examples/react-router-7-app/providers.tsx
create mode 100644 examples/react-router-7-app/public/favicon.ico
create mode 100644 examples/react-router-7-app/public/vite.svg
create mode 100644 examples/react-router-7-app/queryClient.tsx
create mode 100644 examples/react-router-7-app/tsconfig.json
create mode 100644 examples/react-router-7-app/tsconfig.node.json
create mode 100644 examples/react-router-7-app/vite-env.d.ts
create mode 100644 examples/react-router-7-app/vite.config.ts
diff --git a/examples/react-router-7-app/.gitignore b/examples/react-router-7-app/.gitignore
new file mode 100644
index 0000000..a547bf3
--- /dev/null
+++ b/examples/react-router-7-app/.gitignore
@@ -0,0 +1,24 @@
+# Logs
+logs
+*.log
+npm-debug.log*
+yarn-debug.log*
+yarn-error.log*
+pnpm-debug.log*
+lerna-debug.log*
+
+node_modules
+dist
+dist-ssr
+*.local
+
+# Editor directories and files
+.vscode/*
+!.vscode/extensions.json
+.idea
+.DS_Store
+*.suo
+*.ntvs*
+*.njsproj
+*.sln
+*.sw?
diff --git a/examples/react-router-7-app/app/entry.client.tsx b/examples/react-router-7-app/app/entry.client.tsx
new file mode 100644
index 0000000..bc83c1d
--- /dev/null
+++ b/examples/react-router-7-app/app/entry.client.tsx
@@ -0,0 +1,12 @@
+import React from "react";
+import ReactDOM from "react-dom/client";
+import { HydratedRouter } from "react-router/dom";
+import { routes } from "./routes";
+
+ReactDOM.hydrateRoot(
+ document,
+
+ {/* @ts-expect-error */}
+
+ ,
+);
diff --git a/examples/react-router-7-app/app/index.css b/examples/react-router-7-app/app/index.css
new file mode 100644
index 0000000..fe79a7d
--- /dev/null
+++ b/examples/react-router-7-app/app/index.css
@@ -0,0 +1,87 @@
+:root {
+ font-family: Inter, Avenir, Helvetica, Arial, sans-serif;
+ font-size: 16px;
+ line-height: 24px;
+ font-weight: 400;
+
+ color-scheme: light dark;
+ color: rgba(255, 255, 255, 0.87);
+ background-color: #242424;
+
+ font-synthesis: none;
+ text-rendering: optimizeLegibility;
+ -webkit-font-smoothing: antialiased;
+ -moz-osx-font-smoothing: grayscale;
+ -webkit-text-size-adjust: 100%;
+}
+
+a {
+ font-weight: 500;
+ color: #646cff;
+ text-decoration: inherit;
+}
+a:hover {
+ color: #535bf2;
+}
+
+body {
+ margin: 0;
+ display: flex;
+ place-items: center;
+ min-width: 320px;
+ min-height: 100vh;
+}
+
+h1 {
+ font-size: 3.2em;
+ line-height: 1.1;
+}
+
+button {
+ border-radius: 8px;
+ border: 1px solid transparent;
+ padding: 0.6em 1.2em;
+ font-size: 1em;
+ font-weight: 500;
+ font-family: inherit;
+ background-color: #1a1a1a;
+ cursor: pointer;
+ transition: border-color 0.25s;
+}
+button:hover {
+ border-color: #646cff;
+}
+button:focus,
+button:focus-visible {
+ outline: 4px auto -webkit-focus-ring-color;
+}
+
+@media (prefers-color-scheme: light) {
+ :root {
+ color: #213547;
+ background-color: #ffffff;
+ }
+ a:hover {
+ color: #747bff;
+ }
+ button {
+ background-color: #f9f9f9;
+ }
+}
+
+input {
+ border-radius: 8px;
+ border: 1px solid #ccc;
+ padding: 0.5em;
+ font-size: 1em;
+ font-family: inherit;
+ background-color: #fff;
+ color: #000;
+ transition: border-color 0.25s;
+ margin: 1em;
+}
+
+input:focus {
+ border-color: #646cff;
+ outline: none;
+}
diff --git a/examples/react-router-7-app/app/root.tsx b/examples/react-router-7-app/app/root.tsx
new file mode 100644
index 0000000..314613e
--- /dev/null
+++ b/examples/react-router-7-app/app/root.tsx
@@ -0,0 +1,22 @@
+import "./index.css";
+import { Outlet, Scripts, ScrollRestoration } from "react-router";
+import Providers from "../providers";
+
+export default function Root() {
+ return (
+
+
+
+
+ Vite + React + TS
+
+
+
+
+
+
+
+
+
+ );
+}
diff --git a/examples/react-router-7-app/app/routes.ts b/examples/react-router-7-app/app/routes.ts
new file mode 100644
index 0000000..a9d70eb
--- /dev/null
+++ b/examples/react-router-7-app/app/routes.ts
@@ -0,0 +1,4 @@
+import type { RouteConfig } from "@react-router/dev/routes";
+import { flatRoutes } from "@react-router/fs-routes";
+
+export const routes: RouteConfig = flatRoutes();
diff --git a/examples/react-router-7-app/app/routes/_index/App.css b/examples/react-router-7-app/app/routes/_index/App.css
new file mode 100644
index 0000000..2c5e2ef
--- /dev/null
+++ b/examples/react-router-7-app/app/routes/_index/App.css
@@ -0,0 +1,41 @@
+#root {
+ max-width: 1280px;
+ margin: 0 auto;
+ padding: 2rem;
+ text-align: center;
+}
+
+.logo {
+ height: 6em;
+ padding: 1.5em;
+ will-change: filter;
+}
+.logo:hover {
+ filter: drop-shadow(0 0 2em #646cffaa);
+}
+.logo.react:hover {
+ filter: drop-shadow(0 0 2em #61dafbaa);
+}
+
+@keyframes logo-spin {
+ from {
+ transform: rotate(0deg);
+ }
+ to {
+ transform: rotate(360deg);
+ }
+}
+
+@media (prefers-reduced-motion: no-preference) {
+ a:nth-of-type(2) .logo {
+ animation: logo-spin infinite 20s linear;
+ }
+}
+
+.card {
+ padding: 2em;
+}
+
+.read-the-docs {
+ color: #888;
+}
diff --git a/examples/react-router-7-app/app/routes/_index/route.tsx b/examples/react-router-7-app/app/routes/_index/route.tsx
new file mode 100644
index 0000000..5009238
--- /dev/null
+++ b/examples/react-router-7-app/app/routes/_index/route.tsx
@@ -0,0 +1,109 @@
+import "./App.css";
+import { useState } from "react";
+
+import {
+ HydrationBoundary,
+ QueryClient,
+ dehydrate,
+} from "@tanstack/react-query";
+import React from "react";
+import {
+ UseFindPetsKeyFn,
+ useAddPet,
+ useFindPets,
+} from "../../../openapi/queries";
+import { prefetchUseFindPets } from "../../../openapi/queries/prefetch";
+import { queryClient } from "../../../queryClient";
+
+export const loader = async () => {
+ const queryClient = new QueryClient();
+
+ await prefetchUseFindPets(queryClient, {
+ query: { tags: [], limit: 10 },
+ });
+
+ return { dehydratedState: dehydrate(queryClient) };
+};
+
+function Pets() {
+ const { data, error, refetch } = useFindPets({
+ query: { tags: [], limit: 10 },
+ });
+
+ const { mutate: addPet, isError } = useAddPet();
+
+ const [text, setText] = useState("");
+ const [errorText, setErrorText] = useState();
+
+ if (error)
+ return (
+
+
Failed to fetch pets
+
+
+ );
+
+ return (
+
+
Pet List
+
setText(e.target.value)}
+ />
+
+ {isError && (
+
+ {errorText}
+
+ )}
+
+ {Array.isArray(data) &&
+ data?.map((pet, index) => (
+ - {pet.name}
+ ))}
+
+
+ );
+}
+
+export function Component({ loaderData }) {
+ const { dehydratedState } = loaderData;
+ return (
+
+
+
+ );
+}
diff --git a/examples/react-router-7-app/assets/react.svg b/examples/react-router-7-app/assets/react.svg
new file mode 100644
index 0000000..6c87de9
--- /dev/null
+++ b/examples/react-router-7-app/assets/react.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/examples/react-router-7-app/fetchClient.ts b/examples/react-router-7-app/fetchClient.ts
new file mode 100644
index 0000000..1cc5028
--- /dev/null
+++ b/examples/react-router-7-app/fetchClient.ts
@@ -0,0 +1,6 @@
+import { client } from "../react-app/openapi/requests/services.gen";
+
+client.setConfig({
+ baseURL: "http://localhost:4010",
+ throwOnError: true,
+});
diff --git a/examples/react-router-7-app/package.json b/examples/react-router-7-app/package.json
new file mode 100644
index 0000000..93f0d17
--- /dev/null
+++ b/examples/react-router-7-app/package.json
@@ -0,0 +1,39 @@
+{
+ "name": "@7nohe/react-router-7-app",
+ "private": true,
+ "version": "0.0.0",
+ "type": "module",
+ "scripts": {
+ "dev": "run-p dev:mock dev:client",
+ "dev:client": "react-router dev",
+ "dev:mock": "prism mock ../petstore.yaml --dynamic",
+ "build": "tsc && react-router build",
+ "preview": "react-router-serve ./build/server/index.js",
+ "generate:api": "rimraf ./openapi && node ../../dist/cli.mjs -i ../petstore.yaml --format=biome --lint=biome",
+ "test:generated": "tsc -p ./tsconfig.json --noEmit"
+ },
+ "dependencies": {
+ "@react-router/fs-routes": "^7.0.0-pre.1",
+ "@react-router/node": "^7.0.0-pre.1",
+ "@react-router/serve": "^7.0.0-pre.1",
+ "@tanstack/react-query": "^5.59.13",
+ "@tanstack/react-query-devtools": "^5.32.1",
+ "form-data": "~4.0.0",
+ "isbot": "^5",
+ "react": "^18.3.1",
+ "react-dom": "^18.3.1",
+ "react-router": "^7.0.0-pre.1",
+ "react-router-dom": "^7.0.0-pre.1"
+ },
+ "devDependencies": {
+ "@biomejs/biome": "^1.7.2",
+ "@react-router/dev": "^7.0.0-pre.1",
+ "@stoplight/prism-cli": "^5.5.2",
+ "@types/react": "^18.3.1",
+ "@types/react-dom": "^18.2.18",
+ "@vitejs/plugin-react": "^4.2.1",
+ "npm-run-all": "^4.1.5",
+ "typescript": "^5.4.5",
+ "vite": "^5.0.12"
+ }
+}
diff --git a/examples/react-router-7-app/providers.tsx b/examples/react-router-7-app/providers.tsx
new file mode 100644
index 0000000..ce94ad7
--- /dev/null
+++ b/examples/react-router-7-app/providers.tsx
@@ -0,0 +1,13 @@
+import { QueryClientProvider } from "@tanstack/react-query";
+import { ReactQueryDevtools } from "@tanstack/react-query-devtools";
+import "./fetchClient";
+import { queryClient } from "./queryClient";
+
+export default function Providers({ children }: { children: React.ReactNode }) {
+ return (
+
+ {children}
+
+
+ );
+}
diff --git a/examples/react-router-7-app/public/favicon.ico b/examples/react-router-7-app/public/favicon.ico
new file mode 100644
index 0000000000000000000000000000000000000000..18541a0c1bc2c3a450aad43a42900cd3ac5d1039
GIT binary patch
literal 4286
zcmc(jeO%Sm9mntfY5(MFYisUhSz2jYYi#o|+uW?JoFivW$-#6rQSzAunyHl!1ZtY1
zC`kB3P#RYO69w*7NkvmJK_fL(6rE2cPr~SeaNheI;bv~HlzU&>Ysc4z-|znJ`JMAV
z-}8MqSBK*}`q#0e!~S)w|GvY~*5Pn;mGsEbPqNRiH+}a|K(m@3I2`!f8Vx4)1ZLbJ
zxKi)$DE_~9xC-;kZcNV|u)657T`+
zriWy&aVNp}H=IvzRn=oA?8EfV!Sr%N581%ZKOi4ItM+Lqe>$6tQ<&dvhQ3)84cf!T
zki+tUmVKCY6zZG&8MbxroUg%zTEYfr=cDHStF49})f
z7ns5C7hMuVEv12q!#>%VzT05Sh1-wkOOJ+YnD`x-;8mDm$(W&H7`zT-i&thI$FTwC
zMQZPVvl;WmR!r!}@TJF>8E)OTP(C+qCFX^9FvC}iV=X2q1qP>*8u2lA$Q=S!UFGy(
z7xep3vAGrAE4}rYt^KyPPI-2tY#)aim4JCs3?o)S@M;KJOTkOov`ee!yP5FTv`^vb
z4Ef1x`#Wr
zKpSb{8;2oKeyaE|LD^7T?%(V--rUM7uf2(x7K3?33=s>jGcbM$v*HeNr?$I|^t~KO
zQ?=2x*ZWnR8UCRdJ`jTwGxvaUQlsw-=T*~U-@?qAiFqRmGb0)^b)Iao0KymIoS#iw
zm*Iy>!9Ng#S9j&YqNqao=6lV#Vn_z;^D!Q;H7JG^U-MptnAb6LEW;d_5d~9YAaX86
zvr~9D=PT~s4nLCaR@htJrTack*&tLwq4+S*u9FQvQcm*Wj8G~+PMEHROo0W{VD1d+
zVxriPkipiaPEJLw;N$7QQE6W|>wAsm)PXfcziiJi%y+_T)H)Yg8l=9Jp+f%~NPD!pFat5W3E
zl0^kDTzM;449|T|y>m6T1AAB|89D_9l)J?cqWZB$(2Y(1$xwL$T$(E*1e||`
z^?y?immQMBVD(rUlO_@AF5tmK&{?i!)k!Q~S*Gg}*8{rmAl)zh)>T2-WYvn$c;)Uy
z<*!sYcJb!iNbQp9VD*^PyU0U9N}39?&ELw~)1)b?
zArYz};i_Y{mQIM*8s$L8w7#Mzp-}S{>i)>fdM5VM>*1n;xv~W6uBeWBNUt(<*T-Lc
zenUSOk5^xFiEpL-J#y)SY5GheZ
\ No newline at end of file
diff --git a/examples/react-router-7-app/queryClient.tsx b/examples/react-router-7-app/queryClient.tsx
new file mode 100644
index 0000000..6c7b9de
--- /dev/null
+++ b/examples/react-router-7-app/queryClient.tsx
@@ -0,0 +1,3 @@
+import { QueryClient } from "@tanstack/react-query";
+
+export const queryClient = new QueryClient();
diff --git a/examples/react-router-7-app/tsconfig.json b/examples/react-router-7-app/tsconfig.json
new file mode 100644
index 0000000..7a35035
--- /dev/null
+++ b/examples/react-router-7-app/tsconfig.json
@@ -0,0 +1,35 @@
+{
+ "compilerOptions": {
+ "target": "ESNext",
+ "useDefineForClassFields": true,
+ "lib": ["DOM", "DOM.Iterable", "ESNext"],
+ "allowJs": false,
+ "skipLibCheck": true,
+ "esModuleInterop": false,
+ "allowSyntheticDefaultImports": true,
+ "strict": true,
+ "forceConsistentCasingInFileNames": true,
+ "module": "ESNext",
+ "moduleResolution": "Bundler",
+ "resolveJsonModule": true,
+ "isolatedModules": true,
+ "noEmit": true,
+ "jsx": "react-jsx"
+ },
+ "include": [
+ "src",
+ "app/root.tsx",
+ "app/entry.client.tsx",
+ "queryClient.tsx",
+ "ClientFetchWrapper.tsx",
+ "fetchClient.ts",
+ "app/routes.ts",
+ "vite-env.d.ts",
+ "providers.tsx"
+ ],
+ "references": [
+ {
+ "path": "./tsconfig.node.json"
+ }
+ ]
+}
diff --git a/examples/react-router-7-app/tsconfig.node.json b/examples/react-router-7-app/tsconfig.node.json
new file mode 100644
index 0000000..9b5ccea
--- /dev/null
+++ b/examples/react-router-7-app/tsconfig.node.json
@@ -0,0 +1,9 @@
+{
+ "compilerOptions": {
+ "composite": true,
+ "module": "Node16",
+ "moduleResolution": "Node16",
+ "allowSyntheticDefaultImports": true
+ },
+ "include": ["vite.config.ts"]
+}
diff --git a/examples/react-router-7-app/vite-env.d.ts b/examples/react-router-7-app/vite-env.d.ts
new file mode 100644
index 0000000..11f02fe
--- /dev/null
+++ b/examples/react-router-7-app/vite-env.d.ts
@@ -0,0 +1 @@
+///
diff --git a/examples/react-router-7-app/vite.config.ts b/examples/react-router-7-app/vite.config.ts
new file mode 100644
index 0000000..47ca651
--- /dev/null
+++ b/examples/react-router-7-app/vite.config.ts
@@ -0,0 +1,11 @@
+import { reactRouter } from "@react-router/dev/vite";
+import { defineConfig } from "vite";
+
+// https://vitejs.dev/config/
+export default defineConfig({
+ plugins: [
+ reactRouter({
+ ssr: true,
+ }),
+ ],
+});
diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml
index 599638b..53a758f 100644
--- a/pnpm-lock.yaml
+++ b/pnpm-lock.yaml
@@ -159,6 +159,122 @@ importers:
specifier: ^5.0.12
version: 5.2.13(@types/node@22.7.4)(terser@5.34.1)
+ examples/react-router-6-app:
+ dependencies:
+ '@hey-api/client-axios':
+ specifier: ^0.2.7
+ version: 0.2.7(axios@1.7.7)
+ '@tanstack/react-query':
+ specifier: ^5.59.13
+ version: 5.59.13(react@18.3.1)
+ '@tanstack/react-query-devtools':
+ specifier: ^5.32.1
+ version: 5.45.0(@tanstack/react-query@5.59.13(react@18.3.1))(react@18.3.1)
+ axios:
+ specifier: ^1.7.7
+ version: 1.7.7
+ form-data:
+ specifier: ~4.0.0
+ version: 4.0.0
+ react:
+ specifier: ^18.3.1
+ version: 18.3.1
+ react-dom:
+ specifier: ^18.3.1
+ version: 18.3.1(react@18.3.1)
+ react-router-dom:
+ specifier: ^6.27.0
+ version: 6.27.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
+ devDependencies:
+ '@biomejs/biome':
+ specifier: ^1.7.2
+ version: 1.9.3
+ '@stoplight/prism-cli':
+ specifier: ^5.5.2
+ version: 5.8.1
+ '@types/react':
+ specifier: ^18.3.1
+ version: 18.3.3
+ '@types/react-dom':
+ specifier: ^18.2.18
+ version: 18.3.0
+ '@vitejs/plugin-react':
+ specifier: ^4.2.1
+ version: 4.3.1(vite@5.4.8(@types/node@22.7.4)(terser@5.34.1))
+ npm-run-all:
+ specifier: ^4.1.5
+ version: 4.1.5
+ typescript:
+ specifier: ^5.4.5
+ version: 5.6.3
+ vite:
+ specifier: ^5.0.12
+ version: 5.4.8(@types/node@22.7.4)(terser@5.34.1)
+
+ examples/react-router-7-app:
+ dependencies:
+ '@react-router/fs-routes':
+ specifier: ^7.0.0-pre.1
+ version: 7.0.0-pre.1(@react-router/dev@7.0.0-pre.1(@react-router/serve@7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3))(@types/node@22.7.4)(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(terser@5.34.1)(typescript@5.6.3)(vite@5.4.8(@types/node@22.7.4)(terser@5.34.1)))(typescript@5.6.3)
+ '@react-router/node':
+ specifier: ^7.0.0-pre.1
+ version: 7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
+ '@react-router/serve':
+ specifier: ^7.0.0-pre.1
+ version: 7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
+ '@tanstack/react-query':
+ specifier: ^5.59.13
+ version: 5.59.13(react@18.3.1)
+ '@tanstack/react-query-devtools':
+ specifier: ^5.32.1
+ version: 5.45.0(@tanstack/react-query@5.59.13(react@18.3.1))(react@18.3.1)
+ form-data:
+ specifier: ~4.0.0
+ version: 4.0.0
+ isbot:
+ specifier: ^5
+ version: 5.1.17
+ react:
+ specifier: ^18.3.1
+ version: 18.3.1
+ react-dom:
+ specifier: ^18.3.1
+ version: 18.3.1(react@18.3.1)
+ react-router:
+ specifier: ^7.0.0-pre.1
+ version: 7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
+ react-router-dom:
+ specifier: ^7.0.0-pre.1
+ version: 7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
+ devDependencies:
+ '@biomejs/biome':
+ specifier: ^1.7.2
+ version: 1.9.3
+ '@react-router/dev':
+ specifier: ^7.0.0-pre.1
+ version: 7.0.0-pre.1(@react-router/serve@7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3))(@types/node@22.7.4)(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(terser@5.34.1)(typescript@5.6.3)(vite@5.4.8(@types/node@22.7.4)(terser@5.34.1))
+ '@stoplight/prism-cli':
+ specifier: ^5.5.2
+ version: 5.8.1
+ '@types/react':
+ specifier: ^18.3.1
+ version: 18.3.3
+ '@types/react-dom':
+ specifier: ^18.2.18
+ version: 18.3.0
+ '@vitejs/plugin-react':
+ specifier: ^4.2.1
+ version: 4.3.1(vite@5.4.8(@types/node@22.7.4)(terser@5.34.1))
+ npm-run-all:
+ specifier: ^4.1.5
+ version: 4.1.5
+ typescript:
+ specifier: ^5.4.5
+ version: 5.6.3
+ vite:
+ specifier: ^5.0.12
+ version: 5.4.8(@types/node@22.7.4)(terser@5.34.1)
+
examples/tanstack-router-app:
dependencies:
'@tanstack/react-query':
@@ -279,6 +395,10 @@ packages:
resolution: {integrity: sha512-0xZJFNE5XMpENsgfHYTw8FbX4kv53mFLn2i3XPoq69LyhYSCBJtitaHx9QnsVTrsogI4Z3+HtEfZ2/GFPOtf5g==}
engines: {node: '>=6.9.0'}
+ '@babel/code-frame@7.25.9':
+ resolution: {integrity: sha512-z88xeGxnzehn2sqZ8UdGQEvYErF1odv2CftxInpSYJt6uHuPe9YjahKZITGs3l5LeI9d2ROG+obuDAoSlqbNfQ==}
+ engines: {node: '>=6.9.0'}
+
'@babel/compat-data@7.24.7':
resolution: {integrity: sha512-qJzAIcv03PyaWqxRgO4mSU3lihncDT296vnyuE2O8uA4w3UHWI4S3hgeZd1L8W1Bft40w9JxJ2b412iDUFFRhw==}
engines: {node: '>=6.9.0'}
@@ -303,10 +423,18 @@ packages:
resolution: {integrity: sha512-5Dqpl5fyV9pIAD62yK9P7fcA768uVPUyrQmqpqstHWgMma4feF1x/oFysBCVZLY5wJ2GkMUCdsNDnGZrPoR6rA==}
engines: {node: '>=6.9.0'}
+ '@babel/generator@7.25.9':
+ resolution: {integrity: sha512-omlUGkr5EaoIJrhLf9CJ0TvjBRpd9+AXRG//0GEQ9THSo8wPiTlbpy1/Ow8ZTrbXpjd9FHXfbFQx32I04ht0FA==}
+ engines: {node: '>=6.9.0'}
+
'@babel/helper-annotate-as-pure@7.25.7':
resolution: {integrity: sha512-4xwU8StnqnlIhhioZf1tqnVWeQ9pvH/ujS8hRfw/WOza+/a+1qv69BWNy+oY231maTCWgKWhfBU7kDpsds6zAA==}
engines: {node: '>=6.9.0'}
+ '@babel/helper-annotate-as-pure@7.25.9':
+ resolution: {integrity: sha512-gv7320KBUFJz1RnylIg5WWYPRXKZ884AGkYpgpWW02TH66Dl+HaC1t1CKd0z3R4b6hdYEcmrNZHUmfCP+1u3/g==}
+ engines: {node: '>=6.9.0'}
+
'@babel/helper-compilation-targets@7.24.7':
resolution: {integrity: sha512-ctSdRHBi20qWOfy27RUb4Fhp07KSJ3sXcuSvTrXrc4aG8NSYDo1ici3Vhg9bg69y5bj0Mr1lh0aeEgTvc12rMg==}
engines: {node: '>=6.9.0'}
@@ -315,6 +443,12 @@ packages:
resolution: {integrity: sha512-DniTEax0sv6isaw6qSQSfV4gVRNtw2rte8HHM45t9ZR0xILaufBRNkpMifCRiAPyvL4ACD6v0gfCwCmtOQaV4A==}
engines: {node: '>=6.9.0'}
+ '@babel/helper-create-class-features-plugin@7.25.9':
+ resolution: {integrity: sha512-UTZQMvt0d/rSz6KI+qdu7GQze5TIajwTS++GUozlw8VBJDEOAqSXwm1WvmYEZwqdqSGQshRocPDqrt4HBZB3fQ==}
+ engines: {node: '>=6.9.0'}
+ peerDependencies:
+ '@babel/core': ^7.0.0
+
'@babel/helper-environment-visitor@7.24.7':
resolution: {integrity: sha512-DoiN84+4Gnd0ncbBOM9AZENV4a5ZiL39HYMyZJGZ/AZEykHYdJw0wW3kdcsh9/Kn+BRXHLkkklZ51ecPKmI1CQ==}
engines: {node: '>=6.9.0'}
@@ -327,6 +461,10 @@ packages:
resolution: {integrity: sha512-MJJwhkoGy5c4ehfoRyrJ/owKeMl19U54h27YYftT0o2teQ3FJ3nQUf/I3LlJsX4l3qlw7WRXUmiyajvHXoTubQ==}
engines: {node: '>=6.9.0'}
+ '@babel/helper-member-expression-to-functions@7.25.9':
+ resolution: {integrity: sha512-wbfdZ9w5vk0C0oyHqAJbc62+vet5prjj01jjJ8sKn3j9h3MQQlflEdXYvuqRWjHnM12coDEqiC1IRCi0U/EKwQ==}
+ engines: {node: '>=6.9.0'}
+
'@babel/helper-module-imports@7.24.7':
resolution: {integrity: sha512-8AyH3C+74cgCVVXow/myrynrAGv+nTVg5vKu2nZph9x7RcRwzmh0VFallJuFTZ9mx6u4eSdXZfcOzSqTUm0HCA==}
engines: {node: '>=6.9.0'}
@@ -335,6 +473,10 @@ packages:
resolution: {integrity: sha512-o0xCgpNmRohmnoWKQ0Ij8IdddjyBFE4T2kagL/x6M3+4zUgc+4qTOUBoNe4XxDskt1HPKO007ZPiMgLDq2s7Kw==}
engines: {node: '>=6.9.0'}
+ '@babel/helper-module-imports@7.25.9':
+ resolution: {integrity: sha512-tnUA4RsrmflIM6W6RFTLFSXITtl0wKjgpnLgXyowocVPrbYrLUXSBXDgTs8BlbmIzIdlBySRQjINYs2BAkiLtw==}
+ engines: {node: '>=6.9.0'}
+
'@babel/helper-module-transforms@7.24.7':
resolution: {integrity: sha512-1fuJEwIrp+97rM4RWdO+qrRsZlAeL1lQJoPqtCYWv0NL115XM93hIH4CSRln2w52SqvmY5hqdtauB6QFCDiZNQ==}
engines: {node: '>=6.9.0'}
@@ -347,6 +489,16 @@ packages:
peerDependencies:
'@babel/core': ^7.0.0
+ '@babel/helper-module-transforms@7.25.9':
+ resolution: {integrity: sha512-TvLZY/F3+GvdRYFZFyxMvnsKi+4oJdgZzU3BoGN9Uc2d9C6zfNwJcKKhjqLAhK8i46mv93jsO74fDh3ih6rpHA==}
+ engines: {node: '>=6.9.0'}
+ peerDependencies:
+ '@babel/core': ^7.0.0
+
+ '@babel/helper-optimise-call-expression@7.25.9':
+ resolution: {integrity: sha512-FIpuNaz5ow8VyrYcnXQTDRGvV6tTjkNtCK/RYNDXGSLlUD6cBuQTSw43CShGxjvfBTfcUA/r6UhUCbtYqkhcuQ==}
+ engines: {node: '>=6.9.0'}
+
'@babel/helper-plugin-utils@7.24.7':
resolution: {integrity: sha512-Rq76wjt7yz9AAc1KnlRKNAi/dMSVWgDRx43FHoJEbcYU6xOWaE2dVPwcdTukJrjxS65GITyfbvEYHvkirZ6uEg==}
engines: {node: '>=6.9.0'}
@@ -355,6 +507,16 @@ packages:
resolution: {integrity: sha512-eaPZai0PiqCi09pPs3pAFfl/zYgGaE6IdXtYvmf0qlcDTd3WCtO7JWCcRd64e0EQrcYgiHibEZnOGsSY4QSgaw==}
engines: {node: '>=6.9.0'}
+ '@babel/helper-plugin-utils@7.25.9':
+ resolution: {integrity: sha512-kSMlyUVdWe25rEsRGviIgOWnoT/nfABVWlqt9N19/dIPWViAOW2s9wznP5tURbs/IDuNk4gPy3YdYRgH3uxhBw==}
+ engines: {node: '>=6.9.0'}
+
+ '@babel/helper-replace-supers@7.25.9':
+ resolution: {integrity: sha512-IiDqTOTBQy0sWyeXyGSC5TBJpGFXBkRynjBeXsvbhQFKj2viwJC76Epz35YLU1fpe/Am6Vppb7W7zM4fPQzLsQ==}
+ engines: {node: '>=6.9.0'}
+ peerDependencies:
+ '@babel/core': ^7.0.0
+
'@babel/helper-simple-access@7.24.7':
resolution: {integrity: sha512-zBAIvbCMh5Ts+b86r/CjU+4XGYIs+R1j951gxI3KmmxBMhCg4oQMsv6ZXQ64XOm/cvzfU1FmoCyt6+owc5QMYg==}
engines: {node: '>=6.9.0'}
@@ -363,6 +525,14 @@ packages:
resolution: {integrity: sha512-FPGAkJmyoChQeM+ruBGIDyrT2tKfZJO8NcxdC+CWNJi7N8/rZpSxK7yvBJ5O/nF1gfu5KzN7VKG3YVSLFfRSxQ==}
engines: {node: '>=6.9.0'}
+ '@babel/helper-simple-access@7.25.9':
+ resolution: {integrity: sha512-c6WHXuiaRsJTyHYLJV75t9IqsmTbItYfdj99PnzYGQZkYKvan5/2jKJ7gu31J3/BJ/A18grImSPModuyG/Eo0Q==}
+ engines: {node: '>=6.9.0'}
+
+ '@babel/helper-skip-transparent-expression-wrappers@7.25.9':
+ resolution: {integrity: sha512-K4Du3BFa3gvyhzgPcntrkDgZzQaq6uozzcpGbOO1OEJaI+EJdqWIMTLgFgQf6lrfiDFo5FU+BxKepI9RmZqahA==}
+ engines: {node: '>=6.9.0'}
+
'@babel/helper-split-export-declaration@7.24.7':
resolution: {integrity: sha512-oy5V7pD+UvfkEATUKvIjvIAH/xCzfsFVw7ygW2SI6NClZzquT+mwdTfgfdbUiceh6iQO0CHtCPsyze/MZ2YbAA==}
engines: {node: '>=6.9.0'}
@@ -375,6 +545,10 @@ packages:
resolution: {integrity: sha512-CbkjYdsJNHFk8uqpEkpCvRs3YRp9tY6FmFY7wLMSYuGYkrdUi7r2lc4/wqsvlHoMznX3WJ9IP8giGPq68T/Y6g==}
engines: {node: '>=6.9.0'}
+ '@babel/helper-string-parser@7.25.9':
+ resolution: {integrity: sha512-4A/SCr/2KLd5jrtOMFzaKjVtAei3+2r/NChoBNoZ3EyP/+GlhoaEGoWOZUmFmoITP7zOJyHIMm+DYRd8o3PvHA==}
+ engines: {node: '>=6.9.0'}
+
'@babel/helper-validator-identifier@7.24.7':
resolution: {integrity: sha512-rR+PBcQ1SMQDDyF6X0wxtG8QyLCgUB0eRAGguqRLfkCA87l7yAP7ehq8SNj96OOGTO8OBV70KhuFYcIkHXOg0w==}
engines: {node: '>=6.9.0'}
@@ -383,6 +557,10 @@ packages:
resolution: {integrity: sha512-AM6TzwYqGChO45oiuPqwL2t20/HdMC1rTPAesnBCgPCSF1x3oN9MVUwQV2iyz4xqWrctwK5RNC8LV22kaQCNYg==}
engines: {node: '>=6.9.0'}
+ '@babel/helper-validator-identifier@7.25.9':
+ resolution: {integrity: sha512-Ed61U6XJc3CVRfkERJWDz4dJwKe7iLmmJsbOGu9wSloNSFttHV0I8g6UAgb7qnK5ly5bGLPd4oXZlxCdANBOWQ==}
+ engines: {node: '>=6.9.0'}
+
'@babel/helper-validator-option@7.24.7':
resolution: {integrity: sha512-yy1/KvjhV/ZCL+SM7hBrvnZJ3ZuT9OuZgIJAGpPEToANvc3iM6iDvBnRjtElWibHU6n8/LPR/EjX9EtIEYO3pw==}
engines: {node: '>=6.9.0'}
@@ -391,6 +569,10 @@ packages:
resolution: {integrity: sha512-ytbPLsm+GjArDYXJ8Ydr1c/KJuutjF2besPNbIZnZ6MKUxi/uTA22t2ymmA4WFjZFpjiAMO0xuuJPqK2nvDVfQ==}
engines: {node: '>=6.9.0'}
+ '@babel/helper-validator-option@7.25.9':
+ resolution: {integrity: sha512-e/zv1co8pp55dNdEcCynfj9X7nyUKUXoUEwfXqaZt0omVOmDe9oOTdKStH4GmAw6zxMFs50ZayuMfHDKlO7Tfw==}
+ engines: {node: '>=6.9.0'}
+
'@babel/helpers@7.24.7':
resolution: {integrity: sha512-NlmJJtvcw72yRJRcnCmGvSi+3jDEg8qFu3z0AFoymmzLx5ERVWyzd9kVXr7Th9/8yIJi2Zc6av4Tqz3wFs8QWg==}
engines: {node: '>=6.9.0'}
@@ -407,6 +589,10 @@ packages:
resolution: {integrity: sha512-iYyACpW3iW8Fw+ZybQK+drQre+ns/tKpXbNESfrhNnPLIklLbXr7MYJ6gPEd0iETGLOK+SxMjVvKb/ffmk+FEw==}
engines: {node: '>=6.9.0'}
+ '@babel/highlight@7.25.9':
+ resolution: {integrity: sha512-llL88JShoCsth8fF8R4SJnIn+WLvR6ccFxu1H3FlMhDontdcmZWf2HgIZ7AIqV3Xcck1idlohrN4EUBQz6klbw==}
+ engines: {node: '>=6.9.0'}
+
'@babel/parser@7.24.7':
resolution: {integrity: sha512-9uUYRm6OqQrCqQdG1iCBwBPZgN8ciDBro2nIOFaiRz1/BCxaI7CNvQbDHvsArAC7Tw9Hda/B3U+6ui9u4HWXPw==}
engines: {node: '>=6.0.0'}
@@ -417,18 +603,47 @@ packages:
engines: {node: '>=6.0.0'}
hasBin: true
+ '@babel/parser@7.25.9':
+ resolution: {integrity: sha512-aI3jjAAO1fh7vY/pBGsn1i9LDbRP43+asrRlkPuTXW5yHXtd1NgTEMudbBoDDxrf1daEEfPJqR+JBMakzrR4Dg==}
+ engines: {node: '>=6.0.0'}
+ hasBin: true
+
+ '@babel/plugin-syntax-decorators@7.25.9':
+ resolution: {integrity: sha512-ryzI0McXUPJnRCvMo4lumIKZUzhYUO/ScI+Mz4YVaTLt04DHNSjEUjKVvbzQjZFLuod/cYEc07mJWhzl6v4DPg==}
+ engines: {node: '>=6.9.0'}
+ peerDependencies:
+ '@babel/core': ^7.0.0-0
+
'@babel/plugin-syntax-jsx@7.25.7':
resolution: {integrity: sha512-ruZOnKO+ajVL/MVx+PwNBPOkrnXTXoWMtte1MBpegfCArhqOe3Bj52avVj1huLLxNKYKXYaSxZ2F+woK1ekXfw==}
engines: {node: '>=6.9.0'}
peerDependencies:
'@babel/core': ^7.0.0-0
+ '@babel/plugin-syntax-jsx@7.25.9':
+ resolution: {integrity: sha512-ld6oezHQMZsZfp6pWtbjaNDF2tiiCYYDqQszHt5VV437lewP9aSi2Of99CK0D0XB21k7FLgnLcmQKyKzynfeAA==}
+ engines: {node: '>=6.9.0'}
+ peerDependencies:
+ '@babel/core': ^7.0.0-0
+
'@babel/plugin-syntax-typescript@7.25.7':
resolution: {integrity: sha512-rR+5FDjpCHqqZN2bzZm18bVYGaejGq5ZkpVCJLXor/+zlSrSoc4KWcHI0URVWjl/68Dyr1uwZUz/1njycEAv9g==}
engines: {node: '>=6.9.0'}
peerDependencies:
'@babel/core': ^7.0.0-0
+ '@babel/plugin-syntax-typescript@7.25.9':
+ resolution: {integrity: sha512-hjMgRy5hb8uJJjUcdWunWVcoi9bGpJp8p5Ol1229PoN6aytsLwNMgmdftO23wnCLMfVmTwZDWMPNq/D1SY60JQ==}
+ engines: {node: '>=6.9.0'}
+ peerDependencies:
+ '@babel/core': ^7.0.0-0
+
+ '@babel/plugin-transform-modules-commonjs@7.25.9':
+ resolution: {integrity: sha512-dwh2Ol1jWwL2MgkCzUSOvfmKElqQcuswAZypBSUsScMXvgdT8Ekq5YA6TtqpTVWH+4903NmboMuH1o9i8Rxlyg==}
+ engines: {node: '>=6.9.0'}
+ peerDependencies:
+ '@babel/core': ^7.0.0-0
+
'@babel/plugin-transform-react-jsx-self@7.24.7':
resolution: {integrity: sha512-fOPQYbGSgH0HUp4UJO4sMBFjY6DuWq+2i8rixyUMb3CdGixs/gccURvYOAhajBdKDoGajFr3mUq5rH3phtkGzw==}
engines: {node: '>=6.9.0'}
@@ -447,6 +662,18 @@ packages:
peerDependencies:
'@babel/core': ^7.0.0-0
+ '@babel/plugin-transform-typescript@7.25.9':
+ resolution: {integrity: sha512-7PbZQZP50tzv2KGGnhh82GSyMB01yKY9scIjf1a+GfZCtInOWqUH5+1EBU4t9fyR5Oykkkc9vFTs4OHrhHXljQ==}
+ engines: {node: '>=6.9.0'}
+ peerDependencies:
+ '@babel/core': ^7.0.0-0
+
+ '@babel/preset-typescript@7.25.9':
+ resolution: {integrity: sha512-XWxw1AcKk36kgxf4C//fl0ikjLeqGUWn062/Fd8GtpTfDJOX6Ud95FK+4JlDA36BX4bNGndXi3a6Vr4Jo5/61A==}
+ engines: {node: '>=6.9.0'}
+ peerDependencies:
+ '@babel/core': ^7.0.0-0
+
'@babel/runtime@7.25.7':
resolution: {integrity: sha512-FjoyLe754PMiYsFaN5C94ttGiOmBNYTf6pLr4xXHAT5uctHb092PBszndLDR5XA/jghQvn4n7JMHl7dmTgbm9w==}
engines: {node: '>=6.9.0'}
@@ -459,6 +686,10 @@ packages:
resolution: {integrity: sha512-wRwtAgI3bAS+JGU2upWNL9lSlDcRCqD05BZ1n3X2ONLH1WilFP6O1otQjeMK/1g0pvYcXC7b/qVUB1keofjtZA==}
engines: {node: '>=6.9.0'}
+ '@babel/template@7.25.9':
+ resolution: {integrity: sha512-9DGttpmPvIxBb/2uwpVo3dqJ+O6RooAFOS+lB+xDqoE2PVCE8nfoHMdZLpfCQRLwvohzXISPZcgxt80xLfsuwg==}
+ engines: {node: '>=6.9.0'}
+
'@babel/traverse@7.24.7':
resolution: {integrity: sha512-yb65Ed5S/QAcewNPh0nZczy9JdYXkkAbIsEo+P7BE7yO3txAY30Y/oPa3QkQ5It3xVG2kpKMg9MsdxZaO31uKA==}
engines: {node: '>=6.9.0'}
@@ -467,6 +698,10 @@ packages:
resolution: {integrity: sha512-jatJPT1Zjqvh/1FyJs6qAHL+Dzb7sTb+xr7Q+gM1b+1oBsMsQQ4FkVKb6dFlJvLlVssqkRzV05Jzervt9yhnzg==}
engines: {node: '>=6.9.0'}
+ '@babel/traverse@7.25.9':
+ resolution: {integrity: sha512-ZCuvfwOwlz/bawvAuvcj8rrithP2/N55Tzz342AkTvq4qaWbGfmCk/tKhNaV2cthijKrPAA8SRJV5WWe7IBMJw==}
+ engines: {node: '>=6.9.0'}
+
'@babel/types@7.24.7':
resolution: {integrity: sha512-XEFXSlxiG5td2EJRe8vOmRbaXVgfcBlszKujvVmWIK/UpywWljQCfzAv3RQCGujWQ1RD4YYWEAqDXfuJiy8f5Q==}
engines: {node: '>=6.9.0'}
@@ -475,6 +710,10 @@ packages:
resolution: {integrity: sha512-vwIVdXG+j+FOpkwqHRcBgHLYNL7XMkufrlaFvL9o6Ai9sJn9+PdyIL5qa0XzTZw084c+u9LOls53eoZWP/W5WQ==}
engines: {node: '>=6.9.0'}
+ '@babel/types@7.25.9':
+ resolution: {integrity: sha512-OwS2CM5KocvQ/k7dFJa8i5bNGJP0hXWfVCfDkqRFP1IreH1JDC7wG6eCYCi0+McbfT8OR/kNqsI0UU0xP9H6PQ==}
+ engines: {node: '>=6.9.0'}
+
'@bcoe/v8-coverage@0.2.3':
resolution: {integrity: sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==}
@@ -1050,6 +1289,7 @@ packages:
'@faker-js/faker@5.5.3':
resolution: {integrity: sha512-R11tGE6yIFwqpaIqcfkcg7AICXzFg14+5h5v0TfF/9+RMDL6jhzCy/pxHVOfbALGdtVYdt6JdR21tuxEgl34dw==}
+ deprecated: Please update to a newer version.
'@faker-js/faker@6.3.1':
resolution: {integrity: sha512-8YXBE2ZcU/pImVOHX7MWrSR/X5up7t6rPWZlk34RwZEcdr3ua6X+32pSd6XuOQRN+vbuvYNfA6iey8NbrjuMFQ==}
@@ -1289,6 +1529,18 @@ packages:
resolution: {integrity: sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==}
engines: {node: '>= 8'}
+ '@npmcli/git@4.1.0':
+ resolution: {integrity: sha512-9hwoB3gStVfa0N31ymBmrX+GuDGdVA/QWShZVqE0HK2Af+7QGGrCTbZia/SW0ImUTjTne7SP91qxDmtXvDHRPQ==}
+ engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0}
+
+ '@npmcli/package-json@4.0.1':
+ resolution: {integrity: sha512-lRCEGdHZomFsURroh522YvA/2cVb9oPIJrjHanCJZkiasz1BzcnLr3tBJhlV7S86MBJBuAQ33is2D60YitZL2Q==}
+ engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0}
+
+ '@npmcli/promise-spawn@6.0.2':
+ resolution: {integrity: sha512-gGq0NJkIGSwdbUt4yhdF8ZrmkGKVz9vAdVzpOfnom+V8PLSmSOVhZwbNvZZS1EYcJN5hzzKBxmmVVAInM6HQLg==}
+ engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0}
+
'@oslojs/encoding@1.1.0':
resolution: {integrity: sha512-70wQhgYmndg4GCPxPPxPGevRKqTIJ2Nh4OkiMWmDAVYsTQ+Ta7Sq+rPevXyXGdzr30/qZBnyOalCszoMxlyldQ==}
@@ -1324,6 +1576,66 @@ packages:
resolution: {integrity: sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==}
engines: {node: '>=14'}
+ '@react-router/dev@7.0.0-pre.1':
+ resolution: {integrity: sha512-Nlp6YXuC2DSMJ7ZgfT/OBwRGlHvieO27WB+SrlL6ipqbi/Ut23UOQ3pn5+y2SS3h1+N6Y+uIOFlnEg8k9adT1g==}
+ engines: {node: '>=18.0.0'}
+ hasBin: true
+ peerDependencies:
+ '@react-router/serve': ^7.0.0-pre.1
+ react-router: ^7.0.0-pre.1
+ typescript: ^5.1.0
+ vite: ^5.1.0
+ wrangler: ^3.28.2
+ peerDependenciesMeta:
+ '@react-router/serve':
+ optional: true
+ typescript:
+ optional: true
+ wrangler:
+ optional: true
+
+ '@react-router/express@7.0.0-pre.1':
+ resolution: {integrity: sha512-24JCslUiirvBckOfRlZmJzr//xFUU2o585Aszf19Dpnga3s+2xCihNbAVIfyZ7kY/AVsJNIuJDo/oJX/STaY6w==}
+ engines: {node: '>=18.0.0'}
+ peerDependencies:
+ express: ^4.17.1
+ react-router: 7.0.0-pre.1
+ typescript: ^5.1.0
+ peerDependenciesMeta:
+ typescript:
+ optional: true
+
+ '@react-router/fs-routes@7.0.0-pre.1':
+ resolution: {integrity: sha512-MQu2egp+5l5lPliWB33wLN/rZ4TMWCIPvbVjI1sdpy3NYhPan1/RDGAUAdIX5MddhLZm5DKQaxlKSxpiQutCug==}
+ engines: {node: '>=18.0.0'}
+ peerDependencies:
+ '@react-router/dev': ^7.0.0-pre.1
+ typescript: ^5.1.0
+ peerDependenciesMeta:
+ typescript:
+ optional: true
+
+ '@react-router/node@7.0.0-pre.1':
+ resolution: {integrity: sha512-592GlQxAUcMSzyzeC28dvmLHJgq4uk2uGB9Lzouj9M7uINuFOdBMP/k+bjRD9m281fEB/TBpKsTVfrpnat//Ug==}
+ engines: {node: '>=18.0.0'}
+ peerDependencies:
+ react-router: 7.0.0-pre.1
+ typescript: ^5.1.0
+ peerDependenciesMeta:
+ typescript:
+ optional: true
+
+ '@react-router/serve@7.0.0-pre.1':
+ resolution: {integrity: sha512-WVfYNighCdg0SluI/WaUL1Fg5bvU5pGElLZlXE0jtwpb7NyuRNBl+h8exWbi4odzzfsipUMYGJEwPiX5FGiczw==}
+ engines: {node: '>=18.0.0'}
+ hasBin: true
+ peerDependencies:
+ react-router: 7.0.0-pre.1
+
+ '@remix-run/router@1.20.0':
+ resolution: {integrity: sha512-mUnk8rPJBI9loFDZ+YzPGdeniYK+FTmRD1TMCz7ev2SNIozyKKpnGgsxO34u6Z4z/t0ITuu7voi/AshfsGsgFg==}
+ engines: {node: '>=14.0.0'}
+
'@rollup/pluginutils@5.1.2':
resolution: {integrity: sha512-/FIdS3PyZ39bjZlwqFnWqCOVnW7o963LtKMwQOD0NhQqw22gSr2YY1afu3FxRip4ZCZNsD5jq6Aaz6QV3D/Njw==}
engines: {node: '>=14.0.0'}
@@ -1824,6 +2136,9 @@ packages:
'@vscode/l10n@0.0.18':
resolution: {integrity: sha512-KYSIHVmslkaCDyw013pphY+d7x1qV8IZupYfeIfzNA+nsaWHbn5uPuQRvdRFsa9zFzGeudPuoGoZ1Op4jrJXIQ==}
+ '@web3-storage/multipart-parser@1.0.0':
+ resolution: {integrity: sha512-BEO6al7BYqcnfX15W2cnGR+Q566ACXAT9UQykORCWW80lmkpWsnEob6zJS1ZVBKsSJC8+7vJkHwlp+lXG1UCdw==}
+
abstract-logging@2.0.1:
resolution: {integrity: sha512-2BjRTZxTPvheOvGbBslFSYOUkr+SjPtOnrLP33f+VIWLzezQpZcqVg7ja3L4dBXmzzgwT+a029jRx5PCi3JuiA==}
@@ -1919,6 +2234,9 @@ packages:
resolution: {integrity: sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg==}
engines: {node: '>= 0.4'}
+ array-flatten@1.1.1:
+ resolution: {integrity: sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==}
+
array-iterate@2.0.1:
resolution: {integrity: sha512-I1jXZMjAgCMmxT4qxXfPXa6SthSoE8h6gkSI9BGGNv8mP8G/v0blc+qFnZu6K42vTOiuME596QaLO0TP3Lk0xg==}
@@ -1994,6 +2312,10 @@ packages:
base64-js@1.5.1:
resolution: {integrity: sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==}
+ basic-auth@2.0.1:
+ resolution: {integrity: sha512-NF+epuEdnUYVlGuhaxbbq+dvJttwLnGY+YixlXlME5KpQ5W3CnXA5cVTneY3SPbPDRkcjMbifrwmFYcClgOZeg==}
+ engines: {node: '>= 0.8'}
+
bcp-47-match@2.0.3:
resolution: {integrity: sha512-JtTezzbAibu8G0R9op9zb3vcWZd9JF6M0xOYGPn0fNCd7wOpRB1mU2mH9T8gaBGbAAyIIVgB2G7xG0GP98zMAQ==}
@@ -2010,6 +2332,10 @@ packages:
bluebird@3.7.2:
resolution: {integrity: sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==}
+ body-parser@1.20.3:
+ resolution: {integrity: sha512-7rAxByjUMqQ3/bHJy7D6OGXvx/MMc4IqBn/X0fcM1QUcAItpZrBEYhWGem+tzXH90c+G01ypMcYJBO9Y30203g==}
+ engines: {node: '>= 0.8', npm: 1.2.8000 || >= 1.4.16}
+
boolbase@1.0.0:
resolution: {integrity: sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==}
@@ -2027,6 +2353,9 @@ packages:
resolution: {integrity: sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==}
engines: {node: '>=8'}
+ browserify-zlib@0.1.4:
+ resolution: {integrity: sha512-19OEpq7vWgsH6WkvkBJQDFvJS1uPcbFOQ4v9CU839dO+ZZXUZO6XpE6hNCqvlIIj+4fZvRiJ6DsAQ382GwiyTQ==}
+
browserslist@4.23.1:
resolution: {integrity: sha512-TUfofFo/KsK/bWZ9TWQ5O26tsWW4Uhmt8IYklbnUa70udB6P2wA7w7o4PY4muaEPBQaAX+CEnmmIA41NVHtPVw==}
engines: {node: ^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7}
@@ -2047,6 +2376,14 @@ packages:
resolution: {integrity: sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA==}
engines: {node: '>=10.16.0'}
+ bytes@3.0.0:
+ resolution: {integrity: sha512-pMhOfFDPiv9t5jjIXkHosWmkSyQbvsgEVNkz0ERHbuLh2T/7j4Mqqpz523Fe8MVY89KC6Sh/QfS2sM+SjgFDcw==}
+ engines: {node: '>= 0.8'}
+
+ bytes@3.1.2:
+ resolution: {integrity: sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==}
+ engines: {node: '>= 0.8'}
+
c12@2.0.1:
resolution: {integrity: sha512-Z4JgsKXHG37C6PYUtIxCfLJZvo6FyhHJoClwwb9ftUkLpPSkuYqn6Tr+vnaN8hymm0kIbcg6Ey3kv/Q71k5w/A==}
peerDependencies:
@@ -2216,6 +2553,14 @@ packages:
common-ancestor-path@1.0.1:
resolution: {integrity: sha512-L3sHRo1pXXEqX8VU28kfgUY+YGsk09hPqZiZmLacNib6XNTCM8ubYeT7ryXQw8asB1sKgcU5lkB7ONug08aB8w==}
+ compressible@2.0.18:
+ resolution: {integrity: sha512-AF3r7P5dWxL8MxyITRMlORQNaOA2IkAFaTr4k7BUumjPtRpGDTZpl0Pb1XCO6JeDCBdp126Cgs9sMxqSjgYyRg==}
+ engines: {node: '>= 0.6'}
+
+ compression@1.7.4:
+ resolution: {integrity: sha512-jaSIDzP9pZVS4ZfQ+TzvtiWhdpFhE2RDHz8QJkpX9SIpLq88VueF5jJw6t+6CUQcAoA6t+x89MLrWAqpfDE8iQ==}
+ engines: {node: '>= 0.8.0'}
+
compute-gcd@1.2.1:
resolution: {integrity: sha512-TwMbxBNz0l71+8Sc4czv13h4kEqnchV9igQZBi6QUaz09dnz13juGnnaWWJTRsP3brxOoxeB4SA2WELLw1hCtg==}
@@ -2232,6 +2577,10 @@ packages:
resolution: {integrity: sha512-I5qxpzLv+sJhTVEoLYNcTW+bThDCPsit0vLNKShZx6rLtpilNpmmeTPaeqJb9ZE9dV3DGaeby6Vuhrw38WjeyQ==}
engines: {node: ^14.18.0 || >=16.10.0}
+ content-disposition@0.5.4:
+ resolution: {integrity: sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==}
+ engines: {node: '>= 0.6'}
+
content-type@1.0.5:
resolution: {integrity: sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==}
engines: {node: '>= 0.6'}
@@ -2239,10 +2588,24 @@ packages:
convert-source-map@2.0.0:
resolution: {integrity: sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==}
+ cookie-signature@1.0.6:
+ resolution: {integrity: sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==}
+
+ cookie@0.6.0:
+ resolution: {integrity: sha512-U71cyTamuh1CRNCfpGY6to28lxvNwPG4Guz/EVjgf3Jmzv0vlDp1atT9eS5dDjMYHucpHbWns6Lwf3BKz6svdw==}
+ engines: {node: '>= 0.6'}
+
+ cookie@0.7.1:
+ resolution: {integrity: sha512-6DnInpx7SJ2AK3+CTUE/ZM0vWTUboZCegxhC2xiIydHR9jNuTAASBrfEpHhiGOZw/nX51bHt6YQl8jsGo4y/0w==}
+ engines: {node: '>= 0.6'}
+
cookie@0.7.2:
resolution: {integrity: sha512-yki5XnKuf750l50uGTllt6kKILY4nQ1eNIQatoXEByZ5dWgnKqbnqmTrBE5B4N7lrMJKQ2ytWMiTO2o0v6Ew/w==}
engines: {node: '>= 0.6'}
+ core-util-is@1.0.3:
+ resolution: {integrity: sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==}
+
create-require@1.1.1:
resolution: {integrity: sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==}
@@ -2280,6 +2643,14 @@ packages:
resolution: {integrity: sha512-t/Ygsytq+R995EJ5PZlD4Cu56sWa8InXySaViRzw9apusqsOO2bQP+SbYzAhR0pFKoB+43lYy8rWban9JSuXnA==}
engines: {node: '>= 0.4'}
+ debug@2.6.9:
+ resolution: {integrity: sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==}
+ peerDependencies:
+ supports-color: '*'
+ peerDependenciesMeta:
+ supports-color:
+ optional: true
+
debug@4.3.5:
resolution: {integrity: sha512-pt0bNEmneDIvdL1Xsd9oDQ/wrQRkXDT4AUWlNZNPKvW5x/jyO9VFXkJUP07vQ2upmw5PlaITaPKc31jK13V+jg==}
engines: {node: '>=6.0'}
@@ -2305,6 +2676,14 @@ packages:
resolution: {integrity: sha512-aW35yZM6Bb/4oJlZncMH2LCoZtJXTRxES17vE3hoRiowU2kWHaJKFkSBDnDR+cm9J+9QhXmREyIfv0pji9ejCQ==}
engines: {node: '>=10'}
+ dedent@1.5.3:
+ resolution: {integrity: sha512-NHQtfOOW68WD8lgypbLA5oT+Bt0xXJhiYvoR6SmmNXZfpzOGXwdKWmcwG8N7PwVVWV3eF/68nmD9BaJSsTBhyQ==}
+ peerDependencies:
+ babel-plugin-macros: ^3.1.0
+ peerDependenciesMeta:
+ babel-plugin-macros:
+ optional: true
+
deep-eql@4.1.4:
resolution: {integrity: sha512-SUwdGfqdKOwxCPeVYjwSyRpJ7Z+fhpwIAtmCUdZIWZ/YP5R9WAsyuSgpLVDi9bjWoN2LXHNss/dk3urXtdQxGg==}
engines: {node: '>=6'}
@@ -2328,6 +2707,10 @@ packages:
resolution: {integrity: sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==}
engines: {node: '>=0.4.0'}
+ depd@2.0.0:
+ resolution: {integrity: sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==}
+ engines: {node: '>= 0.8'}
+
dequal@2.0.3:
resolution: {integrity: sha512-0je+qPKHEMohvfRTCEo3CrPG6cAzAYgmzKyxRiYSSDkS6eGJdyVJm7WaYA5ECaAD9wLB2T4EEeymA5aFVcYXCA==}
engines: {node: '>=6'}
@@ -2335,6 +2718,10 @@ packages:
destr@2.0.3:
resolution: {integrity: sha512-2N3BOUU4gYMpTP24s5rF5iP7BDr7uNTCs4ozw3kf/eKfvWSIu93GEBi5m427YoyJoeOzQ5smuu4nNAPGb8idSQ==}
+ destroy@1.2.0:
+ resolution: {integrity: sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==}
+ engines: {node: '>= 0.8', npm: 1.2.8000 || >= 1.4.16}
+
detect-libc@2.0.3:
resolution: {integrity: sha512-bwy0MGW55bG41VqxxypOsdSdGqLwXPI/focwgTYCFMbdUiBAxLg9CFzG08sz2aqzknwiX7Hkl0bQENjg8iLByw==}
engines: {node: '>=8'}
@@ -2379,9 +2766,15 @@ packages:
resolution: {integrity: sha512-2QF/g9/zTaPDc3BjNcVTGoBbXBgYfMTTceLaYcFJ/W9kggFUkhxD/hMEeuLKbugyef9SqAx8cpgwlIP/jinUTA==}
engines: {node: '>=4'}
+ duplexify@3.7.1:
+ resolution: {integrity: sha512-07z8uv2wMyS51kKhD1KsdXJg5WQ6t93RneqRxUHnskXVtlYYkLqM0gqStQZ3pj073g687jPCHrqNfCzawLYh5g==}
+
eastasianwidth@0.2.0:
resolution: {integrity: sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==}
+ ee-first@1.1.1:
+ resolution: {integrity: sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==}
+
electron-to-chromium@1.4.799:
resolution: {integrity: sha512-3D3DwWkRTzrdEpntY0hMLYwj7SeBk1138CkPE8sBDSj3WzrzOiG2rHm3luw8jucpf+WiyLBCZyU9lMHyQI9M9Q==}
@@ -2400,6 +2793,14 @@ packages:
emoji-regex@9.2.2:
resolution: {integrity: sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==}
+ encodeurl@1.0.2:
+ resolution: {integrity: sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==}
+ engines: {node: '>= 0.8'}
+
+ encodeurl@2.0.0:
+ resolution: {integrity: sha512-Q0n9HRi4m6JuGIV1eFlmvJB7ZEVxu93IrMyiMsGC0lrMJMWzRgx6WGquyfQgZVb31vhGgXnfmPNNXmxnOkRBrg==}
+ engines: {node: '>= 0.8'}
+
end-of-stream@1.4.4:
resolution: {integrity: sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==}
@@ -2407,6 +2808,9 @@ packages:
resolution: {integrity: sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==}
engines: {node: '>=0.12'}
+ err-code@2.0.3:
+ resolution: {integrity: sha512-2bmlRpNKBxT/CRmPOlyISQpNj+qSeYvcym/uT0Jx2bMOlKLtSy1ZmLuVxSEKKyor/N5yhvp/ZiG1oE3DEYMSFA==}
+
error-ex@1.3.2:
resolution: {integrity: sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==}
@@ -2460,6 +2864,9 @@ packages:
resolution: {integrity: sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==}
engines: {node: '>=6'}
+ escape-html@1.0.3:
+ resolution: {integrity: sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==}
+
escape-string-regexp@1.0.5:
resolution: {integrity: sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==}
engines: {node: '>=0.8.0'}
@@ -2494,6 +2901,10 @@ packages:
estree-walker@3.0.3:
resolution: {integrity: sha512-7RUKfXgSMMkzt6ZuXmqapOurLGPPfgj6l9uRZ7lRGolvk0y2yocc35LdcxKC5PQZdn2DMqioAQ2NoWcrTKmm6g==}
+ etag@1.8.1:
+ resolution: {integrity: sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==}
+ engines: {node: '>= 0.6'}
+
eventemitter3@5.0.1:
resolution: {integrity: sha512-GWkBvjiSZK87ELrYOSESUYeVIc9mvLLf/nXalMOS5dYrgZq9o5OVkbZAVM06CVxYsCwH9BDZFPlQTlPA1j4ahA==}
@@ -2501,10 +2912,18 @@ packages:
resolution: {integrity: sha512-VyhnebXciFV2DESc+p6B+y0LjSm0krU4OgJN44qFAhBY0TJ+1V61tYD2+wHusZ6F9n5K+vl8k0sTy7PEfV4qpg==}
engines: {node: '>=16.17'}
+ exit-hook@2.2.1:
+ resolution: {integrity: sha512-eNTPlAD67BmP31LDINZ3U7HSF8l57TxOY2PmBJ1shpCvpnxBF93mWCE8YHBnXs8qiUZJc9WDcWIeC3a2HIAMfw==}
+ engines: {node: '>=6'}
+
expand-template@2.0.3:
resolution: {integrity: sha512-XYfuKMvj4O35f/pOXLObndIRvyQ+/+6AhODh+OKWj9S9498pHHn/IMszH+gt0fBCRWMNfk1ZSp5x3AifmnI2vg==}
engines: {node: '>=6'}
+ express@4.21.1:
+ resolution: {integrity: sha512-YSFlK1Ee0/GC8QaO91tHcDxJiE/X4FbpAyQWkxAvG6AXCuR65YzK8ua6D9hvi/TzUfZMpc+BwuM1IPw8fmQBiQ==}
+ engines: {node: '>= 0.10.0'}
+
expressive-code@0.35.6:
resolution: {integrity: sha512-+mx+TPTbMqgo0mL92Xh9QgjW0kSQIsEivMgEcOnaqKqL7qCw8Vkqc5Rg/di7ZYw4aMUSr74VTc+w8GQWu05j1g==}
@@ -2554,6 +2973,10 @@ packages:
resolution: {integrity: sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==}
engines: {node: '>=8'}
+ finalhandler@1.3.1:
+ resolution: {integrity: sha512-6BN9trH7bp3qvnrRyzsBz+g3lZxTNZTbVO2EV1CS0WIcDbawYVdYvGflME/9QP0h0pYlCDBCTjYa9nZzMDpyxQ==}
+ engines: {node: '>= 0.8'}
+
find-up-simple@1.0.0:
resolution: {integrity: sha512-q7Us7kcjj2VMePAa02hDAF6d+MzsdsAWEwYyOpwUtlerRBkOEPBCRZrAV4XfcSN8fHAgaD0hP7miwoay6DCprw==}
engines: {node: '>=18'}
@@ -2605,12 +3028,24 @@ packages:
format-util@1.0.5:
resolution: {integrity: sha512-varLbTj0e0yVyRpqQhuWV+8hlePAgaoFRhNFj50BNjEIrw1/DphHSObtqwskVCPWNgzwPoQrZAbfa/SBiicNeg==}
+ forwarded@0.2.0:
+ resolution: {integrity: sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==}
+ engines: {node: '>= 0.6'}
+
fp-ts@2.16.6:
resolution: {integrity: sha512-v7w209VPj4L6pPn/ftFRJu31Oa8QagwcVw7BZmLCUWU4AQoc954rX9ogSIahDf67Pg+GjPbkW/Kn9XWnlWJG0g==}
+ fresh@0.5.2:
+ resolution: {integrity: sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==}
+ engines: {node: '>= 0.6'}
+
fs-constants@1.0.0:
resolution: {integrity: sha512-y6OAwoSIf7FyjMIv94u+b5rdheZEjzR63GTyZJm5qh4Bi+2YgwLCcI/fPFZkL5PSixOt6ZNKm+w+Hfp/Bciwow==}
+ fs-extra@10.1.0:
+ resolution: {integrity: sha512-oRXApq54ETRj4eMiFzGnHWGy+zo5raudjuxN0b8H7s/RU2oW0Wvsx9O0ACRN/kRq9E8Vu/ReskGB5o3ji+FzHQ==}
+ engines: {node: '>=12'}
+
fs-minipass@2.1.0:
resolution: {integrity: sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg==}
engines: {node: '>= 8'}
@@ -2652,6 +3087,10 @@ packages:
resolution: {integrity: sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==}
engines: {node: '>= 0.4'}
+ get-port@5.1.1:
+ resolution: {integrity: sha512-g/Q1aTSDOxFpchXC4i8ZWvxA1lnPqx/JHqcpIw0/LX9T8x/GBbi6YnlN5nhaKIFkT8oFsscUKgDJYxfwfS6QsQ==}
+ engines: {node: '>=8'}
+
get-stream@8.0.1:
resolution: {integrity: sha512-VaUJspBffn/LMCJVoMvSAdmscJyS1auj5Zulnn5UoYcY531UWmdwhRWkcGKnGU93m5HSXP9LP2usOryrBtQowA==}
engines: {node: '>=16'}
@@ -2713,6 +3152,10 @@ packages:
resolution: {integrity: sha512-5v6yZd4JK3eMI3FqqCouswVqwugaA9r4dNZB1wwcmrD02QkV5H0y7XBQW8QwQqEaZY1pM9aqORSORhJRdNK44Q==}
engines: {node: '>=6.0'}
+ gunzip-maybe@1.4.2:
+ resolution: {integrity: sha512-4haO1M4mLO91PW57BMsDFf75UmwoRX0GkdD+Faw+Lr+r/OZrOCS0pIBwOL1xCKQqnQzbNFGgK2V2CpBUPeFNTw==}
+ hasBin: true
+
handlebars@4.7.8:
resolution: {integrity: sha512-vafaFqs8MZkRrSX7sFVUdo3ap/eNiLnb4IakshzvP56X5Nr1iGKAIqdX6tMlm6HcNRIkr6AxO5jFEoJzzpT8aQ==}
engines: {node: '>=0.4.7'}
@@ -2817,6 +3260,10 @@ packages:
hosted-git-info@2.8.9:
resolution: {integrity: sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==}
+ hosted-git-info@6.1.1:
+ resolution: {integrity: sha512-r0EI+HBMcXadMrugk0GCQ+6BQV39PiWAZVfq7oIckeGiN7sjRGyQxPdft3nQekFTCQbYxLBH+/axZMeH8UX6+w==}
+ engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0}
+
html-escaper@2.0.2:
resolution: {integrity: sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==}
@@ -2832,6 +3279,10 @@ packages:
http-cache-semantics@4.1.1:
resolution: {integrity: sha512-er295DKPVsV82j5kw1Gjt+ADA/XYHsajl82cGNQG2eyoPkvgUhX+nDIyelzhIWbbsXP39EHcI6l5tYs2FYqYXQ==}
+ http-errors@2.0.0:
+ resolution: {integrity: sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==}
+ engines: {node: '>= 0.8'}
+
http-proxy-agent@5.0.0:
resolution: {integrity: sha512-n2hY8YdoRE1i7r6M0w9DIw5GgZN0G25P8zLCRQ8rjXtTU3vsNFBI/vWK/UIeE6g5MUUz6avwAPXmL6Fy9D/90w==}
engines: {node: '>= 6'}
@@ -2850,6 +3301,10 @@ packages:
i18next@23.15.2:
resolution: {integrity: sha512-zcPSWzCvw6uKnuYHIqs4W7hTuB9e3AFcSdZgvCWoPXIZsBjBd4djN2/2uOHIB+1DFFkQnMBXvhNg7J3WyCuywQ==}
+ iconv-lite@0.4.24:
+ resolution: {integrity: sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==}
+ engines: {node: '>=0.10.0'}
+
iconv-lite@0.6.3:
resolution: {integrity: sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==}
engines: {node: '>=0.10.0'}
@@ -2885,6 +3340,10 @@ packages:
peerDependencies:
fp-ts: ^2.5.0
+ ipaddr.js@1.9.1:
+ resolution: {integrity: sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==}
+ engines: {node: '>= 0.10'}
+
is-alphabetical@2.0.1:
resolution: {integrity: sha512-FWyyY60MeTNyeSRpkM2Iry0G9hpr7/9kD40mD/cGQEuilcZYS4okz8SN2Q6rLCJ8gbCt6fN+rC+6tMGS99LaxQ==}
@@ -2930,6 +3389,9 @@ packages:
is-decimal@2.0.1:
resolution: {integrity: sha512-AAB9hiomQs5DXWcRB1rqsxGUstbRroFOPPVAomNk/3XHR5JyEZChOyTWe2oayKnsSsr/kcGqF+z6yuH6HHpN0A==}
+ is-deflate@1.0.0:
+ resolution: {integrity: sha512-YDoFpuZWu1VRXlsnlYMzKyVRITXj7Ej/V9gXQ2/pAe7X1J7M/RNOqaIYi6qUn+B7nGyB9pDXrv02dsB58d2ZAQ==}
+
is-docker@3.0.0:
resolution: {integrity: sha512-eljcgEDlEns/7AXFosB5K/2nCM4P7FQPkGc/DWLy5rmFEWvZayGrik1d9/QIY5nJ4f9YsVvBkA6kJpHn9rISdQ==}
engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0}
@@ -2951,6 +3413,10 @@ packages:
resolution: {integrity: sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==}
engines: {node: '>=0.10.0'}
+ is-gzip@1.0.0:
+ resolution: {integrity: sha512-rcfALRIb1YewtnksfRIHGcIY93QnK8BIQ/2c9yDYcG/Y6+vRoJuTWBmmSEbyLLYtXm7q35pHOHbZFQBaLrhlWQ==}
+ engines: {node: '>=0.10.0'}
+
is-hexadecimal@2.0.1:
resolution: {integrity: sha512-DgZQp241c8oO6cA1SbTEWiXeoxV42vlcJxgH+B3hi1AiqqKruZR3ZGF8In3fj4+/y/7rHvlOZLZtgJ/4ttYGZg==}
@@ -3021,9 +3487,16 @@ packages:
resolution: {integrity: sha512-UcVfVfaK4Sc4m7X3dUSoHoozQGBEFeDC+zVo06t98xe8CzHSZZBekNXH+tu0NalHolcJ/QAGqS46Hef7QXBIMw==}
engines: {node: '>=16'}
+ isarray@1.0.0:
+ resolution: {integrity: sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==}
+
isarray@2.0.5:
resolution: {integrity: sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==}
+ isbot@5.1.17:
+ resolution: {integrity: sha512-/wch8pRKZE+aoVhRX/hYPY1C7dMCeeMyhkQLNLNlYAbGQn9bkvMB8fOUXNnk5I0m4vDYbBJ9ciVtkr9zfBJ7qA==}
+ engines: {node: '>=18'}
+
isexe@2.0.0:
resolution: {integrity: sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==}
@@ -3085,6 +3558,10 @@ packages:
json-parse-better-errors@1.0.2:
resolution: {integrity: sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==}
+ json-parse-even-better-errors@3.0.2:
+ resolution: {integrity: sha512-fi0NG4bPjCHunUJffmLd0gxssIgkNmArMvis4iNah6Owg1MCJjWhEcDLmsK6iGkJq3tHwbDkTlce70/tmXN4cQ==}
+ engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0}
+
json-pointer@0.6.2:
resolution: {integrity: sha512-vLWcKbOaXlO+jvRy4qNd+TI1QUPZzfJj1tpJ3vAXDych5XJf93ftpUKe5pKCrzyIIwgBJcOcCVRUfqQP25afBw==}
@@ -3119,6 +3596,9 @@ packages:
jsonc-parser@3.3.1:
resolution: {integrity: sha512-HUgH65KyejrUFPvHFPbqOY0rsFip3Bo5wb4ngvdi1EpCYWUQDC5V+Y7mZws+DLkr4M//zQJoanu1SP+87Dv1oQ==}
+ jsonfile@6.1.0:
+ resolution: {integrity: sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ==}
+
jsonpath-plus@7.2.0:
resolution: {integrity: sha512-zBfiUPM5nD0YZSBT/o/fbCUlCcepMIdP0CJZxM1+KgA4f2T206f6VAg9e7mX35+KlMaIc5qXW34f3BnwJ3w+RA==}
engines: {node: '>=12.0.0'}
@@ -3245,6 +3725,10 @@ packages:
resolution: {integrity: sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==}
engines: {node: '>=10'}
+ lru-cache@7.18.3:
+ resolution: {integrity: sha512-jumlc0BIUrS3qJGgIkWZsyfAM7NCWiBcCDhnd+3NNM5KbBmLTgHVfWBcg6W+rLUsIpzpERPsvwUP7CckAQSOoA==}
+ engines: {node: '>=12'}
+
magic-string@0.30.10:
resolution: {integrity: sha512-iIRwTIf0QKV3UAnYK4PU8uiEc4SRh5jX0mwpIwETPpHdhVM4f53RSwS/vXvN1JhGX+Cs7B8qIq3d6AH49O5fAQ==}
@@ -3333,6 +3817,9 @@ packages:
resolution: {integrity: sha512-S3UwM3yj5mtUSEfP41UZmt/0SCoVYUcU1rkXv+BQ5Ig8ndL4sPoJNBUJERafdPb5jjHJGuMgytgKvKIf58XNBw==}
engines: {node: '>= 0.10.0'}
+ merge-descriptors@1.0.3:
+ resolution: {integrity: sha512-gaNvAS7TZ897/rVaZ0nMtAyxNyi/pdbjbAwUpFQpN70GqnVfOiXpeUUMKRBmzXaSQ8DdTX4/0ms62r2K+hE6mQ==}
+
merge-stream@2.0.0:
resolution: {integrity: sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==}
@@ -3340,6 +3827,10 @@ packages:
resolution: {integrity: sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==}
engines: {node: '>= 8'}
+ methods@1.1.2:
+ resolution: {integrity: sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==}
+ engines: {node: '>= 0.6'}
+
micri@4.5.1:
resolution: {integrity: sha512-AtvnSBGFglNr+iqs5gufpHT9xRXUabgu9vYEnQYPXSBs+nLSBvmUS5Mzg+3LJ9eQBrNA1o5M49WeqiX1f+d2sg==}
engines: {node: '>= 12.0.0'}
@@ -3471,6 +3962,11 @@ packages:
resolution: {integrity: sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==}
engines: {node: '>= 0.6'}
+ mime@1.6.0:
+ resolution: {integrity: sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==}
+ engines: {node: '>=4'}
+ hasBin: true
+
mimic-fn@4.0.0:
resolution: {integrity: sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw==}
engines: {node: '>=12'}
@@ -3532,10 +4028,17 @@ packages:
mlly@1.7.1:
resolution: {integrity: sha512-rrVRZRELyQzrIUAVMHxP97kv+G786pHmOKzuFII8zDYahFBS7qnHh2AlYSl1GAHhaMPCz6/oHjVMcfFYgFYHgA==}
+ morgan@1.10.0:
+ resolution: {integrity: sha512-AbegBVI4sh6El+1gNwvD5YIck7nSA36weD7xvIxG4in80j/UoK8AEGaWnnz8v1GxonMCltmlNs5ZKbGvl9b1XQ==}
+ engines: {node: '>= 0.8.0'}
+
mrmime@2.0.0:
resolution: {integrity: sha512-eu38+hdgojoyq63s+yTpN4XMBdt5l8HhMhc4VKLO9KM5caLIBvUm4thi7fFaxyTmCKeNnXZ5pAlBwCUnhA09uw==}
engines: {node: '>=10'}
+ ms@2.0.0:
+ resolution: {integrity: sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==}
+
ms@2.1.2:
resolution: {integrity: sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==}
@@ -3622,10 +4125,30 @@ packages:
normalize-package-data@2.5.0:
resolution: {integrity: sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==}
+ normalize-package-data@5.0.0:
+ resolution: {integrity: sha512-h9iPVIfrVZ9wVYQnxFgtw1ugSvGEMOlyPWWtm8BMJhnwyEL/FLbYbTY3V3PpjI/BUK67n9PEWDu6eHzu1fB15Q==}
+ engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0}
+
normalize-path@3.0.0:
resolution: {integrity: sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==}
engines: {node: '>=0.10.0'}
+ npm-install-checks@6.3.0:
+ resolution: {integrity: sha512-W29RiK/xtpCGqn6f3ixfRYGk+zRyr+Ew9F2E20BfXxT5/euLdA/Nm7fO7OeTGuAmTs30cpgInyJ0cYe708YTZw==}
+ engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0}
+
+ npm-normalize-package-bin@3.0.1:
+ resolution: {integrity: sha512-dMxCf+zZ+3zeQZXKxmyuCKlIDPGuv8EF940xbkC4kQVDTtqoh6rJFO+JTKSA6/Rwi0getWmtuy4Itup0AMcaDQ==}
+ engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0}
+
+ npm-package-arg@10.1.0:
+ resolution: {integrity: sha512-uFyyCEmgBfZTtrKk/5xDfHp6+MdrqGotX/VoOyEEl3mBwiEE5FlBaePanazJSVMPT7vKepcjYBY2ztg9A3yPIA==}
+ engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0}
+
+ npm-pick-manifest@8.0.2:
+ resolution: {integrity: sha512-1dKY+86/AIiq1tkKVD3l0WI+Gd3vkknVGAggsFeBkTvbhMQ1OND/LKkYv4JtXPKUJ8bOTCyLiqEg2P6QNdK+Gg==}
+ engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0}
+
npm-run-all@4.1.5:
resolution: {integrity: sha512-Oo82gJDAVcaMdi3nuoKFavkIHBRVqQ1qvMb+9LHk/cF4P6B2m8aP04hGf7oL6wZ9BuGwX1onlLhpuoofSyoQDQ==}
engines: {node: '>= 4'}
@@ -3668,6 +4191,18 @@ packages:
ohash@1.1.4:
resolution: {integrity: sha512-FlDryZAahJmEF3VR3w1KogSEdWX3WhA5GPakFx4J81kEAiHyLMpdLLElS8n8dfNadMgAne/MywcvmogzscVt4g==}
+ on-finished@2.3.0:
+ resolution: {integrity: sha512-ikqdkGAAyf/X/gPhXGvfgAytDZtDbr+bkNUJ0N9h5MI/dmdgCs3l6hoHrcUv41sRKew3jIwrp4qQDXiK99Utww==}
+ engines: {node: '>= 0.8'}
+
+ on-finished@2.4.1:
+ resolution: {integrity: sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==}
+ engines: {node: '>= 0.8'}
+
+ on-headers@1.0.2:
+ resolution: {integrity: sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==}
+ engines: {node: '>= 0.8'}
+
once@1.4.0:
resolution: {integrity: sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==}
@@ -3736,6 +4271,9 @@ packages:
resolution: {integrity: sha512-U2YR0dQN5B2fbIXrLtt/UXNS0yWSSYfePaad1KcBPTi0p+zRtsVjwmoPaMQgTks5DnHNbmDxyJUL5TGaLljK3A==}
hasBin: true
+ pako@0.2.9:
+ resolution: {integrity: sha512-NUcwaKxUxWrZLpDG+z/xZaCgQITkA/Dv4V/T6bw7VON6l1Xz/VnrBqrYjZQ12TamKHzITTfOEIYUj48y2KXImA==}
+
parse-entities@4.0.1:
resolution: {integrity: sha512-SWzvYcSJh4d/SGLIOQfZ/CoNv6BTlI6YEQ7Nj82oDVnRpwe/Z/F1EMx42x3JAOwGBlCjeCH0BRJQbQ/opHL17w==}
@@ -3755,6 +4293,10 @@ packages:
parse5@7.2.0:
resolution: {integrity: sha512-ZkDsAOcxsUMZ4Lz5fVciOehNcJ+Gb8gTzcA4yl3wnc273BAybYWrQ+Ks/OjCjSEpjvQkDSeZbybK9qj2VHHdGA==}
+ parseurl@1.3.3:
+ resolution: {integrity: sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==}
+ engines: {node: '>= 0.8'}
+
path-browserify@1.0.1:
resolution: {integrity: sha512-b7uo2UCUOYZcnF/3ID0lulOJi/bafxa1xPe7ZPsammBSpjSWQkjNxlt635YGS2MiR9GjvuXCtz2emr3jbsz98g==}
@@ -3789,6 +4331,9 @@ packages:
resolution: {integrity: sha512-Xa4Nw17FS9ApQFJ9umLiJS4orGjm7ZzwUrwamcGQuHSzDyth9boKDaycYdDcZDuqYATXw4HFXgaqWTctW/v1HA==}
engines: {node: '>=16 || 14 >=14.18'}
+ path-to-regexp@0.1.10:
+ resolution: {integrity: sha512-7lf7qcQidTku0Gu3YDPc8DJ1q7OOucfa/BSsIwjuh56VU7katFvuM8hULfkwB3Fns/rsVF7PwPKVw1sl5KQS9w==}
+
path-type@3.0.0:
resolution: {integrity: sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==}
engines: {node: '>=4'}
@@ -3799,6 +4344,9 @@ packages:
pathval@1.1.1:
resolution: {integrity: sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==}
+ peek-stream@1.1.3:
+ resolution: {integrity: sha512-FhJ+YbOSBb9/rIl2ZeE/QHEsWn7PqNYt8ARAY3kIgNGOk13g9FGyIY6JIl/xB/3TFRVoTv5as0l11weORrTekA==}
+
perfect-debounce@1.0.0:
resolution: {integrity: sha512-xCy9V055GLEqoFaHoC1SoLIaLmWctgCUaBaWxDZ7/Zx4CTyX7cJQLJOok/orfjZAh9kEYpjJa4d0KcJmCbctZA==}
@@ -3948,9 +4496,28 @@ packages:
resolution: {integrity: sha512-Kx/1w86q/epKcmte75LNrEoT+lX8pBpavuAbvJWRXar7Hz8jrtF+e3vY751p0R8H9HdArwaCTNDDzHg/ScJK1Q==}
engines: {node: '>=6'}
+ proc-log@3.0.0:
+ resolution: {integrity: sha512-++Vn7NS4Xf9NacaU9Xq3URUuqZETPsf8L4j5/ckhaRYsfPeRyzGw+iDjFhV/Jr3uNmTvvddEJFWh5R1gRgUH8A==}
+ engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0}
+
+ process-nextick-args@2.0.1:
+ resolution: {integrity: sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==}
+
process-warning@1.0.0:
resolution: {integrity: sha512-du4wfLyj4yCZq1VupnVSZmRsPJsNuxoDQFdCFHLaYiEbFBD7QE0a+I4D7hOxrVnh78QE/YipFAj9lXHiXocV+Q==}
+ promise-inflight@1.0.1:
+ resolution: {integrity: sha512-6zWPyEOFaQBJYcGMHBKTKJ3u6TBsnMFOIZSa6ce1e/ZrrsOlnHRHbabMjLiBYKp+n44X9eUI6VUPaukCXHuG4g==}
+ peerDependencies:
+ bluebird: '*'
+ peerDependenciesMeta:
+ bluebird:
+ optional: true
+
+ promise-retry@2.0.1:
+ resolution: {integrity: sha512-y+WKFlBR8BGXnsNlIHFGPZmyDf3DFMoLhaflAnyZgV6rG6xu+JwesTo2Q9R6XwYmtmwAFCkAk3e35jEdoeh/3g==}
+ engines: {node: '>=10'}
+
prompts@2.4.2:
resolution: {integrity: sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q==}
engines: {node: '>= 6'}
@@ -3958,16 +4525,30 @@ packages:
property-information@6.5.0:
resolution: {integrity: sha512-PgTgs/BlvHxOu8QuEN7wi5A0OmXaBcHpmCSTehcs6Uuu9IkDIEo13Hy7n898RHfrQ49vKCoGeWZSaAK01nwVig==}
+ proxy-addr@2.0.7:
+ resolution: {integrity: sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==}
+ engines: {node: '>= 0.10'}
+
proxy-from-env@1.1.0:
resolution: {integrity: sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==}
+ pump@2.0.1:
+ resolution: {integrity: sha512-ruPMNRkN3MHP1cWJc9OWr+T/xDP0jhXYCLfJcBuX54hhfIBnaQmAUMfDcG4DM5UMWByBbJY69QSphm3jtDKIkA==}
+
pump@3.0.2:
resolution: {integrity: sha512-tUPXtzlGM8FE3P0ZL6DVs/3P58k9nk8/jZeQCurTJylQA8qFYzHFfhBJkuqyE0FifOsQ0uKWekiZ5g8wtr28cw==}
+ pumpify@1.5.1:
+ resolution: {integrity: sha512-oClZI37HvuUJJxSKKrC17bZ9Cu0ZYhEAGPsPUy9KlMUmv9dKX2o77RUmq7f3XjIxbwyGwYzbzQ1L2Ks8sIradQ==}
+
punycode@2.3.1:
resolution: {integrity: sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==}
engines: {node: '>=6'}
+ qs@6.13.0:
+ resolution: {integrity: sha512-+38qI9SOr8tfZ4QmJNplMUxqjbe7LKvvZgWdExBOmd+egZTtjLB67Gu0HRX3u/XOq7UU2Nx6nsjvS16Z9uwfpg==}
+ engines: {node: '>=0.6'}
+
queue-microtask@1.2.3:
resolution: {integrity: sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==}
@@ -3977,6 +4558,14 @@ packages:
quick-format-unescaped@4.0.4:
resolution: {integrity: sha512-tYC1Q1hgyRuHgloV/YXs2w15unPVh8qfu/qCTfhTYamaw7fyhumKa2yGpdSo87vY32rIclj+4fWYQXUMs9EHvg==}
+ range-parser@1.2.1:
+ resolution: {integrity: sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==}
+ engines: {node: '>= 0.6'}
+
+ raw-body@2.5.2:
+ resolution: {integrity: sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA==}
+ engines: {node: '>= 0.8'}
+
rc9@2.1.2:
resolution: {integrity: sha512-btXCnMmRIBINM2LDZoEmOogIZU7Qe7zn4BpomSKZ/ykbLObuBdvG+mFq11DL6fjH1DRwHhrlgtYWG96bJiC7Cg==}
@@ -3996,6 +4585,36 @@ packages:
resolution: {integrity: sha512-jCvmsr+1IUSMUyzOkRcvnVbX3ZYC6g9TDrDbFuFmRDq7PD4yaGbLKNQL6k2jnArV8hjYxh7hVhAZB6s9HDGpZA==}
engines: {node: '>=0.10.0'}
+ react-router-dom@6.27.0:
+ resolution: {integrity: sha512-+bvtFWMC0DgAFrfKXKG9Fc+BcXWRUO1aJIihbB79xaeq0v5UzfvnM5houGUm1Y461WVRcgAQ+Clh5rdb1eCx4g==}
+ engines: {node: '>=14.0.0'}
+ peerDependencies:
+ react: '>=16.8'
+ react-dom: '>=16.8'
+
+ react-router-dom@7.0.0-pre.1:
+ resolution: {integrity: sha512-HurKqnx581SLe0o/KI26X5UhJzQr+cdo6B58+LZORJYwTOlS1iM67jGLJwlfJa/QyDSdKq+1zFMVGdvXwF8Fzw==}
+ engines: {node: '>=18.0.0'}
+ peerDependencies:
+ react: '>=18'
+ react-dom: '>=18'
+
+ react-router@6.27.0:
+ resolution: {integrity: sha512-YA+HGZXz4jaAkVoYBE98VQl+nVzI+cVI2Oj/06F5ZM+0u3TgedN9Y9kmMRo2mnkSK2nCpNQn0DVob4HCsY/WLw==}
+ engines: {node: '>=14.0.0'}
+ peerDependencies:
+ react: '>=16.8'
+
+ react-router@7.0.0-pre.1:
+ resolution: {integrity: sha512-KAopqhQWpZUdIbSVGXBszhvHJjI20XBgYYwD83GL2uXFluKzb1SEw1XY4h3kg0wOT6WpQB7m655MJnk2CIBufQ==}
+ engines: {node: '>=18.0.0'}
+ peerDependencies:
+ react: '>=18'
+ react-dom: '>=18'
+ peerDependenciesMeta:
+ react-dom:
+ optional: true
+
react@18.3.1:
resolution: {integrity: sha512-wS+hAgJShR0KhEvPJArfuPVN1+Hz1t0Y6n5jLrGQbkb4urgPE/0Rve+1kMB1v/oWgHgm4WIcV+i7F2pTVj+2iQ==}
engines: {node: '>=0.10.0'}
@@ -4007,6 +4626,9 @@ packages:
resolution: {integrity: sha512-BLq/cCO9two+lBgiTYNqD6GdtK8s4NpaWrl6/rCO9w0TUS8oJl7cmToOZfRYllKTISY6nt1U7jQ53brmKqY6BA==}
engines: {node: '>=4'}
+ readable-stream@2.3.8:
+ resolution: {integrity: sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==}
+
readable-stream@3.6.2:
resolution: {integrity: sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==}
engines: {node: '>= 6'}
@@ -4106,6 +4728,10 @@ packages:
retext@9.0.0:
resolution: {integrity: sha512-sbMDcpHCNjvlheSgMfEcVrZko3cDzdbe1x/e7G66dFp0Ff7Mldvi2uv6JkJQzdRcvLYE8CA8Oe8siQx8ZOgTcA==}
+ retry@0.12.0:
+ resolution: {integrity: sha512-9LkiTwjUh6rT555DtE9rTX+BKByPfrMzEAtnlEtdEwr3Nkffwiihqe2bWADg+OQRjt9gl6ICdmB/ZFDCGAtSow==}
+ engines: {node: '>= 4'}
+
reusify@1.0.4:
resolution: {integrity: sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==}
engines: {iojs: '>=1.0.0', node: '>=0.10.0'}
@@ -4132,6 +4758,9 @@ packages:
resolution: {integrity: sha512-vj6RsCsWBCf19jIeHEfkRMw8DPiBb+DMXklQ/1SGDHOMlHdPUkZXFQ2YdplS23zESTijAcurb1aSgJA3AgMu1Q==}
engines: {node: '>=0.4'}
+ safe-buffer@5.1.2:
+ resolution: {integrity: sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==}
+
safe-buffer@5.2.1:
resolution: {integrity: sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==}
@@ -4178,6 +4807,17 @@ packages:
engines: {node: '>=10'}
hasBin: true
+ send@0.19.0:
+ resolution: {integrity: sha512-dW41u5VfLXu8SJh5bwRmyYUbAoSB3c9uQh6L8h/KtsFREPWpbX1lrljJo186Jc4nmci/sGUZ9a0a0J2zgfq2hw==}
+ engines: {node: '>= 0.8.0'}
+
+ serve-static@1.16.2:
+ resolution: {integrity: sha512-VqpjJZKadQB/PEbEwvFdO43Ax5dFBZ2UECszz8bQ7pi7wt//PWe1P6MN7eCnjsatYtBT6EuiClbjSWP2WrIoTw==}
+ engines: {node: '>= 0.8.0'}
+
+ set-cookie-parser@2.7.1:
+ resolution: {integrity: sha512-IOc8uWeOZgnb3ptbCURJWNjWUPcO3ZnTTdzsurqERrP6nPyv+paC55vJM0LpOlT2ne+Ix+9+CRG1MNLlyZ4GjQ==}
+
set-function-length@1.2.2:
resolution: {integrity: sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==}
engines: {node: '>= 0.4'}
@@ -4186,6 +4826,9 @@ packages:
resolution: {integrity: sha512-7PGFlmtwsEADb0WYyvCMa1t+yke6daIG4Wirafur5kcf+MhUnPms1UeR0CKQdTZD81yESwMHbtn+TR+dMviakQ==}
engines: {node: '>= 0.4'}
+ setprototypeof@1.2.0:
+ resolution: {integrity: sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==}
+
sharp@0.32.6:
resolution: {integrity: sha512-KyLTWwgcR9Oe4d9HwCwNM2l7+J0dUQwn/yf7S0EnTtb0eVS4RxO0eUSvxPtzT4F3SY+C4K6fqdv/DO27sJ/v/w==}
engines: {node: '>=14.15.0'}
@@ -4294,6 +4937,10 @@ packages:
stackback@0.0.2:
resolution: {integrity: sha512-1XMJE5fQo1jGH6Y/7ebnwPOBEkIEnT4QF32d5R1+VXdXveM0IBMJt8zfaxX1P3QhVwrYe+576+jkANtSS2mBbw==}
+ statuses@2.0.1:
+ resolution: {integrity: sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==}
+ engines: {node: '>= 0.8'}
+
std-env@3.7.0:
resolution: {integrity: sha512-JPbdCEQLj1w5GilpiHAx3qJvFndqybBysA3qUOnznweH4QbNYUsW/ea8QzSrnh0vNsezMMw5bcVool8lM0gwzg==}
@@ -4304,6 +4951,12 @@ packages:
stream-replace-string@2.0.0:
resolution: {integrity: sha512-TlnjJ1C0QrmxRNrON00JvaFFlNh5TTG00APw23j74ET7gkQpTASi6/L2fuiav8pzK715HXtUeClpBTw2NPSn6w==}
+ stream-shift@1.0.3:
+ resolution: {integrity: sha512-76ORR0DO1o1hlKwTbi/DM3EXWGf3ZJYO8cXX5RJwnul2DEg2oyoZyjLNoQM8WsvZiFKCRfC1O0J7iCvie3RZmQ==}
+
+ stream-slice@0.1.2:
+ resolution: {integrity: sha512-QzQxpoacatkreL6jsxnVb7X5R/pGw9OUv2qWTYWnmLpg4NdN31snPy/f3TdQE1ZUXaThRvj1Zw4/OGg0ZkaLMA==}
+
streamsearch@1.1.0:
resolution: {integrity: sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==}
engines: {node: '>=10.0.0'}
@@ -4338,6 +4991,9 @@ packages:
resolution: {integrity: sha512-UXSH262CSZY1tfu3G3Secr6uGLCFVPMhIqHjlgCUtCCcgihYc/xKs9djMTMUOb2j1mVSeU8EU6NWc/iQKU6Gfg==}
engines: {node: '>= 0.4'}
+ string_decoder@1.1.1:
+ resolution: {integrity: sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==}
+
string_decoder@1.3.0:
resolution: {integrity: sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==}
@@ -4451,6 +5107,9 @@ packages:
thenify@3.3.1:
resolution: {integrity: sha512-RVZSIV5IG10Hk3enotrhvz0T9em6cyHBLkH/YAZuKqd8hRkKhSfCGIcP2KUY0EPxndzANBmNllzWPwak+bheSw==}
+ through2@2.0.5:
+ resolution: {integrity: sha512-/mrRod8xqpA+IHSLyGCQ2s8SPHiCDEeQJSep1jqLYeEUClOFG2Qsh+4FU6G9VeqpZnGW/Su8LQGc4YKni5rYSQ==}
+
tiny-invariant@1.3.3:
resolution: {integrity: sha512-+FbBPE1o9QAYvviau/qC5SE3caw21q3xkvWKBtja5vgqOWIHHJ3ioaq1VPfn/Szqctz2bU/oYeKd9/z5BL+PVg==}
@@ -4479,6 +5138,10 @@ packages:
resolution: {integrity: sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==}
engines: {node: '>=8.0'}
+ toidentifier@1.0.1:
+ resolution: {integrity: sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==}
+ engines: {node: '>=0.6'}
+
tr46@0.0.3:
resolution: {integrity: sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==}
@@ -4529,6 +5192,9 @@ packages:
tunnel-agent@0.6.0:
resolution: {integrity: sha512-McnNiV1l8RYeY8tBgEpuodCC1mLUdbSN+CYBL7kJsJNInOP8UjDDEwdk6Mw60vdLLrr5NHKZhMAOSrR2NZuQ+w==}
+ turbo-stream@2.4.0:
+ resolution: {integrity: sha512-FHncC10WpBd2eOmGwpmQsWLDoK4cqsA/UT/GqNoaKOQnT8uzhtCbg3EoUDMvqpOSAI0S26mr0rkjzbOO6S3v1g==}
+
type-detect@4.0.8:
resolution: {integrity: sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==}
engines: {node: '>=4'}
@@ -4595,6 +5261,10 @@ packages:
undici-types@6.19.8:
resolution: {integrity: sha512-ve2KP6f/JnbPBFyobGHuerC9g1FYGn/F8n1LWTwNxCEzd6IfqTwUQcNXgEtmmQ6DlRrC1hrSrBnCZPokRrDHjw==}
+ undici@6.20.1:
+ resolution: {integrity: sha512-AjQF1QsmqfJys+LXfGTNum+qw4S88CojRInG/6t31W/1fk6G59s92bnAvGz5Cmur+kQv2SURXEvvudLmbrE8QA==}
+ engines: {node: '>=18.17'}
+
unified@11.0.5:
resolution: {integrity: sha512-xKvGhPWw3k84Qjh8bI3ZeJjqnyadK+GEFtazSfZv/rKeTkTjOJho6mFqh2SM96iIcZokxiOpg78GazTSg8+KHA==}
@@ -4628,6 +5298,14 @@ packages:
unist-util-visit@5.0.0:
resolution: {integrity: sha512-MR04uvD+07cwl/yhVuVWAtw+3GOR/knlL55Nd/wAdblk27GCVt3lqpTivy/tkJcZoNPzTwS1Y+KMojlLDhoTzg==}
+ universalify@2.0.1:
+ resolution: {integrity: sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw==}
+ engines: {node: '>= 10.0.0'}
+
+ unpipe@1.0.0:
+ resolution: {integrity: sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==}
+ engines: {node: '>= 0.8'}
+
unplugin@1.14.1:
resolution: {integrity: sha512-lBlHbfSFPToDYp9pjXlUEFVxYLaue9f9T1HC+4OHlmj+HnMDdz9oZY+erXfoCe/5V/7gKUSY2jpXPb9S7f0f/w==}
engines: {node: '>=14.0.0'}
@@ -4670,6 +5348,10 @@ packages:
resolution: {integrity: sha512-6Z7Ma2aVEWisaL6TvBCy7P8rm2LQoPv6dJ7ecIaIixHcwfbJ0x7mWdbcwlIM5IGQxPZSFYeqRCqlOOeKoJYMkw==}
engines: {node: '>= 4'}
+ utils-merge@1.0.1:
+ resolution: {integrity: sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==}
+ engines: {node: '>= 0.4.0'}
+
uuid@8.3.2:
resolution: {integrity: sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==}
hasBin: true
@@ -4677,9 +5359,21 @@ packages:
v8-compile-cache-lib@3.0.1:
resolution: {integrity: sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg==}
+ valibot@0.41.0:
+ resolution: {integrity: sha512-igDBb8CTYr8YTQlOKgaN9nSS0Be7z+WRuaeYqGf3Cjz3aKmSnqEmYnkfVjzIuumGqfHpa3fLIvMEAfhrpqN8ng==}
+ peerDependencies:
+ typescript: '>=5'
+ peerDependenciesMeta:
+ typescript:
+ optional: true
+
validate-npm-package-license@3.0.4:
resolution: {integrity: sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==}
+ validate-npm-package-name@5.0.1:
+ resolution: {integrity: sha512-OljLrQ9SQdOUqTaQxqL5dEfZWrXExyyWsozYlAWFawPVNuD83igl7uJD2RTkNMbniIYgt8l81eCJGIdQF7avLQ==}
+ engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0}
+
validate.io-array@1.0.6:
resolution: {integrity: sha512-DeOy7CnPEziggrOO5CZhVKJw6S3Yi7e9e65R1Nl/RTN1vTQKnzjfvks0/8kQ40FP/dsjRAOd4hxmJ7uLa6vxkg==}
@@ -4695,6 +5389,10 @@ packages:
validate.io-number@1.0.3:
resolution: {integrity: sha512-kRAyotcbNaSYoDnXvb4MHg/0a1egJdLwS6oJ38TJY7aw9n93Fl/3blIXdyYvPOp55CNxywooG/3BcrwNrBpcSg==}
+ vary@1.1.2:
+ resolution: {integrity: sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==}
+ engines: {node: '>= 0.8'}
+
vfile-location@5.0.3:
resolution: {integrity: sha512-5yXvWDEgqeiYiBe1lbxYF7UMAIm/IcopxMHrMQDq3nvKcjPKIhZklUKL+AE7J7uApI4kwe2snsK+eI6UTj9EHg==}
@@ -4953,6 +5651,11 @@ packages:
engines: {node: '>= 8'}
hasBin: true
+ which@3.0.1:
+ resolution: {integrity: sha512-XA1b62dzQzLfaEOSQFTCOd5KFf/1VSzZo7/7TUjnya6u0vGGKzU96UQBZTAThCb2j4/xjBAyii1OhRLJEivHvg==}
+ engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0}
+ hasBin: true
+
why-is-node-running@2.2.2:
resolution: {integrity: sha512-6tSwToZxTOcotxHeA+qGCq1mVzKR3CwcJGmVcY+QE8SHy6TnpFnh8PAvPNHYr7EcuVeG0QSMxtYCuO1ta/G/oA==}
engines: {node: '>=8'}
@@ -4980,6 +5683,10 @@ packages:
wrappy@1.0.2:
resolution: {integrity: sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==}
+ xtend@4.0.2:
+ resolution: {integrity: sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==}
+ engines: {node: '>=0.4'}
+
xxhash-wasm@1.0.2:
resolution: {integrity: sha512-ibF0Or+FivM9lNrg+HGJfVX8WJqgo+kCLDc4vx6xMeTce7Aj+DLttKbxxRR/gNLSAelRc1omAPlJ77N/Jem07A==}
@@ -5222,6 +5929,11 @@ snapshots:
'@babel/highlight': 7.25.7
picocolors: 1.0.1
+ '@babel/code-frame@7.25.9':
+ dependencies:
+ '@babel/highlight': 7.25.9
+ picocolors: 1.1.0
+
'@babel/compat-data@7.24.7': {}
'@babel/compat-data@7.25.7': {}
@@ -5259,7 +5971,7 @@ snapshots:
'@babel/traverse': 7.25.7
'@babel/types': 7.25.7
convert-source-map: 2.0.0
- debug: 4.3.5
+ debug: 4.3.7
gensync: 1.0.0-beta.2
json5: 2.2.3
semver: 6.3.1
@@ -5280,10 +5992,21 @@ snapshots:
'@jridgewell/trace-mapping': 0.3.25
jsesc: 3.0.2
+ '@babel/generator@7.25.9':
+ dependencies:
+ '@babel/types': 7.25.9
+ '@jridgewell/gen-mapping': 0.3.5
+ '@jridgewell/trace-mapping': 0.3.25
+ jsesc: 3.0.2
+
'@babel/helper-annotate-as-pure@7.25.7':
dependencies:
'@babel/types': 7.25.7
+ '@babel/helper-annotate-as-pure@7.25.9':
+ dependencies:
+ '@babel/types': 7.25.9
+
'@babel/helper-compilation-targets@7.24.7':
dependencies:
'@babel/compat-data': 7.24.7
@@ -5300,6 +6023,19 @@ snapshots:
lru-cache: 5.1.1
semver: 6.3.1
+ '@babel/helper-create-class-features-plugin@7.25.9(@babel/core@7.25.7)':
+ dependencies:
+ '@babel/core': 7.25.7
+ '@babel/helper-annotate-as-pure': 7.25.9
+ '@babel/helper-member-expression-to-functions': 7.25.9
+ '@babel/helper-optimise-call-expression': 7.25.9
+ '@babel/helper-replace-supers': 7.25.9(@babel/core@7.25.7)
+ '@babel/helper-skip-transparent-expression-wrappers': 7.25.9
+ '@babel/traverse': 7.25.9
+ semver: 6.3.1
+ transitivePeerDependencies:
+ - supports-color
+
'@babel/helper-environment-visitor@7.24.7':
dependencies:
'@babel/types': 7.24.7
@@ -5313,6 +6049,13 @@ snapshots:
dependencies:
'@babel/types': 7.24.7
+ '@babel/helper-member-expression-to-functions@7.25.9':
+ dependencies:
+ '@babel/traverse': 7.25.9
+ '@babel/types': 7.25.9
+ transitivePeerDependencies:
+ - supports-color
+
'@babel/helper-module-imports@7.24.7':
dependencies:
'@babel/traverse': 7.24.7
@@ -5327,6 +6070,13 @@ snapshots:
transitivePeerDependencies:
- supports-color
+ '@babel/helper-module-imports@7.25.9':
+ dependencies:
+ '@babel/traverse': 7.25.9
+ '@babel/types': 7.25.9
+ transitivePeerDependencies:
+ - supports-color
+
'@babel/helper-module-transforms@7.24.7(@babel/core@7.24.7)':
dependencies:
'@babel/core': 7.24.7
@@ -5348,10 +6098,35 @@ snapshots:
transitivePeerDependencies:
- supports-color
+ '@babel/helper-module-transforms@7.25.9(@babel/core@7.25.7)':
+ dependencies:
+ '@babel/core': 7.25.7
+ '@babel/helper-module-imports': 7.25.9
+ '@babel/helper-simple-access': 7.25.9
+ '@babel/helper-validator-identifier': 7.25.9
+ '@babel/traverse': 7.25.9
+ transitivePeerDependencies:
+ - supports-color
+
+ '@babel/helper-optimise-call-expression@7.25.9':
+ dependencies:
+ '@babel/types': 7.25.9
+
'@babel/helper-plugin-utils@7.24.7': {}
'@babel/helper-plugin-utils@7.25.7': {}
+ '@babel/helper-plugin-utils@7.25.9': {}
+
+ '@babel/helper-replace-supers@7.25.9(@babel/core@7.25.7)':
+ dependencies:
+ '@babel/core': 7.25.7
+ '@babel/helper-member-expression-to-functions': 7.25.9
+ '@babel/helper-optimise-call-expression': 7.25.9
+ '@babel/traverse': 7.25.9
+ transitivePeerDependencies:
+ - supports-color
+
'@babel/helper-simple-access@7.24.7':
dependencies:
'@babel/traverse': 7.24.7
@@ -5366,6 +6141,20 @@ snapshots:
transitivePeerDependencies:
- supports-color
+ '@babel/helper-simple-access@7.25.9':
+ dependencies:
+ '@babel/traverse': 7.25.9
+ '@babel/types': 7.25.9
+ transitivePeerDependencies:
+ - supports-color
+
+ '@babel/helper-skip-transparent-expression-wrappers@7.25.9':
+ dependencies:
+ '@babel/traverse': 7.25.9
+ '@babel/types': 7.25.9
+ transitivePeerDependencies:
+ - supports-color
+
'@babel/helper-split-export-declaration@7.24.7':
dependencies:
'@babel/types': 7.24.7
@@ -5374,14 +6163,20 @@ snapshots:
'@babel/helper-string-parser@7.25.7': {}
+ '@babel/helper-string-parser@7.25.9': {}
+
'@babel/helper-validator-identifier@7.24.7': {}
'@babel/helper-validator-identifier@7.25.7': {}
+ '@babel/helper-validator-identifier@7.25.9': {}
+
'@babel/helper-validator-option@7.24.7': {}
'@babel/helper-validator-option@7.25.7': {}
+ '@babel/helper-validator-option@7.25.9': {}
+
'@babel/helpers@7.24.7':
dependencies:
'@babel/template': 7.24.7
@@ -5406,6 +6201,13 @@ snapshots:
js-tokens: 4.0.0
picocolors: 1.0.1
+ '@babel/highlight@7.25.9':
+ dependencies:
+ '@babel/helper-validator-identifier': 7.25.9
+ chalk: 2.4.2
+ js-tokens: 4.0.0
+ picocolors: 1.1.0
+
'@babel/parser@7.24.7':
dependencies:
'@babel/types': 7.24.7
@@ -5414,16 +6216,44 @@ snapshots:
dependencies:
'@babel/types': 7.25.7
+ '@babel/parser@7.25.9':
+ dependencies:
+ '@babel/types': 7.25.9
+
+ '@babel/plugin-syntax-decorators@7.25.9(@babel/core@7.25.7)':
+ dependencies:
+ '@babel/core': 7.25.7
+ '@babel/helper-plugin-utils': 7.25.9
+
'@babel/plugin-syntax-jsx@7.25.7(@babel/core@7.25.7)':
dependencies:
'@babel/core': 7.25.7
'@babel/helper-plugin-utils': 7.25.7
+ '@babel/plugin-syntax-jsx@7.25.9(@babel/core@7.25.7)':
+ dependencies:
+ '@babel/core': 7.25.7
+ '@babel/helper-plugin-utils': 7.25.9
+
'@babel/plugin-syntax-typescript@7.25.7(@babel/core@7.25.7)':
dependencies:
'@babel/core': 7.25.7
'@babel/helper-plugin-utils': 7.25.7
+ '@babel/plugin-syntax-typescript@7.25.9(@babel/core@7.25.7)':
+ dependencies:
+ '@babel/core': 7.25.7
+ '@babel/helper-plugin-utils': 7.25.9
+
+ '@babel/plugin-transform-modules-commonjs@7.25.9(@babel/core@7.25.7)':
+ dependencies:
+ '@babel/core': 7.25.7
+ '@babel/helper-module-transforms': 7.25.9(@babel/core@7.25.7)
+ '@babel/helper-plugin-utils': 7.25.9
+ '@babel/helper-simple-access': 7.25.9
+ transitivePeerDependencies:
+ - supports-color
+
'@babel/plugin-transform-react-jsx-self@7.24.7(@babel/core@7.24.7)':
dependencies:
'@babel/core': 7.24.7
@@ -5445,6 +6275,28 @@ snapshots:
transitivePeerDependencies:
- supports-color
+ '@babel/plugin-transform-typescript@7.25.9(@babel/core@7.25.7)':
+ dependencies:
+ '@babel/core': 7.25.7
+ '@babel/helper-annotate-as-pure': 7.25.9
+ '@babel/helper-create-class-features-plugin': 7.25.9(@babel/core@7.25.7)
+ '@babel/helper-plugin-utils': 7.25.9
+ '@babel/helper-skip-transparent-expression-wrappers': 7.25.9
+ '@babel/plugin-syntax-typescript': 7.25.9(@babel/core@7.25.7)
+ transitivePeerDependencies:
+ - supports-color
+
+ '@babel/preset-typescript@7.25.9(@babel/core@7.25.7)':
+ dependencies:
+ '@babel/core': 7.25.7
+ '@babel/helper-plugin-utils': 7.25.9
+ '@babel/helper-validator-option': 7.25.9
+ '@babel/plugin-syntax-jsx': 7.25.9(@babel/core@7.25.7)
+ '@babel/plugin-transform-modules-commonjs': 7.25.9(@babel/core@7.25.7)
+ '@babel/plugin-transform-typescript': 7.25.9(@babel/core@7.25.7)
+ transitivePeerDependencies:
+ - supports-color
+
'@babel/runtime@7.25.7':
dependencies:
regenerator-runtime: 0.14.1
@@ -5461,6 +6313,12 @@ snapshots:
'@babel/parser': 7.25.7
'@babel/types': 7.25.7
+ '@babel/template@7.25.9':
+ dependencies:
+ '@babel/code-frame': 7.25.9
+ '@babel/parser': 7.25.9
+ '@babel/types': 7.25.9
+
'@babel/traverse@7.24.7':
dependencies:
'@babel/code-frame': 7.24.7
@@ -5483,7 +6341,19 @@ snapshots:
'@babel/parser': 7.25.7
'@babel/template': 7.25.7
'@babel/types': 7.25.7
- debug: 4.3.5
+ debug: 4.3.7
+ globals: 11.12.0
+ transitivePeerDependencies:
+ - supports-color
+
+ '@babel/traverse@7.25.9':
+ dependencies:
+ '@babel/code-frame': 7.25.9
+ '@babel/generator': 7.25.9
+ '@babel/parser': 7.25.9
+ '@babel/template': 7.25.9
+ '@babel/types': 7.25.9
+ debug: 4.3.7
globals: 11.12.0
transitivePeerDependencies:
- supports-color
@@ -5500,6 +6370,11 @@ snapshots:
'@babel/helper-validator-identifier': 7.25.7
to-fast-properties: 2.0.0
+ '@babel/types@7.25.9':
+ dependencies:
+ '@babel/helper-string-parser': 7.25.9
+ '@babel/helper-validator-identifier': 7.25.9
+
'@bcoe/v8-coverage@0.2.3': {}
'@biomejs/biome@1.8.1':
@@ -6049,10 +6924,39 @@ snapshots:
'@nodelib/fs.stat@2.0.5': {}
- '@nodelib/fs.walk@1.2.8':
+ '@nodelib/fs.walk@1.2.8':
+ dependencies:
+ '@nodelib/fs.scandir': 2.1.5
+ fastq: 1.17.1
+
+ '@npmcli/git@4.1.0':
+ dependencies:
+ '@npmcli/promise-spawn': 6.0.2
+ lru-cache: 7.18.3
+ npm-pick-manifest: 8.0.2
+ proc-log: 3.0.0
+ promise-inflight: 1.0.1
+ promise-retry: 2.0.1
+ semver: 7.6.3
+ which: 3.0.1
+ transitivePeerDependencies:
+ - bluebird
+
+ '@npmcli/package-json@4.0.1':
+ dependencies:
+ '@npmcli/git': 4.1.0
+ glob: 10.4.1
+ hosted-git-info: 6.1.1
+ json-parse-even-better-errors: 3.0.2
+ normalize-package-data: 5.0.0
+ proc-log: 3.0.0
+ semver: 7.6.3
+ transitivePeerDependencies:
+ - bluebird
+
+ '@npmcli/promise-spawn@6.0.2':
dependencies:
- '@nodelib/fs.scandir': 2.1.5
- fastq: 1.17.1
+ which: 3.0.1
'@oslojs/encoding@1.1.0': {}
@@ -6076,6 +6980,97 @@ snapshots:
'@pkgjs/parseargs@0.11.0':
optional: true
+ '@react-router/dev@7.0.0-pre.1(@react-router/serve@7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3))(@types/node@22.7.4)(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(terser@5.34.1)(typescript@5.6.3)(vite@5.4.8(@types/node@22.7.4)(terser@5.34.1))':
+ dependencies:
+ '@babel/core': 7.25.7
+ '@babel/generator': 7.25.9
+ '@babel/parser': 7.25.9
+ '@babel/plugin-syntax-decorators': 7.25.9(@babel/core@7.25.7)
+ '@babel/plugin-syntax-jsx': 7.25.9(@babel/core@7.25.7)
+ '@babel/preset-typescript': 7.25.9(@babel/core@7.25.7)
+ '@babel/traverse': 7.25.9
+ '@babel/types': 7.25.9
+ '@npmcli/package-json': 4.0.1
+ '@react-router/node': 7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
+ arg: 5.0.2
+ babel-dead-code-elimination: 1.0.6
+ chalk: 4.1.2
+ chokidar: 4.0.1
+ dedent: 1.5.3
+ es-module-lexer: 1.5.4
+ exit-hook: 2.2.1
+ fs-extra: 10.1.0
+ gunzip-maybe: 1.4.2
+ jsesc: 3.0.2
+ lodash: 4.17.21
+ pathe: 1.1.2
+ picocolors: 1.1.0
+ picomatch: 2.3.1
+ prettier: 2.8.7
+ react-refresh: 0.14.2
+ react-router: 7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
+ semver: 7.6.3
+ set-cookie-parser: 2.7.1
+ valibot: 0.41.0(typescript@5.6.3)
+ vite: 5.4.8(@types/node@22.7.4)(terser@5.34.1)
+ vite-node: 1.6.0(@types/node@22.7.4)(terser@5.34.1)
+ optionalDependencies:
+ '@react-router/serve': 7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
+ typescript: 5.6.3
+ transitivePeerDependencies:
+ - '@types/node'
+ - babel-plugin-macros
+ - bluebird
+ - less
+ - lightningcss
+ - sass
+ - sass-embedded
+ - stylus
+ - sugarss
+ - supports-color
+ - terser
+
+ '@react-router/express@7.0.0-pre.1(express@4.21.1)(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)':
+ dependencies:
+ '@react-router/node': 7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
+ express: 4.21.1
+ react-router: 7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
+ optionalDependencies:
+ typescript: 5.6.3
+
+ '@react-router/fs-routes@7.0.0-pre.1(@react-router/dev@7.0.0-pre.1(@react-router/serve@7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3))(@types/node@22.7.4)(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(terser@5.34.1)(typescript@5.6.3)(vite@5.4.8(@types/node@22.7.4)(terser@5.34.1)))(typescript@5.6.3)':
+ dependencies:
+ '@react-router/dev': 7.0.0-pre.1(@react-router/serve@7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3))(@types/node@22.7.4)(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(terser@5.34.1)(typescript@5.6.3)(vite@5.4.8(@types/node@22.7.4)(terser@5.34.1))
+ minimatch: 9.0.4
+ optionalDependencies:
+ typescript: 5.6.3
+
+ '@react-router/node@7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)':
+ dependencies:
+ '@web3-storage/multipart-parser': 1.0.0
+ react-router: 7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
+ source-map-support: 0.5.21
+ stream-slice: 0.1.2
+ undici: 6.20.1
+ optionalDependencies:
+ typescript: 5.6.3
+
+ '@react-router/serve@7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)':
+ dependencies:
+ '@react-router/express': 7.0.0-pre.1(express@4.21.1)(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
+ '@react-router/node': 7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
+ compression: 1.7.4
+ express: 4.21.1
+ get-port: 5.1.1
+ morgan: 1.10.0
+ react-router: 7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
+ source-map-support: 0.5.21
+ transitivePeerDependencies:
+ - supports-color
+ - typescript
+
+ '@remix-run/router@1.20.0': {}
+
'@rollup/pluginutils@5.1.2(rollup@4.24.0)':
dependencies:
'@types/estree': 1.0.5
@@ -6717,6 +7712,8 @@ snapshots:
'@vscode/l10n@0.0.18': {}
+ '@web3-storage/multipart-parser@1.0.0': {}
+
abstract-logging@2.0.1: {}
accepts@1.3.8:
@@ -6796,6 +7793,8 @@ snapshots:
call-bind: 1.0.7
is-array-buffer: 3.0.4
+ array-flatten@1.1.1: {}
+
array-iterate@2.0.1: {}
arraybuffer.prototype.slice@1.0.3:
@@ -6958,6 +7957,10 @@ snapshots:
base64-js@1.5.1: {}
+ basic-auth@2.0.1:
+ dependencies:
+ safe-buffer: 5.1.2
+
bcp-47-match@2.0.3: {}
bcp-47@2.1.0:
@@ -6976,6 +7979,23 @@ snapshots:
bluebird@3.7.2: {}
+ body-parser@1.20.3:
+ dependencies:
+ bytes: 3.1.2
+ content-type: 1.0.5
+ debug: 2.6.9
+ depd: 2.0.0
+ destroy: 1.2.0
+ http-errors: 2.0.0
+ iconv-lite: 0.4.24
+ on-finished: 2.4.1
+ qs: 6.13.0
+ raw-body: 2.5.2
+ type-is: 1.6.18
+ unpipe: 1.0.0
+ transitivePeerDependencies:
+ - supports-color
+
boolbase@1.0.0: {}
boxen@8.0.1:
@@ -7002,6 +8022,10 @@ snapshots:
dependencies:
fill-range: 7.1.1
+ browserify-zlib@0.1.4:
+ dependencies:
+ pako: 0.2.9
+
browserslist@4.23.1:
dependencies:
caniuse-lite: 1.0.30001632
@@ -7016,8 +8040,7 @@ snapshots:
node-releases: 2.0.18
update-browserslist-db: 1.1.1(browserslist@4.24.0)
- buffer-from@1.1.2:
- optional: true
+ buffer-from@1.1.2: {}
buffer@5.7.1:
dependencies:
@@ -7028,6 +8051,10 @@ snapshots:
dependencies:
streamsearch: 1.1.0
+ bytes@3.0.0: {}
+
+ bytes@3.1.2: {}
+
c12@2.0.1(magicast@0.3.5):
dependencies:
chokidar: 4.0.1
@@ -7197,6 +8224,22 @@ snapshots:
common-ancestor-path@1.0.1: {}
+ compressible@2.0.18:
+ dependencies:
+ mime-db: 1.52.0
+
+ compression@1.7.4:
+ dependencies:
+ accepts: 1.3.8
+ bytes: 3.0.0
+ compressible: 2.0.18
+ debug: 2.6.9
+ on-headers: 1.0.2
+ safe-buffer: 5.1.2
+ vary: 1.1.2
+ transitivePeerDependencies:
+ - supports-color
+
compute-gcd@1.2.1:
dependencies:
validate.io-array: 1.0.6
@@ -7216,12 +8259,24 @@ snapshots:
consola@3.2.3: {}
+ content-disposition@0.5.4:
+ dependencies:
+ safe-buffer: 5.2.1
+
content-type@1.0.5: {}
convert-source-map@2.0.0: {}
+ cookie-signature@1.0.6: {}
+
+ cookie@0.6.0: {}
+
+ cookie@0.7.1: {}
+
cookie@0.7.2: {}
+ core-util-is@1.0.3: {}
+
create-require@1.1.1:
optional: true
@@ -7269,6 +8324,10 @@ snapshots:
es-errors: 1.3.0
is-data-view: 1.0.1
+ debug@2.6.9:
+ dependencies:
+ ms: 2.0.0
+
debug@4.3.5:
dependencies:
ms: 2.1.2
@@ -7285,6 +8344,8 @@ snapshots:
dependencies:
mimic-response: 3.1.0
+ dedent@1.5.3: {}
+
deep-eql@4.1.4:
dependencies:
type-detect: 4.0.8
@@ -7307,10 +8368,14 @@ snapshots:
delayed-stream@1.0.0: {}
+ depd@2.0.0: {}
+
dequal@2.0.3: {}
destr@2.0.3: {}
+ destroy@1.2.0: {}
+
detect-libc@2.0.3: {}
deterministic-object-hash@2.0.2:
@@ -7340,8 +8405,17 @@ snapshots:
dset@3.1.4: {}
+ duplexify@3.7.1:
+ dependencies:
+ end-of-stream: 1.4.4
+ inherits: 2.0.4
+ readable-stream: 2.3.8
+ stream-shift: 1.0.3
+
eastasianwidth@0.2.0: {}
+ ee-first@1.1.1: {}
+
electron-to-chromium@1.4.799: {}
electron-to-chromium@1.5.32: {}
@@ -7357,12 +8431,18 @@ snapshots:
emoji-regex@9.2.2: {}
+ encodeurl@1.0.2: {}
+
+ encodeurl@2.0.0: {}
+
end-of-stream@1.4.4:
dependencies:
once: 1.4.0
entities@4.5.0: {}
+ err-code@2.0.3: {}
+
error-ex@1.3.2:
dependencies:
is-arrayish: 0.2.1
@@ -7523,6 +8603,8 @@ snapshots:
escalade@3.2.0: {}
+ escape-html@1.0.3: {}
+
escape-string-regexp@1.0.5: {}
escape-string-regexp@5.0.0: {}
@@ -7559,6 +8641,8 @@ snapshots:
dependencies:
'@types/estree': 1.0.5
+ etag@1.8.1: {}
+
eventemitter3@5.0.1: {}
execa@8.0.1:
@@ -7573,8 +8657,46 @@ snapshots:
signal-exit: 4.1.0
strip-final-newline: 3.0.0
+ exit-hook@2.2.1: {}
+
expand-template@2.0.3: {}
+ express@4.21.1:
+ dependencies:
+ accepts: 1.3.8
+ array-flatten: 1.1.1
+ body-parser: 1.20.3
+ content-disposition: 0.5.4
+ content-type: 1.0.5
+ cookie: 0.7.1
+ cookie-signature: 1.0.6
+ debug: 2.6.9
+ depd: 2.0.0
+ encodeurl: 2.0.0
+ escape-html: 1.0.3
+ etag: 1.8.1
+ finalhandler: 1.3.1
+ fresh: 0.5.2
+ http-errors: 2.0.0
+ merge-descriptors: 1.0.3
+ methods: 1.1.2
+ on-finished: 2.4.1
+ parseurl: 1.3.3
+ path-to-regexp: 0.1.10
+ proxy-addr: 2.0.7
+ qs: 6.13.0
+ range-parser: 1.2.1
+ safe-buffer: 5.2.1
+ send: 0.19.0
+ serve-static: 1.16.2
+ setprototypeof: 1.2.0
+ statuses: 2.0.1
+ type-is: 1.6.18
+ utils-merge: 1.0.1
+ vary: 1.1.2
+ transitivePeerDependencies:
+ - supports-color
+
expressive-code@0.35.6:
dependencies:
'@expressive-code/core': 0.35.6
@@ -7624,6 +8746,18 @@ snapshots:
dependencies:
to-regex-range: 5.0.1
+ finalhandler@1.3.1:
+ dependencies:
+ debug: 2.6.9
+ encodeurl: 2.0.0
+ escape-html: 1.0.3
+ on-finished: 2.4.1
+ parseurl: 1.3.3
+ statuses: 2.0.1
+ unpipe: 1.0.0
+ transitivePeerDependencies:
+ - supports-color
+
find-up-simple@1.0.0: {}
find-up@2.1.0:
@@ -7667,10 +8801,20 @@ snapshots:
format-util@1.0.5: {}
+ forwarded@0.2.0: {}
+
fp-ts@2.16.6: {}
+ fresh@0.5.2: {}
+
fs-constants@1.0.0: {}
+ fs-extra@10.1.0:
+ dependencies:
+ graceful-fs: 4.2.11
+ jsonfile: 6.1.0
+ universalify: 2.0.1
+
fs-minipass@2.1.0:
dependencies:
minipass: 3.3.6
@@ -7707,6 +8851,8 @@ snapshots:
has-symbols: 1.0.3
hasown: 2.0.2
+ get-port@5.1.1: {}
+
get-stream@8.0.1: {}
get-symbol-description@1.0.2:
@@ -7783,6 +8929,15 @@ snapshots:
section-matter: 1.0.0
strip-bom-string: 1.0.0
+ gunzip-maybe@1.4.2:
+ dependencies:
+ browserify-zlib: 0.1.4
+ is-deflate: 1.0.0
+ is-gzip: 1.0.0
+ peek-stream: 1.1.3
+ pumpify: 1.5.1
+ through2: 2.0.5
+
handlebars@4.7.8:
dependencies:
minimist: 1.2.8
@@ -8015,6 +9170,10 @@ snapshots:
hosted-git-info@2.8.9: {}
+ hosted-git-info@6.1.1:
+ dependencies:
+ lru-cache: 7.18.3
+
html-escaper@2.0.2: {}
html-escaper@3.0.3: {}
@@ -8025,6 +9184,14 @@ snapshots:
http-cache-semantics@4.1.1: {}
+ http-errors@2.0.0:
+ dependencies:
+ depd: 2.0.0
+ inherits: 2.0.4
+ setprototypeof: 1.2.0
+ statuses: 2.0.1
+ toidentifier: 1.0.1
+
http-proxy-agent@5.0.0:
dependencies:
'@tootallnate/once': 2.0.0
@@ -8048,6 +9215,10 @@ snapshots:
dependencies:
'@babel/runtime': 7.25.7
+ iconv-lite@0.4.24:
+ dependencies:
+ safer-buffer: 2.1.2
+
iconv-lite@0.6.3:
dependencies:
safer-buffer: 2.1.2
@@ -8079,6 +9250,8 @@ snapshots:
dependencies:
fp-ts: 2.16.6
+ ipaddr.js@1.9.1: {}
+
is-alphabetical@2.0.1: {}
is-alphanumerical@2.0.1:
@@ -8124,6 +9297,8 @@ snapshots:
is-decimal@2.0.1: {}
+ is-deflate@1.0.0: {}
+
is-docker@3.0.0: {}
is-extendable@0.1.1: {}
@@ -8136,6 +9311,8 @@ snapshots:
dependencies:
is-extglob: 2.1.1
+ is-gzip@1.0.0: {}
+
is-hexadecimal@2.0.1: {}
is-inside-container@1.0.0:
@@ -8193,8 +9370,12 @@ snapshots:
dependencies:
is-inside-container: 1.0.0
+ isarray@1.0.0: {}
+
isarray@2.0.5: {}
+ isbot@5.1.17: {}
+
isexe@2.0.0: {}
isomorphic-fetch@3.0.0:
@@ -8254,6 +9435,8 @@ snapshots:
json-parse-better-errors@1.0.2: {}
+ json-parse-even-better-errors@3.0.2: {}
+
json-pointer@0.6.2:
dependencies:
foreach: 2.0.6
@@ -8287,6 +9470,12 @@ snapshots:
jsonc-parser@3.3.1: {}
+ jsonfile@6.1.0:
+ dependencies:
+ universalify: 2.0.1
+ optionalDependencies:
+ graceful-fs: 4.2.11
+
jsonpath-plus@7.2.0: {}
kind-of@6.0.3: {}
@@ -8395,6 +9584,8 @@ snapshots:
dependencies:
yallist: 4.0.0
+ lru-cache@7.18.3: {}
+
magic-string@0.30.10:
dependencies:
'@jridgewell/sourcemap-codec': 1.4.15
@@ -8611,10 +9802,14 @@ snapshots:
memorystream@0.3.1: {}
+ merge-descriptors@1.0.3: {}
+
merge-stream@2.0.0: {}
merge2@1.4.1: {}
+ methods@1.1.2: {}
+
micri@4.5.1:
dependencies:
handler-agent: 0.2.0
@@ -8915,6 +10110,8 @@ snapshots:
dependencies:
mime-db: 1.52.0
+ mime@1.6.0: {}
+
mimic-fn@4.0.0: {}
mimic-function@5.0.1: {}
@@ -8963,8 +10160,20 @@ snapshots:
pkg-types: 1.1.1
ufo: 1.5.3
+ morgan@1.10.0:
+ dependencies:
+ basic-auth: 2.0.1
+ debug: 2.6.9
+ depd: 2.0.0
+ on-finished: 2.3.0
+ on-headers: 1.0.2
+ transitivePeerDependencies:
+ - supports-color
+
mrmime@2.0.0: {}
+ ms@2.0.0: {}
+
ms@2.1.2: {}
ms@2.1.3: {}
@@ -9043,8 +10252,35 @@ snapshots:
semver: 5.7.2
validate-npm-package-license: 3.0.4
+ normalize-package-data@5.0.0:
+ dependencies:
+ hosted-git-info: 6.1.1
+ is-core-module: 2.13.1
+ semver: 7.6.3
+ validate-npm-package-license: 3.0.4
+
normalize-path@3.0.0: {}
+ npm-install-checks@6.3.0:
+ dependencies:
+ semver: 7.6.3
+
+ npm-normalize-package-bin@3.0.1: {}
+
+ npm-package-arg@10.1.0:
+ dependencies:
+ hosted-git-info: 6.1.1
+ proc-log: 3.0.0
+ semver: 7.6.3
+ validate-npm-package-name: 5.0.1
+
+ npm-pick-manifest@8.0.2:
+ dependencies:
+ npm-install-checks: 6.3.0
+ npm-normalize-package-bin: 3.0.1
+ npm-package-arg: 10.1.0
+ semver: 7.6.3
+
npm-run-all@4.1.5:
dependencies:
ansi-styles: 3.2.1
@@ -9092,6 +10328,16 @@ snapshots:
ohash@1.1.4: {}
+ on-finished@2.3.0:
+ dependencies:
+ ee-first: 1.1.1
+
+ on-finished@2.4.1:
+ dependencies:
+ ee-first: 1.1.1
+
+ on-headers@1.0.2: {}
+
once@1.4.0:
dependencies:
wrappy: 1.0.2
@@ -9171,6 +10417,8 @@ snapshots:
'@pagefind/linux-x64': 1.1.1
'@pagefind/windows-x64': 1.1.1
+ pako@0.2.9: {}
+
parse-entities@4.0.1:
dependencies:
'@types/unist': 2.0.11
@@ -9206,6 +10454,8 @@ snapshots:
dependencies:
entities: 4.5.0
+ parseurl@1.3.3: {}
+
path-browserify@1.0.1: {}
path-exists@3.0.0: {}
@@ -9227,6 +10477,8 @@ snapshots:
lru-cache: 10.2.2
minipass: 7.1.2
+ path-to-regexp@0.1.10: {}
+
path-type@3.0.0:
dependencies:
pify: 3.0.0
@@ -9235,6 +10487,12 @@ snapshots:
pathval@1.1.1: {}
+ peek-stream@1.1.3:
+ dependencies:
+ buffer-from: 1.1.2
+ duplexify: 3.7.1
+ through2: 2.0.5
+
perfect-debounce@1.0.0: {}
periscopic@3.1.0:
@@ -9388,8 +10646,7 @@ snapshots:
find-yarn-workspace-root2: 1.2.16
which-pm: 3.0.0
- prettier@2.8.7:
- optional: true
+ prettier@2.8.7: {}
prettier@3.3.3: {}
@@ -9403,8 +10660,19 @@ snapshots:
prismjs@1.29.0: {}
+ proc-log@3.0.0: {}
+
+ process-nextick-args@2.0.1: {}
+
process-warning@1.0.0: {}
+ promise-inflight@1.0.1: {}
+
+ promise-retry@2.0.1:
+ dependencies:
+ err-code: 2.0.3
+ retry: 0.12.0
+
prompts@2.4.2:
dependencies:
kleur: 3.0.3
@@ -9412,21 +10680,50 @@ snapshots:
property-information@6.5.0: {}
+ proxy-addr@2.0.7:
+ dependencies:
+ forwarded: 0.2.0
+ ipaddr.js: 1.9.1
+
proxy-from-env@1.1.0: {}
+ pump@2.0.1:
+ dependencies:
+ end-of-stream: 1.4.4
+ once: 1.4.0
+
pump@3.0.2:
dependencies:
end-of-stream: 1.4.4
once: 1.4.0
+ pumpify@1.5.1:
+ dependencies:
+ duplexify: 3.7.1
+ inherits: 2.0.4
+ pump: 2.0.1
+
punycode@2.3.1: {}
+ qs@6.13.0:
+ dependencies:
+ side-channel: 1.0.6
+
queue-microtask@1.2.3: {}
queue-tick@1.0.1: {}
quick-format-unescaped@4.0.4: {}
+ range-parser@1.2.1: {}
+
+ raw-body@2.5.2:
+ dependencies:
+ bytes: 3.1.2
+ http-errors: 2.0.0
+ iconv-lite: 0.4.24
+ unpipe: 1.0.0
+
rc9@2.1.2:
dependencies:
defu: 6.1.4
@@ -9449,6 +10746,36 @@ snapshots:
react-refresh@0.14.2: {}
+ react-router-dom@6.27.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1):
+ dependencies:
+ '@remix-run/router': 1.20.0
+ react: 18.3.1
+ react-dom: 18.3.1(react@18.3.1)
+ react-router: 6.27.0(react@18.3.1)
+
+ react-router-dom@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1):
+ dependencies:
+ react: 18.3.1
+ react-dom: 18.3.1(react@18.3.1)
+ react-router: 7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
+
+ react-router@6.27.0(react@18.3.1):
+ dependencies:
+ '@remix-run/router': 1.20.0
+ react: 18.3.1
+
+ react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1):
+ dependencies:
+ '@types/cookie': 0.6.0
+ '@web3-storage/multipart-parser': 1.0.0
+ cookie: 0.6.0
+ react: 18.3.1
+ set-cookie-parser: 2.7.1
+ source-map: 0.7.4
+ turbo-stream: 2.4.0
+ optionalDependencies:
+ react-dom: 18.3.1(react@18.3.1)
+
react@18.3.1:
dependencies:
loose-envify: 1.4.0
@@ -9463,6 +10790,16 @@ snapshots:
normalize-package-data: 2.5.0
path-type: 3.0.0
+ readable-stream@2.3.8:
+ dependencies:
+ core-util-is: 1.0.3
+ inherits: 2.0.4
+ isarray: 1.0.0
+ process-nextick-args: 2.0.1
+ safe-buffer: 5.1.2
+ string_decoder: 1.1.1
+ util-deprecate: 1.0.2
+
readable-stream@3.6.2:
dependencies:
inherits: 2.0.4
@@ -9623,6 +10960,8 @@ snapshots:
retext-stringify: 4.0.0
unified: 11.0.5
+ retry@0.12.0: {}
+
reusify@1.0.4: {}
rimraf@5.0.7:
@@ -9684,6 +11023,8 @@ snapshots:
has-symbols: 1.0.3
isarray: 2.0.5
+ safe-buffer@5.1.2: {}
+
safe-buffer@5.2.1: {}
safe-regex-test@1.0.3:
@@ -9719,6 +11060,35 @@ snapshots:
semver@7.6.3: {}
+ send@0.19.0:
+ dependencies:
+ debug: 2.6.9
+ depd: 2.0.0
+ destroy: 1.2.0
+ encodeurl: 1.0.2
+ escape-html: 1.0.3
+ etag: 1.8.1
+ fresh: 0.5.2
+ http-errors: 2.0.0
+ mime: 1.6.0
+ ms: 2.1.3
+ on-finished: 2.4.1
+ range-parser: 1.2.1
+ statuses: 2.0.1
+ transitivePeerDependencies:
+ - supports-color
+
+ serve-static@1.16.2:
+ dependencies:
+ encodeurl: 2.0.0
+ escape-html: 1.0.3
+ parseurl: 1.3.3
+ send: 0.19.0
+ transitivePeerDependencies:
+ - supports-color
+
+ set-cookie-parser@2.7.1: {}
+
set-function-length@1.2.2:
dependencies:
define-data-property: 1.1.4
@@ -9735,6 +11105,8 @@ snapshots:
functions-have-names: 1.2.3
has-property-descriptors: 1.0.2
+ setprototypeof@1.2.0: {}
+
sharp@0.32.6:
dependencies:
color: 4.2.3
@@ -9847,7 +11219,6 @@ snapshots:
dependencies:
buffer-from: 1.1.2
source-map: 0.6.1
- optional: true
source-map@0.6.1: {}
@@ -9877,12 +11248,18 @@ snapshots:
stackback@0.0.2: {}
+ statuses@2.0.1: {}
+
std-env@3.7.0: {}
stdin-discarder@0.2.2: {}
stream-replace-string@2.0.0: {}
+ stream-shift@1.0.3: {}
+
+ stream-slice@0.1.2: {}
+
streamsearch@1.1.0: {}
streamx@2.20.1:
@@ -9937,6 +11314,10 @@ snapshots:
define-properties: 1.2.1
es-object-atoms: 1.0.0
+ string_decoder@1.1.1:
+ dependencies:
+ safe-buffer: 5.1.2
+
string_decoder@1.3.0:
dependencies:
safe-buffer: 5.2.1
@@ -10092,6 +11473,11 @@ snapshots:
dependencies:
any-promise: 1.3.0
+ through2@2.0.5:
+ dependencies:
+ readable-stream: 2.3.8
+ xtend: 4.0.2
+
tiny-invariant@1.3.3: {}
tiny-warning@1.0.3: {}
@@ -10110,6 +11496,8 @@ snapshots:
dependencies:
is-number: 7.0.0
+ toidentifier@1.0.1: {}
+
tr46@0.0.3: {}
trim-lines@3.0.1: {}
@@ -10159,6 +11547,8 @@ snapshots:
dependencies:
safe-buffer: 5.2.1
+ turbo-stream@2.4.0: {}
+
type-detect@4.0.8: {}
type-fest@4.26.1: {}
@@ -10228,6 +11618,8 @@ snapshots:
undici-types@6.19.8: {}
+ undici@6.20.1: {}
+
unified@11.0.5:
dependencies:
'@types/unist': 3.0.3
@@ -10284,6 +11676,10 @@ snapshots:
unist-util-is: 6.0.0
unist-util-visit-parents: 6.0.1
+ universalify@2.0.1: {}
+
+ unpipe@1.0.0: {}
+
unplugin@1.14.1:
dependencies:
acorn: 8.12.1
@@ -10317,16 +11713,24 @@ snapshots:
utility-types@3.11.0: {}
+ utils-merge@1.0.1: {}
+
uuid@8.3.2: {}
v8-compile-cache-lib@3.0.1:
optional: true
+ valibot@0.41.0(typescript@5.6.3):
+ optionalDependencies:
+ typescript: 5.6.3
+
validate-npm-package-license@3.0.4:
dependencies:
spdx-correct: 3.2.0
spdx-expression-parse: 3.0.1
+ validate-npm-package-name@5.0.1: {}
+
validate.io-array@1.0.6: {}
validate.io-function@1.0.2: {}
@@ -10342,6 +11746,8 @@ snapshots:
validate.io-number@1.0.3: {}
+ vary@1.1.2: {}
+
vfile-location@5.0.3:
dependencies:
'@types/unist': 3.0.3
@@ -10590,6 +11996,10 @@ snapshots:
dependencies:
isexe: 2.0.0
+ which@3.0.1:
+ dependencies:
+ isexe: 2.0.0
+
why-is-node-running@2.2.2:
dependencies:
siginfo: 2.0.0
@@ -10621,6 +12031,8 @@ snapshots:
wrappy@1.0.2: {}
+ xtend@4.0.2: {}
+
xxhash-wasm@1.0.2: {}
y18n@5.0.8: {}
From 005c81d5fedcb56560824e8c7137ad873117c636 Mon Sep 17 00:00:00 2001
From: Bryan Thomas <49354825+bryanjtc@users.noreply.github.com>
Date: Thu, 24 Oct 2024 19:07:44 -0500
Subject: [PATCH 04/15] chore: Update react-router and related dependencies to
version 7.0.0-pre.2
---
examples/react-router-7-app/package.json | 12 +-
pnpm-lock.yaml | 158 +++++++++++------------
2 files changed, 85 insertions(+), 85 deletions(-)
diff --git a/examples/react-router-7-app/package.json b/examples/react-router-7-app/package.json
index 93f0d17..71daf1b 100644
--- a/examples/react-router-7-app/package.json
+++ b/examples/react-router-7-app/package.json
@@ -13,21 +13,21 @@
"test:generated": "tsc -p ./tsconfig.json --noEmit"
},
"dependencies": {
- "@react-router/fs-routes": "^7.0.0-pre.1",
- "@react-router/node": "^7.0.0-pre.1",
- "@react-router/serve": "^7.0.0-pre.1",
+ "@react-router/fs-routes": "^7.0.0-pre.2",
+ "@react-router/node": "^7.0.0-pre.2",
+ "@react-router/serve": "^7.0.0-pre.2",
"@tanstack/react-query": "^5.59.13",
"@tanstack/react-query-devtools": "^5.32.1",
"form-data": "~4.0.0",
"isbot": "^5",
"react": "^18.3.1",
"react-dom": "^18.3.1",
- "react-router": "^7.0.0-pre.1",
- "react-router-dom": "^7.0.0-pre.1"
+ "react-router": "^7.0.0-pre.2",
+ "react-router-dom": "^7.0.0-pre.2"
},
"devDependencies": {
"@biomejs/biome": "^1.7.2",
- "@react-router/dev": "^7.0.0-pre.1",
+ "@react-router/dev": "^7.0.0-pre.2",
"@stoplight/prism-cli": "^5.5.2",
"@types/react": "^18.3.1",
"@types/react-dom": "^18.2.18",
diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml
index 53a758f..b199c6b 100644
--- a/pnpm-lock.yaml
+++ b/pnpm-lock.yaml
@@ -214,14 +214,14 @@ importers:
examples/react-router-7-app:
dependencies:
'@react-router/fs-routes':
- specifier: ^7.0.0-pre.1
- version: 7.0.0-pre.1(@react-router/dev@7.0.0-pre.1(@react-router/serve@7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3))(@types/node@22.7.4)(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(terser@5.34.1)(typescript@5.6.3)(vite@5.4.8(@types/node@22.7.4)(terser@5.34.1)))(typescript@5.6.3)
+ specifier: ^7.0.0-pre.2
+ version: 7.0.0-pre.2(@react-router/dev@7.0.0-pre.2(@react-router/serve@7.0.0-pre.2(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3))(@types/node@22.7.4)(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(terser@5.34.1)(typescript@5.6.3)(vite@5.4.8(@types/node@22.7.4)(terser@5.34.1)))(typescript@5.6.3)
'@react-router/node':
- specifier: ^7.0.0-pre.1
- version: 7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
+ specifier: ^7.0.0-pre.2
+ version: 7.0.0-pre.2(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
'@react-router/serve':
- specifier: ^7.0.0-pre.1
- version: 7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
+ specifier: ^7.0.0-pre.2
+ version: 7.0.0-pre.2(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
'@tanstack/react-query':
specifier: ^5.59.13
version: 5.59.13(react@18.3.1)
@@ -241,18 +241,18 @@ importers:
specifier: ^18.3.1
version: 18.3.1(react@18.3.1)
react-router:
- specifier: ^7.0.0-pre.1
- version: 7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
+ specifier: ^7.0.0-pre.2
+ version: 7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
react-router-dom:
- specifier: ^7.0.0-pre.1
- version: 7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
+ specifier: ^7.0.0-pre.2
+ version: 7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
devDependencies:
'@biomejs/biome':
specifier: ^1.7.2
version: 1.9.3
'@react-router/dev':
- specifier: ^7.0.0-pre.1
- version: 7.0.0-pre.1(@react-router/serve@7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3))(@types/node@22.7.4)(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(terser@5.34.1)(typescript@5.6.3)(vite@5.4.8(@types/node@22.7.4)(terser@5.34.1))
+ specifier: ^7.0.0-pre.2
+ version: 7.0.0-pre.2(@react-router/serve@7.0.0-pre.2(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3))(@types/node@22.7.4)(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(terser@5.34.1)(typescript@5.6.3)(vite@5.4.8(@types/node@22.7.4)(terser@5.34.1))
'@stoplight/prism-cli':
specifier: ^5.5.2
version: 5.8.1
@@ -1576,13 +1576,13 @@ packages:
resolution: {integrity: sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==}
engines: {node: '>=14'}
- '@react-router/dev@7.0.0-pre.1':
- resolution: {integrity: sha512-Nlp6YXuC2DSMJ7ZgfT/OBwRGlHvieO27WB+SrlL6ipqbi/Ut23UOQ3pn5+y2SS3h1+N6Y+uIOFlnEg8k9adT1g==}
- engines: {node: '>=18.0.0'}
+ '@react-router/dev@7.0.0-pre.2':
+ resolution: {integrity: sha512-clDNkfuZF1BGSr6VsnB/2vV061VVajBfq/vAVHxq7+OuC9W+wHqYOFmb4ve4E4oOVYQtYClA9xyBQqKh/wNGqw==}
+ engines: {node: '>=20.0.0'}
hasBin: true
peerDependencies:
- '@react-router/serve': ^7.0.0-pre.1
- react-router: ^7.0.0-pre.1
+ '@react-router/serve': ^7.0.0-pre.2
+ react-router: ^7.0.0-pre.2
typescript: ^5.1.0
vite: ^5.1.0
wrangler: ^3.28.2
@@ -1594,43 +1594,43 @@ packages:
wrangler:
optional: true
- '@react-router/express@7.0.0-pre.1':
- resolution: {integrity: sha512-24JCslUiirvBckOfRlZmJzr//xFUU2o585Aszf19Dpnga3s+2xCihNbAVIfyZ7kY/AVsJNIuJDo/oJX/STaY6w==}
- engines: {node: '>=18.0.0'}
+ '@react-router/express@7.0.0-pre.2':
+ resolution: {integrity: sha512-K0lbYzJoayqHjM9fYQvWHTkhf0rAdHz3hWjf09KzUMdEYIBLyHOnSORxF+nJaylqdOhXjS7AYUgltpkLs9hJ9g==}
+ engines: {node: '>=20.0.0'}
peerDependencies:
express: ^4.17.1
- react-router: 7.0.0-pre.1
+ react-router: 7.0.0-pre.2
typescript: ^5.1.0
peerDependenciesMeta:
typescript:
optional: true
- '@react-router/fs-routes@7.0.0-pre.1':
- resolution: {integrity: sha512-MQu2egp+5l5lPliWB33wLN/rZ4TMWCIPvbVjI1sdpy3NYhPan1/RDGAUAdIX5MddhLZm5DKQaxlKSxpiQutCug==}
- engines: {node: '>=18.0.0'}
+ '@react-router/fs-routes@7.0.0-pre.2':
+ resolution: {integrity: sha512-vprjIK/UAtP+gDqvlhh7FFR92Y84xpIx8Z045gbWTKEnYteZw3frOQx9aTkJ3gQFNsBrweT8C2p5MyokjiMMwA==}
+ engines: {node: '>=20.0.0'}
peerDependencies:
- '@react-router/dev': ^7.0.0-pre.1
+ '@react-router/dev': ^7.0.0-pre.2
typescript: ^5.1.0
peerDependenciesMeta:
typescript:
optional: true
- '@react-router/node@7.0.0-pre.1':
- resolution: {integrity: sha512-592GlQxAUcMSzyzeC28dvmLHJgq4uk2uGB9Lzouj9M7uINuFOdBMP/k+bjRD9m281fEB/TBpKsTVfrpnat//Ug==}
- engines: {node: '>=18.0.0'}
+ '@react-router/node@7.0.0-pre.2':
+ resolution: {integrity: sha512-jgXWGomzDQw3yq8EuPCE6AqOvNXT0omOqi2ziHC2Giff4yG5Av5R+OsqEK/NEXvINeAMYKnZ4KdgYVgrtiYKYw==}
+ engines: {node: '>=20.0.0'}
peerDependencies:
- react-router: 7.0.0-pre.1
+ react-router: 7.0.0-pre.2
typescript: ^5.1.0
peerDependenciesMeta:
typescript:
optional: true
- '@react-router/serve@7.0.0-pre.1':
- resolution: {integrity: sha512-WVfYNighCdg0SluI/WaUL1Fg5bvU5pGElLZlXE0jtwpb7NyuRNBl+h8exWbi4odzzfsipUMYGJEwPiX5FGiczw==}
- engines: {node: '>=18.0.0'}
+ '@react-router/serve@7.0.0-pre.2':
+ resolution: {integrity: sha512-WucoEL2kKPhIu0a+XILzExXo20X5j09TlPTzvLu7Sz0mddLLOFiViklJfalcQyAzKr5J7llQZnSH0zrm0BRAaw==}
+ engines: {node: '>=20.0.0'}
hasBin: true
peerDependencies:
- react-router: 7.0.0-pre.1
+ react-router: 7.0.0-pre.2
'@remix-run/router@1.20.0':
resolution: {integrity: sha512-mUnk8rPJBI9loFDZ+YzPGdeniYK+FTmRD1TMCz7ev2SNIozyKKpnGgsxO34u6Z4z/t0ITuu7voi/AshfsGsgFg==}
@@ -2591,10 +2591,6 @@ packages:
cookie-signature@1.0.6:
resolution: {integrity: sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==}
- cookie@0.6.0:
- resolution: {integrity: sha512-U71cyTamuh1CRNCfpGY6to28lxvNwPG4Guz/EVjgf3Jmzv0vlDp1atT9eS5dDjMYHucpHbWns6Lwf3BKz6svdw==}
- engines: {node: '>= 0.6'}
-
cookie@0.7.1:
resolution: {integrity: sha512-6DnInpx7SJ2AK3+CTUE/ZM0vWTUboZCegxhC2xiIydHR9jNuTAASBrfEpHhiGOZw/nX51bHt6YQl8jsGo4y/0w==}
engines: {node: '>= 0.6'}
@@ -2603,6 +2599,10 @@ packages:
resolution: {integrity: sha512-yki5XnKuf750l50uGTllt6kKILY4nQ1eNIQatoXEByZ5dWgnKqbnqmTrBE5B4N7lrMJKQ2ytWMiTO2o0v6Ew/w==}
engines: {node: '>= 0.6'}
+ cookie@1.0.1:
+ resolution: {integrity: sha512-Xd8lFX4LM9QEEwxQpF9J9NTUh8pmdJO0cyRJhFiDoLTk2eH8FXlRv2IFGYVadZpqI3j8fhNrSdKCeYPxiAhLXw==}
+ engines: {node: '>=18'}
+
core-util-is@1.0.3:
resolution: {integrity: sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==}
@@ -4592,9 +4592,9 @@ packages:
react: '>=16.8'
react-dom: '>=16.8'
- react-router-dom@7.0.0-pre.1:
- resolution: {integrity: sha512-HurKqnx581SLe0o/KI26X5UhJzQr+cdo6B58+LZORJYwTOlS1iM67jGLJwlfJa/QyDSdKq+1zFMVGdvXwF8Fzw==}
- engines: {node: '>=18.0.0'}
+ react-router-dom@7.0.0-pre.2:
+ resolution: {integrity: sha512-TJgsYrY5NLRntT8EJhXO8uqSLoc42wSCTwlgZ7Tuhts/Bz3xynnjmVM/k7EkDsTcsHiXdDZEaZfUy5Hv/s5wsw==}
+ engines: {node: '>=20.0.0'}
peerDependencies:
react: '>=18'
react-dom: '>=18'
@@ -4605,9 +4605,9 @@ packages:
peerDependencies:
react: '>=16.8'
- react-router@7.0.0-pre.1:
- resolution: {integrity: sha512-KAopqhQWpZUdIbSVGXBszhvHJjI20XBgYYwD83GL2uXFluKzb1SEw1XY4h3kg0wOT6WpQB7m655MJnk2CIBufQ==}
- engines: {node: '>=18.0.0'}
+ react-router@7.0.0-pre.2:
+ resolution: {integrity: sha512-SKt4Era+LiwvXnqM05MsogMF79DJ33Gw6TYDjjfQyuU9Rca5ub+DrU4UpQshB28PuXqcjMd5Zbo1H1eM0LQPhg==}
+ engines: {node: '>=20.0.0'}
peerDependencies:
react: '>=18'
react-dom: '>=18'
@@ -6038,16 +6038,16 @@ snapshots:
'@babel/helper-environment-visitor@7.24.7':
dependencies:
- '@babel/types': 7.24.7
+ '@babel/types': 7.25.9
'@babel/helper-function-name@7.24.7':
dependencies:
'@babel/template': 7.24.7
- '@babel/types': 7.24.7
+ '@babel/types': 7.25.9
'@babel/helper-hoist-variables@7.24.7':
dependencies:
- '@babel/types': 7.24.7
+ '@babel/types': 7.25.9
'@babel/helper-member-expression-to-functions@7.25.9':
dependencies:
@@ -6058,8 +6058,8 @@ snapshots:
'@babel/helper-module-imports@7.24.7':
dependencies:
- '@babel/traverse': 7.24.7
- '@babel/types': 7.24.7
+ '@babel/traverse': 7.25.9
+ '@babel/types': 7.25.9
transitivePeerDependencies:
- supports-color
@@ -6129,15 +6129,15 @@ snapshots:
'@babel/helper-simple-access@7.24.7':
dependencies:
- '@babel/traverse': 7.24.7
- '@babel/types': 7.24.7
+ '@babel/traverse': 7.25.9
+ '@babel/types': 7.25.9
transitivePeerDependencies:
- supports-color
'@babel/helper-simple-access@7.25.7':
dependencies:
- '@babel/traverse': 7.25.7
- '@babel/types': 7.25.7
+ '@babel/traverse': 7.25.9
+ '@babel/types': 7.25.9
transitivePeerDependencies:
- supports-color
@@ -6157,7 +6157,7 @@ snapshots:
'@babel/helper-split-export-declaration@7.24.7':
dependencies:
- '@babel/types': 7.24.7
+ '@babel/types': 7.25.9
'@babel/helper-string-parser@7.24.7': {}
@@ -6192,14 +6192,14 @@ snapshots:
'@babel/helper-validator-identifier': 7.24.7
chalk: 2.4.2
js-tokens: 4.0.0
- picocolors: 1.0.1
+ picocolors: 1.1.0
'@babel/highlight@7.25.7':
dependencies:
'@babel/helper-validator-identifier': 7.25.7
chalk: 2.4.2
js-tokens: 4.0.0
- picocolors: 1.0.1
+ picocolors: 1.1.0
'@babel/highlight@7.25.9':
dependencies:
@@ -6980,7 +6980,7 @@ snapshots:
'@pkgjs/parseargs@0.11.0':
optional: true
- '@react-router/dev@7.0.0-pre.1(@react-router/serve@7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3))(@types/node@22.7.4)(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(terser@5.34.1)(typescript@5.6.3)(vite@5.4.8(@types/node@22.7.4)(terser@5.34.1))':
+ '@react-router/dev@7.0.0-pre.2(@react-router/serve@7.0.0-pre.2(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3))(@types/node@22.7.4)(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(terser@5.34.1)(typescript@5.6.3)(vite@5.4.8(@types/node@22.7.4)(terser@5.34.1))':
dependencies:
'@babel/core': 7.25.7
'@babel/generator': 7.25.9
@@ -6991,7 +6991,7 @@ snapshots:
'@babel/traverse': 7.25.9
'@babel/types': 7.25.9
'@npmcli/package-json': 4.0.1
- '@react-router/node': 7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
+ '@react-router/node': 7.0.0-pre.2(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
arg: 5.0.2
babel-dead-code-elimination: 1.0.6
chalk: 4.1.2
@@ -7008,14 +7008,14 @@ snapshots:
picomatch: 2.3.1
prettier: 2.8.7
react-refresh: 0.14.2
- react-router: 7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
+ react-router: 7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
semver: 7.6.3
set-cookie-parser: 2.7.1
valibot: 0.41.0(typescript@5.6.3)
vite: 5.4.8(@types/node@22.7.4)(terser@5.34.1)
vite-node: 1.6.0(@types/node@22.7.4)(terser@5.34.1)
optionalDependencies:
- '@react-router/serve': 7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
+ '@react-router/serve': 7.0.0-pre.2(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
typescript: 5.6.3
transitivePeerDependencies:
- '@types/node'
@@ -7030,40 +7030,40 @@ snapshots:
- supports-color
- terser
- '@react-router/express@7.0.0-pre.1(express@4.21.1)(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)':
+ '@react-router/express@7.0.0-pre.2(express@4.21.1)(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)':
dependencies:
- '@react-router/node': 7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
+ '@react-router/node': 7.0.0-pre.2(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
express: 4.21.1
- react-router: 7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
+ react-router: 7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
optionalDependencies:
typescript: 5.6.3
- '@react-router/fs-routes@7.0.0-pre.1(@react-router/dev@7.0.0-pre.1(@react-router/serve@7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3))(@types/node@22.7.4)(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(terser@5.34.1)(typescript@5.6.3)(vite@5.4.8(@types/node@22.7.4)(terser@5.34.1)))(typescript@5.6.3)':
+ '@react-router/fs-routes@7.0.0-pre.2(@react-router/dev@7.0.0-pre.2(@react-router/serve@7.0.0-pre.2(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3))(@types/node@22.7.4)(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(terser@5.34.1)(typescript@5.6.3)(vite@5.4.8(@types/node@22.7.4)(terser@5.34.1)))(typescript@5.6.3)':
dependencies:
- '@react-router/dev': 7.0.0-pre.1(@react-router/serve@7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3))(@types/node@22.7.4)(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(terser@5.34.1)(typescript@5.6.3)(vite@5.4.8(@types/node@22.7.4)(terser@5.34.1))
+ '@react-router/dev': 7.0.0-pre.2(@react-router/serve@7.0.0-pre.2(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3))(@types/node@22.7.4)(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(terser@5.34.1)(typescript@5.6.3)(vite@5.4.8(@types/node@22.7.4)(terser@5.34.1))
minimatch: 9.0.4
optionalDependencies:
typescript: 5.6.3
- '@react-router/node@7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)':
+ '@react-router/node@7.0.0-pre.2(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)':
dependencies:
'@web3-storage/multipart-parser': 1.0.0
- react-router: 7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
+ react-router: 7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
source-map-support: 0.5.21
stream-slice: 0.1.2
undici: 6.20.1
optionalDependencies:
typescript: 5.6.3
- '@react-router/serve@7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)':
+ '@react-router/serve@7.0.0-pre.2(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)':
dependencies:
- '@react-router/express': 7.0.0-pre.1(express@4.21.1)(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
- '@react-router/node': 7.0.0-pre.1(react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
+ '@react-router/express': 7.0.0-pre.2(express@4.21.1)(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
+ '@react-router/node': 7.0.0-pre.2(react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.6.3)
compression: 1.7.4
express: 4.21.1
get-port: 5.1.1
morgan: 1.10.0
- react-router: 7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
+ react-router: 7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
source-map-support: 0.5.21
transitivePeerDependencies:
- supports-color
@@ -7733,7 +7733,7 @@ snapshots:
agent-base@6.0.2:
dependencies:
- debug: 4.3.5
+ debug: 4.3.7
transitivePeerDependencies:
- supports-color
@@ -8269,12 +8269,12 @@ snapshots:
cookie-signature@1.0.6: {}
- cookie@0.6.0: {}
-
cookie@0.7.1: {}
cookie@0.7.2: {}
+ cookie@1.0.1: {}
+
core-util-is@1.0.3: {}
create-require@1.1.1:
@@ -10753,22 +10753,22 @@ snapshots:
react-dom: 18.3.1(react@18.3.1)
react-router: 6.27.0(react@18.3.1)
- react-router-dom@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1):
+ react-router-dom@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1):
dependencies:
react: 18.3.1
react-dom: 18.3.1(react@18.3.1)
- react-router: 7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
+ react-router: 7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1)
react-router@6.27.0(react@18.3.1):
dependencies:
'@remix-run/router': 1.20.0
react: 18.3.1
- react-router@7.0.0-pre.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1):
+ react-router@7.0.0-pre.2(react-dom@18.3.1(react@18.3.1))(react@18.3.1):
dependencies:
'@types/cookie': 0.6.0
'@web3-storage/multipart-parser': 1.0.0
- cookie: 0.6.0
+ cookie: 1.0.1
react: 18.3.1
set-cookie-parser: 2.7.1
source-map: 0.7.4
@@ -11594,7 +11594,7 @@ snapshots:
typescript-auto-import-cache@0.3.3:
dependencies:
- semver: 7.6.2
+ semver: 7.6.3
typescript@5.4.5: {}
@@ -11689,7 +11689,7 @@ snapshots:
dependencies:
browserslist: 4.23.1
escalade: 3.1.2
- picocolors: 1.0.1
+ picocolors: 1.1.0
update-browserslist-db@1.1.1(browserslist@4.24.0):
dependencies:
From 6c6fb722d339abd21ffaa5e0b2634c79872da65b Mon Sep 17 00:00:00 2001
From: Bryan Thomas <49354825+bryanjtc@users.noreply.github.com>
Date: Thu, 24 Oct 2024 19:16:00 -0500
Subject: [PATCH 05/15] refactor: Simplify rr6 example
---
examples/react-router-6-app/package.json | 2 +-
examples/react-router-6-app/src/App.tsx | 15 +++++++--------
.../react-router-6-app/src/ClientFetchWrapper.tsx | 11 -----------
examples/react-router-6-app/src/axios.ts | 2 +-
examples/react-router-6-app/src/main.tsx | 5 +----
5 files changed, 10 insertions(+), 25 deletions(-)
delete mode 100644 examples/react-router-6-app/src/ClientFetchWrapper.tsx
diff --git a/examples/react-router-6-app/package.json b/examples/react-router-6-app/package.json
index 800f835..761c156 100644
--- a/examples/react-router-6-app/package.json
+++ b/examples/react-router-6-app/package.json
@@ -9,7 +9,7 @@
"dev:mock": "prism mock ../petstore.yaml --dynamic",
"build": "tsc && vite build",
"preview": "vite preview",
- "generate:api": "rimraf ./openapi && node ../../dist/cli.mjs -i ../petstore.yaml --format=biome --lint=biome -c @hey-api/client-axios",
+ "generate:api": "rimraf ./openapi && node ../../dist/cli.mjs -i ../petstore.yaml --format=biome --lint=biome",
"test:generated": "tsc -p ./tsconfig.json --noEmit"
},
"dependencies": {
diff --git a/examples/react-router-6-app/src/App.tsx b/examples/react-router-6-app/src/App.tsx
index 00e63d8..b4f1376 100644
--- a/examples/react-router-6-app/src/App.tsx
+++ b/examples/react-router-6-app/src/App.tsx
@@ -1,22 +1,21 @@
import "./App.css";
-import { useState } from "react";
-
-import type { Options } from "@hey-api/client-axios";
import type { QueryClient } from "@tanstack/react-query";
+import { useState } from "react";
import { type LoaderFunctionArgs, useLoaderData } from "react-router-dom";
import { UseFindPetsKeyFn, useAddPet } from "../openapi/queries";
import { ensureUseFindPetsData } from "../openapi/queries/ensureQueryData";
import { useFindPetsSuspense } from "../openapi/queries/suspense";
-import type { FindPetsData } from "../openapi/requests/types.gen";
import { queryClient } from "./queryClient";
export const loader =
(queryClient: QueryClient) => async (_: LoaderFunctionArgs) => {
- const queryParameters: Options = {
+ const queryParameters = {
query: { tags: [], limit: 10 },
};
- await ensureUseFindPetsData(queryClient, queryParameters);
+ await ensureUseFindPetsData(queryClient, {
+ query: { tags: [], limit: 10 },
+ });
return queryParameters;
};
@@ -66,8 +65,8 @@ export function Compoment() {
console.log("success");
},
onError: (error) => {
- console.log(error.response);
- setErrorText(`Error: ${error.response?.data.message}`);
+ console.log(error.message);
+ setErrorText(`Error: ${error.message}`);
},
},
);
diff --git a/examples/react-router-6-app/src/ClientFetchWrapper.tsx b/examples/react-router-6-app/src/ClientFetchWrapper.tsx
deleted file mode 100644
index 2a30ee7..0000000
--- a/examples/react-router-6-app/src/ClientFetchWrapper.tsx
+++ /dev/null
@@ -1,11 +0,0 @@
-import { createClient } from "@hey-api/client-fetch";
-
-export function ClientFetchWrapper({
- children,
-}: {
- children: React.ReactNode;
-}) {
- createClient({ baseUrl: "http://localhost:4010" });
-
- return <>{children}>;
-}
diff --git a/examples/react-router-6-app/src/axios.ts b/examples/react-router-6-app/src/axios.ts
index 22aaac4..f1c0877 100644
--- a/examples/react-router-6-app/src/axios.ts
+++ b/examples/react-router-6-app/src/axios.ts
@@ -1,6 +1,6 @@
import { client } from "../openapi/requests/services.gen";
client.setConfig({
- baseURL: "http://localhost:4010",
+ baseUrl: "http://localhost:4010",
throwOnError: true,
});
diff --git a/examples/react-router-6-app/src/main.tsx b/examples/react-router-6-app/src/main.tsx
index 1637108..5656b4d 100644
--- a/examples/react-router-6-app/src/main.tsx
+++ b/examples/react-router-6-app/src/main.tsx
@@ -7,7 +7,6 @@ import { ReactQueryDevtools } from "@tanstack/react-query-devtools";
import { queryClient } from "./queryClient";
import "./axios";
import { RouterProvider, createBrowserRouter } from "react-router-dom";
-import { ClientFetchWrapper } from "./ClientFetchWrapper";
const router = createBrowserRouter([
{
@@ -20,9 +19,7 @@ const router = createBrowserRouter([
ReactDOM.createRoot(document.getElementById("root") as HTMLElement).render(
-
-
-
+
,
From 7be80c16c29db1f66a86bf65188ddecc79238442 Mon Sep 17 00:00:00 2001
From: Bryan Thomas <49354825+bryanjtc@users.noreply.github.com>
Date: Thu, 24 Oct 2024 19:16:27 -0500
Subject: [PATCH 06/15] fix: Correct import path
---
examples/react-router-7-app/fetchClient.ts | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/examples/react-router-7-app/fetchClient.ts b/examples/react-router-7-app/fetchClient.ts
index 1cc5028..6fc2ae9 100644
--- a/examples/react-router-7-app/fetchClient.ts
+++ b/examples/react-router-7-app/fetchClient.ts
@@ -1,6 +1,6 @@
-import { client } from "../react-app/openapi/requests/services.gen";
+import { client } from "./openapi/requests/services.gen";
client.setConfig({
- baseURL: "http://localhost:4010",
+ baseUrl: "http://localhost:4010",
throwOnError: true,
});
From 8877342c003652656ba751cfd373370539197faa Mon Sep 17 00:00:00 2001
From: Bryan Thomas <49354825+bryanjtc@users.noreply.github.com>
Date: Thu, 24 Oct 2024 19:43:00 -0500
Subject: [PATCH 07/15] refactor: Use simplier file convention
---
.../{app/routes/_index => }/App.css | 0
examples/react-router-7-app/app/root.tsx | 2 +-
.../app/routes/{_index/route.tsx => _index.tsx} | 13 +++++++------
examples/react-router-7-app/{app => }/index.css | 0
examples/react-router-7-app/providers.tsx | 2 +-
5 files changed, 9 insertions(+), 8 deletions(-)
rename examples/react-router-7-app/{app/routes/_index => }/App.css (100%)
rename examples/react-router-7-app/app/routes/{_index/route.tsx => _index.tsx} (90%)
rename examples/react-router-7-app/{app => }/index.css (100%)
diff --git a/examples/react-router-7-app/app/routes/_index/App.css b/examples/react-router-7-app/App.css
similarity index 100%
rename from examples/react-router-7-app/app/routes/_index/App.css
rename to examples/react-router-7-app/App.css
diff --git a/examples/react-router-7-app/app/root.tsx b/examples/react-router-7-app/app/root.tsx
index 314613e..fa0ce86 100644
--- a/examples/react-router-7-app/app/root.tsx
+++ b/examples/react-router-7-app/app/root.tsx
@@ -1,4 +1,4 @@
-import "./index.css";
+import "../index.css";
import { Outlet, Scripts, ScrollRestoration } from "react-router";
import Providers from "../providers";
diff --git a/examples/react-router-7-app/app/routes/_index/route.tsx b/examples/react-router-7-app/app/routes/_index.tsx
similarity index 90%
rename from examples/react-router-7-app/app/routes/_index/route.tsx
rename to examples/react-router-7-app/app/routes/_index.tsx
index 5009238..921b407 100644
--- a/examples/react-router-7-app/app/routes/_index/route.tsx
+++ b/examples/react-router-7-app/app/routes/_index.tsx
@@ -1,4 +1,4 @@
-import "./App.css";
+import "../../App.css";
import { useState } from "react";
import {
@@ -11,11 +11,11 @@ import {
UseFindPetsKeyFn,
useAddPet,
useFindPets,
-} from "../../../openapi/queries";
-import { prefetchUseFindPets } from "../../../openapi/queries/prefetch";
-import { queryClient } from "../../../queryClient";
+} from "../../openapi/queries";
+import { prefetchUseFindPets } from "../../openapi/queries/prefetch";
+import { queryClient } from "../../queryClient";
-export const loader = async () => {
+export async function loader() {
const queryClient = new QueryClient();
await prefetchUseFindPets(queryClient, {
@@ -23,7 +23,7 @@ export const loader = async () => {
});
return { dehydratedState: dehydrate(queryClient) };
-};
+}
function Pets() {
const { data, error, refetch } = useFindPets({
@@ -101,6 +101,7 @@ function Pets() {
export function Component({ loaderData }) {
const { dehydratedState } = loaderData;
+ console.log(dehydratedState);
return (
diff --git a/examples/react-router-7-app/app/index.css b/examples/react-router-7-app/index.css
similarity index 100%
rename from examples/react-router-7-app/app/index.css
rename to examples/react-router-7-app/index.css
diff --git a/examples/react-router-7-app/providers.tsx b/examples/react-router-7-app/providers.tsx
index ce94ad7..6ab1da2 100644
--- a/examples/react-router-7-app/providers.tsx
+++ b/examples/react-router-7-app/providers.tsx
@@ -1,6 +1,6 @@
+import "./fetchClient";
import { QueryClientProvider } from "@tanstack/react-query";
import { ReactQueryDevtools } from "@tanstack/react-query-devtools";
-import "./fetchClient";
import { queryClient } from "./queryClient";
export default function Providers({ children }: { children: React.ReactNode }) {
From ab8d3e5e6d7abd26b538bb96034c05e6545ed92a Mon Sep 17 00:00:00 2001
From: Bryan Thomas <49354825+bryanjtc@users.noreply.github.com>
Date: Thu, 24 Oct 2024 19:43:27 -0500
Subject: [PATCH 08/15] refactor: Remove console log from Component
---
examples/react-router-7-app/app/routes/_index.tsx | 1 -
1 file changed, 1 deletion(-)
diff --git a/examples/react-router-7-app/app/routes/_index.tsx b/examples/react-router-7-app/app/routes/_index.tsx
index 921b407..5901e75 100644
--- a/examples/react-router-7-app/app/routes/_index.tsx
+++ b/examples/react-router-7-app/app/routes/_index.tsx
@@ -101,7 +101,6 @@ function Pets() {
export function Component({ loaderData }) {
const { dehydratedState } = loaderData;
- console.log(dehydratedState);
return (
From 60558d033296f39d3279d96d24b290813d4aa2fd Mon Sep 17 00:00:00 2001
From: Bryan Thomas <49354825+bryanjtc@users.noreply.github.com>
Date: Thu, 24 Oct 2024 20:27:09 -0500
Subject: [PATCH 09/15] refactor: Update import paths and rename index file
---
examples/react-router-7-app/{ => app}/index.css | 0
examples/react-router-7-app/app/root.tsx | 2 +-
.../react-router-7-app/{ => app/routes/_index}/App.css | 0
.../app/routes/{_index.tsx => _index/route.tsx} | 10 +++++-----
4 files changed, 6 insertions(+), 6 deletions(-)
rename examples/react-router-7-app/{ => app}/index.css (100%)
rename examples/react-router-7-app/{ => app/routes/_index}/App.css (100%)
rename examples/react-router-7-app/app/routes/{_index.tsx => _index/route.tsx} (90%)
diff --git a/examples/react-router-7-app/index.css b/examples/react-router-7-app/app/index.css
similarity index 100%
rename from examples/react-router-7-app/index.css
rename to examples/react-router-7-app/app/index.css
diff --git a/examples/react-router-7-app/app/root.tsx b/examples/react-router-7-app/app/root.tsx
index fa0ce86..314613e 100644
--- a/examples/react-router-7-app/app/root.tsx
+++ b/examples/react-router-7-app/app/root.tsx
@@ -1,4 +1,4 @@
-import "../index.css";
+import "./index.css";
import { Outlet, Scripts, ScrollRestoration } from "react-router";
import Providers from "../providers";
diff --git a/examples/react-router-7-app/App.css b/examples/react-router-7-app/app/routes/_index/App.css
similarity index 100%
rename from examples/react-router-7-app/App.css
rename to examples/react-router-7-app/app/routes/_index/App.css
diff --git a/examples/react-router-7-app/app/routes/_index.tsx b/examples/react-router-7-app/app/routes/_index/route.tsx
similarity index 90%
rename from examples/react-router-7-app/app/routes/_index.tsx
rename to examples/react-router-7-app/app/routes/_index/route.tsx
index 5901e75..5b971b1 100644
--- a/examples/react-router-7-app/app/routes/_index.tsx
+++ b/examples/react-router-7-app/app/routes/_index/route.tsx
@@ -1,4 +1,3 @@
-import "../../App.css";
import { useState } from "react";
import {
@@ -11,9 +10,10 @@ import {
UseFindPetsKeyFn,
useAddPet,
useFindPets,
-} from "../../openapi/queries";
-import { prefetchUseFindPets } from "../../openapi/queries/prefetch";
-import { queryClient } from "../../queryClient";
+} from "../../../openapi/queries";
+import { prefetchUseFindPets } from "../../../openapi/queries/prefetch";
+import { queryClient } from "../../../queryClient";
+import "./App.css";
export async function loader() {
const queryClient = new QueryClient();
@@ -99,7 +99,7 @@ function Pets() {
);
}
-export function Component({ loaderData }) {
+export default function Index({ loaderData }) {
const { dehydratedState } = loaderData;
return (
From 697a871063b2e74d6b8d23b08f8c41c687a2d3ca Mon Sep 17 00:00:00 2001
From: Bryan Thomas <49354825+bryanjtc@users.noreply.github.com>
Date: Thu, 24 Oct 2024 20:42:38 -0500
Subject: [PATCH 10/15] refactor: Remove entry.client.tsx and update tsconfig
for improved type handling
---
.../react-router-7-app/app/entry.client.tsx | 12 ----
.../app/routes/_index/route.tsx | 1 -
examples/react-router-7-app/tsconfig.json | 56 +++++++++----------
3 files changed, 27 insertions(+), 42 deletions(-)
delete mode 100644 examples/react-router-7-app/app/entry.client.tsx
diff --git a/examples/react-router-7-app/app/entry.client.tsx b/examples/react-router-7-app/app/entry.client.tsx
deleted file mode 100644
index bc83c1d..0000000
--- a/examples/react-router-7-app/app/entry.client.tsx
+++ /dev/null
@@ -1,12 +0,0 @@
-import React from "react";
-import ReactDOM from "react-dom/client";
-import { HydratedRouter } from "react-router/dom";
-import { routes } from "./routes";
-
-ReactDOM.hydrateRoot(
- document,
-
- {/* @ts-expect-error */}
-
- ,
-);
diff --git a/examples/react-router-7-app/app/routes/_index/route.tsx b/examples/react-router-7-app/app/routes/_index/route.tsx
index 5b971b1..ff7b170 100644
--- a/examples/react-router-7-app/app/routes/_index/route.tsx
+++ b/examples/react-router-7-app/app/routes/_index/route.tsx
@@ -5,7 +5,6 @@ import {
QueryClient,
dehydrate,
} from "@tanstack/react-query";
-import React from "react";
import {
UseFindPetsKeyFn,
useAddPet,
diff --git a/examples/react-router-7-app/tsconfig.json b/examples/react-router-7-app/tsconfig.json
index 7a35035..ccd2bc8 100644
--- a/examples/react-router-7-app/tsconfig.json
+++ b/examples/react-router-7-app/tsconfig.json
@@ -1,35 +1,33 @@
{
+ "include": [
+ "**/*.ts",
+ "**/*.tsx",
+ "**/.server/**/*.ts",
+ "**/.server/**/*.tsx",
+ "**/.client/**/*.ts",
+ "**/.client/**/*.tsx",
+ ".react-router/types/**/*"
+ ],
"compilerOptions": {
- "target": "ESNext",
- "useDefineForClassFields": true,
- "lib": ["DOM", "DOM.Iterable", "ESNext"],
- "allowJs": false,
- "skipLibCheck": true,
- "esModuleInterop": false,
- "allowSyntheticDefaultImports": true,
- "strict": true,
- "forceConsistentCasingInFileNames": true,
+ "lib": ["DOM", "DOM.Iterable", "ES2022"],
+ "types": ["@react-router/node", "vite/client"],
+ "isolatedModules": true,
+ "esModuleInterop": true,
+ "jsx": "react-jsx",
"module": "ESNext",
"moduleResolution": "Bundler",
"resolveJsonModule": true,
- "isolatedModules": true,
+ "target": "ES2022",
+ "strict": true,
+ "allowJs": true,
+ "skipLibCheck": true,
+ "forceConsistentCasingInFileNames": true,
+ "baseUrl": ".",
+ "paths": {
+ "~/*": ["./app/*"]
+ },
"noEmit": true,
- "jsx": "react-jsx"
- },
- "include": [
- "src",
- "app/root.tsx",
- "app/entry.client.tsx",
- "queryClient.tsx",
- "ClientFetchWrapper.tsx",
- "fetchClient.ts",
- "app/routes.ts",
- "vite-env.d.ts",
- "providers.tsx"
- ],
- "references": [
- {
- "path": "./tsconfig.node.json"
- }
- ]
-}
+ "rootDirs": [".", "./.react-router/types"],
+ "plugins": [{ "name": "@react-router/dev" }]
+ }
+}
\ No newline at end of file
From 652df013208d68cd25a7c0b5274d2bfd22296a4a Mon Sep 17 00:00:00 2001
From: Bryan Thomas <49354825+bryanjtc@users.noreply.github.com>
Date: Fri, 25 Oct 2024 08:40:35 -0500
Subject: [PATCH 11/15] refactor: Update query client handling and improve type
definitions
---
examples/react-router-7-app/.gitignore | 2 ++
.../app/routes/_index/route.tsx | 9 ++++++---
examples/react-router-7-app/package.json | 3 ++-
examples/react-router-7-app/providers.tsx | 16 +++++++++++++++-
examples/react-router-7-app/queryClient.tsx | 3 ---
5 files changed, 25 insertions(+), 8 deletions(-)
delete mode 100644 examples/react-router-7-app/queryClient.tsx
diff --git a/examples/react-router-7-app/.gitignore b/examples/react-router-7-app/.gitignore
index a547bf3..7824ebe 100644
--- a/examples/react-router-7-app/.gitignore
+++ b/examples/react-router-7-app/.gitignore
@@ -22,3 +22,5 @@ dist-ssr
*.njsproj
*.sln
*.sw?
+
+.react-router
\ No newline at end of file
diff --git a/examples/react-router-7-app/app/routes/_index/route.tsx b/examples/react-router-7-app/app/routes/_index/route.tsx
index ff7b170..b432f78 100644
--- a/examples/react-router-7-app/app/routes/_index/route.tsx
+++ b/examples/react-router-7-app/app/routes/_index/route.tsx
@@ -11,10 +11,10 @@ import {
useFindPets,
} from "../../../openapi/queries";
import { prefetchUseFindPets } from "../../../openapi/queries/prefetch";
-import { queryClient } from "../../../queryClient";
import "./App.css";
+import type * as Route from "./+types.route"
-export async function loader() {
+export async function loader({ params }: Route.LoaderArgs) {
const queryClient = new QueryClient();
await prefetchUseFindPets(queryClient, {
@@ -25,10 +25,13 @@ export async function loader() {
}
function Pets() {
+ const queryClient = new QueryClient();
const { data, error, refetch } = useFindPets({
query: { tags: [], limit: 10 },
});
+ console.log(data);
+
const { mutate: addPet, isError } = useAddPet();
const [text, setText] = useState("");
@@ -98,7 +101,7 @@ function Pets() {
);
}
-export default function Index({ loaderData }) {
+export default function Index({ loaderData }: Route.ComponentProps) {
const { dehydratedState } = loaderData;
return (
diff --git a/examples/react-router-7-app/package.json b/examples/react-router-7-app/package.json
index 71daf1b..8770cb1 100644
--- a/examples/react-router-7-app/package.json
+++ b/examples/react-router-7-app/package.json
@@ -10,7 +10,8 @@
"build": "tsc && react-router build",
"preview": "react-router-serve ./build/server/index.js",
"generate:api": "rimraf ./openapi && node ../../dist/cli.mjs -i ../petstore.yaml --format=biome --lint=biome",
- "test:generated": "tsc -p ./tsconfig.json --noEmit"
+ "test:generated": "tsc -p ./tsconfig.json --noEmit",
+ "typegen": "react-router typegen"
},
"dependencies": {
"@react-router/fs-routes": "^7.0.0-pre.2",
diff --git a/examples/react-router-7-app/providers.tsx b/examples/react-router-7-app/providers.tsx
index 6ab1da2..6a8c3c1 100644
--- a/examples/react-router-7-app/providers.tsx
+++ b/examples/react-router-7-app/providers.tsx
@@ -1,9 +1,23 @@
import "./fetchClient";
import { QueryClientProvider } from "@tanstack/react-query";
import { ReactQueryDevtools } from "@tanstack/react-query-devtools";
-import { queryClient } from "./queryClient";
+import { QueryClient } from "@tanstack/react-query";
+import React from "react";
export default function Providers({ children }: { children: React.ReactNode }) {
+ const [queryClient] = React.useState(
+ () =>
+ new QueryClient({
+ defaultOptions: {
+ queries: {
+ // With SSR, we usually want to set some default staleTime
+ // above 0 to avoid refetching immediately on the client
+ staleTime: 30 * 1000,
+ },
+ },
+ }),
+ )
+
return (
{children}
diff --git a/examples/react-router-7-app/queryClient.tsx b/examples/react-router-7-app/queryClient.tsx
deleted file mode 100644
index 6c7b9de..0000000
--- a/examples/react-router-7-app/queryClient.tsx
+++ /dev/null
@@ -1,3 +0,0 @@
-import { QueryClient } from "@tanstack/react-query";
-
-export const queryClient = new QueryClient();
From 91eeca1ad6c6827bff2e8664e36423a20827c2e6 Mon Sep 17 00:00:00 2001
From: Bryan Thomas <49354825+bryanjtc@users.noreply.github.com>
Date: Fri, 25 Oct 2024 08:44:01 -0500
Subject: [PATCH 12/15] docs: Add examples for React Router 6 and 7 integration
---
docs/src/content/docs/examples/react-router-6.md | 6 ++++++
docs/src/content/docs/examples/react-router-7.md | 6 ++++++
examples/react-router-7-app/app/routes/_index/route.tsx | 6 ++----
3 files changed, 14 insertions(+), 4 deletions(-)
create mode 100644 docs/src/content/docs/examples/react-router-6.md
create mode 100644 docs/src/content/docs/examples/react-router-7.md
diff --git a/docs/src/content/docs/examples/react-router-6.md b/docs/src/content/docs/examples/react-router-6.md
new file mode 100644
index 0000000..b305373
--- /dev/null
+++ b/docs/src/content/docs/examples/react-router-6.md
@@ -0,0 +1,6 @@
+---
+title: React Router 6 Example
+description: A simple example of using React Router 6 with OpenAPI React Query Codegen.
+---
+
+Example of using React Router 6 can be found in the [`examples/react-router-6-app`](https://github.com/7nohe/openapi-react-query-codegen/tree/main/examples/react-router-6-app) directory of the repository.
diff --git a/docs/src/content/docs/examples/react-router-7.md b/docs/src/content/docs/examples/react-router-7.md
new file mode 100644
index 0000000..7652648
--- /dev/null
+++ b/docs/src/content/docs/examples/react-router-7.md
@@ -0,0 +1,6 @@
+---
+title: React Router 7 Example
+description: A simple example of using React Router 7 with OpenAPI React Query Codegen.
+---
+
+Example of using React Router 7 can be found in the [`examples/react-router-7-app`](https://github.com/7nohe/openapi-react-query-codegen/tree/main/examples/react-router-7-app) directory of the repository.
diff --git a/examples/react-router-7-app/app/routes/_index/route.tsx b/examples/react-router-7-app/app/routes/_index/route.tsx
index b432f78..b4cc894 100644
--- a/examples/react-router-7-app/app/routes/_index/route.tsx
+++ b/examples/react-router-7-app/app/routes/_index/route.tsx
@@ -4,6 +4,7 @@ import {
HydrationBoundary,
QueryClient,
dehydrate,
+ useQueryClient,
} from "@tanstack/react-query";
import {
UseFindPetsKeyFn,
@@ -25,13 +26,11 @@ export async function loader({ params }: Route.LoaderArgs) {
}
function Pets() {
- const queryClient = new QueryClient();
+ const queryClient = useQueryClient();
const { data, error, refetch } = useFindPets({
query: { tags: [], limit: 10 },
});
- console.log(data);
-
const { mutate: addPet, isError } = useAddPet();
const [text, setText] = useState("");
@@ -70,7 +69,6 @@ function Pets() {
query: { tags: [], limit: 10 },
}),
});
- console.log("success");
},
onError: (error) => {
console.log(error.message);
From f94a30cfb92050e952ee6e33b5d1afa82260cbed Mon Sep 17 00:00:00 2001
From: Bryan Thomas <49354825+bryanjtc@users.noreply.github.com>
Date: Fri, 25 Oct 2024 09:03:04 -0500
Subject: [PATCH 13/15] refactor: Update build and typecheck scripts in React
Router 7 example
---
examples/react-router-7-app/.gitignore | 3 ++-
examples/react-router-7-app/package.json | 9 +++++----
2 files changed, 7 insertions(+), 5 deletions(-)
diff --git a/examples/react-router-7-app/.gitignore b/examples/react-router-7-app/.gitignore
index 7824ebe..c2fd82b 100644
--- a/examples/react-router-7-app/.gitignore
+++ b/examples/react-router-7-app/.gitignore
@@ -23,4 +23,5 @@ dist-ssr
*.sln
*.sw?
-.react-router
\ No newline at end of file
+.react-router
+build
\ No newline at end of file
diff --git a/examples/react-router-7-app/package.json b/examples/react-router-7-app/package.json
index 8770cb1..ef3056a 100644
--- a/examples/react-router-7-app/package.json
+++ b/examples/react-router-7-app/package.json
@@ -7,11 +7,12 @@
"dev": "run-p dev:mock dev:client",
"dev:client": "react-router dev",
"dev:mock": "prism mock ../petstore.yaml --dynamic",
- "build": "tsc && react-router build",
+ "build": "pnpm typecheck && react-router build",
"preview": "react-router-serve ./build/server/index.js",
+ "typegen": "react-router typegen",
+ "typecheck": "pnpm typegen && tsc",
"generate:api": "rimraf ./openapi && node ../../dist/cli.mjs -i ../petstore.yaml --format=biome --lint=biome",
- "test:generated": "tsc -p ./tsconfig.json --noEmit",
- "typegen": "react-router typegen"
+ "test:generated": "tsc -p ./tsconfig.json --noEmit"
},
"dependencies": {
"@react-router/fs-routes": "^7.0.0-pre.2",
@@ -37,4 +38,4 @@
"typescript": "^5.4.5",
"vite": "^5.0.12"
}
-}
+}
\ No newline at end of file
From 092bde2bf6e16734090ebb8f972eb6b86ee5a822 Mon Sep 17 00:00:00 2001
From: Bryan Thomas <49354825+bryanjtc@users.noreply.github.com>
Date: Fri, 25 Oct 2024 19:28:26 -0500
Subject: [PATCH 14/15] lint: Update biome.json
---
biome.json | 2 ++
1 file changed, 2 insertions(+)
diff --git a/biome.json b/biome.json
index 271bd01..cf26d43 100644
--- a/biome.json
+++ b/biome.json
@@ -13,6 +13,8 @@
"examples/nextjs-app/.next",
"examples/tanstack-router-app/openapi",
"examples/tanstack-router-app/src/routeTree.gen.ts",
+ "examples/react-router-6-app/openapi",
+ "examples/react-router-7-app/openapi",
"docs/.astro"
]
},
From f304cc69435616b9deb3d80758658c13935cb64e Mon Sep 17 00:00:00 2001
From: Urata Daiki <7nohe@users.noreply.github.com>
Date: Sat, 26 Oct 2024 15:25:29 +0900
Subject: [PATCH 15/15] chore: Run `lint:fix`
---
examples/react-router-7-app/app/routes/_index/route.tsx | 2 +-
examples/react-router-7-app/package.json | 2 +-
examples/react-router-7-app/providers.tsx | 4 ++--
examples/react-router-7-app/tsconfig.json | 2 +-
4 files changed, 5 insertions(+), 5 deletions(-)
diff --git a/examples/react-router-7-app/app/routes/_index/route.tsx b/examples/react-router-7-app/app/routes/_index/route.tsx
index b4cc894..1d9abbc 100644
--- a/examples/react-router-7-app/app/routes/_index/route.tsx
+++ b/examples/react-router-7-app/app/routes/_index/route.tsx
@@ -13,7 +13,7 @@ import {
} from "../../../openapi/queries";
import { prefetchUseFindPets } from "../../../openapi/queries/prefetch";
import "./App.css";
-import type * as Route from "./+types.route"
+import type * as Route from "./+types.route";
export async function loader({ params }: Route.LoaderArgs) {
const queryClient = new QueryClient();
diff --git a/examples/react-router-7-app/package.json b/examples/react-router-7-app/package.json
index ef3056a..8a28a49 100644
--- a/examples/react-router-7-app/package.json
+++ b/examples/react-router-7-app/package.json
@@ -38,4 +38,4 @@
"typescript": "^5.4.5",
"vite": "^5.0.12"
}
-}
\ No newline at end of file
+}
diff --git a/examples/react-router-7-app/providers.tsx b/examples/react-router-7-app/providers.tsx
index 6a8c3c1..070cf98 100644
--- a/examples/react-router-7-app/providers.tsx
+++ b/examples/react-router-7-app/providers.tsx
@@ -1,7 +1,7 @@
import "./fetchClient";
import { QueryClientProvider } from "@tanstack/react-query";
-import { ReactQueryDevtools } from "@tanstack/react-query-devtools";
import { QueryClient } from "@tanstack/react-query";
+import { ReactQueryDevtools } from "@tanstack/react-query-devtools";
import React from "react";
export default function Providers({ children }: { children: React.ReactNode }) {
@@ -16,7 +16,7 @@ export default function Providers({ children }: { children: React.ReactNode }) {
},
},
}),
- )
+ );
return (
diff --git a/examples/react-router-7-app/tsconfig.json b/examples/react-router-7-app/tsconfig.json
index ccd2bc8..29b2316 100644
--- a/examples/react-router-7-app/tsconfig.json
+++ b/examples/react-router-7-app/tsconfig.json
@@ -30,4 +30,4 @@
"rootDirs": [".", "./.react-router/types"],
"plugins": [{ "name": "@react-router/dev" }]
}
-}
\ No newline at end of file
+}