diff --git a/.env.local.example b/.env.local.example
new file mode 100644
index 0000000000000000000000000000000000000000..84d370c73177e50fe9a45330d36c84ad511dfb66
--- /dev/null
+++ b/.env.local.example
@@ -0,0 +1,4 @@
+VITE_AUTH0_DOMAIN=
+VITE_AUTH0_CLIENT_ID=
+VITE_JWT_AUDIENCE=
+VITE_JWT_ISSUER=
\ No newline at end of file
diff --git a/.eslintrc.cjs b/.eslintrc.cjs
new file mode 100644
index 0000000000000000000000000000000000000000..ee8cdb225c224b48374c6c5dfa99962b51a34608
--- /dev/null
+++ b/.eslintrc.cjs
@@ -0,0 +1,18 @@
+module.exports = {
+ root: true,
+ env: { browser: true, es2020: true },
+ extends: [
+ 'eslint:recommended',
+ 'plugin:@typescript-eslint/recommended',
+ 'plugin:react-hooks/recommended'
+ ],
+ ignorePatterns: ['dist', '.eslintrc.cjs'],
+ parser: '@typescript-eslint/parser',
+ plugins: ['react-refresh'],
+ rules: {
+ 'react-refresh/only-export-components': [
+ 'warn',
+ { allowConstantExport: true }
+ ]
+ }
+};
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000000000000000000000000000000000000..a547bf36d8d11a4f89c59c144f24795749086dd1
--- /dev/null
+++ b/.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/.prettierrc b/.prettierrc
new file mode 100644
index 0000000000000000000000000000000000000000..8167e85fea438968df8784d7f7117617920d192f
--- /dev/null
+++ b/.prettierrc
@@ -0,0 +1,9 @@
+{
+ "semi": true,
+ "singleQuote": true,
+ "printWidth": 80,
+ "tabWidth": 2,
+ "useTabs": false,
+ "trailingComma": "none",
+ "bracketSpacing": true
+}
diff --git a/Dockerfile b/Dockerfile
new file mode 100644
index 0000000000000000000000000000000000000000..a3cbe04e6f5fb58ad2b01c076710df7113f5eacf
--- /dev/null
+++ b/Dockerfile
@@ -0,0 +1,62 @@
+FROM node:current-bullseye-slim as dev
+
+WORKDIR /app
+
+COPY ./package.json .
+COPY ./package-lock.json .
+
+RUN npm install
+
+RUN echo "VITE_AUTH0_DOMAIN=$VITE_AUTH0_DOMAIN" > .env.local && \
+ echo "VITE_AUTH0_CLIENT_ID=$VITE_AUTH0_CLIENT_ID" >> .env.local && \
+ echo "VITE_JWT_AUDIENCE=$VITE_JWT_AUDIENCE" >> .env.local && \
+ echo "VITE_JWT_ISSUER=$VITE_JWT_ISSUER" >> .env.local
+
+COPY entrypoint.sh ./entrypoint.sh
+
+RUN ["chmod", "+x", "entrypoint.sh"]
+ENTRYPOINT ["/app/entrypoint.sh"]
+
+FROM node:current-bullseye-slim as prod
+
+ARG VITE_AUTH0_DOMAIN
+ARG VITE_AUTH0_CLIENT_ID
+ARG VITE_JWT_AUDIENCE
+ARG VITE_JWT_ISSUER
+
+ENV VITE_AUTH0_DOMAIN=$VITE_AUTH0_DOMAIN \
+ VITE_AUTH0_CLIENT_ID=$VITE_AUTH0_CLIENT_ID \
+ VITE_JWT_AUDIENCE=$VITE_JWT_AUDIENCE \
+ VITE_JWT_ISSUER=$VITE_JWT_ISSUER
+
+WORKDIR /app
+
+COPY package.json package-lock.json ./
+
+RUN npm install
+
+RUN echo "VITE_AUTH0_DOMAIN=$VITE_AUTH0_DOMAIN" > .env.production.local && \
+ echo "VITE_AUTH0_CLIENT_ID=$VITE_AUTH0_CLIENT_ID" >> .env.production.local && \
+ echo "VITE_JWT_AUDIENCE=$VITE_JWT_AUDIENCE" >> .env.production.local && \
+ echo "VITE_JWT_ISSUER=$VITE_JWT_ISSUER" >> .env.production.local
+
+COPY . .
+
+RUN npm run build
+
+# Prod Stage
+FROM nginx:stable-alpine
+
+WORKDIR /usr/share/nginx/html
+
+RUN rm -rf ./*
+
+RUN mkdir -p /etc/nginx/ssl
+
+COPY --from=prod /app/dist .
+
+COPY nginx.conf /etc/nginx/conf.d/default.conf
+
+EXPOSE 80
+
+CMD ["nginx", "-g", "daemon off;"]
diff --git a/README copy.md b/README copy.md
new file mode 100644
index 0000000000000000000000000000000000000000..09ff6fc5dbcf08f6326ef36f29c75bff16c9c9dd
--- /dev/null
+++ b/README copy.md
@@ -0,0 +1,30 @@
+# React + TypeScript + Vite
+
+This template provides a minimal setup to get React working in Vite with HMR and some ESLint rules.
+
+Currently, two official plugins are available:
+
+- [@vitejs/plugin-react](https://github.com/vitejs/vite-plugin-react/blob/main/packages/plugin-react/README.md) uses [Babel](https://babeljs.io/) for Fast Refresh
+- [@vitejs/plugin-react-swc](https://github.com/vitejs/vite-plugin-react-swc) uses [SWC](https://swc.rs/) for Fast Refresh
+
+## Expanding the ESLint configuration
+
+If you are developing a production application, we recommend updating the configuration to enable type aware lint rules:
+
+- Configure the top-level `parserOptions` property like this:
+
+```js
+export default {
+ // other rules...
+ parserOptions: {
+ ecmaVersion: 'latest',
+ sourceType: 'module',
+ project: ['./tsconfig.json', './tsconfig.node.json'],
+ tsconfigRootDir: __dirname
+ }
+};
+```
+
+- Replace `plugin:@typescript-eslint/recommended` to `plugin:@typescript-eslint/recommended-type-checked` or `plugin:@typescript-eslint/strict-type-checked`
+- Optionally add `plugin:@typescript-eslint/stylistic-type-checked`
+- Install [eslint-plugin-react](https://github.com/jsx-eslint/eslint-plugin-react) and add `plugin:react/recommended` & `plugin:react/jsx-runtime` to the `extends` list
diff --git a/entrypoint.sh b/entrypoint.sh
new file mode 100755
index 0000000000000000000000000000000000000000..43c1a87877aefc92e740c6c744f138950a42a0dc
--- /dev/null
+++ b/entrypoint.sh
@@ -0,0 +1,5 @@
+#!/bin/sh
+
+cd /app
+npm install
+npm run dev
\ No newline at end of file
diff --git a/fly.toml b/fly.toml
new file mode 100644
index 0000000000000000000000000000000000000000..ca87a343850e885fcee0494c70eacb6d3019ccbe
--- /dev/null
+++ b/fly.toml
@@ -0,0 +1,17 @@
+# fly.toml app configuration file generated for ccc-frontend on 2023-08-21T15:35:09+02:00
+#
+# See https://fly.io/docs/reference/configuration/ for information about how to use this file.
+#
+
+app = "ccc-frontend"
+primary_region = "ams"
+
+[build]
+
+[http_service]
+ internal_port = 443
+ force_https = true
+ auto_stop_machines = false
+ auto_start_machines = true
+ min_machines_running = 0
+ processes = ["app"]
diff --git a/i18next-parser.config.js b/i18next-parser.config.js
new file mode 100644
index 0000000000000000000000000000000000000000..0c7873a22d05baee4348c6bd58950bf1164e2712
--- /dev/null
+++ b/i18next-parser.config.js
@@ -0,0 +1,5 @@
+export default {
+ locales: ['en', 'de'],
+ output: 'public/locales/$LOCALE/translation.json',
+ input: 'src/**/*.{js,jsx,ts,tsx}'
+};
diff --git a/index.html b/index.html
new file mode 100644
index 0000000000000000000000000000000000000000..c61bd6eff108bde0d0e7c339a1656e23804d190c
--- /dev/null
+++ b/index.html
@@ -0,0 +1,15 @@
+
+
+
+
+
+ ChatGPTfirewall
+
+
+
+
+
+
+
diff --git a/nginx.conf b/nginx.conf
new file mode 100644
index 0000000000000000000000000000000000000000..d14010e83a1dd77de4f525f5dd36f7347269ec26
--- /dev/null
+++ b/nginx.conf
@@ -0,0 +1,17 @@
+server {
+ listen 7860
+ server_name _
+
+ location / {
+ root /usr/share/nginx/html
+ try_files $uri $uri/ /index.html
+ }
+
+ location /api {
+ proxy_pass http://185.112.181.192:8000/api;
+ proxy_set_header X-Forwarded-Host $host;
+ proxy_set_header X-Real-IP $remote_addr;
+ proxy_set_header Host $host;
+ proxy_read_timeout 3600;
+ }
+}
diff --git a/package-lock.json b/package-lock.json
new file mode 100644
index 0000000000000000000000000000000000000000..aeee99366177ca317c6e7e522aabbf30ba25bc5b
--- /dev/null
+++ b/package-lock.json
@@ -0,0 +1,7273 @@
+{
+ "name": "frontend",
+ "version": "0.0.0",
+ "lockfileVersion": 3,
+ "requires": true,
+ "packages": {
+ "": {
+ "name": "frontend",
+ "version": "0.0.0",
+ "dependencies": {
+ "@auth0/auth0-react": "^2.2.4",
+ "@fluentui/react": "^8.115.5",
+ "@fluentui/react-components": "^9.46.3",
+ "@fluentui/react-icons": "^2.0.226",
+ "axios": "^1.6.7",
+ "date-fns": "^3.3.1",
+ "draft-js": "^0.11.7",
+ "i18next": "^23.8.2",
+ "i18next-browser-languagedetector": "^7.2.0",
+ "i18next-http-backend": "^2.4.3",
+ "prettier": "^3.2.4",
+ "react": "^18.2.0",
+ "react-country-flag": "^3.1.0",
+ "react-dom": "^18.2.0",
+ "react-highlight-within-textarea": "^3.2.1",
+ "react-i18next": "^14.0.1",
+ "react-router-dom": "^6.21.3"
+ },
+ "devDependencies": {
+ "@flydotio/dockerfile": "^0.5.2",
+ "@types/react": "^18.2.43",
+ "@types/react-dom": "^18.2.17",
+ "@typescript-eslint/eslint-plugin": "^6.14.0",
+ "@typescript-eslint/parser": "^6.20.0",
+ "@vitejs/plugin-react": "^4.2.1",
+ "eslint": "^8.55.0",
+ "eslint-plugin-react-hooks": "^4.6.0",
+ "eslint-plugin-react-refresh": "^0.4.5",
+ "i18next-parser": "^8.12.0",
+ "typescript": "^5.2.2",
+ "vite": "^5.0.8",
+ "vite-plugin-svgr": "^4.2.0"
+ }
+ },
+ "node_modules/@aashutoshrathi/word-wrap": {
+ "version": "1.2.6",
+ "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz",
+ "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/@ampproject/remapping": {
+ "version": "2.2.1",
+ "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz",
+ "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/gen-mapping": "^0.3.0",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@auth0/auth0-react": {
+ "version": "2.2.4",
+ "resolved": "https://registry.npmjs.org/@auth0/auth0-react/-/auth0-react-2.2.4.tgz",
+ "integrity": "sha512-l29PQC0WdgkCoOc6WeMAY26gsy/yXJICW0jHfj0nz8rZZphYKrLNqTRWFFCMJY+sagza9tSgB1kG/UvQYgGh9A==",
+ "dependencies": {
+ "@auth0/auth0-spa-js": "^2.1.3"
+ },
+ "peerDependencies": {
+ "react": "^16.11.0 || ^17 || ^18",
+ "react-dom": "^16.11.0 || ^17 || ^18"
+ }
+ },
+ "node_modules/@auth0/auth0-spa-js": {
+ "version": "2.1.3",
+ "resolved": "https://registry.npmjs.org/@auth0/auth0-spa-js/-/auth0-spa-js-2.1.3.tgz",
+ "integrity": "sha512-NMTBNuuG4g3rame1aCnNS5qFYIzsTUV5qTFPRfTyYFS1feS6jsCBR+eTq9YkxCp1yuoM2UIcjunPaoPl77U9xQ=="
+ },
+ "node_modules/@babel/code-frame": {
+ "version": "7.23.5",
+ "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.23.5.tgz",
+ "integrity": "sha512-CgH3s1a96LipHCmSUmYFPwY7MNx8C3avkq7i4Wl3cfa662ldtUe4VM1TPXX70pfmrlWTb6jLqTYrZyT2ZTJBgA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/highlight": "^7.23.4",
+ "chalk": "^2.4.2"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/compat-data": {
+ "version": "7.23.5",
+ "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.23.5.tgz",
+ "integrity": "sha512-uU27kfDRlhfKl+w1U6vp16IuvSLtjAxdArVXPa9BvLkrr7CYIsxH5adpHObeAGY/41+syctUWOZ140a2Rvkgjw==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/core": {
+ "version": "7.23.9",
+ "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.23.9.tgz",
+ "integrity": "sha512-5q0175NOjddqpvvzU+kDiSOAk4PfdO6FvwCWoQ6RO7rTzEe8vlo+4HVfcnAREhD4npMs0e9uZypjTwzZPCf/cw==",
+ "dev": true,
+ "dependencies": {
+ "@ampproject/remapping": "^2.2.0",
+ "@babel/code-frame": "^7.23.5",
+ "@babel/generator": "^7.23.6",
+ "@babel/helper-compilation-targets": "^7.23.6",
+ "@babel/helper-module-transforms": "^7.23.3",
+ "@babel/helpers": "^7.23.9",
+ "@babel/parser": "^7.23.9",
+ "@babel/template": "^7.23.9",
+ "@babel/traverse": "^7.23.9",
+ "@babel/types": "^7.23.9",
+ "convert-source-map": "^2.0.0",
+ "debug": "^4.1.0",
+ "gensync": "^1.0.0-beta.2",
+ "json5": "^2.2.3",
+ "semver": "^6.3.1"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/babel"
+ }
+ },
+ "node_modules/@babel/core/node_modules/convert-source-map": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz",
+ "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==",
+ "dev": true
+ },
+ "node_modules/@babel/core/node_modules/semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true,
+ "bin": {
+ "semver": "bin/semver.js"
+ }
+ },
+ "node_modules/@babel/generator": {
+ "version": "7.23.6",
+ "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.23.6.tgz",
+ "integrity": "sha512-qrSfCYxYQB5owCmGLbl8XRpX1ytXlpueOb0N0UmQwA073KZxejgQTzAmJezxvpwQD9uGtK2shHdi55QT+MbjIw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.23.6",
+ "@jridgewell/gen-mapping": "^0.3.2",
+ "@jridgewell/trace-mapping": "^0.3.17",
+ "jsesc": "^2.5.1"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-compilation-targets": {
+ "version": "7.23.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.23.6.tgz",
+ "integrity": "sha512-9JB548GZoQVmzrFgp8o7KxdgkTGm6xs9DW0o/Pim72UDjzr5ObUQ6ZzYPqA+g9OTS2bBQoctLJrky0RDCAWRgQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/compat-data": "^7.23.5",
+ "@babel/helper-validator-option": "^7.23.5",
+ "browserslist": "^4.22.2",
+ "lru-cache": "^5.1.1",
+ "semver": "^6.3.1"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-compilation-targets/node_modules/semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true,
+ "bin": {
+ "semver": "bin/semver.js"
+ }
+ },
+ "node_modules/@babel/helper-environment-visitor": {
+ "version": "7.22.20",
+ "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.20.tgz",
+ "integrity": "sha512-zfedSIzFhat/gFhWfHtgWvlec0nqB9YEIVrpuwjruLlXfUSnA8cJB0miHKwqDnQ7d32aKo2xt88/xZptwxbfhA==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-function-name": {
+ "version": "7.23.0",
+ "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.23.0.tgz",
+ "integrity": "sha512-OErEqsrxjZTJciZ4Oo+eoZqeW9UIiOcuYKRJA4ZAgV9myA+pOXhhmpfNCKjEH/auVfEYVFJ6y1Tc4r0eIApqiw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/template": "^7.22.15",
+ "@babel/types": "^7.23.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-hoist-variables": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.22.5.tgz",
+ "integrity": "sha512-wGjk9QZVzvknA6yKIUURb8zY3grXCcOZt+/7Wcy8O2uctxhplmUPkOdlgoNhmdVee2c92JXbf1xpMtVNbfoxRw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-module-imports": {
+ "version": "7.22.15",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.22.15.tgz",
+ "integrity": "sha512-0pYVBnDKZO2fnSPCrgM/6WMc7eS20Fbok+0r88fp+YtWVLZrp4CkafFGIp+W0VKw4a22sgebPT99y+FDNMdP4w==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.22.15"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-module-transforms": {
+ "version": "7.23.3",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.23.3.tgz",
+ "integrity": "sha512-7bBs4ED9OmswdfDzpz4MpWgSrV7FXlc3zIagvLFjS5H+Mk7Snr21vQ6QwrsoCGMfNC4e4LQPdoULEt4ykz0SRQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-environment-visitor": "^7.22.20",
+ "@babel/helper-module-imports": "^7.22.15",
+ "@babel/helper-simple-access": "^7.22.5",
+ "@babel/helper-split-export-declaration": "^7.22.6",
+ "@babel/helper-validator-identifier": "^7.22.20"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/helper-plugin-utils": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.22.5.tgz",
+ "integrity": "sha512-uLls06UVKgFG9QD4OeFYLEGteMIAa5kpTPcFL28yuCIIzsf6ZyKZMllKVOCZFhiZ5ptnwX4mtKdWCBE/uT4amg==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-simple-access": {
+ "version": "7.22.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.22.5.tgz",
+ "integrity": "sha512-n0H99E/K+Bika3++WNL17POvo4rKWZ7lZEp1Q+fStVbUi8nxPQEBOlTmCOxW/0JsS56SKKQ+ojAe2pHKJHN35w==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-split-export-declaration": {
+ "version": "7.22.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.22.6.tgz",
+ "integrity": "sha512-AsUnxuLhRYsisFiaJwvp1QF+I3KjD5FOxut14q/GzovUe6orHLesW2C7d754kRm53h5gqrz6sFl6sxc4BVtE/g==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-string-parser": {
+ "version": "7.23.4",
+ "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.23.4.tgz",
+ "integrity": "sha512-803gmbQdqwdf4olxrX4AJyFBV/RTr3rSmOj0rKwesmzlfhYNDEs+/iOcznzpNWlJlIlTJC2QfPFcHB6DlzdVLQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-validator-identifier": {
+ "version": "7.22.20",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz",
+ "integrity": "sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-validator-option": {
+ "version": "7.23.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.23.5.tgz",
+ "integrity": "sha512-85ttAOMLsr53VgXkTbkx8oA6YTfT4q7/HzXSLEYmjcSTJPMPQtvq1BD79Byep5xMUYbGRzEpDsjUf3dyp54IKw==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helpers": {
+ "version": "7.23.9",
+ "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.23.9.tgz",
+ "integrity": "sha512-87ICKgU5t5SzOT7sBMfCOZQ2rHjRU+Pcb9BoILMYz600W6DkVRLFBPwQ18gwUVvggqXivaUakpnxWQGbpywbBQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/template": "^7.23.9",
+ "@babel/traverse": "^7.23.9",
+ "@babel/types": "^7.23.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/highlight": {
+ "version": "7.23.4",
+ "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.23.4.tgz",
+ "integrity": "sha512-acGdbYSfp2WheJoJm/EBBBLh/ID8KDc64ISZ9DYtBmC8/Q204PZJLHyzeB5qMzJ5trcOkybd78M4x2KWsUq++A==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-validator-identifier": "^7.22.20",
+ "chalk": "^2.4.2",
+ "js-tokens": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/parser": {
+ "version": "7.23.9",
+ "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.23.9.tgz",
+ "integrity": "sha512-9tcKgqKbs3xGJ+NtKF2ndOBBLVwPjl1SHxPQkd36r3Dlirw3xWUeGaTbqr7uGZcTaxkVNwc+03SVP7aCdWrTlA==",
+ "dev": true,
+ "bin": {
+ "parser": "bin/babel-parser.js"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-react-jsx-self": {
+ "version": "7.23.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.23.3.tgz",
+ "integrity": "sha512-qXRvbeKDSfwnlJnanVRp0SfuWE5DQhwQr5xtLBzp56Wabyo+4CMosF6Kfp+eOD/4FYpql64XVJ2W0pVLlJZxOQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-react-jsx-source": {
+ "version": "7.23.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.23.3.tgz",
+ "integrity": "sha512-91RS0MDnAWDNvGC6Wio5XYkyWI39FMFO+JK9+4AlgaTH+yWwVTsw7/sn6LK0lH7c5F+TFkpv/3LfCJ1Ydwof/g==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.22.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/runtime": {
+ "version": "7.23.9",
+ "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.23.9.tgz",
+ "integrity": "sha512-0CX6F+BI2s9dkUqr08KFrAIZgNFj75rdBU/DjCyYLIaV/quFjkk6T+EJ2LkZHyZTbEV4L5p97mNkUsHl2wLFAw==",
+ "dependencies": {
+ "regenerator-runtime": "^0.14.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/template": {
+ "version": "7.23.9",
+ "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.23.9.tgz",
+ "integrity": "sha512-+xrD2BWLpvHKNmX2QbpdpsBaWnRxahMwJjO+KZk2JOElj5nSmKezyS1B4u+QbHMTX69t4ukm6hh9lsYQ7GHCKA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/code-frame": "^7.23.5",
+ "@babel/parser": "^7.23.9",
+ "@babel/types": "^7.23.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/traverse": {
+ "version": "7.23.9",
+ "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.23.9.tgz",
+ "integrity": "sha512-I/4UJ9vs90OkBtY6iiiTORVMyIhJ4kAVmsKo9KFc8UOxMeUfi2hvtIBsET5u9GizXE6/GFSuKCTNfgCswuEjRg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/code-frame": "^7.23.5",
+ "@babel/generator": "^7.23.6",
+ "@babel/helper-environment-visitor": "^7.22.20",
+ "@babel/helper-function-name": "^7.23.0",
+ "@babel/helper-hoist-variables": "^7.22.5",
+ "@babel/helper-split-export-declaration": "^7.22.6",
+ "@babel/parser": "^7.23.9",
+ "@babel/types": "^7.23.9",
+ "debug": "^4.3.1",
+ "globals": "^11.1.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/types": {
+ "version": "7.23.9",
+ "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.23.9.tgz",
+ "integrity": "sha512-dQjSq/7HaSjRM43FFGnv5keM2HsxpmyV1PfaSVm0nzzjwwTmjOe6J4bC8e3+pTEIgHaHj+1ZlLThRJ2auc/w1Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-string-parser": "^7.23.4",
+ "@babel/helper-validator-identifier": "^7.22.20",
+ "to-fast-properties": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@emotion/hash": {
+ "version": "0.9.1",
+ "resolved": "https://registry.npmjs.org/@emotion/hash/-/hash-0.9.1.tgz",
+ "integrity": "sha512-gJB6HLm5rYwSLI6PQa+X1t5CFGrv1J1TWG+sOyMCeKz2ojaj6Fnl/rZEspogG+cvqbt4AE/2eIyD2QfLKTBNlQ=="
+ },
+ "node_modules/@esbuild/aix-ppc64": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.19.12.tgz",
+ "integrity": "sha512-bmoCYyWdEL3wDQIVbcyzRyeKLgk2WtWLTWz1ZIAZF/EGbNOwSA6ew3PftJ1PqMiOOGu0OyFMzG53L0zqIpPeNA==",
+ "cpu": [
+ "ppc64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "aix"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/android-arm": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.19.12.tgz",
+ "integrity": "sha512-qg/Lj1mu3CdQlDEEiWrlC4eaPZ1KztwGJ9B6J+/6G+/4ewxJg7gqj8eVYWvao1bXrqGiW2rsBZFSX3q2lcW05w==",
+ "cpu": [
+ "arm"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/android-arm64": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.19.12.tgz",
+ "integrity": "sha512-P0UVNGIienjZv3f5zq0DP3Nt2IE/3plFzuaS96vihvD0Hd6H/q4WXUGpCxD/E8YrSXfNyRPbpTq+T8ZQioSuPA==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/android-x64": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.19.12.tgz",
+ "integrity": "sha512-3k7ZoUW6Q6YqhdhIaq/WZ7HwBpnFBlW905Fa4s4qWJyiNOgT1dOqDiVAQFwBH7gBRZr17gLrlFCRzF6jFh7Kew==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/darwin-arm64": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.19.12.tgz",
+ "integrity": "sha512-B6IeSgZgtEzGC42jsI+YYu9Z3HKRxp8ZT3cqhvliEHovq8HSX2YX8lNocDn79gCKJXOSaEot9MVYky7AKjCs8g==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/darwin-x64": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.19.12.tgz",
+ "integrity": "sha512-hKoVkKzFiToTgn+41qGhsUJXFlIjxI/jSYeZf3ugemDYZldIXIxhvwN6erJGlX4t5h417iFuheZ7l+YVn05N3A==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/freebsd-arm64": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.19.12.tgz",
+ "integrity": "sha512-4aRvFIXmwAcDBw9AueDQ2YnGmz5L6obe5kmPT8Vd+/+x/JMVKCgdcRwH6APrbpNXsPz+K653Qg8HB/oXvXVukA==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "freebsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/freebsd-x64": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.19.12.tgz",
+ "integrity": "sha512-EYoXZ4d8xtBoVN7CEwWY2IN4ho76xjYXqSXMNccFSx2lgqOG/1TBPW0yPx1bJZk94qu3tX0fycJeeQsKovA8gg==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "freebsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-arm": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.19.12.tgz",
+ "integrity": "sha512-J5jPms//KhSNv+LO1S1TX1UWp1ucM6N6XuL6ITdKWElCu8wXP72l9MM0zDTzzeikVyqFE6U8YAV9/tFyj0ti+w==",
+ "cpu": [
+ "arm"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-arm64": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.19.12.tgz",
+ "integrity": "sha512-EoTjyYyLuVPfdPLsGVVVC8a0p1BFFvtpQDB/YLEhaXyf/5bczaGeN15QkR+O4S5LeJ92Tqotve7i1jn35qwvdA==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-ia32": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.19.12.tgz",
+ "integrity": "sha512-Thsa42rrP1+UIGaWz47uydHSBOgTUnwBwNq59khgIwktK6x60Hivfbux9iNR0eHCHzOLjLMLfUMLCypBkZXMHA==",
+ "cpu": [
+ "ia32"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-loong64": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.19.12.tgz",
+ "integrity": "sha512-LiXdXA0s3IqRRjm6rV6XaWATScKAXjI4R4LoDlvO7+yQqFdlr1Bax62sRwkVvRIrwXxvtYEHHI4dm50jAXkuAA==",
+ "cpu": [
+ "loong64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-mips64el": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.19.12.tgz",
+ "integrity": "sha512-fEnAuj5VGTanfJ07ff0gOA6IPsvrVHLVb6Lyd1g2/ed67oU1eFzL0r9WL7ZzscD+/N6i3dWumGE1Un4f7Amf+w==",
+ "cpu": [
+ "mips64el"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-ppc64": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.19.12.tgz",
+ "integrity": "sha512-nYJA2/QPimDQOh1rKWedNOe3Gfc8PabU7HT3iXWtNUbRzXS9+vgB0Fjaqr//XNbd82mCxHzik2qotuI89cfixg==",
+ "cpu": [
+ "ppc64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-riscv64": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.19.12.tgz",
+ "integrity": "sha512-2MueBrlPQCw5dVJJpQdUYgeqIzDQgw3QtiAHUC4RBz9FXPrskyyU3VI1hw7C0BSKB9OduwSJ79FTCqtGMWqJHg==",
+ "cpu": [
+ "riscv64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-s390x": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.19.12.tgz",
+ "integrity": "sha512-+Pil1Nv3Umes4m3AZKqA2anfhJiVmNCYkPchwFJNEJN5QxmTs1uzyy4TvmDrCRNT2ApwSari7ZIgrPeUx4UZDg==",
+ "cpu": [
+ "s390x"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-x64": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.19.12.tgz",
+ "integrity": "sha512-B71g1QpxfwBvNrfyJdVDexenDIt1CiDN1TIXLbhOw0KhJzE78KIFGX6OJ9MrtC0oOqMWf+0xop4qEU8JrJTwCg==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/netbsd-x64": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.19.12.tgz",
+ "integrity": "sha512-3ltjQ7n1owJgFbuC61Oj++XhtzmymoCihNFgT84UAmJnxJfm4sYCiSLTXZtE00VWYpPMYc+ZQmB6xbSdVh0JWA==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "netbsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/openbsd-x64": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.19.12.tgz",
+ "integrity": "sha512-RbrfTB9SWsr0kWmb9srfF+L933uMDdu9BIzdA7os2t0TXhCRjrQyCeOt6wVxr79CKD4c+p+YhCj31HBkYcXebw==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "openbsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/sunos-x64": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.19.12.tgz",
+ "integrity": "sha512-HKjJwRrW8uWtCQnQOz9qcU3mUZhTUQvi56Q8DPTLLB+DawoiQdjsYq+j+D3s9I8VFtDr+F9CjgXKKC4ss89IeA==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "sunos"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/win32-arm64": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.19.12.tgz",
+ "integrity": "sha512-URgtR1dJnmGvX864pn1B2YUYNzjmXkuJOIqG2HdU62MVS4EHpU2946OZoTMnRUHklGtJdJZ33QfzdjGACXhn1A==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/win32-ia32": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.19.12.tgz",
+ "integrity": "sha512-+ZOE6pUkMOJfmxmBZElNOx72NKpIa/HFOMGzu8fqzQJ5kgf6aTGrcJaFsNiVMH4JKpMipyK+7k0n2UXN7a8YKQ==",
+ "cpu": [
+ "ia32"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/win32-x64": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.19.12.tgz",
+ "integrity": "sha512-T1QyPSDCyMXaO3pzBkF96E8xMkiRYbUEZADd29SyPGabqxMViNoii+NcK7eWJAEoU6RZyEm5lVSIjTmcdoB9HA==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@eslint-community/eslint-utils": {
+ "version": "4.4.0",
+ "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz",
+ "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==",
+ "dev": true,
+ "dependencies": {
+ "eslint-visitor-keys": "^3.3.0"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "peerDependencies": {
+ "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0"
+ }
+ },
+ "node_modules/@eslint-community/regexpp": {
+ "version": "4.10.0",
+ "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.10.0.tgz",
+ "integrity": "sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA==",
+ "dev": true,
+ "engines": {
+ "node": "^12.0.0 || ^14.0.0 || >=16.0.0"
+ }
+ },
+ "node_modules/@eslint/eslintrc": {
+ "version": "2.1.4",
+ "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz",
+ "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==",
+ "dev": true,
+ "dependencies": {
+ "ajv": "^6.12.4",
+ "debug": "^4.3.2",
+ "espree": "^9.6.0",
+ "globals": "^13.19.0",
+ "ignore": "^5.2.0",
+ "import-fresh": "^3.2.1",
+ "js-yaml": "^4.1.0",
+ "minimatch": "^3.1.2",
+ "strip-json-comments": "^3.1.1"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/@eslint/eslintrc/node_modules/brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "dependencies": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "node_modules/@eslint/eslintrc/node_modules/globals": {
+ "version": "13.24.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz",
+ "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==",
+ "dev": true,
+ "dependencies": {
+ "type-fest": "^0.20.2"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/@eslint/eslintrc/node_modules/minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dev": true,
+ "dependencies": {
+ "brace-expansion": "^1.1.7"
+ },
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/@eslint/js": {
+ "version": "8.56.0",
+ "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.56.0.tgz",
+ "integrity": "sha512-gMsVel9D7f2HLkBma9VbtzZRehRogVRfbr++f06nL2vnCGCNlzOD+/MUov/F4p8myyAHspEhVobgjpX64q5m6A==",
+ "dev": true,
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ }
+ },
+ "node_modules/@floating-ui/core": {
+ "version": "1.6.0",
+ "resolved": "https://registry.npmjs.org/@floating-ui/core/-/core-1.6.0.tgz",
+ "integrity": "sha512-PcF++MykgmTj3CIyOQbKA/hDzOAiqI3mhuoN44WRCopIs1sgoDoU4oty4Jtqaj/y3oDU6fnVSm4QG0a3t5i0+g==",
+ "dependencies": {
+ "@floating-ui/utils": "^0.2.1"
+ }
+ },
+ "node_modules/@floating-ui/devtools": {
+ "version": "0.2.1",
+ "resolved": "https://registry.npmjs.org/@floating-ui/devtools/-/devtools-0.2.1.tgz",
+ "integrity": "sha512-8PHJLbD6VhBh+LJ1uty/Bz30qs02NXCE5u8WpOhSewlYXUWl03GNXknr9AS2yaAWJEQaY27x7eByJs44gODBcw==",
+ "peerDependencies": {
+ "@floating-ui/dom": ">=1.5.4"
+ }
+ },
+ "node_modules/@floating-ui/dom": {
+ "version": "1.6.1",
+ "resolved": "https://registry.npmjs.org/@floating-ui/dom/-/dom-1.6.1.tgz",
+ "integrity": "sha512-iA8qE43/H5iGozC3W0YSnVSW42Vh522yyM1gj+BqRwVsTNOyr231PsXDaV04yT39PsO0QL2QpbI/M0ZaLUQgRQ==",
+ "dependencies": {
+ "@floating-ui/core": "^1.6.0",
+ "@floating-ui/utils": "^0.2.1"
+ }
+ },
+ "node_modules/@floating-ui/utils": {
+ "version": "0.2.1",
+ "resolved": "https://registry.npmjs.org/@floating-ui/utils/-/utils-0.2.1.tgz",
+ "integrity": "sha512-9TANp6GPoMtYzQdt54kfAyMmz1+osLlXdg2ENroU7zzrtflTLrrC/lgrIfaSe+Wu0b89GKccT7vxXA0MoAIO+Q=="
+ },
+ "node_modules/@fluentui/date-time-utilities": {
+ "version": "8.5.16",
+ "resolved": "https://registry.npmjs.org/@fluentui/date-time-utilities/-/date-time-utilities-8.5.16.tgz",
+ "integrity": "sha512-l+mLfJ2VhdHjBpELLLPDaWgT7GMLynm2aqR7SttbEb6Jh7hc/7ck1MWm93RTb3gYVHYai8SENqimNcvIxHt/zg==",
+ "dependencies": {
+ "@fluentui/set-version": "^8.2.14",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@fluentui/dom-utilities": {
+ "version": "2.2.14",
+ "resolved": "https://registry.npmjs.org/@fluentui/dom-utilities/-/dom-utilities-2.2.14.tgz",
+ "integrity": "sha512-+4DVm5sNfJh+l8fM+7ylpOkGNZkNr4X1z1uKQPzRJ1PRhlnvc6vLpWNNicGwpjTbgufSrVtGKXwP5sf++r81lg==",
+ "dependencies": {
+ "@fluentui/set-version": "^8.2.14",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@fluentui/font-icons-mdl2": {
+ "version": "8.5.32",
+ "resolved": "https://registry.npmjs.org/@fluentui/font-icons-mdl2/-/font-icons-mdl2-8.5.32.tgz",
+ "integrity": "sha512-PCZMijJlDQ5Zy8oNb80vUD6I4ORiR03qFgDT8o08mAGu+KzQO96q4jm0rzPRQuI9CO7pDD/6naOo8UVrmhZ2Aw==",
+ "dependencies": {
+ "@fluentui/set-version": "^8.2.14",
+ "@fluentui/style-utilities": "^8.10.3",
+ "@fluentui/utilities": "^8.13.24",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@fluentui/foundation-legacy": {
+ "version": "8.2.52",
+ "resolved": "https://registry.npmjs.org/@fluentui/foundation-legacy/-/foundation-legacy-8.2.52.tgz",
+ "integrity": "sha512-tHCD0m58Zja7wN1FTsvj4Gaj0B22xOhRTpyDzyvxRfjFGYPpR2Jgx/y/KRB3JTOX5EfJHAVzInyWZBeN5IfsVA==",
+ "dependencies": {
+ "@fluentui/merge-styles": "^8.5.15",
+ "@fluentui/set-version": "^8.2.14",
+ "@fluentui/style-utilities": "^8.10.3",
+ "@fluentui/utilities": "^8.13.24",
+ "tslib": "^2.1.0"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.8.0 <19.0.0",
+ "react": ">=16.8.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/keyboard-key": {
+ "version": "0.4.14",
+ "resolved": "https://registry.npmjs.org/@fluentui/keyboard-key/-/keyboard-key-0.4.14.tgz",
+ "integrity": "sha512-XzZHcyFEM20H23h3i15UpkHi2AhRBriXPGAHq0Jm98TKFppXehedjjEFuUsh+CyU5JKBhDalWp8TAQ1ArpNzow==",
+ "dependencies": {
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@fluentui/keyboard-keys": {
+ "version": "9.0.7",
+ "resolved": "https://registry.npmjs.org/@fluentui/keyboard-keys/-/keyboard-keys-9.0.7.tgz",
+ "integrity": "sha512-vaQ+lOveQTdoXJYqDQXWb30udSfTVcIuKk1rV0X0eGAgcHeSDeP1HxMy+OgHOQZH3OiBH4ZYeWxb+tmfiDiygQ==",
+ "dependencies": {
+ "@swc/helpers": "^0.5.1"
+ }
+ },
+ "node_modules/@fluentui/merge-styles": {
+ "version": "8.5.15",
+ "resolved": "https://registry.npmjs.org/@fluentui/merge-styles/-/merge-styles-8.5.15.tgz",
+ "integrity": "sha512-4CdKwo4k1Un2QLulpSVIz/KMgLNBMgin4NPyapmKDMVuO1OOxJUqfocubRGNO5x9mKgAMMYwBKGO9i0uxMMpJw==",
+ "dependencies": {
+ "@fluentui/set-version": "^8.2.14",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@fluentui/priority-overflow": {
+ "version": "9.1.11",
+ "resolved": "https://registry.npmjs.org/@fluentui/priority-overflow/-/priority-overflow-9.1.11.tgz",
+ "integrity": "sha512-sdrpavvKX2kepQ1d6IaI3ObLq5SAQBPRHPGx2+wiMWL7cEx9vGGM0fmeicl3soqqmM5uwCmWnZk9QZv9XOY98w==",
+ "dependencies": {
+ "@swc/helpers": "^0.5.1"
+ }
+ },
+ "node_modules/@fluentui/react": {
+ "version": "8.115.5",
+ "resolved": "https://registry.npmjs.org/@fluentui/react/-/react-8.115.5.tgz",
+ "integrity": "sha512-/Dmtf52r1pd2tbJ6NqbC65Zs+V/lOharui2uTtc0GxaMr3QREUWUkojtxKFwLVHqCrO1NzcIZm6siqR4z6ucRw==",
+ "dependencies": {
+ "@fluentui/date-time-utilities": "^8.5.16",
+ "@fluentui/font-icons-mdl2": "^8.5.32",
+ "@fluentui/foundation-legacy": "^8.2.52",
+ "@fluentui/merge-styles": "^8.5.15",
+ "@fluentui/react-focus": "^8.8.40",
+ "@fluentui/react-hooks": "^8.6.36",
+ "@fluentui/react-portal-compat-context": "^9.0.11",
+ "@fluentui/react-window-provider": "^2.2.18",
+ "@fluentui/set-version": "^8.2.14",
+ "@fluentui/style-utilities": "^8.10.3",
+ "@fluentui/theme": "^2.6.41",
+ "@fluentui/utilities": "^8.13.24",
+ "@microsoft/load-themed-styles": "^1.10.26",
+ "tslib": "^2.1.0"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.8.0 <19.0.0",
+ "@types/react-dom": ">=16.8.0 <19.0.0",
+ "react": ">=16.8.0 <19.0.0",
+ "react-dom": ">=16.8.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-accordion": {
+ "version": "9.3.40",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-accordion/-/react-accordion-9.3.40.tgz",
+ "integrity": "sha512-XZoCL9PXkIQTOqDQuetShyB9YZKoM/H0eCDKtHG0xNh++HBB0rbjUkyrBx9YG+Bzky9lL7DioJ8Xcm2hXg6mIQ==",
+ "dependencies": {
+ "@fluentui/react-aria": "^9.8.1",
+ "@fluentui/react-context-selector": "^9.1.51",
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0",
+ "scheduler": "^0.19.0 || ^0.20.0"
+ }
+ },
+ "node_modules/@fluentui/react-alert": {
+ "version": "9.0.0-beta.108",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-alert/-/react-alert-9.0.0-beta.108.tgz",
+ "integrity": "sha512-u60x564eUHMOeKKu9xBRT8BAaynKXWM529Px2ie86R2H569ZlDDooEXsVqWc0mj8Hvvyk+oDDIUwRAMMfDaWFA==",
+ "dependencies": {
+ "@fluentui/react-avatar": "^9.6.13",
+ "@fluentui/react-button": "^9.3.67",
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-aria": {
+ "version": "9.8.1",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-aria/-/react-aria-9.8.1.tgz",
+ "integrity": "sha512-yQl78RgM6Bx5cEkm+vlRR7jcf/8cIeWkN7EuTgPSXx0mF83V+FG6hCngpbGur7HQQ2QSXkDG0YrPXP+hmnermQ==",
+ "dependencies": {
+ "@fluentui/keyboard-keys": "^9.0.7",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-avatar": {
+ "version": "9.6.13",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-avatar/-/react-avatar-9.6.13.tgz",
+ "integrity": "sha512-0ZlZW4/+0CqnVKiFltIxeYf5VY5TUglESFQxdpu1RpuwS8SRh7JqRFYP9HS3KHj7qiP3jpI0u6ADRr7PW7bpPQ==",
+ "dependencies": {
+ "@fluentui/react-badge": "^9.2.24",
+ "@fluentui/react-context-selector": "^9.1.51",
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-popover": "^9.8.37",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-tooltip": "^9.4.15",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0",
+ "scheduler": "^0.19.0 || ^0.20.0"
+ }
+ },
+ "node_modules/@fluentui/react-badge": {
+ "version": "9.2.24",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-badge/-/react-badge-9.2.24.tgz",
+ "integrity": "sha512-ThGVHf5wO8xpf/JbYSEMK0tGoRqprMDcx+jD7NK5lxjqv4oOxRGSFYfG5GYf4qJZZKbBc2hTOy/BHpts6WBtzw==",
+ "dependencies": {
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-breadcrumb": {
+ "version": "9.0.13",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-breadcrumb/-/react-breadcrumb-9.0.13.tgz",
+ "integrity": "sha512-ypEDH2StHil2Ih7uwY21TEVHkiBh87lH7++qfzoGXhhkCdApbaTS0BSaekeFNXmSwlSCk3QVda5hb7jTGBdwFA==",
+ "dependencies": {
+ "@fluentui/react-aria": "^9.8.1",
+ "@fluentui/react-button": "^9.3.67",
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-link": "^9.2.9",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-button": {
+ "version": "9.3.67",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-button/-/react-button-9.3.67.tgz",
+ "integrity": "sha512-bKTUrkrbty/y4lbXejOO//ZE6sUgbFKymGtu0C1Tb38Ddr37cEePzmrEYZrX7CyE1geP4sCDkLrKysQrVK+2OA==",
+ "dependencies": {
+ "@fluentui/keyboard-keys": "^9.0.7",
+ "@fluentui/react-aria": "^9.8.1",
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-card": {
+ "version": "9.0.66",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-card/-/react-card-9.0.66.tgz",
+ "integrity": "sha512-z6c+B/wf44U6mCtZW9h807Ac95jtnA39uv8MHFx4mPJtK5Dsc4tNHq5O97eDRLQpmY78qic7HTqAPaXOMkXU/w==",
+ "dependencies": {
+ "@fluentui/keyboard-keys": "^9.0.7",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-checkbox": {
+ "version": "9.2.11",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-checkbox/-/react-checkbox-9.2.11.tgz",
+ "integrity": "sha512-jEcPXTuQ8o9N4XkTdqxbUBvq7izp9whwP14U0PMccsfJacZ0muo3G9YWS6wrL83M0YRZg61hOE9HcD4/oxEztA==",
+ "dependencies": {
+ "@fluentui/react-field": "^9.1.53",
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-label": "^9.1.61",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-combobox": {
+ "version": "9.7.4",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-combobox/-/react-combobox-9.7.4.tgz",
+ "integrity": "sha512-eLbgU4pF/9gDm+ksb5y2XPORloFtbMA8Py+ppFs2jy/s3GAdFbto9B5BHkSnCv46rCbfJsPS7fThAkh7i2rLug==",
+ "dependencies": {
+ "@fluentui/keyboard-keys": "^9.0.7",
+ "@fluentui/react-context-selector": "^9.1.51",
+ "@fluentui/react-field": "^9.1.53",
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-portal": "^9.4.12",
+ "@fluentui/react-positioning": "^9.13.2",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0",
+ "scheduler": "^0.19.0 || ^0.20.0"
+ }
+ },
+ "node_modules/@fluentui/react-components": {
+ "version": "9.46.3",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-components/-/react-components-9.46.3.tgz",
+ "integrity": "sha512-rpYQ5NwV2puIHqaVfeRFXxS40Sft9w7Brk98KSP2zH+wuVhVb7oAo+u66N9d68t6yMrkS6tfv3lRKz8KjQNw3w==",
+ "dependencies": {
+ "@fluentui/react-accordion": "^9.3.40",
+ "@fluentui/react-alert": "9.0.0-beta.108",
+ "@fluentui/react-aria": "^9.8.1",
+ "@fluentui/react-avatar": "^9.6.13",
+ "@fluentui/react-badge": "^9.2.24",
+ "@fluentui/react-breadcrumb": "^9.0.13",
+ "@fluentui/react-button": "^9.3.67",
+ "@fluentui/react-card": "^9.0.66",
+ "@fluentui/react-checkbox": "^9.2.11",
+ "@fluentui/react-combobox": "^9.7.4",
+ "@fluentui/react-dialog": "^9.9.9",
+ "@fluentui/react-divider": "^9.2.60",
+ "@fluentui/react-drawer": "^9.1.3",
+ "@fluentui/react-field": "^9.1.53",
+ "@fluentui/react-image": "^9.1.57",
+ "@fluentui/react-infobutton": "9.0.0-beta.92",
+ "@fluentui/react-infolabel": "^9.0.20",
+ "@fluentui/react-input": "^9.4.63",
+ "@fluentui/react-label": "^9.1.61",
+ "@fluentui/react-link": "^9.2.9",
+ "@fluentui/react-menu": "^9.12.49",
+ "@fluentui/react-message-bar": "^9.0.18",
+ "@fluentui/react-overflow": "^9.1.10",
+ "@fluentui/react-persona": "^9.2.72",
+ "@fluentui/react-popover": "^9.8.37",
+ "@fluentui/react-portal": "^9.4.12",
+ "@fluentui/react-positioning": "^9.13.2",
+ "@fluentui/react-progress": "^9.1.63",
+ "@fluentui/react-provider": "^9.13.10",
+ "@fluentui/react-radio": "^9.2.6",
+ "@fluentui/react-select": "^9.1.63",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-skeleton": "^9.0.51",
+ "@fluentui/react-slider": "^9.1.68",
+ "@fluentui/react-spinbutton": "^9.2.63",
+ "@fluentui/react-spinner": "^9.3.41",
+ "@fluentui/react-switch": "^9.1.68",
+ "@fluentui/react-table": "^9.11.9",
+ "@fluentui/react-tabs": "^9.4.8",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-tags": "^9.0.26",
+ "@fluentui/react-text": "^9.4.9",
+ "@fluentui/react-textarea": "^9.3.63",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-toast": "^9.3.29",
+ "@fluentui/react-toolbar": "^9.1.69",
+ "@fluentui/react-tooltip": "^9.4.15",
+ "@fluentui/react-tree": "^9.4.29",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@fluentui/react-virtualizer": "9.0.0-alpha.68",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0",
+ "scheduler": "^0.19.0 || ^0.20.0"
+ }
+ },
+ "node_modules/@fluentui/react-context-selector": {
+ "version": "9.1.51",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-context-selector/-/react-context-selector-9.1.51.tgz",
+ "integrity": "sha512-AzRC2XH7Ra39CQiGzV8xdfeVGIDqz6s7IjcBtL4HpA7G1g4pzfe2W9QbXOOr8iDwryCdMVbO+QP/sak+vMAcFw==",
+ "dependencies": {
+ "@fluentui/react-utilities": "^9.18.0",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0",
+ "scheduler": "^0.19.0 || ^0.20.0"
+ }
+ },
+ "node_modules/@fluentui/react-dialog": {
+ "version": "9.9.9",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-dialog/-/react-dialog-9.9.9.tgz",
+ "integrity": "sha512-UDOw4BOe7TjpI7+p+V8rHfHlWoNALxgJZ3cpQh/8yNwd6LrSQa2vpQEREhT0JU4C3VUQPj00iEWpiM5diE6vgQ==",
+ "dependencies": {
+ "@fluentui/keyboard-keys": "^9.0.7",
+ "@fluentui/react-aria": "^9.8.1",
+ "@fluentui/react-context-selector": "^9.1.51",
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-portal": "^9.4.12",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1",
+ "react-transition-group": "^4.4.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-divider": {
+ "version": "9.2.60",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-divider/-/react-divider-9.2.60.tgz",
+ "integrity": "sha512-TdFxSnSAK2SGzfzKsg/6Yfl+UxtirJpXY6B/ibHogLjLqsKm+RnVB8nyO5wd5RUoAQofWkQAAArTEl6UkJf1Kw==",
+ "dependencies": {
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-drawer": {
+ "version": "9.1.3",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-drawer/-/react-drawer-9.1.3.tgz",
+ "integrity": "sha512-0Er+0KPsQrKv3qfsaxZGpXKfntOXJMiYSl9JNQJxqKVoN+3Txc2WoSPe/En6xAPkW/oFIEFWpUEFqo/evjFzhw==",
+ "dependencies": {
+ "@fluentui/react-dialog": "^9.9.9",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-motion-preview": "^0.5.12",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-field": {
+ "version": "9.1.53",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-field/-/react-field-9.1.53.tgz",
+ "integrity": "sha512-u3zd2EjYZIMtCwEMAdb9wLODZWpfpWGWwgBKZMcZ3CpLm68TTcpkjqzUjg60l5aiyPvT8wThEUEHaeJBe0EgEg==",
+ "dependencies": {
+ "@fluentui/react-context-selector": "^9.1.51",
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-label": "^9.1.61",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-focus": {
+ "version": "8.8.40",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-focus/-/react-focus-8.8.40.tgz",
+ "integrity": "sha512-ha0CbLv5EIbjYCtQky6LVZObxOeMfhixrgrzfXm3Ta2eGs1NyZRDm1VeM6acOolWB/8QiN/CbdGckjALli8L2g==",
+ "dependencies": {
+ "@fluentui/keyboard-key": "^0.4.14",
+ "@fluentui/merge-styles": "^8.5.15",
+ "@fluentui/set-version": "^8.2.14",
+ "@fluentui/style-utilities": "^8.10.3",
+ "@fluentui/utilities": "^8.13.24",
+ "tslib": "^2.1.0"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.8.0 <19.0.0",
+ "react": ">=16.8.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-hooks": {
+ "version": "8.6.36",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-hooks/-/react-hooks-8.6.36.tgz",
+ "integrity": "sha512-kI0Z4Q4xHUs4SOmmI5n5OH5fPckqMSCovTRpiuxzCO2TNzLmfC861+nqf4Ygw/ChqNm2gWNZZfUADfnNAEsq+Q==",
+ "dependencies": {
+ "@fluentui/react-window-provider": "^2.2.18",
+ "@fluentui/set-version": "^8.2.14",
+ "@fluentui/utilities": "^8.13.24",
+ "tslib": "^2.1.0"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.8.0 <19.0.0",
+ "react": ">=16.8.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-icons": {
+ "version": "2.0.226",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-icons/-/react-icons-2.0.226.tgz",
+ "integrity": "sha512-OF2m1plWQnvvgXqdBTAIe+S7juC1fp2fnO3kMzIFH0c6doXMegNL6brD3mIDPk+JPIaZTAmWsDHTlIV10FyvHA==",
+ "dependencies": {
+ "@griffel/react": "^1.0.0",
+ "tslib": "^2.1.0"
+ },
+ "peerDependencies": {
+ "react": ">=16.8.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-image": {
+ "version": "9.1.57",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-image/-/react-image-9.1.57.tgz",
+ "integrity": "sha512-dB0/NFvYChztwmEnEK5XjCtC5BjhI5zA/kUsdxXXnXyT5SnRsOz4qLIU3z6RN7E2ZXvmtWEgwtzSy6UsmKuICw==",
+ "dependencies": {
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-infobutton": {
+ "version": "9.0.0-beta.92",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-infobutton/-/react-infobutton-9.0.0-beta.92.tgz",
+ "integrity": "sha512-VyBug0Rm7yI6r5X9qkbbbc4cJakzdM6Uw1iNQU7R+2a1tGTC6zpD+KCPJbIph0v06kWi6dUsYGv583UF0QUk1g==",
+ "dependencies": {
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-label": "^9.1.61",
+ "@fluentui/react-popover": "^9.8.37",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-infolabel": {
+ "version": "9.0.20",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-infolabel/-/react-infolabel-9.0.20.tgz",
+ "integrity": "sha512-ZWMKuD1bBXPG1/D1xWo4HkfFEeDH6ALzWehIdlg5Ush10m99AcrvbHRStbSlXYQzipkzLwezMND6la5t7FKUQw==",
+ "dependencies": {
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-label": "^9.1.61",
+ "@fluentui/react-popover": "^9.8.37",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.8.0 <19.0.0",
+ "@types/react-dom": ">=16.8.0 <19.0.0",
+ "react": ">=16.8.0 <19.0.0",
+ "react-dom": ">=16.8.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-input": {
+ "version": "9.4.63",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-input/-/react-input-9.4.63.tgz",
+ "integrity": "sha512-mj54J3w4RUxFEVntU6XKfKM2n5z0A619OplNHBK/C/boWL3vL1llNcWMAbcpB3EqsjeaOR/+MhPVrMwAh4+nPg==",
+ "dependencies": {
+ "@fluentui/react-field": "^9.1.53",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-jsx-runtime": {
+ "version": "9.0.29",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-jsx-runtime/-/react-jsx-runtime-9.0.29.tgz",
+ "integrity": "sha512-C+jurF0i0qaioKOFzpbC3DGER+W/QOW1v0qgEJemu2R2ldSbwgCBVagFysfjxAfnONz4zaDPTMRj58PwyEnBIQ==",
+ "dependencies": {
+ "@fluentui/react-utilities": "^9.18.0",
+ "@swc/helpers": "^0.5.1",
+ "react-is": "^17.0.2"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-label": {
+ "version": "9.1.61",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-label/-/react-label-9.1.61.tgz",
+ "integrity": "sha512-VTiZ2Y9Nipmsq4YL3qjhZeyRMkj2nKHMOWrvifkG85ss62+PpWUDC8BBQKqbI0vLiFVYImMezCeQUX3qSYqgoA==",
+ "dependencies": {
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-link": {
+ "version": "9.2.9",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-link/-/react-link-9.2.9.tgz",
+ "integrity": "sha512-qUq//CMImYOb9Q4U4GSxh35ZDEayy7sFlCcW/xRYffAxYvxzjYVCUduIIAwVl++5eZiJ8zZh1pGmhgBux+Lv/Q==",
+ "dependencies": {
+ "@fluentui/keyboard-keys": "^9.0.7",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-menu": {
+ "version": "9.12.49",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-menu/-/react-menu-9.12.49.tgz",
+ "integrity": "sha512-0hwp63b5T7G6gs0GEOhFsjHDvWEkj0M8di1X+OFtzU7sumkk/Mw5AUjqh/9jz/xoD8RzJzbZQxc3Vm/Q10aKrQ==",
+ "dependencies": {
+ "@fluentui/keyboard-keys": "^9.0.7",
+ "@fluentui/react-aria": "^9.8.1",
+ "@fluentui/react-context-selector": "^9.1.51",
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-portal": "^9.4.12",
+ "@fluentui/react-positioning": "^9.13.2",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0",
+ "scheduler": "^0.19.0 || ^0.20.0"
+ }
+ },
+ "node_modules/@fluentui/react-message-bar": {
+ "version": "9.0.18",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-message-bar/-/react-message-bar-9.0.18.tgz",
+ "integrity": "sha512-bujBtXcYF8FBCNzLJJQ8yyYSsHProvjMjE2vLtIV75X4Ow/m57Ab8LJQFkcRhR5Ks4yeASA6MBrH3HMD56R72A==",
+ "dependencies": {
+ "@fluentui/react-button": "^9.3.67",
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1",
+ "react-transition-group": "^4.4.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.8.0 <19.0.0",
+ "@types/react-dom": ">=16.8.0 <19.0.0",
+ "react": ">=16.8.0 <19.0.0",
+ "react-dom": ">=16.8.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-motion-preview": {
+ "version": "0.5.12",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-motion-preview/-/react-motion-preview-0.5.12.tgz",
+ "integrity": "sha512-mZ5Ys4ASWyrDAD1XKZI4rQtmEPLvnYp8Bv59ebINJcdeNJSETSq1TThwIDyfoimO4Kaw/092ydOJyL98dGXA1w==",
+ "dependencies": {
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-overflow": {
+ "version": "9.1.10",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-overflow/-/react-overflow-9.1.10.tgz",
+ "integrity": "sha512-llvTkxT63c8vBGo/ihivMMqCth9BYf63VTZgx01Sj+v+ABxnDlZfh8D8vJjijghwL0X3MeG24CYci4FHLdDfjg==",
+ "dependencies": {
+ "@fluentui/priority-overflow": "^9.1.11",
+ "@fluentui/react-context-selector": "^9.1.51",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0",
+ "scheduler": "^0.19.0 || ^0.20.0"
+ }
+ },
+ "node_modules/@fluentui/react-persona": {
+ "version": "9.2.72",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-persona/-/react-persona-9.2.72.tgz",
+ "integrity": "sha512-6P5JK95IXaguzUKtCE0FrVT899/RG1kX1IIsFXnON6F4Kas5eVWQCRqYuP8cJd6Jwvg38twPXJk/I7OslB1Hgw==",
+ "dependencies": {
+ "@fluentui/react-avatar": "^9.6.13",
+ "@fluentui/react-badge": "^9.2.24",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-popover": {
+ "version": "9.8.37",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-popover/-/react-popover-9.8.37.tgz",
+ "integrity": "sha512-iJvJ5C7uED03R3tc+D4ybovS3omHeZbrnXBF9XLwdoA5jJX5tXmKrHjUyA8o+nF+C6IVlMyVDT/nYMhYIYZ/DA==",
+ "dependencies": {
+ "@fluentui/keyboard-keys": "^9.0.7",
+ "@fluentui/react-aria": "^9.8.1",
+ "@fluentui/react-context-selector": "^9.1.51",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-portal": "^9.4.12",
+ "@fluentui/react-positioning": "^9.13.2",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0",
+ "scheduler": "^0.19.0 || ^0.20.0"
+ }
+ },
+ "node_modules/@fluentui/react-portal": {
+ "version": "9.4.12",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-portal/-/react-portal-9.4.12.tgz",
+ "integrity": "sha512-gUiu+K9ZPBz/VGk1UVP+1JB7cIfyZTDLqJZreYjG8xHFx3qxsD9f26uaPasWFC36wfc29MWPeNFJ0WaEXwlfPQ==",
+ "dependencies": {
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1",
+ "use-disposable": "^1.0.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-portal-compat-context": {
+ "version": "9.0.11",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-portal-compat-context/-/react-portal-compat-context-9.0.11.tgz",
+ "integrity": "sha512-ubvW/ej0O+Pago9GH3mPaxzUgsNnBoqvghNamWjyKvZIViyaXUG6+sgcAl721R+qGAFac+A20akI5qDJz/xtdg==",
+ "dependencies": {
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-positioning": {
+ "version": "9.13.2",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-positioning/-/react-positioning-9.13.2.tgz",
+ "integrity": "sha512-oGaOq0CjSdGRf0fI0cclKSO0PHJtyceyJpyQhjdXPdlqLGlgeQPE2ZnZ3FTDv9oICRGEgj/icElIZF5QzT+NNg==",
+ "dependencies": {
+ "@floating-ui/devtools": "0.2.1",
+ "@floating-ui/dom": "^1.2.0",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-progress": {
+ "version": "9.1.63",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-progress/-/react-progress-9.1.63.tgz",
+ "integrity": "sha512-dsUbahuDIvCYKJPGVZmz5S5aZjEAWcax1cDF/t51YGhfYCaKhqKeaw70z/5dgQpn3+Tvs1aYnlf4WudT7ThAxQ==",
+ "dependencies": {
+ "@fluentui/react-field": "^9.1.53",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-provider": {
+ "version": "9.13.10",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-provider/-/react-provider-9.13.10.tgz",
+ "integrity": "sha512-TViUxZNiTfOOPCsKx7fyRuso7t6TmYlQh3C3+gTm5oHKZoED4YSAruWkYqVehRvLDQMw7oNaRK54IalfIQTXNA==",
+ "dependencies": {
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/core": "^1.14.1",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-radio": {
+ "version": "9.2.6",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-radio/-/react-radio-9.2.6.tgz",
+ "integrity": "sha512-uatP+BkFOq6hQGAxa416na5qnBmkeLwwJnSVra51KQKgznpg2NT0DilUeCqz5PXclOZf31TQXvCIUh3U5uoxHA==",
+ "dependencies": {
+ "@fluentui/react-field": "^9.1.53",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-label": "^9.1.61",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0",
+ "scheduler": "^0.19.0 || ^0.20.0"
+ }
+ },
+ "node_modules/@fluentui/react-select": {
+ "version": "9.1.63",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-select/-/react-select-9.1.63.tgz",
+ "integrity": "sha512-6IEUpitDaPuOpxBidKQsgwFfs0ppluKzC3ONAaCVVr3rV6iMkN47t28GHFjJnEHfeYXn6mzfs9vFJTijyhrc/A==",
+ "dependencies": {
+ "@fluentui/react-field": "^9.1.53",
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-shared-contexts": {
+ "version": "9.14.0",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-shared-contexts/-/react-shared-contexts-9.14.0.tgz",
+ "integrity": "sha512-P9yhg31WYfB1W66/gD3+qVCLBsyIEcOzQvKVaIQvd9UhF67lNW4kMXUB6YVOk5PV0Og4hXnkH/vuHl7YMD9RHw==",
+ "dependencies": {
+ "@fluentui/react-theme": "^9.1.16",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-skeleton": {
+ "version": "9.0.51",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-skeleton/-/react-skeleton-9.0.51.tgz",
+ "integrity": "sha512-2HBRXEjAMjiEhT+cotqxuCeRh67ZgXTPgIXvZpzgk2hEsxTcWKBfpVv2dSQpnE4boxmpt8Jg4KlzqtMYV0+T+Q==",
+ "dependencies": {
+ "@fluentui/react-field": "^9.1.53",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-slider": {
+ "version": "9.1.68",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-slider/-/react-slider-9.1.68.tgz",
+ "integrity": "sha512-UN4PBuOjrZ4dMA/wMnSdaT/CUtKpXrUR2K1VNLEqWMfPsplFU5SWov6EfKtDwrfphRqSg1k0dDQfSBe/C2okPQ==",
+ "dependencies": {
+ "@fluentui/react-field": "^9.1.53",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-spinbutton": {
+ "version": "9.2.63",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-spinbutton/-/react-spinbutton-9.2.63.tgz",
+ "integrity": "sha512-/7LnVtaYAz7rDtyqEMgMRftWg7IOEw/9rLFldzBCbUpn1A4/VuzQD2W8QAdpTutpEoIw5ripA3GEAsLYkJBEDA==",
+ "dependencies": {
+ "@fluentui/keyboard-keys": "^9.0.7",
+ "@fluentui/react-field": "^9.1.53",
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-spinner": {
+ "version": "9.3.41",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-spinner/-/react-spinner-9.3.41.tgz",
+ "integrity": "sha512-8ojZ+S34p+eLBMsy22zYcZIWibQ1xz44bFaqziV79kuThHe0960W18lOj2PXmGsAhiFVSAEZYwx5Hm+h027qEg==",
+ "dependencies": {
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-label": "^9.1.61",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-switch": {
+ "version": "9.1.68",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-switch/-/react-switch-9.1.68.tgz",
+ "integrity": "sha512-Kx7F3Tf2L+GvstrlE2ebnOXLPKXSp4CTVjuSzP5/sR5Q62lGaHMN+AOFLXi2gumfMn61c6ApqxU0LEFpPuQmjw==",
+ "dependencies": {
+ "@fluentui/react-field": "^9.1.53",
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-label": "^9.1.61",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-table": {
+ "version": "9.11.9",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-table/-/react-table-9.11.9.tgz",
+ "integrity": "sha512-jvUbBgKoI8Ne1w19urfWkpnuGlXKWlX8Bqf1MqlswZWPESGmKv2A8gXuSVJVjkld2BUeUORNSvoSDcY8IccIHQ==",
+ "dependencies": {
+ "@fluentui/keyboard-keys": "^9.0.7",
+ "@fluentui/react-aria": "^9.8.1",
+ "@fluentui/react-avatar": "^9.6.13",
+ "@fluentui/react-checkbox": "^9.2.11",
+ "@fluentui/react-context-selector": "^9.1.51",
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-radio": "^9.2.6",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-tabs": {
+ "version": "9.4.8",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-tabs/-/react-tabs-9.4.8.tgz",
+ "integrity": "sha512-mdPB05KLRghYU2p8W8X6w5LifYijqQGF0+EQKCdGm4vV1IibleasOvA1sNvuMfCn5fVUojQWGBkj9PpqJdzzHQ==",
+ "dependencies": {
+ "@fluentui/react-context-selector": "^9.1.51",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0",
+ "scheduler": "^0.19.0 || ^0.20.0"
+ }
+ },
+ "node_modules/@fluentui/react-tabster": {
+ "version": "9.18.0",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-tabster/-/react-tabster-9.18.0.tgz",
+ "integrity": "sha512-WYeyeb35EWC+gXTjTzuKNCxOpuvk0nJ52zJ4Z0Wqm8gj/GdlHqlgjzv3a/jO229ELTfbJFwDEU4X/EvEU87OxA==",
+ "dependencies": {
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1",
+ "keyborg": "^2.5.0",
+ "tabster": "^6.0.0"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-tags": {
+ "version": "9.0.26",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-tags/-/react-tags-9.0.26.tgz",
+ "integrity": "sha512-+nTxZGRA/0uw21Js++PIA69OKif9ic1VzEkmrhbOMXr5UnCe0emFSC/sIQzmuoHHUt0+qHBHkoCO27vC8LHgRA==",
+ "dependencies": {
+ "@fluentui/keyboard-keys": "^9.0.7",
+ "@fluentui/react-aria": "^9.8.1",
+ "@fluentui/react-avatar": "^9.6.13",
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-text": {
+ "version": "9.4.9",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-text/-/react-text-9.4.9.tgz",
+ "integrity": "sha512-vEUnZf4Yj4JJpmMmObXJ7SWVsX10dcEMEola9+UuuNyi7jV6hODdeU6gzAbuOli0lqBTfUcyPlCKOxRyGURMAw==",
+ "dependencies": {
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-textarea": {
+ "version": "9.3.63",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-textarea/-/react-textarea-9.3.63.tgz",
+ "integrity": "sha512-MZBhuQzLh9S2gLitM+Szjd8zdb0uUfIxxjqdHrDgJ49xLhYlo3I/4vX4LM4UQmuESVJn5gnK2I+BXX7LXwOjZw==",
+ "dependencies": {
+ "@fluentui/react-field": "^9.1.53",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-theme": {
+ "version": "9.1.16",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-theme/-/react-theme-9.1.16.tgz",
+ "integrity": "sha512-QK2dGE5aQXN1UGdiEmGKpYGP3tHXIchLvFf8DEEOWnF4XBc9SiEPNFYkvLMJjHxZmDz4D670rsOPe0r5jFDEKQ==",
+ "dependencies": {
+ "@fluentui/tokens": "1.0.0-alpha.13",
+ "@swc/helpers": "^0.5.1"
+ }
+ },
+ "node_modules/@fluentui/react-toast": {
+ "version": "9.3.29",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-toast/-/react-toast-9.3.29.tgz",
+ "integrity": "sha512-mAGgdFrm3wHO3rBXGESpX035934BCKDMZ9FixjLQW7mEI9wEszPHptkD6ph2cmylQS2ktmPV1xz2YEx2IwlFXQ==",
+ "dependencies": {
+ "@fluentui/keyboard-keys": "^9.0.7",
+ "@fluentui/react-aria": "^9.8.1",
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-portal": "^9.4.12",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1",
+ "react-transition-group": "^4.4.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-toolbar": {
+ "version": "9.1.69",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-toolbar/-/react-toolbar-9.1.69.tgz",
+ "integrity": "sha512-U+xIa9BBKPf8rA1rsTShgngg3nDl2Gd9NQ8JjqFdxdzWUwhkfU3+pdxwNnfV2z2McD2rVR8OTP+jJidbrEBn3Q==",
+ "dependencies": {
+ "@fluentui/react-button": "^9.3.67",
+ "@fluentui/react-context-selector": "^9.1.51",
+ "@fluentui/react-divider": "^9.2.60",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-radio": "^9.2.6",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-tooltip": {
+ "version": "9.4.15",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-tooltip/-/react-tooltip-9.4.15.tgz",
+ "integrity": "sha512-Etox9sBgDwTcqTyQ5vPY0bkqAY8F2xvkpYPxKFZQa8ws5pFsC/o1vA6kAiIbYR7rSBRivU5mKIIIhCqpUD+mgQ==",
+ "dependencies": {
+ "@fluentui/keyboard-keys": "^9.0.7",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-portal": "^9.4.12",
+ "@fluentui/react-positioning": "^9.13.2",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-tree": {
+ "version": "9.4.29",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-tree/-/react-tree-9.4.29.tgz",
+ "integrity": "sha512-d4eKM8as43MrgeRUjwkeM0thpGrjhxV9y/nz/B/bqs7XAFFN51mSQNuZ6kDEd6BUoIzWXGwVVLpFHsoaFJ2RFg==",
+ "dependencies": {
+ "@fluentui/keyboard-keys": "^9.0.7",
+ "@fluentui/react-aria": "^9.8.1",
+ "@fluentui/react-avatar": "^9.6.13",
+ "@fluentui/react-button": "^9.3.67",
+ "@fluentui/react-checkbox": "^9.2.11",
+ "@fluentui/react-context-selector": "^9.1.51",
+ "@fluentui/react-icons": "^2.0.224",
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-radio": "^9.2.6",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-tabster": "^9.18.0",
+ "@fluentui/react-theme": "^9.1.16",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-utilities": {
+ "version": "9.18.0",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-utilities/-/react-utilities-9.18.0.tgz",
+ "integrity": "sha512-PuuTKm/HReDdLwhpMiEC9SxaCe2NtIL8Ed+kVGBDzqEeVjJylCJWHy4tyOJCJ/+yz1Xyj6thiXr2k8Q5X+m7eg==",
+ "dependencies": {
+ "@fluentui/keyboard-keys": "^9.0.7",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-virtualizer": {
+ "version": "9.0.0-alpha.68",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-virtualizer/-/react-virtualizer-9.0.0-alpha.68.tgz",
+ "integrity": "sha512-01sTPBW1W1FyaJwb1JlV7wyCBBLo+y9NQzPET3LQDJSQ7py1XEd7RL6XPMa/IJ+XbeR8hEPhHEHdtehylliMVw==",
+ "dependencies": {
+ "@fluentui/react-jsx-runtime": "^9.0.29",
+ "@fluentui/react-shared-contexts": "^9.14.0",
+ "@fluentui/react-utilities": "^9.18.0",
+ "@griffel/react": "^1.5.14",
+ "@swc/helpers": "^0.5.1"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.14.0 <19.0.0",
+ "@types/react-dom": ">=16.9.0 <19.0.0",
+ "react": ">=16.14.0 <19.0.0",
+ "react-dom": ">=16.14.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/react-window-provider": {
+ "version": "2.2.18",
+ "resolved": "https://registry.npmjs.org/@fluentui/react-window-provider/-/react-window-provider-2.2.18.tgz",
+ "integrity": "sha512-nBKqxd0P8NmIR0qzFvka1urE2LVbUm6cse1I1T7TcOVNYa5jDf5BrO06+JRZfwbn00IJqOnIVoP0qONqceypWQ==",
+ "dependencies": {
+ "@fluentui/set-version": "^8.2.14",
+ "tslib": "^2.1.0"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.8.0 <19.0.0",
+ "react": ">=16.8.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/set-version": {
+ "version": "8.2.14",
+ "resolved": "https://registry.npmjs.org/@fluentui/set-version/-/set-version-8.2.14.tgz",
+ "integrity": "sha512-f/QWJnSeyfAjGAqq57yjMb6a5ejPlwfzdExPmzFBuEOuupi8hHbV8Yno12XJcTW4I0KXEQGw+PUaM1aOf/j7jw==",
+ "dependencies": {
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@fluentui/style-utilities": {
+ "version": "8.10.3",
+ "resolved": "https://registry.npmjs.org/@fluentui/style-utilities/-/style-utilities-8.10.3.tgz",
+ "integrity": "sha512-pyO9BGkwIxXaIMVT6ma98GIZAgTjGc0LZ5iUai9GLIrFLQWnIKnS//hgUx8qG4AecUeqZ26Wb0e+Ale9NyPQCQ==",
+ "dependencies": {
+ "@fluentui/merge-styles": "^8.5.15",
+ "@fluentui/set-version": "^8.2.14",
+ "@fluentui/theme": "^2.6.41",
+ "@fluentui/utilities": "^8.13.24",
+ "@microsoft/load-themed-styles": "^1.10.26",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@fluentui/theme": {
+ "version": "2.6.41",
+ "resolved": "https://registry.npmjs.org/@fluentui/theme/-/theme-2.6.41.tgz",
+ "integrity": "sha512-h9RguEzqzJ0+59ys5Kkp7JtsjhDUxBLmQunu5rpHp5Mp788OtEjI/n1a9FIcOAL/priPSQwXN7RbuDpeP7+aSw==",
+ "dependencies": {
+ "@fluentui/merge-styles": "^8.5.15",
+ "@fluentui/set-version": "^8.2.14",
+ "@fluentui/utilities": "^8.13.24",
+ "tslib": "^2.1.0"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.8.0 <19.0.0",
+ "react": ">=16.8.0 <19.0.0"
+ }
+ },
+ "node_modules/@fluentui/tokens": {
+ "version": "1.0.0-alpha.13",
+ "resolved": "https://registry.npmjs.org/@fluentui/tokens/-/tokens-1.0.0-alpha.13.tgz",
+ "integrity": "sha512-IzYysTTBkAH7tQZxYKpzhxYnTJkvwXhjhTOpmERgnqTFifHTP8/vaQjJAAm7dI/9zlDx1oN+y/I+KzL9bDLHZQ==",
+ "dependencies": {
+ "@swc/helpers": "^0.5.1"
+ }
+ },
+ "node_modules/@fluentui/utilities": {
+ "version": "8.13.24",
+ "resolved": "https://registry.npmjs.org/@fluentui/utilities/-/utilities-8.13.24.tgz",
+ "integrity": "sha512-/jo6hWCzTGCx06l2baAMwsjjBZ/dyMouls53uNaQLUGUUhUwXh/DcDDXMqLRJB3MaH9zvgfvRw61iKmm2s9fIA==",
+ "dependencies": {
+ "@fluentui/dom-utilities": "^2.2.14",
+ "@fluentui/merge-styles": "^8.5.15",
+ "@fluentui/set-version": "^8.2.14",
+ "tslib": "^2.1.0"
+ },
+ "peerDependencies": {
+ "@types/react": ">=16.8.0 <19.0.0",
+ "react": ">=16.8.0 <19.0.0"
+ }
+ },
+ "node_modules/@flydotio/dockerfile": {
+ "version": "0.5.2",
+ "resolved": "https://registry.npmjs.org/@flydotio/dockerfile/-/dockerfile-0.5.2.tgz",
+ "integrity": "sha512-2IQ32c6Eeag1gUD35wNLfdJw7CK1HanwESQKBkHdVjsT1eakMFgP/9QJ7a88QkfPBmzQFU2yNci/bxQZBpAucw==",
+ "dev": true,
+ "dependencies": {
+ "chalk": "^5.3.0",
+ "diff": "^5.1.0",
+ "ejs": "^3.1.9",
+ "shell-quote": "^1.8.1",
+ "yargs": "^17.7.2"
+ },
+ "bin": {
+ "dockerfile": "index.js"
+ },
+ "engines": {
+ "node": ">=16.0.0"
+ }
+ },
+ "node_modules/@flydotio/dockerfile/node_modules/chalk": {
+ "version": "5.3.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-5.3.0.tgz",
+ "integrity": "sha512-dLitG79d+GV1Nb/VYcCDFivJeK1hiukt9QjRNVOsUtTy1rR1YJsmpGGTZ3qJos+uw7WmWF4wUwBd9jxjocFC2w==",
+ "dev": true,
+ "engines": {
+ "node": "^12.17.0 || ^14.13 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/@griffel/core": {
+ "version": "1.15.2",
+ "resolved": "https://registry.npmjs.org/@griffel/core/-/core-1.15.2.tgz",
+ "integrity": "sha512-RlsIXoSS3gaYykUgxFpwKAs/DV9cRUKp3CW1kt3iPAtsDTWn/o+8bT1jvBws/tMM2GBu/Uc0EkaIzUPqD7uA+Q==",
+ "dependencies": {
+ "@emotion/hash": "^0.9.0",
+ "@griffel/style-types": "^1.0.3",
+ "csstype": "^3.1.3",
+ "rtl-css-js": "^1.16.1",
+ "stylis": "^4.2.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@griffel/react": {
+ "version": "1.5.20",
+ "resolved": "https://registry.npmjs.org/@griffel/react/-/react-1.5.20.tgz",
+ "integrity": "sha512-1P2yaPctENFSCwyPIYXBmgpNH68c0lc/jwSzPij1QATHDK1AASKuSeq6hW108I67RKjhRyHCcALshdZ3GcQXSg==",
+ "dependencies": {
+ "@griffel/core": "^1.15.2",
+ "tslib": "^2.1.0"
+ },
+ "peerDependencies": {
+ "react": ">=16.8.0 <19.0.0"
+ }
+ },
+ "node_modules/@griffel/style-types": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/@griffel/style-types/-/style-types-1.0.3.tgz",
+ "integrity": "sha512-AzbbYV/EobNIBtfMtyu2edFin895gjVxtu1nsRhTETUAIb0/LCZoue3Jd/kFLuPwe95rv5WRUBiQpVwJsrrFcw==",
+ "dependencies": {
+ "csstype": "^3.1.3"
+ }
+ },
+ "node_modules/@gulpjs/to-absolute-glob": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/@gulpjs/to-absolute-glob/-/to-absolute-glob-4.0.0.tgz",
+ "integrity": "sha512-kjotm7XJrJ6v+7knhPaRgaT6q8F8K2jiafwYdNHLzmV0uGLuZY43FK6smNSHUPrhq5kX2slCUy+RGG/xGqmIKA==",
+ "dev": true,
+ "dependencies": {
+ "is-negated-glob": "^1.0.0"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/@humanwhocodes/config-array": {
+ "version": "0.11.14",
+ "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.14.tgz",
+ "integrity": "sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg==",
+ "dev": true,
+ "dependencies": {
+ "@humanwhocodes/object-schema": "^2.0.2",
+ "debug": "^4.3.1",
+ "minimatch": "^3.0.5"
+ },
+ "engines": {
+ "node": ">=10.10.0"
+ }
+ },
+ "node_modules/@humanwhocodes/config-array/node_modules/brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "dependencies": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "node_modules/@humanwhocodes/config-array/node_modules/minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dev": true,
+ "dependencies": {
+ "brace-expansion": "^1.1.7"
+ },
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/@humanwhocodes/module-importer": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz",
+ "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==",
+ "dev": true,
+ "engines": {
+ "node": ">=12.22"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/nzakas"
+ }
+ },
+ "node_modules/@humanwhocodes/object-schema": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.2.tgz",
+ "integrity": "sha512-6EwiSjwWYP7pTckG6I5eyFANjPhmPjUX9JRLUSfNPC7FX7zK9gyZAfUEaECL6ALTpGX5AjnBq3C9XmVWPitNpw==",
+ "dev": true
+ },
+ "node_modules/@jridgewell/gen-mapping": {
+ "version": "0.3.3",
+ "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz",
+ "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/set-array": "^1.0.1",
+ "@jridgewell/sourcemap-codec": "^1.4.10",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/resolve-uri": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.1.tgz",
+ "integrity": "sha512-dSYZh7HhCDtCKm4QakX0xFpsRDqjjtZf/kjI/v3T3Nwt5r8/qz/M19F9ySyOqU94SXBmeG9ttTul+YnR4LOxFA==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/set-array": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz",
+ "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/source-map": {
+ "version": "0.3.5",
+ "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.5.tgz",
+ "integrity": "sha512-UTYAUj/wviwdsMfzoSJspJxbkH5o1snzwX0//0ENX1u/55kkZZkcTZP6u9bwKGkv+dkk9at4m1Cpt0uY80kcpQ==",
+ "dev": true,
+ "optional": true,
+ "peer": true,
+ "dependencies": {
+ "@jridgewell/gen-mapping": "^0.3.0",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ }
+ },
+ "node_modules/@jridgewell/sourcemap-codec": {
+ "version": "1.4.15",
+ "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz",
+ "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==",
+ "dev": true
+ },
+ "node_modules/@jridgewell/trace-mapping": {
+ "version": "0.3.22",
+ "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.22.tgz",
+ "integrity": "sha512-Wf963MzWtA2sjrNt+g18IAln9lKnlRp+K2eH4jjIoF1wYeq3aMREpG09xhlhdzS0EjwU7qmUJYangWa+151vZw==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/resolve-uri": "^3.1.0",
+ "@jridgewell/sourcemap-codec": "^1.4.14"
+ }
+ },
+ "node_modules/@microsoft/load-themed-styles": {
+ "version": "1.10.295",
+ "resolved": "https://registry.npmjs.org/@microsoft/load-themed-styles/-/load-themed-styles-1.10.295.tgz",
+ "integrity": "sha512-W+IzEBw8a6LOOfRJM02dTT7BDZijxm+Z7lhtOAz1+y9vQm1Kdz9jlAO+qCEKsfxtUOmKilW8DIRqFw2aUgKeGg=="
+ },
+ "node_modules/@nodelib/fs.scandir": {
+ "version": "2.1.5",
+ "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz",
+ "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==",
+ "dev": true,
+ "dependencies": {
+ "@nodelib/fs.stat": "2.0.5",
+ "run-parallel": "^1.1.9"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/@nodelib/fs.stat": {
+ "version": "2.0.5",
+ "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz",
+ "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==",
+ "dev": true,
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/@nodelib/fs.walk": {
+ "version": "1.2.8",
+ "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz",
+ "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==",
+ "dev": true,
+ "dependencies": {
+ "@nodelib/fs.scandir": "2.1.5",
+ "fastq": "^1.6.0"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/@remix-run/router": {
+ "version": "1.14.2",
+ "resolved": "https://registry.npmjs.org/@remix-run/router/-/router-1.14.2.tgz",
+ "integrity": "sha512-ACXpdMM9hmKZww21yEqWwiLws/UPLhNKvimN8RrYSqPSvB3ov7sLvAcfvaxePeLvccTQKGdkDIhLYApZVDFuKg==",
+ "engines": {
+ "node": ">=14.0.0"
+ }
+ },
+ "node_modules/@rollup/pluginutils": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-5.1.0.tgz",
+ "integrity": "sha512-XTIWOPPcpvyKI6L1NHo0lFlCyznUEyPmPY1mc3KpPVDYulHSTvyeLNVW00QTLIAFNhR3kYnJTQHeGqU4M3n09g==",
+ "dev": true,
+ "dependencies": {
+ "@types/estree": "^1.0.0",
+ "estree-walker": "^2.0.2",
+ "picomatch": "^2.3.1"
+ },
+ "engines": {
+ "node": ">=14.0.0"
+ },
+ "peerDependencies": {
+ "rollup": "^1.20.0||^2.0.0||^3.0.0||^4.0.0"
+ },
+ "peerDependenciesMeta": {
+ "rollup": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@rollup/rollup-android-arm-eabi": {
+ "version": "4.9.6",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.9.6.tgz",
+ "integrity": "sha512-MVNXSSYN6QXOulbHpLMKYi60ppyO13W9my1qogeiAqtjb2yR4LSmfU2+POvDkLzhjYLXz9Rf9+9a3zFHW1Lecg==",
+ "cpu": [
+ "arm"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "android"
+ ]
+ },
+ "node_modules/@rollup/rollup-android-arm64": {
+ "version": "4.9.6",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.9.6.tgz",
+ "integrity": "sha512-T14aNLpqJ5wzKNf5jEDpv5zgyIqcpn1MlwCrUXLrwoADr2RkWA0vOWP4XxbO9aiO3dvMCQICZdKeDrFl7UMClw==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "android"
+ ]
+ },
+ "node_modules/@rollup/rollup-darwin-arm64": {
+ "version": "4.9.6",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.9.6.tgz",
+ "integrity": "sha512-CqNNAyhRkTbo8VVZ5R85X73H3R5NX9ONnKbXuHisGWC0qRbTTxnF1U4V9NafzJbgGM0sHZpdO83pLPzq8uOZFw==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "darwin"
+ ]
+ },
+ "node_modules/@rollup/rollup-darwin-x64": {
+ "version": "4.9.6",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.9.6.tgz",
+ "integrity": "sha512-zRDtdJuRvA1dc9Mp6BWYqAsU5oeLixdfUvkTHuiYOHwqYuQ4YgSmi6+/lPvSsqc/I0Omw3DdICx4Tfacdzmhog==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "darwin"
+ ]
+ },
+ "node_modules/@rollup/rollup-linux-arm-gnueabihf": {
+ "version": "4.9.6",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.9.6.tgz",
+ "integrity": "sha512-oNk8YXDDnNyG4qlNb6is1ojTOGL/tRhbbKeE/YuccItzerEZT68Z9gHrY3ROh7axDc974+zYAPxK5SH0j/G+QQ==",
+ "cpu": [
+ "arm"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ]
+ },
+ "node_modules/@rollup/rollup-linux-arm64-gnu": {
+ "version": "4.9.6",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.9.6.tgz",
+ "integrity": "sha512-Z3O60yxPtuCYobrtzjo0wlmvDdx2qZfeAWTyfOjEDqd08kthDKexLpV97KfAeUXPosENKd8uyJMRDfFMxcYkDQ==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ]
+ },
+ "node_modules/@rollup/rollup-linux-arm64-musl": {
+ "version": "4.9.6",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.9.6.tgz",
+ "integrity": "sha512-gpiG0qQJNdYEVad+1iAsGAbgAnZ8j07FapmnIAQgODKcOTjLEWM9sRb+MbQyVsYCnA0Im6M6QIq6ax7liws6eQ==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ]
+ },
+ "node_modules/@rollup/rollup-linux-riscv64-gnu": {
+ "version": "4.9.6",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.9.6.tgz",
+ "integrity": "sha512-+uCOcvVmFUYvVDr27aiyun9WgZk0tXe7ThuzoUTAukZJOwS5MrGbmSlNOhx1j80GdpqbOty05XqSl5w4dQvcOA==",
+ "cpu": [
+ "riscv64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ]
+ },
+ "node_modules/@rollup/rollup-linux-x64-gnu": {
+ "version": "4.9.6",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.9.6.tgz",
+ "integrity": "sha512-HUNqM32dGzfBKuaDUBqFB7tP6VMN74eLZ33Q9Y1TBqRDn+qDonkAUyKWwF9BR9unV7QUzffLnz9GrnKvMqC/fw==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ]
+ },
+ "node_modules/@rollup/rollup-linux-x64-musl": {
+ "version": "4.9.6",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.9.6.tgz",
+ "integrity": "sha512-ch7M+9Tr5R4FK40FHQk8VnML0Szi2KRujUgHXd/HjuH9ifH72GUmw6lStZBo3c3GB82vHa0ZoUfjfcM7JiiMrQ==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ]
+ },
+ "node_modules/@rollup/rollup-win32-arm64-msvc": {
+ "version": "4.9.6",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.9.6.tgz",
+ "integrity": "sha512-VD6qnR99dhmTQ1mJhIzXsRcTBvTjbfbGGwKAHcu+52cVl15AC/kplkhxzW/uT0Xl62Y/meBKDZvoJSJN+vTeGA==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "win32"
+ ]
+ },
+ "node_modules/@rollup/rollup-win32-ia32-msvc": {
+ "version": "4.9.6",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.9.6.tgz",
+ "integrity": "sha512-J9AFDq/xiRI58eR2NIDfyVmTYGyIZmRcvcAoJ48oDld/NTR8wyiPUu2X/v1navJ+N/FGg68LEbX3Ejd6l8B7MQ==",
+ "cpu": [
+ "ia32"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "win32"
+ ]
+ },
+ "node_modules/@rollup/rollup-win32-x64-msvc": {
+ "version": "4.9.6",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.9.6.tgz",
+ "integrity": "sha512-jqzNLhNDvIZOrt69Ce4UjGRpXJBzhUBzawMwnaDAwyHriki3XollsewxWzOzz+4yOFDkuJHtTsZFwMxhYJWmLQ==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "win32"
+ ]
+ },
+ "node_modules/@svgr/babel-plugin-add-jsx-attribute": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-add-jsx-attribute/-/babel-plugin-add-jsx-attribute-8.0.0.tgz",
+ "integrity": "sha512-b9MIk7yhdS1pMCZM8VeNfUlSKVRhsHZNMl5O9SfaX0l0t5wjdgu4IDzGB8bpnGBBOjGST3rRFVsaaEtI4W6f7g==",
+ "dev": true,
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@svgr/babel-plugin-remove-jsx-attribute": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-remove-jsx-attribute/-/babel-plugin-remove-jsx-attribute-8.0.0.tgz",
+ "integrity": "sha512-BcCkm/STipKvbCl6b7QFrMh/vx00vIP63k2eM66MfHJzPr6O2U0jYEViXkHJWqXqQYjdeA9cuCl5KWmlwjDvbA==",
+ "dev": true,
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@svgr/babel-plugin-remove-jsx-empty-expression": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-remove-jsx-empty-expression/-/babel-plugin-remove-jsx-empty-expression-8.0.0.tgz",
+ "integrity": "sha512-5BcGCBfBxB5+XSDSWnhTThfI9jcO5f0Ai2V24gZpG+wXF14BzwxxdDb4g6trdOux0rhibGs385BeFMSmxtS3uA==",
+ "dev": true,
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@svgr/babel-plugin-replace-jsx-attribute-value": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-replace-jsx-attribute-value/-/babel-plugin-replace-jsx-attribute-value-8.0.0.tgz",
+ "integrity": "sha512-KVQ+PtIjb1BuYT3ht8M5KbzWBhdAjjUPdlMtpuw/VjT8coTrItWX6Qafl9+ji831JaJcu6PJNKCV0bp01lBNzQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@svgr/babel-plugin-svg-dynamic-title": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-svg-dynamic-title/-/babel-plugin-svg-dynamic-title-8.0.0.tgz",
+ "integrity": "sha512-omNiKqwjNmOQJ2v6ge4SErBbkooV2aAWwaPFs2vUY7p7GhVkzRkJ00kILXQvRhA6miHnNpXv7MRnnSjdRjK8og==",
+ "dev": true,
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@svgr/babel-plugin-svg-em-dimensions": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-svg-em-dimensions/-/babel-plugin-svg-em-dimensions-8.0.0.tgz",
+ "integrity": "sha512-mURHYnu6Iw3UBTbhGwE/vsngtCIbHE43xCRK7kCw4t01xyGqb2Pd+WXekRRoFOBIY29ZoOhUCTEweDMdrjfi9g==",
+ "dev": true,
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@svgr/babel-plugin-transform-react-native-svg": {
+ "version": "8.1.0",
+ "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-transform-react-native-svg/-/babel-plugin-transform-react-native-svg-8.1.0.tgz",
+ "integrity": "sha512-Tx8T58CHo+7nwJ+EhUwx3LfdNSG9R2OKfaIXXs5soiy5HtgoAEkDay9LIimLOcG8dJQH1wPZp/cnAv6S9CrR1Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@svgr/babel-plugin-transform-svg-component": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-transform-svg-component/-/babel-plugin-transform-svg-component-8.0.0.tgz",
+ "integrity": "sha512-DFx8xa3cZXTdb/k3kfPeaixecQLgKh5NVBMwD0AQxOzcZawK4oo1Jh9LbrcACUivsCA7TLG8eeWgrDXjTMhRmw==",
+ "dev": true,
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@svgr/babel-preset": {
+ "version": "8.1.0",
+ "resolved": "https://registry.npmjs.org/@svgr/babel-preset/-/babel-preset-8.1.0.tgz",
+ "integrity": "sha512-7EYDbHE7MxHpv4sxvnVPngw5fuR6pw79SkcrILHJ/iMpuKySNCl5W1qcwPEpU+LgyRXOaAFgH0KhwD18wwg6ug==",
+ "dev": true,
+ "dependencies": {
+ "@svgr/babel-plugin-add-jsx-attribute": "8.0.0",
+ "@svgr/babel-plugin-remove-jsx-attribute": "8.0.0",
+ "@svgr/babel-plugin-remove-jsx-empty-expression": "8.0.0",
+ "@svgr/babel-plugin-replace-jsx-attribute-value": "8.0.0",
+ "@svgr/babel-plugin-svg-dynamic-title": "8.0.0",
+ "@svgr/babel-plugin-svg-em-dimensions": "8.0.0",
+ "@svgr/babel-plugin-transform-react-native-svg": "8.1.0",
+ "@svgr/babel-plugin-transform-svg-component": "8.0.0"
+ },
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@svgr/core": {
+ "version": "8.1.0",
+ "resolved": "https://registry.npmjs.org/@svgr/core/-/core-8.1.0.tgz",
+ "integrity": "sha512-8QqtOQT5ACVlmsvKOJNEaWmRPmcojMOzCz4Hs2BGG/toAp/K38LcsMRyLp349glq5AzJbCEeimEoxaX6v/fLrA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/core": "^7.21.3",
+ "@svgr/babel-preset": "8.1.0",
+ "camelcase": "^6.2.0",
+ "cosmiconfig": "^8.1.3",
+ "snake-case": "^3.0.4"
+ },
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ }
+ },
+ "node_modules/@svgr/hast-util-to-babel-ast": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/@svgr/hast-util-to-babel-ast/-/hast-util-to-babel-ast-8.0.0.tgz",
+ "integrity": "sha512-EbDKwO9GpfWP4jN9sGdYwPBU0kdomaPIL2Eu4YwmgP+sJeXT+L7bMwJUBnhzfH8Q2qMBqZ4fJwpCyYsAN3mt2Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.21.3",
+ "entities": "^4.4.0"
+ },
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ }
+ },
+ "node_modules/@svgr/plugin-jsx": {
+ "version": "8.1.0",
+ "resolved": "https://registry.npmjs.org/@svgr/plugin-jsx/-/plugin-jsx-8.1.0.tgz",
+ "integrity": "sha512-0xiIyBsLlr8quN+WyuxooNW9RJ0Dpr8uOnH/xrCVO8GLUcwHISwj1AG0k+LFzteTkAA0GbX0kj9q6Dk70PTiPA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/core": "^7.21.3",
+ "@svgr/babel-preset": "8.1.0",
+ "@svgr/hast-util-to-babel-ast": "8.0.0",
+ "svg-parser": "^2.0.4"
+ },
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@svgr/core": "*"
+ }
+ },
+ "node_modules/@swc/helpers": {
+ "version": "0.5.3",
+ "resolved": "https://registry.npmjs.org/@swc/helpers/-/helpers-0.5.3.tgz",
+ "integrity": "sha512-FaruWX6KdudYloq1AHD/4nU+UsMTdNE8CKyrseXWEcgjDAbvkwJg2QGPAnfIJLIWsjZOSPLOAykK6fuYp4vp4A==",
+ "dependencies": {
+ "tslib": "^2.4.0"
+ }
+ },
+ "node_modules/@types/babel__core": {
+ "version": "7.20.5",
+ "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.5.tgz",
+ "integrity": "sha512-qoQprZvz5wQFJwMDqeseRXWv3rqMvhgpbXFfVyWhbx9X47POIA6i/+dXefEmZKoAgOaTdaIgNSMqMIU61yRyzA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/parser": "^7.20.7",
+ "@babel/types": "^7.20.7",
+ "@types/babel__generator": "*",
+ "@types/babel__template": "*",
+ "@types/babel__traverse": "*"
+ }
+ },
+ "node_modules/@types/babel__generator": {
+ "version": "7.6.8",
+ "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.8.tgz",
+ "integrity": "sha512-ASsj+tpEDsEiFr1arWrlN6V3mdfjRMZt6LtK/Vp/kreFLnr5QH5+DhvD5nINYZXzwJvXeGq+05iUXcAzVrqWtw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.0.0"
+ }
+ },
+ "node_modules/@types/babel__template": {
+ "version": "7.4.4",
+ "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.4.tgz",
+ "integrity": "sha512-h/NUaSyG5EyxBIp8YRxo4RMe2/qQgvyowRwVMzhYhBCONbW8PUsg4lkFMrhgZhUe5z3L3MiLDuvyJ/CaPa2A8A==",
+ "dev": true,
+ "dependencies": {
+ "@babel/parser": "^7.1.0",
+ "@babel/types": "^7.0.0"
+ }
+ },
+ "node_modules/@types/babel__traverse": {
+ "version": "7.20.5",
+ "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.5.tgz",
+ "integrity": "sha512-WXCyOcRtH37HAUkpXhUduaxdm82b4GSlyTqajXviN4EfiuPgNYR109xMCKvpl6zPIpua0DGlMEDCq+g8EdoheQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.20.7"
+ }
+ },
+ "node_modules/@types/estree": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.5.tgz",
+ "integrity": "sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==",
+ "dev": true
+ },
+ "node_modules/@types/json-schema": {
+ "version": "7.0.15",
+ "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz",
+ "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==",
+ "dev": true
+ },
+ "node_modules/@types/minimatch": {
+ "version": "3.0.5",
+ "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-3.0.5.tgz",
+ "integrity": "sha512-Klz949h02Gz2uZCMGwDUSDS1YBlTdDDgbWHi+81l29tQALUtvz4rAYi5uoVhE5Lagoq6DeqAUlbrHvW/mXDgdQ==",
+ "dev": true
+ },
+ "node_modules/@types/prop-types": {
+ "version": "15.7.11",
+ "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.11.tgz",
+ "integrity": "sha512-ga8y9v9uyeiLdpKddhxYQkxNDrfvuPrlFb0N1qnZZByvcElJaXthF1UhvCh9TLWJBEHeNtdnbysW7Y6Uq8CVng=="
+ },
+ "node_modules/@types/react": {
+ "version": "18.2.51",
+ "resolved": "https://registry.npmjs.org/@types/react/-/react-18.2.51.tgz",
+ "integrity": "sha512-XeoMaU4CzyjdRr3c4IQQtiH7Rpo18V07rYZUucEZQwOUEtGgTXv7e6igQiQ+xnV6MbMe1qjEmKdgMNnfppnXfg==",
+ "dependencies": {
+ "@types/prop-types": "*",
+ "@types/scheduler": "*",
+ "csstype": "^3.0.2"
+ }
+ },
+ "node_modules/@types/react-dom": {
+ "version": "18.2.18",
+ "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.2.18.tgz",
+ "integrity": "sha512-TJxDm6OfAX2KJWJdMEVTwWke5Sc/E/RlnPGvGfS0W7+6ocy2xhDVQVh/KvC2Uf7kACs+gDytdusDSdWfWkaNzw==",
+ "dependencies": {
+ "@types/react": "*"
+ }
+ },
+ "node_modules/@types/scheduler": {
+ "version": "0.16.8",
+ "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.8.tgz",
+ "integrity": "sha512-WZLiwShhwLRmeV6zH+GkbOFT6Z6VklCItrDioxUnv+u4Ll+8vKeFySoFyK/0ctcRpOmwAicELfmys1sDc/Rw+A=="
+ },
+ "node_modules/@types/semver": {
+ "version": "7.5.6",
+ "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.6.tgz",
+ "integrity": "sha512-dn1l8LaMea/IjDoHNd9J52uBbInB796CDffS6VdIxvqYCPSG0V0DzHp76GpaWnlhg88uYyPbXCDIowa86ybd5A==",
+ "dev": true
+ },
+ "node_modules/@types/symlink-or-copy": {
+ "version": "1.2.2",
+ "resolved": "https://registry.npmjs.org/@types/symlink-or-copy/-/symlink-or-copy-1.2.2.tgz",
+ "integrity": "sha512-MQ1AnmTLOncwEf9IVU+B2e4Hchrku5N67NkgcAHW0p3sdzPe0FNMANxEm6OJUzPniEQGkeT3OROLlCwZJLWFZA==",
+ "dev": true
+ },
+ "node_modules/@typescript-eslint/eslint-plugin": {
+ "version": "6.20.0",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-6.20.0.tgz",
+ "integrity": "sha512-fTwGQUnjhoYHeSF6m5pWNkzmDDdsKELYrOBxhjMrofPqCkoC2k3B2wvGHFxa1CTIqkEn88nlW1HVMztjo2K8Hg==",
+ "dev": true,
+ "dependencies": {
+ "@eslint-community/regexpp": "^4.5.1",
+ "@typescript-eslint/scope-manager": "6.20.0",
+ "@typescript-eslint/type-utils": "6.20.0",
+ "@typescript-eslint/utils": "6.20.0",
+ "@typescript-eslint/visitor-keys": "6.20.0",
+ "debug": "^4.3.4",
+ "graphemer": "^1.4.0",
+ "ignore": "^5.2.4",
+ "natural-compare": "^1.4.0",
+ "semver": "^7.5.4",
+ "ts-api-utils": "^1.0.1"
+ },
+ "engines": {
+ "node": "^16.0.0 || >=18.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ },
+ "peerDependencies": {
+ "@typescript-eslint/parser": "^6.0.0 || ^6.0.0-alpha",
+ "eslint": "^7.0.0 || ^8.0.0"
+ },
+ "peerDependenciesMeta": {
+ "typescript": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@typescript-eslint/parser": {
+ "version": "6.20.0",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-6.20.0.tgz",
+ "integrity": "sha512-bYerPDF/H5v6V76MdMYhjwmwgMA+jlPVqjSDq2cRqMi8bP5sR3Z+RLOiOMad3nsnmDVmn2gAFCyNgh/dIrfP/w==",
+ "dev": true,
+ "dependencies": {
+ "@typescript-eslint/scope-manager": "6.20.0",
+ "@typescript-eslint/types": "6.20.0",
+ "@typescript-eslint/typescript-estree": "6.20.0",
+ "@typescript-eslint/visitor-keys": "6.20.0",
+ "debug": "^4.3.4"
+ },
+ "engines": {
+ "node": "^16.0.0 || >=18.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ },
+ "peerDependencies": {
+ "eslint": "^7.0.0 || ^8.0.0"
+ },
+ "peerDependenciesMeta": {
+ "typescript": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@typescript-eslint/scope-manager": {
+ "version": "6.20.0",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.20.0.tgz",
+ "integrity": "sha512-p4rvHQRDTI1tGGMDFQm+GtxP1ZHyAh64WANVoyEcNMpaTFn3ox/3CcgtIlELnRfKzSs/DwYlDccJEtr3O6qBvA==",
+ "dev": true,
+ "dependencies": {
+ "@typescript-eslint/types": "6.20.0",
+ "@typescript-eslint/visitor-keys": "6.20.0"
+ },
+ "engines": {
+ "node": "^16.0.0 || >=18.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ }
+ },
+ "node_modules/@typescript-eslint/type-utils": {
+ "version": "6.20.0",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-6.20.0.tgz",
+ "integrity": "sha512-qnSobiJQb1F5JjN0YDRPHruQTrX7ICsmltXhkV536mp4idGAYrIyr47zF/JmkJtEcAVnIz4gUYJ7gOZa6SmN4g==",
+ "dev": true,
+ "dependencies": {
+ "@typescript-eslint/typescript-estree": "6.20.0",
+ "@typescript-eslint/utils": "6.20.0",
+ "debug": "^4.3.4",
+ "ts-api-utils": "^1.0.1"
+ },
+ "engines": {
+ "node": "^16.0.0 || >=18.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ },
+ "peerDependencies": {
+ "eslint": "^7.0.0 || ^8.0.0"
+ },
+ "peerDependenciesMeta": {
+ "typescript": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@typescript-eslint/types": {
+ "version": "6.20.0",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.20.0.tgz",
+ "integrity": "sha512-MM9mfZMAhiN4cOEcUOEx+0HmuaW3WBfukBZPCfwSqFnQy0grXYtngKCqpQN339X3RrwtzspWJrpbrupKYUSBXQ==",
+ "dev": true,
+ "engines": {
+ "node": "^16.0.0 || >=18.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ }
+ },
+ "node_modules/@typescript-eslint/typescript-estree": {
+ "version": "6.20.0",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.20.0.tgz",
+ "integrity": "sha512-RnRya9q5m6YYSpBN7IzKu9FmLcYtErkDkc8/dKv81I9QiLLtVBHrjz+Ev/crAqgMNW2FCsoZF4g2QUylMnJz+g==",
+ "dev": true,
+ "dependencies": {
+ "@typescript-eslint/types": "6.20.0",
+ "@typescript-eslint/visitor-keys": "6.20.0",
+ "debug": "^4.3.4",
+ "globby": "^11.1.0",
+ "is-glob": "^4.0.3",
+ "minimatch": "9.0.3",
+ "semver": "^7.5.4",
+ "ts-api-utils": "^1.0.1"
+ },
+ "engines": {
+ "node": "^16.0.0 || >=18.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ },
+ "peerDependenciesMeta": {
+ "typescript": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@typescript-eslint/utils": {
+ "version": "6.20.0",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-6.20.0.tgz",
+ "integrity": "sha512-/EKuw+kRu2vAqCoDwDCBtDRU6CTKbUmwwI7SH7AashZ+W+7o8eiyy6V2cdOqN49KsTcASWsC5QeghYuRDTyOOg==",
+ "dev": true,
+ "dependencies": {
+ "@eslint-community/eslint-utils": "^4.4.0",
+ "@types/json-schema": "^7.0.12",
+ "@types/semver": "^7.5.0",
+ "@typescript-eslint/scope-manager": "6.20.0",
+ "@typescript-eslint/types": "6.20.0",
+ "@typescript-eslint/typescript-estree": "6.20.0",
+ "semver": "^7.5.4"
+ },
+ "engines": {
+ "node": "^16.0.0 || >=18.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ },
+ "peerDependencies": {
+ "eslint": "^7.0.0 || ^8.0.0"
+ }
+ },
+ "node_modules/@typescript-eslint/visitor-keys": {
+ "version": "6.20.0",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.20.0.tgz",
+ "integrity": "sha512-E8Cp98kRe4gKHjJD4NExXKz/zOJ1A2hhZc+IMVD6i7w4yjIvh6VyuRI0gRtxAsXtoC35uGMaQ9rjI2zJaXDEAw==",
+ "dev": true,
+ "dependencies": {
+ "@typescript-eslint/types": "6.20.0",
+ "eslint-visitor-keys": "^3.4.1"
+ },
+ "engines": {
+ "node": "^16.0.0 || >=18.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ }
+ },
+ "node_modules/@ungap/structured-clone": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz",
+ "integrity": "sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==",
+ "dev": true
+ },
+ "node_modules/@vitejs/plugin-react": {
+ "version": "4.2.1",
+ "resolved": "https://registry.npmjs.org/@vitejs/plugin-react/-/plugin-react-4.2.1.tgz",
+ "integrity": "sha512-oojO9IDc4nCUUi8qIR11KoQm0XFFLIwsRBwHRR4d/88IWghn1y6ckz/bJ8GHDCsYEJee8mDzqtJxh15/cisJNQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/core": "^7.23.5",
+ "@babel/plugin-transform-react-jsx-self": "^7.23.3",
+ "@babel/plugin-transform-react-jsx-source": "^7.23.3",
+ "@types/babel__core": "^7.20.5",
+ "react-refresh": "^0.14.0"
+ },
+ "engines": {
+ "node": "^14.18.0 || >=16.0.0"
+ },
+ "peerDependencies": {
+ "vite": "^4.2.0 || ^5.0.0"
+ }
+ },
+ "node_modules/acorn": {
+ "version": "8.11.3",
+ "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz",
+ "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==",
+ "dev": true,
+ "bin": {
+ "acorn": "bin/acorn"
+ },
+ "engines": {
+ "node": ">=0.4.0"
+ }
+ },
+ "node_modules/acorn-jsx": {
+ "version": "5.3.2",
+ "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz",
+ "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==",
+ "dev": true,
+ "peerDependencies": {
+ "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0"
+ }
+ },
+ "node_modules/ajv": {
+ "version": "6.12.6",
+ "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz",
+ "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==",
+ "dev": true,
+ "dependencies": {
+ "fast-deep-equal": "^3.1.1",
+ "fast-json-stable-stringify": "^2.0.0",
+ "json-schema-traverse": "^0.4.1",
+ "uri-js": "^4.2.2"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/epoberezkin"
+ }
+ },
+ "node_modules/ansi-regex": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz",
+ "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/ansi-styles": {
+ "version": "3.2.1",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz",
+ "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^1.9.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/anymatch": {
+ "version": "3.1.3",
+ "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz",
+ "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==",
+ "dev": true,
+ "dependencies": {
+ "normalize-path": "^3.0.0",
+ "picomatch": "^2.0.4"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/argparse": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz",
+ "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==",
+ "dev": true
+ },
+ "node_modules/array-union": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz",
+ "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/asap": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/asap/-/asap-2.0.6.tgz",
+ "integrity": "sha512-BSHWgDSAiKs50o2Re8ppvp3seVHXSRM44cdSsT9FfNEUUZLOGWVCsiWaRPWM1Znn+mqZ1OfVZ3z3DWEzSp7hRA=="
+ },
+ "node_modules/async": {
+ "version": "3.2.5",
+ "resolved": "https://registry.npmjs.org/async/-/async-3.2.5.tgz",
+ "integrity": "sha512-baNZyqaaLhyLVKm/DlvdW051MSgO6b8eVfIezl9E5PqWxFgzLm/wQntEW4zOytVburDEr0JlALEpdOFwvErLsg==",
+ "dev": true
+ },
+ "node_modules/asynckit": {
+ "version": "0.4.0",
+ "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz",
+ "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q=="
+ },
+ "node_modules/axios": {
+ "version": "1.6.7",
+ "resolved": "https://registry.npmjs.org/axios/-/axios-1.6.7.tgz",
+ "integrity": "sha512-/hDJGff6/c7u0hDkvkGxR/oy6CbCs8ziCsC7SqmhjfozqiJGc8Z11wrv9z9lYfY4K8l+H9TpjcMDX0xOZmx+RA==",
+ "dependencies": {
+ "follow-redirects": "^1.15.4",
+ "form-data": "^4.0.0",
+ "proxy-from-env": "^1.1.0"
+ }
+ },
+ "node_modules/balanced-match": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
+ "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==",
+ "dev": true
+ },
+ "node_modules/base64-js": {
+ "version": "1.5.1",
+ "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz",
+ "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/feross"
+ },
+ {
+ "type": "patreon",
+ "url": "https://www.patreon.com/feross"
+ },
+ {
+ "type": "consulting",
+ "url": "https://feross.org/support"
+ }
+ ]
+ },
+ "node_modules/bl": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/bl/-/bl-5.1.0.tgz",
+ "integrity": "sha512-tv1ZJHLfTDnXE6tMHv73YgSJaWR2AFuPwMntBe7XL/GBFHnT0CLnsHMogfk5+GzCDC5ZWarSCYaIGATZt9dNsQ==",
+ "dev": true,
+ "dependencies": {
+ "buffer": "^6.0.3",
+ "inherits": "^2.0.4",
+ "readable-stream": "^3.4.0"
+ }
+ },
+ "node_modules/bl/node_modules/readable-stream": {
+ "version": "3.6.2",
+ "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz",
+ "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==",
+ "dev": true,
+ "dependencies": {
+ "inherits": "^2.0.3",
+ "string_decoder": "^1.1.1",
+ "util-deprecate": "^1.0.1"
+ },
+ "engines": {
+ "node": ">= 6"
+ }
+ },
+ "node_modules/boolbase": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz",
+ "integrity": "sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==",
+ "dev": true
+ },
+ "node_modules/brace-expansion": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz",
+ "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==",
+ "dev": true,
+ "dependencies": {
+ "balanced-match": "^1.0.0"
+ }
+ },
+ "node_modules/braces": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
+ "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
+ "dev": true,
+ "dependencies": {
+ "fill-range": "^7.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/broccoli-node-api": {
+ "version": "1.7.0",
+ "resolved": "https://registry.npmjs.org/broccoli-node-api/-/broccoli-node-api-1.7.0.tgz",
+ "integrity": "sha512-QIqLSVJWJUVOhclmkmypJJH9u9s/aWH4+FH6Q6Ju5l+Io4dtwqdPUNmDfw40o6sxhbZHhqGujDJuHTML1wG8Yw==",
+ "dev": true
+ },
+ "node_modules/broccoli-node-info": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/broccoli-node-info/-/broccoli-node-info-2.2.0.tgz",
+ "integrity": "sha512-VabSGRpKIzpmC+r+tJueCE5h8k6vON7EIMMWu6d/FyPdtijwLQ7QvzShEw+m3mHoDzUaj/kiZsDYrS8X2adsBg==",
+ "dev": true,
+ "engines": {
+ "node": "8.* || >= 10.*"
+ }
+ },
+ "node_modules/broccoli-output-wrapper": {
+ "version": "3.2.5",
+ "resolved": "https://registry.npmjs.org/broccoli-output-wrapper/-/broccoli-output-wrapper-3.2.5.tgz",
+ "integrity": "sha512-bQAtwjSrF4Nu0CK0JOy5OZqw9t5U0zzv2555EA/cF8/a8SLDTIetk9UgrtMVw7qKLKdSpOZ2liZNeZZDaKgayw==",
+ "dev": true,
+ "dependencies": {
+ "fs-extra": "^8.1.0",
+ "heimdalljs-logger": "^0.1.10",
+ "symlink-or-copy": "^1.2.0"
+ },
+ "engines": {
+ "node": "10.* || >= 12.*"
+ }
+ },
+ "node_modules/broccoli-output-wrapper/node_modules/fs-extra": {
+ "version": "8.1.0",
+ "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz",
+ "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==",
+ "dev": true,
+ "dependencies": {
+ "graceful-fs": "^4.2.0",
+ "jsonfile": "^4.0.0",
+ "universalify": "^0.1.0"
+ },
+ "engines": {
+ "node": ">=6 <7 || >=8"
+ }
+ },
+ "node_modules/broccoli-output-wrapper/node_modules/jsonfile": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz",
+ "integrity": "sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg==",
+ "dev": true,
+ "optionalDependencies": {
+ "graceful-fs": "^4.1.6"
+ }
+ },
+ "node_modules/broccoli-output-wrapper/node_modules/universalify": {
+ "version": "0.1.2",
+ "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz",
+ "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==",
+ "dev": true,
+ "engines": {
+ "node": ">= 4.0.0"
+ }
+ },
+ "node_modules/broccoli-plugin": {
+ "version": "4.0.7",
+ "resolved": "https://registry.npmjs.org/broccoli-plugin/-/broccoli-plugin-4.0.7.tgz",
+ "integrity": "sha512-a4zUsWtA1uns1K7p9rExYVYG99rdKeGRymW0qOCNkvDPHQxVi3yVyJHhQbM3EZwdt2E0mnhr5e0c/bPpJ7p3Wg==",
+ "dev": true,
+ "dependencies": {
+ "broccoli-node-api": "^1.7.0",
+ "broccoli-output-wrapper": "^3.2.5",
+ "fs-merger": "^3.2.1",
+ "promise-map-series": "^0.3.0",
+ "quick-temp": "^0.1.8",
+ "rimraf": "^3.0.2",
+ "symlink-or-copy": "^1.3.1"
+ },
+ "engines": {
+ "node": "10.* || >= 12.*"
+ }
+ },
+ "node_modules/browserslist": {
+ "version": "4.22.3",
+ "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.22.3.tgz",
+ "integrity": "sha512-UAp55yfwNv0klWNapjs/ktHoguxuQNGnOzxYmfnXIS+8AsRDZkSDxg7R1AX3GKzn078SBI5dzwzj/Yx0Or0e3A==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/browserslist"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/browserslist"
+ },
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/ai"
+ }
+ ],
+ "dependencies": {
+ "caniuse-lite": "^1.0.30001580",
+ "electron-to-chromium": "^1.4.648",
+ "node-releases": "^2.0.14",
+ "update-browserslist-db": "^1.0.13"
+ },
+ "bin": {
+ "browserslist": "cli.js"
+ },
+ "engines": {
+ "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7"
+ }
+ },
+ "node_modules/buffer": {
+ "version": "6.0.3",
+ "resolved": "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz",
+ "integrity": "sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/feross"
+ },
+ {
+ "type": "patreon",
+ "url": "https://www.patreon.com/feross"
+ },
+ {
+ "type": "consulting",
+ "url": "https://feross.org/support"
+ }
+ ],
+ "dependencies": {
+ "base64-js": "^1.3.1",
+ "ieee754": "^1.2.1"
+ }
+ },
+ "node_modules/buffer-from": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz",
+ "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==",
+ "dev": true,
+ "optional": true,
+ "peer": true
+ },
+ "node_modules/callsites": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz",
+ "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/camelcase": {
+ "version": "6.3.0",
+ "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz",
+ "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/caniuse-lite": {
+ "version": "1.0.30001582",
+ "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001582.tgz",
+ "integrity": "sha512-vsJG3V5vgfduaQGVxL53uSX/HUzxyr2eA8xCo36OLal7sRcSZbibJtLeh0qja4sFOr/QQGt4opB4tOy+eOgAxg==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/browserslist"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/caniuse-lite"
+ },
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/ai"
+ }
+ ]
+ },
+ "node_modules/chalk": {
+ "version": "2.4.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
+ "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^3.2.1",
+ "escape-string-regexp": "^1.0.5",
+ "supports-color": "^5.3.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/chalk/node_modules/escape-string-regexp": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
+ "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.8.0"
+ }
+ },
+ "node_modules/cheerio": {
+ "version": "1.0.0-rc.12",
+ "resolved": "https://registry.npmjs.org/cheerio/-/cheerio-1.0.0-rc.12.tgz",
+ "integrity": "sha512-VqR8m68vM46BNnuZ5NtnGBKIE/DfN0cRIzg9n40EIq9NOv90ayxLBXA8fXC5gquFRGJSTRqBq25Jt2ECLR431Q==",
+ "dev": true,
+ "dependencies": {
+ "cheerio-select": "^2.1.0",
+ "dom-serializer": "^2.0.0",
+ "domhandler": "^5.0.3",
+ "domutils": "^3.0.1",
+ "htmlparser2": "^8.0.1",
+ "parse5": "^7.0.0",
+ "parse5-htmlparser2-tree-adapter": "^7.0.0"
+ },
+ "engines": {
+ "node": ">= 6"
+ },
+ "funding": {
+ "url": "https://github.com/cheeriojs/cheerio?sponsor=1"
+ }
+ },
+ "node_modules/cheerio-select": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/cheerio-select/-/cheerio-select-2.1.0.tgz",
+ "integrity": "sha512-9v9kG0LvzrlcungtnJtpGNxY+fzECQKhK4EGJX2vByejiMX84MFNQw4UxPJl3bFbTMw+Dfs37XaIkCwTZfLh4g==",
+ "dev": true,
+ "dependencies": {
+ "boolbase": "^1.0.0",
+ "css-select": "^5.1.0",
+ "css-what": "^6.1.0",
+ "domelementtype": "^2.3.0",
+ "domhandler": "^5.0.3",
+ "domutils": "^3.0.1"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/fb55"
+ }
+ },
+ "node_modules/cliui": {
+ "version": "8.0.1",
+ "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz",
+ "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==",
+ "dev": true,
+ "dependencies": {
+ "string-width": "^4.2.0",
+ "strip-ansi": "^6.0.1",
+ "wrap-ansi": "^7.0.0"
+ },
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/clone": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/clone/-/clone-2.1.2.tgz",
+ "integrity": "sha512-3Pe/CF1Nn94hyhIYpjtiLhdCoEoz0DqQ+988E9gmeEdQZlojxnOb74wctFyuwWQHzqyf9X7C7MG8juUpqBJT8w==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.8"
+ }
+ },
+ "node_modules/clone-stats": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/clone-stats/-/clone-stats-1.0.0.tgz",
+ "integrity": "sha512-au6ydSpg6nsrigcZ4m8Bc9hxjeW+GJ8xh5G3BJCMt4WXe1H10UNaVOamqQTmrx1kjVuxAHIQSNU6hY4Nsn9/ag==",
+ "dev": true
+ },
+ "node_modules/color-convert": {
+ "version": "1.9.3",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz",
+ "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "1.1.3"
+ }
+ },
+ "node_modules/color-name": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz",
+ "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==",
+ "dev": true
+ },
+ "node_modules/colors": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/colors/-/colors-1.4.0.tgz",
+ "integrity": "sha512-a+UqTh4kgZg/SlGvfbzDHpgRu7AAQOmmqRHJnxhRZICKFUT91brVhNNt58CMWU9PsBbv3PDCZUHbVxuDiH2mtA==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.1.90"
+ }
+ },
+ "node_modules/combined-stream": {
+ "version": "1.0.8",
+ "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz",
+ "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==",
+ "dependencies": {
+ "delayed-stream": "~1.0.0"
+ },
+ "engines": {
+ "node": ">= 0.8"
+ }
+ },
+ "node_modules/commander": {
+ "version": "11.1.0",
+ "resolved": "https://registry.npmjs.org/commander/-/commander-11.1.0.tgz",
+ "integrity": "sha512-yPVavfyCcRhmorC7rWlkHn15b4wDVgVmBA7kV4QVBsF7kv/9TKJAbAXVTxvTnwP8HHKjRCJDClKbciiYS7p0DQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=16"
+ }
+ },
+ "node_modules/concat-map": {
+ "version": "0.0.1",
+ "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
+ "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==",
+ "dev": true
+ },
+ "node_modules/core-js": {
+ "version": "3.35.1",
+ "resolved": "https://registry.npmjs.org/core-js/-/core-js-3.35.1.tgz",
+ "integrity": "sha512-IgdsbxNyMskrTFxa9lWHyMwAJU5gXOPP+1yO+K59d50VLVAIDAbs7gIv705KzALModfK3ZrSZTPNpC0PQgIZuw==",
+ "hasInstallScript": true,
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/core-js"
+ }
+ },
+ "node_modules/core-util-is": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz",
+ "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==",
+ "dev": true
+ },
+ "node_modules/cosmiconfig": {
+ "version": "8.3.6",
+ "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-8.3.6.tgz",
+ "integrity": "sha512-kcZ6+W5QzcJ3P1Mt+83OUv/oHFqZHIx8DuxG6eZ5RGMERoLqp4BuGjhHLYGK+Kf5XVkQvqBSmAy/nGWN3qDgEA==",
+ "dev": true,
+ "dependencies": {
+ "import-fresh": "^3.3.0",
+ "js-yaml": "^4.1.0",
+ "parse-json": "^5.2.0",
+ "path-type": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/d-fischer"
+ },
+ "peerDependencies": {
+ "typescript": ">=4.9.5"
+ },
+ "peerDependenciesMeta": {
+ "typescript": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/cross-fetch": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/cross-fetch/-/cross-fetch-4.0.0.tgz",
+ "integrity": "sha512-e4a5N8lVvuLgAWgnCrLr2PP0YyDOTHa9H/Rj54dirp61qXnNq46m82bRhNqIA5VccJtWBvPTFRV3TtvHUKPB1g==",
+ "dependencies": {
+ "node-fetch": "^2.6.12"
+ }
+ },
+ "node_modules/cross-spawn": {
+ "version": "7.0.3",
+ "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz",
+ "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==",
+ "dev": true,
+ "dependencies": {
+ "path-key": "^3.1.0",
+ "shebang-command": "^2.0.0",
+ "which": "^2.0.1"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/css-select": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/css-select/-/css-select-5.1.0.tgz",
+ "integrity": "sha512-nwoRF1rvRRnnCqqY7updORDsuqKzqYJ28+oSMaJMMgOauh3fvwHqMS7EZpIPqK8GL+g9mKxF1vP/ZjSeNjEVHg==",
+ "dev": true,
+ "dependencies": {
+ "boolbase": "^1.0.0",
+ "css-what": "^6.1.0",
+ "domhandler": "^5.0.2",
+ "domutils": "^3.0.1",
+ "nth-check": "^2.0.1"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/fb55"
+ }
+ },
+ "node_modules/css-what": {
+ "version": "6.1.0",
+ "resolved": "https://registry.npmjs.org/css-what/-/css-what-6.1.0.tgz",
+ "integrity": "sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw==",
+ "dev": true,
+ "engines": {
+ "node": ">= 6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/fb55"
+ }
+ },
+ "node_modules/csstype": {
+ "version": "3.1.3",
+ "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz",
+ "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw=="
+ },
+ "node_modules/date-fns": {
+ "version": "3.3.1",
+ "resolved": "https://registry.npmjs.org/date-fns/-/date-fns-3.3.1.tgz",
+ "integrity": "sha512-y8e109LYGgoQDveiEBD3DYXKba1jWf5BA8YU1FL5Tvm0BTdEfy54WLCwnuYWZNnzzvALy/QQ4Hov+Q9RVRv+Zw==",
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/kossnocorp"
+ }
+ },
+ "node_modules/de-indent": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/de-indent/-/de-indent-1.0.2.tgz",
+ "integrity": "sha512-e/1zu3xH5MQryN2zdVaF0OrdNLUbvWxzMbi+iNA6Bky7l1RoP8a2fIbRocyHclXt/arDrrR6lL3TqFD9pMQTsg==",
+ "dev": true
+ },
+ "node_modules/debug": {
+ "version": "4.3.4",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz",
+ "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==",
+ "dev": true,
+ "dependencies": {
+ "ms": "2.1.2"
+ },
+ "engines": {
+ "node": ">=6.0"
+ },
+ "peerDependenciesMeta": {
+ "supports-color": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/deep-is": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz",
+ "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==",
+ "dev": true
+ },
+ "node_modules/delayed-stream": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz",
+ "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==",
+ "engines": {
+ "node": ">=0.4.0"
+ }
+ },
+ "node_modules/diff": {
+ "version": "5.2.0",
+ "resolved": "https://registry.npmjs.org/diff/-/diff-5.2.0.tgz",
+ "integrity": "sha512-uIFDxqpRZGZ6ThOk84hEfqWoHx2devRFvpTZcTHur85vImfaxUbTW9Ryh4CpCuDnToOP1CEtXKIgytHBPVff5A==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.3.1"
+ }
+ },
+ "node_modules/dir-glob": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz",
+ "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==",
+ "dev": true,
+ "dependencies": {
+ "path-type": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/doctrine": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz",
+ "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==",
+ "dev": true,
+ "dependencies": {
+ "esutils": "^2.0.2"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/dom-helpers": {
+ "version": "5.2.1",
+ "resolved": "https://registry.npmjs.org/dom-helpers/-/dom-helpers-5.2.1.tgz",
+ "integrity": "sha512-nRCa7CK3VTrM2NmGkIy4cbK7IZlgBE/PYMn55rrXefr5xXDP0LdtfPnblFDoVdcAfslJ7or6iqAUnx0CCGIWQA==",
+ "dependencies": {
+ "@babel/runtime": "^7.8.7",
+ "csstype": "^3.0.2"
+ }
+ },
+ "node_modules/dom-serializer": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-2.0.0.tgz",
+ "integrity": "sha512-wIkAryiqt/nV5EQKqQpo3SToSOV9J0DnbJqwK7Wv/Trc92zIAYZ4FlMu+JPFW1DfGFt81ZTCGgDEabffXeLyJg==",
+ "dev": true,
+ "dependencies": {
+ "domelementtype": "^2.3.0",
+ "domhandler": "^5.0.2",
+ "entities": "^4.2.0"
+ },
+ "funding": {
+ "url": "https://github.com/cheeriojs/dom-serializer?sponsor=1"
+ }
+ },
+ "node_modules/domelementtype": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.3.0.tgz",
+ "integrity": "sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/fb55"
+ }
+ ]
+ },
+ "node_modules/domhandler": {
+ "version": "5.0.3",
+ "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-5.0.3.tgz",
+ "integrity": "sha512-cgwlv/1iFQiFnU96XXgROh8xTeetsnJiDsTc7TYCLFd9+/WNkIqPTxiM/8pSd8VIrhXGTf1Ny1q1hquVqDJB5w==",
+ "dev": true,
+ "dependencies": {
+ "domelementtype": "^2.3.0"
+ },
+ "engines": {
+ "node": ">= 4"
+ },
+ "funding": {
+ "url": "https://github.com/fb55/domhandler?sponsor=1"
+ }
+ },
+ "node_modules/domutils": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/domutils/-/domutils-3.1.0.tgz",
+ "integrity": "sha512-H78uMmQtI2AhgDJjWeQmHwJJ2bLPD3GMmO7Zja/ZZh84wkm+4ut+IUnUdRa8uCGX88DiVx1j6FRe1XfxEgjEZA==",
+ "dev": true,
+ "dependencies": {
+ "dom-serializer": "^2.0.0",
+ "domelementtype": "^2.3.0",
+ "domhandler": "^5.0.3"
+ },
+ "funding": {
+ "url": "https://github.com/fb55/domutils?sponsor=1"
+ }
+ },
+ "node_modules/dot-case": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/dot-case/-/dot-case-3.0.4.tgz",
+ "integrity": "sha512-Kv5nKlh6yRrdrGvxeJ2e5y2eRUpkUosIW4A2AS38zwSz27zu7ufDwQPi5Jhs3XAlGNetl3bmnGhQsMtkKJnj3w==",
+ "dev": true,
+ "dependencies": {
+ "no-case": "^3.0.4",
+ "tslib": "^2.0.3"
+ }
+ },
+ "node_modules/draft-js": {
+ "version": "0.11.7",
+ "resolved": "https://registry.npmjs.org/draft-js/-/draft-js-0.11.7.tgz",
+ "integrity": "sha512-ne7yFfN4sEL82QPQEn80xnADR8/Q6ALVworbC5UOSzOvjffmYfFsr3xSZtxbIirti14R7Y33EZC5rivpLgIbsg==",
+ "dependencies": {
+ "fbjs": "^2.0.0",
+ "immutable": "~3.7.4",
+ "object-assign": "^4.1.1"
+ },
+ "peerDependencies": {
+ "react": ">=0.14.0",
+ "react-dom": ">=0.14.0"
+ }
+ },
+ "node_modules/ejs": {
+ "version": "3.1.9",
+ "resolved": "https://registry.npmjs.org/ejs/-/ejs-3.1.9.tgz",
+ "integrity": "sha512-rC+QVNMJWv+MtPgkt0y+0rVEIdbtxVADApW9JXrUVlzHetgcyczP/E7DJmWJ4fJCZF2cPcBk0laWO9ZHMG3DmQ==",
+ "dev": true,
+ "dependencies": {
+ "jake": "^10.8.5"
+ },
+ "bin": {
+ "ejs": "bin/cli.js"
+ },
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/electron-to-chromium": {
+ "version": "1.4.653",
+ "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.653.tgz",
+ "integrity": "sha512-wA2A2LQCqnEwQAvwADQq3KpMpNwgAUBnRmrFgRzHnPhbQUFArTR32Ab46f4p0MovDLcg4uqd4nCsN2hTltslpA==",
+ "dev": true
+ },
+ "node_modules/emoji-regex": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz",
+ "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==",
+ "dev": true
+ },
+ "node_modules/ensure-posix-path": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/ensure-posix-path/-/ensure-posix-path-1.1.1.tgz",
+ "integrity": "sha512-VWU0/zXzVbeJNXvME/5EmLuEj2TauvoaTz6aFYK1Z92JCBlDlZ3Gu0tuGR42kpW1754ywTs+QB0g5TP0oj9Zaw==",
+ "dev": true
+ },
+ "node_modules/entities": {
+ "version": "4.5.0",
+ "resolved": "https://registry.npmjs.org/entities/-/entities-4.5.0.tgz",
+ "integrity": "sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.12"
+ },
+ "funding": {
+ "url": "https://github.com/fb55/entities?sponsor=1"
+ }
+ },
+ "node_modules/eol": {
+ "version": "0.9.1",
+ "resolved": "https://registry.npmjs.org/eol/-/eol-0.9.1.tgz",
+ "integrity": "sha512-Ds/TEoZjwggRoz/Q2O7SE3i4Jm66mqTDfmdHdq/7DKVk3bro9Q8h6WdXKdPqFLMoqxrDK5SVRzHVPOS6uuGtrg==",
+ "dev": true
+ },
+ "node_modules/error-ex": {
+ "version": "1.3.2",
+ "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz",
+ "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==",
+ "dev": true,
+ "dependencies": {
+ "is-arrayish": "^0.2.1"
+ }
+ },
+ "node_modules/esbuild": {
+ "version": "0.19.12",
+ "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.19.12.tgz",
+ "integrity": "sha512-aARqgq8roFBj054KvQr5f1sFu0D65G+miZRCuJyJ0G13Zwx7vRar5Zhn2tkQNzIXcBrNVsv/8stehpj+GAjgbg==",
+ "dev": true,
+ "hasInstallScript": true,
+ "bin": {
+ "esbuild": "bin/esbuild"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "optionalDependencies": {
+ "@esbuild/aix-ppc64": "0.19.12",
+ "@esbuild/android-arm": "0.19.12",
+ "@esbuild/android-arm64": "0.19.12",
+ "@esbuild/android-x64": "0.19.12",
+ "@esbuild/darwin-arm64": "0.19.12",
+ "@esbuild/darwin-x64": "0.19.12",
+ "@esbuild/freebsd-arm64": "0.19.12",
+ "@esbuild/freebsd-x64": "0.19.12",
+ "@esbuild/linux-arm": "0.19.12",
+ "@esbuild/linux-arm64": "0.19.12",
+ "@esbuild/linux-ia32": "0.19.12",
+ "@esbuild/linux-loong64": "0.19.12",
+ "@esbuild/linux-mips64el": "0.19.12",
+ "@esbuild/linux-ppc64": "0.19.12",
+ "@esbuild/linux-riscv64": "0.19.12",
+ "@esbuild/linux-s390x": "0.19.12",
+ "@esbuild/linux-x64": "0.19.12",
+ "@esbuild/netbsd-x64": "0.19.12",
+ "@esbuild/openbsd-x64": "0.19.12",
+ "@esbuild/sunos-x64": "0.19.12",
+ "@esbuild/win32-arm64": "0.19.12",
+ "@esbuild/win32-ia32": "0.19.12",
+ "@esbuild/win32-x64": "0.19.12"
+ }
+ },
+ "node_modules/escalade": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz",
+ "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/escape-string-regexp": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz",
+ "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/eslint": {
+ "version": "8.56.0",
+ "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.56.0.tgz",
+ "integrity": "sha512-Go19xM6T9puCOWntie1/P997aXxFsOi37JIHRWI514Hc6ZnaHGKY9xFhrU65RT6CcBEzZoGG1e6Nq+DT04ZtZQ==",
+ "dev": true,
+ "dependencies": {
+ "@eslint-community/eslint-utils": "^4.2.0",
+ "@eslint-community/regexpp": "^4.6.1",
+ "@eslint/eslintrc": "^2.1.4",
+ "@eslint/js": "8.56.0",
+ "@humanwhocodes/config-array": "^0.11.13",
+ "@humanwhocodes/module-importer": "^1.0.1",
+ "@nodelib/fs.walk": "^1.2.8",
+ "@ungap/structured-clone": "^1.2.0",
+ "ajv": "^6.12.4",
+ "chalk": "^4.0.0",
+ "cross-spawn": "^7.0.2",
+ "debug": "^4.3.2",
+ "doctrine": "^3.0.0",
+ "escape-string-regexp": "^4.0.0",
+ "eslint-scope": "^7.2.2",
+ "eslint-visitor-keys": "^3.4.3",
+ "espree": "^9.6.1",
+ "esquery": "^1.4.2",
+ "esutils": "^2.0.2",
+ "fast-deep-equal": "^3.1.3",
+ "file-entry-cache": "^6.0.1",
+ "find-up": "^5.0.0",
+ "glob-parent": "^6.0.2",
+ "globals": "^13.19.0",
+ "graphemer": "^1.4.0",
+ "ignore": "^5.2.0",
+ "imurmurhash": "^0.1.4",
+ "is-glob": "^4.0.0",
+ "is-path-inside": "^3.0.3",
+ "js-yaml": "^4.1.0",
+ "json-stable-stringify-without-jsonify": "^1.0.1",
+ "levn": "^0.4.1",
+ "lodash.merge": "^4.6.2",
+ "minimatch": "^3.1.2",
+ "natural-compare": "^1.4.0",
+ "optionator": "^0.9.3",
+ "strip-ansi": "^6.0.1",
+ "text-table": "^0.2.0"
+ },
+ "bin": {
+ "eslint": "bin/eslint.js"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/eslint-plugin-react-hooks": {
+ "version": "4.6.0",
+ "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.6.0.tgz",
+ "integrity": "sha512-oFc7Itz9Qxh2x4gNHStv3BqJq54ExXmfC+a1NjAta66IAN87Wu0R/QArgIS9qKzX3dXKPI9H5crl9QchNMY9+g==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ },
+ "peerDependencies": {
+ "eslint": "^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0-0"
+ }
+ },
+ "node_modules/eslint-plugin-react-refresh": {
+ "version": "0.4.5",
+ "resolved": "https://registry.npmjs.org/eslint-plugin-react-refresh/-/eslint-plugin-react-refresh-0.4.5.tgz",
+ "integrity": "sha512-D53FYKJa+fDmZMtriODxvhwrO+IOqrxoEo21gMA0sjHdU6dPVH4OhyFip9ypl8HOF5RV5KdTo+rBQLvnY2cO8w==",
+ "dev": true,
+ "peerDependencies": {
+ "eslint": ">=7"
+ }
+ },
+ "node_modules/eslint-scope": {
+ "version": "7.2.2",
+ "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz",
+ "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==",
+ "dev": true,
+ "dependencies": {
+ "esrecurse": "^4.3.0",
+ "estraverse": "^5.2.0"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/eslint-visitor-keys": {
+ "version": "3.4.3",
+ "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz",
+ "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==",
+ "dev": true,
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/eslint/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/eslint/node_modules/brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "dependencies": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "node_modules/eslint/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/eslint/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/eslint/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/eslint/node_modules/globals": {
+ "version": "13.24.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz",
+ "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==",
+ "dev": true,
+ "dependencies": {
+ "type-fest": "^0.20.2"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/eslint/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/eslint/node_modules/minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dev": true,
+ "dependencies": {
+ "brace-expansion": "^1.1.7"
+ },
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/eslint/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/espree": {
+ "version": "9.6.1",
+ "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz",
+ "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==",
+ "dev": true,
+ "dependencies": {
+ "acorn": "^8.9.0",
+ "acorn-jsx": "^5.3.2",
+ "eslint-visitor-keys": "^3.4.1"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/esquery": {
+ "version": "1.5.0",
+ "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz",
+ "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==",
+ "dev": true,
+ "dependencies": {
+ "estraverse": "^5.1.0"
+ },
+ "engines": {
+ "node": ">=0.10"
+ }
+ },
+ "node_modules/esrecurse": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz",
+ "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==",
+ "dev": true,
+ "dependencies": {
+ "estraverse": "^5.2.0"
+ },
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/estraverse": {
+ "version": "5.3.0",
+ "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz",
+ "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==",
+ "dev": true,
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/estree-walker": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-2.0.2.tgz",
+ "integrity": "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==",
+ "dev": true
+ },
+ "node_modules/esutils": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz",
+ "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/fast-deep-equal": {
+ "version": "3.1.3",
+ "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
+ "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==",
+ "dev": true
+ },
+ "node_modules/fast-fifo": {
+ "version": "1.3.2",
+ "resolved": "https://registry.npmjs.org/fast-fifo/-/fast-fifo-1.3.2.tgz",
+ "integrity": "sha512-/d9sfos4yxzpwkDkuN7k2SqFKtYNmCTzgfEpz82x34IM9/zc8KGxQoXg1liNC/izpRM/MBdt44Nmx41ZWqk+FQ==",
+ "dev": true
+ },
+ "node_modules/fast-glob": {
+ "version": "3.3.2",
+ "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz",
+ "integrity": "sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==",
+ "dev": true,
+ "dependencies": {
+ "@nodelib/fs.stat": "^2.0.2",
+ "@nodelib/fs.walk": "^1.2.3",
+ "glob-parent": "^5.1.2",
+ "merge2": "^1.3.0",
+ "micromatch": "^4.0.4"
+ },
+ "engines": {
+ "node": ">=8.6.0"
+ }
+ },
+ "node_modules/fast-glob/node_modules/glob-parent": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
+ "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
+ "dev": true,
+ "dependencies": {
+ "is-glob": "^4.0.1"
+ },
+ "engines": {
+ "node": ">= 6"
+ }
+ },
+ "node_modules/fast-json-stable-stringify": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz",
+ "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==",
+ "dev": true
+ },
+ "node_modules/fast-levenshtein": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz",
+ "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==",
+ "dev": true
+ },
+ "node_modules/fastq": {
+ "version": "1.17.0",
+ "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.0.tgz",
+ "integrity": "sha512-zGygtijUMT7jnk3h26kUms3BkSDp4IfIKjmnqI2tvx6nuBfiF1UqOxbnLfzdv+apBy+53oaImsKtMw/xYbW+1w==",
+ "dev": true,
+ "dependencies": {
+ "reusify": "^1.0.4"
+ }
+ },
+ "node_modules/fbjs": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/fbjs/-/fbjs-2.0.0.tgz",
+ "integrity": "sha512-8XA8ny9ifxrAWlyhAbexXcs3rRMtxWcs3M0lctLfB49jRDHiaxj+Mo0XxbwE7nKZYzgCFoq64FS+WFd4IycPPQ==",
+ "dependencies": {
+ "core-js": "^3.6.4",
+ "cross-fetch": "^3.0.4",
+ "fbjs-css-vars": "^1.0.0",
+ "loose-envify": "^1.0.0",
+ "object-assign": "^4.1.0",
+ "promise": "^7.1.1",
+ "setimmediate": "^1.0.5",
+ "ua-parser-js": "^0.7.18"
+ }
+ },
+ "node_modules/fbjs-css-vars": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/fbjs-css-vars/-/fbjs-css-vars-1.0.2.tgz",
+ "integrity": "sha512-b2XGFAFdWZWg0phtAWLHCk836A1Xann+I+Dgd3Gk64MHKZO44FfoD1KxyvbSh0qZsIoXQGGlVztIY+oitJPpRQ=="
+ },
+ "node_modules/fbjs/node_modules/cross-fetch": {
+ "version": "3.1.8",
+ "resolved": "https://registry.npmjs.org/cross-fetch/-/cross-fetch-3.1.8.tgz",
+ "integrity": "sha512-cvA+JwZoU0Xq+h6WkMvAUqPEYy92Obet6UdKLfW60qn99ftItKjB5T+BkyWOFWe2pUyfQ+IJHmpOTznqk1M6Kg==",
+ "dependencies": {
+ "node-fetch": "^2.6.12"
+ }
+ },
+ "node_modules/file-entry-cache": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz",
+ "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==",
+ "dev": true,
+ "dependencies": {
+ "flat-cache": "^3.0.4"
+ },
+ "engines": {
+ "node": "^10.12.0 || >=12.0.0"
+ }
+ },
+ "node_modules/filelist": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/filelist/-/filelist-1.0.4.tgz",
+ "integrity": "sha512-w1cEuf3S+DrLCQL7ET6kz+gmlJdbq9J7yXCSjK/OZCPA+qEN1WyF4ZAf0YYJa4/shHJra2t/d/r8SV4Ji+x+8Q==",
+ "dev": true,
+ "dependencies": {
+ "minimatch": "^5.0.1"
+ }
+ },
+ "node_modules/filelist/node_modules/minimatch": {
+ "version": "5.1.6",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.6.tgz",
+ "integrity": "sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g==",
+ "dev": true,
+ "dependencies": {
+ "brace-expansion": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/fill-range": {
+ "version": "7.0.1",
+ "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
+ "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
+ "dev": true,
+ "dependencies": {
+ "to-regex-range": "^5.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/find-up": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz",
+ "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==",
+ "dev": true,
+ "dependencies": {
+ "locate-path": "^6.0.0",
+ "path-exists": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/flat-cache": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz",
+ "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==",
+ "dev": true,
+ "dependencies": {
+ "flatted": "^3.2.9",
+ "keyv": "^4.5.3",
+ "rimraf": "^3.0.2"
+ },
+ "engines": {
+ "node": "^10.12.0 || >=12.0.0"
+ }
+ },
+ "node_modules/flatted": {
+ "version": "3.2.9",
+ "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.9.tgz",
+ "integrity": "sha512-36yxDn5H7OFZQla0/jFJmbIKTdZAQHngCedGxiMmpNfEZM0sdEeT+WczLQrjK6D7o2aiyLYDnkw0R3JK0Qv1RQ==",
+ "dev": true
+ },
+ "node_modules/follow-redirects": {
+ "version": "1.15.5",
+ "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.5.tgz",
+ "integrity": "sha512-vSFWUON1B+yAw1VN4xMfxgn5fTUiaOzAJCKBwIIgT/+7CuGy9+r+5gITvP62j3RmaD5Ph65UaERdOSRGUzZtgw==",
+ "funding": [
+ {
+ "type": "individual",
+ "url": "https://github.com/sponsors/RubenVerborgh"
+ }
+ ],
+ "engines": {
+ "node": ">=4.0"
+ },
+ "peerDependenciesMeta": {
+ "debug": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/form-data": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz",
+ "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==",
+ "dependencies": {
+ "asynckit": "^0.4.0",
+ "combined-stream": "^1.0.8",
+ "mime-types": "^2.1.12"
+ },
+ "engines": {
+ "node": ">= 6"
+ }
+ },
+ "node_modules/fs-extra": {
+ "version": "11.2.0",
+ "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-11.2.0.tgz",
+ "integrity": "sha512-PmDi3uwK5nFuXh7XDTlVnS17xJS7vW36is2+w3xcv8SVxiB4NyATf4ctkVY5bkSjX0Y4nbvZCq1/EjtEyr9ktw==",
+ "dev": true,
+ "dependencies": {
+ "graceful-fs": "^4.2.0",
+ "jsonfile": "^6.0.1",
+ "universalify": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=14.14"
+ }
+ },
+ "node_modules/fs-merger": {
+ "version": "3.2.1",
+ "resolved": "https://registry.npmjs.org/fs-merger/-/fs-merger-3.2.1.tgz",
+ "integrity": "sha512-AN6sX12liy0JE7C2evclwoo0aCG3PFulLjrTLsJpWh/2mM+DinhpSGqYLbHBBbIW1PLRNcFhJG8Axtz8mQW3ug==",
+ "dev": true,
+ "dependencies": {
+ "broccoli-node-api": "^1.7.0",
+ "broccoli-node-info": "^2.1.0",
+ "fs-extra": "^8.0.1",
+ "fs-tree-diff": "^2.0.1",
+ "walk-sync": "^2.2.0"
+ }
+ },
+ "node_modules/fs-merger/node_modules/fs-extra": {
+ "version": "8.1.0",
+ "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz",
+ "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==",
+ "dev": true,
+ "dependencies": {
+ "graceful-fs": "^4.2.0",
+ "jsonfile": "^4.0.0",
+ "universalify": "^0.1.0"
+ },
+ "engines": {
+ "node": ">=6 <7 || >=8"
+ }
+ },
+ "node_modules/fs-merger/node_modules/jsonfile": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz",
+ "integrity": "sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg==",
+ "dev": true,
+ "optionalDependencies": {
+ "graceful-fs": "^4.1.6"
+ }
+ },
+ "node_modules/fs-merger/node_modules/universalify": {
+ "version": "0.1.2",
+ "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz",
+ "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==",
+ "dev": true,
+ "engines": {
+ "node": ">= 4.0.0"
+ }
+ },
+ "node_modules/fs-mkdirp-stream": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/fs-mkdirp-stream/-/fs-mkdirp-stream-2.0.1.tgz",
+ "integrity": "sha512-UTOY+59K6IA94tec8Wjqm0FSh5OVudGNB0NL/P6fB3HiE3bYOY3VYBGijsnOHNkQSwC1FKkU77pmq7xp9CskLw==",
+ "dev": true,
+ "dependencies": {
+ "graceful-fs": "^4.2.8",
+ "streamx": "^2.12.0"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/fs-tree-diff": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/fs-tree-diff/-/fs-tree-diff-2.0.1.tgz",
+ "integrity": "sha512-x+CfAZ/lJHQqwlD64pYM5QxWjzWhSjroaVsr8PW831zOApL55qPibed0c+xebaLWVr2BnHFoHdrwOv8pzt8R5A==",
+ "dev": true,
+ "dependencies": {
+ "@types/symlink-or-copy": "^1.2.0",
+ "heimdalljs-logger": "^0.1.7",
+ "object-assign": "^4.1.0",
+ "path-posix": "^1.0.0",
+ "symlink-or-copy": "^1.1.8"
+ },
+ "engines": {
+ "node": "6.* || 8.* || >= 10.*"
+ }
+ },
+ "node_modules/fs.realpath": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz",
+ "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==",
+ "dev": true
+ },
+ "node_modules/fsevents": {
+ "version": "2.3.3",
+ "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz",
+ "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==",
+ "dev": true,
+ "hasInstallScript": true,
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": "^8.16.0 || ^10.6.0 || >=11.0.0"
+ }
+ },
+ "node_modules/gensync": {
+ "version": "1.0.0-beta.2",
+ "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz",
+ "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/get-caller-file": {
+ "version": "2.0.5",
+ "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz",
+ "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==",
+ "dev": true,
+ "engines": {
+ "node": "6.* || 8.* || >= 10.*"
+ }
+ },
+ "node_modules/glob": {
+ "version": "7.2.3",
+ "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz",
+ "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==",
+ "dev": true,
+ "dependencies": {
+ "fs.realpath": "^1.0.0",
+ "inflight": "^1.0.4",
+ "inherits": "2",
+ "minimatch": "^3.1.1",
+ "once": "^1.3.0",
+ "path-is-absolute": "^1.0.0"
+ },
+ "engines": {
+ "node": "*"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/glob-parent": {
+ "version": "6.0.2",
+ "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz",
+ "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==",
+ "dev": true,
+ "dependencies": {
+ "is-glob": "^4.0.3"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/glob-stream": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/glob-stream/-/glob-stream-8.0.0.tgz",
+ "integrity": "sha512-CdIUuwOkYNv9ZadR3jJvap8CMooKziQZ/QCSPhEb7zqfsEI5YnPmvca7IvbaVE3z58ZdUYD2JsU6AUWjL8WZJA==",
+ "dev": true,
+ "dependencies": {
+ "@gulpjs/to-absolute-glob": "^4.0.0",
+ "anymatch": "^3.1.3",
+ "fastq": "^1.13.0",
+ "glob-parent": "^6.0.2",
+ "is-glob": "^4.0.3",
+ "is-negated-glob": "^1.0.0",
+ "normalize-path": "^3.0.0",
+ "streamx": "^2.12.5"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/glob/node_modules/brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "dependencies": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "node_modules/glob/node_modules/minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dev": true,
+ "dependencies": {
+ "brace-expansion": "^1.1.7"
+ },
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/globals": {
+ "version": "11.12.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz",
+ "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/globby": {
+ "version": "11.1.0",
+ "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz",
+ "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==",
+ "dev": true,
+ "dependencies": {
+ "array-union": "^2.1.0",
+ "dir-glob": "^3.0.1",
+ "fast-glob": "^3.2.9",
+ "ignore": "^5.2.0",
+ "merge2": "^1.4.1",
+ "slash": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/graceful-fs": {
+ "version": "4.2.11",
+ "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz",
+ "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==",
+ "dev": true
+ },
+ "node_modules/graphemer": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz",
+ "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==",
+ "dev": true
+ },
+ "node_modules/gulp-sort": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/gulp-sort/-/gulp-sort-2.0.0.tgz",
+ "integrity": "sha512-MyTel3FXOdh1qhw1yKhpimQrAmur9q1X0ZigLmCOxouQD+BD3za9/89O+HfbgBQvvh4igEbp0/PUWO+VqGYG1g==",
+ "dev": true,
+ "dependencies": {
+ "through2": "^2.0.1"
+ }
+ },
+ "node_modules/has-flag": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
+ "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/he": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz",
+ "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==",
+ "dev": true,
+ "bin": {
+ "he": "bin/he"
+ }
+ },
+ "node_modules/heimdalljs": {
+ "version": "0.2.6",
+ "resolved": "https://registry.npmjs.org/heimdalljs/-/heimdalljs-0.2.6.tgz",
+ "integrity": "sha512-o9bd30+5vLBvBtzCPwwGqpry2+n0Hi6H1+qwt6y+0kwRHGGF8TFIhJPmnuM0xO97zaKrDZMwO/V56fAnn8m/tA==",
+ "dev": true,
+ "dependencies": {
+ "rsvp": "~3.2.1"
+ }
+ },
+ "node_modules/heimdalljs-logger": {
+ "version": "0.1.10",
+ "resolved": "https://registry.npmjs.org/heimdalljs-logger/-/heimdalljs-logger-0.1.10.tgz",
+ "integrity": "sha512-pO++cJbhIufVI/fmB/u2Yty3KJD0TqNPecehFae0/eps0hkZ3b4Zc/PezUMOpYuHFQbA7FxHZxa305EhmjLj4g==",
+ "dev": true,
+ "dependencies": {
+ "debug": "^2.2.0",
+ "heimdalljs": "^0.2.6"
+ }
+ },
+ "node_modules/heimdalljs-logger/node_modules/debug": {
+ "version": "2.6.9",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
+ "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "dev": true,
+ "dependencies": {
+ "ms": "2.0.0"
+ }
+ },
+ "node_modules/heimdalljs-logger/node_modules/ms": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
+ "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==",
+ "dev": true
+ },
+ "node_modules/heimdalljs/node_modules/rsvp": {
+ "version": "3.2.1",
+ "resolved": "https://registry.npmjs.org/rsvp/-/rsvp-3.2.1.tgz",
+ "integrity": "sha512-Rf4YVNYpKjZ6ASAmibcwTNciQ5Co5Ztq6iZPEykHpkoflnD/K5ryE/rHehFsTm4NJj8nKDhbi3eKBWGogmNnkg==",
+ "dev": true
+ },
+ "node_modules/html-parse-stringify": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/html-parse-stringify/-/html-parse-stringify-3.0.1.tgz",
+ "integrity": "sha512-KknJ50kTInJ7qIScF3jeaFRpMpE8/lfiTdzf/twXyPBLAGrLRTmkz3AdTnKeh40X8k9L2fdYwEp/42WGXIRGcg==",
+ "dependencies": {
+ "void-elements": "3.1.0"
+ }
+ },
+ "node_modules/htmlparser2": {
+ "version": "8.0.2",
+ "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-8.0.2.tgz",
+ "integrity": "sha512-GYdjWKDkbRLkZ5geuHs5NY1puJ+PXwP7+fHPRz06Eirsb9ugf6d8kkXav6ADhcODhFFPMIXyxkxSuMf3D6NCFA==",
+ "dev": true,
+ "funding": [
+ "https://github.com/fb55/htmlparser2?sponsor=1",
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/fb55"
+ }
+ ],
+ "dependencies": {
+ "domelementtype": "^2.3.0",
+ "domhandler": "^5.0.3",
+ "domutils": "^3.0.1",
+ "entities": "^4.4.0"
+ }
+ },
+ "node_modules/i18next": {
+ "version": "23.8.2",
+ "resolved": "https://registry.npmjs.org/i18next/-/i18next-23.8.2.tgz",
+ "integrity": "sha512-Z84zyEangrlERm0ZugVy4bIt485e/H8VecGUZkZWrH7BDePG6jT73QdL9EA1tRTTVVMpry/MgWIP1FjEn0DRXA==",
+ "funding": [
+ {
+ "type": "individual",
+ "url": "https://locize.com"
+ },
+ {
+ "type": "individual",
+ "url": "https://locize.com/i18next.html"
+ },
+ {
+ "type": "individual",
+ "url": "https://www.i18next.com/how-to/faq#i18next-is-awesome.-how-can-i-support-the-project"
+ }
+ ],
+ "dependencies": {
+ "@babel/runtime": "^7.23.2"
+ }
+ },
+ "node_modules/i18next-browser-languagedetector": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/i18next-browser-languagedetector/-/i18next-browser-languagedetector-7.2.0.tgz",
+ "integrity": "sha512-U00DbDtFIYD3wkWsr2aVGfXGAj2TgnELzOX9qv8bT0aJtvPV9CRO77h+vgmHFBMe7LAxdwvT/7VkCWGya6L3tA==",
+ "dependencies": {
+ "@babel/runtime": "^7.23.2"
+ }
+ },
+ "node_modules/i18next-http-backend": {
+ "version": "2.4.3",
+ "resolved": "https://registry.npmjs.org/i18next-http-backend/-/i18next-http-backend-2.4.3.tgz",
+ "integrity": "sha512-jo2M03O6n1/DNb51WSQ8PsQ0xEELzLZRdYUTbf17mLw3rVwnJF9hwNgMXvEFSxxb+N8dT+o0vtigA6s5mGWyPA==",
+ "dependencies": {
+ "cross-fetch": "4.0.0"
+ }
+ },
+ "node_modules/i18next-parser": {
+ "version": "8.12.0",
+ "resolved": "https://registry.npmjs.org/i18next-parser/-/i18next-parser-8.12.0.tgz",
+ "integrity": "sha512-DUDFX3/nkECyd/zCqZoudTEtokMhOVX+zN8X8JasvYd/Lc/PsMcYuO2n0R7yzLiohXLj/7Hp20x0vAbuY8wo0Q==",
+ "dev": true,
+ "dependencies": {
+ "broccoli-plugin": "^4.0.7",
+ "cheerio": "^1.0.0-rc.2",
+ "colors": "1.4.0",
+ "commander": "~11.1.0",
+ "eol": "^0.9.1",
+ "esbuild": "^0.19.0",
+ "fs-extra": "^11.1.0",
+ "gulp-sort": "^2.0.0",
+ "i18next": "^23.5.1",
+ "js-yaml": "4.1.0",
+ "lilconfig": "^3.0.0",
+ "rsvp": "^4.8.2",
+ "sort-keys": "^5.0.0",
+ "typescript": "^5.0.4",
+ "vinyl": "~3.0.0",
+ "vinyl-fs": "^4.0.0",
+ "vue-template-compiler": "^2.6.11"
+ },
+ "bin": {
+ "i18next": "bin/cli.js"
+ },
+ "engines": {
+ "node": ">=16.0.0 || >=18.0.0 || >=20.0.0",
+ "npm": ">=6",
+ "yarn": ">=1"
+ }
+ },
+ "node_modules/iconv-lite": {
+ "version": "0.6.3",
+ "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz",
+ "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==",
+ "dev": true,
+ "dependencies": {
+ "safer-buffer": ">= 2.1.2 < 3.0.0"
+ },
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/ieee754": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz",
+ "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/feross"
+ },
+ {
+ "type": "patreon",
+ "url": "https://www.patreon.com/feross"
+ },
+ {
+ "type": "consulting",
+ "url": "https://feross.org/support"
+ }
+ ]
+ },
+ "node_modules/ignore": {
+ "version": "5.3.1",
+ "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.1.tgz",
+ "integrity": "sha512-5Fytz/IraMjqpwfd34ke28PTVMjZjJG2MPn5t7OE4eUCUNf8BAa7b5WUS9/Qvr6mwOQS7Mk6vdsMno5he+T8Xw==",
+ "dev": true,
+ "engines": {
+ "node": ">= 4"
+ }
+ },
+ "node_modules/immutable": {
+ "version": "3.7.6",
+ "resolved": "https://registry.npmjs.org/immutable/-/immutable-3.7.6.tgz",
+ "integrity": "sha512-AizQPcaofEtO11RZhPPHBOJRdo/20MKQF9mBLnVkBoyHi1/zXK8fzVdnEpSV9gxqtnh6Qomfp3F0xT5qP/vThw==",
+ "engines": {
+ "node": ">=0.8.0"
+ }
+ },
+ "node_modules/import-fresh": {
+ "version": "3.3.0",
+ "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz",
+ "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==",
+ "dev": true,
+ "dependencies": {
+ "parent-module": "^1.0.0",
+ "resolve-from": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/imurmurhash": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
+ "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.8.19"
+ }
+ },
+ "node_modules/inflight": {
+ "version": "1.0.6",
+ "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz",
+ "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==",
+ "dev": true,
+ "dependencies": {
+ "once": "^1.3.0",
+ "wrappy": "1"
+ }
+ },
+ "node_modules/inherits": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz",
+ "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==",
+ "dev": true
+ },
+ "node_modules/is-arrayish": {
+ "version": "0.2.1",
+ "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz",
+ "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==",
+ "dev": true
+ },
+ "node_modules/is-extglob": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
+ "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/is-fullwidth-code-point": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz",
+ "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/is-glob": {
+ "version": "4.0.3",
+ "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
+ "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
+ "dev": true,
+ "dependencies": {
+ "is-extglob": "^2.1.1"
+ },
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/is-negated-glob": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/is-negated-glob/-/is-negated-glob-1.0.0.tgz",
+ "integrity": "sha512-czXVVn/QEmgvej1f50BZ648vUI+em0xqMq2Sn+QncCLN4zj1UAxlT+kw/6ggQTOaZPd1HqKQGEqbpQVtJucWug==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/is-number": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
+ "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.12.0"
+ }
+ },
+ "node_modules/is-path-inside": {
+ "version": "3.0.3",
+ "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz",
+ "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/is-plain-obj": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-4.1.0.tgz",
+ "integrity": "sha512-+Pgi+vMuUNkJyExiMBt5IlFoMyKnr5zhJ4Uspz58WOhBF5QoIZkFyNHIbBAtHwzVAgk5RtndVNsDRN61/mmDqg==",
+ "dev": true,
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/is-valid-glob": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/is-valid-glob/-/is-valid-glob-1.0.0.tgz",
+ "integrity": "sha512-AhiROmoEFDSsjx8hW+5sGwgKVIORcXnrlAx/R0ZSeaPw70Vw0CqkGBBhHGL58Uox2eXnU1AnvXJl1XlyedO5bA==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/isarray": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
+ "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==",
+ "dev": true
+ },
+ "node_modules/isexe": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
+ "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==",
+ "dev": true
+ },
+ "node_modules/jake": {
+ "version": "10.8.7",
+ "resolved": "https://registry.npmjs.org/jake/-/jake-10.8.7.tgz",
+ "integrity": "sha512-ZDi3aP+fG/LchyBzUM804VjddnwfSfsdeYkwt8NcbKRvo4rFkjhs456iLFn3k2ZUWvNe4i48WACDbza8fhq2+w==",
+ "dev": true,
+ "dependencies": {
+ "async": "^3.2.3",
+ "chalk": "^4.0.2",
+ "filelist": "^1.0.4",
+ "minimatch": "^3.1.2"
+ },
+ "bin": {
+ "jake": "bin/cli.js"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/jake/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/jake/node_modules/brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "dependencies": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "node_modules/jake/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/jake/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/jake/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/jake/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jake/node_modules/minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dev": true,
+ "dependencies": {
+ "brace-expansion": "^1.1.7"
+ },
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/jake/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/js-tokens": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz",
+ "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ=="
+ },
+ "node_modules/js-yaml": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz",
+ "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==",
+ "dev": true,
+ "dependencies": {
+ "argparse": "^2.0.1"
+ },
+ "bin": {
+ "js-yaml": "bin/js-yaml.js"
+ }
+ },
+ "node_modules/jsesc": {
+ "version": "2.5.2",
+ "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz",
+ "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==",
+ "dev": true,
+ "bin": {
+ "jsesc": "bin/jsesc"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/json-buffer": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz",
+ "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==",
+ "dev": true
+ },
+ "node_modules/json-parse-even-better-errors": {
+ "version": "2.3.1",
+ "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz",
+ "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==",
+ "dev": true
+ },
+ "node_modules/json-schema-traverse": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
+ "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
+ "dev": true
+ },
+ "node_modules/json-stable-stringify-without-jsonify": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz",
+ "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==",
+ "dev": true
+ },
+ "node_modules/json5": {
+ "version": "2.2.3",
+ "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz",
+ "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==",
+ "dev": true,
+ "bin": {
+ "json5": "lib/cli.js"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/jsonfile": {
+ "version": "6.1.0",
+ "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-6.1.0.tgz",
+ "integrity": "sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ==",
+ "dev": true,
+ "dependencies": {
+ "universalify": "^2.0.0"
+ },
+ "optionalDependencies": {
+ "graceful-fs": "^4.1.6"
+ }
+ },
+ "node_modules/keyborg": {
+ "version": "2.5.0",
+ "resolved": "https://registry.npmjs.org/keyborg/-/keyborg-2.5.0.tgz",
+ "integrity": "sha512-nb4Ji1suqWqj6VXb61Jrs4ab/UWgtGph4wDch2NIZDfLBUObmLcZE0aiDjZY49ghtu03fvwxDNvS9ZB0XMz6/g=="
+ },
+ "node_modules/keyv": {
+ "version": "4.5.4",
+ "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz",
+ "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==",
+ "dev": true,
+ "dependencies": {
+ "json-buffer": "3.0.1"
+ }
+ },
+ "node_modules/lead": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/lead/-/lead-4.0.0.tgz",
+ "integrity": "sha512-DpMa59o5uGUWWjruMp71e6knmwKU3jRBBn1kjuLWN9EeIOxNeSAwvHf03WIl8g/ZMR2oSQC9ej3yeLBwdDc/pg==",
+ "dev": true,
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/levn": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz",
+ "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==",
+ "dev": true,
+ "dependencies": {
+ "prelude-ls": "^1.2.1",
+ "type-check": "~0.4.0"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/lilconfig": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-3.0.0.tgz",
+ "integrity": "sha512-K2U4W2Ff5ibV7j7ydLr+zLAkIg5JJ4lPn1Ltsdt+Tz/IjQ8buJ55pZAxoP34lqIiwtF9iAvtLv3JGv7CAyAg+g==",
+ "dev": true,
+ "engines": {
+ "node": ">=14"
+ }
+ },
+ "node_modules/lines-and-columns": {
+ "version": "1.2.4",
+ "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz",
+ "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==",
+ "dev": true
+ },
+ "node_modules/locate-path": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz",
+ "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==",
+ "dev": true,
+ "dependencies": {
+ "p-locate": "^5.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/lodash.merge": {
+ "version": "4.6.2",
+ "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz",
+ "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==",
+ "dev": true
+ },
+ "node_modules/loose-envify": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz",
+ "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==",
+ "dependencies": {
+ "js-tokens": "^3.0.0 || ^4.0.0"
+ },
+ "bin": {
+ "loose-envify": "cli.js"
+ }
+ },
+ "node_modules/lower-case": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/lower-case/-/lower-case-2.0.2.tgz",
+ "integrity": "sha512-7fm3l3NAF9WfN6W3JOmf5drwpVqX78JtoGJ3A6W0a6ZnldM41w2fV5D490psKFTpMds8TJse/eHLFFsNHHjHgg==",
+ "dev": true,
+ "dependencies": {
+ "tslib": "^2.0.3"
+ }
+ },
+ "node_modules/lru-cache": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz",
+ "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==",
+ "dev": true,
+ "dependencies": {
+ "yallist": "^3.0.2"
+ }
+ },
+ "node_modules/matcher-collection": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/matcher-collection/-/matcher-collection-2.0.1.tgz",
+ "integrity": "sha512-daE62nS2ZQsDg9raM0IlZzLmI2u+7ZapXBwdoeBUKAYERPDDIc0qNqA8E0Rp2D+gspKR7BgIFP52GeujaGXWeQ==",
+ "dev": true,
+ "dependencies": {
+ "@types/minimatch": "^3.0.3",
+ "minimatch": "^3.0.2"
+ },
+ "engines": {
+ "node": "6.* || 8.* || >= 10.*"
+ }
+ },
+ "node_modules/matcher-collection/node_modules/brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "dependencies": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "node_modules/matcher-collection/node_modules/minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dev": true,
+ "dependencies": {
+ "brace-expansion": "^1.1.7"
+ },
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/merge2": {
+ "version": "1.4.1",
+ "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz",
+ "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==",
+ "dev": true,
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/micromatch": {
+ "version": "4.0.5",
+ "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz",
+ "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==",
+ "dev": true,
+ "dependencies": {
+ "braces": "^3.0.2",
+ "picomatch": "^2.3.1"
+ },
+ "engines": {
+ "node": ">=8.6"
+ }
+ },
+ "node_modules/mime-db": {
+ "version": "1.52.0",
+ "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz",
+ "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==",
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/mime-types": {
+ "version": "2.1.35",
+ "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz",
+ "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==",
+ "dependencies": {
+ "mime-db": "1.52.0"
+ },
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/minimatch": {
+ "version": "9.0.3",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz",
+ "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==",
+ "dev": true,
+ "dependencies": {
+ "brace-expansion": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=16 || 14 >=14.17"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/mktemp": {
+ "version": "0.4.0",
+ "resolved": "https://registry.npmjs.org/mktemp/-/mktemp-0.4.0.tgz",
+ "integrity": "sha512-IXnMcJ6ZyTuhRmJSjzvHSRhlVPiN9Jwc6e59V0bEJ0ba6OBeX2L0E+mRN1QseeOF4mM+F1Rit6Nh7o+rl2Yn/A==",
+ "dev": true,
+ "engines": {
+ "node": ">0.9"
+ }
+ },
+ "node_modules/ms": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
+ "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==",
+ "dev": true
+ },
+ "node_modules/nanoid": {
+ "version": "3.3.7",
+ "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz",
+ "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/ai"
+ }
+ ],
+ "bin": {
+ "nanoid": "bin/nanoid.cjs"
+ },
+ "engines": {
+ "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1"
+ }
+ },
+ "node_modules/natural-compare": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz",
+ "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==",
+ "dev": true
+ },
+ "node_modules/no-case": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/no-case/-/no-case-3.0.4.tgz",
+ "integrity": "sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg==",
+ "dev": true,
+ "dependencies": {
+ "lower-case": "^2.0.2",
+ "tslib": "^2.0.3"
+ }
+ },
+ "node_modules/node-fetch": {
+ "version": "2.7.0",
+ "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.7.0.tgz",
+ "integrity": "sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A==",
+ "dependencies": {
+ "whatwg-url": "^5.0.0"
+ },
+ "engines": {
+ "node": "4.x || >=6.0.0"
+ },
+ "peerDependencies": {
+ "encoding": "^0.1.0"
+ },
+ "peerDependenciesMeta": {
+ "encoding": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/node-releases": {
+ "version": "2.0.14",
+ "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.14.tgz",
+ "integrity": "sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==",
+ "dev": true
+ },
+ "node_modules/normalize-path": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
+ "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/now-and-later": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/now-and-later/-/now-and-later-3.0.0.tgz",
+ "integrity": "sha512-pGO4pzSdaxhWTGkfSfHx3hVzJVslFPwBp2Myq9MYN/ChfJZF87ochMAXnvz6/58RJSf5ik2q9tXprBBrk2cpcg==",
+ "dev": true,
+ "dependencies": {
+ "once": "^1.4.0"
+ },
+ "engines": {
+ "node": ">= 10.13.0"
+ }
+ },
+ "node_modules/nth-check": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-2.1.1.tgz",
+ "integrity": "sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==",
+ "dev": true,
+ "dependencies": {
+ "boolbase": "^1.0.0"
+ },
+ "funding": {
+ "url": "https://github.com/fb55/nth-check?sponsor=1"
+ }
+ },
+ "node_modules/object-assign": {
+ "version": "4.1.1",
+ "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz",
+ "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/once": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
+ "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==",
+ "dev": true,
+ "dependencies": {
+ "wrappy": "1"
+ }
+ },
+ "node_modules/optionator": {
+ "version": "0.9.3",
+ "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz",
+ "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==",
+ "dev": true,
+ "dependencies": {
+ "@aashutoshrathi/word-wrap": "^1.2.3",
+ "deep-is": "^0.1.3",
+ "fast-levenshtein": "^2.0.6",
+ "levn": "^0.4.1",
+ "prelude-ls": "^1.2.1",
+ "type-check": "^0.4.0"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/p-limit": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz",
+ "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==",
+ "dev": true,
+ "dependencies": {
+ "yocto-queue": "^0.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/p-locate": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz",
+ "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==",
+ "dev": true,
+ "dependencies": {
+ "p-limit": "^3.0.2"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/parent-module": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz",
+ "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==",
+ "dev": true,
+ "dependencies": {
+ "callsites": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/parse-json": {
+ "version": "5.2.0",
+ "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz",
+ "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/code-frame": "^7.0.0",
+ "error-ex": "^1.3.1",
+ "json-parse-even-better-errors": "^2.3.0",
+ "lines-and-columns": "^1.1.6"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/parse5": {
+ "version": "7.1.2",
+ "resolved": "https://registry.npmjs.org/parse5/-/parse5-7.1.2.tgz",
+ "integrity": "sha512-Czj1WaSVpaoj0wbhMzLmWD69anp2WH7FXMB9n1Sy8/ZFF9jolSQVMu1Ij5WIyGmcBmhk7EOndpO4mIpihVqAXw==",
+ "dev": true,
+ "dependencies": {
+ "entities": "^4.4.0"
+ },
+ "funding": {
+ "url": "https://github.com/inikulin/parse5?sponsor=1"
+ }
+ },
+ "node_modules/parse5-htmlparser2-tree-adapter": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/parse5-htmlparser2-tree-adapter/-/parse5-htmlparser2-tree-adapter-7.0.0.tgz",
+ "integrity": "sha512-B77tOZrqqfUfnVcOrUvfdLbz4pu4RopLD/4vmu3HUPswwTA8OH0EMW9BlWR2B0RCoiZRAHEUu7IxeP1Pd1UU+g==",
+ "dev": true,
+ "dependencies": {
+ "domhandler": "^5.0.2",
+ "parse5": "^7.0.0"
+ },
+ "funding": {
+ "url": "https://github.com/inikulin/parse5?sponsor=1"
+ }
+ },
+ "node_modules/path-exists": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz",
+ "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/path-is-absolute": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
+ "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/path-key": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz",
+ "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/path-posix": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/path-posix/-/path-posix-1.0.0.tgz",
+ "integrity": "sha512-1gJ0WpNIiYcQydgg3Ed8KzvIqTsDpNwq+cjBCssvBtuTWjEqY1AW+i+OepiEMqDCzyro9B2sLAe4RBPajMYFiA==",
+ "dev": true
+ },
+ "node_modules/path-type": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz",
+ "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/picocolors": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz",
+ "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==",
+ "dev": true
+ },
+ "node_modules/picomatch": {
+ "version": "2.3.1",
+ "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz",
+ "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==",
+ "dev": true,
+ "engines": {
+ "node": ">=8.6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/jonschlinkert"
+ }
+ },
+ "node_modules/postcss": {
+ "version": "8.4.33",
+ "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.33.tgz",
+ "integrity": "sha512-Kkpbhhdjw2qQs2O2DGX+8m5OVqEcbB9HRBvuYM9pgrjEFUg30A9LmXNlTAUj4S9kgtGyrMbTzVjH7E+s5Re2yg==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/postcss/"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/postcss"
+ },
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/ai"
+ }
+ ],
+ "dependencies": {
+ "nanoid": "^3.3.7",
+ "picocolors": "^1.0.0",
+ "source-map-js": "^1.0.2"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14"
+ }
+ },
+ "node_modules/prelude-ls": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz",
+ "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/prettier": {
+ "version": "3.2.4",
+ "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.2.4.tgz",
+ "integrity": "sha512-FWu1oLHKCrtpO1ypU6J0SbK2d9Ckwysq6bHj/uaCP26DxrPpppCLQRGVuqAxSTvhF00AcvDRyYrLNW7ocBhFFQ==",
+ "bin": {
+ "prettier": "bin/prettier.cjs"
+ },
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "url": "https://github.com/prettier/prettier?sponsor=1"
+ }
+ },
+ "node_modules/process-nextick-args": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz",
+ "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==",
+ "dev": true
+ },
+ "node_modules/promise": {
+ "version": "7.3.1",
+ "resolved": "https://registry.npmjs.org/promise/-/promise-7.3.1.tgz",
+ "integrity": "sha512-nolQXZ/4L+bP/UGlkfaIujX9BKxGwmQ9OT4mOt5yvy8iK1h3wqTEJCijzGANTCCl9nWjY41juyAn2K3Q1hLLTg==",
+ "dependencies": {
+ "asap": "~2.0.3"
+ }
+ },
+ "node_modules/promise-map-series": {
+ "version": "0.3.0",
+ "resolved": "https://registry.npmjs.org/promise-map-series/-/promise-map-series-0.3.0.tgz",
+ "integrity": "sha512-3npG2NGhTc8BWBolLLf8l/92OxMGaRLbqvIh9wjCHhDXNvk4zsxaTaCpiCunW09qWPrN2zeNSNwRLVBrQQtutA==",
+ "dev": true,
+ "engines": {
+ "node": "10.* || >= 12.*"
+ }
+ },
+ "node_modules/prop-types": {
+ "version": "15.8.1",
+ "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz",
+ "integrity": "sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==",
+ "dependencies": {
+ "loose-envify": "^1.4.0",
+ "object-assign": "^4.1.1",
+ "react-is": "^16.13.1"
+ }
+ },
+ "node_modules/prop-types/node_modules/react-is": {
+ "version": "16.13.1",
+ "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz",
+ "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ=="
+ },
+ "node_modules/proxy-from-env": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz",
+ "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg=="
+ },
+ "node_modules/punycode": {
+ "version": "2.3.1",
+ "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz",
+ "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/queue-microtask": {
+ "version": "1.2.3",
+ "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz",
+ "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/feross"
+ },
+ {
+ "type": "patreon",
+ "url": "https://www.patreon.com/feross"
+ },
+ {
+ "type": "consulting",
+ "url": "https://feross.org/support"
+ }
+ ]
+ },
+ "node_modules/queue-tick": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/queue-tick/-/queue-tick-1.0.1.tgz",
+ "integrity": "sha512-kJt5qhMxoszgU/62PLP1CJytzd2NKetjSRnyuj31fDd3Rlcz3fzlFdFLD1SItunPwyqEOkca6GbV612BWfaBag==",
+ "dev": true
+ },
+ "node_modules/quick-temp": {
+ "version": "0.1.8",
+ "resolved": "https://registry.npmjs.org/quick-temp/-/quick-temp-0.1.8.tgz",
+ "integrity": "sha512-YsmIFfD9j2zaFwJkzI6eMG7y0lQP7YeWzgtFgNl38pGWZBSXJooZbOWwkcRot7Vt0Fg9L23pX0tqWU3VvLDsiA==",
+ "dev": true,
+ "dependencies": {
+ "mktemp": "~0.4.0",
+ "rimraf": "^2.5.4",
+ "underscore.string": "~3.3.4"
+ }
+ },
+ "node_modules/quick-temp/node_modules/rimraf": {
+ "version": "2.7.1",
+ "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz",
+ "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==",
+ "dev": true,
+ "dependencies": {
+ "glob": "^7.1.3"
+ },
+ "bin": {
+ "rimraf": "bin.js"
+ }
+ },
+ "node_modules/react": {
+ "version": "18.2.0",
+ "resolved": "https://registry.npmjs.org/react/-/react-18.2.0.tgz",
+ "integrity": "sha512-/3IjMdb2L9QbBdWiW5e3P2/npwMBaU9mHCSCUzNln0ZCYbcfTsGbTJrU/kGemdH2IWmB2ioZ+zkxtmq6g09fGQ==",
+ "dependencies": {
+ "loose-envify": "^1.1.0"
+ },
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/react-country-flag": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/react-country-flag/-/react-country-flag-3.1.0.tgz",
+ "integrity": "sha512-JWQFw1efdv9sTC+TGQvTKXQg1NKbDU2mBiAiRWcKM9F1sK+/zjhP2yGmm8YDddWyZdXVkR8Md47rPMJmo4YO5g==",
+ "engines": {
+ "node": ">=12"
+ },
+ "peerDependencies": {
+ "react": ">=16"
+ }
+ },
+ "node_modules/react-dom": {
+ "version": "18.2.0",
+ "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.2.0.tgz",
+ "integrity": "sha512-6IMTriUmvsjHUjNtEDudZfuDQUoWXVxKHhlEGSk81n4YFS+r/Kl99wXiwlVXtPBtJenozv2P+hxDsw9eA7Xo6g==",
+ "dependencies": {
+ "loose-envify": "^1.1.0",
+ "scheduler": "^0.23.0"
+ },
+ "peerDependencies": {
+ "react": "^18.2.0"
+ }
+ },
+ "node_modules/react-dom/node_modules/scheduler": {
+ "version": "0.23.0",
+ "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.0.tgz",
+ "integrity": "sha512-CtuThmgHNg7zIZWAXi3AsyIzA3n4xx7aNyjwC2VJldO2LMVDhFK+63xGqq6CsJH4rTAt6/M+N4GhZiDYPx9eUw==",
+ "dependencies": {
+ "loose-envify": "^1.1.0"
+ }
+ },
+ "node_modules/react-highlight-within-textarea": {
+ "version": "3.2.1",
+ "resolved": "https://registry.npmjs.org/react-highlight-within-textarea/-/react-highlight-within-textarea-3.2.1.tgz",
+ "integrity": "sha512-ettN+GQfNLg6zCcpatsT9yhgpwEh5dV+tRKEmZu9+DnvLL7t1Bm/0wZ2tTC+G7wAZngJ2HbMlusJXR6v3Cs4PQ==",
+ "peerDependencies": {
+ "draft-js": ">=0.11.7",
+ "react": ">=0.14.0",
+ "react-dom": ">=0.14.0"
+ }
+ },
+ "node_modules/react-i18next": {
+ "version": "14.0.1",
+ "resolved": "https://registry.npmjs.org/react-i18next/-/react-i18next-14.0.1.tgz",
+ "integrity": "sha512-TMV8hFismBmpMdIehoFHin/okfvgjFhp723RYgIqB4XyhDobVMyukyM3Z8wtTRmajyFMZrBl/OaaXF2P6WjUAw==",
+ "dependencies": {
+ "@babel/runtime": "^7.22.5",
+ "html-parse-stringify": "^3.0.1"
+ },
+ "peerDependencies": {
+ "i18next": ">= 23.2.3",
+ "react": ">= 16.8.0"
+ },
+ "peerDependenciesMeta": {
+ "react-dom": {
+ "optional": true
+ },
+ "react-native": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/react-is": {
+ "version": "17.0.2",
+ "resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz",
+ "integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w=="
+ },
+ "node_modules/react-refresh": {
+ "version": "0.14.0",
+ "resolved": "https://registry.npmjs.org/react-refresh/-/react-refresh-0.14.0.tgz",
+ "integrity": "sha512-wViHqhAd8OHeLS/IRMJjTSDHF3U9eWi62F/MledQGPdJGDhodXJ9PBLNGr6WWL7qlH12Mt3TyTpbS+hGXMjCzQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/react-router": {
+ "version": "6.21.3",
+ "resolved": "https://registry.npmjs.org/react-router/-/react-router-6.21.3.tgz",
+ "integrity": "sha512-a0H638ZXULv1OdkmiK6s6itNhoy33ywxmUFT/xtSoVyf9VnC7n7+VT4LjVzdIHSaF5TIh9ylUgxMXksHTgGrKg==",
+ "dependencies": {
+ "@remix-run/router": "1.14.2"
+ },
+ "engines": {
+ "node": ">=14.0.0"
+ },
+ "peerDependencies": {
+ "react": ">=16.8"
+ }
+ },
+ "node_modules/react-router-dom": {
+ "version": "6.21.3",
+ "resolved": "https://registry.npmjs.org/react-router-dom/-/react-router-dom-6.21.3.tgz",
+ "integrity": "sha512-kNzubk7n4YHSrErzjLK72j0B5i969GsuCGazRl3G6j1zqZBLjuSlYBdVdkDOgzGdPIffUOc9nmgiadTEVoq91g==",
+ "dependencies": {
+ "@remix-run/router": "1.14.2",
+ "react-router": "6.21.3"
+ },
+ "engines": {
+ "node": ">=14.0.0"
+ },
+ "peerDependencies": {
+ "react": ">=16.8",
+ "react-dom": ">=16.8"
+ }
+ },
+ "node_modules/react-transition-group": {
+ "version": "4.4.5",
+ "resolved": "https://registry.npmjs.org/react-transition-group/-/react-transition-group-4.4.5.tgz",
+ "integrity": "sha512-pZcd1MCJoiKiBR2NRxeCRg13uCXbydPnmB4EOeRrY7480qNWO8IIgQG6zlDkm6uRMsURXPuKq0GWtiM59a5Q6g==",
+ "dependencies": {
+ "@babel/runtime": "^7.5.5",
+ "dom-helpers": "^5.0.1",
+ "loose-envify": "^1.4.0",
+ "prop-types": "^15.6.2"
+ },
+ "peerDependencies": {
+ "react": ">=16.6.0",
+ "react-dom": ">=16.6.0"
+ }
+ },
+ "node_modules/readable-stream": {
+ "version": "2.3.8",
+ "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz",
+ "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==",
+ "dev": true,
+ "dependencies": {
+ "core-util-is": "~1.0.0",
+ "inherits": "~2.0.3",
+ "isarray": "~1.0.0",
+ "process-nextick-args": "~2.0.0",
+ "safe-buffer": "~5.1.1",
+ "string_decoder": "~1.1.1",
+ "util-deprecate": "~1.0.1"
+ }
+ },
+ "node_modules/regenerator-runtime": {
+ "version": "0.14.1",
+ "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.14.1.tgz",
+ "integrity": "sha512-dYnhHh0nJoMfnkZs6GmmhFknAGRrLznOu5nc9ML+EJxGvrx6H7teuevqVqCuPcPK//3eDrrjQhehXVx9cnkGdw=="
+ },
+ "node_modules/remove-trailing-separator": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz",
+ "integrity": "sha512-/hS+Y0u3aOfIETiaiirUFwDBDzmXPvO+jAfKTitUngIPzdKc6Z0LoFjM/CK5PL4C+eKwHohlHAb6H0VFfmmUsw==",
+ "dev": true
+ },
+ "node_modules/replace-ext": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/replace-ext/-/replace-ext-2.0.0.tgz",
+ "integrity": "sha512-UszKE5KVK6JvyD92nzMn9cDapSk6w/CaFZ96CnmDMUqH9oowfxF/ZjRITD25H4DnOQClLA4/j7jLGXXLVKxAug==",
+ "dev": true,
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/require-directory": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz",
+ "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/resolve-from": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz",
+ "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/resolve-options": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-options/-/resolve-options-2.0.0.tgz",
+ "integrity": "sha512-/FopbmmFOQCfsCx77BRFdKOniglTiHumLgwvd6IDPihy1GKkadZbgQJBcTb2lMzSR1pndzd96b1nZrreZ7+9/A==",
+ "dev": true,
+ "dependencies": {
+ "value-or-function": "^4.0.0"
+ },
+ "engines": {
+ "node": ">= 10.13.0"
+ }
+ },
+ "node_modules/reusify": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz",
+ "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==",
+ "dev": true,
+ "engines": {
+ "iojs": ">=1.0.0",
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/rimraf": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz",
+ "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==",
+ "dev": true,
+ "dependencies": {
+ "glob": "^7.1.3"
+ },
+ "bin": {
+ "rimraf": "bin.js"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/rollup": {
+ "version": "4.9.6",
+ "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.9.6.tgz",
+ "integrity": "sha512-05lzkCS2uASX0CiLFybYfVkwNbKZG5NFQ6Go0VWyogFTXXbR039UVsegViTntkk4OglHBdF54ccApXRRuXRbsg==",
+ "dev": true,
+ "dependencies": {
+ "@types/estree": "1.0.5"
+ },
+ "bin": {
+ "rollup": "dist/bin/rollup"
+ },
+ "engines": {
+ "node": ">=18.0.0",
+ "npm": ">=8.0.0"
+ },
+ "optionalDependencies": {
+ "@rollup/rollup-android-arm-eabi": "4.9.6",
+ "@rollup/rollup-android-arm64": "4.9.6",
+ "@rollup/rollup-darwin-arm64": "4.9.6",
+ "@rollup/rollup-darwin-x64": "4.9.6",
+ "@rollup/rollup-linux-arm-gnueabihf": "4.9.6",
+ "@rollup/rollup-linux-arm64-gnu": "4.9.6",
+ "@rollup/rollup-linux-arm64-musl": "4.9.6",
+ "@rollup/rollup-linux-riscv64-gnu": "4.9.6",
+ "@rollup/rollup-linux-x64-gnu": "4.9.6",
+ "@rollup/rollup-linux-x64-musl": "4.9.6",
+ "@rollup/rollup-win32-arm64-msvc": "4.9.6",
+ "@rollup/rollup-win32-ia32-msvc": "4.9.6",
+ "@rollup/rollup-win32-x64-msvc": "4.9.6",
+ "fsevents": "~2.3.2"
+ }
+ },
+ "node_modules/rsvp": {
+ "version": "4.8.5",
+ "resolved": "https://registry.npmjs.org/rsvp/-/rsvp-4.8.5.tgz",
+ "integrity": "sha512-nfMOlASu9OnRJo1mbEk2cz0D56a1MBNrJ7orjRZQG10XDyuvwksKbuXNp6qa+kbn839HwjwhBzhFmdsaEAfauA==",
+ "dev": true,
+ "engines": {
+ "node": "6.* || >= 7.*"
+ }
+ },
+ "node_modules/rtl-css-js": {
+ "version": "1.16.1",
+ "resolved": "https://registry.npmjs.org/rtl-css-js/-/rtl-css-js-1.16.1.tgz",
+ "integrity": "sha512-lRQgou1mu19e+Ya0LsTvKrVJ5TYUbqCVPAiImX3UfLTenarvPUl1QFdvu5Z3PYmHT9RCcwIfbjRQBntExyj3Zg==",
+ "dependencies": {
+ "@babel/runtime": "^7.1.2"
+ }
+ },
+ "node_modules/run-parallel": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz",
+ "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/feross"
+ },
+ {
+ "type": "patreon",
+ "url": "https://www.patreon.com/feross"
+ },
+ {
+ "type": "consulting",
+ "url": "https://feross.org/support"
+ }
+ ],
+ "dependencies": {
+ "queue-microtask": "^1.2.2"
+ }
+ },
+ "node_modules/safe-buffer": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
+ "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==",
+ "dev": true
+ },
+ "node_modules/safer-buffer": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
+ "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==",
+ "dev": true
+ },
+ "node_modules/scheduler": {
+ "version": "0.20.2",
+ "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.20.2.tgz",
+ "integrity": "sha512-2eWfGgAqqWFGqtdMmcL5zCMK1U8KlXv8SQFGglL3CEtd0aDVDWgeF/YoCmvln55m5zSk3J/20hTaSBeSObsQDQ==",
+ "peer": true,
+ "dependencies": {
+ "loose-envify": "^1.1.0",
+ "object-assign": "^4.1.1"
+ }
+ },
+ "node_modules/semver": {
+ "version": "7.5.4",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz",
+ "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==",
+ "dev": true,
+ "dependencies": {
+ "lru-cache": "^6.0.0"
+ },
+ "bin": {
+ "semver": "bin/semver.js"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/semver/node_modules/lru-cache": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
+ "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
+ "dev": true,
+ "dependencies": {
+ "yallist": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/semver/node_modules/yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ },
+ "node_modules/setimmediate": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz",
+ "integrity": "sha512-MATJdZp8sLqDl/68LfQmbP8zKPLQNV6BIZoIgrscFDQ+RsvK/BxeDQOgyxKKoh0y/8h3BqVFnCqQ/gd+reiIXA=="
+ },
+ "node_modules/shebang-command": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz",
+ "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==",
+ "dev": true,
+ "dependencies": {
+ "shebang-regex": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/shebang-regex": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz",
+ "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/shell-quote": {
+ "version": "1.8.1",
+ "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.8.1.tgz",
+ "integrity": "sha512-6j1W9l1iAs/4xYBI1SYOVZyFcCis9b4KCLQ8fgAGG07QvzaRLVVRQvAy85yNmmZSjYjg4MWh4gNvlPujU/5LpA==",
+ "dev": true,
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/slash": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz",
+ "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/snake-case": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/snake-case/-/snake-case-3.0.4.tgz",
+ "integrity": "sha512-LAOh4z89bGQvl9pFfNF8V146i7o7/CqFPbqzYgP+yYzDIDeS9HaNFtXABamRW+AQzEVODcvE79ljJ+8a9YSdMg==",
+ "dev": true,
+ "dependencies": {
+ "dot-case": "^3.0.4",
+ "tslib": "^2.0.3"
+ }
+ },
+ "node_modules/sort-keys": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/sort-keys/-/sort-keys-5.0.0.tgz",
+ "integrity": "sha512-Pdz01AvCAottHTPQGzndktFNdbRA75BgOfeT1hH+AMnJFv8lynkPi42rfeEhpx1saTEI3YNMWxfqu0sFD1G8pw==",
+ "dev": true,
+ "dependencies": {
+ "is-plain-obj": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/source-map": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
+ "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
+ "dev": true,
+ "optional": true,
+ "peer": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/source-map-js": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz",
+ "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/source-map-support": {
+ "version": "0.5.21",
+ "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz",
+ "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==",
+ "dev": true,
+ "optional": true,
+ "peer": true,
+ "dependencies": {
+ "buffer-from": "^1.0.0",
+ "source-map": "^0.6.0"
+ }
+ },
+ "node_modules/sprintf-js": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.1.3.tgz",
+ "integrity": "sha512-Oo+0REFV59/rz3gfJNKQiBlwfHaSESl1pcGyABQsnnIfWOFt6JNj5gCog2U6MLZ//IGYD+nA8nI+mTShREReaA==",
+ "dev": true
+ },
+ "node_modules/stream-composer": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/stream-composer/-/stream-composer-1.0.2.tgz",
+ "integrity": "sha512-bnBselmwfX5K10AH6L4c8+S5lgZMWI7ZYrz2rvYjCPB2DIMC4Ig8OpxGpNJSxRZ58oti7y1IcNvjBAz9vW5m4w==",
+ "dev": true,
+ "dependencies": {
+ "streamx": "^2.13.2"
+ }
+ },
+ "node_modules/streamx": {
+ "version": "2.15.6",
+ "resolved": "https://registry.npmjs.org/streamx/-/streamx-2.15.6.tgz",
+ "integrity": "sha512-q+vQL4AAz+FdfT137VF69Cc/APqUbxy+MDOImRrMvchJpigHj9GksgDU2LYbO9rx7RX6osWgxJB2WxhYv4SZAw==",
+ "dev": true,
+ "dependencies": {
+ "fast-fifo": "^1.1.0",
+ "queue-tick": "^1.0.1"
+ }
+ },
+ "node_modules/string_decoder": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz",
+ "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==",
+ "dev": true,
+ "dependencies": {
+ "safe-buffer": "~5.1.0"
+ }
+ },
+ "node_modules/string-width": {
+ "version": "4.2.3",
+ "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz",
+ "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==",
+ "dev": true,
+ "dependencies": {
+ "emoji-regex": "^8.0.0",
+ "is-fullwidth-code-point": "^3.0.0",
+ "strip-ansi": "^6.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/strip-ansi": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz",
+ "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
+ "dev": true,
+ "dependencies": {
+ "ansi-regex": "^5.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/strip-json-comments": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz",
+ "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/stylis": {
+ "version": "4.3.1",
+ "resolved": "https://registry.npmjs.org/stylis/-/stylis-4.3.1.tgz",
+ "integrity": "sha512-EQepAV+wMsIaGVGX1RECzgrcqRRU/0sYOHkeLsZ3fzHaHXZy4DaOOX0vOlGQdlsjkh3mFHAIlVimpwAs4dslyQ=="
+ },
+ "node_modules/supports-color": {
+ "version": "5.5.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
+ "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/svg-parser": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/svg-parser/-/svg-parser-2.0.4.tgz",
+ "integrity": "sha512-e4hG1hRwoOdRb37cIMSgzNsxyzKfayW6VOflrwvR+/bzrkyxY/31WkbgnQpgtrNp1SdpJvpUAGTa/ZoiPNDuRQ==",
+ "dev": true
+ },
+ "node_modules/symlink-or-copy": {
+ "version": "1.3.1",
+ "resolved": "https://registry.npmjs.org/symlink-or-copy/-/symlink-or-copy-1.3.1.tgz",
+ "integrity": "sha512-0K91MEXFpBUaywiwSSkmKjnGcasG/rVBXFLJz5DrgGabpYD6N+3yZrfD6uUIfpuTu65DZLHi7N8CizHc07BPZA==",
+ "dev": true
+ },
+ "node_modules/tabster": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/tabster/-/tabster-6.0.0.tgz",
+ "integrity": "sha512-Dvrzv4wG+Qjw9wmC7bKOTVXDn24h8XZLNPmc+XfuEv4pGiTxg+EZ5fp265ccqu00E2om8Wznp9jFftWVu624aQ==",
+ "dependencies": {
+ "keyborg": "2.5.0",
+ "tslib": "^2.3.1"
+ }
+ },
+ "node_modules/teex": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/teex/-/teex-1.0.1.tgz",
+ "integrity": "sha512-eYE6iEI62Ni1H8oIa7KlDU6uQBtqr4Eajni3wX7rpfXD8ysFx8z0+dri+KWEPWpBsxXfxu58x/0jvTVT1ekOSg==",
+ "dev": true,
+ "dependencies": {
+ "streamx": "^2.12.5"
+ }
+ },
+ "node_modules/terser": {
+ "version": "5.27.0",
+ "resolved": "https://registry.npmjs.org/terser/-/terser-5.27.0.tgz",
+ "integrity": "sha512-bi1HRwVRskAjheeYl291n3JC4GgO/Ty4z1nVs5AAsmonJulGxpSektecnNedrwK9C7vpvVtcX3cw00VSLt7U2A==",
+ "dev": true,
+ "optional": true,
+ "peer": true,
+ "dependencies": {
+ "@jridgewell/source-map": "^0.3.3",
+ "acorn": "^8.8.2",
+ "commander": "^2.20.0",
+ "source-map-support": "~0.5.20"
+ },
+ "bin": {
+ "terser": "bin/terser"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/terser/node_modules/commander": {
+ "version": "2.20.3",
+ "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz",
+ "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==",
+ "dev": true,
+ "optional": true,
+ "peer": true
+ },
+ "node_modules/text-table": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz",
+ "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==",
+ "dev": true
+ },
+ "node_modules/through2": {
+ "version": "2.0.5",
+ "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.5.tgz",
+ "integrity": "sha512-/mrRod8xqpA+IHSLyGCQ2s8SPHiCDEeQJSep1jqLYeEUClOFG2Qsh+4FU6G9VeqpZnGW/Su8LQGc4YKni5rYSQ==",
+ "dev": true,
+ "dependencies": {
+ "readable-stream": "~2.3.6",
+ "xtend": "~4.0.1"
+ }
+ },
+ "node_modules/to-fast-properties": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz",
+ "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/to-regex-range": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
+ "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
+ "dev": true,
+ "dependencies": {
+ "is-number": "^7.0.0"
+ },
+ "engines": {
+ "node": ">=8.0"
+ }
+ },
+ "node_modules/to-through": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/to-through/-/to-through-3.0.0.tgz",
+ "integrity": "sha512-y8MN937s/HVhEoBU1SxfHC+wxCHkV1a9gW8eAdTadYh/bGyesZIVcbjI+mSpFbSVwQici/XjBjuUyri1dnXwBw==",
+ "dev": true,
+ "dependencies": {
+ "streamx": "^2.12.5"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/tr46": {
+ "version": "0.0.3",
+ "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz",
+ "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw=="
+ },
+ "node_modules/ts-api-utils": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.0.3.tgz",
+ "integrity": "sha512-wNMeqtMz5NtwpT/UZGY5alT+VoKdSsOOP/kqHFcUW1P/VRhH2wJ48+DN2WwUliNbQ976ETwDL0Ifd2VVvgonvg==",
+ "dev": true,
+ "engines": {
+ "node": ">=16.13.0"
+ },
+ "peerDependencies": {
+ "typescript": ">=4.2.0"
+ }
+ },
+ "node_modules/tslib": {
+ "version": "2.6.2",
+ "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz",
+ "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q=="
+ },
+ "node_modules/type-check": {
+ "version": "0.4.0",
+ "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz",
+ "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==",
+ "dev": true,
+ "dependencies": {
+ "prelude-ls": "^1.2.1"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/type-fest": {
+ "version": "0.20.2",
+ "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz",
+ "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/typescript": {
+ "version": "5.3.3",
+ "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.3.3.tgz",
+ "integrity": "sha512-pXWcraxM0uxAS+tN0AG/BF2TyqmHO014Z070UsJ+pFvYuRSq8KH8DmWpnbXe0pEPDHXZV3FcAbJkijJ5oNEnWw==",
+ "dev": true,
+ "bin": {
+ "tsc": "bin/tsc",
+ "tsserver": "bin/tsserver"
+ },
+ "engines": {
+ "node": ">=14.17"
+ }
+ },
+ "node_modules/ua-parser-js": {
+ "version": "0.7.37",
+ "resolved": "https://registry.npmjs.org/ua-parser-js/-/ua-parser-js-0.7.37.tgz",
+ "integrity": "sha512-xV8kqRKM+jhMvcHWUKthV9fNebIzrNy//2O9ZwWcfiBFR5f25XVZPLlEajk/sf3Ra15V92isyQqnIEXRDaZWEA==",
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/ua-parser-js"
+ },
+ {
+ "type": "paypal",
+ "url": "https://paypal.me/faisalman"
+ },
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/faisalman"
+ }
+ ],
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/underscore.string": {
+ "version": "3.3.6",
+ "resolved": "https://registry.npmjs.org/underscore.string/-/underscore.string-3.3.6.tgz",
+ "integrity": "sha512-VoC83HWXmCrF6rgkyxS9GHv8W9Q5nhMKho+OadDJGzL2oDYbYEppBaCMH6pFlwLeqj2QS+hhkw2kpXkSdD1JxQ==",
+ "dev": true,
+ "dependencies": {
+ "sprintf-js": "^1.1.1",
+ "util-deprecate": "^1.0.2"
+ },
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/universalify": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz",
+ "integrity": "sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw==",
+ "dev": true,
+ "engines": {
+ "node": ">= 10.0.0"
+ }
+ },
+ "node_modules/update-browserslist-db": {
+ "version": "1.0.13",
+ "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.13.tgz",
+ "integrity": "sha512-xebP81SNcPuNpPP3uzeW1NYXxI3rxyJzF3pD6sH4jE7o/IX+WtSpwnVU+qIsDPyk0d3hmFQ7mjqc6AtV604hbg==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/browserslist"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/browserslist"
+ },
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/ai"
+ }
+ ],
+ "dependencies": {
+ "escalade": "^3.1.1",
+ "picocolors": "^1.0.0"
+ },
+ "bin": {
+ "update-browserslist-db": "cli.js"
+ },
+ "peerDependencies": {
+ "browserslist": ">= 4.21.0"
+ }
+ },
+ "node_modules/uri-js": {
+ "version": "4.4.1",
+ "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz",
+ "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==",
+ "dev": true,
+ "dependencies": {
+ "punycode": "^2.1.0"
+ }
+ },
+ "node_modules/use-disposable": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/use-disposable/-/use-disposable-1.0.2.tgz",
+ "integrity": "sha512-UMaXVlV77dWOu4GqAFNjRzHzowYKUKbJBQfCexvahrYeIz4OkUYUjna4Tjjdf92NH8Nm8J7wEfFRgTIwYjO5jg==",
+ "peerDependencies": {
+ "@types/react": ">=16.8.0 <19.0.0",
+ "@types/react-dom": ">=16.8.0 <19.0.0",
+ "react": ">=16.8.0 <19.0.0",
+ "react-dom": ">=16.8.0 <19.0.0"
+ }
+ },
+ "node_modules/util-deprecate": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
+ "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==",
+ "dev": true
+ },
+ "node_modules/value-or-function": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/value-or-function/-/value-or-function-4.0.0.tgz",
+ "integrity": "sha512-aeVK81SIuT6aMJfNo9Vte8Dw0/FZINGBV8BfCraGtqVxIeLAEhJyoWs8SmvRVmXfGss2PmmOwZCuBPbZR+IYWg==",
+ "dev": true,
+ "engines": {
+ "node": ">= 10.13.0"
+ }
+ },
+ "node_modules/vinyl": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-3.0.0.tgz",
+ "integrity": "sha512-rC2VRfAVVCGEgjnxHUnpIVh3AGuk62rP3tqVrn+yab0YH7UULisC085+NYH+mnqf3Wx4SpSi1RQMwudL89N03g==",
+ "dev": true,
+ "dependencies": {
+ "clone": "^2.1.2",
+ "clone-stats": "^1.0.0",
+ "remove-trailing-separator": "^1.1.0",
+ "replace-ext": "^2.0.0",
+ "teex": "^1.0.1"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/vinyl-contents": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/vinyl-contents/-/vinyl-contents-2.0.0.tgz",
+ "integrity": "sha512-cHq6NnGyi2pZ7xwdHSW1v4Jfnho4TEGtxZHw01cmnc8+i7jgR6bRnED/LbrKan/Q7CvVLbnvA5OepnhbpjBZ5Q==",
+ "dev": true,
+ "dependencies": {
+ "bl": "^5.0.0",
+ "vinyl": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/vinyl-fs": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/vinyl-fs/-/vinyl-fs-4.0.0.tgz",
+ "integrity": "sha512-7GbgBnYfaquMk3Qu9g22x000vbYkOex32930rBnc3qByw6HfMEAoELjCjoJv4HuEQxHAurT+nvMHm6MnJllFLw==",
+ "dev": true,
+ "dependencies": {
+ "fs-mkdirp-stream": "^2.0.1",
+ "glob-stream": "^8.0.0",
+ "graceful-fs": "^4.2.11",
+ "iconv-lite": "^0.6.3",
+ "is-valid-glob": "^1.0.0",
+ "lead": "^4.0.0",
+ "normalize-path": "3.0.0",
+ "resolve-options": "^2.0.0",
+ "stream-composer": "^1.0.2",
+ "streamx": "^2.14.0",
+ "to-through": "^3.0.0",
+ "value-or-function": "^4.0.0",
+ "vinyl": "^3.0.0",
+ "vinyl-sourcemap": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/vinyl-sourcemap": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/vinyl-sourcemap/-/vinyl-sourcemap-2.0.0.tgz",
+ "integrity": "sha512-BAEvWxbBUXvlNoFQVFVHpybBbjW1r03WhohJzJDSfgrrK5xVYIDTan6xN14DlyImShgDRv2gl9qhM6irVMsV0Q==",
+ "dev": true,
+ "dependencies": {
+ "convert-source-map": "^2.0.0",
+ "graceful-fs": "^4.2.10",
+ "now-and-later": "^3.0.0",
+ "streamx": "^2.12.5",
+ "vinyl": "^3.0.0",
+ "vinyl-contents": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/vinyl-sourcemap/node_modules/convert-source-map": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz",
+ "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==",
+ "dev": true
+ },
+ "node_modules/vite": {
+ "version": "5.0.12",
+ "resolved": "https://registry.npmjs.org/vite/-/vite-5.0.12.tgz",
+ "integrity": "sha512-4hsnEkG3q0N4Tzf1+t6NdN9dg/L3BM+q8SWgbSPnJvrgH2kgdyzfVJwbR1ic69/4uMJJ/3dqDZZE5/WwqW8U1w==",
+ "dev": true,
+ "dependencies": {
+ "esbuild": "^0.19.3",
+ "postcss": "^8.4.32",
+ "rollup": "^4.2.0"
+ },
+ "bin": {
+ "vite": "bin/vite.js"
+ },
+ "engines": {
+ "node": "^18.0.0 || >=20.0.0"
+ },
+ "funding": {
+ "url": "https://github.com/vitejs/vite?sponsor=1"
+ },
+ "optionalDependencies": {
+ "fsevents": "~2.3.3"
+ },
+ "peerDependencies": {
+ "@types/node": "^18.0.0 || >=20.0.0",
+ "less": "*",
+ "lightningcss": "^1.21.0",
+ "sass": "*",
+ "stylus": "*",
+ "sugarss": "*",
+ "terser": "^5.4.0"
+ },
+ "peerDependenciesMeta": {
+ "@types/node": {
+ "optional": true
+ },
+ "less": {
+ "optional": true
+ },
+ "lightningcss": {
+ "optional": true
+ },
+ "sass": {
+ "optional": true
+ },
+ "stylus": {
+ "optional": true
+ },
+ "sugarss": {
+ "optional": true
+ },
+ "terser": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/vite-plugin-svgr": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/vite-plugin-svgr/-/vite-plugin-svgr-4.2.0.tgz",
+ "integrity": "sha512-SC7+FfVtNQk7So0XMjrrtLAbEC8qjFPifyD7+fs/E6aaNdVde6umlVVh0QuwDLdOMu7vp5RiGFsB70nj5yo0XA==",
+ "dev": true,
+ "dependencies": {
+ "@rollup/pluginutils": "^5.0.5",
+ "@svgr/core": "^8.1.0",
+ "@svgr/plugin-jsx": "^8.1.0"
+ },
+ "peerDependencies": {
+ "vite": "^2.6.0 || 3 || 4 || 5"
+ }
+ },
+ "node_modules/void-elements": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/void-elements/-/void-elements-3.1.0.tgz",
+ "integrity": "sha512-Dhxzh5HZuiHQhbvTW9AMetFfBHDMYpo23Uo9btPXgdYP+3T5S+p+jgNy7spra+veYhBP2dCSgxR/i2Y02h5/6w==",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/vue-template-compiler": {
+ "version": "2.7.16",
+ "resolved": "https://registry.npmjs.org/vue-template-compiler/-/vue-template-compiler-2.7.16.tgz",
+ "integrity": "sha512-AYbUWAJHLGGQM7+cNTELw+KsOG9nl2CnSv467WobS5Cv9uk3wFcnr1Etsz2sEIHEZvw1U+o9mRlEO6QbZvUPGQ==",
+ "dev": true,
+ "dependencies": {
+ "de-indent": "^1.0.2",
+ "he": "^1.2.0"
+ }
+ },
+ "node_modules/walk-sync": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/walk-sync/-/walk-sync-2.2.0.tgz",
+ "integrity": "sha512-IC8sL7aB4/ZgFcGI2T1LczZeFWZ06b3zoHH7jBPyHxOtIIz1jppWHjjEXkOFvFojBVAK9pV7g47xOZ4LW3QLfg==",
+ "dev": true,
+ "dependencies": {
+ "@types/minimatch": "^3.0.3",
+ "ensure-posix-path": "^1.1.0",
+ "matcher-collection": "^2.0.0",
+ "minimatch": "^3.0.4"
+ },
+ "engines": {
+ "node": "8.* || >= 10.*"
+ }
+ },
+ "node_modules/walk-sync/node_modules/brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "dependencies": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "node_modules/walk-sync/node_modules/minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dev": true,
+ "dependencies": {
+ "brace-expansion": "^1.1.7"
+ },
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/webidl-conversions": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz",
+ "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ=="
+ },
+ "node_modules/whatwg-url": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz",
+ "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==",
+ "dependencies": {
+ "tr46": "~0.0.3",
+ "webidl-conversions": "^3.0.0"
+ }
+ },
+ "node_modules/which": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
+ "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==",
+ "dev": true,
+ "dependencies": {
+ "isexe": "^2.0.0"
+ },
+ "bin": {
+ "node-which": "bin/node-which"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/wrap-ansi": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
+ "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.0.0",
+ "string-width": "^4.1.0",
+ "strip-ansi": "^6.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/wrap-ansi?sponsor=1"
+ }
+ },
+ "node_modules/wrap-ansi/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/wrap-ansi/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/wrap-ansi/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/wrappy": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
+ "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==",
+ "dev": true
+ },
+ "node_modules/xtend": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz",
+ "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.4"
+ }
+ },
+ "node_modules/y18n": {
+ "version": "5.0.8",
+ "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz",
+ "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/yallist": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz",
+ "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==",
+ "dev": true
+ },
+ "node_modules/yargs": {
+ "version": "17.7.2",
+ "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz",
+ "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==",
+ "dev": true,
+ "dependencies": {
+ "cliui": "^8.0.1",
+ "escalade": "^3.1.1",
+ "get-caller-file": "^2.0.5",
+ "require-directory": "^2.1.1",
+ "string-width": "^4.2.3",
+ "y18n": "^5.0.5",
+ "yargs-parser": "^21.1.1"
+ },
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/yargs-parser": {
+ "version": "21.1.1",
+ "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz",
+ "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==",
+ "dev": true,
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/yocto-queue": {
+ "version": "0.1.0",
+ "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz",
+ "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ }
+ }
+}
diff --git a/package.json b/package.json
new file mode 100644
index 0000000000000000000000000000000000000000..b9d120c2471fee033baa2f5adf749269094b885a
--- /dev/null
+++ b/package.json
@@ -0,0 +1,49 @@
+{
+ "name": "frontend",
+ "private": true,
+ "version": "0.0.0",
+ "type": "module",
+ "scripts": {
+ "dev": "vite",
+ "build": "tsc && vite build --mode production",
+ "lint": "eslint . --ext ts,tsx --report-unused-disable-directives --max-warnings 0",
+ "preview": "vite preview",
+ "i18n:extract": "npx i18next-parser",
+ "format": "prettier --write .",
+ "format:check": "prettier --check ."
+ },
+ "dependencies": {
+ "@auth0/auth0-react": "^2.2.4",
+ "@fluentui/react": "^8.115.5",
+ "@fluentui/react-components": "^9.46.3",
+ "@fluentui/react-icons": "^2.0.226",
+ "axios": "^1.6.7",
+ "date-fns": "^3.3.1",
+ "draft-js": "^0.11.7",
+ "i18next": "^23.8.2",
+ "i18next-browser-languagedetector": "^7.2.0",
+ "i18next-http-backend": "^2.4.3",
+ "prettier": "^3.2.4",
+ "react": "^18.2.0",
+ "react-country-flag": "^3.1.0",
+ "react-dom": "^18.2.0",
+ "react-highlight-within-textarea": "^3.2.1",
+ "react-i18next": "^14.0.1",
+ "react-router-dom": "^6.21.3"
+ },
+ "devDependencies": {
+ "@flydotio/dockerfile": "^0.5.2",
+ "@types/react": "^18.2.43",
+ "@types/react-dom": "^18.2.17",
+ "@typescript-eslint/eslint-plugin": "^6.14.0",
+ "@typescript-eslint/parser": "^6.20.0",
+ "@vitejs/plugin-react": "^4.2.1",
+ "eslint": "^8.55.0",
+ "eslint-plugin-react-hooks": "^4.6.0",
+ "eslint-plugin-react-refresh": "^0.4.5",
+ "i18next-parser": "^8.12.0",
+ "typescript": "^5.2.2",
+ "vite": "^5.0.8",
+ "vite-plugin-svgr": "^4.2.0"
+ }
+}
diff --git a/public/favicon.ico b/public/favicon.ico
new file mode 100644
index 0000000000000000000000000000000000000000..5e64e8cec19062cac63b31f621cde21bfde855ce
Binary files /dev/null and b/public/favicon.ico differ
diff --git a/public/images/android-chrome-192x192.png b/public/images/android-chrome-192x192.png
new file mode 100644
index 0000000000000000000000000000000000000000..91e145b3f4e6255fa98ae83cdeb1d836d21804cd
Binary files /dev/null and b/public/images/android-chrome-192x192.png differ
diff --git a/public/images/android-chrome-512x512.png b/public/images/android-chrome-512x512.png
new file mode 100644
index 0000000000000000000000000000000000000000..9835e0f8d1513db2f9e6d2abd525d91be4901897
Binary files /dev/null and b/public/images/android-chrome-512x512.png differ
diff --git a/public/images/apple-touch-icon.png b/public/images/apple-touch-icon.png
new file mode 100644
index 0000000000000000000000000000000000000000..4681225ede4a8009c4e5a253d52d4064e2d4a048
Binary files /dev/null and b/public/images/apple-touch-icon.png differ
diff --git a/public/images/favicon-16x16.png b/public/images/favicon-16x16.png
new file mode 100644
index 0000000000000000000000000000000000000000..c9b4554274b6b0834ca12683cb0d50aed172d9e7
Binary files /dev/null and b/public/images/favicon-16x16.png differ
diff --git a/public/images/favicon-32x32.png b/public/images/favicon-32x32.png
new file mode 100644
index 0000000000000000000000000000000000000000..c84e6996a5860e0a61435f006ee5b7a45ca15dd9
Binary files /dev/null and b/public/images/favicon-32x32.png differ
diff --git a/public/locales/de/translation.json b/public/locales/de/translation.json
new file mode 100644
index 0000000000000000000000000000000000000000..6a49c8a4f208aaba45bd346da1e8eedda21675eb
--- /dev/null
+++ b/public/locales/de/translation.json
@@ -0,0 +1,86 @@
+{
+ "guideCardStep1Title": "Daten hochladen",
+ "guideCardStep1Content": "Wähle Dateien aus oder lade sie hoch.",
+ "guideCardStep2Title": "Raum erstellen",
+ "guideCardStep2Content": "Richte einen Raum für deine Dateien ein.",
+ "guideCardStep3Title": "Fragen stellen",
+ "guideCardStep3Content": "Erhalte Antworten zu deinen Dokumenten.",
+ "guideCardDemoLinkText": "... oder probiere die Demo aus!",
+ "unexpectedErrorOccurred": "Ein unerwarteter Fehler ist aufgetreten",
+ "errorfetchingFiles": "Fehler beim Abrufen der Dateien",
+ "fileUploadSuccess": "Dateien erfolgreich hochgeladen",
+ "errorUploadingFiles": "Fehler beim hochladen der Dateien",
+ "filesDeletedSuccess": "Dateien erfolgreich entfernt",
+ "errorDeletingFiles": "Fehler beim Entfernen der Dateien",
+ "fileExplorerDialogButton": "Dateien",
+ "fileExplorerTitle": "Deine Dateien",
+ "nextCloudButtonSub": "Verbinden mit Nextcloud",
+ "nextCloudButton": "Nextcloud",
+ "loading": "Lade...",
+ "deleteSelectedFiles": "Löschen",
+ "dialogCloseButton": "Schließen",
+ "uploadButtonSub": "Manuell Dateien hochladen",
+ "uploadButton": "Hochladen",
+ "file": "Datei",
+ "language": "Sprache",
+ "fileSize": "Dateigröße",
+ "uploadedAt": "Hochgeladen am",
+ "FileSelectorTitle": "Wähle deine Dateien aus...",
+ "fileSelectorSelectButton": "Auswählen",
+ "errorSavingLanguage": "Fehler beim Speichern der Sprache",
+ "login": "Anmelden",
+ "chatGPTRoleName": "ChatGPT",
+ "trialOverMessage": "Ihre Testversion ist abgelaufen.",
+ "resultRoleName": "Antworten",
+ "searchMessageIntroText": "Hier finden Sie relevante Auszüge aus Ihren Dokumenten, die potenziell Antwort auf Ihre Frage geben könnten.",
+ "searchMessageStatText": "Ergebnis {{index}} aus \"{{filename}}\" mit einer Genauigkeit von {{accuracy}}%",
+ "searchMessageIntroHint": "Bitte stellen Sie sicher, dass alle sensiblen Informationen bereits identifiziert und entsprechend pseudonymisiert wurden, bevor Sie fortfahren.",
+ "cancelEditResultsButton": "Verwerfen",
+ "save": "Speichern",
+ "editResultsButton": "Bearbeiten",
+ "sendToChatGPTButton": "Senden",
+ "chatGPTSendHint": "Ãœbermittelt Frage und Antworten pseudonymisiert an ChatGPT.",
+ "renameRoom": "Raum umbenennen",
+ "deleteRoom": "Raum löschen",
+ "errorFetchingRooms": "Fehler beim Abrufen der Räume",
+ "roomCreatedSuccessfully": "Raum erfolgreich erstellt",
+ "errorCreateRoom": "Fehler beim Erstellen des Raums",
+ "roomRenamedSuccessfully": "Raum erfolgreich umbenannt",
+ "errorRenameRoom": "Fehler beim Umbenennen des Raums",
+ "roomDeletedSuccessfully": "Raum erfolgreich gelöscht",
+ "errorDeleteRoom": "Fehler beim Löschen des Raums",
+ "createRoomButton": "Raum erstellen",
+ "roomNamePlaceholder": "Neuer Raumname...",
+ "settingsDrawerTitle": "Raum Einstellungen",
+ "promptTemplateLabel": "Prompt",
+ "promptTemplateSelectLabel": "Prompt Templates",
+ "promptTemplateOptionDE": "Prompt Template Deutsch",
+ "promptTemplateOptionEN": "Prompt Template Englisch",
+ "resultSentenceCountLabel": "Anzahl der Sätze vor und nach einem Ergebnis",
+ "actionSuccessful": "Aktion erfolgreich",
+ "actionFailed": "Aktion fehlgeschlagen",
+ "actionWarning": "Warnung",
+ "actionNotice": "Hinweis",
+ "tutorialCardsSubtitle": "Erstelle einen Raum und frage deine Dokumente",
+ "errorNoRoom": "Dieser Raum existiert nicht",
+ "errorUpdatingRoomDocuments": "Fehler beim Auswählen der Dateien",
+ "errorSendingMessage": "Fehler beim Senden der Nachricht",
+ "errorNotEnoughMessages": "Fehlende Nachrichten zum fortfahren",
+ "question": "Frage",
+ "context": "Kontext",
+ "errorSendingMessageToChatGPT": "Fehler beim Senden der Nachricht zu ChatGPT",
+ "isAnonymizedText": "Pseudonymisiert",
+ "isNotAnonymizedText": "Nicht Pseudonymisiert",
+ "exampleCardsSubtitle": "Testen Sie eine Beispielanfrage anhand der bereitgestellten Beispieldokumente",
+ "headerText": "ChatGPTfirewall",
+ "subheaderText": "Logge dich ein um ChatGPTfirewall auszuprobieren",
+ "documentation": "Dokumentation",
+ "landingPage": "Start",
+ "githubRepo": "Github",
+ "errorFetchingRoom": "Fehler beim Abrufen des Raums",
+ "settingsSavedSuccessfully": "Einstellungen erfolgreich gespeichert",
+ "errorSavingSettings": "Fehler beim Speichern der Einstellungen",
+ "emptyStateBodyTextStrong": "Keine Dateien ausgewählt",
+ "emptyStateBodyText": "Bitte wählen Sie die Dateien aus, die Sie für den Chat verwenden möchten.",
+ "addFilesEmptyPage": "Dateien auswählen"
+}
diff --git a/public/locales/de/translation_old.json b/public/locales/de/translation_old.json
new file mode 100644
index 0000000000000000000000000000000000000000..bdff6c378564f9bbcfdefda2ac8561382d4aea5b
--- /dev/null
+++ b/public/locales/de/translation_old.json
@@ -0,0 +1,37 @@
+{
+ "1": {
+ " Upload your data or select it via your Cloud": ""
+ },
+ "2": {
+ " Ask questions that your data can answer": ""
+ },
+ "You can try out the demo": "",
+ "loginAndAskAnything": "",
+ "Logout": "Ausloggen",
+ "Login": "Einloggen",
+ "card1Upload": "",
+ "card2Ask": "",
+ "orText": "",
+ "card3Demo": "",
+ "logout": "Ausloggen",
+ "File": "",
+ "Language": "",
+ "File Size": "",
+ "tutorialCardStep1": "1. Laden Sie Ihre Daten hoch oder wählen Sie sie über Ihre Cloud aus",
+ "tutorialCardStep2": "2. Stellen Sie Fragen, die Ihre Daten beantworten können",
+ "tutorialCardDemoLink": "Sie können die Demo ausprobieren",
+ "or": "oder",
+ "guideCardDemoTitle": "Demo ausprobieren",
+ "guideCardDemoContent": "Nutze die Demo-Seite, um ein vorgefertigtes Beispiel mit Dateien und Fragen zu sehen.",
+ "guideCardDemoText": "",
+ "uploading": "Lade hoch...",
+ "uploadSuccess": "Upload erfolgreich",
+ "uploadError": "Upload fehlgeschlagen",
+ "demoPageChatWithData": "Demo Seite: Chatten Sie mit Ihren Daten",
+ "errorNoRoomSelected": "Es wurde kein Ru",
+ "errorNoFilesSelected": "",
+ "updatingRoomDocumentsSuccessfully": "",
+ "saveEditResultsButton": "Speichern",
+ "saveSettings": "Speichern",
+ "chatWithYourData": ""
+}
diff --git a/public/locales/en/translation.json b/public/locales/en/translation.json
new file mode 100644
index 0000000000000000000000000000000000000000..bd1c761ad4406db044956b3c261dce52e396bb8a
--- /dev/null
+++ b/public/locales/en/translation.json
@@ -0,0 +1,86 @@
+{
+ "guideCardStep1Title": "Upload Data",
+ "guideCardStep1Content": "Choose or upload files.",
+ "guideCardStep2Title": "Create Room",
+ "guideCardStep2Content": "Set up a room for your files.",
+ "guideCardStep3Title": "Ask Questions",
+ "guideCardStep3Content": "Get answers about your documents.",
+ "guideCardDemoLinkText": "...or test the demo!",
+ "unexpectedErrorOccurred": "An unexpected error occurred",
+ "errorfetchingFiles": "Error fetching files",
+ "fileUploadSuccess": "Files uploaded successfully",
+ "errorUploadingFiles": "Error uploading files",
+ "filesDeletedSuccess": "Files deleted successfully",
+ "errorDeletingFiles": "Error deleting files",
+ "fileExplorerDialogButton": "Files",
+ "fileExplorerTitle": "Your Files",
+ "nextCloudButtonSub": "Connect with Nextcloud",
+ "nextCloudButton": "Nextcloud",
+ "loading": "Loading...",
+ "deleteSelectedFiles": "Delete",
+ "dialogCloseButton": "Close",
+ "uploadButtonSub": "Upload files manually",
+ "uploadButton": "Upload",
+ "file": "File",
+ "language": "Language",
+ "fileSize": "File Size",
+ "uploadedAt": "Uploaded at",
+ "FileSelectorTitle": "Select your files...",
+ "fileSelectorSelectButton": "Select",
+ "errorSavingLanguage": "Error while saving language",
+ "login": "Login",
+ "chatGPTRoleName": "ChatGPT",
+ "trialOverMessage": "Your trial is over.",
+ "resultRoleName": "Answers",
+ "searchMessageIntroText": "Below are excerpts from your documents that may potentially answer your question.",
+ "searchMessageStatText": "Result {{index}} from \"{{filename}}\" with {{accuracy}}% accuracy.",
+ "searchMessageIntroHint": "Please ensure that all sensitive data have been identified and appropriately pseudonymized before proceeding.",
+ "cancelEditResultsButton": "Discard",
+ "save": "Save",
+ "editResultsButton": "Edit",
+ "sendToChatGPTButton": "Send",
+ "chatGPTSendHint": "Submits question and answers in pseudonymized form to ChatGPT.",
+ "renameRoom": "Rename Room",
+ "deleteRoom": "Delete Room",
+ "errorFetchingRooms": "Error fetching rooms",
+ "roomCreatedSuccessfully": "Room created successfully",
+ "errorCreateRoom": "Error creating room",
+ "roomRenamedSuccessfully": "Room renamed successfully",
+ "errorRenameRoom": "Error renaming room",
+ "roomDeletedSuccessfully": "Room deleted successfully",
+ "errorDeleteRoom": "Error deleting room",
+ "createRoomButton": "Create Room",
+ "roomNamePlaceholder": "New Roomname...",
+ "settingsDrawerTitle": "Room Settings",
+ "promptTemplateLabel": "Prompt",
+ "promptTemplateSelectLabel": "Prompt Templates",
+ "promptTemplateOptionDE": "Prompt Template German",
+ "promptTemplateOptionEN": "Prompt Template English",
+ "resultSentenceCountLabel": "Number of sentences before and after the result",
+ "actionSuccessful": "Action successful",
+ "actionFailed": "Action failed",
+ "actionWarning": "Warning",
+ "actionNotice": "Notice",
+ "tutorialCardsSubtitle": "Create a room and ask your documents",
+ "errorNoRoom": "This room doesn't exist",
+ "errorUpdatingRoomDocuments": "Error while selecting files",
+ "errorSendingMessage": "Error while sending message",
+ "errorNotEnoughMessages": "Missing messages to continue",
+ "question": "Question",
+ "context": "Context",
+ "errorSendingMessageToChatGPT": "Error while sending message to ChatGPT",
+ "isAnonymizedText": "Pseudonymized",
+ "isNotAnonymizedText": "Not Pseudonymized",
+ "exampleCardsSubtitle": "Try out a sample query using the provided example documents.",
+ "headerText": "ChatGPTfirewall",
+ "subheaderText": "Log in to start your session with ChatGPTFirewall.",
+ "documentation": "Documentation",
+ "landingPage": "Home",
+ "githubRepo": "Github",
+ "errorFetchingRoom": "Error fetching room",
+ "settingsSavedSuccessfully": "Settings saved successfully",
+ "errorSavingSettings": "Error while saving settings",
+ "emptyStateBodyTextStrong": "No Files Selected",
+ "emptyStateBodyText": "Please select the files you wish to use for chatting.",
+ "addFilesEmptyPage": "Select Files"
+}
diff --git a/public/locales/en/translation_old.json b/public/locales/en/translation_old.json
new file mode 100644
index 0000000000000000000000000000000000000000..3f4658af98c859d7764a341fb291b3fb25f683da
--- /dev/null
+++ b/public/locales/en/translation_old.json
@@ -0,0 +1,38 @@
+{
+ "1": {
+ " Upload your data or select it via your Cloud": ""
+ },
+ "2": {
+ " Ask questions that your data can answer": ""
+ },
+ "You can try out the demo": "",
+ "loginAndAskAnything": "",
+ "Logout": "",
+ "Login": "",
+ "Login and ask anything": "",
+ "card1Upload": "",
+ "card2Ask": "",
+ "orText": "",
+ "card3Demo": "",
+ "logout": "Logout",
+ "File": "",
+ "Language": "",
+ "File Size": "",
+ "tutorialCardStep1": "1. Upload your data or select it via your Cloud",
+ "tutorialCardStep2": "2. Ask questions that your data can answer",
+ "tutorialCardDemoLink": "You can try out the demo",
+ "or": "or",
+ "guideCardDemoTitle": "Try the Demo",
+ "guideCardDemoContent": "Use the demo page to see a pre-selected example with files and questions.",
+ "guideCardDemoText": "",
+ "uploading": "Loading...",
+ "uploadSuccess": "Upload successful",
+ "uploadError": "Upload failed",
+ "demoPageChatWithData": "Demo Page: Chat with your data",
+ "errorNoRoomSelected": "",
+ "errorNoFilesSelected": "",
+ "updatingRoomDocumentsSuccessfully": "",
+ "saveEditResultsButton": "Save",
+ "saveSettings": "",
+ "chatWithYourData": ""
+}
diff --git a/src/App.tsx b/src/App.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..04cb199eb5b3eac3e2c8d3cd1f892d8876e7fc4b
--- /dev/null
+++ b/src/App.tsx
@@ -0,0 +1,30 @@
+import { BrowserRouter as Router, Routes, Route } from 'react-router-dom';
+
+import Layout from './pages/Layout/Layout';
+import Demo from './pages/Demo/Demo';
+import Chat from './pages/Chat/Chat';
+import Room from './pages/Room/Room';
+import Page404 from './pages/Page404/Page404';
+import ProtectedRoute from './components/common/ProtectedRoute/ProtectedRoute';
+
+function App() {
+ return (
+
+
+ }>
+ }>
+ } />
+ } />
+
+ } />
+ } />
+
+
+ } />
+
+
+
+ );
+}
+
+export default App;
diff --git a/src/api/Request.ts b/src/api/Request.ts
new file mode 100644
index 0000000000000000000000000000000000000000..aab25ef325c5aa2af75a31eaf977ba42c3d1ff69
--- /dev/null
+++ b/src/api/Request.ts
@@ -0,0 +1,28 @@
+import axios, { AxiosRequestConfig, AxiosResponse } from 'axios';
+
+async function Request(config: AxiosRequestConfig): Promise {
+ try {
+ // Accessing token for subsequent requests
+ const token = localStorage.getItem('userToken');
+ if (token == null) {
+ console.group('get token');
+ } else {
+ axios.defaults.headers.common['Authorization'] = `Bearer ${token}`;
+ }
+ const response: AxiosResponse = await axios(config);
+ return response.data;
+ } catch (error) {
+ if (axios.isAxiosError(error)) {
+ console.error(
+ `API call failed with status: ${error.response?.status}`,
+ error.message
+ );
+ throw new Error(`API call failed: ${error.response?.status}`);
+ } else {
+ console.error('An unexpected error occurred', error);
+ throw error;
+ }
+ }
+}
+
+export default Request;
diff --git a/src/api/fetchAPI.ts b/src/api/fetchAPI.ts
new file mode 100644
index 0000000000000000000000000000000000000000..8097ba225ce929d590f7de33159d40c8d4869154
--- /dev/null
+++ b/src/api/fetchAPI.ts
@@ -0,0 +1,23 @@
+async function fetchAPI(
+ url: string,
+ method: 'GET' | 'POST' | 'PUT' | 'DELETE' = 'POST',
+ body?: TBody,
+ headers?: HeadersInit
+): Promise {
+ const response = await fetch(url, {
+ method,
+ headers: {
+ 'Content-Type': 'application/json',
+ ...headers
+ },
+ body: JSON.stringify(body)
+ });
+
+ if (!response.ok) {
+ throw new Error(`HTTP error! Status: ${response.status}`);
+ }
+
+ return response.json() as TResponse;
+}
+
+export default fetchAPI;
diff --git a/src/api/fileApi.ts b/src/api/fileApi.ts
new file mode 100644
index 0000000000000000000000000000000000000000..341875b52f09a037cdc6efc5303d8f5f6f4729ff
--- /dev/null
+++ b/src/api/fileApi.ts
@@ -0,0 +1,35 @@
+import Request from './Request';
+import { File } from '../models/File';
+
+export async function getFiles(auth0_id: string): Promise {
+ return Request({
+ url: '/api/documents',
+ method: 'POST',
+ headers: {
+ 'Content-Type': 'application/json'
+ },
+ data: JSON.stringify({
+ auth0_id: auth0_id
+ })
+ });
+}
+
+export const getFile = (documentID: string): Promise => {
+ return Request({ url: `/api/documents/${documentID}`, method: 'GET' });
+};
+
+export async function createFiles(data: FormData): Promise {
+ return Request({
+ url: '/api/documents/upload',
+ method: 'POST',
+ data: data
+ });
+}
+
+export function deleteFiles(fileIds: string[]): Promise {
+ return Request({
+ url: '/api/documents',
+ method: 'DELETE',
+ data: fileIds
+ });
+}
diff --git a/src/api/messageApi.ts b/src/api/messageApi.ts
new file mode 100644
index 0000000000000000000000000000000000000000..7585e02a53812eb208222fc9753f28ca867e6149
--- /dev/null
+++ b/src/api/messageApi.ts
@@ -0,0 +1,24 @@
+import { Message } from '../models/Message';
+import Request from './Request';
+
+export const createSearchMessage = (message: Message): Promise => {
+ return Request({
+ url: '/api/messages/search',
+ method: 'POST',
+ data: message
+ });
+};
+
+export const createChatGPTMessage = (
+ message: Message,
+ demo?: boolean
+): Promise => {
+ const baseUrl = '/api/messages/chatgpt';
+ const url = demo ? `${baseUrl}?demo=true` : baseUrl;
+
+ return Request({
+ url: url,
+ method: 'POST',
+ data: message
+ });
+};
diff --git a/src/api/roomsApi.ts b/src/api/roomsApi.ts
new file mode 100644
index 0000000000000000000000000000000000000000..a2b2f4f2fc0bbf607041b5f1cbbb7202b97c8b1c
--- /dev/null
+++ b/src/api/roomsApi.ts
@@ -0,0 +1,47 @@
+import { Room } from '../models/Room';
+import Request from './Request';
+
+export const getRooms = (userAuth0Id: string): Promise => {
+ return Request({
+ url: `/api/rooms?user_auth0_id=${userAuth0Id}`,
+ method: 'GET'
+ });
+};
+
+export const getRoom = (roomId: string): Promise => {
+ return Request({ url: `/api/rooms/${roomId}/`, method: 'GET' });
+};
+
+export const createRoom = (
+ user_auth0_id: string,
+ room_name: string
+): Promise => {
+ return Request({
+ url: '/api/rooms',
+ method: 'POST',
+ data: { user_auth0_id: user_auth0_id, room_name: room_name }
+ });
+};
+
+export const updateRoom = (room: Room): Promise => {
+ return Request({
+ url: `/api/rooms/${room.id}/`,
+ method: 'PUT',
+ data: room
+ });
+};
+
+export const updateRoomFiles = (
+ roomId: string,
+ documentIds: string[]
+): Promise => {
+ return Request({
+ url: `/api/rooms/${roomId}/documents/`,
+ method: 'POST',
+ data: { document_ids: documentIds }
+ });
+};
+
+export const deleteRoom = (roomId: string): Promise => {
+ return Request({ url: `/api/rooms/${roomId}/`, method: 'DELETE' });
+};
diff --git a/src/api/usersApi.ts b/src/api/usersApi.ts
new file mode 100644
index 0000000000000000000000000000000000000000..6b87379d4320832c1635469eb35a37f861658604
--- /dev/null
+++ b/src/api/usersApi.ts
@@ -0,0 +1,18 @@
+import { User } from '../models/User';
+import Request from './Request';
+
+export const getUser = async (auth0_id: string): Promise => {
+ return Request({ url: `/api/user/${auth0_id}/`, method: 'GET' });
+};
+
+export const createUser = async (user: User): Promise => {
+ return Request({ url: '/api/user/', method: 'POST', data: user });
+};
+
+export const updateUser = async (user: User): Promise => {
+ return Request({
+ url: `/api/user/${user.auth0_id}/`,
+ method: 'PUT',
+ data: user
+ });
+};
diff --git a/src/components/common/Cards/CustomCard.tsx b/src/components/common/Cards/CustomCard.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..3dc3bff0eb4306a2d10cc677fb3ebec424136f5a
--- /dev/null
+++ b/src/components/common/Cards/CustomCard.tsx
@@ -0,0 +1,34 @@
+import { Divider } from '@fluentui/react-components';
+import CustomCardStyles from './CustomCardStyles';
+
+interface CustomCardProps {
+ title?: string;
+ step?: string;
+ value?: string;
+ onClick?: (value?: string) => void;
+ children?: React.ReactNode;
+}
+
+const CustomCard = ({
+ step,
+ title,
+ value,
+ onClick,
+ children
+}: CustomCardProps) => {
+ const styles = CustomCardStyles();
+ return (
+
+ );
+};
+
+export default CustomCard;
diff --git a/src/components/common/Cards/CustomCardStyles.tsx b/src/components/common/Cards/CustomCardStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..e240091c22c7aec9fc6f400132ff6df611bd3808
--- /dev/null
+++ b/src/components/common/Cards/CustomCardStyles.tsx
@@ -0,0 +1,52 @@
+import { makeStyles, tokens, shorthands } from '@fluentui/react-components';
+
+const CustomCardStyles = makeStyles({
+ guideCard: {
+ boxShadow: tokens.shadow16,
+ width: '250px',
+ minHeight: '100px',
+ display: 'flex',
+ flexDirection: 'column',
+ ...shorthands.margin(tokens.spacingVerticalXL, tokens.spacingHorizontalXL),
+ ...shorthands.padding(tokens.spacingVerticalL, tokens.spacingHorizontalL),
+ ...shorthands.borderRadius(tokens.borderRadiusLarge),
+ ':hover': {
+ boxShadow: tokens.shadow28,
+ '& .step': {
+ backgroundColor: tokens.colorBrandBackground,
+ color: tokens.colorNeutralBackground1
+ }
+ }
+ },
+ step: {
+ ...shorthands.padding(
+ tokens.spacingVerticalXXS,
+ tokens.spacingHorizontalXXS
+ ),
+ fontSize: tokens.fontSizeBase600,
+ fontWeight: tokens.fontWeightBold,
+ color: tokens.colorBrandBackground,
+ backgroundColor: tokens.colorNeutralBackground1,
+ ...shorthands.borderRadius(tokens.borderRadiusCircular),
+ width: '32px',
+ height: '32px',
+ display: 'flex',
+ justifyContent: 'center',
+ alignItems: 'center',
+ marginRight: tokens.spacingHorizontalM
+ },
+ title: {
+ fontSize: tokens.fontSizeBase500,
+ fontWeight: tokens.fontWeightSemibold
+ },
+ content: {
+ fontSize: tokens.fontSizeBase400,
+ ...shorthands.margin(tokens.spacingVerticalS, 0)
+ },
+ header: {
+ display: 'flex',
+ alignItems: 'center'
+ }
+});
+
+export default CustomCardStyles;
diff --git a/src/components/common/Cards/ExampleCards/ExampleCards.tsx b/src/components/common/Cards/ExampleCards/ExampleCards.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..7aa8b9ec6b3972a96af23ce1a232410b15e39c25
--- /dev/null
+++ b/src/components/common/Cards/ExampleCards/ExampleCards.tsx
@@ -0,0 +1,64 @@
+import { useTranslation } from 'react-i18next';
+import CustomCard from '../CustomCard';
+import ExampleCardsStyles from './ExampleCardsStyles';
+
+export type Example = {
+ text: string;
+ value: string;
+};
+
+const EXAMPLES_DE: Example[] = [
+ {
+ text: 'Was ist auf der Weinversteigerung in Trier passiert?',
+ value: 'Was ist auf der Weinversteigerung in Trier passiert?'
+ },
+ {
+ text: 'Worüber ist der Edelmann E erbost?',
+ value: 'Worüber ist der Edelmann E erbost??'
+ },
+ {
+ text: 'Warum wurde B die Einreise in die USA verweigert?',
+ value: 'Warum wurde B die Einreise in die USA verweigert?'
+ }
+];
+
+const EXAMPLES_EN: Example[] = [
+ {
+ text: 'What did Detective Miller discover?',
+ value: 'What did Detective Miller discover?'
+ },
+ {
+ text: 'What stories does Willow have?',
+ value: 'What stories does Willow have?'
+ },
+ {
+ text: "How many people were in Max's group? ",
+ value: "How many people were in Max's group?"
+ }
+];
+
+interface ExampleCardsProps {
+ onExampleClicked: (value?: string) => void;
+}
+
+export const ExampleCards = ({ onExampleClicked }: ExampleCardsProps) => {
+ const styles = ExampleCardsStyles();
+ const { i18n } = useTranslation();
+ const examples = i18n.language === 'de' ? EXAMPLES_DE : EXAMPLES_EN;
+ return (
+
+ {examples.map((example, i) => (
+
+ {example.text}
+
+ ))}
+
+ );
+};
+
+export default ExampleCards;
diff --git a/src/components/common/Cards/ExampleCards/ExampleCardsStyles.tsx b/src/components/common/Cards/ExampleCards/ExampleCardsStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..b066fd91cb502da1ba3a9a41461e006ea39f7bc9
--- /dev/null
+++ b/src/components/common/Cards/ExampleCards/ExampleCardsStyles.tsx
@@ -0,0 +1,29 @@
+import { makeStyles, tokens, shorthands } from '@fluentui/react-components';
+
+const ExampleCardsStyles = makeStyles({
+ container: {
+ display: 'flex',
+ flexDirection: 'column'
+ },
+ examplesCardList: {
+ display: 'flex',
+ flexWrap: 'wrap',
+ ...shorthands.gap('10px'),
+
+ justifyContent: 'center'
+ },
+ demoTextContainer: {
+ textAlign: 'center', // Zentriert den Text und den Link
+ marginTop: tokens.spacingVerticalM, // Gibt etwas Abstand nach oben
+ marginBottom: tokens.spacingVerticalM // Gibt etwas Abstand nach unten
+ },
+ demoLink: {
+ fontSize: tokens.fontSizeBase400, // Etwas größere Schrift für den Link
+ fontWeight: tokens.fontWeightSemibold, // Macht den Link fett
+ color: tokens.colorBrandBackground, // Farbe für den Link, nutze Brand-Farben für Klickbarkeit
+ ...shorthands.margin(tokens.spacingVerticalS, 0),
+ paddingBottom: '65px'
+ }
+});
+
+export default ExampleCardsStyles;
diff --git a/src/components/common/Cards/GuideCards/GuideCards.tsx b/src/components/common/Cards/GuideCards/GuideCards.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..5b016d83e9c164de38223b21334f627d40c002aa
--- /dev/null
+++ b/src/components/common/Cards/GuideCards/GuideCards.tsx
@@ -0,0 +1,32 @@
+import { Link } from 'react-router-dom';
+import { useTranslation } from 'react-i18next';
+import CustomCard from '../CustomCard';
+import GuideCardsStyles from './GuideCardsStyles';
+
+const GuideCards = () => {
+ const styles = GuideCardsStyles();
+ const { t } = useTranslation();
+
+ return (
+
+
+
+ {t('guideCardStep1Content')}
+
+
+ {t('guideCardStep2Content')}
+
+
+ {t('guideCardStep3Content')}
+
+
+
+
+ {t('guideCardDemoLinkText')}
+
+
+
+ );
+};
+
+export default GuideCards;
diff --git a/src/components/common/Cards/GuideCards/GuideCardsStyles.tsx b/src/components/common/Cards/GuideCards/GuideCardsStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..a9217f577a3e5a5e3e89a3df717093419adcec98
--- /dev/null
+++ b/src/components/common/Cards/GuideCards/GuideCardsStyles.tsx
@@ -0,0 +1,28 @@
+import { makeStyles, tokens, shorthands } from '@fluentui/react-components';
+
+const GuideCardsStyles = makeStyles({
+ container: {
+ display: 'flex',
+ flexDirection: 'column'
+ },
+ guideCardList: {
+ display: 'flex',
+ flexWrap: 'wrap',
+ ...shorthands.gap('10px'),
+ justifyContent: 'center'
+ },
+ demoTextContainer: {
+ textAlign: 'center', // Zentriert den Text und den Link
+ marginTop: tokens.spacingVerticalM, // Gibt etwas Abstand nach oben
+ marginBottom: tokens.spacingVerticalM // Gibt etwas Abstand nach unten
+ },
+ demoLink: {
+ fontSize: tokens.fontSizeBase400, // Etwas größere Schrift für den Link
+ fontWeight: tokens.fontWeightSemibold, // Macht den Link fett
+ color: tokens.colorBrandBackground, // Farbe für den Link, nutze Brand-Farben für Klickbarkeit
+ ...shorthands.margin(tokens.spacingVerticalS, 0),
+ paddingBottom: '65px'
+ }
+});
+
+export default GuideCardsStyles;
diff --git a/src/components/common/ChatMessage/ChatMessage.tsx b/src/components/common/ChatMessage/ChatMessage.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
diff --git a/src/components/common/FileExplorer/FileExplorer.tsx b/src/components/common/FileExplorer/FileExplorer.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..ce1445f3bebfc0c67a6f4c31dd2ff817d8077750
--- /dev/null
+++ b/src/components/common/FileExplorer/FileExplorer.tsx
@@ -0,0 +1,179 @@
+import { KeyboardEvent, MouseEvent, useEffect, useState } from 'react';
+import {
+ Button,
+ Dialog,
+ DialogActions,
+ DialogBody,
+ DialogContent,
+ DialogSurface,
+ DialogTitle,
+ DialogTrigger,
+ CompoundButton,
+ Spinner,
+ OnSelectionChangeData
+} from '@fluentui/react-components';
+import { DocumentFolder24Regular } from '@fluentui/react-icons';
+import { useTranslation } from 'react-i18next';
+import FileExplorerStyles from './FileExplorerStyles';
+import { FileList as FileListComp } from '../FileList/FileList';
+import NextCloudIcon from './NextCloudIcon.svg?react';
+import UploadButton from './UploadButton';
+import { useUser } from '../../../context/UserProvider';
+import { File as FileType } from '../../../models/File';
+import { getFiles, createFiles, deleteFiles } from '../../../api/fileApi';
+import { useToast } from '../../../context/ToastProvider';
+
+export const FileExplorer = () => {
+ const styles = FileExplorerStyles();
+ const { t } = useTranslation();
+ const { user } = useUser();
+ const { showToast } = useToast();
+ const [files, setFiles] = useState([]);
+ const [selectedFiles, setSelectedFiles] = useState(new Set());
+ const [isLoading, setIsLoading] = useState(true);
+
+ useEffect(() => {
+ if (!user) return;
+
+ const getAllDocuments = () => {
+ setIsLoading(true);
+ getFiles(user.auth0_id)
+ .then((response) => {
+ setFiles(response);
+ })
+ .catch((error) => {
+ const errorMessage =
+ error.response?.data?.error || t('unexpectedErrorOccurred');
+ showToast(`${t('errorfetchingFiles')}: ${errorMessage}`, 'error');
+ })
+ .finally(() => {
+ setIsLoading(false);
+ });
+ };
+
+ getAllDocuments();
+ }, [user, showToast, t]);
+
+ const handleFileUpload = (selectedFiles: FileList) => {
+ const formData = new FormData();
+ const tempFiles: FileType[] = [];
+
+ for (const rawFile of selectedFiles) {
+ formData.append('files', rawFile);
+ tempFiles.push({
+ filename: rawFile.name,
+ fileSize: rawFile.size,
+ isUploading: true
+ });
+ }
+
+ setFiles((prevFiles) => [...prevFiles, ...tempFiles]);
+ formData.append('user', user!.auth0_id as string);
+
+ createFiles(formData)
+ .then((response) => {
+ setFiles((prevFiles) =>
+ prevFiles.map((file) => {
+ const updatedFile = response.find(
+ (resFile) => resFile.filename === file.filename
+ );
+ return updatedFile ? { ...updatedFile, isUploading: false } : file;
+ })
+ );
+ showToast(t('fileUploadSuccess'), 'success');
+ })
+ .catch((error) => {
+ setFiles((prevFiles) => prevFiles.filter((file) => !file.isUploading));
+ const errorMessage =
+ error.response?.data?.error || t('unexpectedErrorOccurred');
+ showToast(`${t('errorUploadingFiles')}: ${errorMessage}`, 'error');
+ });
+ };
+
+ const handleSelectedFiles = (
+ _e: MouseEvent | KeyboardEvent,
+ data: OnSelectionChangeData
+ ) => {
+ const selectedFileIds = [...data.selectedItems];
+ setSelectedFiles(new Set(selectedFileIds));
+ };
+
+ const deleteSelectedFiles = () => {
+ const fileIdsToDelete: string[] = Array.from(selectedFiles).map(
+ (id) => id as string
+ );
+
+ deleteFiles(fileIdsToDelete)
+ .then(() => {
+ setFiles((prevFiles) =>
+ prevFiles.filter((file) => !selectedFiles.has(file.id))
+ );
+ setSelectedFiles(new Set());
+ showToast(t('filesDeletedSuccess'), 'success');
+ })
+ .catch((error) => {
+ const errorMessage =
+ error.response?.data?.error || t('unexpectedErrorOccurred');
+ showToast(`${t('errorDeletingFiles')}: ${errorMessage}`, 'error');
+ });
+ };
+
+ return (
+
+ );
+};
+
+export default FileExplorer;
diff --git a/src/components/common/FileExplorer/FileExplorerStyles.tsx b/src/components/common/FileExplorer/FileExplorerStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..44085d00a25e6c74939bede4b02896336903abad
--- /dev/null
+++ b/src/components/common/FileExplorer/FileExplorerStyles.tsx
@@ -0,0 +1,29 @@
+import { makeStyles, tokens } from '@fluentui/react-components';
+
+const FileExplorerStyles = makeStyles({
+ triggerButton: {
+ fontWeight: tokens.fontWeightMedium
+ },
+ surface: {
+ maxWidth: '60%',
+ minWidth: '25%'
+ },
+ content: {
+ display: 'flex',
+ flexDirection: 'column'
+ },
+ actionButtons: {
+ display: 'flex',
+ justifyContent: 'space-around',
+ marginBottom: tokens.spacingVerticalL
+ },
+ fileList: {
+ display: 'flex',
+ flexDirection: 'column'
+ },
+ deleteButton: {
+ alignSelf: 'end'
+ }
+});
+
+export default FileExplorerStyles;
diff --git a/src/components/common/FileExplorer/NextCloudIcon.svg b/src/components/common/FileExplorer/NextCloudIcon.svg
new file mode 100644
index 0000000000000000000000000000000000000000..dd22bab65786b10b2306b893a10c8b9cecb8f33f
--- /dev/null
+++ b/src/components/common/FileExplorer/NextCloudIcon.svg
@@ -0,0 +1,3 @@
+
diff --git a/src/components/common/FileExplorer/UploadButton.tsx b/src/components/common/FileExplorer/UploadButton.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..4701486cb3b6167eda77a97d78a6e80fc6e2c306
--- /dev/null
+++ b/src/components/common/FileExplorer/UploadButton.tsx
@@ -0,0 +1,47 @@
+import { CompoundButton } from '@fluentui/react-components';
+import { ArrowUpload24Regular } from '@fluentui/react-icons';
+import { useTranslation } from 'react-i18next';
+import { useRef, ChangeEvent } from 'react';
+
+interface UploadButtonProps {
+ onFilesSelected: (selectedFiles: FileList) => void;
+}
+
+export const UploadButton = ({ onFilesSelected }: UploadButtonProps) => {
+ const { t } = useTranslation();
+ const hiddenFileInput = useRef(null);
+
+ const handleClick = () => {
+ if (hiddenFileInput.current) {
+ hiddenFileInput.current.click();
+ }
+ };
+
+ const handleFileChange = (event: ChangeEvent) => {
+ if (event.target.files && event.target.files.length > 0) {
+ onFilesSelected(event.target.files);
+ }
+ };
+
+ return (
+ }
+ appearance="subtle"
+ size="small"
+ secondaryContent={t('uploadButtonSub')}
+ onClick={handleClick}
+ >
+ {t('uploadButton')}
+
+
+ );
+};
+
+export default UploadButton;
diff --git a/src/components/common/FileList/FileList.tsx b/src/components/common/FileList/FileList.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..914437515926bb03756daeeb213639d6d461ac7d
--- /dev/null
+++ b/src/components/common/FileList/FileList.tsx
@@ -0,0 +1,216 @@
+import {
+ DataGrid,
+ DataGridBody,
+ DataGridCell,
+ DataGridHeader,
+ DataGridHeaderCell,
+ DataGridRow,
+ OnSelectionChangeData,
+ SelectionItemId,
+ Spinner,
+ TableCellLayout,
+ TableColumnDefinition,
+ createTableColumn
+} from '@fluentui/react-components';
+import FileListStyles from './FileListStyles';
+import { File } from '../../../models/File';
+import { useTranslation } from 'react-i18next';
+import ReactCountryFlag from 'react-country-flag';
+import { format } from 'date-fns';
+import { KeyboardEvent, MouseEvent } from 'react';
+
+const langToCountryCode = (lang: string) => {
+ const map: { [key: string]: string } = {
+ de: 'DE',
+ en: 'US'
+ };
+
+ return map[lang] || 'US';
+};
+
+const formatFileSize = (size: number): string => {
+ if (size < 1024) return size + ' Bytes';
+ else if (size < 1024 * 1024) return (size / 1024).toFixed(1) + ' KB';
+ else if (size < 1024 * 1024 * 1024)
+ return (size / 1024 / 1024).toFixed(1) + ' MB';
+ else return (size / 1024 / 1024 / 1024).toFixed(1) + ' GB';
+};
+
+interface FileListProps {
+ files: File[];
+ selectedFileIds?: Set;
+ onSelectionChange?: (
+ e: MouseEvent | KeyboardEvent,
+ data: OnSelectionChangeData
+ ) => void;
+}
+
+export const FileList = ({
+ files,
+ selectedFileIds,
+ onSelectionChange
+}: FileListProps) => {
+ const styles = FileListStyles();
+ const { t } = useTranslation();
+
+ const columns: TableColumnDefinition[] = [
+ createTableColumn({
+ columnId: 'isUploading',
+ renderHeaderCell: () => {
+ return '';
+ },
+ renderCell: (file) => {
+ return file.isUploading ? : null;
+ }
+ }),
+ createTableColumn({
+ columnId: 'file',
+ compare: (a, b) => {
+ return a.filename.localeCompare(b.filename);
+ },
+ renderHeaderCell: () => {
+ return t('file');
+ },
+ renderCell: (file) => {
+ const [fileName, fileExtension] = file.filename.split('.');
+ const file_icon = `https://res-1.cdn.office.net/files/fabric-cdn-prod_20230815.002/assets/item-types/16/${fileExtension}.svg`;
+
+ return (
+
+
+ {fileName}
+
+ );
+ }
+ }),
+ createTableColumn({
+ columnId: 'lang',
+ compare: (a, b) => {
+ const langA = a.lang || '';
+ const langB = b.lang || '';
+ return langA.localeCompare(langB);
+ },
+ renderHeaderCell: () => t('language'),
+ renderCell: (file) =>
+ file.lang ? (
+
+ }
+ >
+ {file.lang.toUpperCase()}
+
+ ) : null
+ }),
+ createTableColumn({
+ columnId: 'size',
+ compare: (a, b) => {
+ return a.fileSize - b.fileSize;
+ },
+ renderHeaderCell: () => {
+ return t('fileSize');
+ },
+ renderCell: (file) => {
+ return (
+ {formatFileSize(file.fileSize)}
+ );
+ }
+ }),
+ createTableColumn({
+ columnId: 'uploadedAt',
+ compare: (a, b) => {
+ const dateA = a.uploadedAt ? a.uploadedAt.getTime() : 0;
+ const dateB = b.uploadedAt ? b.uploadedAt.getTime() : 0;
+ return dateB - dateA;
+ },
+ renderHeaderCell: () => t('uploadedAt'),
+ renderCell: (file) =>
+ file.uploadedAt ? (
+
+ {format(file.uploadedAt, 'dd.MM.yyyy HH:mm')}
+
+ ) : null
+ })
+ ];
+
+ const columnSizingOptions = {
+ isUploading: {
+ defaultWidth: 20,
+ minWidth: 20,
+ idealWidth: 20
+ },
+ file: {
+ defaultWidth: 240,
+ minWidth: 60,
+ idealWidth: 240
+ },
+ lang: {
+ defaultWidth: 80,
+ minWidth: 60,
+ idealWidth: 80
+ },
+ size: {
+ defaultWidth: 90,
+ minWidth: 90,
+ idealWidth: 90
+ },
+ uploadedAt: {
+ defaultWidth: 120,
+ minWidth: 120,
+ idealWidth: 120
+ }
+ };
+
+ return (
+ item.id}
+ focusMode="composite"
+ selectedItems={selectedFileIds}
+ onSelectionChange={onSelectionChange}
+ >
+
+
+ {({ renderHeaderCell }) => (
+ {renderHeaderCell()}
+ )}
+
+
+ >
+ {({ item, rowId }) => (
+
+ key={rowId}
+ selectionCell={{
+ checkboxIndicator: { 'aria-label': 'Select row' }
+ }}
+ >
+ {({ renderCell }) => (
+ {renderCell(item)}
+ )}
+
+ )}
+
+
+ );
+};
+
+export default FileList;
diff --git a/src/components/common/FileList/FileListStyles.tsx b/src/components/common/FileList/FileListStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..2020a07dc3d33b8c7531425f001d8040be83caa7
--- /dev/null
+++ b/src/components/common/FileList/FileListStyles.tsx
@@ -0,0 +1,23 @@
+import { makeStyles, tokens } from '@fluentui/react-components';
+
+const FileListStyles = makeStyles({
+ fileIcon: {
+ verticalAlign: 'middle',
+ maxHeight: '16px',
+ maxWidth: '16px',
+ marginRight: tokens.spacingHorizontalS
+ },
+ langIcon: {
+ verticalAlign: 'middle',
+ maxHeight: '16px',
+ maxWidth: '16px'
+ },
+ fileCell: {
+ display: 'flex'
+ },
+ fileCellText: {
+ width: '100%'
+ }
+});
+
+export default FileListStyles;
diff --git a/src/components/common/FileSelector/FileSelector.tsx b/src/components/common/FileSelector/FileSelector.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..3f88c6cecf81d1c83a8856d7ed95ef625af68b6d
--- /dev/null
+++ b/src/components/common/FileSelector/FileSelector.tsx
@@ -0,0 +1,126 @@
+import { KeyboardEvent, MouseEvent, useEffect, useState } from 'react';
+import {
+ Button,
+ Dialog,
+ DialogActions,
+ DialogBody,
+ DialogContent,
+ DialogSurface,
+ DialogTitle,
+ DialogTrigger,
+ Spinner,
+ OnSelectionChangeData,
+ SelectionItemId,
+ DialogTriggerChildProps
+} from '@fluentui/react-components';
+import { useTranslation } from 'react-i18next';
+import FileSelectorStyles from './FileSelectorStyles';
+import { FileList as FileListComp } from '../FileList/FileList';
+import { useUser } from '../../../context/UserProvider';
+import { File, File as FileType } from '../../../models/File';
+import { getFiles } from '../../../api/fileApi';
+import { User } from '../../../models/User';
+interface FileSelectorProps {
+ onFilesSelected: (files: File[]) => void;
+ selectedFiles: File[];
+ triggerButton: (props: DialogTriggerChildProps) => JSX.Element;
+ passedUser?: User;
+}
+
+export const FileSelector = ({
+ onFilesSelected,
+ selectedFiles,
+ triggerButton,
+ passedUser
+}: FileSelectorProps) => {
+ const styles = FileSelectorStyles();
+ const { t } = useTranslation();
+ const { user: hookUser } = useUser();
+ const [files, setFiles] = useState([]);
+ const [selectedFileIds, setSelectedFileIds] = useState>(
+ new Set()
+ );
+ const [isLoading, setIsLoading] = useState(true);
+ const [dialogOpen, setDialogState] = useState(false);
+
+ const user = passedUser || hookUser;
+
+ useEffect(() => {
+ if (!user || !dialogOpen) return;
+
+ const getAllDocuments = () => {
+ setIsLoading(true);
+ getFiles(user.auth0_id)
+ .then((response) => {
+ setFiles(response);
+ })
+ .catch((error) => {
+ console.error('Error fetching documents:', error);
+ })
+ .finally(() => {
+ setIsLoading(false);
+ });
+ };
+
+ getAllDocuments();
+ }, [user, dialogOpen]);
+
+ useEffect(() => {
+ const preSelectedIds = new Set(
+ selectedFiles
+ .filter((file) => file.id !== undefined)
+ .map((file) => file.id!)
+ );
+ setSelectedFileIds(preSelectedIds);
+ }, [selectedFiles]);
+
+ const handleSelectedFiles = (
+ _e: MouseEvent | KeyboardEvent,
+ data: OnSelectionChangeData
+ ) => {
+ setSelectedFileIds(new Set(data.selectedItems));
+ };
+
+ const selectFiles = () => {
+ const selectedFiles = files.filter((file) => selectedFileIds.has(file.id!));
+ onFilesSelected(selectedFiles);
+ setDialogState(false);
+ };
+
+ return (
+
+ );
+};
+
+export default FileSelector;
diff --git a/src/components/common/FileSelector/FileSelectorStyles.tsx b/src/components/common/FileSelector/FileSelectorStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..133da426e51752e870d55f9716d9f78f70d55762
--- /dev/null
+++ b/src/components/common/FileSelector/FileSelectorStyles.tsx
@@ -0,0 +1,29 @@
+import { makeStyles, tokens } from '@fluentui/react-components';
+
+const FileSelectorStyles = makeStyles({
+ triggerButton: {
+ fontWeight: tokens.fontWeightMedium
+ },
+ surface: {
+ maxWidth: '60%',
+ minWidth: '25%'
+ },
+ content: {
+ display: 'flex',
+ flexDirection: 'column'
+ },
+ actionButtons: {
+ display: 'flex',
+ justifyContent: 'space-around',
+ marginBottom: tokens.spacingVerticalL
+ },
+ fileList: {
+ display: 'flex',
+ flexDirection: 'column'
+ },
+ deleteButton: {
+ alignSelf: 'end'
+ }
+});
+
+export default FileSelectorStyles;
diff --git a/src/components/common/LanguageSelector/LanguageSelector.tsx b/src/components/common/LanguageSelector/LanguageSelector.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..9e59b11d9d4ba4ed2227fe0dac25207e996ad9c2
--- /dev/null
+++ b/src/components/common/LanguageSelector/LanguageSelector.tsx
@@ -0,0 +1,85 @@
+import { useState, useEffect } from 'react';
+import { useTranslation } from 'react-i18next';
+import {
+ Dropdown,
+ Option,
+ OptionOnSelectData,
+ SelectionEvents
+} from '@fluentui/react-components';
+import LanguageSelectorStyles from './LanguageSelectorStyles';
+import { useUser } from '../../../context/UserProvider';
+import { updateUser } from '../../../api/usersApi';
+import { useToast } from '../../../context/ToastProvider';
+
+const LanguageSelector = () => {
+ const styles = LanguageSelectorStyles();
+ const { t, i18n } = useTranslation();
+ const { user, setUser } = useUser();
+ const { showToast } = useToast();
+
+ const options = [
+ { value: 'en', text: 'EN' },
+ { value: 'de', text: 'DE' }
+ ];
+
+ const [selectedLanguage, setSelectedLanguage] = useState(() => {
+ return user?.lang || localStorage.getItem('cgfwLanguage') || i18n.language;
+ });
+
+ const defaultOption = options.find(
+ (option) => option.value === selectedLanguage,
+ { value: 'en', text: 'EN' }
+ );
+
+ useEffect(() => {
+ const storedLanguage = localStorage.getItem('cgfwLanguage');
+ if (storedLanguage && storedLanguage !== i18n.language) {
+ i18n.changeLanguage(storedLanguage);
+ }
+ }, [i18n]);
+
+ const handleChangeLanguage = (
+ _: SelectionEvents,
+ data: OptionOnSelectData
+ ) => {
+ const newLanguage = data.optionValue;
+ if (newLanguage && newLanguage !== selectedLanguage) {
+ setSelectedLanguage(newLanguage);
+ localStorage.setItem('cgfwLanguage', newLanguage);
+ i18n.changeLanguage(newLanguage);
+
+ if (user) {
+ const updatedUser = { ...user, lang: newLanguage };
+ updateUser(updatedUser)
+ .then((userResponse) => {
+ setUser(userResponse);
+ })
+ .catch((error) => {
+ const errorMessage =
+ error.response?.data?.error || t('unexpectedErrorOccurred');
+ showToast(`${t('errorSavingLanguage')}: ${errorMessage}`, 'error');
+ });
+ }
+ }
+ };
+
+ return (
+
+ {options.map((option) => (
+
+ ))}
+
+ );
+};
+
+export default LanguageSelector;
diff --git a/src/components/common/LanguageSelector/LanguageSelectorStyles.tsx b/src/components/common/LanguageSelector/LanguageSelectorStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..7893712eb3ffa3e127d05c02f02ada6b6d50b1f5
--- /dev/null
+++ b/src/components/common/LanguageSelector/LanguageSelectorStyles.tsx
@@ -0,0 +1,14 @@
+import { makeStyles } from '@fluentui/react-components';
+
+const LanguageSelectorStyles = makeStyles({
+ dropdown: {
+ width: 'auto',
+ minWidth: '32px'
+ },
+ option: {
+ width: 'auto',
+ minWidth: '32px'
+ }
+});
+
+export default LanguageSelectorStyles;
diff --git a/src/components/common/LoginButton/LoginButton.tsx b/src/components/common/LoginButton/LoginButton.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..8ded678f9f2904c375fbaa75c5fced1013ce714b
--- /dev/null
+++ b/src/components/common/LoginButton/LoginButton.tsx
@@ -0,0 +1,33 @@
+import { useAuth0 } from '@auth0/auth0-react';
+import { useTranslation } from 'react-i18next';
+import LoginButtonStyles from './LoginButtonStyles';
+import { Button } from '@fluentui/react-components';
+import { SignOut24Regular } from '@fluentui/react-icons';
+
+const LoginButton = () => {
+ const styles = LoginButtonStyles();
+ const { loginWithRedirect, logout, isAuthenticated, user } = useAuth0();
+ const { t } = useTranslation();
+
+ if (isAuthenticated) {
+ return (
+
+
{user?.email}
+
}
+ size="large"
+ onClick={() => logout()}
+ />
+
+ );
+ } else {
+ return (
+
+ );
+ }
+};
+
+export default LoginButton;
diff --git a/src/components/common/LoginButton/LoginButtonStyles.tsx b/src/components/common/LoginButton/LoginButtonStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..c8589424ea80c4954871b013118ab044bdc51e88
--- /dev/null
+++ b/src/components/common/LoginButton/LoginButtonStyles.tsx
@@ -0,0 +1,14 @@
+import { makeStyles, tokens } from '@fluentui/react-components';
+
+const LoginButtonStyles = makeStyles({
+ userText: {
+ fontWeight: tokens.fontWeightMedium,
+ marginRight: tokens.spacingHorizontalL
+ },
+ loginButtonContainer: {
+ display: 'flex',
+ alignItems: 'center'
+ }
+});
+
+export default LoginButtonStyles;
diff --git a/src/components/common/MenuItem/MenuItem.tsx b/src/components/common/MenuItem/MenuItem.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
diff --git a/src/components/common/Messages/ChatGPTMessageItem/ChatGPTMessageItem.tsx b/src/components/common/Messages/ChatGPTMessageItem/ChatGPTMessageItem.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..45b68e291e6288190faf82dbea314b61868412b8
--- /dev/null
+++ b/src/components/common/Messages/ChatGPTMessageItem/ChatGPTMessageItem.tsx
@@ -0,0 +1,51 @@
+import {
+ Text,
+ Persona,
+ Skeleton,
+ SkeletonItem
+} from '@fluentui/react-components';
+import ChatGPTMessageItemStyles from './ChatGPTMessageItemStyles';
+import { Message } from '../../../../models/Message';
+import { BotSparkleRegular } from '@fluentui/react-icons';
+import { useTranslation } from 'react-i18next';
+
+interface ChatGPTMessageItemProps {
+ message: Message;
+ isLoading?: boolean;
+}
+
+const ChatGPTMessageItem = ({
+ message,
+ isLoading = false
+}: ChatGPTMessageItemProps) => {
+ const styles = ChatGPTMessageItemStyles();
+ const { t } = useTranslation();
+
+ return (
+
+
+
}}
+ primaryText={t('chatGPTRoleName')}
+ secondaryText={new Date(message.created_at).toLocaleDateString()}
+ tertiaryText={new Date(message.created_at).toLocaleTimeString()}
+ />
+
+
+ {isLoading && message.content == 'Loading' ? (
+
+
+
+
+
+
+
+ ) : (
+
{message.content as string}
+ )}
+
+
+ );
+};
+
+export default ChatGPTMessageItem;
diff --git a/src/components/common/Messages/ChatGPTMessageItem/ChatGPTMessageItemStyles.tsx b/src/components/common/Messages/ChatGPTMessageItem/ChatGPTMessageItemStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..b8153067ab9a9a9e4ca0d04600bf2aeaf634ff45
--- /dev/null
+++ b/src/components/common/Messages/ChatGPTMessageItem/ChatGPTMessageItemStyles.tsx
@@ -0,0 +1,62 @@
+import { makeStyles, shorthands, tokens } from '@fluentui/react-components';
+
+const ChatGPTMessageItemStyles = makeStyles({
+ container: {
+ alignSelf: 'start',
+ maxWidth: '1000px',
+ width: '80%',
+ ...shorthands.gap(tokens.spacingHorizontalL),
+ alignItems: 'center',
+ display: 'flex',
+ ':hover & .timestamp': {
+ backgroundColor: tokens.colorBrandBackground,
+ opacity: '1'
+ }
+ },
+ messageContent: {
+ ...shorthands.borderRadius('6px'),
+ ...shorthands.padding(
+ tokens.spacingHorizontalXL,
+ tokens.spacingHorizontalXXXL,
+ tokens.spacingHorizontalL,
+ tokens.spacingHorizontalL
+ ),
+ ...shorthands.margin('10px', '0'),
+ display: 'flex',
+ flexDirection: 'column',
+ backgroundColor: tokens.colorNeutralBackground1,
+ boxShadow: tokens.shadow4,
+ width: '90%',
+ ...shorthands.gap(tokens.spacingHorizontalS)
+ },
+ content: {
+ color: tokens.colorNeutralForeground1,
+ ...shorthands.margin('0'),
+ whiteSpace: 'pre-line'
+ },
+ timestamp: {
+ color: tokens.colorNeutralForeground3,
+ opacity: '1',
+ transitionTimingFunction: tokens.curveDecelerateMid,
+ transitionDuration: tokens.durationFast,
+ transitionProperty: 'opacity'
+ },
+ avatarContainer: {
+ display: 'flex',
+ alignSelf: 'start',
+ marginTop: tokens.spacingHorizontalXL,
+ ...shorthands.gap(tokens.spacingHorizontalS),
+ width: '7rem'
+ },
+ contentSkeleton: {
+ alignItems: 'center',
+ display: 'flex',
+ flexDirection: 'column',
+ paddingBottom: '10px',
+ position: 'relative',
+ ...shorthands.gap('10px'),
+ width: '100%'
+ }
+});
+
+export default ChatGPTMessageItemStyles;
diff --git a/src/components/common/Messages/ChatInput/ChatInput.tsx b/src/components/common/Messages/ChatInput/ChatInput.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..164c58f307e82d38497e8ce8cb29d57e792b145d
--- /dev/null
+++ b/src/components/common/Messages/ChatInput/ChatInput.tsx
@@ -0,0 +1,51 @@
+import React, { useState } from 'react';
+import { Button, Textarea } from '@fluentui/react-components';
+import ChatInputStyles from './ChatInputStyles';
+import { Send24Filled } from '@fluentui/react-icons';
+
+interface ChatInputProps {
+ onSendMessage: (value: string) => void;
+ demo?: boolean;
+}
+
+const ChatInput = ({ onSendMessage, demo = false }: ChatInputProps) => {
+ const [input, setInput] = useState('');
+ const styles = ChatInputStyles();
+
+ const handleSubmit = (e: React.KeyboardEvent) => {
+ e.preventDefault();
+ if (input.trim() !== '') {
+ onSendMessage(input);
+ setInput('');
+ }
+ };
+
+ const handleKeyPress = (e: React.KeyboardEvent) => {
+ if (e.key === 'Enter' && !e.shiftKey) {
+ handleSubmit(e);
+ }
+ };
+
+ return (
+
+ );
+};
+
+export default ChatInput;
diff --git a/src/components/common/Messages/ChatInput/ChatInputStyles.tsx b/src/components/common/Messages/ChatInput/ChatInputStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..5bbfcbc8d4647e0127b7f342901824e7ade7b2ce
--- /dev/null
+++ b/src/components/common/Messages/ChatInput/ChatInputStyles.tsx
@@ -0,0 +1,45 @@
+import { makeStyles, shorthands, tokens } from '@fluentui/react-components';
+
+const ChatInputStyles = makeStyles({
+ demoContainer: {
+ display: 'flex',
+ alignItems: 'center',
+ justifyContent: 'center',
+ ...shorthands.gap('8px'),
+ marginBottom: tokens.spacingVerticalXL,
+ boxShadow: `0px -20px 17px 0px ${tokens.colorNeutralBackground1}`,
+ width: '100%',
+ alignSelf: 'center'
+ },
+
+ container: {
+ display: 'flex',
+ alignItems: 'center',
+ justifyContent: 'center',
+ ...shorthands.gap('8px'),
+ marginBottom: tokens.spacingVerticalXL,
+ boxShadow: `0px -20px 17px 0px ${tokens.colorNeutralBackground1}`
+ },
+ textArea: {
+ flexGrow: 1,
+ ...shorthands.padding(tokens.spacingHorizontalM),
+ width: '100%'
+ },
+ sendButton: {
+ ...shorthands.borderRadius(tokens.borderRadiusMedium),
+ color: tokens.colorBrandBackground,
+ position: 'absolute',
+ bottom: '10px',
+ right: '15px'
+ },
+ inputContainer: {
+ position: 'relative',
+ display: 'inline-block',
+ maxWidth: '75%',
+ width: '75%',
+ minWidth: '400px',
+ boxShadow: tokens.shadow8
+ }
+});
+
+export default ChatInputStyles;
diff --git a/src/components/common/Messages/SearchMessageItem/SearchMessageItem.tsx b/src/components/common/Messages/SearchMessageItem/SearchMessageItem.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..4b1e799f231ccfe7a4aab44bb5cefd36a263d139
--- /dev/null
+++ b/src/components/common/Messages/SearchMessageItem/SearchMessageItem.tsx
@@ -0,0 +1,224 @@
+import { useState, useEffect, Fragment } from 'react';
+import {
+ Text,
+ Button,
+ Tooltip,
+ mergeClasses,
+ Body1Strong,
+ Body1Stronger,
+ Divider,
+ Caption1Strong,
+ Persona,
+ Skeleton,
+ SkeletonItem
+} from '@fluentui/react-components';
+import SearchMessageItemStyles from './SearchMessageItemStyles';
+import { Message, Result } from '../../../../models/Message';
+import { getUser } from '../../../../api/usersApi';
+import {
+ DatabaseSearchRegular,
+ Edit24Regular,
+ Info20Regular,
+ Send24Regular
+} from '@fluentui/react-icons';
+import { useTranslation } from 'react-i18next';
+import { HighlightWithinTextarea } from 'react-highlight-within-textarea';
+import { useAuth0 } from '@auth0/auth0-react';
+
+interface SearchMessageItemProps {
+ message: Message;
+ onSendToChatGPT: () => void;
+ isLoading: boolean;
+}
+
+const SearchMessageItem = ({
+ message,
+ onSendToChatGPT,
+ isLoading = false
+}: SearchMessageItemProps) => {
+ const styles = SearchMessageItemStyles();
+ const { t } = useTranslation();
+ const [editable, setEditable] = useState(false);
+ const [visible, setVisible] = useState(false);
+ // displayed results
+ const [results, setResults] = useState(message.content as Result[]);
+ // results holding the old state while editing the normal results
+ const [tempResults, setTempResults] = useState([]);
+ const [errorMessage, setErrorMessage] = useState(null);
+ const { user: auth0User } = useAuth0();
+
+ const [, setMaxApiCalls] = useState(null);
+
+ useEffect(() => {
+ const fetchUserFromBackend = async () => {
+ if (auth0User?.sub) {
+ try {
+ const fetchedUser = await getUser(auth0User.sub);
+ setMaxApiCalls(fetchedUser.max_api_calls);
+ if (fetchedUser.max_api_calls === 0) {
+ setErrorMessage(`${t('trialOverMessage')}`);
+ } else {
+ setResults(message.content as Result[]);
+ setErrorMessage(null);
+ }
+ } catch (error) {
+ console.error(
+ 'Error fetching user from backend, creating new one.',
+ error
+ );
+ }
+ }
+ };
+
+ fetchUserFromBackend();
+ }, [message.content]);
+
+ const handleEditClick = () => {
+ setEditable(true);
+ setTempResults(structuredClone(results));
+ };
+
+ const handleSaveClick = () => {
+ setEditable(false);
+ };
+
+ const handleDiscardClick = () => {
+ setEditable(false);
+ setResults(structuredClone(tempResults));
+ };
+
+ const handleContentChange = (index: number, value: string) => {
+ setResults((prevResults) => {
+ const newResults = [...prevResults];
+ newResults[index].content = value;
+ return newResults;
+ });
+ };
+ return (
+
+ {/* Persona */}
+
+
}}
+ primaryText={t('resultRoleName')}
+ secondaryText={new Date(message.created_at).toLocaleDateString()}
+ tertiaryText={new Date(message.created_at).toLocaleTimeString()}
+ />
+
+
+ {/* Header */}
+
+ {t('searchMessageIntroText')}
+
+ {/* Body */}
+
+ {isLoading && message.content.length == 0 ? (
+
+
+ {Array.from({ length: 3 }, (_, index) => (
+
+
+
+
+
+
+
+
+
+
+
+
+
+ ))}
+
+
+ ) : (
+ <>
+ {errorMessage ? (
+
{errorMessage}
+ ) : (
+ results.map((result: Result, i: number) => (
+
+
+ {t('searchMessageStatText', {
+ index: i + 1,
+ filename: result.fileName,
+ accuracy: (result.accuracy * 100).toFixed(2)
+ })}
+
+ {editable ? (
+
+
+ handleContentChange(i, value)
+ }
+ />
+
+ ) : (
+
+ {result.content}
+
+ )}
+
+ ))
+ )}
+ >
+ )}
+
+ {/* Footer */}
+
+ {t('searchMessageIntroHint')}
+
+
+ {editable ? (
+ <>
+
+
+ >
+ ) : (
+ <>
+
}
+ onClick={handleEditClick}
+ disabled={isLoading && message.content.length == 0}
+ >
+ {t('editResultsButton')}
+
+
+ }
+ onClick={onSendToChatGPT}
+ disabled={isLoading && message.content.length == 0}
+ >
+ {t('sendToChatGPTButton')}
+
+ setVisible(data.visible)}
+ >
+
+
+
+ >
+ )}
+
+
+
+ );
+};
+
+export default SearchMessageItem;
diff --git a/src/components/common/Messages/SearchMessageItem/SearchMessageItemStyles.tsx b/src/components/common/Messages/SearchMessageItem/SearchMessageItemStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..9952f33987dd51f997ae458aeda0e3e0a1e414ee
--- /dev/null
+++ b/src/components/common/Messages/SearchMessageItem/SearchMessageItemStyles.tsx
@@ -0,0 +1,91 @@
+import { makeStyles, shorthands, tokens } from '@fluentui/react-components';
+
+const SearchMessageItemStyles = makeStyles({
+ container: {
+ alignSelf: 'start',
+ maxWidth: '1000px',
+ width: '80%',
+ ...shorthands.gap(tokens.spacingHorizontalL),
+ alignItems: 'center',
+ display: 'flex',
+ ':hover & .timestamp': {
+ backgroundColor: tokens.colorBrandBackground,
+ opacity: '1'
+ }
+ },
+ messageContent: {
+ ...shorthands.borderRadius('6px'),
+ ...shorthands.padding(
+ tokens.spacingHorizontalXL,
+ tokens.spacingHorizontalXXXL,
+ tokens.spacingHorizontalL,
+ tokens.spacingHorizontalL
+ ),
+ ...shorthands.margin('10px', '0'),
+ display: 'flex',
+ flexDirection: 'column',
+ backgroundColor: tokens.colorNeutralBackground1,
+ boxShadow: tokens.shadow4,
+ width: '90%',
+ ...shorthands.gap(tokens.spacingHorizontalL)
+ },
+ timestamp: {
+ color: tokens.colorNeutralForeground3,
+ opacity: '1',
+ transitionTimingFunction: tokens.curveDecelerateMid,
+ transitionDuration: tokens.durationFast,
+ transitionProperty: 'opacity'
+ },
+ avatarContainer: {
+ display: 'flex',
+ alignSelf: 'start',
+ marginTop: tokens.spacingHorizontalXL,
+ ...shorthands.gap(tokens.spacingHorizontalS),
+ width: '7rem'
+ },
+ introText: {},
+ statText: {
+ opacity: '0.6'
+ },
+ resultContainer: {
+ display: 'flex',
+ flexDirection: 'column',
+ ...shorthands.gap(tokens.spacingHorizontalS)
+ },
+ textarea: {
+ boxShadow: tokens.shadow2,
+ ...shorthands.padding(tokens.spacingHorizontalXS)
+ },
+ resultContent: {
+ display: 'flex',
+ flexDirection: 'column',
+ ...shorthands.padding(tokens.spacingHorizontalXS),
+ whiteSpace: 'pre-line'
+ },
+ actionButtons: {
+ display: 'flex',
+ width: '100%',
+ justifyContent: 'space-between'
+ },
+ visible: {
+ color: tokens.colorNeutralForeground2BrandSelected
+ },
+ contentSkeleton: {
+ alignItems: 'center',
+ display: 'grid',
+ paddingBottom: '10px',
+ position: 'relative',
+ ...shorthands.gap('10px'),
+ gridTemplateColumns: 'min-content 80%'
+ },
+ statSkeleton: {
+ alignItems: 'center',
+ display: 'grid',
+ paddingBottom: '10px',
+ position: 'relative',
+ ...shorthands.gap('10px'),
+ gridTemplateColumns: 'min-content 20% 20% 15%'
+ }
+});
+
+export default SearchMessageItemStyles;
diff --git a/src/components/common/Messages/UserMessageItem/UserMessageItem.tsx b/src/components/common/Messages/UserMessageItem/UserMessageItem.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..167ba317c9dc6745a15b39846729bbab64a59e6a
--- /dev/null
+++ b/src/components/common/Messages/UserMessageItem/UserMessageItem.tsx
@@ -0,0 +1,40 @@
+import { Text, Persona } from '@fluentui/react-components';
+import UserMessageItemStyles from './UserMessageItemStyles';
+import { Message } from '../../../../models/Message';
+import { useUser } from '../../../../context/UserProvider';
+
+interface UserMessageItemProps {
+ message: Message;
+}
+
+const truncateString = (str: string, num: number) => {
+ if (str.length <= num) {
+ return str;
+ }
+ return str.slice(0, num) + '...';
+};
+
+const UserMessageItem = ({ message }: UserMessageItemProps) => {
+ const styles = UserMessageItemStyles();
+ const { user } = useUser();
+ const truncatedName = truncateString(user!.username, 8);
+
+ return (
+
+
+ {message.content as string}
+
+
+
+ );
+};
+
+export default UserMessageItem;
diff --git a/src/components/common/Messages/UserMessageItem/UserMessageItemStyles.tsx b/src/components/common/Messages/UserMessageItem/UserMessageItemStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..d7e0c6fd5740b4708525dba09eb711baefaa454d
--- /dev/null
+++ b/src/components/common/Messages/UserMessageItem/UserMessageItemStyles.tsx
@@ -0,0 +1,53 @@
+import { makeStyles, shorthands, tokens } from '@fluentui/react-components';
+
+const UserMessageItemStyles = makeStyles({
+ container: {
+ alignSelf: 'end',
+ maxWidth: '1000px',
+ width: '80%',
+ ...shorthands.gap(tokens.spacingHorizontalL),
+ alignItems: 'center',
+ display: 'flex',
+ ':hover & .timestamp': {
+ backgroundColor: tokens.colorBrandBackground,
+ opacity: '1'
+ }
+ },
+ messageContent: {
+ ...shorthands.borderRadius('6px'),
+ ...shorthands.padding(
+ tokens.spacingHorizontalXL,
+ tokens.spacingHorizontalXXXL,
+ tokens.spacingHorizontalL,
+ tokens.spacingHorizontalL
+ ),
+ ...shorthands.margin('10px', '0'),
+ display: 'flex',
+ flexDirection: 'column',
+ backgroundColor: tokens.colorNeutralBackground2,
+ boxShadow: tokens.shadow4,
+ width: '90%',
+ ...shorthands.gap(tokens.spacingHorizontalS)
+ },
+ content: {
+ color: tokens.colorNeutralForeground1,
+ ...shorthands.margin('0'),
+ whiteSpace: 'pre-line'
+ },
+ timestamp: {
+ color: tokens.colorNeutralForeground3,
+ opacity: '1',
+ transitionTimingFunction: tokens.curveDecelerateMid,
+ transitionDuration: tokens.durationFast,
+ transitionProperty: 'opacity'
+ },
+ avatarContainer: {
+ display: 'flex',
+ alignSelf: 'start',
+ marginTop: tokens.spacingHorizontalXL,
+ ...shorthands.gap(tokens.spacingHorizontalS),
+ width: '7rem'
+ }
+});
+
+export default UserMessageItemStyles;
diff --git a/src/components/common/ProtectedRoute/ProtectedRoute.module.css b/src/components/common/ProtectedRoute/ProtectedRoute.module.css
new file mode 100644
index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
diff --git a/src/components/common/ProtectedRoute/ProtectedRoute.tsx b/src/components/common/ProtectedRoute/ProtectedRoute.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..fab4d9a34362760c44b3e0fa7cc2463f91fb7655
--- /dev/null
+++ b/src/components/common/ProtectedRoute/ProtectedRoute.tsx
@@ -0,0 +1,15 @@
+import { useAuth0 } from '@auth0/auth0-react';
+import { Navigate, Outlet } from 'react-router-dom';
+import { Spinner } from '@fluentui/react-components';
+
+const ProtectedRoute = () => {
+ const { isAuthenticated, isLoading } = useAuth0();
+
+ if (isLoading) {
+ return ;
+ }
+
+ return isAuthenticated ? : ;
+};
+
+export default ProtectedRoute;
diff --git a/src/components/common/RoomList/RoomItem.tsx b/src/components/common/RoomList/RoomItem.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..877c3dcb94baa620007aa2001bd4daa046f29f94
--- /dev/null
+++ b/src/components/common/RoomList/RoomItem.tsx
@@ -0,0 +1,106 @@
+import { useState, useRef, useEffect } from 'react';
+import { useLocation, useNavigate } from 'react-router-dom';
+import { Room } from '../../../models/Room';
+import { MoreVertical24Regular } from '@fluentui/react-icons';
+import {
+ Button,
+ Menu,
+ MenuButton,
+ MenuItem,
+ MenuList,
+ MenuPopover,
+ MenuTrigger,
+ mergeClasses,
+ Input
+} from '@fluentui/react-components';
+import { useTranslation } from 'react-i18next';
+import RoomItemStyles from './RoomItemStyles';
+
+interface RoomItemProps {
+ room: Room;
+ onRename: (roomID: string, newName: string) => void; // Anpassen, um den neuen Namen als Argument zu akzeptieren
+ onDelete: (roomID: string) => void;
+}
+
+const RoomItem = ({ room, onRename, onDelete }: RoomItemProps) => {
+ const [isEditing, setIsEditing] = useState(false);
+ const [tempName, setTempName] = useState(room.name);
+ const inputRef = useRef(null);
+ const styles = RoomItemStyles();
+ const { t } = useTranslation();
+ const navigate = useNavigate();
+ const location = useLocation();
+ const isSelected = location.pathname === `/chat/room/${room.id}`;
+
+ useEffect(() => {
+ if (isEditing && inputRef.current) {
+ inputRef.current.focus();
+ inputRef.current.select();
+ }
+ }, [isEditing]);
+
+ const handleRoomClick = () => {
+ navigate(`/chat/room/${room.id}`);
+ };
+
+ const handleRenameClick = () => {
+ setIsEditing(true);
+ };
+
+ const handleBlurOrEnter = () => {
+ if (tempName.trim() === '') {
+ setTempName(room.name);
+ } else {
+ onRename(room.id, tempName);
+ }
+ setIsEditing(false);
+ };
+
+ return (
+
+ {isEditing ? (
+ setTempName(data.value || '')}
+ onBlur={handleBlurOrEnter}
+ onKeyDown={(event) => event.key === 'Enter' && handleBlurOrEnter()}
+ ref={inputRef}
+ />
+ ) : (
+
+ )}
+
+
+
+ );
+};
+
+export default RoomItem;
diff --git a/src/components/common/RoomList/RoomItemStyles.tsx b/src/components/common/RoomList/RoomItemStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..4204af46c47911c5ea194ad308c055c58f1e7dd6
--- /dev/null
+++ b/src/components/common/RoomList/RoomItemStyles.tsx
@@ -0,0 +1,54 @@
+import { makeStyles, tokens, shorthands } from '@fluentui/react-components';
+
+const RoomItemStyles = makeStyles({
+ roomItemContainer: {
+ display: 'flex',
+ width: '100%',
+ alignItems: 'center',
+ ...shorthands.borderRadius(tokens.borderRadiusMedium),
+ marginTop: tokens.spacingHorizontalXS,
+ marginBottom: tokens.spacingHorizontalXS
+ },
+ roomButton: {
+ flexGrow: 1,
+ justifyContent: 'start',
+ textOverflow: 'ellipsis',
+ ...shorthands.overflow('hidden'),
+ whiteSpace: 'nowrap',
+ ':hover': {
+ backgroundColor: tokens.colorNeutralStroke2,
+ color: tokens.colorNeutralForeground1
+ },
+ fontWeight: tokens.fontWeightRegular
+ },
+ textArea: {
+ ...shorthands.overflow('hidden'),
+ whiteSpace: 'nowrap',
+ textOverflow: 'ellipsis'
+ },
+ menuButton: {
+ marginLeft: tokens.spacingHorizontalS,
+ ':hover': {
+ backgroundColor: tokens.colorNeutralStroke1
+ },
+ flexShrink: 0
+ },
+ selected: {
+ backgroundColor: tokens.colorNeutralStroke2,
+ color: tokens.colorNeutralForeground1,
+ ':hover': {
+ backgroundColor: tokens.colorNeutralStroke2,
+ color: tokens.colorNeutralForeground1
+ }
+ },
+ unselected: {
+ backgroundColor: tokens.colorNeutralBackground1,
+ color: tokens.colorNeutralForeground1,
+ ':hover': {
+ backgroundColor: tokens.colorNeutralStroke2,
+ color: tokens.colorNeutralForeground1
+ }
+ }
+});
+
+export default RoomItemStyles;
diff --git a/src/components/common/RoomList/RoomList.tsx b/src/components/common/RoomList/RoomList.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..06d35acd330dbb08205984e60dc3e8517b85a730
--- /dev/null
+++ b/src/components/common/RoomList/RoomList.tsx
@@ -0,0 +1,144 @@
+import { useState, useRef, useEffect } from 'react';
+import RoomItem from './RoomItem';
+import { Room } from '../../../models/Room';
+import { Button, Input } from '@fluentui/react-components';
+import RoomListStyles from './RoomListStyles';
+import { useTranslation } from 'react-i18next';
+import { useUser } from '../../../context/UserProvider';
+import {
+ createRoom,
+ deleteRoom,
+ getRooms,
+ updateRoom
+} from '../../../api/roomsApi';
+import { useToast } from '../../../context/ToastProvider';
+
+const RoomList = () => {
+ const styles = RoomListStyles();
+ const { t } = useTranslation();
+ const { user } = useUser();
+ const { showToast } = useToast();
+ const [rooms, setRooms] = useState([]);
+ const [isCreating, setIsCreating] = useState(false);
+ const [newRoomName, setNewRoomName] = useState('');
+ const newRoomInputRef = useRef(null);
+
+ // change focus to input for rename or new room
+ useEffect(() => {
+ if (isCreating) {
+ newRoomInputRef.current?.focus();
+ }
+ }, [isCreating]);
+
+ // fetch all rooms for the user initially
+ useEffect(() => {
+ if (user && user.auth0_id) {
+ getRooms(user.auth0_id)
+ .then((fetchedRooms) => {
+ setRooms(fetchedRooms);
+ })
+ .catch((error) => {
+ const errorMessage =
+ error.response?.data?.error || t('unexpectedErrorOccurred');
+ showToast(`${t('errorFetchingRooms')}: ${errorMessage}`, 'error');
+ setRooms([]);
+ });
+ }
+ }, [user, t, showToast]);
+
+ const handleShowCreateInput = () => {
+ setIsCreating(true);
+ };
+
+ const handleCreateRoom = () => {
+ if (newRoomName.trim() !== '') {
+ createRoom(user!.auth0_id, newRoomName)
+ .then((createdRoom) => {
+ setRooms((prevRooms) => [...prevRooms, createdRoom]);
+ showToast(t('roomCreatedSuccessfully'), 'success');
+ setIsCreating(false);
+ setNewRoomName('');
+ })
+ .catch((error) => {
+ const errorMessage =
+ error.response?.data?.error || t('unexpectedErrorOccurred');
+ showToast(t('errorCreateRoom') + ': ' + errorMessage, 'error');
+ setIsCreating(false);
+ });
+ } else {
+ setIsCreating(false);
+ }
+ };
+
+ const handleRename = (roomId: string, newName: string) => {
+ const roomToUpdate = rooms.find((room) => room.id === roomId);
+ if (roomToUpdate) {
+ const updatedRoom = { ...roomToUpdate, name: newName };
+ updateRoom(updatedRoom)
+ .then((response) => {
+ const updatedRooms = rooms.map((room) =>
+ room.id === roomId ? response : room
+ );
+ setRooms(updatedRooms);
+ showToast(t('roomRenamedSuccessfully'), 'success');
+ })
+ .catch((error) => {
+ const errorMessage =
+ error.response?.data?.error || t('unexpectedErrorOccurred');
+ showToast(t('errorRenameRoom') + ': ' + errorMessage, 'error');
+ });
+ }
+ };
+
+ const handleDelete = (roomId: string) => {
+ deleteRoom(roomId)
+ .then(() => {
+ const updatedRooms = rooms.filter((room) => room.id !== roomId);
+ setRooms(updatedRooms);
+ showToast(t('roomDeletedSuccessfully'), 'success');
+ })
+ .catch((error) => {
+ const errorMessage =
+ error.response?.data?.error || t('unexpectedErrorOccurred');
+ showToast(t('errorDeleteRoom') + ': ' + errorMessage, 'error');
+ });
+ };
+
+ return (
+
+
+ {isCreating && (
+ setNewRoomName(data.value || '')}
+ onBlur={handleCreateRoom}
+ onKeyDown={(e) => {
+ if (e.key === 'Enter') {
+ handleCreateRoom();
+ e.preventDefault();
+ }
+ }}
+ placeholder={t('roomNamePlaceholder')}
+ />
+ )}
+ {rooms.map((room, index) => (
+
+ ))}
+
+ );
+};
+
+export default RoomList;
diff --git a/src/components/common/RoomList/RoomListStyles.tsx b/src/components/common/RoomList/RoomListStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..a5ddb9287291136637c945d3c1c4374a181037d9
--- /dev/null
+++ b/src/components/common/RoomList/RoomListStyles.tsx
@@ -0,0 +1,11 @@
+import { makeStyles, tokens } from '@fluentui/react-components';
+
+const RoomListStyles = makeStyles({
+ createRoomButton: {
+ width: '100%',
+ marginBottom: tokens.spacingVerticalM,
+ marginTop: tokens.spacingVerticalS
+ }
+});
+
+export default RoomListStyles;
diff --git a/src/components/layout/ChatContainer/ChatContainer.tsx b/src/components/layout/ChatContainer/ChatContainer.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..c03054aa0338ae7781544f221265ee5cdc4aa8ec
--- /dev/null
+++ b/src/components/layout/ChatContainer/ChatContainer.tsx
@@ -0,0 +1,58 @@
+import ChatContainerStyles from './ChatContainerStyles';
+import { Message } from '../../../models/Message';
+import UserMessageItem from '../../common/Messages/UserMessageItem/UserMessageItem';
+import SearchMessageItem from '../../common/Messages/SearchMessageItem/SearchMessageItem';
+import ChatGPTMessageItem from '../../common/Messages/ChatGPTMessageItem/ChatGPTMessageItem';
+import { useEffect, useRef } from 'react';
+
+interface ChatContainerProps {
+ messages: Message[];
+ onSendToChatGPT: () => void;
+ isLoading?: boolean;
+}
+
+const ChatContainer = ({
+ messages,
+ onSendToChatGPT,
+ isLoading = false
+}: ChatContainerProps) => {
+ const styles = ChatContainerStyles();
+ const messagesEndRef = useRef(null);
+ useEffect(() => {
+ messagesEndRef.current?.scrollIntoView({ behavior: 'smooth' });
+ }, [messages]);
+
+ const renderMessageItem = (message: Message, index: number) => {
+ switch (message.role) {
+ case 'system':
+ return (
+
+ );
+ case 'assistant':
+ return (
+
+ );
+ default:
+ return (
+
+ );
+ }
+ };
+ return (
+
+ {messages.map((message, index) => renderMessageItem(message, index))}
+
+
+ );
+};
+
+export default ChatContainer;
diff --git a/src/components/layout/ChatContainer/ChatContainerStyles.tsx b/src/components/layout/ChatContainer/ChatContainerStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..887e9bed50fa8808e825f862f5a245ebff3c43ab
--- /dev/null
+++ b/src/components/layout/ChatContainer/ChatContainerStyles.tsx
@@ -0,0 +1,19 @@
+import { makeStyles, shorthands, tokens } from '@fluentui/react-components';
+
+const ChatContainerStyles = makeStyles({
+ container: {
+ display: 'flex',
+ flexDirection: 'column',
+ ...shorthands.gap('10px'),
+ paddingLeft: tokens.spacingHorizontalL,
+ paddingRight: tokens.spacingHorizontalL,
+ paddingTop: tokens.spacingVerticalL,
+ paddingBottom: tokens.spacingVerticalL,
+ marginLeft: tokens.spacingHorizontalXL,
+ marginRight: tokens.spacingHorizontalXL,
+ height: '68vh',
+ overflowY: 'auto'
+ }
+});
+
+export default ChatContainerStyles;
diff --git a/src/components/layout/Modal.tsx b/src/components/layout/Modal.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
diff --git a/src/components/layout/NavBar/NavBar.tsx b/src/components/layout/NavBar/NavBar.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..782c982c6d729b4c1fae8795fa17d0619b0fe41c
--- /dev/null
+++ b/src/components/layout/NavBar/NavBar.tsx
@@ -0,0 +1,68 @@
+import { NavLink, Link, useLocation } from 'react-router-dom';
+import { useAuth0 } from '@auth0/auth0-react';
+import LoginButton from '../../common/LoginButton/LoginButton';
+import LanguageSelector from '../../common/LanguageSelector/LanguageSelector';
+import NavBarStyles from './NavBarStyles';
+import { Divider } from '@fluentui/react-components';
+
+const NavBar = () => {
+ const styles = NavBarStyles();
+ const location = useLocation();
+ const { isAuthenticated } = useAuth0();
+ const logoPath = '/images/android-chrome-512x512.png';
+
+ const isChatActive = location.pathname.startsWith('/chat');
+ const isDemoActive = location.pathname.startsWith('/demo');
+
+ return (
+
+
+
+
+
ChatGPTfirewall
+
+
+
+
+ );
+};
+
+export default NavBar;
diff --git a/src/components/layout/NavBar/NavBarStyles.tsx b/src/components/layout/NavBar/NavBarStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..67f192b3e3b5101388706e6e87f1c489df2180e8
--- /dev/null
+++ b/src/components/layout/NavBar/NavBarStyles.tsx
@@ -0,0 +1,56 @@
+import { makeStyles, tokens } from '@fluentui/react-components';
+
+const NavBarStyles = makeStyles({
+ header: {
+ backgroundColor: tokens.colorBrandBackground,
+ color: tokens.colorNeutralForegroundOnBrand,
+ height: '55px'
+ },
+ headerContainer: {
+ display: 'flex',
+ alignItems: 'center',
+ justifyContent: 'space-between',
+ marginRight: tokens.spacingHorizontalL,
+ marginLeft: tokens.spacingHorizontalL
+ },
+ headerTitleContainer: {
+ display: 'flex',
+ alignItems: 'center',
+ marginRight: tokens.spacingHorizontalXXXL,
+ color: tokens.colorNeutralForegroundOnBrand,
+ textDecorationLine: 'none'
+ },
+ headerTitle: {
+ marginLeft: tokens.spacingHorizontalL,
+ fontWeight: tokens.fontWeightSemibold
+ },
+ headerNavList: {
+ display: 'flex',
+ alignItems: 'center'
+ },
+ headerNavPageLink: {
+ color: tokens.colorNeutralForegroundOnBrand,
+ textDecorationLine: 'none',
+ opacity: '0.75',
+ transitionTimingFunction: tokens.curveDecelerateMid,
+ transitionDuration: tokens.durationUltraSlow,
+ transitionProperty: 'opacity',
+ '&:hover': {
+ opacity: '1'
+ }
+ },
+ headerNavPageLinkActive: {
+ color: tokens.colorNeutralBackground1Selected,
+ fontWeight: tokens.fontWeightSemibold,
+ opacity: '1'
+ },
+ headerNavLeftMargin: {
+ marginLeft: tokens.spacingHorizontalL
+ },
+ appLogo: {
+ marginRight: '-12px',
+ width: '42px'
+ }
+});
+
+export default NavBarStyles;
diff --git a/src/components/layout/SettingsDrawer/SettingsDrawer.tsx b/src/components/layout/SettingsDrawer/SettingsDrawer.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..2b8834990aca91980a9142976d33c5c26027a0a2
--- /dev/null
+++ b/src/components/layout/SettingsDrawer/SettingsDrawer.tsx
@@ -0,0 +1,133 @@
+import SettingsDrawerStyles from './SettingsDrawerStyles';
+import {
+ Button,
+ DrawerBody,
+ DrawerHeader,
+ DrawerHeaderTitle,
+ Field,
+ OverlayDrawer,
+ Select,
+ SpinButton,
+ Textarea
+} from '@fluentui/react-components';
+import { Dismiss24Regular } from '@fluentui/react-icons';
+import { useTranslation } from 'react-i18next';
+import { Room, RoomSettings } from '../../../models/Room';
+import { useEffect, useState } from 'react';
+
+type LanguageKey = keyof RoomSettings['templates'];
+
+interface SettingsDrawerProps {
+ open: boolean;
+ closeDrawer: () => void;
+ room: Room;
+ onSave: (updatedSettings: RoomSettings) => void;
+}
+
+const SettingsDrawer = ({
+ open,
+ closeDrawer,
+ room,
+ onSave
+}: SettingsDrawerProps) => {
+ const styles = SettingsDrawerStyles();
+ const { t } = useTranslation();
+ const [promptTemplate, setPromptTemplate] = useState(
+ room.settings.prompt_template
+ );
+ const [phraseCount, setPhraseCount] = useState(
+ room.settings.pre_phrase_count
+ );
+
+ const handleTemplateChange = (
+ event: React.ChangeEvent
+ ) => {
+ const templateKey = event.target.value as LanguageKey;
+ setPromptTemplate(room.settings.templates?.[templateKey] ?? '');
+ };
+
+ const handleSaveClick = () => {
+ const updatedSettings: RoomSettings = {
+ ...room.settings,
+ prompt_template: promptTemplate,
+ pre_phrase_count: phraseCount,
+ post_phrase_count: phraseCount
+ };
+
+ onSave(updatedSettings);
+ };
+
+ useEffect(() => {
+ if (!open) {
+ setPromptTemplate(room.settings.prompt_template);
+ setPhraseCount(room.settings.pre_phrase_count);
+ }
+ }, [open, room.settings]);
+
+ return (
+
+
+
+ }
+ onClick={closeDrawer}
+ />
+ }
+ >
+ {t('settingsDrawerTitle')}
+
+
+
+
+
+
+
+
+
+
+ {
+ setPhraseCount(data.value!);
+ }}
+ min={0}
+ max={4}
+ />
+
+
+
+
+
+
+ );
+};
+
+export default SettingsDrawer;
diff --git a/src/components/layout/SettingsDrawer/SettingsDrawerStyles.tsx b/src/components/layout/SettingsDrawer/SettingsDrawerStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..328c7bb872b9a2d2ca7155d3662369e0437cb187
--- /dev/null
+++ b/src/components/layout/SettingsDrawer/SettingsDrawerStyles.tsx
@@ -0,0 +1,28 @@
+import { makeStyles, tokens, shorthands } from '@fluentui/react-components';
+
+const SettingsDrawerStyles = makeStyles({
+ promptTemplateSelectContainer: {},
+ resultSentenceCountContainer: {
+ display: 'flex',
+ ...shorthands.gap(tokens.spacingHorizontalXL)
+ },
+ resultSentenceCountLabel: {
+ alignSelf: 'center'
+ },
+ settingsBody: {
+ display: 'flex',
+ flexDirection: 'column',
+ ...shorthands.gap(tokens.spacingHorizontalXXL)
+ },
+ textArea: {
+ minHeight: '52px',
+ height: '260px',
+ maxHeight: '480px'
+ },
+ saveButton: {
+ width: '160px',
+ alignSelf: 'end'
+ }
+});
+
+export default SettingsDrawerStyles;
diff --git a/src/components/layout/SideBar/SideBar.tsx b/src/components/layout/SideBar/SideBar.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..2a2e62a7417334664d641f833e135bf671823dc6
--- /dev/null
+++ b/src/components/layout/SideBar/SideBar.tsx
@@ -0,0 +1,64 @@
+import { useState, useEffect } from 'react';
+import {
+ ChevronRight24Regular,
+ ChevronLeft24Regular
+} from '@fluentui/react-icons';
+import RoomList from '../../common/RoomList/RoomList';
+import {
+ Divider,
+ DrawerBody,
+ DrawerHeader,
+ InlineDrawer
+} from '@fluentui/react-components';
+import FileExplorer from '../../common/FileExplorer/FileExplorer';
+import SideBarStyles from './SideBarStyles';
+
+const Sidebar = () => {
+ const styles = SideBarStyles();
+ const [collapsed, setCollapsed] = useState(() => {
+ const isCollapsed = localStorage.getItem('sidebarCollapsed');
+ return isCollapsed === 'true';
+ });
+
+ const toggleSidebar = () => {
+ setCollapsed(!collapsed);
+ };
+
+ useEffect(() => {
+ localStorage.setItem('sidebarCollapsed', String(collapsed));
+ }, [collapsed]);
+
+ return (
+
+
+
+
+
+
+
+
+
+
+
+ {!collapsed ? (
+
+ ) : (
+
+ )}
+
+
+ );
+};
+
+export default Sidebar;
diff --git a/src/components/layout/SideBar/SideBarStyles.tsx b/src/components/layout/SideBar/SideBarStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..48c97e93df4d082a7c0091eb4b1fef5278f91330
--- /dev/null
+++ b/src/components/layout/SideBar/SideBarStyles.tsx
@@ -0,0 +1,38 @@
+import { makeStyles, tokens } from '@fluentui/react-components';
+
+const SideBarStyles = makeStyles({
+ drawer: {
+ width: '212px'
+ },
+ divider: {
+ marginTop: tokens.spacingVerticalS,
+ marginBottom: tokens.spacingVerticalS
+ },
+ sidebarContainer: {
+ display: 'flex'
+ },
+ collapsed: {
+ width: '0'
+ },
+ toggleArea: {
+ display: 'flex',
+ alignItems: 'center',
+ justifyContent: 'center',
+ color: tokens.colorNeutralForeground4
+ },
+ toggleIcon: {
+ cursor: 'pointer',
+ paddingTop: tokens.spacingVerticalM,
+ paddingBottom: tokens.spacingVerticalM,
+ ':hover': {
+ color: tokens.colorNeutralForeground1Hover
+ }
+ },
+ createRoomButton: {
+ width: '100%',
+ marginBottom: tokens.spacingVerticalM,
+ marginTop: tokens.spacingVerticalS
+ }
+});
+
+export default SideBarStyles;
diff --git a/src/context/ToastProvider.tsx b/src/context/ToastProvider.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..8bd550713c98de48e2be257b9fedd7a735614412
--- /dev/null
+++ b/src/context/ToastProvider.tsx
@@ -0,0 +1,53 @@
+import React, { createContext, useContext, ReactNode } from 'react';
+import {
+ Toaster,
+ useToastController,
+ Toast,
+ ToastTitle,
+ ToastBody,
+ ToastIntent
+} from '@fluentui/react-components';
+import { useTranslation } from 'react-i18next';
+
+const ToastContext = createContext({
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
+ showToast: (_message: string, _type: ToastIntent) => {}
+});
+
+// eslint-disable-next-line react-refresh/only-export-components
+export const useToast = () => useContext(ToastContext);
+
+export const ToastProvider: React.FC<{ children: ReactNode }> = ({
+ children
+}) => {
+ const { t } = useTranslation();
+ const toasterId = 'mainToaster';
+ const { dispatchToast } = useToastController(toasterId);
+
+ const showToast = (message: string, type: ToastIntent) => {
+ const titles: Record = {
+ success: t('actionSuccessful'),
+ error: t('actionFailed'),
+ warning: t('actionWarning'),
+ info: t('actionNotice')
+ };
+
+ const title = titles[type] || t('actionNotice');
+
+ const toastContent = (
+
+ {title}
+ {message}
+
+ );
+
+ dispatchToast(toastContent, { intent: type });
+ };
+
+ return (
+
+
+ {children}
+
+ );
+};
diff --git a/src/context/UserProvider.tsx b/src/context/UserProvider.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..bdd6f4650df3748036f8b4b701bcd930b30015bb
--- /dev/null
+++ b/src/context/UserProvider.tsx
@@ -0,0 +1,80 @@
+import React, {
+ createContext,
+ useContext,
+ ReactNode,
+ useState,
+ useEffect,
+ FunctionComponent
+} from 'react';
+import { User } from '../models/User'; // Stelle sicher, dass der Pfad korrekt ist
+import { useAuth0 } from '@auth0/auth0-react';
+import { getUser, createUser } from '../api/usersApi'; // Stelle sicher, dass der Pfad korrekt ist
+import { useTranslation } from 'react-i18next';
+
+type UserContextType = {
+ user: User | null;
+ setUser: React.Dispatch>;
+};
+
+const UserContext = createContext(undefined);
+
+// eslint-disable-next-line react-refresh/only-export-components
+export const useUser = () => {
+ const context = useContext(UserContext);
+ if (context === undefined) {
+ throw new Error('useUser must be used within a UserProvider');
+ }
+ return context;
+};
+
+export const UserProvider: FunctionComponent<{ children: ReactNode }> = ({
+ children
+}) => {
+ const { i18n } = useTranslation();
+ const [user, setUser] = useState(null);
+ const { user: auth0User, isAuthenticated, isLoading } = useAuth0();
+ const { getAccessTokenSilently } = useAuth0();
+
+ useEffect(() => {
+ const fetchUserFromBackend = async () => {
+ if (!isLoading && isAuthenticated && auth0User?.sub) {
+ try {
+ const audience = import.meta.env.VITE_JWT_AUDIENCE as string;
+ const accessToken = await getAccessTokenSilently({
+ authorizationParams: {
+ audience
+ }
+ });
+ localStorage.setItem('userToken', accessToken);
+ const fetchedUser = await getUser(auth0User.sub);
+ setUser(fetchedUser);
+ } catch (error) {
+ console.error(
+ 'Error fetching user from backend, creating new one.',
+ error
+ );
+ const newUser: User = {
+ auth0_id: auth0User.sub,
+ username: auth0User.name || '',
+ email: auth0User.email || '',
+ lang: i18n.language,
+ max_api_calls: auth0User.max_api_calls
+ };
+ createUser(newUser)
+ .then(setUser)
+ .catch((creationError) => {
+ console.error('Error creating user in backend!', creationError);
+ });
+ }
+ }
+ };
+
+ fetchUserFromBackend();
+ }, [auth0User, isAuthenticated, isLoading, i18n.language]);
+
+ return (
+
+ {children}
+
+ );
+};
diff --git a/src/i18n.ts b/src/i18n.ts
new file mode 100644
index 0000000000000000000000000000000000000000..0bb211743cec7790dc2ba993e7e5ff95669eba5a
--- /dev/null
+++ b/src/i18n.ts
@@ -0,0 +1,16 @@
+import i18n from 'i18next';
+import { initReactI18next } from 'react-i18next';
+import Backend from 'i18next-http-backend';
+
+i18n
+ .use(Backend)
+ .use(initReactI18next)
+ .init({
+ fallbackLng: 'en',
+ debug: true,
+ interpolation: {
+ escapeValue: false
+ }
+ });
+
+export default i18n;
diff --git a/src/main.css b/src/main.css
new file mode 100644
index 0000000000000000000000000000000000000000..8625db0b302cc2f372c51ba3ef7c1f7879196a33
--- /dev/null
+++ b/src/main.css
@@ -0,0 +1,7 @@
+html,
+body,
+#root {
+ height: 100%;
+ margin: 0;
+ padding: 0;
+}
diff --git a/src/main.tsx b/src/main.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..68dfbb8610defd948ca48964b7900ef950226d5c
--- /dev/null
+++ b/src/main.tsx
@@ -0,0 +1,72 @@
+import * as React from 'react';
+import * as ReactDOM from 'react-dom/client';
+
+import { Auth0Provider } from '@auth0/auth0-react';
+
+import App from './App.tsx';
+import './i18n';
+import './main.css';
+import {
+ BrandVariants,
+ FluentProvider,
+ createDarkTheme,
+ createLightTheme,
+ Theme
+} from '@fluentui/react-components';
+import { UserProvider } from './context/UserProvider.tsx';
+import { ToastProvider } from './context/ToastProvider.tsx';
+
+const chatGPTfirewall: BrandVariants = {
+ 10: '#010308',
+ 20: '#07172E',
+ 30: '#00264E',
+ 40: '#003264',
+ 50: '#193E72',
+ 60: '#2D4A7E',
+ 70: '#3F568A',
+ 80: '#506396',
+ 90: '#6170A1',
+ 100: '#717EAB',
+ 110: '#828CB6',
+ 120: '#939AC0',
+ 130: '#A3A9CA',
+ 140: '#B4B8D4',
+ 150: '#C4C7DD',
+ 160: '#D5D6E7'
+};
+
+const lightTheme: Theme = {
+ ...createLightTheme(chatGPTfirewall)
+};
+
+const darkTheme: Theme = {
+ ...createDarkTheme(chatGPTfirewall)
+};
+
+darkTheme.colorBrandForeground1 = chatGPTfirewall[110];
+darkTheme.colorBrandForeground2 = chatGPTfirewall[120];
+
+const rootElement = document.getElementById('root')!;
+const audience = import.meta.env.VITE_JWT_AUDIENCE as string;
+
+ReactDOM.createRoot(rootElement).render(
+
+
+
+
+
+
+
+
+
+
+
+);
diff --git a/src/models/AnonymizationMapping.ts b/src/models/AnonymizationMapping.ts
new file mode 100644
index 0000000000000000000000000000000000000000..153eb64e20b51df3dd60fa531a64d5c6713a41ca
--- /dev/null
+++ b/src/models/AnonymizationMapping.ts
@@ -0,0 +1,8 @@
+import { Room } from './Room';
+
+export type AnonymizationMapping = {
+ room: Room;
+ anonymized: string;
+ deanonymized: string;
+ entityType: string;
+};
diff --git a/src/models/File.ts b/src/models/File.ts
new file mode 100644
index 0000000000000000000000000000000000000000..344c7b86af40d9e21252c0846a2c4eb8b71bfeb9
--- /dev/null
+++ b/src/models/File.ts
@@ -0,0 +1,16 @@
+import { User } from './User';
+
+export type File = {
+ id?: string;
+ filename: string;
+ user?: User;
+ lang?: string;
+ fileSize: number;
+ uploadedAt?: Date;
+ isUploading?: boolean;
+};
+
+export type FileResponse = {
+ error?: string;
+ files: File[];
+};
diff --git a/src/models/Message.ts b/src/models/Message.ts
new file mode 100644
index 0000000000000000000000000000000000000000..dd6c216ebb85331e96744052f56dba649563f7d1
--- /dev/null
+++ b/src/models/Message.ts
@@ -0,0 +1,22 @@
+import { Room } from './Room';
+import { User } from './User';
+
+export type Message = {
+ id?: string;
+ user: User;
+ room: Room;
+ role: string;
+ content: string | Result[];
+ created_at: string;
+};
+
+export type Result = {
+ fileName: string;
+ accuracy: number;
+ content: string;
+ contextBefore?: string;
+ contextAfter?: string;
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
+ entities?: any[];
+ original_entities?: any[];
+};
diff --git a/src/models/Room.ts b/src/models/Room.ts
new file mode 100644
index 0000000000000000000000000000000000000000..ed1de5572c6af042a9b4c1e31813f6f8a8e40396
--- /dev/null
+++ b/src/models/Room.ts
@@ -0,0 +1,26 @@
+import { AnonymizationMapping } from './AnonymizationMapping';
+import { File } from './File';
+import { Message } from './Message';
+import { User } from './User';
+
+export type Room = {
+ id: string;
+ user: User;
+ name: string;
+ anonymizeCompleteContext: boolean;
+ settings: RoomSettings;
+ files: File[];
+ messages: Message[];
+ anonymizationMappings: AnonymizationMapping[];
+ created_at: Date;
+};
+
+export type RoomSettings = {
+ templates: {
+ de: string;
+ en: string;
+ };
+ prompt_template: string;
+ pre_phrase_count: number;
+ post_phrase_count: number;
+};
diff --git a/src/models/User.ts b/src/models/User.ts
new file mode 100644
index 0000000000000000000000000000000000000000..8976f1d84dab794da57012c5f60dad79b50ba9f8
--- /dev/null
+++ b/src/models/User.ts
@@ -0,0 +1,7 @@
+export type User = {
+ auth0_id: string;
+ username: string;
+ email: string;
+ lang: string;
+ max_api_calls: number;
+};
diff --git a/src/pages/Chat/Chat.tsx b/src/pages/Chat/Chat.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..2f0dae1b63abe62357f9683babfb6888a8929f97
--- /dev/null
+++ b/src/pages/Chat/Chat.tsx
@@ -0,0 +1,24 @@
+import TutorialCards from '../../components/common/Cards/GuideCards/GuideCards';
+import { useTranslation } from 'react-i18next';
+import ChatStyles from './ChatStyles';
+
+const Chat = () => {
+ const styles = ChatStyles();
+ const { t } = useTranslation();
+
+ return (
+
+
+
+
ChatGPTfirewall
+
+ {t('tutorialCardsSubtitle')}
+
+
+
+
+
+ );
+};
+
+export default Chat;
diff --git a/src/pages/Chat/ChatStyles.tsx b/src/pages/Chat/ChatStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..0cd166bccff7a5c2919f1cbfec8de45c490e83d3
--- /dev/null
+++ b/src/pages/Chat/ChatStyles.tsx
@@ -0,0 +1,32 @@
+import {
+ makeStyles,
+ tokens,
+ typographyStyles
+} from '@fluentui/react-components';
+
+const ChatStyles = makeStyles({
+ chatRoot: {
+ display: 'flex',
+ overflowY: 'auto',
+ marginTop: tokens.spacingVerticalXL,
+ width: '100%'
+ },
+ chatContainer: {
+ flexGrow: 1,
+ display: 'flex',
+ flexDirection: 'column',
+ alignItems: 'center',
+ width: '100%'
+ },
+ chatEmptyState: {
+ flexGrow: 1,
+ display: 'flex',
+ flexDirection: 'column',
+ justifyContent: 'center',
+ alignItems: 'center'
+ },
+ chatEmptyStateTitle: typographyStyles.display,
+ chatEmptyStateSubtitle: typographyStyles.subtitle1
+});
+
+export default ChatStyles;
diff --git a/src/pages/Demo/Demo.tsx b/src/pages/Demo/Demo.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..1be23ff2acd2ad916317a77f1c730d6df834b63d
--- /dev/null
+++ b/src/pages/Demo/Demo.tsx
@@ -0,0 +1,331 @@
+import { useTranslation } from 'react-i18next';
+import DemoStyles from './DemoStyles';
+import { Button, Switch } from '@fluentui/react-components';
+import { DocumentBulletListMultiple24Regular } from '@fluentui/react-icons';
+import { useState, useEffect, useCallback, ChangeEvent } from 'react';
+import { File } from '../../models/File';
+import ChatInput from '../../components/common/Messages/ChatInput/ChatInput';
+import { Room } from '../../models/Room';
+import { getRooms, updateRoomFiles } from '../../api/roomsApi';
+import { useToast } from '../../context/ToastProvider';
+import ChatContainer from '../../components/layout/ChatContainer/ChatContainer';
+import { Message, Result } from '../../models/Message';
+import {
+ createChatGPTMessage,
+ createSearchMessage
+} from '../../api/messageApi';
+import FileSelector from '../../components/common/FileSelector/FileSelector';
+import ExampleCards from '../../components/common/Cards/ExampleCards/ExampleCards';
+import { AnonymizationMapping } from '../../models/AnonymizationMapping';
+
+const demoUserIdDE = 'auth0|demo_user_de';
+const demoUserIdEN = 'auth0|demo_user_en';
+
+const Demo = () => {
+ const styles = DemoStyles();
+ const { t, i18n } = useTranslation();
+ const { showToast } = useToast();
+ const [room, setRoom] = useState(null);
+ const [anonymized, setAnonymized] = useState(true);
+ const [isMessageLoading, setIsMessageLoading] = useState(false);
+
+ const anonymizeContent = useCallback(
+ (
+ content: string,
+ anonymizationMappings: AnonymizationMapping[],
+ anonymize: boolean
+ ) => {
+ const anonymizeString = (inputString: string) => {
+ const sortedMappings = [...anonymizationMappings].sort(
+ (a, b) => b.deanonymized.length - a.deanonymized.length
+ );
+ return sortedMappings.reduce((acc, { anonymized, deanonymized }) => {
+ const target = anonymize ? deanonymized : anonymized;
+ const replacement = anonymize ? anonymized : deanonymized;
+ const regex = new RegExp(`\\b${target}\\b`, 'g');
+ return acc.replace(regex, replacement);
+ }, inputString);
+ };
+
+ return anonymizeString(content);
+ },
+ []
+ );
+
+ useEffect(() => {
+ const fetchDemoUser = (auth0_id: string) => {
+ getRooms(auth0_id)
+ .then((fetchedRooms) => {
+ setRoom(fetchedRooms[0]);
+ })
+ .catch((error) => {
+ const errorMessage =
+ error.response?.data?.error || t('unexpectedErrorOccurred');
+ showToast(`${t('errorFetchingRooms')}: ${errorMessage}`, 'error');
+ });
+ };
+
+ i18n.language.startsWith('en')
+ ? fetchDemoUser(demoUserIdEN)
+ : fetchDemoUser(demoUserIdDE);
+ }, [i18n.language, showToast, t]);
+
+ useEffect(() => {
+ setRoom((prevRoom) => {
+ if (!prevRoom) return null;
+
+ const updatedMessages = prevRoom.messages.map((message) => {
+ let updatedContent = message.content;
+ if (message.role === 'system' && Array.isArray(message.content)) {
+ updatedContent = message.content.map((contentObj) => ({
+ ...contentObj,
+ content: anonymizeContent(
+ contentObj.content,
+ prevRoom.anonymizationMappings,
+ anonymized
+ )
+ }));
+ } else if (typeof message.content === 'string') {
+ updatedContent = anonymizeContent(
+ message.content,
+ prevRoom.anonymizationMappings,
+ anonymized
+ );
+ }
+ return { ...message, content: updatedContent };
+ });
+
+ return { ...prevRoom, messages: updatedMessages };
+ });
+ }, [anonymized, anonymizeContent]);
+
+ const toggleAnonymization = useCallback(
+ (ev: ChangeEvent) => {
+ setAnonymized(ev.currentTarget.checked);
+ },
+ [setAnonymized]
+ );
+
+ const onExampleClicked = (example?: string) => {
+ onSendMessage(example!);
+ };
+
+ const handleSelectedFiles = (selectedFiles: File[]) => {
+ if (!room) {
+ showToast(t('errorNoRoom'), 'error');
+ return;
+ }
+
+ const fileIds = selectedFiles.map((file) => file.id || '');
+
+ updateRoomFiles(room.id, fileIds)
+ .then((updatedRoom) => {
+ setRoom(updatedRoom);
+ })
+ .catch((error) => {
+ const errorMessage =
+ error.response?.data?.error || t('unexpectedErrorOccurred');
+ showToast(
+ `${t('errorUpdatingRoomDocuments')}: ${errorMessage}`,
+ 'error'
+ );
+ });
+ };
+ const onSendMessage = (value: string) => {
+ if (!room) {
+ showToast(t('errorNoRoom'), 'error');
+ return;
+ }
+
+ const newMessage: Message = {
+ user: room.user,
+ room: room,
+ role: 'user',
+ content: value,
+ created_at: new Date().toISOString()
+ };
+
+ const tempMessage: Message = {
+ user: room.user,
+ room: room,
+ role: 'system',
+ content: [],
+ created_at: new Date().toISOString()
+ };
+
+ setIsMessageLoading(true);
+
+ const updatedRoomWithoutTemp = {
+ ...room,
+ messages: [...room.messages, newMessage]
+ };
+ setRoom(updatedRoomWithoutTemp);
+
+ const updatedRoom = {
+ ...room,
+ messages: [...room.messages, newMessage, tempMessage]
+ };
+ setRoom(updatedRoom);
+
+ createSearchMessage(newMessage)
+ .then((createdMessage) => {
+ if (Array.isArray(createdMessage.content)) {
+ createdMessage.content.forEach((contentObj: Result) => {
+ if (anonymized) {
+ contentObj.content = anonymizeContent(
+ contentObj.content,
+ createdMessage.room.anonymizationMappings,
+ anonymized
+ );
+ }
+ });
+ }
+
+ setRoom((prevRoom) => {
+ if (!prevRoom) return null;
+
+ const filteredMessages = prevRoom.messages.filter(
+ (msg) => msg.role !== 'system'
+ );
+ const newMessages = [...filteredMessages, createdMessage];
+
+ return {
+ ...prevRoom,
+ messages: newMessages,
+ anonymizationMappings: createdMessage.room.anonymizationMappings
+ };
+ });
+ })
+ .catch((error) => {
+ const errorMessage =
+ error.response?.data?.error || t('unexpectedErrorOccurred');
+ showToast(`${t('errorSendingMessage')}: ${errorMessage}`, 'error');
+ })
+ .finally(() => setIsMessageLoading(false));
+ };
+
+ // Doc-Hint: Should be a different solution where message should be grouped together with question and context.
+ const messageToChatGPT = (room: Room) => {
+ let question = '';
+ let context = '';
+ const promptTemplate =
+ room.settings && room.settings.prompt_template
+ ? room.settings.prompt_template
+ : '';
+
+ if (room.messages && room.messages.length >= 2) {
+ const lastIndex = room.messages.length - 1;
+
+ question = room.messages[lastIndex - 1].content as string;
+
+ const contextResults = room.messages[lastIndex].content as Result[];
+ context = contextResults.map((result) => result.content).join('\n');
+ } else {
+ showToast(t('errorNotEnoughMessages'), 'error');
+ }
+
+ return `${promptTemplate}\n\n${t('question')}:\n${question}\n\n${t('context')}:\n${context}`;
+ };
+
+ const onSendToChatGPT = () => {
+ if (!room) {
+ showToast(t('errorNoRoom'), 'error');
+ return;
+ }
+
+ const chatGPTMessage: Message = {
+ user: room.user,
+ room: room,
+ role: 'user',
+ content: messageToChatGPT(room),
+ created_at: new Date().toISOString()
+ };
+
+ const tempMessage: Message = {
+ user: room.user,
+ room: room,
+ role: 'assistant',
+ content: 'Loading',
+ created_at: new Date().toISOString()
+ };
+
+ setIsMessageLoading(true);
+
+ const updatedRoom = {
+ ...room,
+ messages: [...room.messages, chatGPTMessage, tempMessage]
+ };
+ setRoom(updatedRoom);
+
+ createChatGPTMessage(chatGPTMessage, true)
+ .then((createdMessage) => {
+ const updatedMessages = updatedRoom.messages
+ .slice(0, -1)
+ .concat(createdMessage);
+ setRoom({
+ ...updatedRoom,
+ messages: updatedMessages
+ });
+ })
+ .catch((error) => {
+ const errorMessage =
+ error.response?.data?.error || t('unexpectedErrorOccurred');
+ showToast(
+ `${t('errorSendingMessageToChatGPT')}: ${errorMessage}`,
+ 'error'
+ );
+ })
+ .finally(() => setIsMessageLoading(false));
+ };
+
+ return (
+
+
+
+
+ (
+ }
+ />
+ )}
+ passedUser={room?.user}
+ />
+
+
+ {room && room.messages.length === 0 ? (
+
+
+
Demo
+
+ {t('exampleCardsSubtitle')}
+
+
+
+
+
+ ) : (
+
+
+
+
+ )}
+
+ );
+};
+
+export default Demo;
diff --git a/src/pages/Demo/DemoStyles.tsx b/src/pages/Demo/DemoStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..b66dd8d0e50ce63fa5f4dc0671701e301a383a1b
--- /dev/null
+++ b/src/pages/Demo/DemoStyles.tsx
@@ -0,0 +1,54 @@
+import {
+ makeStyles,
+ tokens,
+ typographyStyles
+} from '@fluentui/react-components';
+
+const DemoStyles = makeStyles({
+ chatRoot: {
+ display: 'flex',
+ flexDirection: 'column',
+ width: '100%'
+ },
+ header: {
+ zIndex: '50',
+ height: '8vh',
+ boxShadow: `0px 20px 17px 0px ${tokens.colorNeutralBackground1}`,
+ display: 'flex',
+ justifyContent: 'space-between',
+ alignItems: 'center',
+ paddingLeft: tokens.spacingHorizontalL
+ },
+ actions: {
+ display: 'flex',
+ height: '32px',
+ marginRight: tokens.spacingHorizontalL
+ },
+ exampleContainer: {
+ flexGrow: 1,
+ display: 'flex',
+ flexDirection: 'column',
+ alignItems: 'center',
+ width: '100%'
+ },
+ chatContainer: {
+ flexGrow: 1,
+ display: 'flex',
+ flexDirection: 'column',
+ width: '100%'
+ },
+ chatEmptyState: {
+ flexGrow: 1,
+ display: 'flex',
+ flexDirection: 'column',
+ justifyContent: 'center',
+ alignItems: 'center'
+ },
+ anonSwitch: {
+ width: '240px'
+ },
+ chatEmptyStateTitle: typographyStyles.display,
+ chatEmptyStateSubtitle: typographyStyles.subtitle1
+});
+
+export default DemoStyles;
diff --git a/src/pages/LandingPage/LandingPage.tsx b/src/pages/LandingPage/LandingPage.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..81f594675abb1630cc0d8c2675b68f0d23880253
--- /dev/null
+++ b/src/pages/LandingPage/LandingPage.tsx
@@ -0,0 +1,55 @@
+import { useAuth0 } from '@auth0/auth0-react';
+import { useTranslation } from 'react-i18next';
+import { Button, Link } from '@fluentui/react-components';
+import LandingPageStyles from './LandingPageStyles';
+
+const LandingPage = () => {
+ const styles = LandingPageStyles();
+ const { loginWithRedirect, isAuthenticated } = useAuth0();
+ const { t } = useTranslation();
+ const logoPath = '/images/android-chrome-512x512.png';
+
+ if (isAuthenticated) {
+ return null;
+ }
+
+ return (
+
+
+
+
{t('headerText')}
+
{t('subheaderText')}
+
+
+
+
+ {t('landingPage')}
+
+
+ {t('documentation')}
+
+
+ {t('githubRepo')}
+
+
+
+
+ );
+};
+
+export default LandingPage;
diff --git a/src/pages/LandingPage/LandingPageStyles.tsx b/src/pages/LandingPage/LandingPageStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..f22b3ed02bbeb2d8d9441d221b1c6f37265acd22
--- /dev/null
+++ b/src/pages/LandingPage/LandingPageStyles.tsx
@@ -0,0 +1,37 @@
+import { makeStyles, shorthands } from '@fluentui/react-components';
+
+const LandingPageStyles = makeStyles({
+ landingPage: {
+ display: 'flex',
+ justifyContent: 'center',
+ alignItems: 'start',
+ height: '100%'
+ },
+ landingContent: {
+ textAlign: 'center',
+ maxWidth: '600px',
+ paddingTop: '20px',
+ marginTop: '40px'
+ },
+ header: {
+ fontSize: '2.5rem',
+ marginBottom: '2rem'
+ },
+ subHeader: {
+ fontSize: '1.2rem',
+ marginBottom: '2rem'
+ },
+ appLogo: {
+ marginBottom: '-2rem',
+ width: '300px'
+ },
+ links: {
+ display: 'flex',
+ justifyContent: 'center',
+ marginTop: '40px',
+ color: '#007bff',
+ ...shorthands.gap('12px')
+ }
+});
+
+export default LandingPageStyles;
diff --git a/src/pages/Layout/Layout.tsx b/src/pages/Layout/Layout.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..116aa1f76063f81de485c1026d9467cfe8fed003
--- /dev/null
+++ b/src/pages/Layout/Layout.tsx
@@ -0,0 +1,35 @@
+import { Outlet, useLocation } from 'react-router-dom';
+import NavBar from '../../components/layout/NavBar/NavBar';
+import LayoutStyles from './LayoutStyles';
+import Sidebar from '../../components/layout/SideBar/SideBar';
+import { useAuth0 } from '@auth0/auth0-react';
+import LandingPage from '../LandingPage/LandingPage';
+
+const Layout = () => {
+ const styles = LayoutStyles();
+ const location = useLocation();
+ const { isAuthenticated } = useAuth0();
+ const hideSidebarRoutes = ['/demo', '/chat'];
+ const showSidebar =
+ isAuthenticated && !hideSidebarRoutes.includes(location.pathname);
+
+ if (!isAuthenticated) {
+ return (
+
+
+
+
+ );
+ }
+ return (
+
+
+
+ {showSidebar && }
+
+
+
+ );
+};
+
+export default Layout;
diff --git a/src/pages/Layout/LayoutStyles.tsx b/src/pages/Layout/LayoutStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..9770513fa5672d22e5afd80ed948832398f46801
--- /dev/null
+++ b/src/pages/Layout/LayoutStyles.tsx
@@ -0,0 +1,15 @@
+import { makeStyles } from '@fluentui/react-components';
+
+const LayoutStyles = makeStyles({
+ layout: {
+ display: 'flex',
+ flexDirection: 'column',
+ height: '100%'
+ },
+ container: {
+ display: 'flex',
+ height: '100%'
+ }
+});
+
+export default LayoutStyles;
diff --git a/src/pages/Page404/Page404.module.css b/src/pages/Page404/Page404.module.css
new file mode 100644
index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
diff --git a/src/pages/Page404/Page404.tsx b/src/pages/Page404/Page404.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..635a87a7dd4ff8217dc26b27aa8fce6d1d4836d3
--- /dev/null
+++ b/src/pages/Page404/Page404.tsx
@@ -0,0 +1,5 @@
+const Page404 = () => {
+ return 404 Page not found
;
+};
+
+export default Page404;
diff --git a/src/pages/Room/Room.tsx b/src/pages/Room/Room.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..abbf76988bc1f921eb163f55b0b9d47418a9a993
--- /dev/null
+++ b/src/pages/Room/Room.tsx
@@ -0,0 +1,387 @@
+import { RoomSettings, Room as RoomType } from '../../models/Room';
+import ChatContainer from '../../components/layout/ChatContainer/ChatContainer';
+import RoomStyles from './RoomStyles';
+import ChatInput from '../../components/common/Messages/ChatInput/ChatInput';
+import { Body1, Body1Strong, Button, Switch } from '@fluentui/react-components';
+import {
+ AddRegular,
+ DocumentAdd48Regular,
+ DocumentBulletListMultiple24Regular,
+ Settings32Regular
+} from '@fluentui/react-icons';
+import { File } from '../../models/File';
+import { useNavigate, useParams } from 'react-router-dom';
+import { useCallback, useEffect, useState } from 'react';
+import { Message, Result } from '../../models/Message';
+
+import { t } from 'i18next';
+import SettingsDrawer from '../../components/layout/SettingsDrawer/SettingsDrawer';
+import { useToast } from '../../context/ToastProvider';
+import { getRoom, updateRoom, updateRoomFiles } from '../../api/roomsApi';
+import {
+ createChatGPTMessage,
+ createSearchMessage
+} from '../../api/messageApi';
+import FileSelector from '../../components/common/FileSelector/FileSelector';
+import { AnonymizationMapping } from '../../models/AnonymizationMapping';
+
+const Room = () => {
+ const styles = RoomStyles();
+ const { id } = useParams();
+ const { showToast } = useToast();
+ const navigate = useNavigate();
+ const [room, setRoom] = useState(null);
+ const [settingsDrawerOpen, setSettingsDrawerOpenState] = useState(false);
+ const [anonymized, setAnonymized] = useState(true);
+ const [isMessageLoading, setIsMessageLoading] = useState(false);
+
+ const anonymizeContent = useCallback(
+ (
+ content: string,
+ anonymizationMappings: AnonymizationMapping[],
+ anonymize: boolean
+ ) => {
+ const anonymizeString = (inputString: string) => {
+ const sortedMappings = [...anonymizationMappings].sort(
+ (a, b) => b.deanonymized.length - a.deanonymized.length
+ );
+ return sortedMappings.reduce((acc, { anonymized, deanonymized }) => {
+ const target = anonymize ? deanonymized : anonymized;
+ const replacement = anonymize ? anonymized : deanonymized;
+ const regex = new RegExp(`\\b${target}\\b`, 'g');
+ return acc.replace(regex, replacement);
+ }, inputString);
+ };
+
+ return anonymizeString(content);
+ },
+ []
+ );
+
+ useEffect(() => {
+ if (id) {
+ getRoom(id)
+ .then((fetchedRoom) => {
+ setRoom(fetchedRoom);
+ })
+ .catch((error) => {
+ const errorMessage =
+ error.response?.data?.error || t('unexpectedErrorOccurred');
+ showToast(`${t('errorFetchingRoom')}: ${errorMessage}`, 'error');
+ navigate('/');
+ });
+ }
+ }, [id, showToast, navigate]);
+
+ useEffect(() => {
+ setRoom((prevRoom) => {
+ if (!prevRoom) return null;
+
+ const updatedMessages = prevRoom.messages.map((message) => {
+ let updatedContent = message.content;
+ if (message.role === 'system' && Array.isArray(message.content)) {
+ updatedContent = message.content.map((contentObj) => ({
+ ...contentObj,
+ content: anonymizeContent(
+ contentObj.content,
+ prevRoom.anonymizationMappings,
+ anonymized
+ )
+ }));
+ } else if (typeof message.content === 'string') {
+ updatedContent = anonymizeContent(
+ message.content,
+ prevRoom.anonymizationMappings,
+ anonymized
+ );
+ }
+ return { ...message, content: updatedContent };
+ });
+
+ return { ...prevRoom, messages: updatedMessages };
+ });
+ }, [anonymized, anonymizeContent]);
+
+ const toggleAnonymization = useCallback(
+ (ev: React.ChangeEvent) => {
+ setAnonymized(ev.currentTarget.checked);
+ },
+ [setAnonymized]
+ );
+
+ const onSendMessage = (value: string) => {
+ if (!room) {
+ showToast(t('errorNoRoom'), 'error');
+ return;
+ }
+
+ const newMessage: Message = {
+ user: room.user,
+ room: room,
+ role: 'user',
+ content: value,
+ created_at: new Date().toISOString()
+ };
+
+ const tempMessage: Message = {
+ user: room.user,
+ room: room,
+ role: 'system',
+ content: [],
+ created_at: new Date().toISOString()
+ };
+
+ setIsMessageLoading(true);
+
+ const updatedRoomWithoutTemp = {
+ ...room,
+ messages: [...room.messages, newMessage]
+ };
+ setRoom(updatedRoomWithoutTemp);
+
+ const updatedRoom = {
+ ...room,
+ messages: [...room.messages, newMessage, tempMessage]
+ };
+ setRoom(updatedRoom);
+
+ createSearchMessage(newMessage)
+ .then((createdMessage) => {
+ if (Array.isArray(createdMessage.content)) {
+ createdMessage.content.forEach((contentObj: Result) => {
+ if (anonymized) {
+ contentObj.content = anonymizeContent(
+ contentObj.content,
+ createdMessage.room.anonymizationMappings,
+ anonymized
+ );
+ }
+ });
+ }
+
+ setRoom((prevRoom) => {
+ if (!prevRoom) return null;
+
+ const filteredMessages = prevRoom.messages.filter(
+ (msg) => msg.role !== 'system'
+ );
+ const newMessages = [...filteredMessages, createdMessage];
+
+ return {
+ ...prevRoom,
+ messages: newMessages,
+ anonymizationMappings: createdMessage.room.anonymizationMappings
+ };
+ });
+ })
+ .catch((error) => {
+ const errorMessage =
+ error.response?.data?.error || t('unexpectedErrorOccurred');
+ showToast(`${t('errorSendingMessage')}: ${errorMessage}`, 'error');
+ })
+ .finally(() => setIsMessageLoading(false));
+ };
+ // Doc-Hint: Should be a different solution where message should be grouped together with question and context.
+ const messageToChatGPT = (room: RoomType) => {
+ let question = '';
+ let context = '';
+ const promptTemplate =
+ room.settings && room.settings.prompt_template
+ ? room.settings.prompt_template
+ : '';
+
+ if (room.messages && room.messages.length >= 2) {
+ const lastIndex = room.messages.length - 1;
+
+ question = room.messages[lastIndex - 1].content as string;
+
+ const contextResults = room.messages[lastIndex].content as Result[];
+ context = contextResults.map((result) => result.content).join('\n');
+ } else {
+ showToast(t('errorNotEnoughMessages'), 'error');
+ }
+
+ return `${promptTemplate}\n\n${t('question')}:\n${question}\n\n${t('context')}:\n${context}`;
+ };
+
+ const onSendToChatGPT = () => {
+ if (!room) {
+ showToast(t('errorNoRoom'), 'error');
+ return;
+ }
+
+ const chatGPTMessage: Message = {
+ user: room.user,
+ room: room,
+ role: 'user',
+ content: messageToChatGPT(room),
+ created_at: new Date().toISOString()
+ };
+
+ const tempMessage: Message = {
+ user: room.user,
+ room: room,
+ role: 'assistant',
+ content: 'Loading...',
+ created_at: new Date().toISOString()
+ };
+
+ setIsMessageLoading(true);
+
+ const updatedRoom = {
+ ...room,
+ messages: [...room.messages, chatGPTMessage, tempMessage]
+ };
+ setRoom(updatedRoom);
+
+ createChatGPTMessage(chatGPTMessage)
+ .then((createdMessage) => {
+ const updatedMessages = updatedRoom.messages
+ .slice(0, -1)
+ .concat(createdMessage);
+ setRoom({
+ ...updatedRoom,
+ messages: updatedMessages
+ });
+ })
+ .catch((error) => {
+ const errorMessage =
+ error.response?.data?.error || t('unexpectedErrorOccurred');
+ showToast(
+ `${t('errorSendingMessageToChatGPT')}: ${errorMessage}`,
+ 'error'
+ );
+ })
+ .finally(() => setIsMessageLoading(false));
+ };
+
+ const handleSelectedFiles = (selectedFiles: File[]) => {
+ if (!room) {
+ showToast(t('errorNoRoom'), 'error');
+ return;
+ }
+
+ const fileIds = selectedFiles.map((file) => file.id || '');
+
+ updateRoomFiles(room.id, fileIds)
+ .then((updatedRoom) => {
+ setRoom(updatedRoom);
+ })
+ .catch((error) => {
+ const errorMessage =
+ error.response?.data?.error || t('unexpectedErrorOccurred');
+ showToast(
+ `${t('errorUpdatingRoomDocuments')}: ${errorMessage}`,
+ 'error'
+ );
+ });
+ };
+
+ const onSaveSettings = (updatedSettings: RoomSettings) => {
+ if (!room) {
+ showToast(t('errorNoRoom'), 'error');
+ return;
+ }
+
+ const updatedRoom = {
+ ...room,
+ settings: updatedSettings
+ };
+
+ updateRoom(updatedRoom)
+ .then((updatedRoom) => {
+ setRoom(updatedRoom);
+ showToast(t('settingsSavedSuccessfully'), 'success');
+ })
+ .catch((error) => {
+ const errorMessage =
+ error.response?.data?.error || t('unexpectedErrorOccurred');
+ showToast(`${t('errorSavingSettings')}: ${errorMessage}`, 'error');
+ });
+
+ closeSettingsDrawer();
+ };
+
+ const openSettingsDrawer = () => {
+ setSettingsDrawerOpenState(true);
+ };
+
+ const closeSettingsDrawer = () => {
+ setSettingsDrawerOpenState(false);
+ };
+
+ // Empty files list state
+ if (!room || room.files.length === 0) {
+ return (
+
+
+
+ {t('emptyStateBodyTextStrong')}
+ {t('emptyStateBodyText')}
+
+
(
+ }
+ className={styles.emptyAddFilesButton}
+ >
+ {t('addFilesEmptyPage')}
+
+ )}
+ />
+
+ );
+ }
+
+ return (
+
+
+
{room.name}
+
+
+ }
+ onClick={openSettingsDrawer}
+ />
+
+ (
+ }
+ />
+ )}
+ />
+
+
+
+
+
+ );
+};
+
+export default Room;
diff --git a/src/pages/Room/RoomStyles.tsx b/src/pages/Room/RoomStyles.tsx
new file mode 100644
index 0000000000000000000000000000000000000000..e4da3822d333dce872ab3e9999750770956b6336
--- /dev/null
+++ b/src/pages/Room/RoomStyles.tsx
@@ -0,0 +1,65 @@
+import { makeStyles, tokens, shorthands } from '@fluentui/react-components';
+
+const RoomStyles = makeStyles({
+ roomContainer: {
+ display: 'flex',
+ flexDirection: 'column',
+ width: '100%'
+ },
+ chatSection: {
+ width: '100%',
+ maxWidth: '800px',
+ ...shorthands.border('1px solid gray'),
+ ...shorthands.borderRadius('8px'),
+ ...shorthands.overflow('hidden'),
+ display: 'flex',
+ flexDirection: 'column'
+ },
+ header: {
+ zIndex: '50',
+ height: '8vh',
+ boxShadow: `0px 20px 17px 0px ${tokens.colorNeutralBackground1}`,
+ display: 'flex',
+ justifyContent: 'space-between',
+ alignItems: 'center'
+ },
+ headerTitle: {
+ fontWeight: tokens.fontWeightSemibold,
+ fontSize: tokens.fontSizeBase500,
+ display: 'flex',
+ alignItems: 'center'
+ },
+ actions: {
+ display: 'flex',
+ height: '32px',
+ marginRight: tokens.spacingHorizontalL
+ },
+ emptyContainer: {
+ display: 'flex',
+ flexDirection: 'column',
+ width: '100%',
+ alignItems: 'center',
+ justifyContent: 'center',
+ ...shorthands.gap(tokens.spacingHorizontalXL)
+ },
+ addIcon: {
+ color: tokens.colorNeutralForeground4
+ },
+ bodyText: {
+ color: tokens.colorNeutralForeground4
+ },
+ emptyAddFilesButton: {
+ width: 'fit-content'
+ },
+ emptyTextContainer: {
+ display: 'flex',
+ flexDirection: 'column',
+ ...shorthands.gap(tokens.spacingHorizontalXS),
+ alignItems: 'center'
+ },
+ anonSwitch: {
+ width: '240px'
+ }
+});
+
+export default RoomStyles;
diff --git a/src/vite-env.d.ts b/src/vite-env.d.ts
new file mode 100644
index 0000000000000000000000000000000000000000..11f02fe2a0061d6e6e1f271b21da95423b448b32
--- /dev/null
+++ b/src/vite-env.d.ts
@@ -0,0 +1 @@
+///
diff --git a/tsconfig.json b/tsconfig.json
new file mode 100644
index 0000000000000000000000000000000000000000..ce56e6262a0725dd8d310f12c8b17f9ee10a27bc
--- /dev/null
+++ b/tsconfig.json
@@ -0,0 +1,28 @@
+{
+ "compilerOptions": {
+ "target": "ES2020",
+ "useDefineForClassFields": true,
+ "lib": ["ES2020", "DOM", "DOM.Iterable"],
+ "module": "ESNext",
+ "skipLibCheck": true,
+
+ /* Bundler mode */
+ "moduleResolution": "bundler",
+ "allowImportingTsExtensions": true,
+ "resolveJsonModule": true,
+ "isolatedModules": true,
+ "noEmit": true,
+ "jsx": "react-jsx",
+
+ /* Linting */
+ "strict": true,
+ "noUnusedLocals": true,
+ "noUnusedParameters": true,
+ "noFallthroughCasesInSwitch": true,
+
+ /* Types */
+ "types": ["vite-plugin-svgr/client"]
+ },
+ "include": ["src"],
+ "references": [{ "path": "./tsconfig.node.json" }]
+}
diff --git a/tsconfig.node.json b/tsconfig.node.json
new file mode 100644
index 0000000000000000000000000000000000000000..42872c59f5b01c9155864572bc2fbd5833a7406c
--- /dev/null
+++ b/tsconfig.node.json
@@ -0,0 +1,10 @@
+{
+ "compilerOptions": {
+ "composite": true,
+ "skipLibCheck": true,
+ "module": "ESNext",
+ "moduleResolution": "bundler",
+ "allowSyntheticDefaultImports": true
+ },
+ "include": ["vite.config.ts"]
+}
diff --git a/vite.config.ts b/vite.config.ts
new file mode 100644
index 0000000000000000000000000000000000000000..9bd0b667b1af355ad28e7cb626385dd9e27b4716
--- /dev/null
+++ b/vite.config.ts
@@ -0,0 +1,23 @@
+import { defineConfig } from 'vite';
+import react from '@vitejs/plugin-react';
+import svgr from 'vite-plugin-svgr';
+
+export default defineConfig({
+ plugins: [react(), svgr()],
+ build: {
+ outDir: './dist',
+ emptyOutDir: true,
+ sourcemap: true
+ },
+ server: {
+ watch: {
+ usePolling: true
+ },
+ host: true,
+ strictPort: true,
+ port: 5173,
+ proxy: {
+ '/api': 'http://backend:8000/'
+ }
+ }
+});