diff --git a/client/.yarn/install-state.gz b/client/.yarn/install-state.gz
index 08dda20..78c4b0e 100644
Binary files a/client/.yarn/install-state.gz and b/client/.yarn/install-state.gz differ
diff --git a/client/.zed/settings.json b/client/.zed/settings.json
new file mode 100644
index 0000000..60af096
--- /dev/null
+++ b/client/.zed/settings.json
@@ -0,0 +1,54 @@
+{
+ // Use ESLint's --fix:
+ "code_actions_on_format": {
+ "source.fixAll.eslint": true,
+ },
+ "formatter": [],
+ // Enable eslint for all supported languages
+ // Defaults only include https://github.com/search?q=repo%3Azed-industries%2Fzed%20eslint_languages&type=code
+ "languages": {
+ "HTML": {
+ "language_servers": ["...", "eslint"],
+ },
+ "Markdown": {
+ "language_servers": ["...", "eslint"],
+ },
+ "Markdown-Inline": {
+ "language_servers": ["...", "eslint"],
+ },
+ "JSON": {
+ "language_servers": ["...", "eslint"],
+ },
+ "JSONC": {
+ "language_servers": ["...", "eslint"],
+ },
+ "YAML": {
+ "language_servers": ["...", "eslint"],
+ },
+ "CSS": {
+ "language_servers": ["...", "eslint"],
+ },
+ // Add other languages as needed
+ },
+ "lsp": {
+ "eslint": {
+ "settings": {
+ "workingDirectories": ["./"],
+
+ // Silent the stylistic rules in your IDE, but still auto fix them
+ "rulesCustomizations": [
+ { "rule": "style/*", "severity": "off", "fixable": true },
+ { "rule": "format/*", "severity": "off", "fixable": true },
+ { "rule": "*-indent", "severity": "off", "fixable": true },
+ { "rule": "*-spacing", "severity": "off", "fixable": true },
+ { "rule": "*-spaces", "severity": "off", "fixable": true },
+ { "rule": "*-order", "severity": "off", "fixable": true },
+ { "rule": "*-dangle", "severity": "off", "fixable": true },
+ { "rule": "*-newline", "severity": "off", "fixable": true },
+ { "rule": "*quotes", "severity": "off", "fixable": true },
+ { "rule": "*semi", "severity": "off", "fixable": true },
+ ],
+ },
+ },
+ },
+}
diff --git a/client/app/components/ClientRow.vue b/client/app/components/ClientRow.vue
index 5588d75..b2e9747 100644
--- a/client/app/components/ClientRow.vue
+++ b/client/app/components/ClientRow.vue
@@ -21,7 +21,7 @@
- {{ client.displayName || client.username }}
+ {{ client.displayName || client.username || client.socketId }}
diff --git a/client/app/composables/use-app.ts b/client/app/composables/use-app.ts
index 27ae756..46e6441 100644
--- a/client/app/composables/use-app.ts
+++ b/client/app/composables/use-app.ts
@@ -85,7 +85,7 @@ export const useApp = createGlobalState(() => {
await muteInput()
- await signaling.socket.value?.emitWithAck('updateClient', {
+ await signaling.socket.value?.emitWithAck('update-client', {
outputMuted: true,
})
@@ -98,7 +98,7 @@ export const useApp = createGlobalState(() => {
if (!previousInputMuted.value)
await unmuteInput()
- await signaling.socket.value?.emitWithAck('updateClient', {
+ await signaling.socket.value?.emitWithAck('update-client', {
outputMuted: false,
})
diff --git a/client/app/composables/use-clients.ts b/client/app/composables/use-clients.ts
index 697b348..f3cf1e1 100644
--- a/client/app/composables/use-clients.ts
+++ b/client/app/composables/use-clients.ts
@@ -14,7 +14,7 @@ export const useClients = createGlobalState(() => {
if (!socket)
return
- socket.on('clientChanged', (clientId: ChadClient['socketId'], updatedClient: UpdatedClient) => {
+ socket.on('client-updated', (clientId: ChadClient['socketId'], updatedClient: UpdatedClient) => {
const client = getClient(clientId)
if (!client)
diff --git a/client/app/composables/use-mediasoup.ts b/client/app/composables/use-mediasoup.ts
index c727e2a..6339213 100644
--- a/client/app/composables/use-mediasoup.ts
+++ b/client/app/composables/use-mediasoup.ts
@@ -26,15 +26,15 @@ const ICE_SERVERS: RTCIceServer[] = [
]
export const useMediasoup = createSharedComposable(() => {
- const { emit } = useEventBus()
+ const eventBus = useEventBus()
const signaling = useSignaling()
- const { addClient, removeClient, me } = useClients()
+ const { addClient, removeClient, me, clients, updateClient } = useClients()
const preferences = usePreferences()
const { getShareStream } = useDevices()
const device = shallowRef()
- const rtpCapabilities = shallowRef()
+ const routerRtpCapabilities = shallowRef()
const sendTransport = shallowRef()
const recvTransport = shallowRef()
@@ -79,18 +79,30 @@ export const useMediasoup = createSharedComposable(() => {
if (!socket)
return
- socket.on('authenticated', async () => {
+ socket.on('new-client', (client) => {
+ addClient(client)
+
+ eventBus.emit('client:added', client)
+ })
+
+ socket.on('client-switched-channel', (client) => {
+ updateClient(client.socketId, client)
+ })
+
+ socket.on('initialized', async (initData) => {
if (!signaling.socket.value)
return
device.value = new mediasoupClient.Device()
- rtpCapabilities.value = await signaling.socket.value.emitWithAck('getRtpCapabilities')
+ routerRtpCapabilities.value = initData.rtpCapabilities
- await device.value.load({ routerRtpCapabilities: rtpCapabilities.value! })
+ clients.value = initData.clients
+
+ await device.value.load({ routerRtpCapabilities: routerRtpCapabilities.value! })
// Send transport
{
- const transportInfo = await signaling.socket.value.emitWithAck('createTransport', { producing: true, consuming: false })
+ const transportInfo = await signaling.socket.value.emitWithAck('create-transport', { producing: true, consuming: false })
sendTransport.value = device.value.createSendTransport({
...transportInfo,
iceServers: [
@@ -101,7 +113,7 @@ export const useMediasoup = createSharedComposable(() => {
sendTransport.value.on('connect', async ({ dtlsParameters }, callback, errback) => {
try {
- await signaling.socket.value!.emitWithAck('connectTransport', {
+ await signaling.socket.value!.emitWithAck('connect-transport', {
transportId: sendTransport.value!.id,
dtlsParameters,
})
@@ -135,7 +147,7 @@ export const useMediasoup = createSharedComposable(() => {
// Recv Transport
{
- const transportInfo = await signaling.socket.value.emitWithAck('createTransport', { producing: false, consuming: true })
+ const transportInfo = await signaling.socket.value.emitWithAck('create-transport', { producing: false, consuming: true })
recvTransport.value = device.value.createRecvTransport({
...transportInfo,
iceServers: [
@@ -146,7 +158,7 @@ export const useMediasoup = createSharedComposable(() => {
recvTransport.value.on('connect', async ({ dtlsParameters }, callback, errback) => {
try {
- await signaling.socket.value!.emitWithAck('connectTransport', {
+ await signaling.socket.value!.emitWithAck('connect-transport', {
transportId: recvTransport.value!.id,
dtlsParameters,
})
@@ -160,36 +172,33 @@ export const useMediasoup = createSharedComposable(() => {
}
})
}
+ //
+ // const joinedClients = (await signaling.socket.value.emitWithAck('join', {
+ // rtpCapabilities: routerRtpCapabilities.value,
+ // }))
+ //
+ // addClient(...joinedClients)
+ //
+ // if (me.value)
+ // eventBus.emit('socket:authenticated', { socketId: me.value.socketId })
+ //
- const joinedClients = (await signaling.socket.value.emitWithAck('join', {
- rtpCapabilities: rtpCapabilities.value,
- }))
-
- addClient(...joinedClients)
-
- if (me.value)
- emit('socket:authenticated', { socketId: me.value.socketId })
-
+ // TODO: при переподключении проверять inputMuted
await enableMic()
})
- socket.on('newPeer', (client) => {
- addClient(client)
- emit('client:added', client)
- })
-
- socket.on('peerClosed', (id) => {
+ socket.on('client-disconnected', (id) => {
const { getClient } = useClients()
const client = getClient(id)
removeClient(id)
if (client)
- emit('client:removed', client)
+ eventBus.emit('client:removed', client)
})
socket.on(
- 'newConsumer',
+ 'new-consumer',
async (
{ id, producerId, kind, rtpParameters, socketId, appData, producerPaused },
cb,
@@ -216,18 +225,18 @@ export const useMediasoup = createSharedComposable(() => {
raw: markRaw(consumer),
}
- emit('consumer:added', consumers.value[consumer.id]!)
+ eventBus.emit('consumer:added', consumers.value[consumer.id]!)
consumer.observer.on('resume', () => {
consumers.value[consumer.id]!.paused = false
- emit('consumer:resumed', consumers.value[consumer.id]!)
+ eventBus.emit('consumer:resumed', consumers.value[consumer.id]!)
})
consumer.observer.on('pause', () => {
consumers.value[consumer.id]!.paused = true
- emit('consumer:paused', consumers.value[consumer.id]!)
+ eventBus.emit('consumer:paused', consumers.value[consumer.id]!)
})
consumer.observer.on('close', () => {
@@ -236,7 +245,7 @@ export const useMediasoup = createSharedComposable(() => {
delete consumers.value[consumer.id]
if (consumerData)
- emit('consumer:removed', consumerData)
+ eventBus.emit('consumer:removed', consumerData)
})
consumer.on('trackended', () => {
@@ -248,7 +257,7 @@ export const useMediasoup = createSharedComposable(() => {
)
socket.on(
- 'consumerClosed',
+ 'consumer-closed',
async (
{ consumerId },
) => {
@@ -261,7 +270,7 @@ export const useMediasoup = createSharedComposable(() => {
},
)
- socket.on('consumerPaused', ({ consumerId }) => {
+ socket.on('consumer-paused', ({ consumerId }) => {
const consumer = consumers.value[consumerId]
if (!consumer)
@@ -270,7 +279,7 @@ export const useMediasoup = createSharedComposable(() => {
consumer.raw.pause()
})
- socket.on('consumerResumed', ({ consumerId }) => {
+ socket.on('consumer-resumed', ({ consumerId }) => {
const consumer = consumers.value[consumerId]
if (!consumer)
@@ -279,13 +288,13 @@ export const useMediasoup = createSharedComposable(() => {
consumer.raw.resume()
})
- socket.on('speakingPeers', (value: SpeakingClient[]) => {
+ socket.on('speaking-clients', (value: SpeakingClient[]) => {
speakingClients.value = value
})
socket.on('disconnect', () => {
device.value = undefined
- rtpCapabilities.value = undefined
+ routerRtpCapabilities.value = undefined
sendTransport.value?.close()
sendTransport.value = undefined
@@ -317,27 +326,28 @@ export const useMediasoup = createSharedComposable(() => {
raw: markRaw(producer),
}
- emit('producer:added', producers.value[producer.id]!)
+ eventBus.emit('producer:added', producers.value[producer.id]!)
producer.observer.on('pause', () => {
producers.value[producer.id]!.paused = true
- emit('producer:paused', producers.value[producer.id]!)
+ eventBus.emit('producer:paused', producers.value[producer.id]!)
})
producer.observer.on('resume', () => {
producers.value[producer.id]!.paused = false
- emit('producer:resumed', producers.value[producer.id]!)
+ eventBus.emit('producer:resumed', producers.value[producer.id]!)
})
producer.observer.on('close', () => {
+ console.log('producer closed')
const producerData = producers.value[producer.id]
delete producers.value[producer.id]
if (producerData)
- emit('producer:removed', producerData)
+ eventBus.emit('producer:removed', producerData)
})
producer.on('trackended', () => {
@@ -352,7 +362,7 @@ export const useMediasoup = createSharedComposable(() => {
try {
producer.raw.close()
- await signaling.socket.value.emitWithAck('closeProducer', {
+ await signaling.socket.value.emitWithAck('close-producer', {
producerId: producer.id,
})
}
@@ -455,7 +465,7 @@ export const useMediasoup = createSharedComposable(() => {
await createProducer({
track,
streamId: 'share',
- codec: device.value.rtpCapabilities.codecs?.find(
+ codec: device.value.sendRtpCapabilities.codecs?.find(
c => c.mimeType.toLowerCase() === 'video/AV1',
),
codecOptions: {
@@ -478,7 +488,7 @@ export const useMediasoup = createSharedComposable(() => {
try {
producer.raw.pause()
- await signaling.socket.value.emitWithAck('pauseProducer', {
+ await signaling.socket.value.emitWithAck('pause-producer', {
producerId: producer.id,
})
}
@@ -494,7 +504,7 @@ export const useMediasoup = createSharedComposable(() => {
try {
producer.raw.resume()
- await signaling.socket.value.emitWithAck('resumeProducer', {
+ await signaling.socket.value.emitWithAck('resume-producer', {
producerId: producer.id,
})
}
@@ -526,7 +536,7 @@ export const useMediasoup = createSharedComposable(() => {
speakingClients,
sendTransport,
recvTransport,
- rtpCapabilities,
+ rtpCapabilities: routerRtpCapabilities,
device,
micProducer,
videoProducer,
@@ -536,5 +546,7 @@ export const useMediasoup = createSharedComposable(() => {
enableVideo,
enableShare,
disableProducer,
+ consumersArray,
+ producersArray,
}
})
diff --git a/client/app/layouts/default.vue b/client/app/layouts/default.vue
index 9543290..3261ad2 100644
--- a/client/app/layouts/default.vue
+++ b/client/app/layouts/default.vue
@@ -52,11 +52,39 @@
-
+
+
+
+ {{ channel.name }}
+
+
+
+ {{ client.userId }}
+
+
+
+
+ - Socket ID
+ - {{ socket?.id }}
+
+
+ - Producers
+ -
+ {{ producer.id }}
+ {{ producer.appData }}
+
+
+
+ Consumers
+ -
+ {{ consumer.id }}
+ {{ consumer.appData }}
+
+
@@ -65,6 +93,7 @@
diff --git a/client/package.json b/client/package.json
index 864fa24..4f9976c 100644
--- a/client/package.json
+++ b/client/package.json
@@ -25,7 +25,7 @@
"linkify-string": "^4.3.2",
"linkifyjs": "^4.3.2",
"lucide-vue-next": "^0.562.0",
- "mediasoup-client": "^3.18.6",
+ "mediasoup-client": "^3.19.0",
"mitt": "^3.0.1",
"nuxt": "^4.2.2",
"postcss": "^8.5.6",
diff --git a/client/shared/types.ts b/client/shared/types.ts
index 0aaa22a..d77b95f 100644
--- a/client/shared/types.ts
+++ b/client/shared/types.ts
@@ -3,8 +3,7 @@ import type { Consumer as MediasoupConsumer, Producer as MediasoupProducer } fro
export interface ChadClient {
socketId: string
userId: string
- username: string
- displayName: string
+ channelId: string
inputMuted?: boolean
outputMuted?: boolean
diff --git a/client/yarn.lock b/client/yarn.lock
index ba47cb2..ce6e4f1 100644
--- a/client/yarn.lock
+++ b/client/yarn.lock
@@ -3004,7 +3004,7 @@ __metadata:
languageName: node
linkType: hard
-"@types/debug@npm:^4.0.0, @types/debug@npm:^4.1.12":
+"@types/debug@npm:^4.0.0":
version: 4.1.12
resolution: "@types/debug@npm:4.1.12"
dependencies:
@@ -3013,6 +3013,15 @@ __metadata:
languageName: node
linkType: hard
+"@types/debug@npm:^4.1.13":
+ version: 4.1.13
+ resolution: "@types/debug@npm:4.1.13"
+ dependencies:
+ "@types/ms": "npm:*"
+ checksum: 10c0/e5e124021bbdb23a82727eee0a726ae0fc8a3ae1f57253cbcc47497f259afb357de7f6941375e773e1abbfa1604c1555b901a409d762ec2bb4c1612131d4afb7
+ languageName: node
+ linkType: hard
+
"@types/estree@npm:*, @types/estree@npm:1.0.8, @types/estree@npm:^1.0.0, @types/estree@npm:^1.0.6, @types/estree@npm:^1.0.8":
version: 1.0.8
resolution: "@types/estree@npm:1.0.8"
@@ -4082,7 +4091,7 @@ __metadata:
linkify-string: "npm:^4.3.2"
linkifyjs: "npm:^4.3.2"
lucide-vue-next: "npm:^0.562.0"
- mediasoup-client: "npm:^3.18.6"
+ mediasoup-client: "npm:^3.19.0"
mitt: "npm:^3.0.1"
nuxt: "npm:^4.2.2"
postcss: "npm:^8.5.6"
@@ -7355,11 +7364,11 @@ __metadata:
languageName: node
linkType: hard
-"mediasoup-client@npm:^3.18.6":
- version: 3.18.6
- resolution: "mediasoup-client@npm:3.18.6"
+"mediasoup-client@npm:^3.19.0":
+ version: 3.19.0
+ resolution: "mediasoup-client@npm:3.19.0"
dependencies:
- "@types/debug": "npm:^4.1.12"
+ "@types/debug": "npm:^4.1.13"
"@types/events-alias": "npm:@types/events@^3.0.3"
awaitqueue: "npm:^3.3.0"
debug: "npm:^4.4.3"
@@ -7368,7 +7377,7 @@ __metadata:
h264-profile-level-id: "npm:^2.3.2"
sdp-transform: "npm:^3.0.0"
supports-color: "npm:^10.2.2"
- checksum: 10c0/f5baff9139afccf88de5db767c1139efa5cdd68f4871e2fa9d6ff94d2e71d2365dc40e9ba6e903cde5fbb51a2d82972e738da656be9f6fc7006640fdd82dd5da
+ checksum: 10c0/9fde5ec5daec91d43a88796f49e2b1b7a018c8100a3f99786966678a0e0b5328e88f6e6af36d50f9eed93889b84f23a164865c7177c0767ee805c7a8c7a51eb2
languageName: node
linkType: hard
diff --git a/new-client/.env b/new-client/.env
new file mode 100644
index 0000000..11ec8a3
--- /dev/null
+++ b/new-client/.env
@@ -0,0 +1,3 @@
+; API_BASE_URL=/api
+; API_BASE_URL=https://api.koptilnya.xyz/chad
+API_BASE_URL=http://127.0.0.1:4000
diff --git a/new-client/.gitignore b/new-client/.gitignore
new file mode 100644
index 0000000..a547bf3
--- /dev/null
+++ b/new-client/.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/new-client/.vscode/extensions.json b/new-client/.vscode/extensions.json
new file mode 100644
index 0000000..a7cea0b
--- /dev/null
+++ b/new-client/.vscode/extensions.json
@@ -0,0 +1,3 @@
+{
+ "recommendations": ["Vue.volar"]
+}
diff --git a/new-client/.zed/settings.json b/new-client/.zed/settings.json
new file mode 100644
index 0000000..60af096
--- /dev/null
+++ b/new-client/.zed/settings.json
@@ -0,0 +1,54 @@
+{
+ // Use ESLint's --fix:
+ "code_actions_on_format": {
+ "source.fixAll.eslint": true,
+ },
+ "formatter": [],
+ // Enable eslint for all supported languages
+ // Defaults only include https://github.com/search?q=repo%3Azed-industries%2Fzed%20eslint_languages&type=code
+ "languages": {
+ "HTML": {
+ "language_servers": ["...", "eslint"],
+ },
+ "Markdown": {
+ "language_servers": ["...", "eslint"],
+ },
+ "Markdown-Inline": {
+ "language_servers": ["...", "eslint"],
+ },
+ "JSON": {
+ "language_servers": ["...", "eslint"],
+ },
+ "JSONC": {
+ "language_servers": ["...", "eslint"],
+ },
+ "YAML": {
+ "language_servers": ["...", "eslint"],
+ },
+ "CSS": {
+ "language_servers": ["...", "eslint"],
+ },
+ // Add other languages as needed
+ },
+ "lsp": {
+ "eslint": {
+ "settings": {
+ "workingDirectories": ["./"],
+
+ // Silent the stylistic rules in your IDE, but still auto fix them
+ "rulesCustomizations": [
+ { "rule": "style/*", "severity": "off", "fixable": true },
+ { "rule": "format/*", "severity": "off", "fixable": true },
+ { "rule": "*-indent", "severity": "off", "fixable": true },
+ { "rule": "*-spacing", "severity": "off", "fixable": true },
+ { "rule": "*-spaces", "severity": "off", "fixable": true },
+ { "rule": "*-order", "severity": "off", "fixable": true },
+ { "rule": "*-dangle", "severity": "off", "fixable": true },
+ { "rule": "*-newline", "severity": "off", "fixable": true },
+ { "rule": "*quotes", "severity": "off", "fixable": true },
+ { "rule": "*semi", "severity": "off", "fixable": true },
+ ],
+ },
+ },
+ },
+}
diff --git a/new-client/eslint.config.mjs b/new-client/eslint.config.mjs
new file mode 100644
index 0000000..6fe4bb3
--- /dev/null
+++ b/new-client/eslint.config.mjs
@@ -0,0 +1,17 @@
+import antfu from '@antfu/eslint-config'
+
+export default antfu({
+ formatters: {
+ css: true,
+ },
+ overrides: {
+ typescript: {
+ 'no-console': 'off',
+ },
+ vue: {
+ 'vue/block-order': ['error', {
+ order: ['template', 'script', 'style'],
+ }],
+ },
+ },
+})
diff --git a/new-client/index.html b/new-client/index.html
new file mode 100644
index 0000000..81a196a
--- /dev/null
+++ b/new-client/index.html
@@ -0,0 +1,24 @@
+
+
+
+ Chad
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/new-client/package.json b/new-client/package.json
new file mode 100644
index 0000000..c1fb7df
--- /dev/null
+++ b/new-client/package.json
@@ -0,0 +1,36 @@
+{
+ "name": "new-client",
+ "type": "module",
+ "version": "0.0.0",
+ "private": true,
+ "scripts": {
+ "dev": "vite",
+ "build": "vue-tsc -b && vite build",
+ "preview": "vite preview"
+ },
+ "dependencies": {
+ "@ark-ui/vue": "^5.36.2",
+ "@tauri-apps/plugin-global-shortcut": "^2.3.1",
+ "@tauri-apps/plugin-opener": "~2",
+ "@tauri-apps/plugin-process": "^2.3.1",
+ "@tauri-apps/plugin-updater": "^2.10.1",
+ "@vueuse/core": "^14.3.0",
+ "@zag-js/vue": "^1.40.0",
+ "primevue": "^4.5.5",
+ "vue": "^3.5.32",
+ "vue-router": "^5.0.6"
+ },
+ "devDependencies": {
+ "@antfu/eslint-config": "^8.2.0",
+ "@tauri-apps/cli": "^2.8.4",
+ "@types/node": "^24.12.2",
+ "@vitejs/plugin-vue": "^6.0.6",
+ "@vue/tsconfig": "^0.9.1",
+ "eslint": "^10.3.0",
+ "eslint-plugin-format": "^2.0.1",
+ "sass-embedded": "^1.99.0",
+ "typescript": "~6.0.2",
+ "vite": "^8.0.10",
+ "vue-tsc": "^3.2.7"
+ }
+}
diff --git a/new-client/public/favicon.svg b/new-client/public/favicon.svg
new file mode 100644
index 0000000..6893eb1
--- /dev/null
+++ b/new-client/public/favicon.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/new-client/public/icons.svg b/new-client/public/icons.svg
new file mode 100644
index 0000000..e952219
--- /dev/null
+++ b/new-client/public/icons.svg
@@ -0,0 +1,24 @@
+
diff --git a/new-client/public/sad-pepe.png b/new-client/public/sad-pepe.png
new file mode 100644
index 0000000..28d437a
Binary files /dev/null and b/new-client/public/sad-pepe.png differ
diff --git a/new-client/src-tauri/.gitignore b/new-client/src-tauri/.gitignore
new file mode 100644
index 0000000..502406b
--- /dev/null
+++ b/new-client/src-tauri/.gitignore
@@ -0,0 +1,4 @@
+# Generated by Cargo
+# will have compiled files and executables
+/target/
+/gen/schemas
diff --git a/new-client/src-tauri/Cargo.lock b/new-client/src-tauri/Cargo.lock
new file mode 100644
index 0000000..97ae95d
--- /dev/null
+++ b/new-client/src-tauri/Cargo.lock
@@ -0,0 +1,6228 @@
+# This file is automatically @generated by Cargo.
+# It is not intended for manual editing.
+version = 3
+
+[[package]]
+name = "adler2"
+version = "2.0.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "320119579fcad9c21884f5c4861d16174d0e06250625266f50fe6898340abefa"
+
+[[package]]
+name = "ahash"
+version = "0.7.8"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "891477e0c6a8957309ee5c45a6368af3ae14bb510732d2684ffa19af310920f9"
+dependencies = [
+ "getrandom 0.2.17",
+ "once_cell",
+ "version_check",
+]
+
+[[package]]
+name = "aho-corasick"
+version = "1.1.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ddd31a130427c27518df266943a5308ed92d4b226cc639f5a8f1002816174301"
+dependencies = [
+ "memchr",
+]
+
+[[package]]
+name = "alloc-no-stdlib"
+version = "2.0.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "cc7bb162ec39d46ab1ca8c77bf72e890535becd1751bb45f64c597edb4c8c6b3"
+
+[[package]]
+name = "alloc-stdlib"
+version = "0.2.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "94fb8275041c72129eb51b7d0322c29b8387a0386127718b096429201a5d6ece"
+dependencies = [
+ "alloc-no-stdlib",
+]
+
+[[package]]
+name = "android_log-sys"
+version = "0.3.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "84521a3cf562bc62942e294181d9eef17eb38ceb8c68677bc49f144e4c3d4f8d"
+
+[[package]]
+name = "android_logger"
+version = "0.15.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "dbb4e440d04be07da1f1bf44fb4495ebd58669372fe0cffa6e48595ac5bd88a3"
+dependencies = [
+ "android_log-sys",
+ "env_filter",
+ "log",
+]
+
+[[package]]
+name = "android_system_properties"
+version = "0.1.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "819e7219dbd41043ac279b19830f2efc897156490d7fd6ea916720117ee66311"
+dependencies = [
+ "libc",
+]
+
+[[package]]
+name = "anyhow"
+version = "1.0.102"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7f202df86484c868dbad7eaa557ef785d5c66295e41b460ef922eca0723b842c"
+
+[[package]]
+name = "app"
+version = "0.1.0"
+dependencies = [
+ "log",
+ "serde",
+ "serde_json",
+ "tauri",
+ "tauri-build",
+ "tauri-plugin-global-shortcut",
+ "tauri-plugin-log",
+ "tauri-plugin-opener",
+ "tauri-plugin-process",
+ "tauri-plugin-single-instance",
+ "tauri-plugin-updater",
+ "windows 0.52.0",
+]
+
+[[package]]
+name = "arbitrary"
+version = "1.4.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c3d036a3c4ab069c7b410a2ce876bd74808d2d0888a82667669f8e783a898bf1"
+dependencies = [
+ "derive_arbitrary",
+]
+
+[[package]]
+name = "arrayvec"
+version = "0.7.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7c02d123df017efcdfbd739ef81735b36c5ba83ec3c59c80a9d7ecc718f92e50"
+
+[[package]]
+name = "async-broadcast"
+version = "0.7.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "435a87a52755b8f27fcf321ac4f04b2802e337c8c4872923137471ec39c37532"
+dependencies = [
+ "event-listener",
+ "event-listener-strategy",
+ "futures-core",
+ "pin-project-lite",
+]
+
+[[package]]
+name = "async-channel"
+version = "2.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "924ed96dd52d1b75e9c1a3e6275715fd320f5f9439fb5a4a11fa51f4221158d2"
+dependencies = [
+ "concurrent-queue",
+ "event-listener-strategy",
+ "futures-core",
+ "pin-project-lite",
+]
+
+[[package]]
+name = "async-executor"
+version = "1.14.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c96bf972d85afc50bf5ab8fe2d54d1586b4e0b46c97c50a0c9e71e2f7bcd812a"
+dependencies = [
+ "async-task",
+ "concurrent-queue",
+ "fastrand",
+ "futures-lite",
+ "pin-project-lite",
+ "slab",
+]
+
+[[package]]
+name = "async-io"
+version = "2.6.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "456b8a8feb6f42d237746d4b3e9a178494627745c3c56c6ea55d92ba50d026fc"
+dependencies = [
+ "autocfg",
+ "cfg-if",
+ "concurrent-queue",
+ "futures-io",
+ "futures-lite",
+ "parking",
+ "polling",
+ "rustix",
+ "slab",
+ "windows-sys 0.61.2",
+]
+
+[[package]]
+name = "async-lock"
+version = "3.4.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "290f7f2596bd5b78a9fec8088ccd89180d7f9f55b94b0576823bbbdc72ee8311"
+dependencies = [
+ "event-listener",
+ "event-listener-strategy",
+ "pin-project-lite",
+]
+
+[[package]]
+name = "async-process"
+version = "2.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "fc50921ec0055cdd8a16de48773bfeec5c972598674347252c0399676be7da75"
+dependencies = [
+ "async-channel",
+ "async-io",
+ "async-lock",
+ "async-signal",
+ "async-task",
+ "blocking",
+ "cfg-if",
+ "event-listener",
+ "futures-lite",
+ "rustix",
+]
+
+[[package]]
+name = "async-recursion"
+version = "1.1.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3b43422f69d8ff38f95f1b2bb76517c91589a924d1559a0e935d7c8ce0274c11"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "async-signal"
+version = "0.2.14"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "52b5aaafa020cf5053a01f2a60e8ff5dccf550f0f77ec54a4e47285ac2bab485"
+dependencies = [
+ "async-io",
+ "async-lock",
+ "atomic-waker",
+ "cfg-if",
+ "futures-core",
+ "futures-io",
+ "rustix",
+ "signal-hook-registry",
+ "slab",
+ "windows-sys 0.61.2",
+]
+
+[[package]]
+name = "async-task"
+version = "4.7.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8b75356056920673b02621b35afd0f7dda9306d03c79a30f5c56c44cf256e3de"
+
+[[package]]
+name = "async-trait"
+version = "0.1.89"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9035ad2d096bed7955a320ee7e2230574d28fd3c3a0f186cbea1ff3c7eed5dbb"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "atk"
+version = "0.18.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "241b621213072e993be4f6f3a9e4b45f65b7e6faad43001be957184b7bb1824b"
+dependencies = [
+ "atk-sys",
+ "glib",
+ "libc",
+]
+
+[[package]]
+name = "atk-sys"
+version = "0.18.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c5e48b684b0ca77d2bbadeef17424c2ea3c897d44d566a1617e7e8f30614d086"
+dependencies = [
+ "glib-sys",
+ "gobject-sys",
+ "libc",
+ "system-deps",
+]
+
+[[package]]
+name = "atomic-waker"
+version = "1.1.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1505bd5d3d116872e7271a6d4e16d81d0c8570876c8de68093a09ac269d8aac0"
+
+[[package]]
+name = "autocfg"
+version = "1.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c08606f8c3cbf4ce6ec8e28fb0014a2c086708fe954eaa885384a6165172e7e8"
+
+[[package]]
+name = "base64"
+version = "0.21.7"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9d297deb1925b89f2ccc13d7635fa0714f12c87adce1c75356b39ca9b7178567"
+
+[[package]]
+name = "base64"
+version = "0.22.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "72b3254f16251a8381aa12e40e3c4d2f0199f8c6508fbecb9d91f575e0fbb8c6"
+
+[[package]]
+name = "bit-set"
+version = "0.8.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "08807e080ed7f9d5433fa9b275196cfc35414f66a0c79d864dc51a0d825231a3"
+dependencies = [
+ "bit-vec",
+]
+
+[[package]]
+name = "bit-vec"
+version = "0.8.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5e764a1d40d510daf35e07be9eb06e75770908c27d411ee6c92109c9840eaaf7"
+
+[[package]]
+name = "bitflags"
+version = "1.3.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a"
+
+[[package]]
+name = "bitflags"
+version = "2.11.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c4512299f36f043ab09a583e57bceb5a5aab7a73db1805848e8fef3c9e8c78b3"
+dependencies = [
+ "serde_core",
+]
+
+[[package]]
+name = "bitvec"
+version = "1.0.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1bc2832c24239b0141d5674bb9174f9d68a8b5b3f2753311927c172ca46f7e9c"
+dependencies = [
+ "funty",
+ "radium",
+ "tap",
+ "wyz",
+]
+
+[[package]]
+name = "block-buffer"
+version = "0.10.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3078c7629b62d3f0439517fa394996acacc5cbc91c5a20d8c658e77abd503a71"
+dependencies = [
+ "generic-array",
+]
+
+[[package]]
+name = "block2"
+version = "0.6.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "cdeb9d870516001442e364c5220d3574d2da8dc765554b4a617230d33fa58ef5"
+dependencies = [
+ "objc2",
+]
+
+[[package]]
+name = "blocking"
+version = "1.6.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e83f8d02be6967315521be875afa792a316e28d57b5a2d401897e2a7921b7f21"
+dependencies = [
+ "async-channel",
+ "async-task",
+ "futures-io",
+ "futures-lite",
+ "piper",
+]
+
+[[package]]
+name = "borsh"
+version = "1.6.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "cfd1e3f8955a5d7de9fab72fc8373fade9fb8a703968cb200ae3dc6cf08e185a"
+dependencies = [
+ "borsh-derive",
+ "bytes",
+ "cfg_aliases",
+]
+
+[[package]]
+name = "borsh-derive"
+version = "1.6.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "bfcfdc083699101d5a7965e49925975f2f55060f94f9a05e7187be95d530ca59"
+dependencies = [
+ "once_cell",
+ "proc-macro-crate 3.5.0",
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "brotli"
+version = "8.0.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "4bd8b9603c7aa97359dbd97ecf258968c95f3adddd6db2f7e7a5bef101c84560"
+dependencies = [
+ "alloc-no-stdlib",
+ "alloc-stdlib",
+ "brotli-decompressor",
+]
+
+[[package]]
+name = "brotli-decompressor"
+version = "5.0.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "874bb8112abecc98cbd6d81ea4fa7e94fb9449648c93cc89aa40c81c24d7de03"
+dependencies = [
+ "alloc-no-stdlib",
+ "alloc-stdlib",
+]
+
+[[package]]
+name = "bumpalo"
+version = "3.20.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5d20789868f4b01b2f2caec9f5c4e0213b41e3e5702a50157d699ae31ced2fcb"
+
+[[package]]
+name = "byte-unit"
+version = "5.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8c6d47a4e2961fb8721bcfc54feae6455f2f64e7054f9bc67e875f0e77f4c58d"
+dependencies = [
+ "rust_decimal",
+ "schemars 1.2.1",
+ "serde",
+ "utf8-width",
+]
+
+[[package]]
+name = "bytecheck"
+version = "0.6.12"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "23cdc57ce23ac53c931e88a43d06d070a6fd142f2617be5855eb75efc9beb1c2"
+dependencies = [
+ "bytecheck_derive",
+ "ptr_meta",
+ "simdutf8",
+]
+
+[[package]]
+name = "bytecheck_derive"
+version = "0.6.12"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3db406d29fbcd95542e92559bed4d8ad92636d1ca8b3b72ede10b4bcc010e659"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 1.0.109",
+]
+
+[[package]]
+name = "bytemuck"
+version = "1.25.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c8efb64bd706a16a1bdde310ae86b351e4d21550d98d056f22f8a7f7a2183fec"
+
+[[package]]
+name = "byteorder"
+version = "1.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1fd0f2584146f6f2ef48085050886acf353beff7305ebd1ae69500e27c67f64b"
+
+[[package]]
+name = "bytes"
+version = "1.11.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1e748733b7cbc798e1434b6ac524f0c1ff2ab456fe201501e6497c8417a4fc33"
+dependencies = [
+ "serde",
+]
+
+[[package]]
+name = "cairo-rs"
+version = "0.18.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8ca26ef0159422fb77631dc9d17b102f253b876fe1586b03b803e63a309b4ee2"
+dependencies = [
+ "bitflags 2.11.1",
+ "cairo-sys-rs",
+ "glib",
+ "libc",
+ "once_cell",
+ "thiserror 1.0.69",
+]
+
+[[package]]
+name = "cairo-sys-rs"
+version = "0.18.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "685c9fa8e590b8b3d678873528d83411db17242a73fccaed827770ea0fedda51"
+dependencies = [
+ "glib-sys",
+ "libc",
+ "system-deps",
+]
+
+[[package]]
+name = "camino"
+version = "1.2.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e629a66d692cb9ff1a1c664e41771b3dcaf961985a9774c0eb0bd1b51cf60a48"
+dependencies = [
+ "serde_core",
+]
+
+[[package]]
+name = "cargo-platform"
+version = "0.1.9"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e35af189006b9c0f00a064685c727031e3ed2d8020f7ba284d78cc2671bd36ea"
+dependencies = [
+ "serde",
+]
+
+[[package]]
+name = "cargo_metadata"
+version = "0.19.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "dd5eb614ed4c27c5d706420e4320fbe3216ab31fa1c33cd8246ac36dae4479ba"
+dependencies = [
+ "camino",
+ "cargo-platform",
+ "semver",
+ "serde",
+ "serde_json",
+ "thiserror 2.0.18",
+]
+
+[[package]]
+name = "cargo_toml"
+version = "0.22.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "374b7c592d9c00c1f4972ea58390ac6b18cbb6ab79011f3bdc90a0b82ca06b77"
+dependencies = [
+ "serde",
+ "toml 0.9.12+spec-1.1.0",
+]
+
+[[package]]
+name = "cc"
+version = "1.2.60"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "43c5703da9466b66a946814e1adf53ea2c90f10063b86290cc9eb67ce3478a20"
+dependencies = [
+ "find-msvc-tools",
+ "shlex",
+]
+
+[[package]]
+name = "cesu8"
+version = "1.1.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "6d43a04d8753f35258c91f8ec639f792891f748a1edbd759cf1dcea3382ad83c"
+
+[[package]]
+name = "cfb"
+version = "0.7.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d38f2da7a0a2c4ccf0065be06397cc26a81f4e528be095826eee9d4adbb8c60f"
+dependencies = [
+ "byteorder",
+ "fnv",
+ "uuid",
+]
+
+[[package]]
+name = "cfg-expr"
+version = "0.15.8"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d067ad48b8650848b989a59a86c6c36a995d02d2bf778d45c3c5d57bc2718f02"
+dependencies = [
+ "smallvec",
+ "target-lexicon",
+]
+
+[[package]]
+name = "cfg-if"
+version = "1.0.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9330f8b2ff13f34540b44e946ef35111825727b38d33286ef986142615121801"
+
+[[package]]
+name = "cfg_aliases"
+version = "0.2.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "613afe47fcd5fac7ccf1db93babcb082c5994d996f20b8b159f2ad1658eb5724"
+
+[[package]]
+name = "chrono"
+version = "0.4.44"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c673075a2e0e5f4a1dde27ce9dee1ea4558c7ffe648f576438a20ca1d2acc4b0"
+dependencies = [
+ "iana-time-zone",
+ "num-traits",
+ "serde",
+ "windows-link 0.2.1",
+]
+
+[[package]]
+name = "combine"
+version = "4.6.7"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ba5a308b75df32fe02788e748662718f03fde005016435c444eea572398219fd"
+dependencies = [
+ "bytes",
+ "memchr",
+]
+
+[[package]]
+name = "concurrent-queue"
+version = "2.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "4ca0197aee26d1ae37445ee532fefce43251d24cc7c166799f4d46817f1d3973"
+dependencies = [
+ "crossbeam-utils",
+]
+
+[[package]]
+name = "convert_case"
+version = "0.4.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "6245d59a3e82a7fc217c5828a6692dbc6dfb63a0c8c90495621f7b9d79704a0e"
+
+[[package]]
+name = "cookie"
+version = "0.18.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "4ddef33a339a91ea89fb53151bd0a4689cfce27055c291dfa69945475d22c747"
+dependencies = [
+ "time",
+ "version_check",
+]
+
+[[package]]
+name = "core-foundation"
+version = "0.10.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b2a6cd9ae233e7f62ba4e9353e81a88df7fc8a5987b8d445b4d90c879bd156f6"
+dependencies = [
+ "core-foundation-sys",
+ "libc",
+]
+
+[[package]]
+name = "core-foundation-sys"
+version = "0.8.7"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "773648b94d0e5d620f64f280777445740e61fe701025087ec8b57f45c791888b"
+
+[[package]]
+name = "core-graphics"
+version = "0.25.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "064badf302c3194842cf2c5d61f56cc88e54a759313879cdf03abdd27d0c3b97"
+dependencies = [
+ "bitflags 2.11.1",
+ "core-foundation",
+ "core-graphics-types",
+ "foreign-types",
+ "libc",
+]
+
+[[package]]
+name = "core-graphics-types"
+version = "0.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3d44a101f213f6c4cdc1853d4b78aef6db6bdfa3468798cc1d9912f4735013eb"
+dependencies = [
+ "bitflags 2.11.1",
+ "core-foundation",
+ "libc",
+]
+
+[[package]]
+name = "cpufeatures"
+version = "0.2.17"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "59ed5838eebb26a2bb2e58f6d5b5316989ae9d08bab10e0e6d103e656d1b0280"
+dependencies = [
+ "libc",
+]
+
+[[package]]
+name = "crc32fast"
+version = "1.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9481c1c90cbf2ac953f07c8d4a58aa3945c425b7185c9154d67a65e4230da511"
+dependencies = [
+ "cfg-if",
+]
+
+[[package]]
+name = "crossbeam-channel"
+version = "0.5.15"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "82b8f8f868b36967f9606790d1903570de9ceaf870a7bf9fbbd3016d636a2cb2"
+dependencies = [
+ "crossbeam-utils",
+]
+
+[[package]]
+name = "crossbeam-utils"
+version = "0.8.21"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d0a5c400df2834b80a4c3327b3aad3a4c4cd4de0629063962b03235697506a28"
+
+[[package]]
+name = "crypto-common"
+version = "0.1.7"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "78c8292055d1c1df0cce5d180393dc8cce0abec0a7102adb6c7b1eef6016d60a"
+dependencies = [
+ "generic-array",
+ "typenum",
+]
+
+[[package]]
+name = "cssparser"
+version = "0.29.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f93d03419cb5950ccfd3daf3ff1c7a36ace64609a1a8746d493df1ca0afde0fa"
+dependencies = [
+ "cssparser-macros",
+ "dtoa-short",
+ "itoa",
+ "matches",
+ "phf 0.10.1",
+ "proc-macro2",
+ "quote",
+ "smallvec",
+ "syn 1.0.109",
+]
+
+[[package]]
+name = "cssparser"
+version = "0.36.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "dae61cf9c0abb83bd659dab65b7e4e38d8236824c85f0f804f173567bda257d2"
+dependencies = [
+ "cssparser-macros",
+ "dtoa-short",
+ "itoa",
+ "phf 0.13.1",
+ "smallvec",
+]
+
+[[package]]
+name = "cssparser-macros"
+version = "0.6.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "13b588ba4ac1a99f7f2964d24b3d896ddc6bf847ee3855dbd4366f058cfcd331"
+dependencies = [
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "ctor"
+version = "0.2.9"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "32a2785755761f3ddc1492979ce1e48d2c00d09311c39e4466429188f3dd6501"
+dependencies = [
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "darling"
+version = "0.23.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "25ae13da2f202d56bd7f91c25fba009e7717a1e4a1cc98a76d844b65ae912e9d"
+dependencies = [
+ "darling_core",
+ "darling_macro",
+]
+
+[[package]]
+name = "darling_core"
+version = "0.23.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9865a50f7c335f53564bb694ef660825eb8610e0a53d3e11bf1b0d3df31e03b0"
+dependencies = [
+ "ident_case",
+ "proc-macro2",
+ "quote",
+ "strsim",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "darling_macro"
+version = "0.23.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ac3984ec7bd6cfa798e62b4a642426a5be0e68f9401cfc2a01e3fa9ea2fcdb8d"
+dependencies = [
+ "darling_core",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "deranged"
+version = "0.5.8"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7cd812cc2bc1d69d4764bd80df88b4317eaef9e773c75226407d9bc0876b211c"
+dependencies = [
+ "powerfmt",
+ "serde_core",
+]
+
+[[package]]
+name = "derive_arbitrary"
+version = "1.4.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1e567bd82dcff979e4b03460c307b3cdc9e96fde3d73bed1496d2bc75d9dd62a"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "derive_more"
+version = "0.99.20"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "6edb4b64a43d977b8e99788fe3a04d483834fba1215a7e02caa415b626497f7f"
+dependencies = [
+ "convert_case",
+ "proc-macro2",
+ "quote",
+ "rustc_version",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "derive_more"
+version = "2.1.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d751e9e49156b02b44f9c1815bcb94b984cdcc4396ecc32521c739452808b134"
+dependencies = [
+ "derive_more-impl",
+]
+
+[[package]]
+name = "derive_more-impl"
+version = "2.1.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "799a97264921d8623a957f6c3b9011f3b5492f557bbb7a5a19b7fa6d06ba8dcb"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "rustc_version",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "digest"
+version = "0.10.7"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9ed9a281f7bc9b7576e61468ba615a66a5c8cfdff42420a70aa82701a3b1e292"
+dependencies = [
+ "block-buffer",
+ "crypto-common",
+]
+
+[[package]]
+name = "dirs"
+version = "6.0.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c3e8aa94d75141228480295a7d0e7feb620b1a5ad9f12bc40be62411e38cce4e"
+dependencies = [
+ "dirs-sys",
+]
+
+[[package]]
+name = "dirs-sys"
+version = "0.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e01a3366d27ee9890022452ee61b2b63a67e6f13f58900b651ff5665f0bb1fab"
+dependencies = [
+ "libc",
+ "option-ext",
+ "redox_users",
+ "windows-sys 0.61.2",
+]
+
+[[package]]
+name = "dispatch2"
+version = "0.3.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1e0e367e4e7da84520dedcac1901e4da967309406d1e51017ae1abfb97adbd38"
+dependencies = [
+ "bitflags 2.11.1",
+ "block2",
+ "libc",
+ "objc2",
+]
+
+[[package]]
+name = "displaydoc"
+version = "0.2.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "97369cbbc041bc366949bc74d34658d6cda5621039731c6310521892a3a20ae0"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "dlopen2"
+version = "0.8.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5e2c5bd4158e66d1e215c49b837e11d62f3267b30c92f1d171c4d3105e3dc4d4"
+dependencies = [
+ "dlopen2_derive",
+ "libc",
+ "once_cell",
+ "winapi",
+]
+
+[[package]]
+name = "dlopen2_derive"
+version = "0.4.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0fbbb781877580993a8707ec48672673ec7b81eeba04cfd2310bd28c08e47c8f"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "dom_query"
+version = "0.27.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "521e380c0c8afb8d9a1e83a1822ee03556fc3e3e7dbc1fd30be14e37f9cb3f89"
+dependencies = [
+ "bit-set",
+ "cssparser 0.36.0",
+ "foldhash 0.2.0",
+ "html5ever 0.38.0",
+ "precomputed-hash",
+ "selectors 0.36.1",
+ "tendril 0.5.0",
+]
+
+[[package]]
+name = "dpi"
+version = "0.1.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d8b14ccef22fc6f5a8f4d7d768562a182c04ce9a3b3157b91390b52ddfdf1a76"
+dependencies = [
+ "serde",
+]
+
+[[package]]
+name = "dtoa"
+version = "1.0.11"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "4c3cf4824e2d5f025c7b531afcb2325364084a16806f6d47fbc1f5fbd9960590"
+
+[[package]]
+name = "dtoa-short"
+version = "0.3.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "cd1511a7b6a56299bd043a9c167a6d2bfb37bf84a6dfceaba651168adfb43c87"
+dependencies = [
+ "dtoa",
+]
+
+[[package]]
+name = "dunce"
+version = "1.0.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "92773504d58c093f6de2459af4af33faa518c13451eb8f2b5698ed3d36e7c813"
+
+[[package]]
+name = "dyn-clone"
+version = "1.0.20"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d0881ea181b1df73ff77ffaaf9c7544ecc11e82fba9b5f27b262a3c73a332555"
+
+[[package]]
+name = "embed-resource"
+version = "3.0.8"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "63a1d0de4f2249aa0ff5884d7080814f446bb241a559af6c170a41e878ed2d45"
+dependencies = [
+ "cc",
+ "memchr",
+ "rustc_version",
+ "toml 0.9.12+spec-1.1.0",
+ "vswhom",
+ "winreg",
+]
+
+[[package]]
+name = "embed_plist"
+version = "1.2.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "4ef6b89e5b37196644d8796de5268852ff179b44e96276cf4290264843743bb7"
+
+[[package]]
+name = "endi"
+version = "1.1.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "66b7e2430c6dff6a955451e2cfc438f09cea1965a9d6f87f7e3b90decc014099"
+
+[[package]]
+name = "enumflags2"
+version = "0.7.12"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1027f7680c853e056ebcec683615fb6fbbc07dbaa13b4d5d9442b146ded4ecef"
+dependencies = [
+ "enumflags2_derive",
+ "serde",
+]
+
+[[package]]
+name = "enumflags2_derive"
+version = "0.7.12"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "67c78a4d8fdf9953a5c9d458f9efe940fd97a0cab0941c075a813ac594733827"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "env_filter"
+version = "0.1.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1bf3c259d255ca70051b30e2e95b5446cdb8949ac4cd22c0d7fd634d89f568e2"
+dependencies = [
+ "log",
+ "regex",
+]
+
+[[package]]
+name = "equivalent"
+version = "1.0.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "877a4ace8713b0bcf2a4e7eec82529c029f1d0619886d18145fea96c3ffe5c0f"
+
+[[package]]
+name = "erased-serde"
+version = "0.4.10"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d2add8a07dd6a8d93ff627029c51de145e12686fbc36ecb298ac22e74cf02dec"
+dependencies = [
+ "serde",
+ "serde_core",
+ "typeid",
+]
+
+[[package]]
+name = "errno"
+version = "0.3.14"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "39cab71617ae0d63f51a36d69f866391735b51691dbda63cf6f96d042b63efeb"
+dependencies = [
+ "libc",
+ "windows-sys 0.61.2",
+]
+
+[[package]]
+name = "event-listener"
+version = "5.4.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e13b66accf52311f30a0db42147dadea9850cb48cd070028831ae5f5d4b856ab"
+dependencies = [
+ "concurrent-queue",
+ "parking",
+ "pin-project-lite",
+]
+
+[[package]]
+name = "event-listener-strategy"
+version = "0.5.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8be9f3dfaaffdae2972880079a491a1a8bb7cbed0b8dd7a347f668b4150a3b93"
+dependencies = [
+ "event-listener",
+ "pin-project-lite",
+]
+
+[[package]]
+name = "fastrand"
+version = "2.4.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9f1f227452a390804cdb637b74a86990f2a7d7ba4b7d5693aac9b4dd6defd8d6"
+
+[[package]]
+name = "fdeflate"
+version = "0.3.7"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1e6853b52649d4ac5c0bd02320cddc5ba956bdb407c4b75a2c6b75bf51500f8c"
+dependencies = [
+ "simd-adler32",
+]
+
+[[package]]
+name = "fern"
+version = "0.7.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "4316185f709b23713e41e3195f90edef7fb00c3ed4adc79769cf09cc762a3b29"
+dependencies = [
+ "log",
+]
+
+[[package]]
+name = "field-offset"
+version = "0.3.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "38e2275cc4e4fc009b0669731a1e5ab7ebf11f469eaede2bab9309a5b4d6057f"
+dependencies = [
+ "memoffset",
+ "rustc_version",
+]
+
+[[package]]
+name = "filetime"
+version = "0.2.27"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f98844151eee8917efc50bd9e8318cb963ae8b297431495d3f758616ea5c57db"
+dependencies = [
+ "cfg-if",
+ "libc",
+ "libredox",
+]
+
+[[package]]
+name = "find-msvc-tools"
+version = "0.1.9"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5baebc0774151f905a1a2cc41989300b1e6fbb29aff0ceffa1064fdd3088d582"
+
+[[package]]
+name = "flate2"
+version = "1.1.9"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "843fba2746e448b37e26a819579957415c8cef339bf08564fe8b7ddbd959573c"
+dependencies = [
+ "crc32fast",
+ "miniz_oxide",
+]
+
+[[package]]
+name = "fnv"
+version = "1.0.7"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3f9eec918d3f24069decb9af1554cad7c880e2da24a9afd88aca000531ab82c1"
+
+[[package]]
+name = "foldhash"
+version = "0.1.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d9c4f5dac5e15c24eb999c26181a6ca40b39fe946cbe4c263c7209467bc83af2"
+
+[[package]]
+name = "foldhash"
+version = "0.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "77ce24cb58228fbb8aa041425bb1050850ac19177686ea6e0f41a70416f56fdb"
+
+[[package]]
+name = "foreign-types"
+version = "0.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d737d9aa519fb7b749cbc3b962edcf310a8dd1f4b67c91c4f83975dbdd17d965"
+dependencies = [
+ "foreign-types-macros",
+ "foreign-types-shared",
+]
+
+[[package]]
+name = "foreign-types-macros"
+version = "0.2.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1a5c6c585bc94aaf2c7b51dd4c2ba22680844aba4c687be581871a6f518c5742"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "foreign-types-shared"
+version = "0.3.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "aa9a19cbb55df58761df49b23516a86d432839add4af60fc256da840f66ed35b"
+
+[[package]]
+name = "form_urlencoded"
+version = "1.2.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "cb4cb245038516f5f85277875cdaa4f7d2c9a0fa0468de06ed190163b1581fcf"
+dependencies = [
+ "percent-encoding",
+]
+
+[[package]]
+name = "funty"
+version = "2.0.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e6d5a32815ae3f33302d95fdcb2ce17862f8c65363dcfd29360480ba1001fc9c"
+
+[[package]]
+name = "futf"
+version = "0.1.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "df420e2e84819663797d1ec6544b13c5be84629e7bb00dc960d6917db2987843"
+dependencies = [
+ "mac",
+ "new_debug_unreachable",
+]
+
+[[package]]
+name = "futures-channel"
+version = "0.3.32"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "07bbe89c50d7a535e539b8c17bc0b49bdb77747034daa8087407d655f3f7cc1d"
+dependencies = [
+ "futures-core",
+]
+
+[[package]]
+name = "futures-core"
+version = "0.3.32"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7e3450815272ef58cec6d564423f6e755e25379b217b0bc688e295ba24df6b1d"
+
+[[package]]
+name = "futures-executor"
+version = "0.3.32"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "baf29c38818342a3b26b5b923639e7b1f4a61fc5e76102d4b1981c6dc7a7579d"
+dependencies = [
+ "futures-core",
+ "futures-task",
+ "futures-util",
+]
+
+[[package]]
+name = "futures-io"
+version = "0.3.32"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "cecba35d7ad927e23624b22ad55235f2239cfa44fd10428eecbeba6d6a717718"
+
+[[package]]
+name = "futures-lite"
+version = "2.6.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f78e10609fe0e0b3f4157ffab1876319b5b0db102a2c60dc4626306dc46b44ad"
+dependencies = [
+ "fastrand",
+ "futures-core",
+ "futures-io",
+ "parking",
+ "pin-project-lite",
+]
+
+[[package]]
+name = "futures-macro"
+version = "0.3.32"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e835b70203e41293343137df5c0664546da5745f82ec9b84d40be8336958447b"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "futures-sink"
+version = "0.3.32"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c39754e157331b013978ec91992bde1ac089843443c49cbc7f46150b0fad0893"
+
+[[package]]
+name = "futures-task"
+version = "0.3.32"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "037711b3d59c33004d3856fbdc83b99d4ff37a24768fa1be9ce3538a1cde4393"
+
+[[package]]
+name = "futures-util"
+version = "0.3.32"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "389ca41296e6190b48053de0321d02a77f32f8a5d2461dd38762c0593805c6d6"
+dependencies = [
+ "futures-core",
+ "futures-io",
+ "futures-macro",
+ "futures-sink",
+ "futures-task",
+ "memchr",
+ "pin-project-lite",
+ "slab",
+]
+
+[[package]]
+name = "fxhash"
+version = "0.2.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c31b6d751ae2c7f11320402d34e41349dd1016f8d5d45e48c4312bc8625af50c"
+dependencies = [
+ "byteorder",
+]
+
+[[package]]
+name = "gdk"
+version = "0.18.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d9f245958c627ac99d8e529166f9823fb3b838d1d41fd2b297af3075093c2691"
+dependencies = [
+ "cairo-rs",
+ "gdk-pixbuf",
+ "gdk-sys",
+ "gio",
+ "glib",
+ "libc",
+ "pango",
+]
+
+[[package]]
+name = "gdk-pixbuf"
+version = "0.18.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "50e1f5f1b0bfb830d6ccc8066d18db35c487b1b2b1e8589b5dfe9f07e8defaec"
+dependencies = [
+ "gdk-pixbuf-sys",
+ "gio",
+ "glib",
+ "libc",
+ "once_cell",
+]
+
+[[package]]
+name = "gdk-pixbuf-sys"
+version = "0.18.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3f9839ea644ed9c97a34d129ad56d38a25e6756f99f3a88e15cd39c20629caf7"
+dependencies = [
+ "gio-sys",
+ "glib-sys",
+ "gobject-sys",
+ "libc",
+ "system-deps",
+]
+
+[[package]]
+name = "gdk-sys"
+version = "0.18.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5c2d13f38594ac1e66619e188c6d5a1adb98d11b2fcf7894fc416ad76aa2f3f7"
+dependencies = [
+ "cairo-sys-rs",
+ "gdk-pixbuf-sys",
+ "gio-sys",
+ "glib-sys",
+ "gobject-sys",
+ "libc",
+ "pango-sys",
+ "pkg-config",
+ "system-deps",
+]
+
+[[package]]
+name = "gdkwayland-sys"
+version = "0.18.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "140071d506d223f7572b9f09b5e155afbd77428cd5cc7af8f2694c41d98dfe69"
+dependencies = [
+ "gdk-sys",
+ "glib-sys",
+ "gobject-sys",
+ "libc",
+ "pkg-config",
+ "system-deps",
+]
+
+[[package]]
+name = "gdkx11"
+version = "0.18.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3caa00e14351bebbc8183b3c36690327eb77c49abc2268dd4bd36b856db3fbfe"
+dependencies = [
+ "gdk",
+ "gdkx11-sys",
+ "gio",
+ "glib",
+ "libc",
+ "x11",
+]
+
+[[package]]
+name = "gdkx11-sys"
+version = "0.18.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "6e2e7445fe01ac26f11601db260dd8608fe172514eb63b3b5e261ea6b0f4428d"
+dependencies = [
+ "gdk-sys",
+ "glib-sys",
+ "libc",
+ "system-deps",
+ "x11",
+]
+
+[[package]]
+name = "generic-array"
+version = "0.14.7"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "85649ca51fd72272d7821adaf274ad91c288277713d9c18820d8499a7ff69e9a"
+dependencies = [
+ "typenum",
+ "version_check",
+]
+
+[[package]]
+name = "gethostname"
+version = "1.1.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1bd49230192a3797a9a4d6abe9b3eed6f7fa4c8a8a4947977c6f80025f92cbd8"
+dependencies = [
+ "rustix",
+ "windows-link 0.2.1",
+]
+
+[[package]]
+name = "getrandom"
+version = "0.1.16"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8fc3cb4d91f53b50155bdcfd23f6a4c39ae1969c2ae85982b135750cccaf5fce"
+dependencies = [
+ "cfg-if",
+ "libc",
+ "wasi 0.9.0+wasi-snapshot-preview1",
+]
+
+[[package]]
+name = "getrandom"
+version = "0.2.17"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ff2abc00be7fca6ebc474524697ae276ad847ad0a6b3faa4bcb027e9a4614ad0"
+dependencies = [
+ "cfg-if",
+ "libc",
+ "wasi 0.11.1+wasi-snapshot-preview1",
+]
+
+[[package]]
+name = "getrandom"
+version = "0.3.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "899def5c37c4fd7b2664648c28120ecec138e4d395b459e5ca34f9cce2dd77fd"
+dependencies = [
+ "cfg-if",
+ "libc",
+ "r-efi 5.3.0",
+ "wasip2",
+]
+
+[[package]]
+name = "getrandom"
+version = "0.4.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0de51e6874e94e7bf76d726fc5d13ba782deca734ff60d5bb2fb2607c7406555"
+dependencies = [
+ "cfg-if",
+ "libc",
+ "r-efi 6.0.0",
+ "wasip2",
+ "wasip3",
+]
+
+[[package]]
+name = "gio"
+version = "0.18.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d4fc8f532f87b79cbc51a79748f16a6828fb784be93145a322fa14d06d354c73"
+dependencies = [
+ "futures-channel",
+ "futures-core",
+ "futures-io",
+ "futures-util",
+ "gio-sys",
+ "glib",
+ "libc",
+ "once_cell",
+ "pin-project-lite",
+ "smallvec",
+ "thiserror 1.0.69",
+]
+
+[[package]]
+name = "gio-sys"
+version = "0.18.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "37566df850baf5e4cb0dfb78af2e4b9898d817ed9263d1090a2df958c64737d2"
+dependencies = [
+ "glib-sys",
+ "gobject-sys",
+ "libc",
+ "system-deps",
+ "winapi",
+]
+
+[[package]]
+name = "glib"
+version = "0.18.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "233daaf6e83ae6a12a52055f568f9d7cf4671dabb78ff9560ab6da230ce00ee5"
+dependencies = [
+ "bitflags 2.11.1",
+ "futures-channel",
+ "futures-core",
+ "futures-executor",
+ "futures-task",
+ "futures-util",
+ "gio-sys",
+ "glib-macros",
+ "glib-sys",
+ "gobject-sys",
+ "libc",
+ "memchr",
+ "once_cell",
+ "smallvec",
+ "thiserror 1.0.69",
+]
+
+[[package]]
+name = "glib-macros"
+version = "0.18.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0bb0228f477c0900c880fd78c8759b95c7636dbd7842707f49e132378aa2acdc"
+dependencies = [
+ "heck 0.4.1",
+ "proc-macro-crate 2.0.2",
+ "proc-macro-error",
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "glib-sys"
+version = "0.18.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "063ce2eb6a8d0ea93d2bf8ba1957e78dbab6be1c2220dd3daca57d5a9d869898"
+dependencies = [
+ "libc",
+ "system-deps",
+]
+
+[[package]]
+name = "glob"
+version = "0.3.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0cc23270f6e1808e30a928bdc84dea0b9b4136a8bc82338574f23baf47bbd280"
+
+[[package]]
+name = "global-hotkey"
+version = "0.7.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b9247516746aa8e53411a0db9b62b0e24efbcf6a76e0ba73e5a91b512ddabed7"
+dependencies = [
+ "crossbeam-channel",
+ "keyboard-types",
+ "objc2",
+ "objc2-app-kit",
+ "once_cell",
+ "serde",
+ "thiserror 2.0.18",
+ "windows-sys 0.59.0",
+ "x11rb",
+ "xkeysym",
+]
+
+[[package]]
+name = "gobject-sys"
+version = "0.18.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0850127b514d1c4a4654ead6dedadb18198999985908e6ffe4436f53c785ce44"
+dependencies = [
+ "glib-sys",
+ "libc",
+ "system-deps",
+]
+
+[[package]]
+name = "gtk"
+version = "0.18.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "fd56fb197bfc42bd5d2751f4f017d44ff59fbb58140c6b49f9b3b2bdab08506a"
+dependencies = [
+ "atk",
+ "cairo-rs",
+ "field-offset",
+ "futures-channel",
+ "gdk",
+ "gdk-pixbuf",
+ "gio",
+ "glib",
+ "gtk-sys",
+ "gtk3-macros",
+ "libc",
+ "pango",
+ "pkg-config",
+]
+
+[[package]]
+name = "gtk-sys"
+version = "0.18.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8f29a1c21c59553eb7dd40e918be54dccd60c52b049b75119d5d96ce6b624414"
+dependencies = [
+ "atk-sys",
+ "cairo-sys-rs",
+ "gdk-pixbuf-sys",
+ "gdk-sys",
+ "gio-sys",
+ "glib-sys",
+ "gobject-sys",
+ "libc",
+ "pango-sys",
+ "system-deps",
+]
+
+[[package]]
+name = "gtk3-macros"
+version = "0.18.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "52ff3c5b21f14f0736fed6dcfc0bfb4225ebf5725f3c0209edeec181e4d73e9d"
+dependencies = [
+ "proc-macro-crate 1.3.1",
+ "proc-macro-error",
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "hashbrown"
+version = "0.12.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8a9ee70c43aaf417c914396645a0fa852624801b24ebb7ae78fe8272889ac888"
+dependencies = [
+ "ahash",
+]
+
+[[package]]
+name = "hashbrown"
+version = "0.15.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9229cfe53dfd69f0609a49f65461bd93001ea1ef889cd5529dd176593f5338a1"
+dependencies = [
+ "foldhash 0.1.5",
+]
+
+[[package]]
+name = "hashbrown"
+version = "0.17.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "4f467dd6dccf739c208452f8014c75c18bb8301b050ad1cfb27153803edb0f51"
+
+[[package]]
+name = "heck"
+version = "0.4.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "95505c38b4572b2d910cecb0281560f54b440a19336cbbcb27bf6ce6adc6f5a8"
+
+[[package]]
+name = "heck"
+version = "0.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "2304e00983f87ffb38b55b444b5e3b60a884b5d30c0fca7d82fe33449bbe55ea"
+
+[[package]]
+name = "hermit-abi"
+version = "0.5.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "fc0fef456e4baa96da950455cd02c081ca953b141298e41db3fc7e36b1da849c"
+
+[[package]]
+name = "hex"
+version = "0.4.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7f24254aa9a54b5c858eaee2f5bccdb46aaf0e486a595ed5fd8f86ba55232a70"
+
+[[package]]
+name = "html5ever"
+version = "0.29.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3b7410cae13cbc75623c98ac4cbfd1f0bedddf3227afc24f370cf0f50a44a11c"
+dependencies = [
+ "log",
+ "mac",
+ "markup5ever 0.14.1",
+ "match_token",
+]
+
+[[package]]
+name = "html5ever"
+version = "0.38.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1054432bae2f14e0061e33d23402fbaa67a921d319d56adc6bcf887ddad1cbc2"
+dependencies = [
+ "log",
+ "markup5ever 0.38.0",
+]
+
+[[package]]
+name = "http"
+version = "1.4.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e3ba2a386d7f85a81f119ad7498ebe444d2e22c2af0b86b069416ace48b3311a"
+dependencies = [
+ "bytes",
+ "itoa",
+]
+
+[[package]]
+name = "http-body"
+version = "1.0.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1efedce1fb8e6913f23e0c92de8e62cd5b772a67e7b3946df930a62566c93184"
+dependencies = [
+ "bytes",
+ "http",
+]
+
+[[package]]
+name = "http-body-util"
+version = "0.1.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b021d93e26becf5dc7e1b75b1bed1fd93124b374ceb73f43d4d4eafec896a64a"
+dependencies = [
+ "bytes",
+ "futures-core",
+ "http",
+ "http-body",
+ "pin-project-lite",
+]
+
+[[package]]
+name = "httparse"
+version = "1.10.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "6dbf3de79e51f3d586ab4cb9d5c3e2c14aa28ed23d180cf89b4df0454a69cc87"
+
+[[package]]
+name = "hyper"
+version = "1.9.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "6299f016b246a94207e63da54dbe807655bf9e00044f73ded42c3ac5305fbcca"
+dependencies = [
+ "atomic-waker",
+ "bytes",
+ "futures-channel",
+ "futures-core",
+ "http",
+ "http-body",
+ "httparse",
+ "itoa",
+ "pin-project-lite",
+ "smallvec",
+ "tokio",
+ "want",
+]
+
+[[package]]
+name = "hyper-rustls"
+version = "0.27.9"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "33ca68d021ef39cf6463ab54c1d0f5daf03377b70561305bb89a8f83aab66e0f"
+dependencies = [
+ "http",
+ "hyper",
+ "hyper-util",
+ "rustls",
+ "tokio",
+ "tokio-rustls",
+ "tower-service",
+]
+
+[[package]]
+name = "hyper-util"
+version = "0.1.20"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "96547c2556ec9d12fb1578c4eaf448b04993e7fb79cbaad930a656880a6bdfa0"
+dependencies = [
+ "base64 0.22.1",
+ "bytes",
+ "futures-channel",
+ "futures-util",
+ "http",
+ "http-body",
+ "hyper",
+ "ipnet",
+ "libc",
+ "percent-encoding",
+ "pin-project-lite",
+ "socket2",
+ "tokio",
+ "tower-service",
+ "tracing",
+]
+
+[[package]]
+name = "iana-time-zone"
+version = "0.1.65"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e31bc9ad994ba00e440a8aa5c9ef0ec67d5cb5e5cb0cc7f8b744a35b389cc470"
+dependencies = [
+ "android_system_properties",
+ "core-foundation-sys",
+ "iana-time-zone-haiku",
+ "js-sys",
+ "log",
+ "wasm-bindgen",
+ "windows-core 0.62.2",
+]
+
+[[package]]
+name = "iana-time-zone-haiku"
+version = "0.1.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f31827a206f56af32e590ba56d5d2d085f558508192593743f16b2306495269f"
+dependencies = [
+ "cc",
+]
+
+[[package]]
+name = "ico"
+version = "0.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3e795dff5605e0f04bff85ca41b51a96b83e80b281e96231bcaaf1ac35103371"
+dependencies = [
+ "byteorder",
+ "png",
+]
+
+[[package]]
+name = "icu_collections"
+version = "2.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "2984d1cd16c883d7935b9e07e44071dca8d917fd52ecc02c04d5fa0b5a3f191c"
+dependencies = [
+ "displaydoc",
+ "potential_utf",
+ "utf8_iter",
+ "yoke",
+ "zerofrom",
+ "zerovec",
+]
+
+[[package]]
+name = "icu_locale_core"
+version = "2.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "92219b62b3e2b4d88ac5119f8904c10f8f61bf7e95b640d25ba3075e6cac2c29"
+dependencies = [
+ "displaydoc",
+ "litemap",
+ "tinystr",
+ "writeable",
+ "zerovec",
+]
+
+[[package]]
+name = "icu_normalizer"
+version = "2.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c56e5ee99d6e3d33bd91c5d85458b6005a22140021cc324cea84dd0e72cff3b4"
+dependencies = [
+ "icu_collections",
+ "icu_normalizer_data",
+ "icu_properties",
+ "icu_provider",
+ "smallvec",
+ "zerovec",
+]
+
+[[package]]
+name = "icu_normalizer_data"
+version = "2.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "da3be0ae77ea334f4da67c12f149704f19f81d1adf7c51cf482943e84a2bad38"
+
+[[package]]
+name = "icu_properties"
+version = "2.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "bee3b67d0ea5c2cca5003417989af8996f8604e34fb9ddf96208a033901e70de"
+dependencies = [
+ "icu_collections",
+ "icu_locale_core",
+ "icu_properties_data",
+ "icu_provider",
+ "zerotrie",
+ "zerovec",
+]
+
+[[package]]
+name = "icu_properties_data"
+version = "2.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8e2bbb201e0c04f7b4b3e14382af113e17ba4f63e2c9d2ee626b720cbce54a14"
+
+[[package]]
+name = "icu_provider"
+version = "2.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "139c4cf31c8b5f33d7e199446eff9c1e02decfc2f0eec2c8d71f65befa45b421"
+dependencies = [
+ "displaydoc",
+ "icu_locale_core",
+ "writeable",
+ "yoke",
+ "zerofrom",
+ "zerotrie",
+ "zerovec",
+]
+
+[[package]]
+name = "id-arena"
+version = "2.3.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3d3067d79b975e8844ca9eb072e16b31c3c1c36928edf9c6789548c524d0d954"
+
+[[package]]
+name = "ident_case"
+version = "1.0.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b9e0384b61958566e926dc50660321d12159025e767c18e043daf26b70104c39"
+
+[[package]]
+name = "idna"
+version = "1.1.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3b0875f23caa03898994f6ddc501886a45c7d3d62d04d2d90788d47be1b1e4de"
+dependencies = [
+ "idna_adapter",
+ "smallvec",
+ "utf8_iter",
+]
+
+[[package]]
+name = "idna_adapter"
+version = "1.2.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3acae9609540aa318d1bc588455225fb2085b9ed0c4f6bd0d9d5bcd86f1a0344"
+dependencies = [
+ "icu_normalizer",
+ "icu_properties",
+]
+
+[[package]]
+name = "indexmap"
+version = "1.9.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "bd070e393353796e801d209ad339e89596eb4c8d430d18ede6a1cced8fafbd99"
+dependencies = [
+ "autocfg",
+ "hashbrown 0.12.3",
+ "serde",
+]
+
+[[package]]
+name = "indexmap"
+version = "2.14.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d466e9454f08e4a911e14806c24e16fba1b4c121d1ea474396f396069cf949d9"
+dependencies = [
+ "equivalent",
+ "hashbrown 0.17.0",
+ "serde",
+ "serde_core",
+]
+
+[[package]]
+name = "infer"
+version = "0.19.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "a588916bfdfd92e71cacef98a63d9b1f0d74d6599980d11894290e7ddefffcf7"
+dependencies = [
+ "cfb",
+]
+
+[[package]]
+name = "ipnet"
+version = "2.12.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d98f6fed1fde3f8c21bc40a1abb88dd75e67924f9cffc3ef95607bad8017f8e2"
+
+[[package]]
+name = "iri-string"
+version = "0.7.12"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "25e659a4bb38e810ebc252e53b5814ff908a8c58c2a9ce2fae1bbec24cbf4e20"
+dependencies = [
+ "memchr",
+ "serde",
+]
+
+[[package]]
+name = "is-docker"
+version = "0.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "928bae27f42bc99b60d9ac7334e3a21d10ad8f1835a4e12ec3ec0464765ed1b3"
+dependencies = [
+ "once_cell",
+]
+
+[[package]]
+name = "is-wsl"
+version = "0.4.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "173609498df190136aa7dea1a91db051746d339e18476eed5ca40521f02d7aa5"
+dependencies = [
+ "is-docker",
+ "once_cell",
+]
+
+[[package]]
+name = "itoa"
+version = "1.0.18"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8f42a60cbdf9a97f5d2305f08a87dc4e09308d1276d28c869c684d7777685682"
+
+[[package]]
+name = "javascriptcore-rs"
+version = "1.1.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ca5671e9ffce8ffba57afc24070e906da7fc4b1ba66f2cabebf61bf2ea257fcc"
+dependencies = [
+ "bitflags 1.3.2",
+ "glib",
+ "javascriptcore-rs-sys",
+]
+
+[[package]]
+name = "javascriptcore-rs-sys"
+version = "1.1.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "af1be78d14ffa4b75b66df31840478fef72b51f8c2465d4ca7c194da9f7a5124"
+dependencies = [
+ "glib-sys",
+ "gobject-sys",
+ "libc",
+ "system-deps",
+]
+
+[[package]]
+name = "jni"
+version = "0.21.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1a87aa2bb7d2af34197c04845522473242e1aa17c12f4935d5856491a7fb8c97"
+dependencies = [
+ "cesu8",
+ "cfg-if",
+ "combine",
+ "jni-sys 0.3.1",
+ "log",
+ "thiserror 1.0.69",
+ "walkdir",
+ "windows-sys 0.45.0",
+]
+
+[[package]]
+name = "jni-sys"
+version = "0.3.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "41a652e1f9b6e0275df1f15b32661cf0d4b78d4d87ddec5e0c3c20f097433258"
+dependencies = [
+ "jni-sys 0.4.1",
+]
+
+[[package]]
+name = "jni-sys"
+version = "0.4.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c6377a88cb3910bee9b0fa88d4f42e1d2da8e79915598f65fb0c7ee14c878af2"
+dependencies = [
+ "jni-sys-macros",
+]
+
+[[package]]
+name = "jni-sys-macros"
+version = "0.4.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "38c0b942f458fe50cdac086d2f946512305e5631e720728f2a61aabcd47a6264"
+dependencies = [
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "js-sys"
+version = "0.3.95"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "2964e92d1d9dc3364cae4d718d93f227e3abb088e747d92e0395bfdedf1c12ca"
+dependencies = [
+ "cfg-if",
+ "futures-util",
+ "once_cell",
+ "wasm-bindgen",
+]
+
+[[package]]
+name = "json-patch"
+version = "3.0.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "863726d7afb6bc2590eeff7135d923545e5e964f004c2ccf8716c25e70a86f08"
+dependencies = [
+ "jsonptr",
+ "serde",
+ "serde_json",
+ "thiserror 1.0.69",
+]
+
+[[package]]
+name = "jsonptr"
+version = "0.6.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5dea2b27dd239b2556ed7a25ba842fe47fd602e7fc7433c2a8d6106d4d9edd70"
+dependencies = [
+ "serde",
+ "serde_json",
+]
+
+[[package]]
+name = "keyboard-types"
+version = "0.7.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b750dcadc39a09dbadd74e118f6dd6598df77fa01df0cfcdc52c28dece74528a"
+dependencies = [
+ "bitflags 2.11.1",
+ "serde",
+ "unicode-segmentation",
+]
+
+[[package]]
+name = "kuchikiki"
+version = "0.8.8-speedreader"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "02cb977175687f33fa4afa0c95c112b987ea1443e5a51c8f8ff27dc618270cc2"
+dependencies = [
+ "cssparser 0.29.6",
+ "html5ever 0.29.1",
+ "indexmap 2.14.0",
+ "selectors 0.24.0",
+]
+
+[[package]]
+name = "leb128fmt"
+version = "0.1.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "09edd9e8b54e49e587e4f6295a7d29c3ea94d469cb40ab8ca70b288248a81db2"
+
+[[package]]
+name = "libappindicator"
+version = "0.9.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "03589b9607c868cc7ae54c0b2a22c8dc03dd41692d48f2d7df73615c6a95dc0a"
+dependencies = [
+ "glib",
+ "gtk",
+ "gtk-sys",
+ "libappindicator-sys",
+ "log",
+]
+
+[[package]]
+name = "libappindicator-sys"
+version = "0.9.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "6e9ec52138abedcc58dc17a7c6c0c00a2bdb4f3427c7f63fa97fd0d859155caf"
+dependencies = [
+ "gtk-sys",
+ "libloading",
+ "once_cell",
+]
+
+[[package]]
+name = "libc"
+version = "0.2.185"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "52ff2c0fe9bc6cb6b14a0592c2ff4fa9ceb83eea9db979b0487cd054946a2b8f"
+
+[[package]]
+name = "libloading"
+version = "0.7.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b67380fd3b2fbe7527a606e18729d21c6f3951633d0500574c4dc22d2d638b9f"
+dependencies = [
+ "cfg-if",
+ "winapi",
+]
+
+[[package]]
+name = "libredox"
+version = "0.1.16"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e02f3bb43d335493c96bf3fd3a321600bf6bd07ed34bc64118e9293bdffea46c"
+dependencies = [
+ "bitflags 2.11.1",
+ "libc",
+ "plain",
+ "redox_syscall 0.7.4",
+]
+
+[[package]]
+name = "linux-raw-sys"
+version = "0.12.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "32a66949e030da00e8c7d4434b251670a91556f4144941d37452769c25d58a53"
+
+[[package]]
+name = "litemap"
+version = "0.8.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "92daf443525c4cce67b150400bc2316076100ce0b3686209eb8cf3c31612e6f0"
+
+[[package]]
+name = "lock_api"
+version = "0.4.14"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "224399e74b87b5f3557511d98dff8b14089b3dadafcab6bb93eab67d3aace965"
+dependencies = [
+ "scopeguard",
+]
+
+[[package]]
+name = "log"
+version = "0.4.29"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5e5032e24019045c762d3c0f28f5b6b8bbf38563a65908389bf7978758920897"
+dependencies = [
+ "value-bag",
+]
+
+[[package]]
+name = "mac"
+version = "0.1.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c41e0c4fef86961ac6d6f8a82609f55f31b05e4fce149ac5710e439df7619ba4"
+
+[[package]]
+name = "markup5ever"
+version = "0.14.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c7a7213d12e1864c0f002f52c2923d4556935a43dec5e71355c2760e0f6e7a18"
+dependencies = [
+ "log",
+ "phf 0.11.3",
+ "phf_codegen 0.11.3",
+ "string_cache 0.8.9",
+ "string_cache_codegen 0.5.4",
+ "tendril 0.4.3",
+]
+
+[[package]]
+name = "markup5ever"
+version = "0.38.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8983d30f2915feeaaab2d6babdd6bc7e9ed1a00b66b5e6d74df19aa9c0e91862"
+dependencies = [
+ "log",
+ "tendril 0.5.0",
+ "web_atoms",
+]
+
+[[package]]
+name = "match_token"
+version = "0.1.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "88a9689d8d44bf9964484516275f5cd4c9b59457a6940c1d5d0ecbb94510a36b"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "matches"
+version = "0.1.10"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "2532096657941c2fea9c289d370a250971c689d4f143798ff67113ec042024a5"
+
+[[package]]
+name = "memchr"
+version = "2.8.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f8ca58f447f06ed17d5fc4043ce1b10dd205e060fb3ce5b979b8ed8e59ff3f79"
+
+[[package]]
+name = "memoffset"
+version = "0.9.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "488016bfae457b036d996092f6cb448677611ce4449e970ceaf42695203f218a"
+dependencies = [
+ "autocfg",
+]
+
+[[package]]
+name = "mime"
+version = "0.3.17"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "6877bb514081ee2a7ff5ef9de3281f14a4dd4bceac4c09388074a6b5df8a139a"
+
+[[package]]
+name = "minisign-verify"
+version = "0.2.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "22f9645cb765ea72b8111f36c522475d2daa0d22c957a9826437e97534bc4e9e"
+
+[[package]]
+name = "miniz_oxide"
+version = "0.8.9"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1fa76a2c86f704bdb222d66965fb3d63269ce38518b83cb0575fca855ebb6316"
+dependencies = [
+ "adler2",
+ "simd-adler32",
+]
+
+[[package]]
+name = "mio"
+version = "1.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "50b7e5b27aa02a74bac8c3f23f448f8d87ff11f92d3aac1a6ed369ee08cc56c1"
+dependencies = [
+ "libc",
+ "wasi 0.11.1+wasi-snapshot-preview1",
+ "windows-sys 0.61.2",
+]
+
+[[package]]
+name = "muda"
+version = "0.17.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7c9fec5a4e89860383d778d10563a605838f8f0b2f9303868937e5ff32e86177"
+dependencies = [
+ "crossbeam-channel",
+ "dpi",
+ "gtk",
+ "keyboard-types",
+ "objc2",
+ "objc2-app-kit",
+ "objc2-core-foundation",
+ "objc2-foundation",
+ "once_cell",
+ "png",
+ "serde",
+ "thiserror 2.0.18",
+ "windows-sys 0.60.2",
+]
+
+[[package]]
+name = "ndk"
+version = "0.9.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c3f42e7bbe13d351b6bead8286a43aac9534b82bd3cc43e47037f012ebfd62d4"
+dependencies = [
+ "bitflags 2.11.1",
+ "jni-sys 0.3.1",
+ "log",
+ "ndk-sys",
+ "num_enum",
+ "raw-window-handle",
+ "thiserror 1.0.69",
+]
+
+[[package]]
+name = "ndk-context"
+version = "0.1.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "27b02d87554356db9e9a873add8782d4ea6e3e58ea071a9adb9a2e8ddb884a8b"
+
+[[package]]
+name = "ndk-sys"
+version = "0.6.0+11769913"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ee6cda3051665f1fb8d9e08fc35c96d5a244fb1be711a03b71118828afc9a873"
+dependencies = [
+ "jni-sys 0.3.1",
+]
+
+[[package]]
+name = "new_debug_unreachable"
+version = "1.0.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "650eef8c711430f1a879fdd01d4745a7deea475becfb90269c06775983bbf086"
+
+[[package]]
+name = "nodrop"
+version = "0.1.14"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "72ef4a56884ca558e5ddb05a1d1e7e1bfd9a68d9ed024c21704cc98872dae1bb"
+
+[[package]]
+name = "num-conv"
+version = "0.2.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c6673768db2d862beb9b39a78fdcb1a69439615d5794a1be50caa9bc92c81967"
+
+[[package]]
+name = "num-traits"
+version = "0.2.19"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "071dfc062690e90b734c0b2273ce72ad0ffa95f0c74596bc250dcfd960262841"
+dependencies = [
+ "autocfg",
+]
+
+[[package]]
+name = "num_enum"
+version = "0.7.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5d0bca838442ec211fa11de3a8b0e0e8f3a4522575b5c4c06ed722e005036f26"
+dependencies = [
+ "num_enum_derive",
+ "rustversion",
+]
+
+[[package]]
+name = "num_enum_derive"
+version = "0.7.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "680998035259dcfcafe653688bf2aa6d3e2dc05e98be6ab46afb089dc84f1df8"
+dependencies = [
+ "proc-macro-crate 3.5.0",
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "num_threads"
+version = "0.1.7"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5c7398b9c8b70908f6371f47ed36737907c87c52af34c268fed0bf0ceb92ead9"
+dependencies = [
+ "libc",
+]
+
+[[package]]
+name = "objc2"
+version = "0.6.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3a12a8ed07aefc768292f076dc3ac8c48f3781c8f2d5851dd3d98950e8c5a89f"
+dependencies = [
+ "objc2-encode",
+ "objc2-exception-helper",
+]
+
+[[package]]
+name = "objc2-app-kit"
+version = "0.3.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d49e936b501e5c5bf01fda3a9452ff86dc3ea98ad5f283e1455153142d97518c"
+dependencies = [
+ "bitflags 2.11.1",
+ "block2",
+ "objc2",
+ "objc2-core-foundation",
+ "objc2-foundation",
+]
+
+[[package]]
+name = "objc2-core-foundation"
+version = "0.3.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "2a180dd8642fa45cdb7dd721cd4c11b1cadd4929ce112ebd8b9f5803cc79d536"
+dependencies = [
+ "bitflags 2.11.1",
+ "dispatch2",
+ "objc2",
+]
+
+[[package]]
+name = "objc2-core-graphics"
+version = "0.3.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e022c9d066895efa1345f8e33e584b9f958da2fd4cd116792e15e07e4720a807"
+dependencies = [
+ "bitflags 2.11.1",
+ "dispatch2",
+ "objc2",
+ "objc2-core-foundation",
+ "objc2-io-surface",
+]
+
+[[package]]
+name = "objc2-encode"
+version = "4.1.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ef25abbcd74fb2609453eb695bd2f860d389e457f67dc17cafc8b8cbc89d0c33"
+
+[[package]]
+name = "objc2-exception-helper"
+version = "0.1.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c7a1c5fbb72d7735b076bb47b578523aedc40f3c439bea6dfd595c089d79d98a"
+dependencies = [
+ "cc",
+]
+
+[[package]]
+name = "objc2-foundation"
+version = "0.3.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e3e0adef53c21f888deb4fa59fc59f7eb17404926ee8a6f59f5df0fd7f9f3272"
+dependencies = [
+ "bitflags 2.11.1",
+ "block2",
+ "libc",
+ "objc2",
+ "objc2-core-foundation",
+]
+
+[[package]]
+name = "objc2-io-surface"
+version = "0.3.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "180788110936d59bab6bd83b6060ffdfffb3b922ba1396b312ae795e1de9d81d"
+dependencies = [
+ "bitflags 2.11.1",
+ "objc2",
+ "objc2-core-foundation",
+]
+
+[[package]]
+name = "objc2-osa-kit"
+version = "0.3.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f112d1746737b0da274ef79a23aac283376f335f4095a083a267a082f21db0c0"
+dependencies = [
+ "bitflags 2.11.1",
+ "objc2",
+ "objc2-app-kit",
+ "objc2-foundation",
+]
+
+[[package]]
+name = "objc2-quartz-core"
+version = "0.3.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "96c1358452b371bf9f104e21ec536d37a650eb10f7ee379fff67d2e08d537f1f"
+dependencies = [
+ "bitflags 2.11.1",
+ "objc2",
+ "objc2-core-foundation",
+ "objc2-foundation",
+]
+
+[[package]]
+name = "objc2-ui-kit"
+version = "0.3.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d87d638e33c06f577498cbcc50491496a3ed4246998a7fbba7ccb98b1e7eab22"
+dependencies = [
+ "bitflags 2.11.1",
+ "objc2",
+ "objc2-core-foundation",
+ "objc2-foundation",
+]
+
+[[package]]
+name = "objc2-web-kit"
+version = "0.3.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b2e5aaab980c433cf470df9d7af96a7b46a9d892d521a2cbbb2f8a4c16751e7f"
+dependencies = [
+ "bitflags 2.11.1",
+ "block2",
+ "objc2",
+ "objc2-app-kit",
+ "objc2-core-foundation",
+ "objc2-foundation",
+]
+
+[[package]]
+name = "once_cell"
+version = "1.21.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9f7c3e4beb33f85d45ae3e3a1792185706c8e16d043238c593331cc7cd313b50"
+
+[[package]]
+name = "open"
+version = "5.3.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "43bb73a7fa3799b198970490a51174027ba0d4ec504b03cd08caf513d40024bc"
+dependencies = [
+ "dunce",
+ "is-wsl",
+ "libc",
+ "pathdiff",
+]
+
+[[package]]
+name = "openssl-probe"
+version = "0.2.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7c87def4c32ab89d880effc9e097653c8da5d6ef28e6b539d313baaacfbafcbe"
+
+[[package]]
+name = "option-ext"
+version = "0.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "04744f49eae99ab78e0d5c0b603ab218f515ea8cfe5a456d7629ad883a3b6e7d"
+
+[[package]]
+name = "ordered-stream"
+version = "0.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9aa2b01e1d916879f73a53d01d1d6cee68adbb31d6d9177a8cfce093cced1d50"
+dependencies = [
+ "futures-core",
+ "pin-project-lite",
+]
+
+[[package]]
+name = "osakit"
+version = "0.3.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "732c71caeaa72c065bb69d7ea08717bd3f4863a4f451402fc9513e29dbd5261b"
+dependencies = [
+ "objc2",
+ "objc2-foundation",
+ "objc2-osa-kit",
+ "serde",
+ "serde_json",
+ "thiserror 2.0.18",
+]
+
+[[package]]
+name = "pango"
+version = "0.18.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7ca27ec1eb0457ab26f3036ea52229edbdb74dee1edd29063f5b9b010e7ebee4"
+dependencies = [
+ "gio",
+ "glib",
+ "libc",
+ "once_cell",
+ "pango-sys",
+]
+
+[[package]]
+name = "pango-sys"
+version = "0.18.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "436737e391a843e5933d6d9aa102cb126d501e815b83601365a948a518555dc5"
+dependencies = [
+ "glib-sys",
+ "gobject-sys",
+ "libc",
+ "system-deps",
+]
+
+[[package]]
+name = "parking"
+version = "2.2.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f38d5652c16fde515bb1ecef450ab0f6a219d619a7274976324d5e377f7dceba"
+
+[[package]]
+name = "parking_lot"
+version = "0.12.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "93857453250e3077bd71ff98b6a65ea6621a19bb0f559a85248955ac12c45a1a"
+dependencies = [
+ "lock_api",
+ "parking_lot_core",
+]
+
+[[package]]
+name = "parking_lot_core"
+version = "0.9.12"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "2621685985a2ebf1c516881c026032ac7deafcda1a2c9b7850dc81e3dfcb64c1"
+dependencies = [
+ "cfg-if",
+ "libc",
+ "redox_syscall 0.5.18",
+ "smallvec",
+ "windows-link 0.2.1",
+]
+
+[[package]]
+name = "pathdiff"
+version = "0.2.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "df94ce210e5bc13cb6651479fa48d14f601d9858cfe0467f43ae157023b938d3"
+
+[[package]]
+name = "percent-encoding"
+version = "2.3.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9b4f627cb1b25917193a259e49bdad08f671f8d9708acfd5fe0a8c1455d87220"
+
+[[package]]
+name = "phf"
+version = "0.8.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3dfb61232e34fcb633f43d12c58f83c1df82962dcdfa565a4e866ffc17dafe12"
+dependencies = [
+ "phf_shared 0.8.0",
+]
+
+[[package]]
+name = "phf"
+version = "0.10.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "fabbf1ead8a5bcbc20f5f8b939ee3f5b0f6f281b6ad3468b84656b658b455259"
+dependencies = [
+ "phf_macros 0.10.0",
+ "phf_shared 0.10.0",
+ "proc-macro-hack",
+]
+
+[[package]]
+name = "phf"
+version = "0.11.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1fd6780a80ae0c52cc120a26a1a42c1ae51b247a253e4e06113d23d2c2edd078"
+dependencies = [
+ "phf_macros 0.11.3",
+ "phf_shared 0.11.3",
+]
+
+[[package]]
+name = "phf"
+version = "0.13.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c1562dc717473dbaa4c1f85a36410e03c047b2e7df7f45ee938fbef64ae7fadf"
+dependencies = [
+ "phf_macros 0.13.1",
+ "phf_shared 0.13.1",
+ "serde",
+]
+
+[[package]]
+name = "phf_codegen"
+version = "0.8.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "cbffee61585b0411840d3ece935cce9cb6321f01c45477d30066498cd5e1a815"
+dependencies = [
+ "phf_generator 0.8.0",
+ "phf_shared 0.8.0",
+]
+
+[[package]]
+name = "phf_codegen"
+version = "0.11.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "aef8048c789fa5e851558d709946d6d79a8ff88c0440c587967f8e94bfb1216a"
+dependencies = [
+ "phf_generator 0.11.3",
+ "phf_shared 0.11.3",
+]
+
+[[package]]
+name = "phf_codegen"
+version = "0.13.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "49aa7f9d80421bca176ca8dbfebe668cc7a2684708594ec9f3c0db0805d5d6e1"
+dependencies = [
+ "phf_generator 0.13.1",
+ "phf_shared 0.13.1",
+]
+
+[[package]]
+name = "phf_generator"
+version = "0.8.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "17367f0cc86f2d25802b2c26ee58a7b23faeccf78a396094c13dced0d0182526"
+dependencies = [
+ "phf_shared 0.8.0",
+ "rand 0.7.3",
+]
+
+[[package]]
+name = "phf_generator"
+version = "0.10.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5d5285893bb5eb82e6aaf5d59ee909a06a16737a8970984dd7746ba9283498d6"
+dependencies = [
+ "phf_shared 0.10.0",
+ "rand 0.8.5",
+]
+
+[[package]]
+name = "phf_generator"
+version = "0.11.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3c80231409c20246a13fddb31776fb942c38553c51e871f8cbd687a4cfb5843d"
+dependencies = [
+ "phf_shared 0.11.3",
+ "rand 0.8.5",
+]
+
+[[package]]
+name = "phf_generator"
+version = "0.13.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "135ace3a761e564ec88c03a77317a7c6b80bb7f7135ef2544dbe054243b89737"
+dependencies = [
+ "fastrand",
+ "phf_shared 0.13.1",
+]
+
+[[package]]
+name = "phf_macros"
+version = "0.10.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "58fdf3184dd560f160dd73922bea2d5cd6e8f064bf4b13110abd81b03697b4e0"
+dependencies = [
+ "phf_generator 0.10.0",
+ "phf_shared 0.10.0",
+ "proc-macro-hack",
+ "proc-macro2",
+ "quote",
+ "syn 1.0.109",
+]
+
+[[package]]
+name = "phf_macros"
+version = "0.11.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f84ac04429c13a7ff43785d75ad27569f2951ce0ffd30a3321230db2fc727216"
+dependencies = [
+ "phf_generator 0.11.3",
+ "phf_shared 0.11.3",
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "phf_macros"
+version = "0.13.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "812f032b54b1e759ccd5f8b6677695d5268c588701effba24601f6932f8269ef"
+dependencies = [
+ "phf_generator 0.13.1",
+ "phf_shared 0.13.1",
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "phf_shared"
+version = "0.8.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c00cf8b9eafe68dde5e9eaa2cef8ee84a9336a47d566ec55ca16589633b65af7"
+dependencies = [
+ "siphasher 0.3.11",
+]
+
+[[package]]
+name = "phf_shared"
+version = "0.10.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b6796ad771acdc0123d2a88dc428b5e38ef24456743ddb1744ed628f9815c096"
+dependencies = [
+ "siphasher 0.3.11",
+]
+
+[[package]]
+name = "phf_shared"
+version = "0.11.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "67eabc2ef2a60eb7faa00097bd1ffdb5bd28e62bf39990626a582201b7a754e5"
+dependencies = [
+ "siphasher 1.0.2",
+]
+
+[[package]]
+name = "phf_shared"
+version = "0.13.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e57fef6bc5981e38c2ce2d63bfa546861309f875b8a75f092d1d54ae2d64f266"
+dependencies = [
+ "siphasher 1.0.2",
+]
+
+[[package]]
+name = "pin-project-lite"
+version = "0.2.17"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "a89322df9ebe1c1578d689c92318e070967d1042b512afbe49518723f4e6d5cd"
+
+[[package]]
+name = "piper"
+version = "0.2.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c835479a4443ded371d6c535cbfd8d31ad92c5d23ae9770a61bc155e4992a3c1"
+dependencies = [
+ "atomic-waker",
+ "fastrand",
+ "futures-io",
+]
+
+[[package]]
+name = "pkg-config"
+version = "0.3.33"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "19f132c84eca552bf34cab8ec81f1c1dcc229b811638f9d283dceabe58c5569e"
+
+[[package]]
+name = "plain"
+version = "0.2.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b4596b6d070b27117e987119b4dac604f3c58cfb0b191112e24771b2faeac1a6"
+
+[[package]]
+name = "plist"
+version = "1.8.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "740ebea15c5d1428f910cd1a5f52cebf8d25006245ed8ade92702f4943d91e07"
+dependencies = [
+ "base64 0.22.1",
+ "indexmap 2.14.0",
+ "quick-xml",
+ "serde",
+ "time",
+]
+
+[[package]]
+name = "png"
+version = "0.17.16"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "82151a2fc869e011c153adc57cf2789ccb8d9906ce52c0b39a6b5697749d7526"
+dependencies = [
+ "bitflags 1.3.2",
+ "crc32fast",
+ "fdeflate",
+ "flate2",
+ "miniz_oxide",
+]
+
+[[package]]
+name = "polling"
+version = "3.11.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5d0e4f59085d47d8241c88ead0f274e8a0cb551f3625263c05eb8dd897c34218"
+dependencies = [
+ "cfg-if",
+ "concurrent-queue",
+ "hermit-abi",
+ "pin-project-lite",
+ "rustix",
+ "windows-sys 0.61.2",
+]
+
+[[package]]
+name = "potential_utf"
+version = "0.1.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0103b1cef7ec0cf76490e969665504990193874ea05c85ff9bab8b911d0a0564"
+dependencies = [
+ "zerovec",
+]
+
+[[package]]
+name = "powerfmt"
+version = "0.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "439ee305def115ba05938db6eb1644ff94165c5ab5e9420d1c1bcedbba909391"
+
+[[package]]
+name = "ppv-lite86"
+version = "0.2.21"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "85eae3c4ed2f50dcfe72643da4befc30deadb458a9b590d720cde2f2b1e97da9"
+dependencies = [
+ "zerocopy",
+]
+
+[[package]]
+name = "precomputed-hash"
+version = "0.1.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "925383efa346730478fb4838dbe9137d2a47675ad789c546d150a6e1dd4ab31c"
+
+[[package]]
+name = "prettyplease"
+version = "0.2.37"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "479ca8adacdd7ce8f1fb39ce9ecccbfe93a3f1344b3d0d97f20bc0196208f62b"
+dependencies = [
+ "proc-macro2",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "proc-macro-crate"
+version = "1.3.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7f4c021e1093a56626774e81216a4ce732a735e5bad4868a03f3ed65ca0c3919"
+dependencies = [
+ "once_cell",
+ "toml_edit 0.19.15",
+]
+
+[[package]]
+name = "proc-macro-crate"
+version = "2.0.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b00f26d3400549137f92511a46ac1cd8ce37cb5598a96d382381458b992a5d24"
+dependencies = [
+ "toml_datetime 0.6.3",
+ "toml_edit 0.20.2",
+]
+
+[[package]]
+name = "proc-macro-crate"
+version = "3.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e67ba7e9b2b56446f1d419b1d807906278ffa1a658a8a5d8a39dcb1f5a78614f"
+dependencies = [
+ "toml_edit 0.25.11+spec-1.1.0",
+]
+
+[[package]]
+name = "proc-macro-error"
+version = "1.0.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "da25490ff9892aab3fcf7c36f08cfb902dd3e71ca0f9f9517bea02a73a5ce38c"
+dependencies = [
+ "proc-macro-error-attr",
+ "proc-macro2",
+ "quote",
+ "syn 1.0.109",
+ "version_check",
+]
+
+[[package]]
+name = "proc-macro-error-attr"
+version = "1.0.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "a1be40180e52ecc98ad80b184934baf3d0d29f979574e439af5a55274b35f869"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "version_check",
+]
+
+[[package]]
+name = "proc-macro-hack"
+version = "0.5.20+deprecated"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "dc375e1527247fe1a97d8b7156678dfe7c1af2fc075c9a4db3690ecd2a148068"
+
+[[package]]
+name = "proc-macro2"
+version = "1.0.106"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8fd00f0bb2e90d81d1044c2b32617f68fcb9fa3bb7640c23e9c748e53fb30934"
+dependencies = [
+ "unicode-ident",
+]
+
+[[package]]
+name = "ptr_meta"
+version = "0.1.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0738ccf7ea06b608c10564b31debd4f5bc5e197fc8bfe088f68ae5ce81e7a4f1"
+dependencies = [
+ "ptr_meta_derive",
+]
+
+[[package]]
+name = "ptr_meta_derive"
+version = "0.1.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "16b845dbfca988fa33db069c0e230574d15a3088f147a87b64c7589eb662c9ac"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 1.0.109",
+]
+
+[[package]]
+name = "quick-xml"
+version = "0.38.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b66c2058c55a409d601666cffe35f04333cf1013010882cec174a7467cd4e21c"
+dependencies = [
+ "memchr",
+]
+
+[[package]]
+name = "quote"
+version = "1.0.45"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "41f2619966050689382d2b44f664f4bc593e129785a36d6ee376ddf37259b924"
+dependencies = [
+ "proc-macro2",
+]
+
+[[package]]
+name = "r-efi"
+version = "5.3.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "69cdb34c158ceb288df11e18b4bd39de994f6657d83847bdffdbd7f346754b0f"
+
+[[package]]
+name = "r-efi"
+version = "6.0.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f8dcc9c7d52a811697d2151c701e0d08956f92b0e24136cf4cf27b57a6a0d9bf"
+
+[[package]]
+name = "radium"
+version = "0.7.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "dc33ff2d4973d518d823d61aa239014831e521c75da58e3df4840d3f47749d09"
+
+[[package]]
+name = "rand"
+version = "0.7.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "6a6b1679d49b24bbfe0c803429aa1874472f50d9b363131f0e89fc356b544d03"
+dependencies = [
+ "getrandom 0.1.16",
+ "libc",
+ "rand_chacha 0.2.2",
+ "rand_core 0.5.1",
+ "rand_hc",
+ "rand_pcg",
+]
+
+[[package]]
+name = "rand"
+version = "0.8.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "34af8d1a0e25924bc5b7c43c079c942339d8f0a8b57c39049bef581b46327404"
+dependencies = [
+ "libc",
+ "rand_chacha 0.3.1",
+ "rand_core 0.6.4",
+]
+
+[[package]]
+name = "rand_chacha"
+version = "0.2.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f4c8ed856279c9737206bf725bf36935d8666ead7aa69b52be55af369d193402"
+dependencies = [
+ "ppv-lite86",
+ "rand_core 0.5.1",
+]
+
+[[package]]
+name = "rand_chacha"
+version = "0.3.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e6c10a63a0fa32252be49d21e7709d4d4baf8d231c2dbce1eaa8141b9b127d88"
+dependencies = [
+ "ppv-lite86",
+ "rand_core 0.6.4",
+]
+
+[[package]]
+name = "rand_core"
+version = "0.5.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "90bde5296fc891b0cef12a6d03ddccc162ce7b2aff54160af9338f8d40df6d19"
+dependencies = [
+ "getrandom 0.1.16",
+]
+
+[[package]]
+name = "rand_core"
+version = "0.6.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ec0be4795e2f6a28069bec0b5ff3e2ac9bafc99e6a9a7dc3547996c5c816922c"
+dependencies = [
+ "getrandom 0.2.17",
+]
+
+[[package]]
+name = "rand_hc"
+version = "0.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ca3129af7b92a17112d59ad498c6f81eaf463253766b90396d39ea7a39d6613c"
+dependencies = [
+ "rand_core 0.5.1",
+]
+
+[[package]]
+name = "rand_pcg"
+version = "0.2.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "16abd0c1b639e9eb4d7c50c0b8100b0d0f849be2349829c740fe8e6eb4816429"
+dependencies = [
+ "rand_core 0.5.1",
+]
+
+[[package]]
+name = "raw-window-handle"
+version = "0.6.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "20675572f6f24e9e76ef639bc5552774ed45f1c30e2951e1e99c59888861c539"
+
+[[package]]
+name = "redox_syscall"
+version = "0.5.18"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ed2bf2547551a7053d6fdfafda3f938979645c44812fbfcda098faae3f1a362d"
+dependencies = [
+ "bitflags 2.11.1",
+]
+
+[[package]]
+name = "redox_syscall"
+version = "0.7.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f450ad9c3b1da563fb6948a8e0fb0fb9269711c9c73d9ea1de5058c79c8d643a"
+dependencies = [
+ "bitflags 2.11.1",
+]
+
+[[package]]
+name = "redox_users"
+version = "0.5.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "a4e608c6638b9c18977b00b475ac1f28d14e84b27d8d42f70e0bf1e3dec127ac"
+dependencies = [
+ "getrandom 0.2.17",
+ "libredox",
+ "thiserror 2.0.18",
+]
+
+[[package]]
+name = "ref-cast"
+version = "1.0.25"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f354300ae66f76f1c85c5f84693f0ce81d747e2c3f21a45fef496d89c960bf7d"
+dependencies = [
+ "ref-cast-impl",
+]
+
+[[package]]
+name = "ref-cast-impl"
+version = "1.0.25"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b7186006dcb21920990093f30e3dea63b7d6e977bf1256be20c3563a5db070da"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "regex"
+version = "1.12.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e10754a14b9137dd7b1e3e5b0493cc9171fdd105e0ab477f51b72e7f3ac0e276"
+dependencies = [
+ "aho-corasick",
+ "memchr",
+ "regex-automata",
+ "regex-syntax",
+]
+
+[[package]]
+name = "regex-automata"
+version = "0.4.14"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "6e1dd4122fc1595e8162618945476892eefca7b88c52820e74af6262213cae8f"
+dependencies = [
+ "aho-corasick",
+ "memchr",
+ "regex-syntax",
+]
+
+[[package]]
+name = "regex-syntax"
+version = "0.8.10"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "dc897dd8d9e8bd1ed8cdad82b5966c3e0ecae09fb1907d58efaa013543185d0a"
+
+[[package]]
+name = "rend"
+version = "0.4.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "71fe3824f5629716b1589be05dacd749f6aa084c87e00e016714a8cdfccc997c"
+dependencies = [
+ "bytecheck",
+]
+
+[[package]]
+name = "reqwest"
+version = "0.13.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ab3f43e3283ab1488b624b44b0e988d0acea0b3214e694730a055cb6b2efa801"
+dependencies = [
+ "base64 0.22.1",
+ "bytes",
+ "futures-core",
+ "futures-util",
+ "http",
+ "http-body",
+ "http-body-util",
+ "hyper",
+ "hyper-rustls",
+ "hyper-util",
+ "js-sys",
+ "log",
+ "percent-encoding",
+ "pin-project-lite",
+ "rustls",
+ "rustls-pki-types",
+ "rustls-platform-verifier",
+ "serde",
+ "serde_json",
+ "sync_wrapper",
+ "tokio",
+ "tokio-rustls",
+ "tokio-util",
+ "tower",
+ "tower-http",
+ "tower-service",
+ "url",
+ "wasm-bindgen",
+ "wasm-bindgen-futures",
+ "wasm-streams",
+ "web-sys",
+]
+
+[[package]]
+name = "ring"
+version = "0.17.14"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "a4689e6c2294d81e88dc6261c768b63bc4fcdb852be6d1352498b114f61383b7"
+dependencies = [
+ "cc",
+ "cfg-if",
+ "getrandom 0.2.17",
+ "libc",
+ "untrusted",
+ "windows-sys 0.52.0",
+]
+
+[[package]]
+name = "rkyv"
+version = "0.7.46"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "2297bf9c81a3f0dc96bc9521370b88f054168c29826a75e89c55ff196e7ed6a1"
+dependencies = [
+ "bitvec",
+ "bytecheck",
+ "bytes",
+ "hashbrown 0.12.3",
+ "ptr_meta",
+ "rend",
+ "rkyv_derive",
+ "seahash",
+ "tinyvec",
+ "uuid",
+]
+
+[[package]]
+name = "rkyv_derive"
+version = "0.7.46"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "84d7b42d4b8d06048d3ac8db0eb31bcb942cbeb709f0b5f2b2ebde398d3038f5"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 1.0.109",
+]
+
+[[package]]
+name = "rust_decimal"
+version = "1.41.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "2ce901f9a19d251159075a4c37af514c3b8ef99c22e02dd8c19161cf397ee94a"
+dependencies = [
+ "arrayvec",
+ "borsh",
+ "bytes",
+ "num-traits",
+ "rand 0.8.5",
+ "rkyv",
+ "serde",
+ "serde_json",
+ "wasm-bindgen",
+]
+
+[[package]]
+name = "rustc-hash"
+version = "2.1.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "94300abf3f1ae2e2b8ffb7b58043de3d399c73fa6f4b73826402a5c457614dbe"
+
+[[package]]
+name = "rustc_version"
+version = "0.4.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "cfcb3a22ef46e85b45de6ee7e79d063319ebb6594faafcf1c225ea92ab6e9b92"
+dependencies = [
+ "semver",
+]
+
+[[package]]
+name = "rustix"
+version = "1.1.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b6fe4565b9518b83ef4f91bb47ce29620ca828bd32cb7e408f0062e9930ba190"
+dependencies = [
+ "bitflags 2.11.1",
+ "errno",
+ "libc",
+ "linux-raw-sys",
+ "windows-sys 0.61.2",
+]
+
+[[package]]
+name = "rustls"
+version = "0.23.38"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "69f9466fb2c14ea04357e91413efb882e2a6d4a406e625449bc0a5d360d53a21"
+dependencies = [
+ "once_cell",
+ "ring",
+ "rustls-pki-types",
+ "rustls-webpki",
+ "subtle",
+ "zeroize",
+]
+
+[[package]]
+name = "rustls-native-certs"
+version = "0.8.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "612460d5f7bea540c490b2b6395d8e34a953e52b491accd6c86c8164c5932a63"
+dependencies = [
+ "openssl-probe",
+ "rustls-pki-types",
+ "schannel",
+ "security-framework",
+]
+
+[[package]]
+name = "rustls-pki-types"
+version = "1.14.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "be040f8b0a225e40375822a563fa9524378b9d63112f53e19ffff34df5d33fdd"
+dependencies = [
+ "zeroize",
+]
+
+[[package]]
+name = "rustls-platform-verifier"
+version = "0.6.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1d99feebc72bae7ab76ba994bb5e121b8d83d910ca40b36e0921f53becc41784"
+dependencies = [
+ "core-foundation",
+ "core-foundation-sys",
+ "jni",
+ "log",
+ "once_cell",
+ "rustls",
+ "rustls-native-certs",
+ "rustls-platform-verifier-android",
+ "rustls-webpki",
+ "security-framework",
+ "security-framework-sys",
+ "webpki-root-certs",
+ "windows-sys 0.61.2",
+]
+
+[[package]]
+name = "rustls-platform-verifier-android"
+version = "0.1.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f87165f0995f63a9fbeea62b64d10b4d9d8e78ec6d7d51fb2125fda7bb36788f"
+
+[[package]]
+name = "rustls-webpki"
+version = "0.103.12"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8279bb85272c9f10811ae6a6c547ff594d6a7f3c6c6b02ee9726d1d0dcfcdd06"
+dependencies = [
+ "ring",
+ "rustls-pki-types",
+ "untrusted",
+]
+
+[[package]]
+name = "rustversion"
+version = "1.0.22"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b39cdef0fa800fc44525c84ccb54a029961a8215f9619753635a9c0d2538d46d"
+
+[[package]]
+name = "same-file"
+version = "1.0.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "93fc1dc3aaa9bfed95e02e6eadabb4baf7e3078b0bd1b4d7b6b0b68378900502"
+dependencies = [
+ "winapi-util",
+]
+
+[[package]]
+name = "schannel"
+version = "0.1.29"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "91c1b7e4904c873ef0710c1f407dde2e6287de2bebc1bbbf7d430bb7cbffd939"
+dependencies = [
+ "windows-sys 0.61.2",
+]
+
+[[package]]
+name = "schemars"
+version = "0.8.22"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3fbf2ae1b8bc8e02df939598064d22402220cd5bbcca1c76f7d6a310974d5615"
+dependencies = [
+ "dyn-clone",
+ "indexmap 1.9.3",
+ "schemars_derive",
+ "serde",
+ "serde_json",
+ "url",
+ "uuid",
+]
+
+[[package]]
+name = "schemars"
+version = "0.9.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "4cd191f9397d57d581cddd31014772520aa448f65ef991055d7f61582c65165f"
+dependencies = [
+ "dyn-clone",
+ "ref-cast",
+ "serde",
+ "serde_json",
+]
+
+[[package]]
+name = "schemars"
+version = "1.2.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "a2b42f36aa1cd011945615b92222f6bf73c599a102a300334cd7f8dbeec726cc"
+dependencies = [
+ "dyn-clone",
+ "ref-cast",
+ "serde",
+ "serde_json",
+]
+
+[[package]]
+name = "schemars_derive"
+version = "0.8.22"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "32e265784ad618884abaea0600a9adf15393368d840e0222d101a072f3f7534d"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "serde_derive_internals",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "scopeguard"
+version = "1.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49"
+
+[[package]]
+name = "seahash"
+version = "4.1.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1c107b6f4780854c8b126e228ea8869f4d7b71260f962fefb57b996b8959ba6b"
+
+[[package]]
+name = "security-framework"
+version = "3.7.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b7f4bc775c73d9a02cde8bf7b2ec4c9d12743edf609006c7facc23998404cd1d"
+dependencies = [
+ "bitflags 2.11.1",
+ "core-foundation",
+ "core-foundation-sys",
+ "libc",
+ "security-framework-sys",
+]
+
+[[package]]
+name = "security-framework-sys"
+version = "2.17.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "6ce2691df843ecc5d231c0b14ece2acc3efb62c0a398c7e1d875f3983ce020e3"
+dependencies = [
+ "core-foundation-sys",
+ "libc",
+]
+
+[[package]]
+name = "selectors"
+version = "0.24.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0c37578180969d00692904465fb7f6b3d50b9a2b952b87c23d0e2e5cb5013416"
+dependencies = [
+ "bitflags 1.3.2",
+ "cssparser 0.29.6",
+ "derive_more 0.99.20",
+ "fxhash",
+ "log",
+ "phf 0.8.0",
+ "phf_codegen 0.8.0",
+ "precomputed-hash",
+ "servo_arc 0.2.0",
+ "smallvec",
+]
+
+[[package]]
+name = "selectors"
+version = "0.36.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c5d9c0c92a92d33f08817311cf3f2c29a3538a8240e94a6a3c622ce652d7e00c"
+dependencies = [
+ "bitflags 2.11.1",
+ "cssparser 0.36.0",
+ "derive_more 2.1.1",
+ "log",
+ "new_debug_unreachable",
+ "phf 0.13.1",
+ "phf_codegen 0.13.1",
+ "precomputed-hash",
+ "rustc-hash",
+ "servo_arc 0.4.3",
+ "smallvec",
+]
+
+[[package]]
+name = "semver"
+version = "1.0.28"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8a7852d02fc848982e0c167ef163aaff9cd91dc640ba85e263cb1ce46fae51cd"
+dependencies = [
+ "serde",
+ "serde_core",
+]
+
+[[package]]
+name = "serde"
+version = "1.0.228"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9a8e94ea7f378bd32cbbd37198a4a91436180c5bb472411e48b5ec2e2124ae9e"
+dependencies = [
+ "serde_core",
+ "serde_derive",
+]
+
+[[package]]
+name = "serde-untagged"
+version = "0.1.9"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f9faf48a4a2d2693be24c6289dbe26552776eb7737074e6722891fadbe6c5058"
+dependencies = [
+ "erased-serde",
+ "serde",
+ "serde_core",
+ "typeid",
+]
+
+[[package]]
+name = "serde_core"
+version = "1.0.228"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "41d385c7d4ca58e59fc732af25c3983b67ac852c1a25000afe1175de458b67ad"
+dependencies = [
+ "serde_derive",
+]
+
+[[package]]
+name = "serde_derive"
+version = "1.0.228"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d540f220d3187173da220f885ab66608367b6574e925011a9353e4badda91d79"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "serde_derive_internals"
+version = "0.29.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "18d26a20a969b9e3fdf2fc2d9f21eda6c40e2de84c9408bb5d3b05d499aae711"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "serde_json"
+version = "1.0.149"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "83fc039473c5595ace860d8c4fafa220ff474b3fc6bfdb4293327f1a37e94d86"
+dependencies = [
+ "itoa",
+ "memchr",
+ "serde",
+ "serde_core",
+ "zmij",
+]
+
+[[package]]
+name = "serde_repr"
+version = "0.1.20"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "175ee3e80ae9982737ca543e96133087cbd9a485eecc3bc4de9c1a37b47ea59c"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "serde_spanned"
+version = "0.6.9"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "bf41e0cfaf7226dca15e8197172c295a782857fcb97fad1808a166870dee75a3"
+dependencies = [
+ "serde",
+]
+
+[[package]]
+name = "serde_spanned"
+version = "1.1.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "6662b5879511e06e8999a8a235d848113e942c9124f211511b16466ee2995f26"
+dependencies = [
+ "serde_core",
+]
+
+[[package]]
+name = "serde_with"
+version = "3.18.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "dd5414fad8e6907dbdd5bc441a50ae8d6e26151a03b1de04d89a5576de61d01f"
+dependencies = [
+ "base64 0.22.1",
+ "chrono",
+ "hex",
+ "indexmap 1.9.3",
+ "indexmap 2.14.0",
+ "schemars 0.9.0",
+ "schemars 1.2.1",
+ "serde_core",
+ "serde_json",
+ "serde_with_macros",
+ "time",
+]
+
+[[package]]
+name = "serde_with_macros"
+version = "3.18.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d3db8978e608f1fe7357e211969fd9abdcae80bac1ba7a3369bb7eb6b404eb65"
+dependencies = [
+ "darling",
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "serialize-to-javascript"
+version = "0.1.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "04f3666a07a197cdb77cdf306c32be9b7f598d7060d50cfd4d5aa04bfd92f6c5"
+dependencies = [
+ "serde",
+ "serde_json",
+ "serialize-to-javascript-impl",
+]
+
+[[package]]
+name = "serialize-to-javascript-impl"
+version = "0.1.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "772ee033c0916d670af7860b6e1ef7d658a4629a6d0b4c8c3e67f09b3765b75d"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "servo_arc"
+version = "0.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d52aa42f8fdf0fed91e5ce7f23d8138441002fa31dca008acf47e6fd4721f741"
+dependencies = [
+ "nodrop",
+ "stable_deref_trait",
+]
+
+[[package]]
+name = "servo_arc"
+version = "0.4.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "170fb83ab34de17dc69aa7c67482b22218ddb85da56546f9bd6b929e32a05930"
+dependencies = [
+ "stable_deref_trait",
+]
+
+[[package]]
+name = "sha2"
+version = "0.10.9"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "a7507d819769d01a365ab707794a4084392c824f54a7a6a7862f8c3d0892b283"
+dependencies = [
+ "cfg-if",
+ "cpufeatures",
+ "digest",
+]
+
+[[package]]
+name = "shlex"
+version = "1.3.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0fda2ff0d084019ba4d7c6f371c95d8fd75ce3524c3cb8fb653a3023f6323e64"
+
+[[package]]
+name = "signal-hook-registry"
+version = "1.4.8"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c4db69cba1110affc0e9f7bcd48bbf87b3f4fc7c61fc9155afd4c469eb3d6c1b"
+dependencies = [
+ "errno",
+ "libc",
+]
+
+[[package]]
+name = "simd-adler32"
+version = "0.3.9"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "703d5c7ef118737c72f1af64ad2f6f8c5e1921f818cdcb97b8fe6fc69bf66214"
+
+[[package]]
+name = "simdutf8"
+version = "0.1.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e3a9fe34e3e7a50316060351f37187a3f546bce95496156754b601a5fa71b76e"
+
+[[package]]
+name = "siphasher"
+version = "0.3.11"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "38b58827f4464d87d377d175e90bf58eb00fd8716ff0a62f80356b5e61555d0d"
+
+[[package]]
+name = "siphasher"
+version = "1.0.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b2aa850e253778c88a04c3d7323b043aeda9d3e30d5971937c1855769763678e"
+
+[[package]]
+name = "slab"
+version = "0.4.12"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0c790de23124f9ab44544d7ac05d60440adc586479ce501c1d6d7da3cd8c9cf5"
+
+[[package]]
+name = "smallvec"
+version = "1.15.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "67b1b7a3b5fe4f1376887184045fcf45c69e92af734b7aaddc05fb777b6fbd03"
+
+[[package]]
+name = "socket2"
+version = "0.6.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3a766e1110788c36f4fa1c2b71b387a7815aa65f88ce0229841826633d93723e"
+dependencies = [
+ "libc",
+ "windows-sys 0.61.2",
+]
+
+[[package]]
+name = "softbuffer"
+version = "0.4.8"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "aac18da81ebbf05109ab275b157c22a653bb3c12cf884450179942f81bcbf6c3"
+dependencies = [
+ "bytemuck",
+ "js-sys",
+ "ndk",
+ "objc2",
+ "objc2-core-foundation",
+ "objc2-core-graphics",
+ "objc2-foundation",
+ "objc2-quartz-core",
+ "raw-window-handle",
+ "redox_syscall 0.5.18",
+ "tracing",
+ "wasm-bindgen",
+ "web-sys",
+ "windows-sys 0.61.2",
+]
+
+[[package]]
+name = "soup3"
+version = "0.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "471f924a40f31251afc77450e781cb26d55c0b650842efafc9c6cbd2f7cc4f9f"
+dependencies = [
+ "futures-channel",
+ "gio",
+ "glib",
+ "libc",
+ "soup3-sys",
+]
+
+[[package]]
+name = "soup3-sys"
+version = "0.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7ebe8950a680a12f24f15ebe1bf70db7af98ad242d9db43596ad3108aab86c27"
+dependencies = [
+ "gio-sys",
+ "glib-sys",
+ "gobject-sys",
+ "libc",
+ "system-deps",
+]
+
+[[package]]
+name = "stable_deref_trait"
+version = "1.2.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "6ce2be8dc25455e1f91df71bfa12ad37d7af1092ae736f3a6cd0e37bc7810596"
+
+[[package]]
+name = "string_cache"
+version = "0.8.9"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "bf776ba3fa74f83bf4b63c3dcbbf82173db2632ed8452cb2d891d33f459de70f"
+dependencies = [
+ "new_debug_unreachable",
+ "parking_lot",
+ "phf_shared 0.11.3",
+ "precomputed-hash",
+ "serde",
+]
+
+[[package]]
+name = "string_cache"
+version = "0.9.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "a18596f8c785a729f2819c0f6a7eae6ebeebdfffbfe4214ae6b087f690e31901"
+dependencies = [
+ "new_debug_unreachable",
+ "parking_lot",
+ "phf_shared 0.13.1",
+ "precomputed-hash",
+]
+
+[[package]]
+name = "string_cache_codegen"
+version = "0.5.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c711928715f1fe0fe509c53b43e993a9a557babc2d0a3567d0a3006f1ac931a0"
+dependencies = [
+ "phf_generator 0.11.3",
+ "phf_shared 0.11.3",
+ "proc-macro2",
+ "quote",
+]
+
+[[package]]
+name = "string_cache_codegen"
+version = "0.6.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "585635e46db231059f76c5849798146164652513eb9e8ab2685939dd90f29b69"
+dependencies = [
+ "phf_generator 0.13.1",
+ "phf_shared 0.13.1",
+ "proc-macro2",
+ "quote",
+]
+
+[[package]]
+name = "strsim"
+version = "0.11.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7da8b5736845d9f2fcb837ea5d9e2628564b3b043a70948a3f0b778838c5fb4f"
+
+[[package]]
+name = "subtle"
+version = "2.6.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "13c2bddecc57b384dee18652358fb23172facb8a2c51ccc10d74c157bdea3292"
+
+[[package]]
+name = "swift-rs"
+version = "1.0.7"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "4057c98e2e852d51fdcfca832aac7b571f6b351ad159f9eda5db1655f8d0c4d7"
+dependencies = [
+ "base64 0.21.7",
+ "serde",
+ "serde_json",
+]
+
+[[package]]
+name = "syn"
+version = "1.0.109"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "72b64191b275b66ffe2469e8af2c1cfe3bafa67b529ead792a6d0160888b4237"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "unicode-ident",
+]
+
+[[package]]
+name = "syn"
+version = "2.0.117"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e665b8803e7b1d2a727f4023456bbbbe74da67099c585258af0ad9c5013b9b99"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "unicode-ident",
+]
+
+[[package]]
+name = "sync_wrapper"
+version = "1.0.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0bf256ce5efdfa370213c1dabab5935a12e49f2c58d15e9eac2870d3b4f27263"
+dependencies = [
+ "futures-core",
+]
+
+[[package]]
+name = "synstructure"
+version = "0.13.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "728a70f3dbaf5bab7f0c4b1ac8d7ae5ea60a4b5549c8a5914361c99147a709d2"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "system-deps"
+version = "6.2.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "a3e535eb8dded36d55ec13eddacd30dec501792ff23a0b1682c38601b8cf2349"
+dependencies = [
+ "cfg-expr",
+ "heck 0.5.0",
+ "pkg-config",
+ "toml 0.8.2",
+ "version-compare",
+]
+
+[[package]]
+name = "tao"
+version = "0.34.8"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9103edf55f2da3c82aea4c7fab7c4241032bfeea0e71fa557d98e00e7ce7cc20"
+dependencies = [
+ "bitflags 2.11.1",
+ "block2",
+ "core-foundation",
+ "core-graphics",
+ "crossbeam-channel",
+ "dispatch2",
+ "dlopen2",
+ "dpi",
+ "gdkwayland-sys",
+ "gdkx11-sys",
+ "gtk",
+ "jni",
+ "libc",
+ "log",
+ "ndk",
+ "ndk-context",
+ "ndk-sys",
+ "objc2",
+ "objc2-app-kit",
+ "objc2-foundation",
+ "once_cell",
+ "parking_lot",
+ "raw-window-handle",
+ "tao-macros",
+ "unicode-segmentation",
+ "url",
+ "windows 0.61.3",
+ "windows-core 0.61.2",
+ "windows-version",
+ "x11-dl",
+]
+
+[[package]]
+name = "tao-macros"
+version = "0.1.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f4e16beb8b2ac17db28eab8bca40e62dbfbb34c0fcdc6d9826b11b7b5d047dfd"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "tap"
+version = "1.0.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "55937e1799185b12863d447f42597ed69d9928686b8d88a1df17376a097d8369"
+
+[[package]]
+name = "tar"
+version = "0.4.45"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "22692a6476a21fa75fdfc11d452fda482af402c008cdbaf3476414e122040973"
+dependencies = [
+ "filetime",
+ "libc",
+ "xattr",
+]
+
+[[package]]
+name = "target-lexicon"
+version = "0.12.16"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "61c41af27dd6d1e27b1b16b489db798443478cef1f06a660c96db617ba5de3b1"
+
+[[package]]
+name = "tauri"
+version = "2.10.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "da77cc00fb9028caf5b5d4650f75e31f1ef3693459dfca7f7e506d1ecef0ba2d"
+dependencies = [
+ "anyhow",
+ "bytes",
+ "cookie",
+ "dirs",
+ "dunce",
+ "embed_plist",
+ "getrandom 0.3.4",
+ "glob",
+ "gtk",
+ "heck 0.5.0",
+ "http",
+ "jni",
+ "libc",
+ "log",
+ "mime",
+ "muda",
+ "objc2",
+ "objc2-app-kit",
+ "objc2-foundation",
+ "objc2-ui-kit",
+ "objc2-web-kit",
+ "percent-encoding",
+ "plist",
+ "raw-window-handle",
+ "reqwest",
+ "serde",
+ "serde_json",
+ "serde_repr",
+ "serialize-to-javascript",
+ "swift-rs",
+ "tauri-build",
+ "tauri-macros",
+ "tauri-runtime",
+ "tauri-runtime-wry",
+ "tauri-utils",
+ "thiserror 2.0.18",
+ "tokio",
+ "tray-icon",
+ "url",
+ "webkit2gtk",
+ "webview2-com",
+ "window-vibrancy",
+ "windows 0.61.3",
+]
+
+[[package]]
+name = "tauri-build"
+version = "2.5.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "4bbc990d1dbf57a8e1c7fa2327f2a614d8b757805603c1b9ba5c81bade09fd4d"
+dependencies = [
+ "anyhow",
+ "cargo_toml",
+ "dirs",
+ "glob",
+ "heck 0.5.0",
+ "json-patch",
+ "schemars 0.8.22",
+ "semver",
+ "serde",
+ "serde_json",
+ "tauri-utils",
+ "tauri-winres",
+ "toml 0.9.12+spec-1.1.0",
+ "walkdir",
+]
+
+[[package]]
+name = "tauri-codegen"
+version = "2.5.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d4a24476afd977c5d5d169f72425868613d82747916dd29e0a357c84c4bd6d29"
+dependencies = [
+ "base64 0.22.1",
+ "brotli",
+ "ico",
+ "json-patch",
+ "plist",
+ "png",
+ "proc-macro2",
+ "quote",
+ "semver",
+ "serde",
+ "serde_json",
+ "sha2",
+ "syn 2.0.117",
+ "tauri-utils",
+ "thiserror 2.0.18",
+ "time",
+ "url",
+ "uuid",
+ "walkdir",
+]
+
+[[package]]
+name = "tauri-macros"
+version = "2.5.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d39b349a98dadaffebb73f0a40dcd1f23c999211e5a2e744403db384d0c33de7"
+dependencies = [
+ "heck 0.5.0",
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+ "tauri-codegen",
+ "tauri-utils",
+]
+
+[[package]]
+name = "tauri-plugin"
+version = "2.5.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ddde7d51c907b940fb573006cdda9a642d6a7c8153657e88f8a5c3c9290cd4aa"
+dependencies = [
+ "anyhow",
+ "glob",
+ "plist",
+ "schemars 0.8.22",
+ "serde",
+ "serde_json",
+ "tauri-utils",
+ "toml 0.9.12+spec-1.1.0",
+ "walkdir",
+]
+
+[[package]]
+name = "tauri-plugin-global-shortcut"
+version = "2.3.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "424af23c7e88d05e4a1a6fc2c7be077912f8c76bd7900fd50aa2b7cbf5a2c405"
+dependencies = [
+ "global-hotkey",
+ "log",
+ "serde",
+ "serde_json",
+ "tauri",
+ "tauri-plugin",
+ "thiserror 2.0.18",
+]
+
+[[package]]
+name = "tauri-plugin-log"
+version = "2.8.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7545bd67f070a4500432c826e2e0682146a1d6712aee22a2786490156b574d93"
+dependencies = [
+ "android_logger",
+ "byte-unit",
+ "fern",
+ "log",
+ "objc2",
+ "objc2-foundation",
+ "serde",
+ "serde_json",
+ "serde_repr",
+ "swift-rs",
+ "tauri",
+ "tauri-plugin",
+ "thiserror 2.0.18",
+ "time",
+]
+
+[[package]]
+name = "tauri-plugin-opener"
+version = "2.5.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "fc624469b06f59f5a29f874bbc61a2ed737c0f9c23ef09855a292c389c42e83f"
+dependencies = [
+ "dunce",
+ "glob",
+ "objc2-app-kit",
+ "objc2-foundation",
+ "open",
+ "schemars 0.8.22",
+ "serde",
+ "serde_json",
+ "tauri",
+ "tauri-plugin",
+ "thiserror 2.0.18",
+ "url",
+ "windows 0.61.3",
+ "zbus",
+]
+
+[[package]]
+name = "tauri-plugin-process"
+version = "2.3.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d55511a7bf6cd70c8767b02c97bf8134fa434daf3926cfc1be0a0f94132d165a"
+dependencies = [
+ "tauri",
+ "tauri-plugin",
+]
+
+[[package]]
+name = "tauri-plugin-single-instance"
+version = "2.4.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "a33a5b7d78f0dec4406b003ea87c40bf928d801b6fd9323a556172c91d8712c1"
+dependencies = [
+ "serde",
+ "serde_json",
+ "tauri",
+ "thiserror 2.0.18",
+ "tracing",
+ "windows-sys 0.60.2",
+ "zbus",
+]
+
+[[package]]
+name = "tauri-plugin-updater"
+version = "2.10.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "806d9dac662c2e4594ff03c647a552f2c9bd544e7d0f683ec58f872f952ce4af"
+dependencies = [
+ "base64 0.22.1",
+ "dirs",
+ "flate2",
+ "futures-util",
+ "http",
+ "infer",
+ "log",
+ "minisign-verify",
+ "osakit",
+ "percent-encoding",
+ "reqwest",
+ "rustls",
+ "semver",
+ "serde",
+ "serde_json",
+ "tar",
+ "tauri",
+ "tauri-plugin",
+ "tempfile",
+ "thiserror 2.0.18",
+ "time",
+ "tokio",
+ "url",
+ "windows-sys 0.60.2",
+ "zip",
+]
+
+[[package]]
+name = "tauri-runtime"
+version = "2.10.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "2826d79a3297ed08cd6ea7f412644ef58e32969504bc4fbd8d7dbeabc4445ea2"
+dependencies = [
+ "cookie",
+ "dpi",
+ "gtk",
+ "http",
+ "jni",
+ "objc2",
+ "objc2-ui-kit",
+ "objc2-web-kit",
+ "raw-window-handle",
+ "serde",
+ "serde_json",
+ "tauri-utils",
+ "thiserror 2.0.18",
+ "url",
+ "webkit2gtk",
+ "webview2-com",
+ "windows 0.61.3",
+]
+
+[[package]]
+name = "tauri-runtime-wry"
+version = "2.10.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e11ea2e6f801d275fdd890d6c9603736012742a1c33b96d0db788c9cdebf7f9e"
+dependencies = [
+ "gtk",
+ "http",
+ "jni",
+ "log",
+ "objc2",
+ "objc2-app-kit",
+ "once_cell",
+ "percent-encoding",
+ "raw-window-handle",
+ "softbuffer",
+ "tao",
+ "tauri-runtime",
+ "tauri-utils",
+ "url",
+ "webkit2gtk",
+ "webview2-com",
+ "windows 0.61.3",
+ "wry",
+]
+
+[[package]]
+name = "tauri-utils"
+version = "2.8.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "219a1f983a2af3653f75b5747f76733b0da7ff03069c7a41901a5eb3ace4557d"
+dependencies = [
+ "anyhow",
+ "brotli",
+ "cargo_metadata",
+ "ctor",
+ "dunce",
+ "glob",
+ "html5ever 0.29.1",
+ "http",
+ "infer",
+ "json-patch",
+ "kuchikiki",
+ "log",
+ "memchr",
+ "phf 0.11.3",
+ "proc-macro2",
+ "quote",
+ "regex",
+ "schemars 0.8.22",
+ "semver",
+ "serde",
+ "serde-untagged",
+ "serde_json",
+ "serde_with",
+ "swift-rs",
+ "thiserror 2.0.18",
+ "toml 0.9.12+spec-1.1.0",
+ "url",
+ "urlpattern",
+ "uuid",
+ "walkdir",
+]
+
+[[package]]
+name = "tauri-winres"
+version = "0.3.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1087b111fe2b005e42dbdc1990fc18593234238d47453b0c99b7de1c9ab2c1e0"
+dependencies = [
+ "dunce",
+ "embed-resource",
+ "toml 0.9.12+spec-1.1.0",
+]
+
+[[package]]
+name = "tempfile"
+version = "3.27.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "32497e9a4c7b38532efcdebeef879707aa9f794296a4f0244f6f69e9bc8574bd"
+dependencies = [
+ "fastrand",
+ "getrandom 0.4.2",
+ "once_cell",
+ "rustix",
+ "windows-sys 0.61.2",
+]
+
+[[package]]
+name = "tendril"
+version = "0.4.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d24a120c5fc464a3458240ee02c299ebcb9d67b5249c8848b09d639dca8d7bb0"
+dependencies = [
+ "futf",
+ "mac",
+ "utf-8",
+]
+
+[[package]]
+name = "tendril"
+version = "0.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c4790fc369d5a530f4b544b094e31388b9b3a37c0f4652ade4505945f5660d24"
+dependencies = [
+ "new_debug_unreachable",
+ "utf-8",
+]
+
+[[package]]
+name = "thiserror"
+version = "1.0.69"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b6aaf5339b578ea85b50e080feb250a3e8ae8cfcdff9a461c9ec2904bc923f52"
+dependencies = [
+ "thiserror-impl 1.0.69",
+]
+
+[[package]]
+name = "thiserror"
+version = "2.0.18"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "4288b5bcbc7920c07a1149a35cf9590a2aa808e0bc1eafaade0b80947865fbc4"
+dependencies = [
+ "thiserror-impl 2.0.18",
+]
+
+[[package]]
+name = "thiserror-impl"
+version = "1.0.69"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "4fee6c4efc90059e10f81e6d42c60a18f76588c3d74cb83a0b242a2b6c7504c1"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "thiserror-impl"
+version = "2.0.18"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ebc4ee7f67670e9b64d05fa4253e753e016c6c95ff35b89b7941d6b856dec1d5"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "time"
+version = "0.3.47"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "743bd48c283afc0388f9b8827b976905fb217ad9e647fae3a379a9283c4def2c"
+dependencies = [
+ "deranged",
+ "itoa",
+ "libc",
+ "num-conv",
+ "num_threads",
+ "powerfmt",
+ "serde_core",
+ "time-core",
+ "time-macros",
+]
+
+[[package]]
+name = "time-core"
+version = "0.1.8"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7694e1cfe791f8d31026952abf09c69ca6f6fa4e1a1229e18988f06a04a12dca"
+
+[[package]]
+name = "time-macros"
+version = "0.2.27"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "2e70e4c5a0e0a8a4823ad65dfe1a6930e4f4d756dcd9dd7939022b5e8c501215"
+dependencies = [
+ "num-conv",
+ "time-core",
+]
+
+[[package]]
+name = "tinystr"
+version = "0.8.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c8323304221c2a851516f22236c5722a72eaa19749016521d6dff0824447d96d"
+dependencies = [
+ "displaydoc",
+ "zerovec",
+]
+
+[[package]]
+name = "tinyvec"
+version = "1.11.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3e61e67053d25a4e82c844e8424039d9745781b3fc4f32b8d55ed50f5f667ef3"
+dependencies = [
+ "tinyvec_macros",
+]
+
+[[package]]
+name = "tinyvec_macros"
+version = "0.1.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20"
+
+[[package]]
+name = "tokio"
+version = "1.52.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "a91135f59b1cbf38c91e73cf3386fca9bb77915c45ce2771460c9d92f0f3d776"
+dependencies = [
+ "bytes",
+ "libc",
+ "mio",
+ "pin-project-lite",
+ "socket2",
+ "windows-sys 0.61.2",
+]
+
+[[package]]
+name = "tokio-rustls"
+version = "0.26.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1729aa945f29d91ba541258c8df89027d5792d85a8841fb65e8bf0f4ede4ef61"
+dependencies = [
+ "rustls",
+ "tokio",
+]
+
+[[package]]
+name = "tokio-util"
+version = "0.7.18"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9ae9cec805b01e8fc3fd2fe289f89149a9b66dd16786abd8b19cfa7b48cb0098"
+dependencies = [
+ "bytes",
+ "futures-core",
+ "futures-sink",
+ "pin-project-lite",
+ "tokio",
+]
+
+[[package]]
+name = "toml"
+version = "0.8.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "185d8ab0dfbb35cf1399a6344d8484209c088f75f8f68230da55d48d95d43e3d"
+dependencies = [
+ "serde",
+ "serde_spanned 0.6.9",
+ "toml_datetime 0.6.3",
+ "toml_edit 0.20.2",
+]
+
+[[package]]
+name = "toml"
+version = "0.9.12+spec-1.1.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "cf92845e79fc2e2def6a5d828f0801e29a2f8acc037becc5ab08595c7d5e9863"
+dependencies = [
+ "indexmap 2.14.0",
+ "serde_core",
+ "serde_spanned 1.1.1",
+ "toml_datetime 0.7.5+spec-1.1.0",
+ "toml_parser",
+ "toml_writer",
+ "winnow 0.7.15",
+]
+
+[[package]]
+name = "toml_datetime"
+version = "0.6.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7cda73e2f1397b1262d6dfdcef8aafae14d1de7748d66822d3bfeeb6d03e5e4b"
+dependencies = [
+ "serde",
+]
+
+[[package]]
+name = "toml_datetime"
+version = "0.7.5+spec-1.1.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "92e1cfed4a3038bc5a127e35a2d360f145e1f4b971b551a2ba5fd7aedf7e1347"
+dependencies = [
+ "serde_core",
+]
+
+[[package]]
+name = "toml_datetime"
+version = "1.1.1+spec-1.1.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3165f65f62e28e0115a00b2ebdd37eb6f3b641855f9d636d3cd4103767159ad7"
+dependencies = [
+ "serde_core",
+]
+
+[[package]]
+name = "toml_edit"
+version = "0.19.15"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1b5bb770da30e5cbfde35a2d7b9b8a2c4b8ef89548a7a6aeab5c9a576e3e7421"
+dependencies = [
+ "indexmap 2.14.0",
+ "toml_datetime 0.6.3",
+ "winnow 0.5.40",
+]
+
+[[package]]
+name = "toml_edit"
+version = "0.20.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "396e4d48bbb2b7554c944bde63101b5ae446cff6ec4a24227428f15eb72ef338"
+dependencies = [
+ "indexmap 2.14.0",
+ "serde",
+ "serde_spanned 0.6.9",
+ "toml_datetime 0.6.3",
+ "winnow 0.5.40",
+]
+
+[[package]]
+name = "toml_edit"
+version = "0.25.11+spec-1.1.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0b59c4d22ed448339746c59b905d24568fcbb3ab65a500494f7b8c3e97739f2b"
+dependencies = [
+ "indexmap 2.14.0",
+ "toml_datetime 1.1.1+spec-1.1.0",
+ "toml_parser",
+ "winnow 1.0.1",
+]
+
+[[package]]
+name = "toml_parser"
+version = "1.1.2+spec-1.1.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "a2abe9b86193656635d2411dc43050282ca48aa31c2451210f4202550afb7526"
+dependencies = [
+ "winnow 1.0.1",
+]
+
+[[package]]
+name = "toml_writer"
+version = "1.1.1+spec-1.1.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "756daf9b1013ebe47a8776667b466417e2d4c5679d441c26230efd9ef78692db"
+
+[[package]]
+name = "tower"
+version = "0.5.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ebe5ef63511595f1344e2d5cfa636d973292adc0eec1f0ad45fae9f0851ab1d4"
+dependencies = [
+ "futures-core",
+ "futures-util",
+ "pin-project-lite",
+ "sync_wrapper",
+ "tokio",
+ "tower-layer",
+ "tower-service",
+]
+
+[[package]]
+name = "tower-http"
+version = "0.6.8"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d4e6559d53cc268e5031cd8429d05415bc4cb4aefc4aa5d6cc35fbf5b924a1f8"
+dependencies = [
+ "bitflags 2.11.1",
+ "bytes",
+ "futures-util",
+ "http",
+ "http-body",
+ "iri-string",
+ "pin-project-lite",
+ "tower",
+ "tower-layer",
+ "tower-service",
+]
+
+[[package]]
+name = "tower-layer"
+version = "0.3.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "121c2a6cda46980bb0fcd1647ffaf6cd3fc79a013de288782836f6df9c48780e"
+
+[[package]]
+name = "tower-service"
+version = "0.3.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8df9b6e13f2d32c91b9bd719c00d1958837bc7dec474d94952798cc8e69eeec3"
+
+[[package]]
+name = "tracing"
+version = "0.1.44"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "63e71662fa4b2a2c3a26f570f037eb95bb1f85397f3cd8076caed2f026a6d100"
+dependencies = [
+ "pin-project-lite",
+ "tracing-attributes",
+ "tracing-core",
+]
+
+[[package]]
+name = "tracing-attributes"
+version = "0.1.31"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7490cfa5ec963746568740651ac6781f701c9c5ea257c58e057f3ba8cf69e8da"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "tracing-core"
+version = "0.1.36"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "db97caf9d906fbde555dd62fa95ddba9eecfd14cb388e4f491a66d74cd5fb79a"
+dependencies = [
+ "once_cell",
+]
+
+[[package]]
+name = "tray-icon"
+version = "0.21.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "a5e85aa143ceb072062fc4d6356c1b520a51d636e7bc8e77ec94be3608e5e80c"
+dependencies = [
+ "crossbeam-channel",
+ "dirs",
+ "libappindicator",
+ "muda",
+ "objc2",
+ "objc2-app-kit",
+ "objc2-core-foundation",
+ "objc2-core-graphics",
+ "objc2-foundation",
+ "once_cell",
+ "png",
+ "serde",
+ "thiserror 2.0.18",
+ "windows-sys 0.60.2",
+]
+
+[[package]]
+name = "try-lock"
+version = "0.2.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e421abadd41a4225275504ea4d6566923418b7f05506fbc9c0fe86ba7396114b"
+
+[[package]]
+name = "typeid"
+version = "1.0.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "bc7d623258602320d5c55d1bc22793b57daff0ec7efc270ea7d55ce1d5f5471c"
+
+[[package]]
+name = "typenum"
+version = "1.19.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "562d481066bde0658276a35467c4af00bdc6ee726305698a55b86e61d7ad82bb"
+
+[[package]]
+name = "uds_windows"
+version = "1.2.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f2f6fb2847f6742cd76af783a2a2c49e9375d0a111c7bef6f71cd9e738c72d6e"
+dependencies = [
+ "memoffset",
+ "tempfile",
+ "windows-sys 0.61.2",
+]
+
+[[package]]
+name = "unic-char-property"
+version = "0.9.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "a8c57a407d9b6fa02b4795eb81c5b6652060a15a7903ea981f3d723e6c0be221"
+dependencies = [
+ "unic-char-range",
+]
+
+[[package]]
+name = "unic-char-range"
+version = "0.9.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0398022d5f700414f6b899e10b8348231abf9173fa93144cbc1a43b9793c1fbc"
+
+[[package]]
+name = "unic-common"
+version = "0.9.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "80d7ff825a6a654ee85a63e80f92f054f904f21e7d12da4e22f9834a4aaa35bc"
+
+[[package]]
+name = "unic-ucd-ident"
+version = "0.9.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e230a37c0381caa9219d67cf063aa3a375ffed5bf541a452db16e744bdab6987"
+dependencies = [
+ "unic-char-property",
+ "unic-char-range",
+ "unic-ucd-version",
+]
+
+[[package]]
+name = "unic-ucd-version"
+version = "0.9.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "96bd2f2237fe450fcd0a1d2f5f4e91711124f7857ba2e964247776ebeeb7b0c4"
+dependencies = [
+ "unic-common",
+]
+
+[[package]]
+name = "unicode-ident"
+version = "1.0.24"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e6e4313cd5fcd3dad5cafa179702e2b244f760991f45397d14d4ebf38247da75"
+
+[[package]]
+name = "unicode-segmentation"
+version = "1.13.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9629274872b2bfaf8d66f5f15725007f635594914870f65218920345aa11aa8c"
+
+[[package]]
+name = "unicode-xid"
+version = "0.2.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ebc1c04c71510c7f702b52b7c350734c9ff1295c464a03335b00bb84fc54f853"
+
+[[package]]
+name = "untrusted"
+version = "0.9.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8ecb6da28b8a351d773b68d5825ac39017e680750f980f3a1a85cd8dd28a47c1"
+
+[[package]]
+name = "url"
+version = "2.5.8"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ff67a8a4397373c3ef660812acab3268222035010ab8680ec4215f38ba3d0eed"
+dependencies = [
+ "form_urlencoded",
+ "idna",
+ "percent-encoding",
+ "serde",
+ "serde_derive",
+]
+
+[[package]]
+name = "urlpattern"
+version = "0.3.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "70acd30e3aa1450bc2eece896ce2ad0d178e9c079493819301573dae3c37ba6d"
+dependencies = [
+ "regex",
+ "serde",
+ "unic-ucd-ident",
+ "url",
+]
+
+[[package]]
+name = "utf-8"
+version = "0.7.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "09cc8ee72d2a9becf2f2febe0205bbed8fc6615b7cb429ad062dc7b7ddd036a9"
+
+[[package]]
+name = "utf8-width"
+version = "0.1.8"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1292c0d970b54115d14f2492fe0170adf21d68a1de108eebc51c1df4f346a091"
+
+[[package]]
+name = "utf8_iter"
+version = "1.0.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b6c140620e7ffbb22c2dee59cafe6084a59b5ffc27a8859a5f0d494b5d52b6be"
+
+[[package]]
+name = "uuid"
+version = "1.23.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5ac8b6f42ead25368cf5b098aeb3dc8a1a2c05a3eee8a9a1a68c640edbfc79d9"
+dependencies = [
+ "getrandom 0.4.2",
+ "js-sys",
+ "serde_core",
+ "wasm-bindgen",
+]
+
+[[package]]
+name = "value-bag"
+version = "1.12.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7ba6f5989077681266825251a52748b8c1d8a4ad098cc37e440103d0ea717fc0"
+
+[[package]]
+name = "version-compare"
+version = "0.2.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "03c2856837ef78f57382f06b2b8563a2f512f7185d732608fd9176cb3b8edf0e"
+
+[[package]]
+name = "version_check"
+version = "0.9.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0b928f33d975fc6ad9f86c8f283853ad26bdd5b10b7f1542aa2fa15e2289105a"
+
+[[package]]
+name = "vswhom"
+version = "0.1.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "be979b7f07507105799e854203b470ff7c78a1639e330a58f183b5fea574608b"
+dependencies = [
+ "libc",
+ "vswhom-sys",
+]
+
+[[package]]
+name = "vswhom-sys"
+version = "0.1.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "fb067e4cbd1ff067d1df46c9194b5de0e98efd2810bbc95c5d5e5f25a3231150"
+dependencies = [
+ "cc",
+ "libc",
+]
+
+[[package]]
+name = "walkdir"
+version = "2.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "29790946404f91d9c5d06f9874efddea1dc06c5efe94541a7d6863108e3a5e4b"
+dependencies = [
+ "same-file",
+ "winapi-util",
+]
+
+[[package]]
+name = "want"
+version = "0.3.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "bfa7760aed19e106de2c7c0b581b509f2f25d3dacaf737cb82ac61bc6d760b0e"
+dependencies = [
+ "try-lock",
+]
+
+[[package]]
+name = "wasi"
+version = "0.9.0+wasi-snapshot-preview1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "cccddf32554fecc6acb585f82a32a72e28b48f8c4c1883ddfeeeaa96f7d8e519"
+
+[[package]]
+name = "wasi"
+version = "0.11.1+wasi-snapshot-preview1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ccf3ec651a847eb01de73ccad15eb7d99f80485de043efb2f370cd654f4ea44b"
+
+[[package]]
+name = "wasip2"
+version = "1.0.2+wasi-0.2.9"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9517f9239f02c069db75e65f174b3da828fe5f5b945c4dd26bd25d89c03ebcf5"
+dependencies = [
+ "wit-bindgen",
+]
+
+[[package]]
+name = "wasip3"
+version = "0.4.0+wasi-0.3.0-rc-2026-01-06"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5428f8bf88ea5ddc08faddef2ac4a67e390b88186c703ce6dbd955e1c145aca5"
+dependencies = [
+ "wit-bindgen",
+]
+
+[[package]]
+name = "wasm-bindgen"
+version = "0.2.118"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0bf938a0bacb0469e83c1e148908bd7d5a6010354cf4fb73279b7447422e3a89"
+dependencies = [
+ "cfg-if",
+ "once_cell",
+ "rustversion",
+ "wasm-bindgen-macro",
+ "wasm-bindgen-shared",
+]
+
+[[package]]
+name = "wasm-bindgen-futures"
+version = "0.4.68"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f371d383f2fb139252e0bfac3b81b265689bf45b6874af544ffa4c975ac1ebf8"
+dependencies = [
+ "js-sys",
+ "wasm-bindgen",
+]
+
+[[package]]
+name = "wasm-bindgen-macro"
+version = "0.2.118"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "eeff24f84126c0ec2db7a449f0c2ec963c6a49efe0698c4242929da037ca28ed"
+dependencies = [
+ "quote",
+ "wasm-bindgen-macro-support",
+]
+
+[[package]]
+name = "wasm-bindgen-macro-support"
+version = "0.2.118"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9d08065faf983b2b80a79fd87d8254c409281cf7de75fc4b773019824196c904"
+dependencies = [
+ "bumpalo",
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+ "wasm-bindgen-shared",
+]
+
+[[package]]
+name = "wasm-bindgen-shared"
+version = "0.2.118"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5fd04d9e306f1907bd13c6361b5c6bfc7b3b3c095ed3f8a9246390f8dbdee129"
+dependencies = [
+ "unicode-ident",
+]
+
+[[package]]
+name = "wasm-encoder"
+version = "0.244.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "990065f2fe63003fe337b932cfb5e3b80e0b4d0f5ff650e6985b1048f62c8319"
+dependencies = [
+ "leb128fmt",
+ "wasmparser",
+]
+
+[[package]]
+name = "wasm-metadata"
+version = "0.244.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "bb0e353e6a2fbdc176932bbaab493762eb1255a7900fe0fea1a2f96c296cc909"
+dependencies = [
+ "anyhow",
+ "indexmap 2.14.0",
+ "wasm-encoder",
+ "wasmparser",
+]
+
+[[package]]
+name = "wasm-streams"
+version = "0.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9d1ec4f6517c9e11ae630e200b2b65d193279042e28edd4a2cda233e46670bbb"
+dependencies = [
+ "futures-util",
+ "js-sys",
+ "wasm-bindgen",
+ "wasm-bindgen-futures",
+ "web-sys",
+]
+
+[[package]]
+name = "wasmparser"
+version = "0.244.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "47b807c72e1bac69382b3a6fb3dbe8ea4c0ed87ff5629b8685ae6b9a611028fe"
+dependencies = [
+ "bitflags 2.11.1",
+ "hashbrown 0.15.5",
+ "indexmap 2.14.0",
+ "semver",
+]
+
+[[package]]
+name = "web-sys"
+version = "0.3.95"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "4f2dfbb17949fa2088e5d39408c48368947b86f7834484e87b73de55bc14d97d"
+dependencies = [
+ "js-sys",
+ "wasm-bindgen",
+]
+
+[[package]]
+name = "web_atoms"
+version = "0.2.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "57a9779e9f04d2ac1ce317aee707aa2f6b773afba7b931222bff6983843b1576"
+dependencies = [
+ "phf 0.13.1",
+ "phf_codegen 0.13.1",
+ "string_cache 0.9.0",
+ "string_cache_codegen 0.6.1",
+]
+
+[[package]]
+name = "webkit2gtk"
+version = "2.0.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "a1027150013530fb2eaf806408df88461ae4815a45c541c8975e61d6f2fc4793"
+dependencies = [
+ "bitflags 1.3.2",
+ "cairo-rs",
+ "gdk",
+ "gdk-sys",
+ "gio",
+ "gio-sys",
+ "glib",
+ "glib-sys",
+ "gobject-sys",
+ "gtk",
+ "gtk-sys",
+ "javascriptcore-rs",
+ "libc",
+ "once_cell",
+ "soup3",
+ "webkit2gtk-sys",
+]
+
+[[package]]
+name = "webkit2gtk-sys"
+version = "2.0.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "916a5f65c2ef0dfe12fff695960a2ec3d4565359fdbb2e9943c974e06c734ea5"
+dependencies = [
+ "bitflags 1.3.2",
+ "cairo-sys-rs",
+ "gdk-sys",
+ "gio-sys",
+ "glib-sys",
+ "gobject-sys",
+ "gtk-sys",
+ "javascriptcore-rs-sys",
+ "libc",
+ "pkg-config",
+ "soup3-sys",
+ "system-deps",
+]
+
+[[package]]
+name = "webpki-root-certs"
+version = "1.0.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "804f18a4ac2676ffb4e8b5b5fa9ae38af06df08162314f96a68d2a363e21a8ca"
+dependencies = [
+ "rustls-pki-types",
+]
+
+[[package]]
+name = "webview2-com"
+version = "0.38.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7130243a7a5b33c54a444e54842e6a9e133de08b5ad7b5861cd8ed9a6a5bc96a"
+dependencies = [
+ "webview2-com-macros",
+ "webview2-com-sys",
+ "windows 0.61.3",
+ "windows-core 0.61.2",
+ "windows-implement",
+ "windows-interface",
+]
+
+[[package]]
+name = "webview2-com-macros"
+version = "0.8.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "67a921c1b6914c367b2b823cd4cde6f96beec77d30a939c8199bb377cf9b9b54"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "webview2-com-sys"
+version = "0.38.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "381336cfffd772377d291702245447a5251a2ffa5bad679c99e61bc48bacbf9c"
+dependencies = [
+ "thiserror 2.0.18",
+ "windows 0.61.3",
+ "windows-core 0.61.2",
+]
+
+[[package]]
+name = "winapi"
+version = "0.3.9"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5c839a674fcd7a98952e593242ea400abe93992746761e38641405d28b00f419"
+dependencies = [
+ "winapi-i686-pc-windows-gnu",
+ "winapi-x86_64-pc-windows-gnu",
+]
+
+[[package]]
+name = "winapi-i686-pc-windows-gnu"
+version = "0.4.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ac3b87c63620426dd9b991e5ce0329eff545bccbbb34f3be09ff6fb6ab51b7b6"
+
+[[package]]
+name = "winapi-util"
+version = "0.1.11"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c2a7b1c03c876122aa43f3020e6c3c3ee5c05081c9a00739faf7503aeba10d22"
+dependencies = [
+ "windows-sys 0.61.2",
+]
+
+[[package]]
+name = "winapi-x86_64-pc-windows-gnu"
+version = "0.4.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f"
+
+[[package]]
+name = "window-vibrancy"
+version = "0.6.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d9bec5a31f3f9362f2258fd0e9c9dd61a9ca432e7306cc78c444258f0dce9a9c"
+dependencies = [
+ "objc2",
+ "objc2-app-kit",
+ "objc2-core-foundation",
+ "objc2-foundation",
+ "raw-window-handle",
+ "windows-sys 0.59.0",
+ "windows-version",
+]
+
+[[package]]
+name = "windows"
+version = "0.52.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e48a53791691ab099e5e2ad123536d0fff50652600abaf43bbf952894110d0be"
+dependencies = [
+ "windows-core 0.52.0",
+ "windows-targets 0.52.6",
+]
+
+[[package]]
+name = "windows"
+version = "0.61.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9babd3a767a4c1aef6900409f85f5d53ce2544ccdfaa86dad48c91782c6d6893"
+dependencies = [
+ "windows-collections",
+ "windows-core 0.61.2",
+ "windows-future",
+ "windows-link 0.1.3",
+ "windows-numerics",
+]
+
+[[package]]
+name = "windows-collections"
+version = "0.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3beeceb5e5cfd9eb1d76b381630e82c4241ccd0d27f1a39ed41b2760b255c5e8"
+dependencies = [
+ "windows-core 0.61.2",
+]
+
+[[package]]
+name = "windows-core"
+version = "0.52.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "33ab640c8d7e35bf8ba19b884ba838ceb4fba93a4e8c65a9059d08afcfc683d9"
+dependencies = [
+ "windows-targets 0.52.6",
+]
+
+[[package]]
+name = "windows-core"
+version = "0.61.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c0fdd3ddb90610c7638aa2b3a3ab2904fb9e5cdbecc643ddb3647212781c4ae3"
+dependencies = [
+ "windows-implement",
+ "windows-interface",
+ "windows-link 0.1.3",
+ "windows-result 0.3.4",
+ "windows-strings 0.4.2",
+]
+
+[[package]]
+name = "windows-core"
+version = "0.62.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b8e83a14d34d0623b51dce9581199302a221863196a1dde71a7663a4c2be9deb"
+dependencies = [
+ "windows-implement",
+ "windows-interface",
+ "windows-link 0.2.1",
+ "windows-result 0.4.1",
+ "windows-strings 0.5.1",
+]
+
+[[package]]
+name = "windows-future"
+version = "0.2.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "fc6a41e98427b19fe4b73c550f060b59fa592d7d686537eebf9385621bfbad8e"
+dependencies = [
+ "windows-core 0.61.2",
+ "windows-link 0.1.3",
+ "windows-threading",
+]
+
+[[package]]
+name = "windows-implement"
+version = "0.60.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "053e2e040ab57b9dc951b72c264860db7eb3b0200ba345b4e4c3b14f67855ddf"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "windows-interface"
+version = "0.59.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "3f316c4a2570ba26bbec722032c4099d8c8bc095efccdc15688708623367e358"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "windows-link"
+version = "0.1.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5e6ad25900d524eaabdbbb96d20b4311e1e7ae1699af4fb28c17ae66c80d798a"
+
+[[package]]
+name = "windows-link"
+version = "0.2.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f0805222e57f7521d6a62e36fa9163bc891acd422f971defe97d64e70d0a4fe5"
+
+[[package]]
+name = "windows-numerics"
+version = "0.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9150af68066c4c5c07ddc0ce30421554771e528bde427614c61038bc2c92c2b1"
+dependencies = [
+ "windows-core 0.61.2",
+ "windows-link 0.1.3",
+]
+
+[[package]]
+name = "windows-result"
+version = "0.3.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "56f42bd332cc6c8eac5af113fc0c1fd6a8fd2aa08a0119358686e5160d0586c6"
+dependencies = [
+ "windows-link 0.1.3",
+]
+
+[[package]]
+name = "windows-result"
+version = "0.4.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7781fa89eaf60850ac3d2da7af8e5242a5ea78d1a11c49bf2910bb5a73853eb5"
+dependencies = [
+ "windows-link 0.2.1",
+]
+
+[[package]]
+name = "windows-strings"
+version = "0.4.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "56e6c93f3a0c3b36176cb1327a4958a0353d5d166c2a35cb268ace15e91d3b57"
+dependencies = [
+ "windows-link 0.1.3",
+]
+
+[[package]]
+name = "windows-strings"
+version = "0.5.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7837d08f69c77cf6b07689544538e017c1bfcf57e34b4c0ff58e6c2cd3b37091"
+dependencies = [
+ "windows-link 0.2.1",
+]
+
+[[package]]
+name = "windows-sys"
+version = "0.45.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "75283be5efb2831d37ea142365f009c02ec203cd29a3ebecbc093d52315b66d0"
+dependencies = [
+ "windows-targets 0.42.2",
+]
+
+[[package]]
+name = "windows-sys"
+version = "0.52.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "282be5f36a8ce781fad8c8ae18fa3f9beff57ec1b52cb3de0789201425d9a33d"
+dependencies = [
+ "windows-targets 0.52.6",
+]
+
+[[package]]
+name = "windows-sys"
+version = "0.59.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1e38bc4d79ed67fd075bcc251a1c39b32a1776bbe92e5bef1f0bf1f8c531853b"
+dependencies = [
+ "windows-targets 0.52.6",
+]
+
+[[package]]
+name = "windows-sys"
+version = "0.60.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f2f500e4d28234f72040990ec9d39e3a6b950f9f22d3dba18416c35882612bcb"
+dependencies = [
+ "windows-targets 0.53.5",
+]
+
+[[package]]
+name = "windows-sys"
+version = "0.61.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ae137229bcbd6cdf0f7b80a31df61766145077ddf49416a728b02cb3921ff3fc"
+dependencies = [
+ "windows-link 0.2.1",
+]
+
+[[package]]
+name = "windows-targets"
+version = "0.42.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8e5180c00cd44c9b1c88adb3693291f1cd93605ded80c250a75d472756b4d071"
+dependencies = [
+ "windows_aarch64_gnullvm 0.42.2",
+ "windows_aarch64_msvc 0.42.2",
+ "windows_i686_gnu 0.42.2",
+ "windows_i686_msvc 0.42.2",
+ "windows_x86_64_gnu 0.42.2",
+ "windows_x86_64_gnullvm 0.42.2",
+ "windows_x86_64_msvc 0.42.2",
+]
+
+[[package]]
+name = "windows-targets"
+version = "0.52.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9b724f72796e036ab90c1021d4780d4d3d648aca59e491e6b98e725b84e99973"
+dependencies = [
+ "windows_aarch64_gnullvm 0.52.6",
+ "windows_aarch64_msvc 0.52.6",
+ "windows_i686_gnu 0.52.6",
+ "windows_i686_gnullvm 0.52.6",
+ "windows_i686_msvc 0.52.6",
+ "windows_x86_64_gnu 0.52.6",
+ "windows_x86_64_gnullvm 0.52.6",
+ "windows_x86_64_msvc 0.52.6",
+]
+
+[[package]]
+name = "windows-targets"
+version = "0.53.5"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "4945f9f551b88e0d65f3db0bc25c33b8acea4d9e41163edf90dcd0b19f9069f3"
+dependencies = [
+ "windows-link 0.2.1",
+ "windows_aarch64_gnullvm 0.53.1",
+ "windows_aarch64_msvc 0.53.1",
+ "windows_i686_gnu 0.53.1",
+ "windows_i686_gnullvm 0.53.1",
+ "windows_i686_msvc 0.53.1",
+ "windows_x86_64_gnu 0.53.1",
+ "windows_x86_64_gnullvm 0.53.1",
+ "windows_x86_64_msvc 0.53.1",
+]
+
+[[package]]
+name = "windows-threading"
+version = "0.1.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b66463ad2e0ea3bbf808b7f1d371311c80e115c0b71d60efc142cafbcfb057a6"
+dependencies = [
+ "windows-link 0.1.3",
+]
+
+[[package]]
+name = "windows-version"
+version = "0.1.7"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e4060a1da109b9d0326b7262c8e12c84df67cc0dbc9e33cf49e01ccc2eb63631"
+dependencies = [
+ "windows-link 0.2.1",
+]
+
+[[package]]
+name = "windows_aarch64_gnullvm"
+version = "0.42.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "597a5118570b68bc08d8d59125332c54f1ba9d9adeedeef5b99b02ba2b0698f8"
+
+[[package]]
+name = "windows_aarch64_gnullvm"
+version = "0.52.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "32a4622180e7a0ec044bb555404c800bc9fd9ec262ec147edd5989ccd0c02cd3"
+
+[[package]]
+name = "windows_aarch64_gnullvm"
+version = "0.53.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "a9d8416fa8b42f5c947f8482c43e7d89e73a173cead56d044f6a56104a6d1b53"
+
+[[package]]
+name = "windows_aarch64_msvc"
+version = "0.42.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e08e8864a60f06ef0d0ff4ba04124db8b0fb3be5776a5cd47641e942e58c4d43"
+
+[[package]]
+name = "windows_aarch64_msvc"
+version = "0.52.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "09ec2a7bb152e2252b53fa7803150007879548bc709c039df7627cabbd05d469"
+
+[[package]]
+name = "windows_aarch64_msvc"
+version = "0.53.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b9d782e804c2f632e395708e99a94275910eb9100b2114651e04744e9b125006"
+
+[[package]]
+name = "windows_i686_gnu"
+version = "0.42.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c61d927d8da41da96a81f029489353e68739737d3beca43145c8afec9a31a84f"
+
+[[package]]
+name = "windows_i686_gnu"
+version = "0.52.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8e9b5ad5ab802e97eb8e295ac6720e509ee4c243f69d781394014ebfe8bbfa0b"
+
+[[package]]
+name = "windows_i686_gnu"
+version = "0.53.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "960e6da069d81e09becb0ca57a65220ddff016ff2d6af6a223cf372a506593a3"
+
+[[package]]
+name = "windows_i686_gnullvm"
+version = "0.52.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0eee52d38c090b3caa76c563b86c3a4bd71ef1a819287c19d586d7334ae8ed66"
+
+[[package]]
+name = "windows_i686_gnullvm"
+version = "0.53.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "fa7359d10048f68ab8b09fa71c3daccfb0e9b559aed648a8f95469c27057180c"
+
+[[package]]
+name = "windows_i686_msvc"
+version = "0.42.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "44d840b6ec649f480a41c8d80f9c65108b92d89345dd94027bfe06ac444d1060"
+
+[[package]]
+name = "windows_i686_msvc"
+version = "0.52.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "240948bc05c5e7c6dabba28bf89d89ffce3e303022809e73deaefe4f6ec56c66"
+
+[[package]]
+name = "windows_i686_msvc"
+version = "0.53.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1e7ac75179f18232fe9c285163565a57ef8d3c89254a30685b57d83a38d326c2"
+
+[[package]]
+name = "windows_x86_64_gnu"
+version = "0.42.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8de912b8b8feb55c064867cf047dda097f92d51efad5b491dfb98f6bbb70cb36"
+
+[[package]]
+name = "windows_x86_64_gnu"
+version = "0.52.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "147a5c80aabfbf0c7d901cb5895d1de30ef2907eb21fbbab29ca94c5b08b1a78"
+
+[[package]]
+name = "windows_x86_64_gnu"
+version = "0.53.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9c3842cdd74a865a8066ab39c8a7a473c0778a3f29370b5fd6b4b9aa7df4a499"
+
+[[package]]
+name = "windows_x86_64_gnullvm"
+version = "0.42.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "26d41b46a36d453748aedef1486d5c7a85db22e56aff34643984ea85514e94a3"
+
+[[package]]
+name = "windows_x86_64_gnullvm"
+version = "0.52.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "24d5b23dc417412679681396f2b49f3de8c1473deb516bd34410872eff51ed0d"
+
+[[package]]
+name = "windows_x86_64_gnullvm"
+version = "0.53.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0ffa179e2d07eee8ad8f57493436566c7cc30ac536a3379fdf008f47f6bb7ae1"
+
+[[package]]
+name = "windows_x86_64_msvc"
+version = "0.42.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9aec5da331524158c6d1a4ac0ab1541149c0b9505fde06423b02f5ef0106b9f0"
+
+[[package]]
+name = "windows_x86_64_msvc"
+version = "0.52.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "589f6da84c646204747d1270a2a5661ea66ed1cced2631d546fdfb155959f9ec"
+
+[[package]]
+name = "windows_x86_64_msvc"
+version = "0.53.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d6bbff5f0aada427a1e5a6da5f1f98158182f26556f345ac9e04d36d0ebed650"
+
+[[package]]
+name = "winnow"
+version = "0.5.40"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f593a95398737aeed53e489c785df13f3618e41dbcd6718c6addbf1395aa6876"
+dependencies = [
+ "memchr",
+]
+
+[[package]]
+name = "winnow"
+version = "0.7.15"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "df79d97927682d2fd8adb29682d1140b343be4ac0f08fd68b7765d9c059d3945"
+dependencies = [
+ "memchr",
+]
+
+[[package]]
+name = "winnow"
+version = "1.0.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "09dac053f1cd375980747450bfc7250c264eaae0583872e845c0c7cd578872b5"
+dependencies = [
+ "memchr",
+]
+
+[[package]]
+name = "winreg"
+version = "0.55.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "cb5a765337c50e9ec252c2069be9bf91c7df47afb103b642ba3a53bf8101be97"
+dependencies = [
+ "cfg-if",
+ "windows-sys 0.59.0",
+]
+
+[[package]]
+name = "wit-bindgen"
+version = "0.51.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d7249219f66ced02969388cf2bb044a09756a083d0fab1e566056b04d9fbcaa5"
+dependencies = [
+ "wit-bindgen-rust-macro",
+]
+
+[[package]]
+name = "wit-bindgen-core"
+version = "0.51.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ea61de684c3ea68cb082b7a88508a8b27fcc8b797d738bfc99a82facf1d752dc"
+dependencies = [
+ "anyhow",
+ "heck 0.5.0",
+ "wit-parser",
+]
+
+[[package]]
+name = "wit-bindgen-rust"
+version = "0.51.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b7c566e0f4b284dd6561c786d9cb0142da491f46a9fbed79ea69cdad5db17f21"
+dependencies = [
+ "anyhow",
+ "heck 0.5.0",
+ "indexmap 2.14.0",
+ "prettyplease",
+ "syn 2.0.117",
+ "wasm-metadata",
+ "wit-bindgen-core",
+ "wit-component",
+]
+
+[[package]]
+name = "wit-bindgen-rust-macro"
+version = "0.51.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0c0f9bfd77e6a48eccf51359e3ae77140a7f50b1e2ebfe62422d8afdaffab17a"
+dependencies = [
+ "anyhow",
+ "prettyplease",
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+ "wit-bindgen-core",
+ "wit-bindgen-rust",
+]
+
+[[package]]
+name = "wit-component"
+version = "0.244.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9d66ea20e9553b30172b5e831994e35fbde2d165325bec84fc43dbf6f4eb9cb2"
+dependencies = [
+ "anyhow",
+ "bitflags 2.11.1",
+ "indexmap 2.14.0",
+ "log",
+ "serde",
+ "serde_derive",
+ "serde_json",
+ "wasm-encoder",
+ "wasm-metadata",
+ "wasmparser",
+ "wit-parser",
+]
+
+[[package]]
+name = "wit-parser"
+version = "0.244.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ecc8ac4bc1dc3381b7f59c34f00b67e18f910c2c0f50015669dde7def656a736"
+dependencies = [
+ "anyhow",
+ "id-arena",
+ "indexmap 2.14.0",
+ "log",
+ "semver",
+ "serde",
+ "serde_derive",
+ "serde_json",
+ "unicode-xid",
+ "wasmparser",
+]
+
+[[package]]
+name = "writeable"
+version = "0.6.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1ffae5123b2d3fc086436f8834ae3ab053a283cfac8fe0a0b8eaae044768a4c4"
+
+[[package]]
+name = "wry"
+version = "0.54.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e5a8135d8676225e5744de000d4dff5a082501bf7db6a1c1495034f8c314edbc"
+dependencies = [
+ "base64 0.22.1",
+ "block2",
+ "cookie",
+ "crossbeam-channel",
+ "dirs",
+ "dom_query",
+ "dpi",
+ "dunce",
+ "gdkx11",
+ "gtk",
+ "http",
+ "javascriptcore-rs",
+ "jni",
+ "libc",
+ "ndk",
+ "objc2",
+ "objc2-app-kit",
+ "objc2-core-foundation",
+ "objc2-foundation",
+ "objc2-ui-kit",
+ "objc2-web-kit",
+ "once_cell",
+ "percent-encoding",
+ "raw-window-handle",
+ "sha2",
+ "soup3",
+ "tao-macros",
+ "thiserror 2.0.18",
+ "url",
+ "webkit2gtk",
+ "webkit2gtk-sys",
+ "webview2-com",
+ "windows 0.61.3",
+ "windows-core 0.61.2",
+ "windows-version",
+ "x11-dl",
+]
+
+[[package]]
+name = "wyz"
+version = "0.5.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "05f360fc0b24296329c78fda852a1e9ae82de9cf7b27dae4b7f62f118f77b9ed"
+dependencies = [
+ "tap",
+]
+
+[[package]]
+name = "x11"
+version = "2.21.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "502da5464ccd04011667b11c435cb992822c2c0dbde1770c988480d312a0db2e"
+dependencies = [
+ "libc",
+ "pkg-config",
+]
+
+[[package]]
+name = "x11-dl"
+version = "2.21.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "38735924fedd5314a6e548792904ed8c6de6636285cb9fec04d5b1db85c1516f"
+dependencies = [
+ "libc",
+ "once_cell",
+ "pkg-config",
+]
+
+[[package]]
+name = "x11rb"
+version = "0.13.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9993aa5be5a26815fe2c3eacfc1fde061fc1a1f094bf1ad2a18bf9c495dd7414"
+dependencies = [
+ "gethostname",
+ "rustix",
+ "x11rb-protocol",
+]
+
+[[package]]
+name = "x11rb-protocol"
+version = "0.13.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ea6fc2961e4ef194dcbfe56bb845534d0dc8098940c7e5c012a258bfec6701bd"
+
+[[package]]
+name = "xattr"
+version = "1.6.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "32e45ad4206f6d2479085147f02bc2ef834ac85886624a23575ae137c8aa8156"
+dependencies = [
+ "libc",
+ "rustix",
+]
+
+[[package]]
+name = "xkeysym"
+version = "0.2.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b9cc00251562a284751c9973bace760d86c0276c471b4be569fe6b068ee97a56"
+
+[[package]]
+name = "yoke"
+version = "0.8.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "abe8c5fda708d9ca3df187cae8bfb9ceda00dd96231bed36e445a1a48e66f9ca"
+dependencies = [
+ "stable_deref_trait",
+ "yoke-derive",
+ "zerofrom",
+]
+
+[[package]]
+name = "yoke-derive"
+version = "0.8.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "de844c262c8848816172cef550288e7dc6c7b7814b4ee56b3e1553f275f1858e"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+ "synstructure",
+]
+
+[[package]]
+name = "zbus"
+version = "5.14.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ca82f95dbd3943a40a53cfded6c2d0a2ca26192011846a1810c4256ef92c60bc"
+dependencies = [
+ "async-broadcast",
+ "async-executor",
+ "async-io",
+ "async-lock",
+ "async-process",
+ "async-recursion",
+ "async-task",
+ "async-trait",
+ "blocking",
+ "enumflags2",
+ "event-listener",
+ "futures-core",
+ "futures-lite",
+ "hex",
+ "libc",
+ "ordered-stream",
+ "rustix",
+ "serde",
+ "serde_repr",
+ "tracing",
+ "uds_windows",
+ "uuid",
+ "windows-sys 0.61.2",
+ "winnow 0.7.15",
+ "zbus_macros",
+ "zbus_names",
+ "zvariant",
+]
+
+[[package]]
+name = "zbus_macros"
+version = "5.14.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "897e79616e84aac4b2c46e9132a4f63b93105d54fe8c0e8f6bffc21fa8d49222"
+dependencies = [
+ "proc-macro-crate 3.5.0",
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+ "zbus_names",
+ "zvariant",
+ "zvariant_utils",
+]
+
+[[package]]
+name = "zbus_names"
+version = "4.3.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "ffd8af6d5b78619bab301ff3c560a5bd22426150253db278f164d6cf3b72c50f"
+dependencies = [
+ "serde",
+ "winnow 0.7.15",
+ "zvariant",
+]
+
+[[package]]
+name = "zerocopy"
+version = "0.8.48"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "eed437bf9d6692032087e337407a86f04cd8d6a16a37199ed57949d415bd68e9"
+dependencies = [
+ "zerocopy-derive",
+]
+
+[[package]]
+name = "zerocopy-derive"
+version = "0.8.48"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "70e3cd084b1788766f53af483dd21f93881ff30d7320490ec3ef7526d203bad4"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "zerofrom"
+version = "0.1.7"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "69faa1f2a1ea75661980b013019ed6687ed0e83d069bc1114e2cc74c6c04c4df"
+dependencies = [
+ "zerofrom-derive",
+]
+
+[[package]]
+name = "zerofrom-derive"
+version = "0.1.7"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "11532158c46691caf0f2593ea8358fed6bbf68a0315e80aae9bd41fbade684a1"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+ "synstructure",
+]
+
+[[package]]
+name = "zeroize"
+version = "1.8.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b97154e67e32c85465826e8bcc1c59429aaaf107c1e4a9e53c8d8ccd5eff88d0"
+
+[[package]]
+name = "zerotrie"
+version = "0.2.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0f9152d31db0792fa83f70fb2f83148effb5c1f5b8c7686c3459e361d9bc20bf"
+dependencies = [
+ "displaydoc",
+ "yoke",
+ "zerofrom",
+]
+
+[[package]]
+name = "zerovec"
+version = "0.11.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "90f911cbc359ab6af17377d242225f4d75119aec87ea711a880987b18cd7b239"
+dependencies = [
+ "yoke",
+ "zerofrom",
+ "zerovec-derive",
+]
+
+[[package]]
+name = "zerovec-derive"
+version = "0.11.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "625dc425cab0dca6dc3c3319506e6593dcb08a9f387ea3b284dbd52a92c40555"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+]
+
+[[package]]
+name = "zip"
+version = "4.6.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "caa8cd6af31c3b31c6631b8f483848b91589021b28fffe50adada48d4f4d2ed1"
+dependencies = [
+ "arbitrary",
+ "crc32fast",
+ "indexmap 2.14.0",
+ "memchr",
+]
+
+[[package]]
+name = "zmij"
+version = "1.0.21"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b8848ee67ecc8aedbaf3e4122217aff892639231befc6a1b58d29fff4c2cabaa"
+
+[[package]]
+name = "zvariant"
+version = "5.10.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5708299b21903bbe348e94729f22c49c55d04720a004aa350f1f9c122fd2540b"
+dependencies = [
+ "endi",
+ "enumflags2",
+ "serde",
+ "winnow 0.7.15",
+ "zvariant_derive",
+ "zvariant_utils",
+]
+
+[[package]]
+name = "zvariant_derive"
+version = "5.10.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5b59b012ebe9c46656f9cc08d8da8b4c726510aef12559da3e5f1bf72780752c"
+dependencies = [
+ "proc-macro-crate 3.5.0",
+ "proc-macro2",
+ "quote",
+ "syn 2.0.117",
+ "zvariant_utils",
+]
+
+[[package]]
+name = "zvariant_utils"
+version = "3.3.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f75c23a64ef8f40f13a6989991e643554d9bef1d682a281160cf0c1bc389c5e9"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "serde",
+ "syn 2.0.117",
+ "winnow 0.7.15",
+]
diff --git a/new-client/src-tauri/Cargo.toml b/new-client/src-tauri/Cargo.toml
new file mode 100644
index 0000000..248ceca
--- /dev/null
+++ b/new-client/src-tauri/Cargo.toml
@@ -0,0 +1,33 @@
+[package]
+name = "app"
+version = "0.1.0"
+description = "WW додепчик"
+authors = ["KPTL"]
+license = ""
+repository = ""
+edition = "2021"
+rust-version = "1.77.2"
+
+# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
+
+[lib]
+name = "app_lib"
+crate-type = ["staticlib", "cdylib", "rlib"]
+
+[build-dependencies]
+tauri-build = { version = "2.4.1", features = [] }
+
+[dependencies]
+serde_json = "1.0"
+serde = { version = "1.0", features = ["derive"] }
+log = "0.4"
+tauri = { version = "2.8.5", features = [] }
+tauri-plugin-log = "2"
+tauri-plugin-process = "2"
+windows = { version = "0.52", features = ["Win32_UI_Shell"] }
+tauri-plugin-opener = "2"
+
+[target.'cfg(not(any(target_os = "android", target_os = "ios")))'.dependencies]
+tauri-plugin-global-shortcut = "2"
+tauri-plugin-single-instance = "2"
+tauri-plugin-updater = "2"
diff --git a/new-client/src-tauri/Info.plist b/new-client/src-tauri/Info.plist
new file mode 100644
index 0000000..c8de34e
--- /dev/null
+++ b/new-client/src-tauri/Info.plist
@@ -0,0 +1,10 @@
+
+
+
+
+ NSCameraUsageDescription
+ Request camera access for WebRTC
+ NSMicrophoneUsageDescription
+ Request microphone access for WebRTC
+
+
\ No newline at end of file
diff --git a/new-client/src-tauri/build.rs b/new-client/src-tauri/build.rs
new file mode 100644
index 0000000..d860e1e
--- /dev/null
+++ b/new-client/src-tauri/build.rs
@@ -0,0 +1,3 @@
+fn main() {
+ tauri_build::build()
+}
diff --git a/new-client/src-tauri/capabilities/default.json b/new-client/src-tauri/capabilities/default.json
new file mode 100644
index 0000000..c135d7f
--- /dev/null
+++ b/new-client/src-tauri/capabilities/default.json
@@ -0,0 +1,11 @@
+{
+ "$schema": "../gen/schemas/desktop-schema.json",
+ "identifier": "default",
+ "description": "enables the default permissions",
+ "windows": [
+ "main"
+ ],
+ "permissions": [
+ "core:default"
+ ]
+}
diff --git a/new-client/src-tauri/capabilities/desktop.json b/new-client/src-tauri/capabilities/desktop.json
new file mode 100644
index 0000000..e1a7933
--- /dev/null
+++ b/new-client/src-tauri/capabilities/desktop.json
@@ -0,0 +1,20 @@
+{
+ "identifier": "desktop-capability",
+ "platforms": [
+ "macOS",
+ "windows",
+ "linux"
+ ],
+ "windows": [
+ "main"
+ ],
+ "permissions": [
+ "updater:default",
+ "global-shortcut:allow-is-registered",
+ "global-shortcut:allow-register",
+ "global-shortcut:allow-unregister",
+ "global-shortcut:allow-unregister-all",
+ "opener:allow-default-urls",
+ "opener:allow-open-url"
+ ]
+}
\ No newline at end of file
diff --git a/new-client/src-tauri/icons/128x128.png b/new-client/src-tauri/icons/128x128.png
new file mode 100644
index 0000000..707d6f4
Binary files /dev/null and b/new-client/src-tauri/icons/128x128.png differ
diff --git a/new-client/src-tauri/icons/128x128@2x.png b/new-client/src-tauri/icons/128x128@2x.png
new file mode 100644
index 0000000..48ea400
Binary files /dev/null and b/new-client/src-tauri/icons/128x128@2x.png differ
diff --git a/new-client/src-tauri/icons/32x32.png b/new-client/src-tauri/icons/32x32.png
new file mode 100644
index 0000000..16e92cb
Binary files /dev/null and b/new-client/src-tauri/icons/32x32.png differ
diff --git a/new-client/src-tauri/icons/64x64.png b/new-client/src-tauri/icons/64x64.png
new file mode 100644
index 0000000..4b138ec
Binary files /dev/null and b/new-client/src-tauri/icons/64x64.png differ
diff --git a/new-client/src-tauri/icons/Square107x107Logo.png b/new-client/src-tauri/icons/Square107x107Logo.png
new file mode 100644
index 0000000..52ef9cb
Binary files /dev/null and b/new-client/src-tauri/icons/Square107x107Logo.png differ
diff --git a/new-client/src-tauri/icons/Square142x142Logo.png b/new-client/src-tauri/icons/Square142x142Logo.png
new file mode 100644
index 0000000..a1052ed
Binary files /dev/null and b/new-client/src-tauri/icons/Square142x142Logo.png differ
diff --git a/new-client/src-tauri/icons/Square150x150Logo.png b/new-client/src-tauri/icons/Square150x150Logo.png
new file mode 100644
index 0000000..6bc0599
Binary files /dev/null and b/new-client/src-tauri/icons/Square150x150Logo.png differ
diff --git a/new-client/src-tauri/icons/Square284x284Logo.png b/new-client/src-tauri/icons/Square284x284Logo.png
new file mode 100644
index 0000000..dc180a3
Binary files /dev/null and b/new-client/src-tauri/icons/Square284x284Logo.png differ
diff --git a/new-client/src-tauri/icons/Square30x30Logo.png b/new-client/src-tauri/icons/Square30x30Logo.png
new file mode 100644
index 0000000..a3c2427
Binary files /dev/null and b/new-client/src-tauri/icons/Square30x30Logo.png differ
diff --git a/new-client/src-tauri/icons/Square310x310Logo.png b/new-client/src-tauri/icons/Square310x310Logo.png
new file mode 100644
index 0000000..64fdd3e
Binary files /dev/null and b/new-client/src-tauri/icons/Square310x310Logo.png differ
diff --git a/new-client/src-tauri/icons/Square44x44Logo.png b/new-client/src-tauri/icons/Square44x44Logo.png
new file mode 100644
index 0000000..ad9d530
Binary files /dev/null and b/new-client/src-tauri/icons/Square44x44Logo.png differ
diff --git a/new-client/src-tauri/icons/Square71x71Logo.png b/new-client/src-tauri/icons/Square71x71Logo.png
new file mode 100644
index 0000000..fef4d48
Binary files /dev/null and b/new-client/src-tauri/icons/Square71x71Logo.png differ
diff --git a/new-client/src-tauri/icons/Square89x89Logo.png b/new-client/src-tauri/icons/Square89x89Logo.png
new file mode 100644
index 0000000..d2066d2
Binary files /dev/null and b/new-client/src-tauri/icons/Square89x89Logo.png differ
diff --git a/new-client/src-tauri/icons/StoreLogo.png b/new-client/src-tauri/icons/StoreLogo.png
new file mode 100644
index 0000000..834c2bb
Binary files /dev/null and b/new-client/src-tauri/icons/StoreLogo.png differ
diff --git a/new-client/src-tauri/icons/android/mipmap-hdpi/ic_launcher.png b/new-client/src-tauri/icons/android/mipmap-hdpi/ic_launcher.png
new file mode 100644
index 0000000..9db2cfc
Binary files /dev/null and b/new-client/src-tauri/icons/android/mipmap-hdpi/ic_launcher.png differ
diff --git a/new-client/src-tauri/icons/android/mipmap-hdpi/ic_launcher_foreground.png b/new-client/src-tauri/icons/android/mipmap-hdpi/ic_launcher_foreground.png
new file mode 100644
index 0000000..60816e9
Binary files /dev/null and b/new-client/src-tauri/icons/android/mipmap-hdpi/ic_launcher_foreground.png differ
diff --git a/new-client/src-tauri/icons/android/mipmap-hdpi/ic_launcher_round.png b/new-client/src-tauri/icons/android/mipmap-hdpi/ic_launcher_round.png
new file mode 100644
index 0000000..9db2cfc
Binary files /dev/null and b/new-client/src-tauri/icons/android/mipmap-hdpi/ic_launcher_round.png differ
diff --git a/new-client/src-tauri/icons/android/mipmap-mdpi/ic_launcher.png b/new-client/src-tauri/icons/android/mipmap-mdpi/ic_launcher.png
new file mode 100644
index 0000000..d6f95c2
Binary files /dev/null and b/new-client/src-tauri/icons/android/mipmap-mdpi/ic_launcher.png differ
diff --git a/new-client/src-tauri/icons/android/mipmap-mdpi/ic_launcher_foreground.png b/new-client/src-tauri/icons/android/mipmap-mdpi/ic_launcher_foreground.png
new file mode 100644
index 0000000..4b7d7bc
Binary files /dev/null and b/new-client/src-tauri/icons/android/mipmap-mdpi/ic_launcher_foreground.png differ
diff --git a/new-client/src-tauri/icons/android/mipmap-mdpi/ic_launcher_round.png b/new-client/src-tauri/icons/android/mipmap-mdpi/ic_launcher_round.png
new file mode 100644
index 0000000..d6f95c2
Binary files /dev/null and b/new-client/src-tauri/icons/android/mipmap-mdpi/ic_launcher_round.png differ
diff --git a/new-client/src-tauri/icons/android/mipmap-xhdpi/ic_launcher.png b/new-client/src-tauri/icons/android/mipmap-xhdpi/ic_launcher.png
new file mode 100644
index 0000000..ac22d58
Binary files /dev/null and b/new-client/src-tauri/icons/android/mipmap-xhdpi/ic_launcher.png differ
diff --git a/new-client/src-tauri/icons/android/mipmap-xhdpi/ic_launcher_foreground.png b/new-client/src-tauri/icons/android/mipmap-xhdpi/ic_launcher_foreground.png
new file mode 100644
index 0000000..1da0b44
Binary files /dev/null and b/new-client/src-tauri/icons/android/mipmap-xhdpi/ic_launcher_foreground.png differ
diff --git a/new-client/src-tauri/icons/android/mipmap-xhdpi/ic_launcher_round.png b/new-client/src-tauri/icons/android/mipmap-xhdpi/ic_launcher_round.png
new file mode 100644
index 0000000..ac22d58
Binary files /dev/null and b/new-client/src-tauri/icons/android/mipmap-xhdpi/ic_launcher_round.png differ
diff --git a/new-client/src-tauri/icons/android/mipmap-xxhdpi/ic_launcher.png b/new-client/src-tauri/icons/android/mipmap-xxhdpi/ic_launcher.png
new file mode 100644
index 0000000..92ddd44
Binary files /dev/null and b/new-client/src-tauri/icons/android/mipmap-xxhdpi/ic_launcher.png differ
diff --git a/new-client/src-tauri/icons/android/mipmap-xxhdpi/ic_launcher_foreground.png b/new-client/src-tauri/icons/android/mipmap-xxhdpi/ic_launcher_foreground.png
new file mode 100644
index 0000000..ac05047
Binary files /dev/null and b/new-client/src-tauri/icons/android/mipmap-xxhdpi/ic_launcher_foreground.png differ
diff --git a/new-client/src-tauri/icons/android/mipmap-xxhdpi/ic_launcher_round.png b/new-client/src-tauri/icons/android/mipmap-xxhdpi/ic_launcher_round.png
new file mode 100644
index 0000000..92ddd44
Binary files /dev/null and b/new-client/src-tauri/icons/android/mipmap-xxhdpi/ic_launcher_round.png differ
diff --git a/new-client/src-tauri/icons/android/mipmap-xxxhdpi/ic_launcher.png b/new-client/src-tauri/icons/android/mipmap-xxxhdpi/ic_launcher.png
new file mode 100644
index 0000000..a6ebf92
Binary files /dev/null and b/new-client/src-tauri/icons/android/mipmap-xxxhdpi/ic_launcher.png differ
diff --git a/new-client/src-tauri/icons/android/mipmap-xxxhdpi/ic_launcher_foreground.png b/new-client/src-tauri/icons/android/mipmap-xxxhdpi/ic_launcher_foreground.png
new file mode 100644
index 0000000..10ff05e
Binary files /dev/null and b/new-client/src-tauri/icons/android/mipmap-xxxhdpi/ic_launcher_foreground.png differ
diff --git a/new-client/src-tauri/icons/android/mipmap-xxxhdpi/ic_launcher_round.png b/new-client/src-tauri/icons/android/mipmap-xxxhdpi/ic_launcher_round.png
new file mode 100644
index 0000000..a6ebf92
Binary files /dev/null and b/new-client/src-tauri/icons/android/mipmap-xxxhdpi/ic_launcher_round.png differ
diff --git a/new-client/src-tauri/icons/icon.icns b/new-client/src-tauri/icons/icon.icns
new file mode 100644
index 0000000..d1f02a1
Binary files /dev/null and b/new-client/src-tauri/icons/icon.icns differ
diff --git a/new-client/src-tauri/icons/icon.ico b/new-client/src-tauri/icons/icon.ico
new file mode 100644
index 0000000..3ab412d
Binary files /dev/null and b/new-client/src-tauri/icons/icon.ico differ
diff --git a/new-client/src-tauri/icons/icon.png b/new-client/src-tauri/icons/icon.png
new file mode 100644
index 0000000..bb988af
Binary files /dev/null and b/new-client/src-tauri/icons/icon.png differ
diff --git a/new-client/src-tauri/icons/ios/AppIcon-20x20@1x.png b/new-client/src-tauri/icons/ios/AppIcon-20x20@1x.png
new file mode 100644
index 0000000..b457138
Binary files /dev/null and b/new-client/src-tauri/icons/ios/AppIcon-20x20@1x.png differ
diff --git a/new-client/src-tauri/icons/ios/AppIcon-20x20@2x-1.png b/new-client/src-tauri/icons/ios/AppIcon-20x20@2x-1.png
new file mode 100644
index 0000000..097f1af
Binary files /dev/null and b/new-client/src-tauri/icons/ios/AppIcon-20x20@2x-1.png differ
diff --git a/new-client/src-tauri/icons/ios/AppIcon-20x20@2x.png b/new-client/src-tauri/icons/ios/AppIcon-20x20@2x.png
new file mode 100644
index 0000000..097f1af
Binary files /dev/null and b/new-client/src-tauri/icons/ios/AppIcon-20x20@2x.png differ
diff --git a/new-client/src-tauri/icons/ios/AppIcon-20x20@3x.png b/new-client/src-tauri/icons/ios/AppIcon-20x20@3x.png
new file mode 100644
index 0000000..7aede6f
Binary files /dev/null and b/new-client/src-tauri/icons/ios/AppIcon-20x20@3x.png differ
diff --git a/new-client/src-tauri/icons/ios/AppIcon-29x29@1x.png b/new-client/src-tauri/icons/ios/AppIcon-29x29@1x.png
new file mode 100644
index 0000000..0872b29
Binary files /dev/null and b/new-client/src-tauri/icons/ios/AppIcon-29x29@1x.png differ
diff --git a/new-client/src-tauri/icons/ios/AppIcon-29x29@2x-1.png b/new-client/src-tauri/icons/ios/AppIcon-29x29@2x-1.png
new file mode 100644
index 0000000..c6396cf
Binary files /dev/null and b/new-client/src-tauri/icons/ios/AppIcon-29x29@2x-1.png differ
diff --git a/new-client/src-tauri/icons/ios/AppIcon-29x29@2x.png b/new-client/src-tauri/icons/ios/AppIcon-29x29@2x.png
new file mode 100644
index 0000000..c6396cf
Binary files /dev/null and b/new-client/src-tauri/icons/ios/AppIcon-29x29@2x.png differ
diff --git a/new-client/src-tauri/icons/ios/AppIcon-29x29@3x.png b/new-client/src-tauri/icons/ios/AppIcon-29x29@3x.png
new file mode 100644
index 0000000..ece7b1a
Binary files /dev/null and b/new-client/src-tauri/icons/ios/AppIcon-29x29@3x.png differ
diff --git a/new-client/src-tauri/icons/ios/AppIcon-40x40@1x.png b/new-client/src-tauri/icons/ios/AppIcon-40x40@1x.png
new file mode 100644
index 0000000..097f1af
Binary files /dev/null and b/new-client/src-tauri/icons/ios/AppIcon-40x40@1x.png differ
diff --git a/new-client/src-tauri/icons/ios/AppIcon-40x40@2x-1.png b/new-client/src-tauri/icons/ios/AppIcon-40x40@2x-1.png
new file mode 100644
index 0000000..bfb839b
Binary files /dev/null and b/new-client/src-tauri/icons/ios/AppIcon-40x40@2x-1.png differ
diff --git a/new-client/src-tauri/icons/ios/AppIcon-40x40@2x.png b/new-client/src-tauri/icons/ios/AppIcon-40x40@2x.png
new file mode 100644
index 0000000..bfb839b
Binary files /dev/null and b/new-client/src-tauri/icons/ios/AppIcon-40x40@2x.png differ
diff --git a/new-client/src-tauri/icons/ios/AppIcon-40x40@3x.png b/new-client/src-tauri/icons/ios/AppIcon-40x40@3x.png
new file mode 100644
index 0000000..7c0ef8e
Binary files /dev/null and b/new-client/src-tauri/icons/ios/AppIcon-40x40@3x.png differ
diff --git a/new-client/src-tauri/icons/ios/AppIcon-512@2x.png b/new-client/src-tauri/icons/ios/AppIcon-512@2x.png
new file mode 100644
index 0000000..dffc9bf
Binary files /dev/null and b/new-client/src-tauri/icons/ios/AppIcon-512@2x.png differ
diff --git a/new-client/src-tauri/icons/ios/AppIcon-60x60@2x.png b/new-client/src-tauri/icons/ios/AppIcon-60x60@2x.png
new file mode 100644
index 0000000..7c0ef8e
Binary files /dev/null and b/new-client/src-tauri/icons/ios/AppIcon-60x60@2x.png differ
diff --git a/new-client/src-tauri/icons/ios/AppIcon-60x60@3x.png b/new-client/src-tauri/icons/ios/AppIcon-60x60@3x.png
new file mode 100644
index 0000000..8a0dafc
Binary files /dev/null and b/new-client/src-tauri/icons/ios/AppIcon-60x60@3x.png differ
diff --git a/new-client/src-tauri/icons/ios/AppIcon-76x76@1x.png b/new-client/src-tauri/icons/ios/AppIcon-76x76@1x.png
new file mode 100644
index 0000000..d098b59
Binary files /dev/null and b/new-client/src-tauri/icons/ios/AppIcon-76x76@1x.png differ
diff --git a/new-client/src-tauri/icons/ios/AppIcon-76x76@2x.png b/new-client/src-tauri/icons/ios/AppIcon-76x76@2x.png
new file mode 100644
index 0000000..be2345a
Binary files /dev/null and b/new-client/src-tauri/icons/ios/AppIcon-76x76@2x.png differ
diff --git a/new-client/src-tauri/icons/ios/AppIcon-83.5x83.5@2x.png b/new-client/src-tauri/icons/ios/AppIcon-83.5x83.5@2x.png
new file mode 100644
index 0000000..1be2f76
Binary files /dev/null and b/new-client/src-tauri/icons/ios/AppIcon-83.5x83.5@2x.png differ
diff --git a/new-client/src-tauri/icons/original.svg b/new-client/src-tauri/icons/original.svg
new file mode 100644
index 0000000..11ded56
--- /dev/null
+++ b/new-client/src-tauri/icons/original.svg
@@ -0,0 +1,3 @@
+
diff --git a/new-client/src-tauri/src/lib.rs b/new-client/src-tauri/src/lib.rs
new file mode 100644
index 0000000..1e27923
--- /dev/null
+++ b/new-client/src-tauri/src/lib.rs
@@ -0,0 +1,21 @@
+#[cfg_attr(mobile, tauri::mobile_entry_point)]
+pub fn run() {
+ tauri::Builder::default()
+ .plugin(tauri_plugin_opener::init())
+ .plugin(tauri_plugin_global_shortcut::Builder::new().build())
+ .plugin(tauri_plugin_process::init())
+ .plugin(tauri_plugin_updater::Builder::new().build())
+ // .plugin(tauri_plugin_single_instance::init(|_, _, _| {}))
+ .setup(|app| {
+ if cfg!(debug_assertions) {
+ app.handle().plugin(
+ tauri_plugin_log::Builder::default()
+ .level(log::LevelFilter::Info)
+ .build(),
+ )?;
+ }
+ Ok(())
+ })
+ .run(tauri::generate_context!())
+ .expect("error while running tauri application");
+}
diff --git a/new-client/src-tauri/src/main.rs b/new-client/src-tauri/src/main.rs
new file mode 100644
index 0000000..9ed4335
--- /dev/null
+++ b/new-client/src-tauri/src/main.rs
@@ -0,0 +1,21 @@
+// Prevents additional console window on Windows in release, DO NOT REMOVE!!
+#![cfg_attr(not(debug_assertions), windows_subsystem = "windows")]
+
+#[cfg(target_os = "windows")]
+fn set_app_user_model_id() {
+ use windows::core::HSTRING;
+ use windows::Win32::UI::Shell::SetCurrentProcessExplicitAppUserModelID;
+
+ unsafe {
+ SetCurrentProcessExplicitAppUserModelID(&HSTRING::from("xyz.koptilnya.chad"))
+ .ok()
+ .expect("Failed to set AppUserModelID");
+ }
+}
+
+fn main() {
+ #[cfg(target_os = "windows")]
+ set_app_user_model_id();
+
+ app_lib::run();
+}
diff --git a/new-client/src-tauri/tauri.conf.json b/new-client/src-tauri/tauri.conf.json
new file mode 100644
index 0000000..5ae6ff6
--- /dev/null
+++ b/new-client/src-tauri/tauri.conf.json
@@ -0,0 +1,60 @@
+{
+ "$schema": "../node_modules/@tauri-apps/cli/config.schema.json",
+ "productName": "Chad",
+ "version": "0.3.0-rc.3",
+ "identifier": "xyz.koptilnya.chad",
+ "build": {
+ "frontendDist": "../dist",
+ "devUrl": "http://localhost:3000",
+ "beforeDevCommand": "yarn dev",
+ "beforeBuildCommand": "yarn generate"
+ },
+ "app": {
+ "windows": [
+ {
+ "maximizable": true,
+ "label": "main",
+ "title": "Chad",
+ "width": 800,
+ "height": 600,
+ "minWidth": 800,
+ "minHeight": 600,
+ "resizable": true,
+ "fullscreen": false,
+ "center": true,
+ "theme": "Dark",
+ "additionalBrowserArgs": "--disable-features=msWebOOUI,msPdfOOUI,msSmartScreenProtection --autoplay-policy=no-user-gesture-required --lang=en",
+ "incognito": false
+ }
+ ],
+ "security": {
+ "csp": null,
+ "capabilities": []
+ }
+ },
+ "bundle": {
+ "createUpdaterArtifacts": true,
+ "active": true,
+ "targets": ["nsis"],
+ "icon": [
+ "icons/32x32.png",
+ "icons/128x128.png",
+ "icons/128x128@2x.png",
+ "icons/icon.icns",
+ "icons/icon.ico"
+ ],
+ "windows": {
+ "nsis": {
+ "installerIcon": "icons/icon.ico"
+ }
+ }
+ },
+ "plugins": {
+ "updater": {
+ "pubkey": "dW50cnVzdGVkIGNvbW1lbnQ6IG1pbmlzaWduIHB1YmxpYyBrZXk6IEU3MzkxMzM3RkQ3NTg4QUQKUldTdGlIWDlOeE01NStIak9VbmZTTm9HY2NyNUQrVXB5ZEdIN1BkK2lhYW9zWkNCQnZQSjRmelIK",
+ "endpoints": [
+ "https://git.koptilnya.xyz/opti1337/chad/releases/download/latest/updater.json"
+ ]
+ }
+ }
+}
diff --git a/new-client/src/app/App.vue b/new-client/src/app/App.vue
new file mode 100644
index 0000000..dd6b837
--- /dev/null
+++ b/new-client/src/app/App.vue
@@ -0,0 +1,20 @@
+
+
+
+
+
+
+
+
+
diff --git a/new-client/src/app/Error.vue b/new-client/src/app/Error.vue
new file mode 100644
index 0000000..ef06c66
--- /dev/null
+++ b/new-client/src/app/Error.vue
@@ -0,0 +1,35 @@
+
+
+

+
+
+ {{ message }}
+
+
+
+
+
+
+
diff --git a/new-client/src/app/Preloader.vue b/new-client/src/app/Preloader.vue
new file mode 100644
index 0000000..4a7dd6d
--- /dev/null
+++ b/new-client/src/app/Preloader.vue
@@ -0,0 +1,25 @@
+
+
+
+
+
+
+
diff --git a/new-client/src/app/Updater.vue b/new-client/src/app/Updater.vue
new file mode 100644
index 0000000..875539d
--- /dev/null
+++ b/new-client/src/app/Updater.vue
@@ -0,0 +1,30 @@
+
+
+
+ Checking updates...
+
+
+ Update available: {{ lastUpdate.version }}
+
+
+
+
+
+
+
diff --git a/new-client/src/app/bootstrap/app.ts b/new-client/src/app/bootstrap/app.ts
new file mode 100644
index 0000000..80d4b7a
--- /dev/null
+++ b/new-client/src/app/bootstrap/app.ts
@@ -0,0 +1,21 @@
+import { useAuth } from '@shared/composables/use-auth'
+import { createApp } from 'vue'
+import App from '../App.vue'
+import routerPlugin, { router } from '../plugins/router'
+
+const mountPoint = '#app'
+
+export default async function () {
+ const { authorized } = useAuth()
+ const app = createApp(App)
+
+ app.use(routerPlugin)
+
+ await router.isReady()
+
+ if (!authorized.value && router.currentRoute.value.meta.auth === undefined) {
+ router.push('/auth/login')
+ }
+
+ app.mount(mountPoint)
+}
diff --git a/new-client/src/app/bootstrap/authorize.ts b/new-client/src/app/bootstrap/authorize.ts
new file mode 100644
index 0000000..10f98f8
--- /dev/null
+++ b/new-client/src/app/bootstrap/authorize.ts
@@ -0,0 +1,17 @@
+import api from '@shared/api/client'
+import { useAuth } from '@shared/composables/use-auth'
+
+export default async function () {
+ const { setMe } = useAuth()
+
+ try {
+ const response = await api.chad.authMe()
+
+ setMe(response.data)
+ }
+ catch (error) {
+ if (error.error?.statusCode !== 401) {
+ throw new Error('Authorization failed')
+ }
+ }
+}
diff --git a/new-client/src/app/bootstrap/error.ts b/new-client/src/app/bootstrap/error.ts
new file mode 100644
index 0000000..e7c8f20
--- /dev/null
+++ b/new-client/src/app/bootstrap/error.ts
@@ -0,0 +1,10 @@
+import { createApp } from 'vue'
+import Error from '../Error.vue'
+
+const mountPoint = '#app'
+
+export default async function (message: string) {
+ const app = createApp(Error, { message })
+
+ app.mount(mountPoint)
+}
diff --git a/new-client/src/app/bootstrap/preloader.ts b/new-client/src/app/bootstrap/preloader.ts
new file mode 100644
index 0000000..c97bcd5
--- /dev/null
+++ b/new-client/src/app/bootstrap/preloader.ts
@@ -0,0 +1,19 @@
+import type { App } from 'vue'
+import { createApp } from 'vue'
+import Preloader from '../Preloader.vue'
+
+const mountPoint = '#preloader'
+
+let preloaderApp: App | undefined
+
+export default {
+ show() {
+ preloaderApp = createApp(Preloader)
+
+ preloaderApp.mount(mountPoint)
+ },
+ hide() {
+ preloaderApp?.unmount()
+ preloaderApp = undefined
+ },
+}
diff --git a/new-client/src/app/bootstrap/updater.ts b/new-client/src/app/bootstrap/updater.ts
new file mode 100644
index 0000000..e37a465
--- /dev/null
+++ b/new-client/src/app/bootstrap/updater.ts
@@ -0,0 +1,23 @@
+import { createApp } from 'vue'
+import { useUpdater } from '@/shared/composables/use-updater'
+import Updater from '../Updater.vue'
+
+const mountPoint = '#updater'
+
+export default async function () {
+ const { lastUpdate, checkForUpdates } = useUpdater()
+
+ const updater = createApp(Updater)
+
+ updater.mount(mountPoint)
+
+ await checkForUpdates()
+
+ if (!lastUpdate.value) {
+ updater.unmount()
+
+ return
+ }
+
+ await lastUpdate.value.downloadAndInstall()
+}
diff --git a/new-client/src/app/entry.ts b/new-client/src/app/entry.ts
new file mode 100644
index 0000000..c773193
--- /dev/null
+++ b/new-client/src/app/entry.ts
@@ -0,0 +1,30 @@
+import initializeApp from './bootstrap/app'
+import authorize from './bootstrap/authorize'
+import showError from './bootstrap/error'
+import preloader from './bootstrap/preloader'
+import checkUpdates from './bootstrap/updater'
+
+(async () => {
+ try {
+ await checkUpdates()
+
+ preloader.show()
+
+ await authorize()
+
+ initializeApp()
+ }
+ catch (error) {
+ console.error(error)
+
+ if (error instanceof Error && error.message) {
+ showError(error.message)
+ }
+ else {
+ showError('Something went wrong')
+ }
+ }
+ finally {
+ preloader.hide()
+ }
+})()
diff --git a/new-client/src/app/plugins/primevue.ts b/new-client/src/app/plugins/primevue.ts
new file mode 100644
index 0000000..3e727bb
--- /dev/null
+++ b/new-client/src/app/plugins/primevue.ts
@@ -0,0 +1,11 @@
+import type { PrimeVueConfiguration } from 'primevue/config'
+import type { FunctionPlugin, Plugin } from 'vue'
+import PrimeVue from 'primevue/config'
+
+export default {
+ install(app) {
+ app.use(PrimeVue as Plugin, {
+ unstyled: true,
+ })
+ },
+} as FunctionPlugin
diff --git a/new-client/src/app/plugins/router.ts b/new-client/src/app/plugins/router.ts
new file mode 100644
index 0000000..6a38f6f
--- /dev/null
+++ b/new-client/src/app/plugins/router.ts
@@ -0,0 +1,21 @@
+import type { Component, FunctionPlugin } from 'vue'
+import { createRouter, createWebHistory } from 'vue-router'
+import { routes } from 'vue-router/auto-routes'
+
+declare module 'vue-router' {
+ interface RouteMeta {
+ layout?: Component
+ auth?: false | 'guest'
+ }
+}
+
+export const router = createRouter({
+ history: createWebHistory(),
+ routes,
+})
+
+export default {
+ install(app) {
+ app.use(router)
+ },
+} as FunctionPlugin
diff --git a/new-client/src/pages/auth.vue b/new-client/src/pages/auth.vue
new file mode 100644
index 0000000..092fa96
--- /dev/null
+++ b/new-client/src/pages/auth.vue
@@ -0,0 +1,14 @@
+
+
+
+
+
diff --git a/new-client/src/pages/auth/login.vue b/new-client/src/pages/auth/login.vue
new file mode 100644
index 0000000..4f23ef8
--- /dev/null
+++ b/new-client/src/pages/auth/login.vue
@@ -0,0 +1,35 @@
+
+
+
+
+
+
+
diff --git a/new-client/src/pages/auth/register.vue b/new-client/src/pages/auth/register.vue
new file mode 100644
index 0000000..b436366
--- /dev/null
+++ b/new-client/src/pages/auth/register.vue
@@ -0,0 +1,6 @@
+
+ Register page
+
+
+
diff --git a/new-client/src/pages/index.vue b/new-client/src/pages/index.vue
new file mode 100644
index 0000000..e84d75b
--- /dev/null
+++ b/new-client/src/pages/index.vue
@@ -0,0 +1,5 @@
+
+ Index page
+
+
+
diff --git a/new-client/src/shared/api/client.ts b/new-client/src/shared/api/client.ts
new file mode 100644
index 0000000..7918e1f
--- /dev/null
+++ b/new-client/src/shared/api/client.ts
@@ -0,0 +1,11 @@
+import { Api } from './generated-chad-api'
+
+const api = new Api({
+ baseUrl: 'http://localhost:4000',
+})
+
+function isChadResponseError(error) {
+
+}
+
+export default api
diff --git a/new-client/src/shared/api/generated-chad-api.ts b/new-client/src/shared/api/generated-chad-api.ts
new file mode 100644
index 0000000..7f4256c
--- /dev/null
+++ b/new-client/src/shared/api/generated-chad-api.ts
@@ -0,0 +1,755 @@
+/* eslint-disable */
+/* tslint:disable */
+// @ts-nocheck
+/*
+ * ---------------------------------------------------------------
+ * ## THIS FILE WAS GENERATED VIA SWAGGER-TYPESCRIPT-API ##
+ * ## ##
+ * ## AUTHOR: acacode ##
+ * ## SOURCE: https://github.com/acacode/swagger-typescript-api ##
+ * ---------------------------------------------------------------
+ */
+
+/**
+ * Attachment
+ * Attachment
+ */
+export interface Attachment {
+ id: string;
+ name: string;
+ mimetype: string;
+ /** @min 0 */
+ size: number;
+ /** @format date-time */
+ createdAt: string;
+}
+
+/**
+ * Channel
+ * Channel
+ */
+export interface Channel {
+ id: string;
+ ownerId: string | null;
+ name: string;
+ persistent: boolean;
+}
+
+/**
+ * ChatMessage
+ * ChatMessage
+ */
+export interface ChatMessage {
+ /** @format uuid */
+ id: string;
+ /** @format uuid */
+ senderId: string;
+ /** @minLength 1 */
+ text: string;
+ /** @format date-time */
+ createdAt: string;
+ /** @format date-time */
+ updatedAt: string;
+ attachments: string[];
+}
+
+/**
+ * CreateChannelPayload
+ * CreateChannelPayload
+ */
+export interface CreateChannelPayload {
+ name: string;
+ persistent: boolean;
+}
+
+/**
+ * CreateUser
+ * CreateUser
+ */
+export interface CreateUser {
+ /** @minLength 1 */
+ username: string;
+ /** @minLength 6 */
+ password: string;
+}
+
+/**
+ * GetAttachmentParams
+ * GetAttachmentParams
+ */
+export interface GetAttachmentParams {
+ /** @format uuid */
+ id: string;
+}
+
+/**
+ * GetUserQuery
+ * GetUserQuery
+ */
+export interface GetUserQuery {
+ username?: string;
+}
+
+/**
+ * Login
+ * Login
+ */
+export interface Login {
+ /** @minLength 1 */
+ username: string;
+ /** @minLength 1 */
+ password: string;
+}
+
+/**
+ * NewChatMessagePayload
+ * NewChatMessagePayload
+ */
+export interface NewChatMessagePayload {
+ /** @minLength 1 */
+ text: string;
+ attachments?: string[];
+}
+
+/**
+ * Reply
+ * Reply
+ */
+export interface Reply {
+ /** @format uuid */
+ messageId: string;
+ /** @format uuid */
+ senderId: string;
+ text: string;
+}
+
+/**
+ * ResponseError
+ * ResponseError
+ */
+export interface ResponseError {
+ statusCode: number;
+ error: string;
+ message: string;
+}
+
+/**
+ * UpdateUserPayload
+ * UpdateUserPayload
+ */
+export interface UpdateUserPayload {
+ displayName: string;
+}
+
+/**
+ * UpdateUserPreferencesPayload
+ * UpdateUserPreferencesPayload
+ */
+export interface UpdateUserPreferencesPayload {
+ toggleInputHotkey?: string;
+ toggleOutputHotkey?: string;
+}
+
+/**
+ * UserPreferences
+ * UserPreferences
+ */
+export interface UserPreferences {
+ toggleInputHotkey: string;
+ toggleOutputHotkey: string;
+}
+
+/**
+ * User
+ * User
+ */
+export interface User {
+ id: string;
+ username: string;
+ displayName: string;
+ /** @format date-time */
+ createdAt: string;
+}
+
+export type QueryParamsType = Record;
+export type ResponseFormat = keyof Omit;
+
+export interface FullRequestParams extends Omit {
+ /** set parameter to `true` for call `securityWorker` for this request */
+ secure?: boolean;
+ /** request path */
+ path: string;
+ /** content type of request body */
+ type?: ContentType;
+ /** query params */
+ query?: QueryParamsType;
+ /** format of response (i.e. response.json() -> format: "json") */
+ format?: ResponseFormat;
+ /** request body */
+ body?: unknown;
+ /** base url */
+ baseUrl?: string;
+ /** request cancellation token */
+ cancelToken?: CancelToken;
+}
+
+export type RequestParams = Omit<
+ FullRequestParams,
+ "body" | "method" | "query" | "path"
+>;
+
+export interface ApiConfig {
+ baseUrl?: string;
+ baseApiParams?: Omit;
+ securityWorker?: (
+ securityData: SecurityDataType | null,
+ ) => Promise | RequestParams | void;
+ customFetch?: typeof fetch;
+}
+
+export interface HttpResponse
+ extends Response {
+ data: D;
+ error: E;
+}
+
+type CancelToken = Symbol | string | number;
+
+export enum ContentType {
+ Json = "application/json",
+ JsonApi = "application/vnd.api+json",
+ FormData = "multipart/form-data",
+ UrlEncoded = "application/x-www-form-urlencoded",
+ Text = "text/plain",
+}
+
+export class HttpClient {
+ public baseUrl: string = "";
+ private securityData: SecurityDataType | null = null;
+ private securityWorker?: ApiConfig["securityWorker"];
+ private abortControllers = new Map();
+ private customFetch = (...fetchParams: Parameters) =>
+ fetch(...fetchParams);
+
+ private baseApiParams: RequestParams = {
+ credentials: "same-origin",
+ headers: {},
+ redirect: "follow",
+ referrerPolicy: "no-referrer",
+ };
+
+ constructor(apiConfig: ApiConfig = {}) {
+ Object.assign(this, apiConfig);
+ }
+
+ public setSecurityData = (data: SecurityDataType | null) => {
+ this.securityData = data;
+ };
+
+ protected encodeQueryParam(key: string, value: any) {
+ const encodedKey = encodeURIComponent(key);
+ return `${encodedKey}=${encodeURIComponent(typeof value === "number" ? value : `${value}`)}`;
+ }
+
+ protected addQueryParam(query: QueryParamsType, key: string) {
+ return this.encodeQueryParam(key, query[key]);
+ }
+
+ protected addArrayQueryParam(query: QueryParamsType, key: string) {
+ const value = query[key];
+ return value.map((v: any) => this.encodeQueryParam(key, v)).join("&");
+ }
+
+ protected toQueryString(rawQuery?: QueryParamsType): string {
+ const query = rawQuery || {};
+ const keys = Object.keys(query).filter(
+ (key) => "undefined" !== typeof query[key],
+ );
+ return keys
+ .map((key) =>
+ Array.isArray(query[key])
+ ? this.addArrayQueryParam(query, key)
+ : this.addQueryParam(query, key),
+ )
+ .join("&");
+ }
+
+ protected addQueryParams(rawQuery?: QueryParamsType): string {
+ const queryString = this.toQueryString(rawQuery);
+ return queryString ? `?${queryString}` : "";
+ }
+
+ private contentFormatters: Record any> = {
+ [ContentType.Json]: (input: any) =>
+ input !== null && (typeof input === "object" || typeof input === "string")
+ ? JSON.stringify(input)
+ : input,
+ [ContentType.JsonApi]: (input: any) =>
+ input !== null && (typeof input === "object" || typeof input === "string")
+ ? JSON.stringify(input)
+ : input,
+ [ContentType.Text]: (input: any) =>
+ input !== null && typeof input !== "string"
+ ? JSON.stringify(input)
+ : input,
+ [ContentType.FormData]: (input: any) => {
+ if (input instanceof FormData) {
+ return input;
+ }
+
+ return Object.keys(input || {}).reduce((formData, key) => {
+ const property = input[key];
+ formData.append(
+ key,
+ property instanceof Blob
+ ? property
+ : typeof property === "object" && property !== null
+ ? JSON.stringify(property)
+ : `${property}`,
+ );
+ return formData;
+ }, new FormData());
+ },
+ [ContentType.UrlEncoded]: (input: any) => this.toQueryString(input),
+ };
+
+ protected mergeRequestParams(
+ params1: RequestParams,
+ params2?: RequestParams,
+ ): RequestParams {
+ return {
+ ...this.baseApiParams,
+ ...params1,
+ ...(params2 || {}),
+ headers: {
+ ...(this.baseApiParams.headers || {}),
+ ...(params1.headers || {}),
+ ...((params2 && params2.headers) || {}),
+ },
+ };
+ }
+
+ protected createAbortSignal = (
+ cancelToken: CancelToken,
+ ): AbortSignal | undefined => {
+ if (this.abortControllers.has(cancelToken)) {
+ const abortController = this.abortControllers.get(cancelToken);
+ if (abortController) {
+ return abortController.signal;
+ }
+ return void 0;
+ }
+
+ const abortController = new AbortController();
+ this.abortControllers.set(cancelToken, abortController);
+ return abortController.signal;
+ };
+
+ public abortRequest = (cancelToken: CancelToken) => {
+ const abortController = this.abortControllers.get(cancelToken);
+
+ if (abortController) {
+ abortController.abort();
+ this.abortControllers.delete(cancelToken);
+ }
+ };
+
+ public request = async ({
+ body,
+ secure,
+ path,
+ type,
+ query,
+ format,
+ baseUrl,
+ cancelToken,
+ ...params
+ }: FullRequestParams): Promise> => {
+ const secureParams =
+ ((typeof secure === "boolean" ? secure : this.baseApiParams.secure) &&
+ this.securityWorker &&
+ (await this.securityWorker(this.securityData))) ||
+ {};
+ const requestParams = this.mergeRequestParams(params, secureParams);
+ const queryString = query && this.toQueryString(query);
+ const payloadFormatter = this.contentFormatters[type || ContentType.Json];
+ const responseFormat = format || requestParams.format;
+
+ return this.customFetch(
+ `${baseUrl || this.baseUrl || ""}${path}${queryString ? `?${queryString}` : ""}`,
+ {
+ ...requestParams,
+ headers: {
+ ...(requestParams.headers || {}),
+ ...(type && type !== ContentType.FormData
+ ? { "Content-Type": type }
+ : {}),
+ },
+ signal:
+ (cancelToken
+ ? this.createAbortSignal(cancelToken)
+ : requestParams.signal) || null,
+ body:
+ typeof body === "undefined" || body === null
+ ? null
+ : payloadFormatter(body),
+ },
+ ).then(async (response) => {
+ const r = response as HttpResponse;
+ r.data = null as unknown as T;
+ r.error = null as unknown as E;
+
+ const responseToParse = responseFormat ? response.clone() : response;
+ const data = !responseFormat
+ ? r
+ : await responseToParse[responseFormat]()
+ .then((data) => {
+ if (r.ok) {
+ r.data = data;
+ } else {
+ r.error = data;
+ }
+ return r;
+ })
+ .catch((e) => {
+ r.error = e;
+ return r;
+ });
+
+ if (cancelToken) {
+ this.abortControllers.delete(cancelToken);
+ }
+
+ if (!response.ok) throw data;
+ return data;
+ });
+ };
+}
+
+/**
+ * @title Chad API
+ * @version 1.0.0
+ */
+export class Api<
+ SecurityDataType extends unknown,
+> extends HttpClient {
+ chad = {
+ /**
+ * @description Pass file to multipart/form-data
+ *
+ * @tags Attachment
+ * @name AttachmentUpload
+ * @summary Upload attachment
+ * @request POST:/chad/attachment/upload
+ */
+ attachmentUpload: (params: RequestParams = {}) =>
+ this.request({
+ path: `/chad/attachment/upload`,
+ method: "POST",
+ format: "json",
+ ...params,
+ }),
+
+ /**
+ * No description
+ *
+ * @tags Attachment
+ * @name AttachmentGet
+ * @summary Get attachment
+ * @request GET:/chad/attachment/{id}
+ */
+ attachmentGet: (id: string, params: RequestParams = {}) =>
+ this.request({
+ path: `/chad/attachment/${id}`,
+ method: "GET",
+ format: "json",
+ ...params,
+ }),
+
+ /**
+ * No description
+ *
+ * @tags Auth
+ * @name AuthRegister
+ * @summary Register
+ * @request POST:/chad/auth/register
+ */
+ authRegister: (data: CreateUser, params: RequestParams = {}) =>
+ this.request({
+ path: `/chad/auth/register`,
+ method: "POST",
+ body: data,
+ type: ContentType.Json,
+ format: "json",
+ ...params,
+ }),
+
+ /**
+ * No description
+ *
+ * @tags Auth
+ * @name AuthLogin
+ * @summary Login
+ * @request POST:/chad/auth/login
+ */
+ authLogin: (data: Login, params: RequestParams = {}) =>
+ this.request({
+ path: `/chad/auth/login`,
+ method: "POST",
+ body: data,
+ type: ContentType.Json,
+ format: "json",
+ ...params,
+ }),
+
+ /**
+ * No description
+ *
+ * @tags Auth
+ * @name AuthMe
+ * @summary Me
+ * @request GET:/chad/auth/me
+ */
+ authMe: (params: RequestParams = {}) =>
+ this.request({
+ path: `/chad/auth/me`,
+ method: "GET",
+ format: "json",
+ ...params,
+ }),
+
+ /**
+ * No description
+ *
+ * @tags Auth
+ * @name AuthLogout
+ * @summary Logout
+ * @request POST:/chad/auth/logout
+ */
+ authLogout: (params: RequestParams = {}) =>
+ this.request({
+ path: `/chad/auth/logout`,
+ method: "POST",
+ ...params,
+ }),
+
+ /**
+ * No description
+ *
+ * @tags Channel
+ * @name ChannelList
+ * @summary Get channel list
+ * @request GET:/chad/channels
+ */
+ channelList: (params: RequestParams = {}) =>
+ this.request({
+ path: `/chad/channels`,
+ method: "GET",
+ format: "json",
+ ...params,
+ }),
+
+ /**
+ * No description
+ *
+ * @tags Channel
+ * @name ChannelCreate
+ * @summary Create channel
+ * @request POST:/chad/channels
+ */
+ channelCreate: (data: CreateChannelPayload, params: RequestParams = {}) =>
+ this.request({
+ path: `/chad/channels`,
+ method: "POST",
+ body: data,
+ type: ContentType.Json,
+ format: "json",
+ ...params,
+ }),
+
+ /**
+ * No description
+ *
+ * @tags Channel
+ * @name ChannelDelete
+ * @summary Delete channel
+ * @request DELETE:/chad/channels/{id}
+ */
+ channelDelete: (id: string, params: RequestParams = {}) =>
+ this.request({
+ path: `/chad/channels/${id}`,
+ method: "DELETE",
+ ...params,
+ }),
+
+ /**
+ * No description
+ *
+ * @tags Chat
+ * @name ChatSend
+ * @summary Send message
+ * @request POST:/chad/chat/send
+ */
+ chatSend: (
+ data: {
+ /** @minLength 1 */
+ text: string;
+ attachments?: string[];
+ },
+ params: RequestParams = {},
+ ) =>
+ this.request<
+ {
+ /** @format uuid */
+ id: string;
+ /** @format uuid */
+ senderId: string;
+ /** @minLength 1 */
+ text: string;
+ /** @format date-time */
+ createdAt: string;
+ /** @format date-time */
+ updatedAt: string;
+ attachments: string[];
+ },
+ ResponseError
+ >({
+ path: `/chad/chat/send`,
+ method: "POST",
+ body: data,
+ type: ContentType.Json,
+ format: "json",
+ ...params,
+ }),
+
+ /**
+ * No description
+ *
+ * @tags Chat
+ * @name ChatMessages
+ * @summary Get messages
+ * @request GET:/chad/chat
+ */
+ chatMessages: (
+ query: {
+ /**
+ * Cursor to message
+ * @format uuid
+ */
+ cursor?: string;
+ /**
+ * @min 1
+ * @max 100
+ * @default 10
+ */
+ limit: number;
+ },
+ params: RequestParams = {},
+ ) =>
+ this.request<
+ {
+ messages: {
+ /** @format uuid */
+ id: string;
+ /** @format uuid */
+ senderId: string;
+ /** @minLength 1 */
+ text: string;
+ /** @format date-time */
+ createdAt: string;
+ /** @format date-time */
+ updatedAt: string;
+ attachments: string[];
+ }[];
+ /**
+ * Cursor to last message
+ * @format uuid
+ */
+ nextCursor?: string;
+ },
+ ResponseError
+ >({
+ path: `/chad/chat`,
+ method: "GET",
+ query: query,
+ format: "json",
+ ...params,
+ }),
+
+ /**
+ * No description
+ *
+ * @tags User
+ * @name UserGet
+ * @summary Get user
+ * @request GET:/chad/user
+ */
+ userGet: (
+ query?: {
+ username?: string;
+ },
+ params: RequestParams = {},
+ ) =>
+ this.request({
+ path: `/chad/user`,
+ method: "GET",
+ query: query,
+ format: "json",
+ ...params,
+ }),
+
+ /**
+ * No description
+ *
+ * @tags User
+ * @name UserGetPreferences
+ * @summary Get preferences
+ * @request GET:/chad/user/preferences
+ */
+ userGetPreferences: (params: RequestParams = {}) =>
+ this.request({
+ path: `/chad/user/preferences`,
+ method: "GET",
+ format: "json",
+ ...params,
+ }),
+
+ /**
+ * No description
+ *
+ * @tags User
+ * @name UserUpdatePreferences
+ * @summary Update preferences
+ * @request PATCH:/chad/user/preferences
+ */
+ userUpdatePreferences: (
+ data: UpdateUserPreferencesPayload,
+ params: RequestParams = {},
+ ) =>
+ this.request({
+ path: `/chad/user/preferences`,
+ method: "PATCH",
+ body: data,
+ type: ContentType.Json,
+ ...params,
+ }),
+
+ /**
+ * No description
+ *
+ * @tags User
+ * @name UserUpdateProfile
+ * @summary Update profile
+ * @request PATCH:/chad/profile
+ */
+ userUpdateProfile: (data: UpdateUserPayload, params: RequestParams = {}) =>
+ this.request({
+ path: `/chad/profile`,
+ method: "PATCH",
+ body: data,
+ type: ContentType.Json,
+ format: "json",
+ ...params,
+ }),
+ };
+}
diff --git a/new-client/src/shared/components/AppLogo.vue b/new-client/src/shared/components/AppLogo.vue
new file mode 100644
index 0000000..4615f70
--- /dev/null
+++ b/new-client/src/shared/components/AppLogo.vue
@@ -0,0 +1,31 @@
+
+
+
+ Chad
+
+
+ {{ version }}
+
+
+
+
+
+
+
diff --git a/new-client/src/shared/components/ui/Button.vue b/new-client/src/shared/components/ui/Button.vue
new file mode 100644
index 0000000..32c100d
--- /dev/null
+++ b/new-client/src/shared/components/ui/Button.vue
@@ -0,0 +1,59 @@
+
+
+
+
+
+
+
diff --git a/new-client/src/shared/components/ui/Input.vue b/new-client/src/shared/components/ui/Input.vue
new file mode 100644
index 0000000..a23fd8f
--- /dev/null
+++ b/new-client/src/shared/components/ui/Input.vue
@@ -0,0 +1,111 @@
+
+
+
+ {{ label }}
+
+
+
+
+
+
+
+ {{ helper }}
+
+
+ {{ error }}
+
+
+
+
+
+
+
diff --git a/new-client/src/shared/components/ui/PasswordInput.vue b/new-client/src/shared/components/ui/PasswordInput.vue
new file mode 100644
index 0000000..a672572
--- /dev/null
+++ b/new-client/src/shared/components/ui/PasswordInput.vue
@@ -0,0 +1,126 @@
+
+
+
+ {{ label }}
+
+
+
+
+
+
+
+ Z
+
+ X
+
+
+
+
+
+
+
+ {{ helper }}
+
+
+ {{ error }}
+
+
+
+
+
+
+
diff --git a/new-client/src/shared/composables/use-app.ts b/new-client/src/shared/composables/use-app.ts
new file mode 100644
index 0000000..ec98b34
--- /dev/null
+++ b/new-client/src/shared/composables/use-app.ts
@@ -0,0 +1,25 @@
+import { getVersion as getTauriVersion } from '@tauri-apps/api/app'
+import { computedAsync } from '@vueuse/core'
+
+export function useApp() {
+ const isTauri = '__TAURI_INTERNALS__' in window
+ const commitSha = __COMMIT_SHA__
+
+ const version = computedAsync(() => {
+ if (import.meta.dev) {
+ return 'dev'
+ }
+ else if (isTauri) {
+ return getTauriVersion()
+ }
+ else {
+ return 'web'
+ }
+ }, '-')
+
+ return {
+ isTauri,
+ commitSha,
+ version,
+ }
+}
diff --git a/new-client/src/shared/composables/use-auth.ts b/new-client/src/shared/composables/use-auth.ts
new file mode 100644
index 0000000..d7b0182
--- /dev/null
+++ b/new-client/src/shared/composables/use-auth.ts
@@ -0,0 +1,58 @@
+import type { User } from '../api/generated-chad-api'
+import { createGlobalState } from '@vueuse/core'
+import { computed, readonly, shallowRef } from 'vue'
+import api from '../api/client'
+
+export const useAuth = createGlobalState(() => {
+ const me = shallowRef()
+
+ const authorized = computed(() => !!me.value)
+
+ function setMe(value: User | undefined): void {
+ me.value = value
+ }
+
+ async function login(username: string, password: string): Promise {
+ try {
+ const response = await api.chad.authLogin({
+ username,
+ password,
+ })
+
+ setMe(response.data)
+ }
+ catch {
+ setMe(undefined)
+ }
+ }
+
+ async function register(username: string, password: string): Promise {
+ try {
+ const response = await api.chad.authRegister({
+ username,
+ password,
+ })
+
+ setMe(response.data)
+ }
+ catch {}
+ }
+
+ async function logout(): Promise {
+ try {
+ await api.chad.authLogout()
+
+ setMe(undefined)
+ }
+ catch {}
+ }
+
+ return {
+ authorized,
+ me: readonly(me),
+ setMe,
+ login,
+ register,
+ logout,
+ }
+})
diff --git a/new-client/src/shared/composables/use-updater.ts b/new-client/src/shared/composables/use-updater.ts
new file mode 100644
index 0000000..13d680b
--- /dev/null
+++ b/new-client/src/shared/composables/use-updater.ts
@@ -0,0 +1,38 @@
+import type { Update } from '@tauri-apps/plugin-updater'
+import { check } from '@tauri-apps/plugin-updater'
+import { createGlobalState } from '@vueuse/core'
+import { ref, shallowRef } from 'vue'
+import { useApp } from './use-app'
+
+export const useUpdater = createGlobalState(() => {
+ const { isTauri } = useApp()
+
+ const lastUpdate = shallowRef()
+
+ const checking = ref(false)
+
+ async function checkForUpdates() {
+ if (!isTauri)
+ return
+
+ try {
+ checking.value = true
+
+ await new Promise(resolve => setTimeout(resolve, 500))
+
+ lastUpdate.value = (await check()) ?? undefined
+ }
+ catch { }
+ finally {
+ checking.value = false
+ }
+
+ return lastUpdate.value
+ }
+
+ return {
+ lastUpdate,
+ checking,
+ checkForUpdates,
+ }
+})
diff --git a/new-client/src/shared/globals.d.ts b/new-client/src/shared/globals.d.ts
new file mode 100644
index 0000000..90c9d01
--- /dev/null
+++ b/new-client/src/shared/globals.d.ts
@@ -0,0 +1,2 @@
+declare const __API_BASE_URL__: string
+declare const __COMMIT_SHA__: string
diff --git a/new-client/src/shared/layouts/Auth.vue b/new-client/src/shared/layouts/Auth.vue
new file mode 100644
index 0000000..eaedcbe
--- /dev/null
+++ b/new-client/src/shared/layouts/Auth.vue
@@ -0,0 +1,44 @@
+
+
+
+
+
+
+
diff --git a/new-client/src/shared/layouts/Default.vue b/new-client/src/shared/layouts/Default.vue
new file mode 100644
index 0000000..eae6993
--- /dev/null
+++ b/new-client/src/shared/layouts/Default.vue
@@ -0,0 +1,82 @@
+
+
+
+
+
+
+
diff --git a/new-client/src/shared/styles/main.scss b/new-client/src/shared/styles/main.scss
new file mode 100644
index 0000000..8031a69
--- /dev/null
+++ b/new-client/src/shared/styles/main.scss
@@ -0,0 +1,29 @@
+@use 'tokens.scss';
+
+html,
+body,
+[data-mount-point]:not(:empty) {
+ height: 100%;
+}
+
+[data-mount-point]:empty {
+ display: none;
+}
+
+body {
+ background-color: var(--bg-dark);
+ color: var(--text);
+ height: 100%;
+}
+
+*,
+*::before,
+*::after {
+ font-family: 'Inter', sans-serif;
+ font-optical-sizing: auto;
+ font-weight: 400;
+ font-style: normal;
+ font-variation-settings:
+ 'wdth' 100,
+ 'YTLC' 500;
+}
diff --git a/new-client/src/shared/styles/reset.css b/new-client/src/shared/styles/reset.css
new file mode 100644
index 0000000..f76f6d0
--- /dev/null
+++ b/new-client/src/shared/styles/reset.css
@@ -0,0 +1,128 @@
+/* http://meyerweb.com/eric/tools/css/reset/
+ v2.0 | 20110126
+ License: none (public domain)
+*/
+
+html,
+body,
+div,
+span,
+applet,
+object,
+iframe,
+h1,
+h2,
+h3,
+h4,
+h5,
+h6,
+p,
+blockquote,
+pre,
+a,
+abbr,
+acronym,
+address,
+big,
+cite,
+code,
+del,
+dfn,
+em,
+img,
+ins,
+kbd,
+q,
+s,
+samp,
+small,
+strike,
+strong,
+sub,
+sup,
+tt,
+var,
+b,
+u,
+i,
+center,
+dl,
+dt,
+dd,
+ol,
+ul,
+li,
+fieldset,
+form,
+label,
+legend,
+table,
+caption,
+tbody,
+tfoot,
+thead,
+tr,
+th,
+td,
+article,
+aside,
+canvas,
+details,
+embed,
+figure,
+figcaption,
+footer,
+header,
+hgroup,
+menu,
+nav,
+output,
+ruby,
+section,
+summary,
+time,
+mark,
+audio,
+video {
+ margin: 0;
+ padding: 0;
+ border: 0;
+ font-size: 100%;
+ vertical-align: baseline;
+}
+/* HTML5 display-role reset for older browsers */
+article,
+aside,
+details,
+figcaption,
+figure,
+footer,
+header,
+hgroup,
+menu,
+nav,
+section {
+ display: block;
+}
+body {
+ line-height: 1;
+}
+ol,
+ul {
+ list-style: none;
+}
+blockquote,
+q {
+ quotes: none;
+}
+blockquote:before,
+blockquote:after,
+q:before,
+q:after {
+ content: '';
+ content: none;
+}
+table {
+ border-collapse: collapse;
+ border-spacing: 0;
+}
diff --git a/new-client/src/shared/styles/sanitize.css b/new-client/src/shared/styles/sanitize.css
new file mode 100644
index 0000000..acb1d71
--- /dev/null
+++ b/new-client/src/shared/styles/sanitize.css
@@ -0,0 +1,566 @@
+/* Document
+ * ========================================================================== */
+
+/**
+ * Add border box sizing in all browsers (opinionated).
+ */
+
+*,
+::before,
+::after {
+ box-sizing: border-box;
+}
+
+/**
+ * 1. Add text decoration inheritance in all browsers (opinionated).
+ * 2. Add vertical alignment inheritance in all browsers (opinionated).
+ */
+
+::before,
+::after {
+ text-decoration: inherit; /* 1 */
+ vertical-align: inherit; /* 2 */
+}
+
+/**
+ * 1. Use the default cursor in all browsers (opinionated).
+ * 2. Change the line height in all browsers (opinionated).
+ * 3. Use a 4-space tab width in all browsers (opinionated).
+ * 4. Remove the grey highlight on links in iOS (opinionated).
+ * 5. Prevent adjustments of font size after orientation changes in
+ * IE on Windows Phone and in iOS.
+ * 6. Breaks words to prevent overflow in all browsers (opinionated).
+ */
+
+html {
+ cursor: default; /* 1 */
+ line-height: 1.5; /* 2 */
+ -moz-tab-size: 4; /* 3 */
+ tab-size: 4; /* 3 */
+ -webkit-tap-highlight-color: transparent /* 4 */;
+ -ms-text-size-adjust: 100%; /* 5 */
+ -webkit-text-size-adjust: 100%; /* 5 */
+ word-break: break-word; /* 6 */
+}
+
+/* Sections
+ * ========================================================================== */
+
+/**
+ * Remove the margin in all browsers (opinionated).
+ */
+
+body {
+ margin: 0;
+}
+
+/**
+ * Correct the font size and margin on `h1` elements within `section` and
+ * `article` contexts in Chrome, Edge, Firefox, and Safari.
+ */
+
+h1 {
+ font-size: 2em;
+ margin: 0.67em 0;
+}
+
+/* Grouping content
+ * ========================================================================== */
+
+/**
+ * Remove the margin on nested lists in Chrome, Edge, IE, and Safari.
+ */
+
+dl dl,
+dl ol,
+dl ul,
+ol dl,
+ul dl {
+ margin: 0;
+}
+
+/**
+ * Remove the margin on nested lists in Edge 18- and IE.
+ */
+
+ol ol,
+ol ul,
+ul ol,
+ul ul {
+ margin: 0;
+}
+
+/**
+ * 1. Add the correct sizing in Firefox.
+ * 2. Show the overflow in Edge 18- and IE.
+ */
+
+hr {
+ height: 0; /* 1 */
+ overflow: visible; /* 2 */
+}
+
+/**
+ * Add the correct display in IE.
+ */
+
+main {
+ display: block;
+}
+
+/**
+ * Remove the list style on navigation lists in all browsers (opinionated).
+ */
+
+nav ol,
+nav ul {
+ list-style: none;
+ padding: 0;
+}
+
+/**
+ * 1. Correct the inheritance and scaling of font size in all browsers.
+ * 2. Correct the odd `em` font sizing in all browsers.
+ */
+
+pre {
+ font-family: monospace, monospace; /* 1 */
+ font-size: 1em; /* 2 */
+}
+
+/* Text-level semantics
+ * ========================================================================== */
+
+/**
+ * Remove the gray background on active links in IE 10.
+ */
+
+a {
+ background-color: transparent;
+}
+
+/**
+ * Add the correct text decoration in Edge 18-, IE, and Safari.
+ */
+
+abbr[title] {
+ text-decoration: underline;
+ text-decoration: underline dotted;
+}
+
+/**
+ * Add the correct font weight in Chrome, Edge, and Safari.
+ */
+
+b,
+strong {
+ font-weight: bolder;
+}
+
+/**
+ * 1. Correct the inheritance and scaling of font size in all browsers.
+ * 2. Correct the odd `em` font sizing in all browsers.
+ */
+
+code,
+kbd,
+samp {
+ font-family: monospace, monospace; /* 1 */
+ font-size: 1em; /* 2 */
+}
+
+/**
+ * Add the correct font size in all browsers.
+ */
+
+small {
+ font-size: 80%;
+}
+
+/* Embedded content
+ * ========================================================================== */
+
+/*
+ * Change the alignment on media elements in all browsers (opinionated).
+ */
+
+audio,
+canvas,
+iframe,
+img,
+svg,
+video {
+ vertical-align: middle;
+}
+
+/**
+ * Add the correct display in IE 9-.
+ */
+
+audio,
+video {
+ display: inline-block;
+}
+
+/**
+ * Add the correct display in iOS 4-7.
+ */
+
+audio:not([controls]) {
+ display: none;
+ height: 0;
+}
+
+/**
+ * Remove the border on iframes in all browsers (opinionated).
+ */
+
+iframe {
+ border-style: none;
+}
+
+/**
+ * Remove the border on images within links in IE 10-.
+ */
+
+img {
+ border-style: none;
+}
+
+/**
+ * Change the fill color to match the text color in all browsers (opinionated).
+ */
+
+svg:not([fill]) {
+ fill: currentColor;
+}
+
+/**
+ * Hide the overflow in IE.
+ */
+
+svg:not(:root) {
+ overflow: hidden;
+}
+
+/* Tabular data
+ * ========================================================================== */
+
+/**
+ * Collapse border spacing in all browsers (opinionated).
+ */
+
+table {
+ border-collapse: collapse;
+}
+
+/* Forms
+ * ========================================================================== */
+
+/**
+ * Remove the margin on controls in Safari.
+ */
+
+button,
+input,
+select {
+ margin: 0;
+}
+
+/**
+ * 1. Show the overflow in IE.
+ * 2. Remove the inheritance of text transform in Edge 18-, Firefox, and IE.
+ */
+
+button {
+ overflow: visible; /* 1 */
+ text-transform: none; /* 2 */
+}
+
+/**
+ * Correct the inability to style buttons in iOS and Safari.
+ */
+
+button,
+[type="button"],
+[type="reset"],
+[type="submit"] {
+ -webkit-appearance: button;
+}
+
+/**
+ * 1. Change the inconsistent appearance in all browsers (opinionated).
+ * 2. Correct the padding in Firefox.
+ */
+
+fieldset {
+ border: 1px solid #a0a0a0; /* 1 */
+ padding: 0.35em 0.75em 0.625em; /* 2 */
+}
+
+/**
+ * Show the overflow in Edge 18- and IE.
+ */
+
+input {
+ overflow: visible;
+}
+
+/**
+ * 1. Correct the text wrapping in Edge 18- and IE.
+ * 2. Correct the color inheritance from `fieldset` elements in IE.
+ */
+
+legend {
+ color: inherit; /* 2 */
+ display: table; /* 1 */
+ max-width: 100%; /* 1 */
+ white-space: normal; /* 1 */
+}
+
+/**
+ * 1. Add the correct display in Edge 18- and IE.
+ * 2. Add the correct vertical alignment in Chrome, Edge, and Firefox.
+ */
+
+progress {
+ display: inline-block; /* 1 */
+ vertical-align: baseline; /* 2 */
+}
+
+/**
+ * Remove the inheritance of text transform in Firefox.
+ */
+
+select {
+ text-transform: none;
+}
+
+/**
+ * 1. Remove the margin in Firefox and Safari.
+ * 2. Remove the default vertical scrollbar in IE.
+ * 3. Change the resize direction in all browsers (opinionated).
+ */
+
+textarea {
+ margin: 0; /* 1 */
+ overflow: auto; /* 2 */
+ resize: vertical; /* 3 */
+}
+
+/**
+ * Remove the padding in IE 10-.
+ */
+
+[type="checkbox"],
+[type="radio"] {
+ padding: 0;
+}
+
+/**
+ * 1. Correct the odd appearance in Chrome, Edge, and Safari.
+ * 2. Correct the outline style in Safari.
+ */
+
+[type="search"] {
+ -webkit-appearance: textfield; /* 1 */
+ outline-offset: -2px; /* 2 */
+}
+
+/**
+ * Correct the cursor style of increment and decrement buttons in Safari.
+ */
+
+::-webkit-inner-spin-button,
+::-webkit-outer-spin-button {
+ height: auto;
+}
+
+/**
+ * Correct the text style of placeholders in Chrome, Edge, and Safari.
+ */
+
+::-webkit-input-placeholder {
+ color: inherit;
+ opacity: 0.54;
+}
+
+/**
+ * Remove the inner padding in Chrome, Edge, and Safari on macOS.
+ */
+
+::-webkit-search-decoration {
+ -webkit-appearance: none;
+}
+
+/**
+ * 1. Correct the inability to style upload buttons in iOS and Safari.
+ * 2. Change font properties to `inherit` in Safari.
+ */
+
+::-webkit-file-upload-button {
+ -webkit-appearance: button; /* 1 */
+ font: inherit; /* 2 */
+}
+
+/**
+ * Remove the inner border and padding of focus outlines in Firefox.
+ */
+
+::-moz-focus-inner {
+ border-style: none;
+ padding: 0;
+}
+
+/**
+ * Restore the focus outline styles unset by the previous rule in Firefox.
+ */
+
+:-moz-focusring {
+ outline: 1px dotted ButtonText;
+}
+
+/**
+ * Remove the additional :invalid styles in Firefox.
+ */
+
+:-moz-ui-invalid {
+ box-shadow: none;
+}
+
+/* Interactive
+ * ========================================================================== */
+
+/*
+ * Add the correct display in Edge 18- and IE.
+ */
+
+details {
+ display: block;
+}
+
+/*
+ * Add the correct styles in Edge 18-, IE, and Safari.
+ */
+
+dialog {
+ background-color: white;
+ border: solid;
+ color: black;
+ display: block;
+ height: -moz-fit-content;
+ height: -webkit-fit-content;
+ height: fit-content;
+ left: 0;
+ margin: auto;
+ padding: 1em;
+ position: absolute;
+ right: 0;
+ width: -moz-fit-content;
+ width: -webkit-fit-content;
+ width: fit-content;
+}
+
+dialog:not([open]) {
+ display: none;
+}
+
+/*
+ * Add the correct display in all browsers.
+ */
+
+summary {
+ display: list-item;
+}
+
+/* Scripting
+ * ========================================================================== */
+
+/**
+ * Add the correct display in IE 9-.
+ */
+
+canvas {
+ display: inline-block;
+}
+
+/**
+ * Add the correct display in IE.
+ */
+
+template {
+ display: none;
+}
+
+/* User interaction
+ * ========================================================================== */
+
+/*
+ * 1. Remove the tapping delay in IE 10.
+ * 2. Remove the tapping delay on clickable elements
+ in all browsers (opinionated).
+ */
+
+a,
+area,
+button,
+input,
+label,
+select,
+summary,
+textarea,
+[tabindex] {
+ -ms-touch-action: manipulation; /* 1 */
+ touch-action: manipulation; /* 2 */
+}
+
+/**
+ * Add the correct display in IE 10-.
+ */
+
+[hidden] {
+ display: none;
+}
+
+/* Accessibility
+ * ========================================================================== */
+
+/**
+ * Change the cursor on busy elements in all browsers (opinionated).
+ */
+
+[aria-busy="true"] {
+ cursor: progress;
+}
+
+/*
+ * Change the cursor on control elements in all browsers (opinionated).
+ */
+
+[aria-controls] {
+ cursor: pointer;
+}
+
+/*
+ * Change the cursor on disabled, not-editable, or otherwise
+ * inoperable elements in all browsers (opinionated).
+ */
+
+[aria-disabled="true"],
+[disabled] {
+ cursor: not-allowed;
+}
+
+/*
+ * Change the display on visually hidden accessible elements
+ * in all browsers (opinionated).
+ */
+
+[aria-hidden="false"][hidden] {
+ display: initial;
+}
+
+[aria-hidden="false"][hidden]:not(:focus) {
+ clip: rect(0, 0, 0, 0);
+ position: absolute;
+}
diff --git a/new-client/src/shared/styles/tokens.scss b/new-client/src/shared/styles/tokens.scss
new file mode 100644
index 0000000..17790de
--- /dev/null
+++ b/new-client/src/shared/styles/tokens.scss
@@ -0,0 +1,64 @@
+:root {
+ /* hsl (fallback color) */
+ --bg-dark: hsl(208 100% 2%);
+ --bg: hsl(201 86% 4%);
+ --bg-light: hsl(198 56% 8%);
+ --text: hsl(199 100% 93%);
+ --text-muted: hsl(199 36% 68%);
+ --highlight: hsl(199 28% 37%);
+ --border: hsl(198 40% 26%);
+ --border-muted: hsl(197 70% 15%);
+ --primary: hsl(198 69% 65%);
+ --secondary: hsl(20 68% 69%);
+ --danger: hsl(9 26% 64%);
+ --warning: hsl(52 19% 57%);
+ --success: hsl(146 17% 59%);
+ --info: hsl(217 28% 65%);
+ /* oklch */
+ --bg-dark: oklch(0.1 0.025 228);
+ --bg: oklch(0.15 0.025 228);
+ --bg-light: oklch(0.2 0.025 228);
+ --text: oklch(0.96 0.05 228);
+ --text-muted: oklch(0.76 0.05 228);
+ --highlight: oklch(0.5 0.05 228);
+ --border: oklch(0.4 0.05 228);
+ --border-muted: oklch(0.3 0.05 228);
+ --primary: oklch(0.76 0.1 228);
+ --secondary: oklch(0.76 0.1 48);
+ --danger: oklch(0.7 0.05 30);
+ --warning: oklch(0.7 0.05 100);
+ --success: oklch(0.7 0.05 160);
+ --info: oklch(0.7 0.05 260);
+}
+[data-theme="light"] {
+ /* hsl (fallback color) */
+ --bg-dark: hsl(199 53% 89%);
+ --bg: hsl(199 100% 94%);
+ --bg-light: hsl(199 100% 99%);
+ --text: hsl(204 100% 4%);
+ --text-muted: hsl(198 40% 26%);
+ --highlight: hsl(199 100% 99%);
+ --border: hsl(199 22% 49%);
+ --border-muted: hsl(199 28% 61%);
+ --primary: hsl(193 100% 16%);
+ --secondary: hsl(23 81% 25%);
+ --danger: hsl(9 21% 41%);
+ --warning: hsl(52 23% 34%);
+ --success: hsl(147 19% 36%);
+ --info: hsl(217 22% 41%);
+ /* oklch */
+ --bg-dark: oklch(0.92 0.025 228);
+ --bg: oklch(0.96 0.025 228);
+ --bg-light: oklch(1 0.025 228);
+ --text: oklch(0.15 0.05 228);
+ --text-muted: oklch(0.4 0.05 228);
+ --highlight: oklch(1 0.05 228);
+ --border: oklch(0.6 0.05 228);
+ --border-muted: oklch(0.7 0.05 228);
+ --primary: oklch(0.4 0.1 228);
+ --secondary: oklch(0.4 0.1 48);
+ --danger: oklch(0.5 0.05 30);
+ --warning: oklch(0.5 0.05 100);
+ --success: oklch(0.5 0.05 160);
+ --info: oklch(0.5 0.05 260);
+}
diff --git a/new-client/tsconfig.app.json b/new-client/tsconfig.app.json
new file mode 100644
index 0000000..34f9b2c
--- /dev/null
+++ b/new-client/tsconfig.app.json
@@ -0,0 +1,27 @@
+{
+ "extends": "@vue/tsconfig/tsconfig.dom.json",
+ "compilerOptions": {
+ "tsBuildInfoFile": "./node_modules/.tmp/tsconfig.app.tsbuildinfo",
+
+ "moduleResolution": "Bundler",
+ "paths": {
+ "@app/*": ["./src/app/*"],
+ "@pages/*": ["./src/pages/*"],
+ "@widgets/*": ["./src/widgets/*"],
+ "@features/*": ["./src/features/*"],
+ "@entites/*": ["./src/entites/*"],
+ "@shared/*": ["./src/shared/*"],
+ "@/*": ["./src/*"]
+ },
+
+ "types": ["vite/client"],
+
+ "noFallthroughCasesInSwitch": true,
+ /* Linting */
+ "noUnusedLocals": true,
+ "noUnusedParameters": true,
+ "erasableSyntaxOnly": true
+ },
+
+ "include": ["src/**/*.ts", "src/**/*.tsx", "src/**/*.vue", "typed-router.d.ts"]
+}
diff --git a/new-client/tsconfig.json b/new-client/tsconfig.json
new file mode 100644
index 0000000..1ffef60
--- /dev/null
+++ b/new-client/tsconfig.json
@@ -0,0 +1,7 @@
+{
+ "files": [],
+ "references": [
+ { "path": "./tsconfig.app.json" },
+ { "path": "./tsconfig.node.json" }
+ ]
+}
diff --git a/new-client/tsconfig.node.json b/new-client/tsconfig.node.json
new file mode 100644
index 0000000..d3c52ea
--- /dev/null
+++ b/new-client/tsconfig.node.json
@@ -0,0 +1,24 @@
+{
+ "compilerOptions": {
+ "tsBuildInfoFile": "./node_modules/.tmp/tsconfig.node.tsbuildinfo",
+ "target": "es2023",
+ "lib": ["ES2023"],
+ "module": "esnext",
+ "types": ["node"],
+ "skipLibCheck": true,
+
+ /* Bundler mode */
+ "moduleResolution": "bundler",
+ "allowImportingTsExtensions": true,
+ "verbatimModuleSyntax": true,
+ "moduleDetection": "force",
+ "noEmit": true,
+
+ /* Linting */
+ "noUnusedLocals": true,
+ "noUnusedParameters": true,
+ "erasableSyntaxOnly": true,
+ "noFallthroughCasesInSwitch": true
+ },
+ "include": ["vite.config.ts"]
+}
diff --git a/new-client/typed-router.d.ts b/new-client/typed-router.d.ts
new file mode 100644
index 0000000..c69c325
--- /dev/null
+++ b/new-client/typed-router.d.ts
@@ -0,0 +1,115 @@
+/* eslint-disable */
+/* prettier-ignore */
+// oxfmt-ignore
+// @ts-nocheck
+// noinspection ES6UnusedImports
+// Generated by vue-router. !! DO NOT MODIFY THIS FILE !!
+// It's recommended to commit this file.
+// Make sure to add this file to your tsconfig.json file as an "includes" or "files" entry.
+
+import type {
+ RouteRecordInfo,
+ ParamValue,
+ ParamValueOneOrMore,
+ ParamValueZeroOrMore,
+ ParamValueZeroOrOne,
+} from 'vue-router'
+import type {
+ _ExtractParamParserType,
+} from 'vue-router/experimental'
+
+declare module 'vue-router' {
+ interface TypesConfig {
+ ParamParsers:
+ | never
+ }
+}
+
+declare module 'vue-router/auto-routes' {
+ /**
+ * Route name map generated by vue-router
+ */
+ export interface RouteNamedMap {
+ '/': RouteRecordInfo<
+ '/',
+ '/',
+ Record,
+ Record,
+ | never
+ >,
+ '/auth': RouteRecordInfo<
+ '/auth',
+ '/auth',
+ Record,
+ Record,
+ | '/auth/login'
+ | '/auth/register'
+ >,
+ '/auth/login': RouteRecordInfo<
+ '/auth/login',
+ '/auth/login',
+ Record,
+ Record,
+ | never
+ >,
+ '/auth/register': RouteRecordInfo<
+ '/auth/register',
+ '/auth/register',
+ Record,
+ Record,
+ | never
+ >,
+ }
+
+ /**
+ * Route file to route info map by vue-router.
+ * Used by the \`sfc-typed-router\` Volar plugin to automatically type \`useRoute()\`.
+ *
+ * Each key is a file path relative to the project root with 2 properties:
+ * - routes: union of route names of the possible routes when in this page (passed to useRoute<...>())
+ * - views: names of nested views (can be passed to )
+ *
+ * @internal
+ */
+ export interface _RouteFileInfoMap {
+ 'src/pages/index.vue': {
+ routes:
+ | '/'
+ views:
+ | never
+ }
+ 'src/pages/auth.vue': {
+ routes:
+ | '/auth'
+ | '/auth/login'
+ | '/auth/register'
+ views:
+ | 'default'
+ }
+ 'src/pages/auth/login.vue': {
+ routes:
+ | '/auth/login'
+ views:
+ | never
+ }
+ 'src/pages/auth/register.vue': {
+ routes:
+ | '/auth/register'
+ views:
+ | never
+ }
+ }
+
+ /**
+ * Get a union of possible route names in a certain route component file.
+ * Used by the \`sfc-typed-router\` Volar plugin to automatically type \`useRoute()\`.
+ *
+ * @internal
+ */
+ export type _RouteNamesForFilePath =
+ _RouteFileInfoMap extends Record
+ ? Info['routes']
+ : keyof RouteNamedMap
+}
+
+export {}
diff --git a/new-client/vite.config.ts b/new-client/vite.config.ts
new file mode 100644
index 0000000..22afb65
--- /dev/null
+++ b/new-client/vite.config.ts
@@ -0,0 +1,44 @@
+import path from 'node:path'
+import VuePlugin from '@vitejs/plugin-vue'
+import { defineConfig } from 'vite'
+import VueRouterPlugin from 'vue-router/vite'
+
+// https://vite.dev/config/
+export default defineConfig({
+ plugins: [
+ VueRouterPlugin(),
+ VuePlugin(),
+ ],
+ resolve: {
+ alias: [
+ { find: '@app', replacement: path.resolve(__dirname, './src/app') },
+ { find: '@pages', replacement: path.resolve(__dirname, './src/pages') },
+ { find: '@widgets', replacement: path.resolve(__dirname, './src/widgets') },
+ { find: '@features', replacement: path.resolve(__dirname, './src/features') },
+ { find: '@entites', replacement: path.resolve(__dirname, './src/entites') },
+ { find: '@shared', replacement: path.resolve(__dirname, './src/shared') },
+ { find: '@', replacement: path.resolve(__dirname, './src') },
+ ],
+ },
+ // css: {
+ // preprocessorOptions: {
+ // scss: {
+ // additionalData: `
+ // @use '${path.resolve(__dirname, './shared/styles/tokens.scss')}'' as *;
+ // `,
+ // },
+ // },
+ // },
+ server: {
+ port: 3000,
+ strictPort: true,
+ },
+ preview: {
+ port: 3000,
+ strictPort: true,
+ },
+ define: {
+ __API_BASE_URL__: JSON.stringify(import.meta.env?.API_BASE_URL || 'http://localhost:4000/chad'),
+ __COMMIT_SHA__: JSON.stringify(import.meta.env?.COMMIT_SHA || 'local'),
+ },
+})
diff --git a/new-client/yarn.lock b/new-client/yarn.lock
new file mode 100644
index 0000000..ab39f23
--- /dev/null
+++ b/new-client/yarn.lock
@@ -0,0 +1,4383 @@
+# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY.
+# yarn lockfile v1
+
+
+"@antfu/eslint-config@^8.2.0":
+ version "8.2.0"
+ resolved "https://registry.yarnpkg.com/@antfu/eslint-config/-/eslint-config-8.2.0.tgz#f10a0a968167608ba78aff8d7df84cb024b7e5ab"
+ integrity sha512-spfwYXMNrlkl69riTSBnbC0C2K8EVfVMOK3ceP2EpAAioyfprIW1gTwyLRtd9jZSFeNdX4mFNAIG+o0sOneOfA==
+ dependencies:
+ "@antfu/install-pkg" "^1.1.0"
+ "@clack/prompts" "^1.2.0"
+ "@e18e/eslint-plugin" "^0.3.0"
+ "@eslint-community/eslint-plugin-eslint-comments" "^4.7.1"
+ "@eslint/markdown" "^8.0.1"
+ "@stylistic/eslint-plugin" "^5.10.0"
+ "@typescript-eslint/eslint-plugin" "^8.58.1"
+ "@typescript-eslint/parser" "^8.58.1"
+ "@vitest/eslint-plugin" "^1.6.15"
+ ansis "^4.2.0"
+ cac "^7.0.0"
+ eslint-config-flat-gitignore "^2.3.0"
+ eslint-flat-config-utils "^3.1.0"
+ eslint-merge-processors "^2.0.0"
+ eslint-plugin-antfu "^3.2.2"
+ eslint-plugin-command "^3.5.2"
+ eslint-plugin-import-lite "^0.6.0"
+ eslint-plugin-jsdoc "^62.9.0"
+ eslint-plugin-jsonc "^3.1.2"
+ eslint-plugin-n "^17.24.0"
+ eslint-plugin-no-only-tests "^3.3.0"
+ eslint-plugin-perfectionist "^5.8.0"
+ eslint-plugin-pnpm "^1.6.0"
+ eslint-plugin-regexp "^3.1.0"
+ eslint-plugin-toml "^1.3.1"
+ eslint-plugin-unicorn "^64.0.0"
+ eslint-plugin-unused-imports "^4.4.1"
+ eslint-plugin-vue "^10.8.0"
+ eslint-plugin-yml "^3.3.1"
+ eslint-processor-vue-blocks "^2.0.0"
+ globals "^17.5.0"
+ local-pkg "^1.1.2"
+ parse-gitignore "^2.0.0"
+ toml-eslint-parser "^1.0.3"
+ vue-eslint-parser "^10.4.0"
+ yaml-eslint-parser "^2.0.0"
+
+"@antfu/install-pkg@^1.1.0":
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/@antfu/install-pkg/-/install-pkg-1.1.0.tgz#78fa036be1a6081b5a77a5cf59f50c7752b6ba26"
+ integrity sha512-MGQsmw10ZyI+EJo45CdSER4zEb+p31LpDAFp2Z3gkSd1yqVZGi0Ebx++YTEMonJy4oChEMLsxZ64j8FH6sSqtQ==
+ dependencies:
+ package-manager-detector "^1.3.0"
+ tinyexec "^1.0.1"
+
+"@ark-ui/vue@^5.36.2":
+ version "5.36.2"
+ resolved "https://registry.yarnpkg.com/@ark-ui/vue/-/vue-5.36.2.tgz#b3899d14711d1097217545ddd91737d7e522a36d"
+ integrity sha512-GI22MHnEvcSeLyIdNPYz1DR7ktogpXRWQRMLdf9D1j4hG6FK7O0Z6vUwegghY0Dc4n3ar9IQY7OU8Bp+AjhgdQ==
+ dependencies:
+ "@internationalized/date" "3.12.0"
+ "@zag-js/accordion" "1.40.0"
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/angle-slider" "1.40.0"
+ "@zag-js/async-list" "1.40.0"
+ "@zag-js/auto-resize" "1.40.0"
+ "@zag-js/avatar" "1.40.0"
+ "@zag-js/carousel" "1.40.0"
+ "@zag-js/cascade-select" "1.40.0"
+ "@zag-js/checkbox" "1.40.0"
+ "@zag-js/clipboard" "1.40.0"
+ "@zag-js/collapsible" "1.40.0"
+ "@zag-js/collection" "1.40.0"
+ "@zag-js/color-picker" "1.40.0"
+ "@zag-js/color-utils" "1.40.0"
+ "@zag-js/combobox" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/date-input" "1.40.0"
+ "@zag-js/date-picker" "1.40.0"
+ "@zag-js/date-utils" "1.40.0"
+ "@zag-js/dialog" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/drawer" "1.40.0"
+ "@zag-js/editable" "1.40.0"
+ "@zag-js/file-upload" "1.40.0"
+ "@zag-js/file-utils" "1.40.0"
+ "@zag-js/floating-panel" "1.40.0"
+ "@zag-js/focus-trap" "1.40.0"
+ "@zag-js/focus-visible" "1.40.0"
+ "@zag-js/highlight-word" "1.40.0"
+ "@zag-js/hover-card" "1.40.0"
+ "@zag-js/i18n-utils" "1.40.0"
+ "@zag-js/image-cropper" "1.40.0"
+ "@zag-js/json-tree-utils" "1.40.0"
+ "@zag-js/listbox" "1.40.0"
+ "@zag-js/marquee" "1.40.0"
+ "@zag-js/menu" "1.40.0"
+ "@zag-js/navigation-menu" "1.40.0"
+ "@zag-js/number-input" "1.40.0"
+ "@zag-js/pagination" "1.40.0"
+ "@zag-js/password-input" "1.40.0"
+ "@zag-js/pin-input" "1.40.0"
+ "@zag-js/popover" "1.40.0"
+ "@zag-js/presence" "1.40.0"
+ "@zag-js/progress" "1.40.0"
+ "@zag-js/qr-code" "1.40.0"
+ "@zag-js/radio-group" "1.40.0"
+ "@zag-js/rating-group" "1.40.0"
+ "@zag-js/scroll-area" "1.40.0"
+ "@zag-js/select" "1.40.0"
+ "@zag-js/signature-pad" "1.40.0"
+ "@zag-js/slider" "1.40.0"
+ "@zag-js/splitter" "1.40.0"
+ "@zag-js/steps" "1.40.0"
+ "@zag-js/switch" "1.40.0"
+ "@zag-js/tabs" "1.40.0"
+ "@zag-js/tags-input" "1.40.0"
+ "@zag-js/timer" "1.40.0"
+ "@zag-js/toast" "1.40.0"
+ "@zag-js/toggle" "1.40.0"
+ "@zag-js/toggle-group" "1.40.0"
+ "@zag-js/tooltip" "1.40.0"
+ "@zag-js/tour" "1.40.0"
+ "@zag-js/tree-view" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+ "@zag-js/vue" "1.40.0"
+
+"@babel/generator@^7.28.6":
+ version "7.29.1"
+ resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.29.1.tgz#d09876290111abbb00ef962a7b83a5307fba0d50"
+ integrity sha512-qsaF+9Qcm2Qv8SRIMMscAvG4O3lJ0F1GuMo5HR/Bp02LopNgnZBC/EkbevHFeGs4ls/oPz9v+Bsmzbkbe+0dUw==
+ dependencies:
+ "@babel/parser" "^7.29.0"
+ "@babel/types" "^7.29.0"
+ "@jridgewell/gen-mapping" "^0.3.12"
+ "@jridgewell/trace-mapping" "^0.3.28"
+ jsesc "^3.0.2"
+
+"@babel/helper-string-parser@^7.27.1":
+ version "7.27.1"
+ resolved "https://registry.yarnpkg.com/@babel/helper-string-parser/-/helper-string-parser-7.27.1.tgz#54da796097ab19ce67ed9f88b47bb2ec49367687"
+ integrity sha512-qMlSxKbpRlAridDExk92nSobyDdpPijUq2DW6oDnUqd0iOGxmQjyqhMIihI9+zv4LPyZdRje2cavWPbCbWm3eA==
+
+"@babel/helper-validator-identifier@^7.28.5":
+ version "7.28.5"
+ resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.28.5.tgz#010b6938fab7cb7df74aa2bbc06aa503b8fe5fb4"
+ integrity sha512-qSs4ifwzKJSV39ucNjsvc6WVHs6b7S03sOh2OcHF9UHfVPqWWALUsNUVzhSBiItjRZoLHx7nIarVjqKVusUZ1Q==
+
+"@babel/parser@^7.28.4", "@babel/parser@^7.28.5", "@babel/parser@^7.29.0", "@babel/parser@^7.29.3":
+ version "7.29.3"
+ resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.29.3.tgz#116f70a77958307fceac27747573032f8a62f88e"
+ integrity sha512-b3ctpQwp+PROvU/cttc4OYl4MzfJUWy6FZg+PMXfzmt/+39iHVF0sDfqay8TQM3JA2EUOyKcFZt75jWriQijsA==
+ dependencies:
+ "@babel/types" "^7.29.0"
+
+"@babel/types@^7.29.0":
+ version "7.29.0"
+ resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.29.0.tgz#9f5b1e838c446e72cf3cd4b918152b8c605e37c7"
+ integrity sha512-LwdZHpScM4Qz8Xw2iKSzS+cfglZzJGvofQICy7W7v4caru4EaAmyUuO6BGrbyQ2mYV11W0U8j5mBhd14dd3B0A==
+ dependencies:
+ "@babel/helper-string-parser" "^7.27.1"
+ "@babel/helper-validator-identifier" "^7.28.5"
+
+"@bufbuild/protobuf@^2.5.0":
+ version "2.12.0"
+ resolved "https://registry.yarnpkg.com/@bufbuild/protobuf/-/protobuf-2.12.0.tgz#53225636a8fcebb2bd94998ad9d42f99f96add4d"
+ integrity sha512-B/XlCaFIP8LOwzo+bz5uFzATYokcwCKQcghqnlfwSmM5eX/qTkvDBnDPs+gXtX/RyjxJ4DRikECcPJbyALA8FA==
+
+"@clack/core@1.3.0":
+ version "1.3.0"
+ resolved "https://registry.yarnpkg.com/@clack/core/-/core-1.3.0.tgz#d890a18c636cbaa554fa69bf48d4c25924da5b84"
+ integrity sha512-xJPHpAmEQUBrXSLx0gF+q5K/IyihXpsHZcha+jB+tyahsKRK3Dxo4D0coZDewHo12NhiuzC3dTtMPbm53GEAAA==
+ dependencies:
+ fast-wrap-ansi "^0.2.0"
+ sisteransi "^1.0.5"
+
+"@clack/prompts@^1.2.0":
+ version "1.3.0"
+ resolved "https://registry.yarnpkg.com/@clack/prompts/-/prompts-1.3.0.tgz#d6abd868703b78b146ebd5f7d4caa20bafc88dbf"
+ integrity sha512-GgcWwRCs/xPtaqlMy8qRhPnZf9vlWcWZNHAitnVQ3yk7JmSralSiq5q07yaffYE8SogtDm7zFeKccx1QNVARpw==
+ dependencies:
+ "@clack/core" "1.3.0"
+ fast-string-width "^3.0.2"
+ fast-wrap-ansi "^0.2.0"
+ sisteransi "^1.0.5"
+
+"@dprint/formatter@^0.5.1":
+ version "0.5.1"
+ resolved "https://registry.yarnpkg.com/@dprint/formatter/-/formatter-0.5.1.tgz#1f776471d0af07c3c42595cab3d70ba78aaee6b3"
+ integrity sha512-cdZUrm0iv/FnnY3CKE2dEcVhNEzrC551aE2h2mTFwQCRBrqyARLDnb7D+3PlXTUVp3s34ftlnGOVCmhLT9DeKA==
+
+"@dprint/markdown@^0.21.1":
+ version "0.21.1"
+ resolved "https://registry.yarnpkg.com/@dprint/markdown/-/markdown-0.21.1.tgz#29e3347ae173fffe02da80c3a0a182d75deb6fb7"
+ integrity sha512-XbZ/R7vRrBaZFYXG6vAvLvtaMVXHu8XB+xwie7OYrG+dPoGDP8UADGirIbzUyX8TmrAZcl6QBmalipTGlpzRmQ==
+
+"@dprint/toml@^0.7.0":
+ version "0.7.0"
+ resolved "https://registry.yarnpkg.com/@dprint/toml/-/toml-0.7.0.tgz#2caacd0be776f5cda6be918923c11855085a8814"
+ integrity sha512-eFaQTcfxKHB+YyTh83x7GEv+gDPuj9q5NFOTaoj5rZmQTbj6OgjjMxUicmS1R8zYcx8YAq5oA9J3YFa5U6x2gA==
+
+"@e18e/eslint-plugin@^0.3.0":
+ version "0.3.0"
+ resolved "https://registry.yarnpkg.com/@e18e/eslint-plugin/-/eslint-plugin-0.3.0.tgz#8ab0703bfbe4b75ad3b9fb7efc4fceb886de9a4f"
+ integrity sha512-hHgfpxsrZ2UYHcicA+tGZnmk19uJTaye9VH79O+XS8R4ona2Hx3xjhXghclNW58uXMk3xXlbYEOMr8thsoBmWg==
+ dependencies:
+ eslint-plugin-depend "^1.5.0"
+
+"@emnapi/core@1.10.0":
+ version "1.10.0"
+ resolved "https://registry.yarnpkg.com/@emnapi/core/-/core-1.10.0.tgz#380ccc8f2412ea22d1d972df7f8ee23a3b9c7467"
+ integrity sha512-yq6OkJ4p82CAfPl0u9mQebQHKPJkY7WrIuk205cTYnYe+k2Z8YBh11FrbRG/H6ihirqcacOgl2BIO8oyMQLeXw==
+ dependencies:
+ "@emnapi/wasi-threads" "1.2.1"
+ tslib "^2.4.0"
+
+"@emnapi/runtime@1.10.0":
+ version "1.10.0"
+ resolved "https://registry.yarnpkg.com/@emnapi/runtime/-/runtime-1.10.0.tgz#4b260c0d3534204e98c6110b8db1a987d26ec87c"
+ integrity sha512-ewvYlk86xUoGI0zQRNq/mC+16R1QeDlKQy21Ki3oSYXNgLb45GV1P6A0M+/s6nyCuNDqe5VpaY84BzXGwVbwFA==
+ dependencies:
+ tslib "^2.4.0"
+
+"@emnapi/wasi-threads@1.2.1":
+ version "1.2.1"
+ resolved "https://registry.yarnpkg.com/@emnapi/wasi-threads/-/wasi-threads-1.2.1.tgz#28fed21a1ba1ce797c44a070abc94d42f3ae8548"
+ integrity sha512-uTII7OYF+/Mes/MrcIOYp5yOtSMLBWSIoLPpcgwipoiKbli6k322tcoFsxoIIxPDqW01SQGAgko4EzZi2BNv2w==
+ dependencies:
+ tslib "^2.4.0"
+
+"@es-joy/jsdoccomment@^0.84.0":
+ version "0.84.0"
+ resolved "https://registry.yarnpkg.com/@es-joy/jsdoccomment/-/jsdoccomment-0.84.0.tgz#4d798d33207825dd1d85babbfbacc3a76c3ba634"
+ integrity sha512-0xew1CxOam0gV5OMjh2KjFQZsKL2bByX1+q4j3E73MpYIdyUxcZb/xQct9ccUb+ve5KGUYbCUxyPnYB7RbuP+w==
+ dependencies:
+ "@types/estree" "^1.0.8"
+ "@typescript-eslint/types" "^8.54.0"
+ comment-parser "1.4.5"
+ esquery "^1.7.0"
+ jsdoc-type-pratt-parser "~7.1.1"
+
+"@es-joy/jsdoccomment@~0.86.0":
+ version "0.86.0"
+ resolved "https://registry.yarnpkg.com/@es-joy/jsdoccomment/-/jsdoccomment-0.86.0.tgz#f7276904ed73bf2136993627033aeb5183b4392a"
+ integrity sha512-ukZmRQ81WiTpDWO6D/cTBM7XbrNtutHKvAVnZN/8pldAwLoJArGOvkNyxPTBGsPjsoaQBJxlH+tE2TNA/92Qgw==
+ dependencies:
+ "@types/estree" "^1.0.8"
+ "@typescript-eslint/types" "^8.58.0"
+ comment-parser "1.4.6"
+ esquery "^1.7.0"
+ jsdoc-type-pratt-parser "~7.2.0"
+
+"@es-joy/resolve.exports@1.2.0":
+ version "1.2.0"
+ resolved "https://registry.yarnpkg.com/@es-joy/resolve.exports/-/resolve.exports-1.2.0.tgz#fe541a68aa080255f798c8561714ac8fad72cdd5"
+ integrity sha512-Q9hjxWI5xBM+qW2enxfe8wDKdFWMfd0Z29k5ZJnuBqD/CasY5Zryj09aCA6owbGATWz+39p5uIdaHXpopOcG8g==
+
+"@eslint-community/eslint-plugin-eslint-comments@^4.7.1":
+ version "4.7.1"
+ resolved "https://registry.yarnpkg.com/@eslint-community/eslint-plugin-eslint-comments/-/eslint-plugin-eslint-comments-4.7.1.tgz#503fc7ee16390a4720b1bc14be27b546b68e9cb2"
+ integrity sha512-Ql2nJFwA8wUGpILYGOQaT1glPsmvEwE0d+a+l7AALLzQvInqdbXJdx7aSu0DpUX9dB1wMVBMhm99/++S3MdEtQ==
+ dependencies:
+ escape-string-regexp "^4.0.0"
+ ignore "^7.0.5"
+
+"@eslint-community/eslint-utils@^4.1.2", "@eslint-community/eslint-utils@^4.2.0", "@eslint-community/eslint-utils@^4.4.0", "@eslint-community/eslint-utils@^4.5.0", "@eslint-community/eslint-utils@^4.5.1", "@eslint-community/eslint-utils@^4.8.0", "@eslint-community/eslint-utils@^4.9.1":
+ version "4.9.1"
+ resolved "https://registry.yarnpkg.com/@eslint-community/eslint-utils/-/eslint-utils-4.9.1.tgz#4e90af67bc51ddee6cdef5284edf572ec376b595"
+ integrity sha512-phrYmNiYppR7znFEdqgfWHXR6NCkZEK7hwWDHZUjit/2/U0r6XvkDl0SYnoM51Hq7FhCGdLDT6zxCCOY1hexsQ==
+ dependencies:
+ eslint-visitor-keys "^3.4.3"
+
+"@eslint-community/regexpp@^4.11.0", "@eslint-community/regexpp@^4.12.2", "@eslint-community/regexpp@^4.8.0":
+ version "4.12.2"
+ resolved "https://registry.yarnpkg.com/@eslint-community/regexpp/-/regexpp-4.12.2.tgz#bccdf615bcf7b6e8db830ec0b8d21c9a25de597b"
+ integrity sha512-EriSTlt5OC9/7SXkRSCAhfSxxoSUgBm33OH+IkwbdpgoqsSsUg7y3uh+IICI/Qg4BBWr3U2i39RpmycbxMq4ew==
+
+"@eslint/compat@^2.0.3":
+ version "2.0.5"
+ resolved "https://registry.yarnpkg.com/@eslint/compat/-/compat-2.0.5.tgz#65421b3f6e5a864e0255ab31884fb26fdc4d0210"
+ integrity sha512-IbHDbHJfkVNv6xjlET8AIVo/K1NQt7YT4Rp6ok/clyBGcpRx1l6gv0Rq3vBvYfPJIZt6ODf66Zq08FJNDpnzgg==
+ dependencies:
+ "@eslint/core" "^1.2.1"
+
+"@eslint/config-array@^0.23.5":
+ version "0.23.5"
+ resolved "https://registry.yarnpkg.com/@eslint/config-array/-/config-array-0.23.5.tgz#56e86d243049195d8acc0c06a1b3dfdc3fa3de95"
+ integrity sha512-Y3kKLvC1dvTOT+oGlqNQ1XLqK6D1HU2YXPc52NmAlJZbMMWDzGYXMiPRJ8TYD39muD/OTjlZmNJ4ib7dvSrMBA==
+ dependencies:
+ "@eslint/object-schema" "^3.0.5"
+ debug "^4.3.1"
+ minimatch "^10.2.4"
+
+"@eslint/config-helpers@^0.5.5":
+ version "0.5.5"
+ resolved "https://registry.yarnpkg.com/@eslint/config-helpers/-/config-helpers-0.5.5.tgz#ae16134e4792ac5fbdc533548a24ac1ea9f7f3ae"
+ integrity sha512-eIJYKTCECbP/nsKaaruF6LW967mtbQbsw4JTtSVkUQc9MneSkbrgPJAbKl9nWr0ZeowV8BfsarBmPpBzGelA2w==
+ dependencies:
+ "@eslint/core" "^1.2.1"
+
+"@eslint/core@^1.0.1", "@eslint/core@^1.1.1", "@eslint/core@^1.2.1":
+ version "1.2.1"
+ resolved "https://registry.yarnpkg.com/@eslint/core/-/core-1.2.1.tgz#c1da7cd1b82fa8787f98b5629fb811848a1b63ce"
+ integrity sha512-MwcE1P+AZ4C6DWlpin/OmOA54mmIZ/+xZuJiQd4SyB29oAJjN30UW9wkKNptW2ctp4cEsvhlLY/CsQ1uoHDloQ==
+ dependencies:
+ "@types/json-schema" "^7.0.15"
+
+"@eslint/markdown@^8.0.1":
+ version "8.0.1"
+ resolved "https://registry.yarnpkg.com/@eslint/markdown/-/markdown-8.0.1.tgz#48a1fd05ecc480fff60128a9b50694e9ce02d192"
+ integrity sha512-WWKmld/EyNdEB8GMq7JMPX1SDWgyJAM1uhtCi5ySrqYQM4HQjmg11EX/q3ZpnpRXHfdccFtli3NBvvGaYjWyQw==
+ dependencies:
+ "@eslint/core" "^1.1.1"
+ "@eslint/plugin-kit" "^0.6.1"
+ github-slugger "^2.0.0"
+ mdast-util-from-markdown "^2.0.2"
+ mdast-util-frontmatter "^2.0.1"
+ mdast-util-gfm "^3.1.0"
+ mdast-util-math "^3.0.0"
+ micromark-extension-frontmatter "^2.0.0"
+ micromark-extension-gfm "^3.0.0"
+ micromark-extension-math "^3.1.0"
+ micromark-util-normalize-identifier "^2.0.1"
+
+"@eslint/object-schema@^3.0.5":
+ version "3.0.5"
+ resolved "https://registry.yarnpkg.com/@eslint/object-schema/-/object-schema-3.0.5.tgz#88e9bf4d11d2b19c082e78ebe7ce88724a5eb091"
+ integrity sha512-vqTaUEgxzm+YDSdElad6PiRoX4t8VGDjCtt05zn4nU810UIx/uNEV7/lZJ6KwFThKZOzOxzXy48da+No7HZaMw==
+
+"@eslint/plugin-kit@^0.6.0", "@eslint/plugin-kit@^0.6.1":
+ version "0.6.1"
+ resolved "https://registry.yarnpkg.com/@eslint/plugin-kit/-/plugin-kit-0.6.1.tgz#eb9e6689b56ce8bc1855bb33090e63f3fc115e8e"
+ integrity sha512-iH1B076HoAshH1mLpHMgwdGeTs0CYwL0SPMkGuSebZrwBp16v415e9NZXg2jtrqPVQjf6IANe2Vtlr5KswtcZQ==
+ dependencies:
+ "@eslint/core" "^1.1.1"
+ levn "^0.4.1"
+
+"@eslint/plugin-kit@^0.7.0", "@eslint/plugin-kit@^0.7.1":
+ version "0.7.1"
+ resolved "https://registry.yarnpkg.com/@eslint/plugin-kit/-/plugin-kit-0.7.1.tgz#c4125fd015eceeb09b793109fdbcd4dd0a02d346"
+ integrity sha512-rZAP3aVgB9ds9KOeUSL+zZ21hPmo8dh6fnIFwRQj5EAZl9gzR7wxYbYXYysAM8CTqGmUGyp2S4kUdV17MnGuWQ==
+ dependencies:
+ "@eslint/core" "^1.2.1"
+ levn "^0.4.1"
+
+"@floating-ui/core@^1.7.5":
+ version "1.7.5"
+ resolved "https://registry.yarnpkg.com/@floating-ui/core/-/core-1.7.5.tgz#d4af157a03330af5a60e69da7a4692507ada0622"
+ integrity sha512-1Ih4WTWyw0+lKyFMcBHGbb5U5FtuHJuujoyyr5zTaWS5EYMeT6Jb2AuDeftsCsEuchO+mM2ij5+q9crhydzLhQ==
+ dependencies:
+ "@floating-ui/utils" "^0.2.11"
+
+"@floating-ui/dom@^1.7.6":
+ version "1.7.6"
+ resolved "https://registry.yarnpkg.com/@floating-ui/dom/-/dom-1.7.6.tgz#f915bba5abbb177e1f227cacee1b4d0634b187bf"
+ integrity sha512-9gZSAI5XM36880PPMm//9dfiEngYoC6Am2izES1FF406YFsjvyBMmeJ2g4SAju3xWwtuynNRFL2s9hgxpLI5SQ==
+ dependencies:
+ "@floating-ui/core" "^1.7.5"
+ "@floating-ui/utils" "^0.2.11"
+
+"@floating-ui/utils@^0.2.11":
+ version "0.2.11"
+ resolved "https://registry.yarnpkg.com/@floating-ui/utils/-/utils-0.2.11.tgz#a269e055e40e2f45873bae9d1a2fdccbd314ea3f"
+ integrity sha512-RiB/yIh78pcIxl6lLMG0CgBXAZ2Y0eVHqMPYugu+9U0AeT6YBeiJpf7lbdJNIugFP5SIjwNRgo4DhR1Qxi26Gg==
+
+"@humanfs/core@^0.19.2":
+ version "0.19.2"
+ resolved "https://registry.yarnpkg.com/@humanfs/core/-/core-0.19.2.tgz#a8272ca03b2acf492670222b2320b6c421bfde60"
+ integrity sha512-UhXNm+CFMWcbChXywFwkmhqjs3PRCmcSa/hfBgLIb7oQ5HNb1wS0icWsGtSAUNgefHeI+eBrA8I1fxmbHsGdvA==
+ dependencies:
+ "@humanfs/types" "^0.15.0"
+
+"@humanfs/node@^0.16.6":
+ version "0.16.8"
+ resolved "https://registry.yarnpkg.com/@humanfs/node/-/node-0.16.8.tgz#8f800cccc13f4f8cd3116e2d9c0a94939da3e3ed"
+ integrity sha512-gE1eQNZ3R++kTzFUpdGlpmy8kDZD/MLyHqDwqjkVQI0JMdI1D51sy1H958PNXYkM2rAac7e5/CnIKZrHtPh3BQ==
+ dependencies:
+ "@humanfs/core" "^0.19.2"
+ "@humanfs/types" "^0.15.0"
+ "@humanwhocodes/retry" "^0.4.0"
+
+"@humanfs/types@^0.15.0":
+ version "0.15.0"
+ resolved "https://registry.yarnpkg.com/@humanfs/types/-/types-0.15.0.tgz#f2a09f62012390b2bff3fc6fb248ddec8c09a090"
+ integrity sha512-ZZ1w0aoQkwuUuC7Yf+7sdeaNfqQiiLcSRbfI08oAxqLtpXQr9AIVX7Ay7HLDuiLYAaFPu8oBYNq/QIi9URHJ3Q==
+
+"@humanwhocodes/module-importer@^1.0.1":
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz#af5b2691a22b44be847b0ca81641c5fb6ad0172c"
+ integrity sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==
+
+"@humanwhocodes/retry@^0.4.0", "@humanwhocodes/retry@^0.4.2":
+ version "0.4.3"
+ resolved "https://registry.yarnpkg.com/@humanwhocodes/retry/-/retry-0.4.3.tgz#c2b9d2e374ee62c586d3adbea87199b1d7a7a6ba"
+ integrity sha512-bV0Tgo9K4hfPCek+aMAn81RppFKv2ySDQeMoSZuvTASywNTnVJCArCZE2FWqpvIatKu7VMRLWlR1EazvVhDyhQ==
+
+"@internationalized/date@3.12.0":
+ version "3.12.0"
+ resolved "https://registry.yarnpkg.com/@internationalized/date/-/date-3.12.0.tgz#cdcd12adf36e1ccb05ec7b964f4857e7ec62137d"
+ integrity sha512-/PyIMzK29jtXaGU23qTvNZxvBXRtKbNnGDFD+PY6CZw/Y8Ex8pFUzkuCJCG9aOqmShjqhS9mPqP6Dk5onQY8rQ==
+ dependencies:
+ "@swc/helpers" "^0.5.0"
+
+"@internationalized/number@3.6.5":
+ version "3.6.5"
+ resolved "https://registry.yarnpkg.com/@internationalized/number/-/number-3.6.5.tgz#1103f2832ca8d9dd3e4eecf95733d497791dbbbe"
+ integrity sha512-6hY4Kl4HPBvtfS62asS/R22JzNNy8vi/Ssev7x6EobfCp+9QIB2hKvI2EtbdJ0VSQacxVNtqhE/NmF/NZ0gm6g==
+ dependencies:
+ "@swc/helpers" "^0.5.0"
+
+"@jridgewell/gen-mapping@^0.3.12", "@jridgewell/gen-mapping@^0.3.5":
+ version "0.3.13"
+ resolved "https://registry.yarnpkg.com/@jridgewell/gen-mapping/-/gen-mapping-0.3.13.tgz#6342a19f44347518c93e43b1ac69deb3c4656a1f"
+ integrity sha512-2kkt/7niJ6MgEPxF0bYdQ6etZaA+fQvDcLKckhy1yIQOzaoKjBBjSj63/aLVjYE3qhRt5dvM+uUyfCg6UKCBbA==
+ dependencies:
+ "@jridgewell/sourcemap-codec" "^1.5.0"
+ "@jridgewell/trace-mapping" "^0.3.24"
+
+"@jridgewell/remapping@^2.3.5":
+ version "2.3.5"
+ resolved "https://registry.yarnpkg.com/@jridgewell/remapping/-/remapping-2.3.5.tgz#375c476d1972947851ba1e15ae8f123047445aa1"
+ integrity sha512-LI9u/+laYG4Ds1TDKSJW2YPrIlcVYOwi2fUC6xB43lueCjgxV4lffOCZCtYFiH6TNOX+tQKXx97T4IKHbhyHEQ==
+ dependencies:
+ "@jridgewell/gen-mapping" "^0.3.5"
+ "@jridgewell/trace-mapping" "^0.3.24"
+
+"@jridgewell/resolve-uri@^3.1.0":
+ version "3.1.2"
+ resolved "https://registry.yarnpkg.com/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz#7a0ee601f60f99a20c7c7c5ff0c80388c1189bd6"
+ integrity sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==
+
+"@jridgewell/sourcemap-codec@^1.4.14", "@jridgewell/sourcemap-codec@^1.5.0", "@jridgewell/sourcemap-codec@^1.5.5":
+ version "1.5.5"
+ resolved "https://registry.yarnpkg.com/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.5.tgz#6912b00d2c631c0d15ce1a7ab57cd657f2a8f8ba"
+ integrity sha512-cYQ9310grqxueWbl+WuIUIaiUaDcj7WOq5fVhEljNVgRfOUhY9fy2zTvfoqWsnebh8Sl70VScFbICvJnLKB0Og==
+
+"@jridgewell/trace-mapping@^0.3.24", "@jridgewell/trace-mapping@^0.3.28":
+ version "0.3.31"
+ resolved "https://registry.yarnpkg.com/@jridgewell/trace-mapping/-/trace-mapping-0.3.31.tgz#db15d6781c931f3a251a3dac39501c98a6082fd0"
+ integrity sha512-zzNR+SdQSDJzc8joaeP8QQoCQr8NuYx2dIIytl1QeBEZHJ9uW6hebsrYgbz8hJwUQao3TWCMtmfV8Nu1twOLAw==
+ dependencies:
+ "@jridgewell/resolve-uri" "^3.1.0"
+ "@jridgewell/sourcemap-codec" "^1.4.14"
+
+"@napi-rs/wasm-runtime@^1.1.4":
+ version "1.1.4"
+ resolved "https://registry.yarnpkg.com/@napi-rs/wasm-runtime/-/wasm-runtime-1.1.4.tgz#a46bbfedc29751b7170c5d23bc1d8ee8c7e3c1e1"
+ integrity sha512-3NQNNgA1YSlJb/kMH1ildASP9HW7/7kYnRI2szWJaofaS1hWmbGI4H+d3+22aGzXXN9IJ+n+GiFVcGipJP18ow==
+ dependencies:
+ "@tybys/wasm-util" "^0.10.1"
+
+"@ota-meshi/ast-token-store@^0.3.0":
+ version "0.3.0"
+ resolved "https://registry.yarnpkg.com/@ota-meshi/ast-token-store/-/ast-token-store-0.3.0.tgz#c4112dabb53c8bd0c298d94d858849c30f1d3283"
+ integrity sha512-XRO0zi2NIUKq2lUk3T1ecFSld1fMWRKE6naRFGkgkdeosx7IslyUKNv5Dcb5PJTja9tHJoFu0v/7yEpAkrkrTg==
+
+"@oxc-project/types@=0.127.0":
+ version "0.127.0"
+ resolved "https://registry.yarnpkg.com/@oxc-project/types/-/types-0.127.0.tgz#8374fcdfb4a641861218daa5700c447c00b66663"
+ integrity sha512-aIYXQBo4lCbO4z0R3FHeucQHpF46l2LbMdxRvqvuRuW2OxdnSkcng5B8+K12spgLDj93rtN3+J2Vac/TIO+ciQ==
+
+"@oxfmt/binding-android-arm-eabi@0.35.0":
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/@oxfmt/binding-android-arm-eabi/-/binding-android-arm-eabi-0.35.0.tgz#8720e90fb2cbf5ae891a35e9e44004d32e396864"
+ integrity sha512-BaRKlM3DyG81y/xWTsE6gZiv89F/3pHe2BqX2H4JbiB8HNVlWWtplzgATAE5IDSdwChdeuWLDTQzJ92Lglw3ZA==
+
+"@oxfmt/binding-android-arm64@0.35.0":
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/@oxfmt/binding-android-arm64/-/binding-android-arm64-0.35.0.tgz#9909bf8b0d6e3db7e973fc0c0a502cd1b8e6bf80"
+ integrity sha512-/O+EbuAJYs6nde/anv+aID6uHsGQApyE9JtYBo/79KyU8e6RBN3DMbT0ix97y1SOnCglurmL2iZ+hlohjP2PnQ==
+
+"@oxfmt/binding-darwin-arm64@0.35.0":
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/@oxfmt/binding-darwin-arm64/-/binding-darwin-arm64-0.35.0.tgz#027b2eae0c300f51f80327c71749e3e73e4da13e"
+ integrity sha512-pGqRtqlNdn9d4VrmGUWVyQjkw79ryhI6je9y2jfqNUIZCfqceob+R97YYAoG7C5TFyt8ILdLVoN+L2vw/hSFyA==
+
+"@oxfmt/binding-darwin-x64@0.35.0":
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/@oxfmt/binding-darwin-x64/-/binding-darwin-x64-0.35.0.tgz#924918966f1404469bf6e105f19845f62ce95c79"
+ integrity sha512-8GmsDcSozTPjrCJeGpp+sCmS9+9V5yRrdEZ1p/sTWxPG5nYeAfSLuS0nuEYjXSO+CtdSbStIW6dxa+4NM58yRw==
+
+"@oxfmt/binding-freebsd-x64@0.35.0":
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/@oxfmt/binding-freebsd-x64/-/binding-freebsd-x64-0.35.0.tgz#eda224b82599b62406c32a71644c777092f2ad85"
+ integrity sha512-QyfKfTe0ytHpFKHAcHCGQEzN45QSqq1AHJOYYxQMgLM3KY4xu8OsXHpCnINjDsV4XGnQzczJDU9e04Zmd8XqIQ==
+
+"@oxfmt/binding-linux-arm-gnueabihf@0.35.0":
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/@oxfmt/binding-linux-arm-gnueabihf/-/binding-linux-arm-gnueabihf-0.35.0.tgz#9b311c1527da9e051e608a0c0d2c86163bd912fb"
+ integrity sha512-u+kv3JD6P3J38oOyUaiCqgY5TNESzBRZJ5lyZQ6c2czUW2v5SIN9E/KWWa9vxoc+P8AFXQFUVrdzGy1tK+nbPQ==
+
+"@oxfmt/binding-linux-arm-musleabihf@0.35.0":
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/@oxfmt/binding-linux-arm-musleabihf/-/binding-linux-arm-musleabihf-0.35.0.tgz#ad59e9b6f3d9461ae2a71e50a8ed267fa247dbc7"
+ integrity sha512-1NiZroCiV57I7Pf8kOH4XGR366kW5zir3VfSMBU2D0V14GpYjiYmPYFAoJboZvp8ACnZKUReWyMkNKSa5ad58A==
+
+"@oxfmt/binding-linux-arm64-gnu@0.35.0":
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/@oxfmt/binding-linux-arm64-gnu/-/binding-linux-arm64-gnu-0.35.0.tgz#f921e961d6cbaa0e4cc5e07760e05efad16f75a0"
+ integrity sha512-7Q0Xeg7ZnW2nxnZ4R7aF6DEbCFls4skgHZg+I63XitpNvJCbVIU8MFOTZlvZGRsY9+rPgWPQGeUpLHlyx0wvMA==
+
+"@oxfmt/binding-linux-arm64-musl@0.35.0":
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/@oxfmt/binding-linux-arm64-musl/-/binding-linux-arm64-musl-0.35.0.tgz#a52625d0255b9db408dc5f12518b2d66067719df"
+ integrity sha512-5Okqi+uhYFxwKz8hcnUftNNwdm8BCkf6GSCbcz9xJxYMm87k1E4p7PEmAAbhLTk7cjSdDre6TDL0pDzNX+Y22Q==
+
+"@oxfmt/binding-linux-ppc64-gnu@0.35.0":
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/@oxfmt/binding-linux-ppc64-gnu/-/binding-linux-ppc64-gnu-0.35.0.tgz#838008064aae1b9770a29d73e3d414b7a436a6bd"
+ integrity sha512-9k66pbZQXM/lBJWys3Xbc5yhl4JexyfqkEf/tvtq8976VIJnLAAL3M127xHA3ifYSqxdVHfVGTg84eiBHCGcNw==
+
+"@oxfmt/binding-linux-riscv64-gnu@0.35.0":
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/@oxfmt/binding-linux-riscv64-gnu/-/binding-linux-riscv64-gnu-0.35.0.tgz#a2bcc5b7a2924cf1db4cc25e9334496b63c25bef"
+ integrity sha512-aUcY9ofKPtjO52idT6t0SAQvEF6ctjzUQa1lLp7GDsRpSBvuTrBQGeq0rYKz3gN8dMIQ7mtMdGD9tT4LhR8jAQ==
+
+"@oxfmt/binding-linux-riscv64-musl@0.35.0":
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/@oxfmt/binding-linux-riscv64-musl/-/binding-linux-riscv64-musl-0.35.0.tgz#38a68003a5c9d6ea16c1df110f7f520090ee9edb"
+ integrity sha512-C6yhY5Hvc2sGM+mCPek9ZLe5xRUOC/BvhAt2qIWFAeXMn4il04EYIjl3DsWiJr0xDMTJhvMOmD55xTRPlNp39w==
+
+"@oxfmt/binding-linux-s390x-gnu@0.35.0":
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/@oxfmt/binding-linux-s390x-gnu/-/binding-linux-s390x-gnu-0.35.0.tgz#e873740658ee915331a161d0c39742ae62d5b615"
+ integrity sha512-RG2hlvOMK4OMZpO3mt8MpxLQ0AAezlFqhn5mI/g5YrVbPFyoCv9a34AAvbSJS501ocOxlFIRcKEuw5hFvddf9g==
+
+"@oxfmt/binding-linux-x64-gnu@0.35.0":
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/@oxfmt/binding-linux-x64-gnu/-/binding-linux-x64-gnu-0.35.0.tgz#684ab3104126d51bbcc78c83a20e30040a08ffaf"
+ integrity sha512-wzmh90Pwvqj9xOKHJjkQYBpydRkaXG77ZvDz+iFDRRQpnqIEqGm5gmim2s6vnZIkDGsvKCuTdtxm0GFmBjM1+w==
+
+"@oxfmt/binding-linux-x64-musl@0.35.0":
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/@oxfmt/binding-linux-x64-musl/-/binding-linux-x64-musl-0.35.0.tgz#563eec158a656079d6e998c5f942f94584519498"
+ integrity sha512-+HCqYCJPCUy5I+b2cf+gUVaApfgtoQT3HdnSg/l7NIcLHOhKstlYaGyrFZLmUpQt4WkFbpGKZZayG6zjRU0KFA==
+
+"@oxfmt/binding-openharmony-arm64@0.35.0":
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/@oxfmt/binding-openharmony-arm64/-/binding-openharmony-arm64-0.35.0.tgz#2df29fa81fe4ada6ec9c01b5f2f6ce55e6a3e9d8"
+ integrity sha512-kFYmWfR9YL78XyO5ws+1dsxNvZoD973qfVMNFOS4e9bcHXGF7DvGC2tY5UDFwyMCeB33t3sDIuGONKggnVNSJA==
+
+"@oxfmt/binding-win32-arm64-msvc@0.35.0":
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/@oxfmt/binding-win32-arm64-msvc/-/binding-win32-arm64-msvc-0.35.0.tgz#0062c50efe08763b27a3d23c2419b3e8567fcea4"
+ integrity sha512-uD/NGdM65eKNCDGyTGdO8e9n3IHX+wwuorBvEYrPJXhDXL9qz6gzddmXH8EN04ejUXUujlq4FsoSeCfbg0Y+Jg==
+
+"@oxfmt/binding-win32-ia32-msvc@0.35.0":
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/@oxfmt/binding-win32-ia32-msvc/-/binding-win32-ia32-msvc-0.35.0.tgz#66fb1f23f140b4430f4a9537184a73c699c992a1"
+ integrity sha512-oSRD2k8J2uxYDEKR2nAE/YTY9PobOEnhZgCmspHu0+yBQ665yH8lFErQVSTE7fcGJmJp/cC6322/gc8VFuQf7g==
+
+"@oxfmt/binding-win32-x64-msvc@0.35.0":
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/@oxfmt/binding-win32-x64-msvc/-/binding-win32-x64-msvc-0.35.0.tgz#c343d54e063bb208e28bbf402195c21bae8d51dd"
+ integrity sha512-WCDJjlS95NboR0ugI2BEwzt1tYvRDorDRM9Lvctls1SLyKYuNRCyrPwp1urUPFBnwgBNn9p2/gnmo7gFMySRoQ==
+
+"@parcel/watcher-android-arm64@2.5.6":
+ version "2.5.6"
+ resolved "https://registry.yarnpkg.com/@parcel/watcher-android-arm64/-/watcher-android-arm64-2.5.6.tgz#5f32e0dba356f4ac9a11068d2a5c134ca3ba6564"
+ integrity sha512-YQxSS34tPF/6ZG7r/Ih9xy+kP/WwediEUsqmtf0cuCV5TPPKw/PQHRhueUo6JdeFJaqV3pyjm0GdYjZotbRt/A==
+
+"@parcel/watcher-darwin-arm64@2.5.6":
+ version "2.5.6"
+ resolved "https://registry.yarnpkg.com/@parcel/watcher-darwin-arm64/-/watcher-darwin-arm64-2.5.6.tgz#88d3e720b59b1eceffce98dac46d7c40e8be5e8e"
+ integrity sha512-Z2ZdrnwyXvvvdtRHLmM4knydIdU9adO3D4n/0cVipF3rRiwP+3/sfzpAwA/qKFL6i1ModaabkU7IbpeMBgiVEA==
+
+"@parcel/watcher-darwin-x64@2.5.6":
+ version "2.5.6"
+ resolved "https://registry.yarnpkg.com/@parcel/watcher-darwin-x64/-/watcher-darwin-x64-2.5.6.tgz#bf05d76a78bc15974f15ec3671848698b0838063"
+ integrity sha512-HgvOf3W9dhithcwOWX9uDZyn1lW9R+7tPZ4sug+NGrGIo4Rk1hAXLEbcH1TQSqxts0NYXXlOWqVpvS1SFS4fRg==
+
+"@parcel/watcher-freebsd-x64@2.5.6":
+ version "2.5.6"
+ resolved "https://registry.yarnpkg.com/@parcel/watcher-freebsd-x64/-/watcher-freebsd-x64-2.5.6.tgz#8bc26e9848e7303ac82922a5ae1b1ef1bdb48a53"
+ integrity sha512-vJVi8yd/qzJxEKHkeemh7w3YAn6RJCtYlE4HPMoVnCpIXEzSrxErBW5SJBgKLbXU3WdIpkjBTeUNtyBVn8TRng==
+
+"@parcel/watcher-linux-arm-glibc@2.5.6":
+ version "2.5.6"
+ resolved "https://registry.yarnpkg.com/@parcel/watcher-linux-arm-glibc/-/watcher-linux-arm-glibc-2.5.6.tgz#1328fee1deb0c2d7865079ef53a2ba4cc2f8b40a"
+ integrity sha512-9JiYfB6h6BgV50CCfasfLf/uvOcJskMSwcdH1PHH9rvS1IrNy8zad6IUVPVUfmXr+u+Km9IxcfMLzgdOudz9EQ==
+
+"@parcel/watcher-linux-arm-musl@2.5.6":
+ version "2.5.6"
+ resolved "https://registry.yarnpkg.com/@parcel/watcher-linux-arm-musl/-/watcher-linux-arm-musl-2.5.6.tgz#bad0f45cb3e2157746db8b9d22db6a125711f152"
+ integrity sha512-Ve3gUCG57nuUUSyjBq/MAM0CzArtuIOxsBdQ+ftz6ho8n7s1i9E1Nmk/xmP323r2YL0SONs1EuwqBp2u1k5fxg==
+
+"@parcel/watcher-linux-arm64-glibc@2.5.6":
+ version "2.5.6"
+ resolved "https://registry.yarnpkg.com/@parcel/watcher-linux-arm64-glibc/-/watcher-linux-arm64-glibc-2.5.6.tgz#b75913fbd501d9523c5f35d420957bf7d0204809"
+ integrity sha512-f2g/DT3NhGPdBmMWYoxixqYr3v/UXcmLOYy16Bx0TM20Tchduwr4EaCbmxh1321TABqPGDpS8D/ggOTaljijOA==
+
+"@parcel/watcher-linux-arm64-musl@2.5.6":
+ version "2.5.6"
+ resolved "https://registry.yarnpkg.com/@parcel/watcher-linux-arm64-musl/-/watcher-linux-arm64-musl-2.5.6.tgz#da5621a6a576070c8c0de60dea8b46dc9c3827d4"
+ integrity sha512-qb6naMDGlbCwdhLj6hgoVKJl2odL34z2sqkC7Z6kzir8b5W65WYDpLB6R06KabvZdgoHI/zxke4b3zR0wAbDTA==
+
+"@parcel/watcher-linux-x64-glibc@2.5.6":
+ version "2.5.6"
+ resolved "https://registry.yarnpkg.com/@parcel/watcher-linux-x64-glibc/-/watcher-linux-x64-glibc-2.5.6.tgz#ce437accdc4b30f93a090b4a221fd95cd9b89639"
+ integrity sha512-kbT5wvNQlx7NaGjzPFu8nVIW1rWqV780O7ZtkjuWaPUgpv2NMFpjYERVi0UYj1msZNyCzGlaCWEtzc+exjMGbQ==
+
+"@parcel/watcher-linux-x64-musl@2.5.6":
+ version "2.5.6"
+ resolved "https://registry.yarnpkg.com/@parcel/watcher-linux-x64-musl/-/watcher-linux-x64-musl-2.5.6.tgz#02400c54b4a67efcc7e2327b249711920ac969e2"
+ integrity sha512-1JRFeC+h7RdXwldHzTsmdtYR/Ku8SylLgTU/reMuqdVD7CtLwf0VR1FqeprZ0eHQkO0vqsbvFLXUmYm/uNKJBg==
+
+"@parcel/watcher-win32-arm64@2.5.6":
+ version "2.5.6"
+ resolved "https://registry.yarnpkg.com/@parcel/watcher-win32-arm64/-/watcher-win32-arm64-2.5.6.tgz#caae3d3c7583ca0a7171e6bd142c34d20ea1691e"
+ integrity sha512-3ukyebjc6eGlw9yRt678DxVF7rjXatWiHvTXqphZLvo7aC5NdEgFufVwjFfY51ijYEWpXbqF5jtrK275z52D4Q==
+
+"@parcel/watcher-win32-ia32@2.5.6":
+ version "2.5.6"
+ resolved "https://registry.yarnpkg.com/@parcel/watcher-win32-ia32/-/watcher-win32-ia32-2.5.6.tgz#9ac922550896dfe47bfc5ae3be4f1bcaf8155d6d"
+ integrity sha512-k35yLp1ZMwwee3Ez/pxBi5cf4AoBKYXj00CZ80jUz5h8prpiaQsiRPKQMxoLstNuqe2vR4RNPEAEcjEFzhEz/g==
+
+"@parcel/watcher-win32-x64@2.5.6":
+ version "2.5.6"
+ resolved "https://registry.yarnpkg.com/@parcel/watcher-win32-x64/-/watcher-win32-x64-2.5.6.tgz#73fdafba2e21c448f0e456bbe13178d8fe11739d"
+ integrity sha512-hbQlYcCq5dlAX9Qx+kFb0FHue6vbjlf0FrNzSKdYK2APUf7tGfGxQCk2ihEREmbR6ZMc0MVAD5RIX/41gpUzTw==
+
+"@parcel/watcher@^2.4.1":
+ version "2.5.6"
+ resolved "https://registry.yarnpkg.com/@parcel/watcher/-/watcher-2.5.6.tgz#3f932828c894f06d0ad9cfefade1756ecc6ef1f1"
+ integrity sha512-tmmZ3lQxAe/k/+rNnXQRawJ4NjxO2hqiOLTHvWchtGZULp4RyFeh6aU4XdOYBFe2KE1oShQTv4AblOs2iOrNnQ==
+ dependencies:
+ detect-libc "^2.0.3"
+ is-glob "^4.0.3"
+ node-addon-api "^7.0.0"
+ picomatch "^4.0.3"
+ optionalDependencies:
+ "@parcel/watcher-android-arm64" "2.5.6"
+ "@parcel/watcher-darwin-arm64" "2.5.6"
+ "@parcel/watcher-darwin-x64" "2.5.6"
+ "@parcel/watcher-freebsd-x64" "2.5.6"
+ "@parcel/watcher-linux-arm-glibc" "2.5.6"
+ "@parcel/watcher-linux-arm-musl" "2.5.6"
+ "@parcel/watcher-linux-arm64-glibc" "2.5.6"
+ "@parcel/watcher-linux-arm64-musl" "2.5.6"
+ "@parcel/watcher-linux-x64-glibc" "2.5.6"
+ "@parcel/watcher-linux-x64-musl" "2.5.6"
+ "@parcel/watcher-win32-arm64" "2.5.6"
+ "@parcel/watcher-win32-ia32" "2.5.6"
+ "@parcel/watcher-win32-x64" "2.5.6"
+
+"@pkgr/core@^0.2.9":
+ version "0.2.9"
+ resolved "https://registry.yarnpkg.com/@pkgr/core/-/core-0.2.9.tgz#d229a7b7f9dac167a156992ef23c7f023653f53b"
+ integrity sha512-QNqXyfVS2wm9hweSYD2O7F0G06uurj9kZ96TRQE5Y9hU7+tgdZwIkbAKc5Ocy1HxEY2kuDQa6cQ1WRs/O5LFKA==
+
+"@primeuix/styled@^0.7.4":
+ version "0.7.4"
+ resolved "https://registry.yarnpkg.com/@primeuix/styled/-/styled-0.7.4.tgz#d2108a7fad297dea60d549b2c10ed744dc0cbc0e"
+ integrity sha512-QSO/NpOQg8e9BONWRBx9y8VGMCMYz0J/uKfNJEya/RGEu7ARx0oYW0ugI1N3/KB1AAvyGxzKBzGImbwg0KUiOQ==
+ dependencies:
+ "@primeuix/utils" "^0.6.1"
+
+"@primeuix/styles@^2.0.3":
+ version "2.0.3"
+ resolved "https://registry.yarnpkg.com/@primeuix/styles/-/styles-2.0.3.tgz#e42d14c138fe092683228d65a3f6de17de70d6a0"
+ integrity sha512-2ykAB6BaHzR/6TwF8ShpJTsZrid6cVIEBVlookSdvOdmlWuevGu5vWOScgIwqWwlZcvkFYAGR/SUV3OHCTBMdw==
+ dependencies:
+ "@primeuix/styled" "^0.7.4"
+
+"@primeuix/utils@^0.6.1", "@primeuix/utils@^0.6.2":
+ version "0.6.4"
+ resolved "https://registry.yarnpkg.com/@primeuix/utils/-/utils-0.6.4.tgz#f436eae1be166662d424b8550a97ba0c150819e6"
+ integrity sha512-pZ5f+vj7wSzRhC7KoEQRU5fvYAe+RP9+m39CTscZ3UywCD1Y2o6Fe1rRgklMPSkzUcty2jzkA0zMYkiJBD1hgg==
+
+"@primevue/core@4.5.5":
+ version "4.5.5"
+ resolved "https://registry.yarnpkg.com/@primevue/core/-/core-4.5.5.tgz#c450314a6e891f9840c915ccace3055e84d03087"
+ integrity sha512-JpkXhq1ddc70JdsC3CC4dM+UbeeWuCW/8DpS9dNBfrOk824TLSlRlMEGFyVKqRMn5WPQvYLiy3xXfLQeNdSqhQ==
+ dependencies:
+ "@primeuix/styled" "^0.7.4"
+ "@primeuix/utils" "^0.6.2"
+
+"@primevue/icons@4.5.5":
+ version "4.5.5"
+ resolved "https://registry.yarnpkg.com/@primevue/icons/-/icons-4.5.5.tgz#282702f4a21393a9bbde2b326efe1454169f1365"
+ integrity sha512-eteOhTdAOXEYE9qW1AOrBBgDxQ2szHJxSkEK1XVdV2TKxGM5FQf03Ovms0VDyZTc16XBIgvwYjXJQS0BPbhPaA==
+ dependencies:
+ "@primeuix/utils" "^0.6.2"
+ "@primevue/core" "4.5.5"
+
+"@rolldown/binding-android-arm64@1.0.0-rc.17":
+ version "1.0.0-rc.17"
+ resolved "https://registry.yarnpkg.com/@rolldown/binding-android-arm64/-/binding-android-arm64-1.0.0-rc.17.tgz#0a502a88c39d0ffa81aa30b561dade6f6217dcc5"
+ integrity sha512-s70pVGhw4zqGeFnXWvAzJDlvxhlRollagdCCKRgOsgUOH3N1l0LIxf83AtGzmb5SiVM4Hjl5HyarMRfdfj3DaQ==
+
+"@rolldown/binding-darwin-arm64@1.0.0-rc.17":
+ version "1.0.0-rc.17"
+ resolved "https://registry.yarnpkg.com/@rolldown/binding-darwin-arm64/-/binding-darwin-arm64-1.0.0-rc.17.tgz#8b7f05ac9000ab19161a79a0346b1b64a1bc7ba3"
+ integrity sha512-4ksWc9n0mhlZpZ9PMZgTGjeOPRu8MB1Z3Tz0Mo02eWfWCHMW1zN82Qz/pL/rC+yQa+8ZnutMF0JjJe7PjwasYw==
+
+"@rolldown/binding-darwin-x64@1.0.0-rc.17":
+ version "1.0.0-rc.17"
+ resolved "https://registry.yarnpkg.com/@rolldown/binding-darwin-x64/-/binding-darwin-x64-1.0.0-rc.17.tgz#f8b465b3a4e992053890b162f1ae19e4f1719a6a"
+ integrity sha512-SUSDOI6WwUVNcWxd02QEBjLdY1VPHvlEkw6T/8nYG322iYWCTxRb1vzk4E+mWWYehTp7ERibq54LSJGjmouOsw==
+
+"@rolldown/binding-freebsd-x64@1.0.0-rc.17":
+ version "1.0.0-rc.17"
+ resolved "https://registry.yarnpkg.com/@rolldown/binding-freebsd-x64/-/binding-freebsd-x64-1.0.0-rc.17.tgz#a8281e14fa9c243fe22dc2d0e54900e66b31935e"
+ integrity sha512-hwnz3nw9dbJ05EDO/PvcjaaewqqDy7Y1rn1UO81l8iIK1GjenME75dl16ajbvSSMfv66WXSRCYKIqfgq2KCfxw==
+
+"@rolldown/binding-linux-arm-gnueabihf@1.0.0-rc.17":
+ version "1.0.0-rc.17"
+ resolved "https://registry.yarnpkg.com/@rolldown/binding-linux-arm-gnueabihf/-/binding-linux-arm-gnueabihf-1.0.0-rc.17.tgz#cd29cf869ddd4fac8d6929abf94b91ddb0494650"
+ integrity sha512-IS+W7epTcwANmFSQFrS1SivEXHtl1JtuQA9wlxrZTcNi6mx+FDOYrakGevvvTwgj2JvWiK8B29/qD9BELZPyXQ==
+
+"@rolldown/binding-linux-arm64-gnu@1.0.0-rc.17":
+ version "1.0.0-rc.17"
+ resolved "https://registry.yarnpkg.com/@rolldown/binding-linux-arm64-gnu/-/binding-linux-arm64-gnu-1.0.0-rc.17.tgz#91c331236ec3728366218d61a62f0bd226546c6c"
+ integrity sha512-e6usGaHKW5BMNZOymS1UcEYGowQMWcgZ71Z17Sl/h2+ZziNJ1a9n3Zvcz6LdRyIW5572wBCTH/Z+bKuZouGk9Q==
+
+"@rolldown/binding-linux-arm64-musl@1.0.0-rc.17":
+ version "1.0.0-rc.17"
+ resolved "https://registry.yarnpkg.com/@rolldown/binding-linux-arm64-musl/-/binding-linux-arm64-musl-1.0.0-rc.17.tgz#80108957db752e7826836e22240e56b8140e9684"
+ integrity sha512-b/CgbwAJpmrRLp02RPfhbudf5tZnN9nsPWK82znefso832etkem8H7FSZwxrOI9djcdTP7U6YfNhbRnh7djErg==
+
+"@rolldown/binding-linux-ppc64-gnu@1.0.0-rc.17":
+ version "1.0.0-rc.17"
+ resolved "https://registry.yarnpkg.com/@rolldown/binding-linux-ppc64-gnu/-/binding-linux-ppc64-gnu-1.0.0-rc.17.tgz#1dce51148cbc6bab3c3f9157b5323d2a31aac924"
+ integrity sha512-4EII1iNGRUN5WwGbF/kOh/EIkoDN9HsupgLQoXfY+D1oyJm7/F4t5PYU5n8SWZgG0FEwakyM8pGgwcBYruGTlA==
+
+"@rolldown/binding-linux-s390x-gnu@1.0.0-rc.17":
+ version "1.0.0-rc.17"
+ resolved "https://registry.yarnpkg.com/@rolldown/binding-linux-s390x-gnu/-/binding-linux-s390x-gnu-1.0.0-rc.17.tgz#d4a0d2e01d8d441e4ac3af3fa68eec17a7d0e9cd"
+ integrity sha512-AH8oq3XqQo4IibpVXvPeLDI5pzkpYn0WiZAfT05kFzoJ6tQNzwRdDYQ45M8I/gslbodRZwW8uxLhbSBbkv96rA==
+
+"@rolldown/binding-linux-x64-gnu@1.0.0-rc.17":
+ version "1.0.0-rc.17"
+ resolved "https://registry.yarnpkg.com/@rolldown/binding-linux-x64-gnu/-/binding-linux-x64-gnu-1.0.0-rc.17.tgz#0ac8b3139cefeea798ad147f30ea70572b133af1"
+ integrity sha512-cLnjV3xfo7KslbU41Z7z8BH/E1y5mzUYzAqih1d1MDaIGZRCMqTijqLv76/P7fyHuvUcfGsIpqCdddbxLLK9rA==
+
+"@rolldown/binding-linux-x64-musl@1.0.0-rc.17":
+ version "1.0.0-rc.17"
+ resolved "https://registry.yarnpkg.com/@rolldown/binding-linux-x64-musl/-/binding-linux-x64-musl-1.0.0-rc.17.tgz#2af61bee087571728f58f1c47734bbbd41dd7050"
+ integrity sha512-0phclDw1spsL7dUB37sIARuis2tAgomCJXAHZlpt8PXZ4Ba0dRP1e+66lsRqrfhISeN9bEGNjQs+T/Fbd7oYGw==
+
+"@rolldown/binding-openharmony-arm64@1.0.0-rc.17":
+ version "1.0.0-rc.17"
+ resolved "https://registry.yarnpkg.com/@rolldown/binding-openharmony-arm64/-/binding-openharmony-arm64-1.0.0-rc.17.tgz#56c1afbf6c592819abf47b4a983987dc288b30c1"
+ integrity sha512-0ag/hEgXOwgw4t8QyQvUCxvEg+V0KBcA6YuOx9g0r02MprutRF5dyljgm3EmR02O292UX7UeS6HzWHAl6KgyhA==
+
+"@rolldown/binding-wasm32-wasi@1.0.0-rc.17":
+ version "1.0.0-rc.17"
+ resolved "https://registry.yarnpkg.com/@rolldown/binding-wasm32-wasi/-/binding-wasm32-wasi-1.0.0-rc.17.tgz#5d112ff4dd0d268a60fb4e0eb3077e3ea2531f0d"
+ integrity sha512-LEXei6vo0E5wTGwpkJ4KoT3OZJRnglwldt5ziLzOlc6qqb55z4tWNq2A+PFqCJuvWWdP53CVhG1Z9NtToDPJrA==
+ dependencies:
+ "@emnapi/core" "1.10.0"
+ "@emnapi/runtime" "1.10.0"
+ "@napi-rs/wasm-runtime" "^1.1.4"
+
+"@rolldown/binding-win32-arm64-msvc@1.0.0-rc.17":
+ version "1.0.0-rc.17"
+ resolved "https://registry.yarnpkg.com/@rolldown/binding-win32-arm64-msvc/-/binding-win32-arm64-msvc-1.0.0-rc.17.tgz#5125a85222d64a543201d28e16a395cc45bf4d17"
+ integrity sha512-gUmyzBl3SPMa6hrqFUth9sVfcLBlYsbMzBx5PlexMroZStgzGqlZ26pYG89rBb45Mnia+oil6YAIFeEWGWhoZA==
+
+"@rolldown/binding-win32-x64-msvc@1.0.0-rc.17":
+ version "1.0.0-rc.17"
+ resolved "https://registry.yarnpkg.com/@rolldown/binding-win32-x64-msvc/-/binding-win32-x64-msvc-1.0.0-rc.17.tgz#fc6b78e759a0bb2054b5c0a3489da12b2cae54b4"
+ integrity sha512-3hkiolcUAvPB9FLb3UZdfjVVNWherN1f/skkGWJP/fgSQhYUZpSIRr0/I8ZK9TkF3F7kxvJAk0+IcKvPHk9qQg==
+
+"@rolldown/pluginutils@1.0.0-rc.13":
+ version "1.0.0-rc.13"
+ resolved "https://registry.yarnpkg.com/@rolldown/pluginutils/-/pluginutils-1.0.0-rc.13.tgz#093a01af0cde13552f058544fcadf12e9b522c3b"
+ integrity sha512-3ngTAv6F/Py35BsYbeeLeecvhMKdsKm4AoOETVhAA+Qc8nrA2I0kF7oa93mE9qnIurngOSpMnQ0x2nQY2FPviA==
+
+"@rolldown/pluginutils@1.0.0-rc.17":
+ version "1.0.0-rc.17"
+ resolved "https://registry.yarnpkg.com/@rolldown/pluginutils/-/pluginutils-1.0.0-rc.17.tgz#a89b30833fb628bc834fe2e89fea93a2da9fa69a"
+ integrity sha512-n8iosDOt6Ig1UhJ2AYqoIhHWh/isz0xpicHTzpKBeotdVsTEcxsSA/i3EVM7gQAj0rU27OLAxCjzlj15IWY7bg==
+
+"@sindresorhus/base62@^1.0.0":
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/@sindresorhus/base62/-/base62-1.0.0.tgz#c47c42410e5212e4fa4657670e118ddfba39acd6"
+ integrity sha512-TeheYy0ILzBEI/CO55CP6zJCSdSWeRtGnHy8U8dWSUH4I68iqTsy7HkMktR4xakThc9jotkPQUXT4ITdbV7cHA==
+
+"@stylistic/eslint-plugin@^5.10.0":
+ version "5.10.0"
+ resolved "https://registry.yarnpkg.com/@stylistic/eslint-plugin/-/eslint-plugin-5.10.0.tgz#471bbd9f7a27ceaac4a217e7f5b3890855e5640c"
+ integrity sha512-nPK52ZHvot8Ju/0A4ucSX1dcPV2/1clx0kLcH5wDmrE4naKso7TUC/voUyU1O9OTKTrR6MYip6LP0ogEMQ9jPQ==
+ dependencies:
+ "@eslint-community/eslint-utils" "^4.9.1"
+ "@typescript-eslint/types" "^8.56.0"
+ eslint-visitor-keys "^4.2.1"
+ espree "^10.4.0"
+ estraverse "^5.3.0"
+ picomatch "^4.0.3"
+
+"@swc/helpers@^0.5.0":
+ version "0.5.21"
+ resolved "https://registry.yarnpkg.com/@swc/helpers/-/helpers-0.5.21.tgz#0b1b020317ee1282860ca66f7e9a7c7790f05ae0"
+ integrity sha512-jI/VAmtdjB/RnI8GTnokyX7Ug8c+g+ffD6QRLa6XQewtnGyukKkKSk3wLTM3b5cjt1jNh9x0jfVlagdN2gDKQg==
+ dependencies:
+ tslib "^2.8.0"
+
+"@tauri-apps/api@^2.10.1", "@tauri-apps/api@^2.11.0", "@tauri-apps/api@^2.8.0":
+ version "2.11.0"
+ resolved "https://registry.yarnpkg.com/@tauri-apps/api/-/api-2.11.0.tgz#00fb69996010178a5153798d4a84f6fe3a1e1182"
+ integrity sha512-7CinYODhky9lmO23xHnUFv0Xt43fbtWMyxZcLcRBlFkcgXKuEirBvHpmtJ89YMhyeGcq20Wuc47Fa4XjyniywA==
+
+"@tauri-apps/cli-darwin-arm64@2.11.1":
+ version "2.11.1"
+ resolved "https://registry.yarnpkg.com/@tauri-apps/cli-darwin-arm64/-/cli-darwin-arm64-2.11.1.tgz#4fc2e2165cde2d71bb9a56beacb75542ceb7dc0e"
+ integrity sha512-6eEKMBXsQPCuM1EmvrjT2+aBuxWQuFdKdW8pzNuNQtpq45nEEpBlD5gr8pUeAyOU1DQKlkFaEc/MPBxb/Pfjtg==
+
+"@tauri-apps/cli-darwin-x64@2.11.1":
+ version "2.11.1"
+ resolved "https://registry.yarnpkg.com/@tauri-apps/cli-darwin-x64/-/cli-darwin-x64-2.11.1.tgz#dfea5d1448bd7f4dae5c6483c6f21ab6df53e9c7"
+ integrity sha512-LQUO7exfRWjWALNhetph5guWpMeHphRpokOLk0OIbTTExaNwJNFu3I4vb+CCM/4G/QGoZe/5XikZOJdNEFP1ig==
+
+"@tauri-apps/cli-linux-arm-gnueabihf@2.11.1":
+ version "2.11.1"
+ resolved "https://registry.yarnpkg.com/@tauri-apps/cli-linux-arm-gnueabihf/-/cli-linux-arm-gnueabihf-2.11.1.tgz#fd054d074fe1dc7a24e589957e11e8bb1f3bfe90"
+ integrity sha512-5i/awiBCRRhOUG8yjn0fMHXIWD5Ez8eEk5LtvOxyQrKuJkRaZDvnbIjZbE183blAwkoA4xN3aO/prJiqscl02Q==
+
+"@tauri-apps/cli-linux-arm64-gnu@2.11.1":
+ version "2.11.1"
+ resolved "https://registry.yarnpkg.com/@tauri-apps/cli-linux-arm64-gnu/-/cli-linux-arm64-gnu-2.11.1.tgz#13d068385371de50cc876713ded71975a268a3be"
+ integrity sha512-9LrwDw3S9Fygtw/Q6WDhOP+3svJRGAsejeE+GKrc0eO1ThMVhwi2LL6hw4dlKw93IfS7VY1G19sWGxJ/NcU4nA==
+
+"@tauri-apps/cli-linux-arm64-musl@2.11.1":
+ version "2.11.1"
+ resolved "https://registry.yarnpkg.com/@tauri-apps/cli-linux-arm64-musl/-/cli-linux-arm64-musl-2.11.1.tgz#a3ff5b2abffd4ef0ba0169ecfceecf71b14e2312"
+ integrity sha512-mNA5dbbqPqDUdTIwdUYYuhO2GvIe9UnB2r0VU2njxBOS3Opbx4gKNC5yP0Iu4rYmEmqdlwry9VzGZQ3wq9dyFg==
+
+"@tauri-apps/cli-linux-riscv64-gnu@2.11.1":
+ version "2.11.1"
+ resolved "https://registry.yarnpkg.com/@tauri-apps/cli-linux-riscv64-gnu/-/cli-linux-riscv64-gnu-2.11.1.tgz#708711c15705dca13f51fb1ee45a16a6fccac809"
+ integrity sha512-fZj3Gwq+6fUs305T5WQiD5iSGJw+j/4w/HGmk4sHDAcy+rp9zU5eaxB7nOyz5/I/nkNAuKPqfp6uIbiUBXkBCw==
+
+"@tauri-apps/cli-linux-x64-gnu@2.11.1":
+ version "2.11.1"
+ resolved "https://registry.yarnpkg.com/@tauri-apps/cli-linux-x64-gnu/-/cli-linux-x64-gnu-2.11.1.tgz#c59b7d54aeb8d3d0975e99eaee121d6ac51fd898"
+ integrity sha512-XFxGxOvHM7jjeD6ozCKdGfhzJ7lERYDGZl1/Kb4fsvchaJsfLJ981TlyTG8Qy/gFq+f5GitH3bfrX9JAkjPEyw==
+
+"@tauri-apps/cli-linux-x64-musl@2.11.1":
+ version "2.11.1"
+ resolved "https://registry.yarnpkg.com/@tauri-apps/cli-linux-x64-musl/-/cli-linux-x64-musl-2.11.1.tgz#1df5392521893d199b49b31466ebf7d36bb262a0"
+ integrity sha512-d5C2/Zm+68v7R9wTuTCjRQEVrWjcdMkJBZ1+rXse+QdMMlTB9+u9PDNDLw9PQflWxYLaYZ7tjxxL9Nb9II6PbA==
+
+"@tauri-apps/cli-win32-arm64-msvc@2.11.1":
+ version "2.11.1"
+ resolved "https://registry.yarnpkg.com/@tauri-apps/cli-win32-arm64-msvc/-/cli-win32-arm64-msvc-2.11.1.tgz#f28fccdaabc63d76d820a4b46173f387069c5851"
+ integrity sha512-YdeVWFAR1pTXzUU6NLstPq4G6OLxuDrXCXEBdmBH+5EZIDXUx0D2kJlz3+YjpazkKvAzYpgziTsyRagls0OfRQ==
+
+"@tauri-apps/cli-win32-ia32-msvc@2.11.1":
+ version "2.11.1"
+ resolved "https://registry.yarnpkg.com/@tauri-apps/cli-win32-ia32-msvc/-/cli-win32-ia32-msvc-2.11.1.tgz#85d0261420ed790fef3f344ca935a743dc43977e"
+ integrity sha512-VBGkuH0eB9K9LLSMv361Gzr5Ou72sCS4+ztpmkWEQ+wd/amhcYOsf3X6qn1RJZDzIhiOYHJEOysZUC3baD01rA==
+
+"@tauri-apps/cli-win32-x64-msvc@2.11.1":
+ version "2.11.1"
+ resolved "https://registry.yarnpkg.com/@tauri-apps/cli-win32-x64-msvc/-/cli-win32-x64-msvc-2.11.1.tgz#78e631ef50dd47f992eb2a4ae83b9bf8781b251f"
+ integrity sha512-b3ORhIAKgp9ZYY+zBt7b7r0kLU2kjvyGF0+MS2SBym3emsweGPybEqocJcmtMuxyBhkOKHP4CiuEJEDuAlTx6A==
+
+"@tauri-apps/cli@^2.8.4":
+ version "2.11.1"
+ resolved "https://registry.yarnpkg.com/@tauri-apps/cli/-/cli-2.11.1.tgz#46493afee700baadf0209bc879069485aa9525f3"
+ integrity sha512-rpEbaJ/HzNb6fwsquwoAbq29/Vt4gADhS423A8fdkwL4edJ0wZmoB8ar7O6JPDL834MUKOCm/rrJ7c9oAaEaYQ==
+ optionalDependencies:
+ "@tauri-apps/cli-darwin-arm64" "2.11.1"
+ "@tauri-apps/cli-darwin-x64" "2.11.1"
+ "@tauri-apps/cli-linux-arm-gnueabihf" "2.11.1"
+ "@tauri-apps/cli-linux-arm64-gnu" "2.11.1"
+ "@tauri-apps/cli-linux-arm64-musl" "2.11.1"
+ "@tauri-apps/cli-linux-riscv64-gnu" "2.11.1"
+ "@tauri-apps/cli-linux-x64-gnu" "2.11.1"
+ "@tauri-apps/cli-linux-x64-musl" "2.11.1"
+ "@tauri-apps/cli-win32-arm64-msvc" "2.11.1"
+ "@tauri-apps/cli-win32-ia32-msvc" "2.11.1"
+ "@tauri-apps/cli-win32-x64-msvc" "2.11.1"
+
+"@tauri-apps/plugin-global-shortcut@^2.3.1":
+ version "2.3.1"
+ resolved "https://registry.yarnpkg.com/@tauri-apps/plugin-global-shortcut/-/plugin-global-shortcut-2.3.1.tgz#c9c7a3db688eaaac2e1a9e22a37beb60004f2ed5"
+ integrity sha512-vr40W2N6G63dmBPaha1TsBQLLURXG538RQbH5vAm0G/ovVZyXJrmZR1HF1W+WneNloQvwn4dm8xzwpEXRW560g==
+ dependencies:
+ "@tauri-apps/api" "^2.8.0"
+
+"@tauri-apps/plugin-opener@~2":
+ version "2.5.4"
+ resolved "https://registry.yarnpkg.com/@tauri-apps/plugin-opener/-/plugin-opener-2.5.4.tgz#b37883e4d36125b8c5a0c74f683395958a65bd7d"
+ integrity sha512-1HnPkb+AmgO29HBazm4uPLKB+r7zzcTBW1d0fyYp1uP+jwtpoiNDGKMMzz58SFp49nOIrxdE3aUJtT57lfO9CQ==
+ dependencies:
+ "@tauri-apps/api" "^2.11.0"
+
+"@tauri-apps/plugin-process@^2.3.1":
+ version "2.3.1"
+ resolved "https://registry.yarnpkg.com/@tauri-apps/plugin-process/-/plugin-process-2.3.1.tgz#fff77aa7550c9c5347689c859d581f88287bf7ae"
+ integrity sha512-nCa4fGVaDL/B9ai03VyPOjfAHRHSBz5v6F/ObsB73r/dA3MHHhZtldaDMIc0V/pnUw9ehzr2iEG+XkSEyC0JJA==
+ dependencies:
+ "@tauri-apps/api" "^2.8.0"
+
+"@tauri-apps/plugin-updater@^2.10.1":
+ version "2.10.1"
+ resolved "https://registry.yarnpkg.com/@tauri-apps/plugin-updater/-/plugin-updater-2.10.1.tgz#ea0efd766890394b6c719b9fc21de7da0029c69c"
+ integrity sha512-NFYMg+tWOZPJdzE/PpFj2qfqwAWwNS3kXrb1tm1gnBJ9mYzZ4WDRrwy8udzWoAnfGCHLuePNLY1WVCNHnh3eRA==
+ dependencies:
+ "@tauri-apps/api" "^2.10.1"
+
+"@tybys/wasm-util@^0.10.1":
+ version "0.10.2"
+ resolved "https://registry.yarnpkg.com/@tybys/wasm-util/-/wasm-util-0.10.2.tgz#12b3a1b33db1f9cad4ddff1f604ab7dd00bf464e"
+ integrity sha512-RoBvJ2X0wuKlWFIjrwffGw1IqZHKQqzIchKaadZZfnNpsAYp2mM0h36JtPCjNDAHGgYez/15uMBpfGwchhiMgg==
+ dependencies:
+ tslib "^2.4.0"
+
+"@types/debug@^4.0.0":
+ version "4.1.13"
+ resolved "https://registry.yarnpkg.com/@types/debug/-/debug-4.1.13.tgz#22d1cc9d542d3593caea764f974306ab36286ee7"
+ integrity sha512-KSVgmQmzMwPlmtljOomayoR89W4FynCAi3E8PPs7vmDVPe84hT+vGPKkJfThkmXs0x0jAaa9U8uW8bbfyS2fWw==
+ dependencies:
+ "@types/ms" "*"
+
+"@types/esrecurse@^4.3.1":
+ version "4.3.1"
+ resolved "https://registry.yarnpkg.com/@types/esrecurse/-/esrecurse-4.3.1.tgz#6f636af962fbe6191b830bd676ba5986926bccec"
+ integrity sha512-xJBAbDifo5hpffDBuHl0Y8ywswbiAp/Wi7Y/GtAgSlZyIABppyurxVueOPE8LUQOxdlgi6Zqce7uoEpqNTeiUw==
+
+"@types/estree@^1.0.6", "@types/estree@^1.0.8":
+ version "1.0.8"
+ resolved "https://registry.yarnpkg.com/@types/estree/-/estree-1.0.8.tgz#958b91c991b1867ced318bedea0e215ee050726e"
+ integrity sha512-dWHzHa2WqEXI/O1E9OjrocMTKJl2mSrEolh1Iomrv6U+JuNwaHXsXx9bLu5gG7BUWFIN0skIQJQ/L1rIex4X6w==
+
+"@types/hast@^3.0.0":
+ version "3.0.4"
+ resolved "https://registry.yarnpkg.com/@types/hast/-/hast-3.0.4.tgz#1d6b39993b82cea6ad783945b0508c25903e15aa"
+ integrity sha512-WPs+bbQw5aCj+x6laNGWLH3wviHtoCv/P3+otBhbOhJgG8qtpdAMlTCxLtsTWA7LH1Oh/bFCHsBn0TPS5m30EQ==
+ dependencies:
+ "@types/unist" "*"
+
+"@types/json-schema@^7.0.15":
+ version "7.0.15"
+ resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.15.tgz#596a1747233694d50f6ad8a7869fcb6f56cf5841"
+ integrity sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==
+
+"@types/katex@^0.16.0":
+ version "0.16.8"
+ resolved "https://registry.yarnpkg.com/@types/katex/-/katex-0.16.8.tgz#80bf3e0814d09a846412a0b0f140946b79c36c3e"
+ integrity sha512-trgaNyfU+Xh2Tc+ABIb44a5AYUpicB3uwirOioeOkNPPbmgRNtcWyDeeFRzjPZENO9Vq8gvVqfhaaXWLlevVwg==
+
+"@types/mdast@^4.0.0":
+ version "4.0.4"
+ resolved "https://registry.yarnpkg.com/@types/mdast/-/mdast-4.0.4.tgz#7ccf72edd2f1aa7dd3437e180c64373585804dd6"
+ integrity sha512-kGaNbPh1k7AFzgpud/gMdvIm5xuECykRR+JnWKQno9TAXVa6WIVCGTPvYGekIDL4uwCZQSYbUxNBSb1aUo79oA==
+ dependencies:
+ "@types/unist" "*"
+
+"@types/ms@*":
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/@types/ms/-/ms-2.1.0.tgz#052aa67a48eccc4309d7f0191b7e41434b90bb78"
+ integrity sha512-GsCCIZDE/p3i96vtEqx+7dBUGXrc7zeSK3wwPHIaRThS+9OhWIXRqzs4d6k1SVU8g91DrNRWxWUGhp5KXQb2VA==
+
+"@types/node@^24.12.2":
+ version "24.12.2"
+ resolved "https://registry.yarnpkg.com/@types/node/-/node-24.12.2.tgz#353cb161dbf1785ea25e8829ba7ec574c5c629ac"
+ integrity sha512-A1sre26ke7HDIuY/M23nd9gfB+nrmhtYyMINbjI1zHJxYteKR6qSMX56FsmjMcDb3SMcjJg5BiRRgOCC/yBD0g==
+ dependencies:
+ undici-types "~7.16.0"
+
+"@types/unist@*", "@types/unist@^3.0.0":
+ version "3.0.3"
+ resolved "https://registry.yarnpkg.com/@types/unist/-/unist-3.0.3.tgz#acaab0f919ce69cce629c2d4ed2eb4adc1b6c20c"
+ integrity sha512-ko/gIFJRv177XgZsZcBwnqJN5x/Gien8qNOn0D5bQU/zAzVf9Zt3BlcUiLqhV9y4ARk0GbT3tnUiPNgnTXzc/Q==
+
+"@types/web-bluetooth@^0.0.21":
+ version "0.0.21"
+ resolved "https://registry.yarnpkg.com/@types/web-bluetooth/-/web-bluetooth-0.0.21.tgz#525433c784aed9b457aaa0ee3d92aeb71f346b63"
+ integrity sha512-oIQLCGWtcFZy2JW77j9k8nHzAOpqMHLQejDA48XXMWH6tjCQHz5RCFz1bzsmROyL6PUm+LLnUiI4BCn221inxA==
+
+"@typescript-eslint/eslint-plugin@^8.58.1":
+ version "8.59.2"
+ resolved "https://registry.yarnpkg.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-8.59.2.tgz#f37b2c189a0177141fe3de3b08f2a83991bfdbfa"
+ integrity sha512-j/bwmkBvHUtPNxzuWe5z6BEk3q54YRyGlBXkSsmfoih7zNrBvl5A9A98anlp/7JbyZcWIJ8KXo/3Tq/DjFLtuQ==
+ dependencies:
+ "@eslint-community/regexpp" "^4.12.2"
+ "@typescript-eslint/scope-manager" "8.59.2"
+ "@typescript-eslint/type-utils" "8.59.2"
+ "@typescript-eslint/utils" "8.59.2"
+ "@typescript-eslint/visitor-keys" "8.59.2"
+ ignore "^7.0.5"
+ natural-compare "^1.4.0"
+ ts-api-utils "^2.5.0"
+
+"@typescript-eslint/parser@^8.58.1":
+ version "8.59.2"
+ resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-8.59.2.tgz#e2fd0084baa5dd0c24cd789af1c72cbc3a7a1c62"
+ integrity sha512-plR3pp6D+SSUn1HM7xvSkx12/DhoHInI2YF35KAcVFNZvlC0gtrWqx7Qq1oH2Ssgi0vlFRCTbP+DZc7B9+TtsQ==
+ dependencies:
+ "@typescript-eslint/scope-manager" "8.59.2"
+ "@typescript-eslint/types" "8.59.2"
+ "@typescript-eslint/typescript-estree" "8.59.2"
+ "@typescript-eslint/visitor-keys" "8.59.2"
+ debug "^4.4.3"
+
+"@typescript-eslint/project-service@8.59.2":
+ version "8.59.2"
+ resolved "https://registry.yarnpkg.com/@typescript-eslint/project-service/-/project-service-8.59.2.tgz#f8b8cbf8692e3a51c2c394acf8cf6900f7e755af"
+ integrity sha512-+2hqvEkeyf/0FBor67duF0Ll7Ot8jyKzDQOSrxazF/danillRq2DwR9dLptsXpoZQqxE1UisSmoZewrlPas9Vw==
+ dependencies:
+ "@typescript-eslint/tsconfig-utils" "^8.59.2"
+ "@typescript-eslint/types" "^8.59.2"
+ debug "^4.4.3"
+
+"@typescript-eslint/scope-manager@8.59.2", "@typescript-eslint/scope-manager@^8.58.0":
+ version "8.59.2"
+ resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-8.59.2.tgz#63cbd0af2e3180949d6be81122cc555bc71e736d"
+ integrity sha512-JzfyEpEtOU89CcFSwyNS3mu4MLvLSXqnmX05+aKBDM+TdR5jzcGOEBwxwGNxrEQ7p/z6kK2WyioCGBf2zZBnvg==
+ dependencies:
+ "@typescript-eslint/types" "8.59.2"
+ "@typescript-eslint/visitor-keys" "8.59.2"
+
+"@typescript-eslint/tsconfig-utils@8.59.2", "@typescript-eslint/tsconfig-utils@^8.59.2":
+ version "8.59.2"
+ resolved "https://registry.yarnpkg.com/@typescript-eslint/tsconfig-utils/-/tsconfig-utils-8.59.2.tgz#6e92bc412083753185a79c9f1431e78169d9232f"
+ integrity sha512-BKK4alN7oi4C/zv4VqHQ+uRU+lTa6JGIZ7s1juw7b3RHo9OfKB+bKX3u0iVZetdsUCBBkSbdWbarJbmN0fTeSw==
+
+"@typescript-eslint/type-utils@8.59.2":
+ version "8.59.2"
+ resolved "https://registry.yarnpkg.com/@typescript-eslint/type-utils/-/type-utils-8.59.2.tgz#a60a1192a804fa472a92c41656853ac6a9ba7176"
+ integrity sha512-nhqaj1nmTdVVl/BP5omXNRGO38jn5iosis2vbdmupF2txCf8ylWT8lx+JlvMYYVqzGVKtjojUFoQ3JRWK+mfzQ==
+ dependencies:
+ "@typescript-eslint/types" "8.59.2"
+ "@typescript-eslint/typescript-estree" "8.59.2"
+ "@typescript-eslint/utils" "8.59.2"
+ debug "^4.4.3"
+ ts-api-utils "^2.5.0"
+
+"@typescript-eslint/types@8.59.2", "@typescript-eslint/types@^8.54.0", "@typescript-eslint/types@^8.56.0", "@typescript-eslint/types@^8.58.0", "@typescript-eslint/types@^8.59.2":
+ version "8.59.2"
+ resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-8.59.2.tgz#01caabcd7e4715c33ad5e11cab260829714d6b9c"
+ integrity sha512-e82GVOE8Ps3E++Egvb6Y3Dw0S10u8NkQ9KXmtRhCWJJ8kDhOJTvtMAWnFL16kB1583goCWXsr0NieKCZMs2/0Q==
+
+"@typescript-eslint/typescript-estree@8.59.2":
+ version "8.59.2"
+ resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-8.59.2.tgz#6a217ef65b18dbd12c718fc86a675d1d7a1414cc"
+ integrity sha512-o0XPGNwcWw+FIwStOWn+BwBuEmL6QXP0rsvAFg7ET1dey1Nr6Wb1ac8p5HEsK0ygO/6mUxlk+YWQD9xcb/nnXg==
+ dependencies:
+ "@typescript-eslint/project-service" "8.59.2"
+ "@typescript-eslint/tsconfig-utils" "8.59.2"
+ "@typescript-eslint/types" "8.59.2"
+ "@typescript-eslint/visitor-keys" "8.59.2"
+ debug "^4.4.3"
+ minimatch "^10.2.2"
+ semver "^7.7.3"
+ tinyglobby "^0.2.15"
+ ts-api-utils "^2.5.0"
+
+"@typescript-eslint/utils@8.59.2", "@typescript-eslint/utils@^8.58.0", "@typescript-eslint/utils@^8.58.2":
+ version "8.59.2"
+ resolved "https://registry.yarnpkg.com/@typescript-eslint/utils/-/utils-8.59.2.tgz#ff619a6a3075f4017fa91b8610b752a8ca3366aa"
+ integrity sha512-Juw3EinkXqjaffxz6roowvV7GZT/kET5vSKKZT6upl5TXdWkLkYmNPXwDDL2Vkt2DPn0nODIS4egC/0AGxKo/Q==
+ dependencies:
+ "@eslint-community/eslint-utils" "^4.9.1"
+ "@typescript-eslint/scope-manager" "8.59.2"
+ "@typescript-eslint/types" "8.59.2"
+ "@typescript-eslint/typescript-estree" "8.59.2"
+
+"@typescript-eslint/visitor-keys@8.59.2":
+ version "8.59.2"
+ resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-8.59.2.tgz#5ccc486913cd347883d69158836b1189a660bfe6"
+ integrity sha512-NwjLUnGy8/Zfx23fl50tRC8rYaYnM52xNRYFAXvmiil9yh1+K6aRVQMnzW6gQB/1DLgWt977lYQn7C+wtgXZiA==
+ dependencies:
+ "@typescript-eslint/types" "8.59.2"
+ eslint-visitor-keys "^5.0.0"
+
+"@vitejs/plugin-vue@^6.0.6":
+ version "6.0.6"
+ resolved "https://registry.yarnpkg.com/@vitejs/plugin-vue/-/plugin-vue-6.0.6.tgz#4d8a3a7941382cf2760ac5593364bea6856ae7b2"
+ integrity sha512-u9HHgfrq3AjXlysn0eINFnWQOJQLO9WN6VprZ8FXl7A2bYisv3Hui9Ij+7QZ41F/WYWarHjwBbXtD7dKg3uxbg==
+ dependencies:
+ "@rolldown/pluginutils" "1.0.0-rc.13"
+
+"@vitest/eslint-plugin@^1.6.15":
+ version "1.6.16"
+ resolved "https://registry.yarnpkg.com/@vitest/eslint-plugin/-/eslint-plugin-1.6.16.tgz#55017c65cdceffd9a3efdb4062177bf0c74cf819"
+ integrity sha512-2pBN1F1JXq6zTSaYC58CMJa7pGxXIRsLfOioeZM4cPE3pRdSh1ySTSoHPQlOTEF5WgoVzWZQxhGQ3ygT78hOVg==
+ dependencies:
+ "@typescript-eslint/scope-manager" "^8.58.0"
+ "@typescript-eslint/utils" "^8.58.0"
+
+"@volar/language-core@2.4.28":
+ version "2.4.28"
+ resolved "https://registry.yarnpkg.com/@volar/language-core/-/language-core-2.4.28.tgz#c21f365a91c1dffe8bd7264fd491770c8d74fef3"
+ integrity sha512-w4qhIJ8ZSitgLAkVay6AbcnC7gP3glYM3fYwKV3srj8m494E3xtrCv6E+bWviiK/8hs6e6t1ij1s2Endql7vzQ==
+ dependencies:
+ "@volar/source-map" "2.4.28"
+
+"@volar/source-map@2.4.28":
+ version "2.4.28"
+ resolved "https://registry.yarnpkg.com/@volar/source-map/-/source-map-2.4.28.tgz#b40254e8c96199e5f1e0796777c593c617ad270e"
+ integrity sha512-yX2BDBqJkRXfKw8my8VarTyjv48QwxdJtvRgUpNE5erCsgEUdI2DsLbpa+rOQVAJYshY99szEcRDmyHbF10ggQ==
+
+"@volar/typescript@2.4.28":
+ version "2.4.28"
+ resolved "https://registry.yarnpkg.com/@volar/typescript/-/typescript-2.4.28.tgz#83f86356e84eb101b8081a44c104f2f2ced8411f"
+ integrity sha512-Ja6yvWrbis2QtN4ClAKreeUZPVYMARDYZl9LMEv1iQ1QdepB6wn0jTRxA9MftYmYa4DQ4k/DaSZpFPUfxl8giw==
+ dependencies:
+ "@volar/language-core" "2.4.28"
+ path-browserify "^1.0.1"
+ vscode-uri "^3.0.8"
+
+"@vue-macros/common@^3.1.1":
+ version "3.1.2"
+ resolved "https://registry.yarnpkg.com/@vue-macros/common/-/common-3.1.2.tgz#6b5f71ea219732fc955fdcfb15a95a417b87a0fe"
+ integrity sha512-h9t4ArDdniO9ekYHAD95t9AZcAbb19lEGK+26iAjUODOIJKmObDNBSe4+6ELQAA3vtYiFPPBtHh7+cQCKi3Dng==
+ dependencies:
+ "@vue/compiler-sfc" "^3.5.22"
+ ast-kit "^2.1.2"
+ local-pkg "^1.1.2"
+ magic-string-ast "^1.0.2"
+ unplugin-utils "^0.3.0"
+
+"@vue/compiler-core@3.5.34":
+ version "3.5.34"
+ resolved "https://registry.yarnpkg.com/@vue/compiler-core/-/compiler-core-3.5.34.tgz#6d84a46b7fdf1162cf8225aa2be42918a76ab827"
+ integrity sha512-s9cLyK5mLcvZ4Agva5QgRsQyLKvts9WbU9DB6NqiZkkGEdwmcEiylj5Jbwkp680drF/NNCV8OlAJSe+yMLxaJw==
+ dependencies:
+ "@babel/parser" "^7.29.3"
+ "@vue/shared" "3.5.34"
+ entities "^7.0.1"
+ estree-walker "^2.0.2"
+ source-map-js "^1.2.1"
+
+"@vue/compiler-dom@3.5.34", "@vue/compiler-dom@^3.5.0":
+ version "3.5.34"
+ resolved "https://registry.yarnpkg.com/@vue/compiler-dom/-/compiler-dom-3.5.34.tgz#6b943e8106822868e74d66c615432bbba6a589be"
+ integrity sha512-EbF/T++k0e2MMZlJsBhzK8Sgwt0HcIPOhzn1CTB/lv6sQcyk+OWf8YeiLxZp3ro7MbbLcAfAJ6sEvjFWuNgUCw==
+ dependencies:
+ "@vue/compiler-core" "3.5.34"
+ "@vue/shared" "3.5.34"
+
+"@vue/compiler-sfc@3.5.34", "@vue/compiler-sfc@^3.5.22":
+ version "3.5.34"
+ resolved "https://registry.yarnpkg.com/@vue/compiler-sfc/-/compiler-sfc-3.5.34.tgz#93b6aeb3393cd7b3c71ff07f28879558f72e5f1d"
+ integrity sha512-D/ihr6uZeIt6r+pVZf46RWT1fAsLFMbUP7k8G1VkiiWexriED9GrX3echHd4Abbt17zjlfiFJ8z7a3BxZOPNjg==
+ dependencies:
+ "@babel/parser" "^7.29.3"
+ "@vue/compiler-core" "3.5.34"
+ "@vue/compiler-dom" "3.5.34"
+ "@vue/compiler-ssr" "3.5.34"
+ "@vue/shared" "3.5.34"
+ estree-walker "^2.0.2"
+ magic-string "^0.30.21"
+ postcss "^8.5.14"
+ source-map-js "^1.2.1"
+
+"@vue/compiler-ssr@3.5.34":
+ version "3.5.34"
+ resolved "https://registry.yarnpkg.com/@vue/compiler-ssr/-/compiler-ssr-3.5.34.tgz#0561ae3f9b81564929a8544769eee9cc92a76c42"
+ integrity sha512-cDtTHKibkThKGHH1SP+WdccquNRYQDFH6rRjQCqT9G2ltFAfoR5pUftpab/z+aM5mW9HLLVQW7hfKKQe/1GBeQ==
+ dependencies:
+ "@vue/compiler-dom" "3.5.34"
+ "@vue/shared" "3.5.34"
+
+"@vue/devtools-api@^8.0.6":
+ version "8.1.1"
+ resolved "https://registry.yarnpkg.com/@vue/devtools-api/-/devtools-api-8.1.1.tgz#367caf696349b1a49c655939ce605f4c96e30357"
+ integrity sha512-bsDMJ07b3GN1puVwJb/fyFnj/U2imyswK5UQVLZwVl7O05jDrt6BHxeG5XffmOOdasOj/bOmIjxJvGPxU7pcqw==
+ dependencies:
+ "@vue/devtools-kit" "^8.1.1"
+
+"@vue/devtools-kit@^8.1.1":
+ version "8.1.1"
+ resolved "https://registry.yarnpkg.com/@vue/devtools-kit/-/devtools-kit-8.1.1.tgz#f205563eab389099d5181706b5b98e2d6fd2489d"
+ integrity sha512-gVBaBv++i+adg4JpH71k9ppl4soyR7Y2McEqO5YNgv0BI1kMZ7BDX5gnwkZ5COYgiCyhejZG+yGNrBAjj6Coqg==
+ dependencies:
+ "@vue/devtools-shared" "^8.1.1"
+ birpc "^2.6.1"
+ hookable "^5.5.3"
+ perfect-debounce "^2.0.0"
+
+"@vue/devtools-shared@^8.1.1":
+ version "8.1.1"
+ resolved "https://registry.yarnpkg.com/@vue/devtools-shared/-/devtools-shared-8.1.1.tgz#daaa16243d2f5eaa50f7e34902d2bb9e98235b52"
+ integrity sha512-+h4ttmJYl/txpxHKaoZcaKpC+pvckgLzIDiSQlaQ7kKthKh8KuwoLW2D8hPJEnqKzXOvu15UHEoGyngAXCz0EQ==
+
+"@vue/language-core@3.2.8":
+ version "3.2.8"
+ resolved "https://registry.yarnpkg.com/@vue/language-core/-/language-core-3.2.8.tgz#3bd38c343b89976208b7996bc670df56313047de"
+ integrity sha512-9OiSPQFiAAWNVnXb0d2dcTmcKnFQamhuNES6ayyISrb/mwPWVgoGdAqSfCWqKhQpa3D5gDTcYD+w7ObiheZ81g==
+ dependencies:
+ "@volar/language-core" "2.4.28"
+ "@vue/compiler-dom" "^3.5.0"
+ "@vue/shared" "^3.5.0"
+ alien-signals "^3.1.2"
+ muggle-string "^0.4.1"
+ path-browserify "^1.0.1"
+ picomatch "^4.0.4"
+
+"@vue/reactivity@3.5.34":
+ version "3.5.34"
+ resolved "https://registry.yarnpkg.com/@vue/reactivity/-/reactivity-3.5.34.tgz#d41355f7e8b1784078ea498ec7d974e4e26d4b74"
+ integrity sha512-y9XDjCEuBp+98k+UL5dbYkh57AHU4o6cxZedOPXw3bmrZZYLQsVHguGurq7hVrPCSrQtrnz1f9dssyFr+dMXfQ==
+ dependencies:
+ "@vue/shared" "3.5.34"
+
+"@vue/runtime-core@3.5.34":
+ version "3.5.34"
+ resolved "https://registry.yarnpkg.com/@vue/runtime-core/-/runtime-core-3.5.34.tgz#1b4ce2ebf94d670acbd8f22d92e45908e2a2c96a"
+ integrity sha512-mKeBYvu8tcMSLhypAHBmriUFfWXKTCF/23Z4jiCoYK3UtWepkliViNLuR90V9XOyD62mUxs9p1jsrpK3CCGIzw==
+ dependencies:
+ "@vue/reactivity" "3.5.34"
+ "@vue/shared" "3.5.34"
+
+"@vue/runtime-dom@3.5.34":
+ version "3.5.34"
+ resolved "https://registry.yarnpkg.com/@vue/runtime-dom/-/runtime-dom-3.5.34.tgz#1b4e5c009fe9d6ce682cfc2372da4abd40614d29"
+ integrity sha512-e8kZzERmCwUnBRVsgSQlAfrfU2rGoy0FFKPBXSlfEjc/O3KfA7QP0t1/2ZylrbchjmIKB4dPTd07A6WPr0eOrg==
+ dependencies:
+ "@vue/reactivity" "3.5.34"
+ "@vue/runtime-core" "3.5.34"
+ "@vue/shared" "3.5.34"
+ csstype "^3.2.3"
+
+"@vue/server-renderer@3.5.34":
+ version "3.5.34"
+ resolved "https://registry.yarnpkg.com/@vue/server-renderer/-/server-renderer-3.5.34.tgz#e0776f839312b4111fb5bd742a70f435298a3e21"
+ integrity sha512-nHxmJoTrKsmrkbILRhkC9gY1G3moZbJTqCzDd7DOOzG5KH9oeJ0Unqrff5f9v0pW//jES05ZkJcNtfE8JjOIew==
+ dependencies:
+ "@vue/compiler-ssr" "3.5.34"
+ "@vue/shared" "3.5.34"
+
+"@vue/shared@3.5.34", "@vue/shared@^3.5.0":
+ version "3.5.34"
+ resolved "https://registry.yarnpkg.com/@vue/shared/-/shared-3.5.34.tgz#665f2b2fd600f6c180668423909a6fde64cbfccd"
+ integrity sha512-24uqU4OIiX29ryC3MeWid/Xf2fa2EFRUVLb77nRhk+UrTVrh/XiGtFAFmJBAtBRbjwNdsPRP+jj/OL27Eg1NDA==
+
+"@vue/tsconfig@^0.9.1":
+ version "0.9.1"
+ resolved "https://registry.yarnpkg.com/@vue/tsconfig/-/tsconfig-0.9.1.tgz#6aa901e9f89242b26e1e564c98747278df6882e5"
+ integrity sha512-buvjm+9NzLCJL29KY1j1991YYJ5e6275OiK+G4jtmfIb+z4POywbdm0wXusT9adVWqe0xqg70TbI7+mRx4uU9w==
+
+"@vueuse/core@^14.3.0":
+ version "14.3.0"
+ resolved "https://registry.yarnpkg.com/@vueuse/core/-/core-14.3.0.tgz#66c92f9ad7ee989e4a8fd23ec368e55429ea42b2"
+ integrity sha512-aHfz47g0ZhMtTVHmIzMVpJy8ePhhOy68GY5bv110+5DVtZ+W7BsOx+m61UNQqfrWyPztIHIanWa3E2tib3NFIw==
+ dependencies:
+ "@types/web-bluetooth" "^0.0.21"
+ "@vueuse/metadata" "14.3.0"
+ "@vueuse/shared" "14.3.0"
+
+"@vueuse/metadata@14.3.0":
+ version "14.3.0"
+ resolved "https://registry.yarnpkg.com/@vueuse/metadata/-/metadata-14.3.0.tgz#d782b00732d1568503027965c0be92bc1699d76c"
+ integrity sha512-BwxmbAzwAVF50+MW57GXOUEV61nFBGnlBvrTqj49PqWJu3uw7hdu72ztXeZ33RdZtDY6kO+bfCAE1PCn88Tktw==
+
+"@vueuse/shared@14.3.0":
+ version "14.3.0"
+ resolved "https://registry.yarnpkg.com/@vueuse/shared/-/shared-14.3.0.tgz#a3e7e6391f9ed7f363cbb28c32c4a278efaacbd0"
+ integrity sha512-bZpge9eSXwa4ToSiqJ7j6KRwhAsneMFoSz3LMWKQDkqimm3D/tbFlrklrs/IOqC8tEcYmXQZJ6N0UrjhBirVCg==
+
+"@zag-js/accordion@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/accordion/-/accordion-1.40.0.tgz#fabf5eeae61d6285a781f76d16a11e2fbc5efb43"
+ integrity sha512-YDdyvZJ6fr92RZazyXQq+juT3ZA0ubjDISptb5YPgMoTPdnjKNiICPpMeCeVj1ncYRDkHXrOdChS/5CtuX/K6g==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/anatomy@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/anatomy/-/anatomy-1.40.0.tgz#df087ed1a287d14bc99eca1e4a580fb68db04c5a"
+ integrity sha512-oiB4uAaV//L38JluLVPtOHO3xvqambrfrXVOoq4kmNrBv1LLlCmFvrXA2HOR9lakn4ExK27XSUrKhUN7YlKjfQ==
+
+"@zag-js/angle-slider@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/angle-slider/-/angle-slider-1.40.0.tgz#196f3d973877e4567989dd2af9e4ab931d7b4802"
+ integrity sha512-6X6bOBoCyYG0/lFY0Y+AXJZZG6CeYQiWkcMXvegxCC2zxthodqOVzkVOASW+6rzLjn2bru+V5O9RMjNgmCumKg==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/rect-utils" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/aria-hidden@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/aria-hidden/-/aria-hidden-1.40.0.tgz#9deec4d211d7a903b1717d1306238921be5bb470"
+ integrity sha512-lNWujEIlfGKwMQIcgfXuOZSsJD2avrgPsQHrXNVF9mkXygjLFcIRKz2pEexTSCqFh/HuUZJ6rG4pM/hJ/BiVCw==
+ dependencies:
+ "@zag-js/dom-query" "1.40.0"
+
+"@zag-js/async-list@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/async-list/-/async-list-1.40.0.tgz#0ebf0b37c55750af6b237651b27775f260bf8da7"
+ integrity sha512-hLGUTtwRFl6FIdYxSIYSeLQjJeG4isKpdmGCUvtWNnKr7ayf1yAkkSwX10SdBMWOCldbtvKCZXumKvP6dDwNvw==
+ dependencies:
+ "@zag-js/core" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/auto-resize@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/auto-resize/-/auto-resize-1.40.0.tgz#3aed4b048c1ddcb82af6609a88b09030dee5dad3"
+ integrity sha512-eZC+AGKUip7UMu41/ApeT1wCIgn2fmo63FJeGAdMMD8E9M8M7QLsfISMIoieNNGBAYWhSyqELQ3jPgkUf6xReA==
+ dependencies:
+ "@zag-js/dom-query" "1.40.0"
+
+"@zag-js/avatar@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/avatar/-/avatar-1.40.0.tgz#6d412fe7f7726f7924fcb6a46da397650f07987c"
+ integrity sha512-DayZDsNXbipT+1GUkX29tVhO4hZonDnidwE3SjEQv9Ic9vCdnwP95+B0FPEuaca03F5ZXFqVXjnPmRVbRMyDYQ==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/carousel@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/carousel/-/carousel-1.40.0.tgz#6292395b24a8830fb69ab58066c744777310933a"
+ integrity sha512-9svWc2jjvUP8iQ0afuu/ZAI75PuPLm4qB7h+10rmDrAgUPn7fwUBVzyATKubJPdtmaYQQvTTIiZU2B8mV88oGg==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/scroll-snap" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/cascade-select@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/cascade-select/-/cascade-select-1.40.0.tgz#f6b74eec4be5e756ad5ba2fae5c3ec15622cf2e7"
+ integrity sha512-0fkE0Fd2VQ4QsaWXHdgQxHWiaef3UWW0l6Jd47frtMNnrvg5t5Xfqowa7c2S23hcduOUfz2WC0xEuGXnO4UVDQ==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/collection" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dismissable" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/focus-visible" "1.40.0"
+ "@zag-js/popper" "1.40.0"
+ "@zag-js/rect-utils" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/checkbox@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/checkbox/-/checkbox-1.40.0.tgz#32041efac6a6b89521b14b6aef7a25cf2e10353f"
+ integrity sha512-oFCgnkOjrUDejB1wEp5s3cyJ+uFe/GoI3+wqNyckqOtcdKL1MBxy193GYVdj0LDfuCNrk8V0aIJGTdusCD2b4A==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/focus-visible" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/clipboard@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/clipboard/-/clipboard-1.40.0.tgz#2bd3f923a7bf811f260eb848ce45e63cf2602db2"
+ integrity sha512-QbFhJMwwUxTKcbWyb9ZrKgAp13U4+IzfHSLhPxbDVSQ15mIrjIkjW68gS6ElzhRDwGr1qawkZVApsqcToUqSaQ==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/collapsible@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/collapsible/-/collapsible-1.40.0.tgz#a8cf143963df8be1421ec5b3f3cbd76581c36f62"
+ integrity sha512-xDLY4j9D3gdoTirkwzMaCtelfCjnMhBzPyY6c/mh4oPvD3RB6dr3V3kI80i3yxHaUUeDCIUm/XAxK0InPsRBug==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/collection@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/collection/-/collection-1.40.0.tgz#2da47bd984a6a7da10eb443872569138aef5b420"
+ integrity sha512-+3o1nvbcA9Kz2hDDFf8Kngpd+of33S4TS5Tb9KvrHlU5ieQdvEUtc7/pWG2aCTkGpmgda+j91akB6ZB8+oVkvA==
+ dependencies:
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/color-picker@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/color-picker/-/color-picker-1.40.0.tgz#1ad9f401a4e3470f7986267c579f014c73005775"
+ integrity sha512-lT93xd1BlNBbitl2RxST8ARYE6q/HZD5a0QhMIT1RbndB8F4e9j/NxkStgE9f0QqgpC/rO+nKHLoR+H1xs/EkA==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/color-utils" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dismissable" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/popper" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/color-utils@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/color-utils/-/color-utils-1.40.0.tgz#538158008c69134ee2ba1e1ac38a41f3c3d52f0b"
+ integrity sha512-PZihcGheb5bn0/cEUwozjJjPoKkEwlJNpTA5mUxj/+sOElLaZM+zY2AnGYeMl6w5zIyZZUDoJMIT5rcb5sN87g==
+ dependencies:
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/combobox@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/combobox/-/combobox-1.40.0.tgz#3b5fc41628ce57f58151b81026b757353726fbbf"
+ integrity sha512-5IVCDrB8m7XrKBu28j7bIRE5KiyKJLPDZB3AJ+PLJyL69D+9z1anhLDmkUYcPseyCasszLKzIejby+kYQJgHlA==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/collection" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dismissable" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/focus-visible" "1.40.0"
+ "@zag-js/live-region" "1.40.0"
+ "@zag-js/popper" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/core@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/core/-/core-1.40.0.tgz#0640fdda8611417fb88d5d2df65048dd2bd2b84b"
+ integrity sha512-0YcqCh7TmhSonkbKM/7NWolxlaQgvvXgqedocW9oeRYiDJIpBZyRqnHPoGAS2XwbBPkCnrqSosxSF5yBjhZpgw==
+ dependencies:
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/date-input@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/date-input/-/date-input-1.40.0.tgz#51a189b979350302f963f4bdb5f538e8a9c86f3a"
+ integrity sha512-/VU8g3dugggC5xW2OJW1KONWzPkEbK/yLA0lPxymW/Uo0ixh2mKJUVTOTqDFWf1b0vzLX2XlYoLL+I2ryUyPvA==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/date-utils" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/live-region" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/date-picker@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/date-picker/-/date-picker-1.40.0.tgz#567cd1f8246905713c7cdc75da8b5e5c08cd5247"
+ integrity sha512-Nm3aSKn/5tGOZk8rIddLyBk+oeE0zr/ZsJuuTc3rysd04owVy1UhmUh6X9CqfTJtwTDpUZe+orHaIvKlE3Rd0w==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/date-utils" "1.40.0"
+ "@zag-js/dismissable" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/live-region" "1.40.0"
+ "@zag-js/popper" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/date-utils@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/date-utils/-/date-utils-1.40.0.tgz#7c17a009e6884ba11c8959a3a91fee5899d2e0cc"
+ integrity sha512-nuB1QM3X7yY0k2JiZbHHm6wigY+Cl1QK6sRlh+C7mOyzEKnNEqNSVIqgSionCtWO6zAZh1R8Znp5ZeCdbbc27w==
+
+"@zag-js/dialog@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/dialog/-/dialog-1.40.0.tgz#8ad955596e999f3eb02475ac7d71f9748f88f28f"
+ integrity sha512-1FHxR7/Kuu+9K2dxH7dKlSckCZ26n5ec79qWr0aMSSs2DF+ypQf5GUlaS6z2UqroZvIoJCvABVMm9OMko/qxlA==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/aria-hidden" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dismissable" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/focus-trap" "1.40.0"
+ "@zag-js/remove-scroll" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/dismissable@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/dismissable/-/dismissable-1.40.0.tgz#9509f9c7c47b94c1577d71d8a7b9eb2652fde344"
+ integrity sha512-bBkFvPg/zbYn31ZgEfx8not6s2Ekx7zU2sO8tGXb8rYPnHBfGDYEzVQansUStJn0Atzw+y7XR7B3G3u5AFQJKw==
+ dependencies:
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/interact-outside" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/dom-query@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/dom-query/-/dom-query-1.40.0.tgz#f35d1de3d7050da2b758aee35cb42f9c1332d920"
+ integrity sha512-4J3EO2gHpZ1VZiGLuMlH6G1Tsp4gKB8PPt2yKeNQWYGEXyrHUXrvMhRUzv7Z4/2I1s1tnxlFG4F8ovB3kTpz/Q==
+ dependencies:
+ "@zag-js/types" "1.40.0"
+
+"@zag-js/drawer@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/drawer/-/drawer-1.40.0.tgz#a2220676f6f04d16f4c2af0b757491be47d7c319"
+ integrity sha512-N2OR5ZYuTsWkYYmwsNgmL+wfuM3qUxB8GAfo53AWvOh07QUVz1Dvh1WP4km5L6Tkz4UBQZACu8T/ZLyeZ+PdWg==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/aria-hidden" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dismissable" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/focus-trap" "1.40.0"
+ "@zag-js/remove-scroll" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/editable@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/editable/-/editable-1.40.0.tgz#3b794e1724bff3d218bb60c3fbcfe7353add7d0c"
+ integrity sha512-X23wOg42BPvFWfJQi3yd8HiL8xtisrpL5ouFEzba56SQIxWZHDRpeWoqXqyLODq2/z2+SsZ0wV3laRD3ZH0C2g==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/interact-outside" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/file-upload@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/file-upload/-/file-upload-1.40.0.tgz#ffc910381478b963d8d785caf3343fae874122f2"
+ integrity sha512-hUZlJYjSGk7SAflTmQIjZv6M+icujaHS6I+dik2LM48rLWwNa/GYTNx+uY4zJLd9oW1eEj+6NcCYZpPWzKku4Q==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/file-utils" "1.40.0"
+ "@zag-js/i18n-utils" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/file-utils@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/file-utils/-/file-utils-1.40.0.tgz#65bfea43ff88c3534b79c1d880de9a6fc382fc8a"
+ integrity sha512-BGny4rafiBQ5TPCBXfzbH7lSyFdnoix7brq/+FllKpDqpWPQz0tIsgSZueF/Z8GPTrAkwMKOFI99P7OVhAhRig==
+ dependencies:
+ "@zag-js/i18n-utils" "1.40.0"
+
+"@zag-js/floating-panel@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/floating-panel/-/floating-panel-1.40.0.tgz#e7729597e6f820006c654da8094f8be0e9dbabc5"
+ integrity sha512-e2QXwapCbjLJnU+MAz06CoByj4XJ3sdSBgWF+PSe2X2T8dd/FkZUnaDPaX0yyfyTWKzBbyRRNyon2LMAs8ndHw==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/popper" "1.40.0"
+ "@zag-js/rect-utils" "1.40.0"
+ "@zag-js/store" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/focus-trap@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/focus-trap/-/focus-trap-1.40.0.tgz#f8863317f0dd5bc1dc0121305abf4b972fb09ffb"
+ integrity sha512-Q6W+DU7pix5rtRwoDnYzTYMkUV2kMWrFV0/EdNN3spFSvnUSkDWRmcNpzf+56AuCNeqsAZxaLJpsHLZkcT2xrw==
+ dependencies:
+ "@zag-js/dom-query" "1.40.0"
+
+"@zag-js/focus-visible@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/focus-visible/-/focus-visible-1.40.0.tgz#e12f324b5ace7707819955674447525a329b551b"
+ integrity sha512-63byl/kLVzDYlnHFma4HKEKrqB1Vx2zg0sBmUSENPyh+Ia1xhEVVC5vu6GX7nu4t/8QRy3Jn0q7T5og81FGb1A==
+ dependencies:
+ "@zag-js/dom-query" "1.40.0"
+
+"@zag-js/highlight-word@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/highlight-word/-/highlight-word-1.40.0.tgz#131f5acb71372fbe6985e6181137f26f34f0707c"
+ integrity sha512-+aeVn3S5NPG6Tk4Sanl0VZk/0atjnF7Xy7POPs1HD5SBui29/6i3vn3bUBNXJXrnhUoNrUhuySVYVhgkffcQ7w==
+
+"@zag-js/hover-card@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/hover-card/-/hover-card-1.40.0.tgz#d0e56e83a630daa3fd3cee9037aa6aa2dea17b69"
+ integrity sha512-lkuLaikPLBIOnR0X75kSXdDYgv3ritAsn4TF1eGs12iYnZVX4PTL3J39tVNm9QrEXZ+iKcA1D2cUXNhEteCTyA==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dismissable" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/popper" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/i18n-utils@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/i18n-utils/-/i18n-utils-1.40.0.tgz#c85c5e6327715dc3a86fc2d677e15905c3b1f3aa"
+ integrity sha512-8D3ki9V81gMKZvtRfNVoHCBDVYjr+WJLBvdfSv3cdOsVM2/E8//xAfYbYzl5Fdmeny3H71fxBNqOX05GN4K6OA==
+ dependencies:
+ "@zag-js/dom-query" "1.40.0"
+
+"@zag-js/image-cropper@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/image-cropper/-/image-cropper-1.40.0.tgz#341997f79550e76b9f220f96f7f8ef712a741f8b"
+ integrity sha512-bpTCaiUXM0Mh6ddoJ1fA1B/YXp5Fc8LA0hg8CuEByDwGRVKPJ0KotL6QXMF6cEJZ1fcHF3Lcmpbj5Xotfkr4mA==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/interact-outside@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/interact-outside/-/interact-outside-1.40.0.tgz#569c3d67b37120ae5a0f4ee53c6d78a7821b2edd"
+ integrity sha512-Fws+O4uD9vS0I5KVcf3U2tNjLKvqlv+RExFbTywckDLOCJ145M/pMQWTr1FHil04jk5PFyM1iGfsbom8tozHpQ==
+ dependencies:
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/json-tree-utils@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/json-tree-utils/-/json-tree-utils-1.40.0.tgz#5e19150e891d9a9d65309b3176aeb7720533ce62"
+ integrity sha512-7zEzU59Gz76nV7n3l70uMB5yAOOQMmt1PTAni6S97uw7/6KzPktsEWBcw7ocC4IIA42PKdT7akpq721H0vthbA==
+
+"@zag-js/listbox@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/listbox/-/listbox-1.40.0.tgz#7618a3036cdb4936746dacccb9e16fda2ad69d01"
+ integrity sha512-zB33y+dk6/e0ZTs3wun2KsuPaH/wygOuD8scnH2a2Y/W9a2P1rq503Kgm5d5kVXBKQLxOBwievWJ8Blajv8LnA==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/collection" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/focus-visible" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/live-region@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/live-region/-/live-region-1.40.0.tgz#08406a21e6ce8f5e94b1192b0405749b75abe5f0"
+ integrity sha512-i1Dx02KGcQOAZGNhkFe8kz26gYJcn7KsT/M1UovjS9RTbl9diY8ShiyfIAhqruoaHQyqsHMRh/f7Idu45HdiDA==
+
+"@zag-js/marquee@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/marquee/-/marquee-1.40.0.tgz#fd0f02fd733dea18be5b4fa80a986fa7367bb689"
+ integrity sha512-XfvAwSNYXV3fEIRc44a9sAsoJoLKt+CWbpSPgQBpiFPpWh0rZ8frUZCslevTzBB3ifIWoSg+svDHQOGsDa8wGA==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/menu@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/menu/-/menu-1.40.0.tgz#a4f02e67510f133ccdd540b90f19e7d736039895"
+ integrity sha512-FRBqwsOjxBi0eSwqwrOw2td1rd0Xxl0f41J2lGc8E7z+2PabbBcJ/poqSiEn8YoaCT4mAWNjt4QQU/Pe1bRJ/g==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dismissable" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/focus-visible" "1.40.0"
+ "@zag-js/popper" "1.40.0"
+ "@zag-js/rect-utils" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/navigation-menu@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/navigation-menu/-/navigation-menu-1.40.0.tgz#79d0d346167c48eccaac64245d517a9f140dcfda"
+ integrity sha512-aJkEGYH8P9NfsQOjxMzxuF4YrrV2N1GQj6Y5Ow19MKuLh42o35bUhwoGsYjFbxgEcImabINtZJqtAPAkOdJXmQ==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dismissable" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/number-input@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/number-input/-/number-input-1.40.0.tgz#1142f29ae0f22572f186a9ef7578fba8f6c87fae"
+ integrity sha512-WffdeqSOpsKmgPzBkNZl9nAolQPlyl9dIabaPguGgXdYtZW/OGCGj8jCYqyEu4VL3kDPPVVQRWEqC/XzwzVCRg==
+ dependencies:
+ "@internationalized/number" "3.6.5"
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/pagination@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/pagination/-/pagination-1.40.0.tgz#5fc9a454965d2729220151557c4409274d0bf9fc"
+ integrity sha512-Ykotky0A/7rswb6BfOD9aXL1EssKwUYfBRbdWGe52uhVc7dGagMSTUDRVeNhVsP/MEdtwqys7urvDbAlEqq+GA==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/password-input@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/password-input/-/password-input-1.40.0.tgz#8d70e938ad5646aef8869d967741a58608d0a16f"
+ integrity sha512-mD4tbA4m82oV+0NbJ+P00Q4Gwz+zf1kZEZ3Z48ohICfK/WO1KhCgviY7vu/7bCMnRiD3dbi+nEeym8Kb29wRHw==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/pin-input@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/pin-input/-/pin-input-1.40.0.tgz#cb5b956e1a741057786ba0bab34b289557674207"
+ integrity sha512-iJIXDJC+9DUx+A3sRdTmHV7vPZXCw9O6le3R0lKf/8kQOgj7FKjbVw2SkUMAoOZ0u5J7Zwg2oZc7ddt1pwUk9w==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/popover@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/popover/-/popover-1.40.0.tgz#0aa2d0efe90a29a2c9bb5190fbb860d0fd1d330c"
+ integrity sha512-bjvOep1YNlsvIYGh/rPsFCHjH2cCt2aKsVLyRvzTT1jhGZJvBdQKQBJjSuG5Nh4y1PUqtrrz69ZMWRrJGQ3rNg==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/aria-hidden" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dismissable" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/focus-trap" "1.40.0"
+ "@zag-js/popper" "1.40.0"
+ "@zag-js/remove-scroll" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/popper@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/popper/-/popper-1.40.0.tgz#7bc2160fb82ed0e790630e5def8e9a4f8f22095a"
+ integrity sha512-rCkgqgwlpgMwcnuSVrZK2xXl1Mvptpuw3cZy6rC2C5F3yE1GmWohdts5VkeQNro+sd/xHTdVovOqY6cU9Htj1w==
+ dependencies:
+ "@floating-ui/dom" "^1.7.6"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/presence@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/presence/-/presence-1.40.0.tgz#f8f38210e7b55bd42724b7e9f1899619c0e623cc"
+ integrity sha512-P0bAuzEIDuMglE1xfmW5xTuSBlWjNZ8nOGXoIksKOKb+b+jy2Vys6WjZjKipV/jop4u85wfzKchcPc3C+cXuog==
+ dependencies:
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+
+"@zag-js/progress@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/progress/-/progress-1.40.0.tgz#5614bce7083e7cd77cdcd6c21acf78a105509568"
+ integrity sha512-V61a5CHEs8suevQVS+/1ENj1RDVYNOUUTawK6uriCA6Ol59xe30DmF+eV6Y9miM7L/pN3YjZRq9uEDJMXXK32g==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/qr-code@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/qr-code/-/qr-code-1.40.0.tgz#b2416846b5a6182c8c2bafb43ea5b93a5043b5c3"
+ integrity sha512-xD37tVrQ46CeqVLqkSm61kURoJ4Z/uOFcB8z7Hu3UX+1OFTfkhgrns6iLUneoRjO3hsqQaTaVkxVOQeLYWb+wA==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+ proxy-memoize "3.0.1"
+ uqr "0.1.2"
+
+"@zag-js/radio-group@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/radio-group/-/radio-group-1.40.0.tgz#3877a9891cfcb6a6dd98434bc90c8188fda6c49b"
+ integrity sha512-sFJCdyOKzQC9hylSP19R71yv44by/C78D9EHfsxQJtvOgDv9E+h13NNX4n9wWyubC20xftlxkja8sNT5NfJKUw==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/focus-visible" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/rating-group@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/rating-group/-/rating-group-1.40.0.tgz#c44107032ad1729b4c280f2c0d91c1632d5f8abe"
+ integrity sha512-UMBI3xAMcm7otpAczMGPEA7jC1hvV8NhnZ4mN3oftJB0bc1winoXxJdCkrXN58TTNWrGNSRzjtm048G+HPCdpw==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/rect-utils@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/rect-utils/-/rect-utils-1.40.0.tgz#8748089c98542eb8f053040f4c285226189e0aa5"
+ integrity sha512-ikgLuE4rLlACm4mGLp6Ga8sJA44uFwohA1nVmb95sQ+VIyx2naf91CEF7SMrZVEwFKHaHpxdKVQSZLRjJqO/dw==
+
+"@zag-js/remove-scroll@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/remove-scroll/-/remove-scroll-1.40.0.tgz#ebb194643959840f41dbe57124b165a92ee4baae"
+ integrity sha512-f6EgODnJMRtkbgdJCgyllND8jui+RtPrCZy6JYhhOg7KQ+bFfV36KzWQMty38ZdOyrh23UUO7MJ3WGcFXPvk3g==
+ dependencies:
+ "@zag-js/dom-query" "1.40.0"
+
+"@zag-js/scroll-area@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/scroll-area/-/scroll-area-1.40.0.tgz#01b2c135bdef8b7c1755fc2ae6ff727e25891a35"
+ integrity sha512-7EtWETRIn8dY7xqAeMOlnEuzhOrtc65mN/0YvT3XYcBz/CzmHzyZTmos3UXBJGnKHSGj61aEpP9g3RK+x/w63A==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/scroll-snap@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/scroll-snap/-/scroll-snap-1.40.0.tgz#5b1fda9025df0063b1ec42c825f3567067051905"
+ integrity sha512-XtjeOd+pwGX0+K7NvsQncrKwV8CTSzHfVVJrdQ+MweiWBpGNeAh43ySN4L+KSTgtnUiZbuwBIxlKK0tX+WupgQ==
+ dependencies:
+ "@zag-js/dom-query" "1.40.0"
+
+"@zag-js/select@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/select/-/select-1.40.0.tgz#e29b5a0bdfe809d33ec620b5f23a1a415730538f"
+ integrity sha512-auMI9SvocVvKHNWF2DobyQN6+1k3OO6UsQTdkofvbHxX7maosy8ZXA6k1r9Ndt4qLUu7CbdAAQ+qJ4VkgJyvxA==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/collection" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dismissable" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/focus-visible" "1.40.0"
+ "@zag-js/popper" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/signature-pad@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/signature-pad/-/signature-pad-1.40.0.tgz#3193d5f930ef5741f421112707959d9370ed04bd"
+ integrity sha512-L0LTxcpdckaGdDDXcQCr4AG+J9xUHH+lsenH7NG4ZI7rSr4nRmHMdDH0GR7nBa6MMdPIIimjWIE/TwZ1OuHzCQ==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+ perfect-freehand "^1.2.3"
+
+"@zag-js/slider@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/slider/-/slider-1.40.0.tgz#91d5c96f9014e70a6523909ade62c22237655fb1"
+ integrity sha512-xZGycm+ghGFG3kTYq8g0t1Av1moxg45WiFz5E3bRgP7YU9beSTaFZI8h6f65NiC5P3YuwA0RoYxA46GH22qoZg==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/splitter@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/splitter/-/splitter-1.40.0.tgz#35aee11423e994c3f7f7777a9b14dd29f8d1c5dc"
+ integrity sha512-64KNKwlIjyUIjp7i/whDCpREiSFrNI/cF7MpBJvBGRPUWq8NpNxMGKWD+vBCV+JC61QF9xg/NgNoigFycS9sYw==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/steps@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/steps/-/steps-1.40.0.tgz#0be1a53e1af20c17fe9ad98bc3ef46d9f594add7"
+ integrity sha512-5sVFzcIYubCn1nJSQIx9WWNlJuFoOJMpkD/ZMwNp0LzpnmnspsCOmdnQUWEftMQ1KdwZ+qNgfo/+kHclb9cBjg==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/store@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/store/-/store-1.40.0.tgz#d27ed18e9bd8bf979315ab672d6481b71b482f1d"
+ integrity sha512-EmgYIdbNZ4TN4Qht/jugY4UVkaWx69l8P1qiX23U4YwqNLq10tyOJmcXWbvsrprU1dGb24B+xq0WBm/RIjw4WA==
+ dependencies:
+ proxy-compare "3.0.1"
+
+"@zag-js/switch@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/switch/-/switch-1.40.0.tgz#2b289bb0eaa9ab320179c6539432f97329aafa65"
+ integrity sha512-hUH3AF79ndSFZxt7Plw7mVZV0QlM0kFqKwrAGBEOE77P3rKpOsMJ3wWgMb3w6nwlxGQsbwmMgAFvYUslLpM4Lg==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/focus-visible" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/tabs@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/tabs/-/tabs-1.40.0.tgz#b80d3cbfed40fef531fe5ec90df51be2471489f3"
+ integrity sha512-xqfPC2nQ6Bn4nqy1L+1CVcQcg/Z7K2q753OvsX2C8Wtu+7tF//HyMbOpF6fGikqlLkUzCkvjkqDjdOXcfWN9ZQ==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/tags-input@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/tags-input/-/tags-input-1.40.0.tgz#aae5785584c669648a199e4854be47498e4ae0df"
+ integrity sha512-3cB7nPlUvzZNZwQw5AaTuxwcRn1n2qkDCjLEb2NEwtmI+YxHbK3k1MtXjTccjcYjU8cAkv+jaeyZPs6KFKQcHA==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/auto-resize" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/interact-outside" "1.40.0"
+ "@zag-js/live-region" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/timer@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/timer/-/timer-1.40.0.tgz#4358358973738032570221c27d4280aae0d2d201"
+ integrity sha512-Rvet226fhUtZnItjHpUYV7MH0uEFZfXT9PSRrX5jdiU4/P0eWKbirwi//AVeqcWFexXvw6ajYSfQN7EVyr2x4w==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/toast@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/toast/-/toast-1.40.0.tgz#16b64be26b73bda23ab69e8c8d03e563317cd9dd"
+ integrity sha512-EDH43zdiH4Bz30cE6YI9g//qXGOOfWObM3dFLG8I0q/cJRf7/6jO82rwZAHPwfOSfKhUDxStirD8F6eoY6BWXA==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dismissable" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/toggle-group@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/toggle-group/-/toggle-group-1.40.0.tgz#c48c3ebb065001e73722b70045d772b88499779a"
+ integrity sha512-+JKcnfEbdQnr5p7uRvYLdivhUsM6iio71UC10tK74nXYRnYm0/Uvxg3oQzvbNTq9WdcU/DIh3gZVZ2Vex9nBnQ==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/toggle@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/toggle/-/toggle-1.40.0.tgz#8c2a757e51acca6ebd25385db8fb70217c51269b"
+ integrity sha512-DW7682lzTP2eDlMvrS7tUX3zAm7ufrrKr7VDiX8BB6oXBRETXrVIxCYNuoIdqjwXebdjAoxaCiUZEreRVucYQg==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/tooltip@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/tooltip/-/tooltip-1.40.0.tgz#428d5836a7e19a3a564412c807d6be159961c5ac"
+ integrity sha512-pyrvit+nB8dIwVNTGBRlHPsh7yMJGAxxM1zfY7HOTJqF+n6+6xYTQ4gQ/Ocy1Q7I5kO88+m16naEh0qLFiTZww==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/focus-visible" "1.40.0"
+ "@zag-js/popper" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/tour@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/tour/-/tour-1.40.0.tgz#a230885a1841c19b0830704119ff6a34a4630894"
+ integrity sha512-VczYGFQM9xsSbfy5N0NP91GdKxbYvfPCDAguD+WQSs1umEIgAAozSKPUdV3NNCX5Pq6B1F3dBxi6gYPdNqrAHg==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dismissable" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/focus-trap" "1.40.0"
+ "@zag-js/interact-outside" "1.40.0"
+ "@zag-js/popper" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/tree-view@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/tree-view/-/tree-view-1.40.0.tgz#4ba8192e5631edbcb6eded37f4d4d35b8cbd2274"
+ integrity sha512-v/20ekjbM+HXDEkpHAz6k8WpoZRmZmdCApDIkIgXVHPRQk+kwAiiIPY20ZDG+DjRu7Lh0MUdQavdZtGj6Ihwkw==
+ dependencies:
+ "@zag-js/anatomy" "1.40.0"
+ "@zag-js/collection" "1.40.0"
+ "@zag-js/core" "1.40.0"
+ "@zag-js/dom-query" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+"@zag-js/types@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/types/-/types-1.40.0.tgz#6bd98a399d58724e6e81c11f4cbd0bb3501cc6fa"
+ integrity sha512-LVvxEyqFv/u9SEe5xdivvG2vYb9cCmbkD+5r6s+IGljpDLaRgv4BYyxEh40ri1ai070tL08ZKmoLfx2/xfvY/A==
+ dependencies:
+ csstype "3.2.3"
+
+"@zag-js/utils@1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/utils/-/utils-1.40.0.tgz#cf590c4b6ac294f74a369e8cda40ca7eec754400"
+ integrity sha512-XUpqDtXfHe7CySjOhLPLj9H8rxbiFUJAGgmBzNdpsGPP4wx12cpOXrpSjRXZ2kMwooMPz/P7RPDBteto8sqhAQ==
+
+"@zag-js/vue@1.40.0", "@zag-js/vue@^1.40.0":
+ version "1.40.0"
+ resolved "https://registry.yarnpkg.com/@zag-js/vue/-/vue-1.40.0.tgz#f5d7f3ff68b6062ecab5611cc846fe39ddf08524"
+ integrity sha512-sUkJfuESY42yNnSXszpkz4PCreW0rvEWir1s01zhow1rDi7WCNO1P7Jc9VrS5goVyzqsfInedUX2nzOO7XV5Iw==
+ dependencies:
+ "@zag-js/core" "1.40.0"
+ "@zag-js/store" "1.40.0"
+ "@zag-js/types" "1.40.0"
+ "@zag-js/utils" "1.40.0"
+
+acorn-jsx@^5.3.2:
+ version "5.3.2"
+ resolved "https://registry.yarnpkg.com/acorn-jsx/-/acorn-jsx-5.3.2.tgz#7ed5bb55908b3b2f1bc55c6af1653bada7f07937"
+ integrity sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==
+
+acorn@^8.15.0, acorn@^8.16.0, acorn@^8.5.0:
+ version "8.16.0"
+ resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.16.0.tgz#4ce79c89be40afe7afe8f3adb902a1f1ce9ac08a"
+ integrity sha512-UVJyE9MttOsBQIDKw1skb9nAwQuR5wuGD3+82K6JgJlm/Y+KI92oNsMNGZCYdDsVtRHSak0pcV5Dno5+4jh9sw==
+
+ajv@^6.14.0:
+ version "6.15.0"
+ resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.15.0.tgz#07e982c74626167aa7a2495c53817892d7139492"
+ integrity sha512-fgFx7Hfoq60ytK2c7DhnF8jIvzYgOMxfugjLOSMHjLIPgenqa7S7oaagATUq99mV6IYvN2tRmC0wnTYX6iPbMw==
+ 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"
+
+alien-signals@^3.1.2:
+ version "3.1.2"
+ resolved "https://registry.yarnpkg.com/alien-signals/-/alien-signals-3.1.2.tgz#26e623e3ed81e401df1a7c503f726e2288a4fa02"
+ integrity sha512-d9dYqZTS90WLiU0I5c6DHj/HcKkF8ZyGN3G5x8wSbslulz70KOxaqCT0hQCo9KOyhVqzqGojvNdJXoTumZOtcw==
+
+ansis@^4.2.0:
+ version "4.2.0"
+ resolved "https://registry.yarnpkg.com/ansis/-/ansis-4.2.0.tgz#2e6e61c46b11726ac67f78785385618b9e658780"
+ integrity sha512-HqZ5rWlFjGiV0tDm3UxxgNRqsOTniqoKZu0pIAfh7TZQMGuZK+hH0drySty0si0QXj1ieop4+SkSfPZBPPkHig==
+
+are-docs-informative@^0.0.2:
+ version "0.0.2"
+ resolved "https://registry.yarnpkg.com/are-docs-informative/-/are-docs-informative-0.0.2.tgz#387f0e93f5d45280373d387a59d34c96db321963"
+ integrity sha512-ixiS0nLNNG5jNQzgZJNoUpBKdo9yTYZMGJ+QgT2jmjR7G7+QHRCc4v6LQ3NgE7EBJq+o0ams3waJwkrlBom8Ig==
+
+ast-kit@^2.1.2, ast-kit@^2.1.3:
+ version "2.2.0"
+ resolved "https://registry.yarnpkg.com/ast-kit/-/ast-kit-2.2.0.tgz#6d9a298acefef5bdfc5a0fa51d94d1334ef2e671"
+ integrity sha512-m1Q/RaVOnTp9JxPX+F+Zn7IcLYMzM8kZofDImfsKZd8MbR+ikdOzTeztStWqfrqIxZnYWryyI9ePm3NGjnZgGw==
+ dependencies:
+ "@babel/parser" "^7.28.5"
+ pathe "^2.0.3"
+
+ast-walker-scope@^0.8.3:
+ version "0.8.3"
+ resolved "https://registry.yarnpkg.com/ast-walker-scope/-/ast-walker-scope-0.8.3.tgz#f516c42669f3b77e1473a78e5e9d3c5b2e7c1e8e"
+ integrity sha512-cbdCP0PGOBq0ASG+sjnKIoYkWMKhhz+F/h9pRexUdX2Hd38+WOlBkRKlqkGOSm0YQpcFMQBJeK4WspUAkwsEdg==
+ dependencies:
+ "@babel/parser" "^7.28.4"
+ ast-kit "^2.1.3"
+
+balanced-match@^4.0.2:
+ version "4.0.4"
+ resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-4.0.4.tgz#bfb10662feed8196a2c62e7c68e17720c274179a"
+ integrity sha512-BLrgEcRTwX2o6gGxGOCNyMvGSp35YofuYzw9h1IMTRmKqttAZZVU67bdb9Pr2vUHA8+j3i2tJfjO6C6+4myGTA==
+
+baseline-browser-mapping@^2.10.12:
+ version "2.10.27"
+ resolved "https://registry.yarnpkg.com/baseline-browser-mapping/-/baseline-browser-mapping-2.10.27.tgz#fee941c2a0b42cdf83c6427e4c830b1d0bdab2c3"
+ integrity sha512-zEs/ufmZoUd7WftKpKyXaT6RFxpQ5Qm9xytKRHvJfxFV9DFJkZph9RvJ1LcOUi0Z1ZVijMte65JbILeV+8QQEA==
+
+birpc@^2.6.1:
+ version "2.9.0"
+ resolved "https://registry.yarnpkg.com/birpc/-/birpc-2.9.0.tgz#b59550897e4cd96a223e2a6c1475b572236ed145"
+ integrity sha512-KrayHS5pBi69Xi9JmvoqrIgYGDkD6mcSe/i6YKi3w5kekCLzrX4+nawcXqrj2tIp50Kw/mT/s3p+GVK0A0sKxw==
+
+boolbase@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/boolbase/-/boolbase-1.0.0.tgz#68dff5fbe60c51eb37725ea9e3ed310dcc1e776e"
+ integrity sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==
+
+brace-expansion@^5.0.5:
+ version "5.0.5"
+ resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-5.0.5.tgz#dcc3a37116b79f3e1b46db994ced5d570e930fdb"
+ integrity sha512-VZznLgtwhn+Mact9tfiwx64fA9erHH/MCXEUfB/0bX/6Fz6ny5EGTXYltMocqg4xFAQZtnO3DHWWXi8RiuN7cQ==
+ dependencies:
+ balanced-match "^4.0.2"
+
+browserslist@^4.28.1:
+ version "4.28.2"
+ resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.28.2.tgz#f50b65362ef48974ca9f50b3680566d786b811d2"
+ integrity sha512-48xSriZYYg+8qXna9kwqjIVzuQxi+KYWp2+5nCYnYKPTr0LvD89Jqk2Or5ogxz0NUMfIjhh2lIUX/LyX9B4oIg==
+ dependencies:
+ baseline-browser-mapping "^2.10.12"
+ caniuse-lite "^1.0.30001782"
+ electron-to-chromium "^1.5.328"
+ node-releases "^2.0.36"
+ update-browserslist-db "^1.2.3"
+
+builtin-modules@^5.0.0:
+ version "5.1.0"
+ resolved "https://registry.yarnpkg.com/builtin-modules/-/builtin-modules-5.1.0.tgz#1122bd65380abffe08f6cf15b381aff38b0ceb1a"
+ integrity sha512-c5JxaDrzwRjq3WyJkI1AGR5xy6Gr6udlt7sQPbl09+3ckB+Zo2qqQ2KhCTBr7Q8dHB43bENGYEk4xddrFH/b7A==
+
+cac@^7.0.0:
+ version "7.0.0"
+ resolved "https://registry.yarnpkg.com/cac/-/cac-7.0.0.tgz#7dda83da2268f75f840ab89ac3bcc36c120a78da"
+ integrity sha512-tixWYgm5ZoOD+3g6UTea91eow5z6AAHaho3g0V9CNSNb45gM8SmflpAc+GRd1InC4AqN/07Unrgp56Y94N9hJQ==
+
+caniuse-lite@^1.0.30001782:
+ version "1.0.30001792"
+ resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001792.tgz#ca8bb9be244835a335e2018272ce7223691873c5"
+ integrity sha512-hVLMUZFgR4JJ6ACt1uEESvQN1/dBVqPAKY0hgrV70eN3391K6juAfTjKZLKvOMsx8PxA7gsY1/tLMMTcfFLLpw==
+
+ccount@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/ccount/-/ccount-2.0.1.tgz#17a3bf82302e0870d6da43a01311a8bc02a3ecf5"
+ integrity sha512-eyrF0jiFpY+3drT6383f1qhkbGsLSifNAjA61IUjZjmLCWjItY6LB9ft9YhoDgwfmclB2zhu51Lc7+95b8NRAg==
+
+change-case@^5.4.4:
+ version "5.4.4"
+ resolved "https://registry.yarnpkg.com/change-case/-/change-case-5.4.4.tgz#0d52b507d8fb8f204343432381d1a6d7bff97a02"
+ integrity sha512-HRQyTk2/YPEkt9TnUPbOpr64Uw3KOicFWPVBb+xiHvd6eBx/qPr9xqfBFDT8P2vWsvvz4jbEkfDe71W3VyNu2w==
+
+character-entities@^2.0.0:
+ version "2.0.2"
+ resolved "https://registry.yarnpkg.com/character-entities/-/character-entities-2.0.2.tgz#2d09c2e72cd9523076ccb21157dff66ad43fcc22"
+ integrity sha512-shx7oQ0Awen/BRIdkjkvz54PnEEI/EjwXDSIZp86/KKdbafHh1Df/RYGBhn4hbe2+uKC9FnT5UCEdyPz3ai9hQ==
+
+chokidar@^4.0.0:
+ version "4.0.3"
+ resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-4.0.3.tgz#7be37a4c03c9aee1ecfe862a4a23b2c70c205d30"
+ integrity sha512-Qgzu8kfBvo+cA4962jnP1KkS6Dop5NS6g7R5LFYJr4b8Ub94PPQXUksCw9PvXoeXPRRddRNC5C1JQUR2SMGtnA==
+ dependencies:
+ readdirp "^4.0.1"
+
+chokidar@^5.0.0:
+ version "5.0.0"
+ resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-5.0.0.tgz#949c126a9238a80792be9a0265934f098af369a5"
+ integrity sha512-TQMmc3w+5AxjpL8iIiwebF73dRDF4fBIieAqGn9RGCWaEVwQ6Fb2cGe31Yns0RRIzii5goJ1Y7xbMwo1TxMplw==
+ dependencies:
+ readdirp "^5.0.0"
+
+ci-info@^4.4.0:
+ version "4.4.0"
+ resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-4.4.0.tgz#7d54eff9f54b45b62401c26032696eb59c8bd18c"
+ integrity sha512-77PSwercCZU2Fc4sX94eF8k8Pxte6JAwL4/ICZLFjJLqegs7kCuAsqqj/70NQF6TvDpgFjkubQB2FW2ZZddvQg==
+
+clean-regexp@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/clean-regexp/-/clean-regexp-1.0.0.tgz#8df7c7aae51fd36874e8f8d05b9180bc11a3fed7"
+ integrity sha512-GfisEZEJvzKrmGWkvfhgzcz/BllN1USeqD2V6tg14OAOgaCD2Z/PUEuxnAZ/nPvmaHRG7a8y77p1T/IRQ4D1Hw==
+ dependencies:
+ escape-string-regexp "^1.0.5"
+
+colorjs.io@^0.5.0:
+ version "0.5.2"
+ resolved "https://registry.yarnpkg.com/colorjs.io/-/colorjs.io-0.5.2.tgz#63b20139b007591ebc3359932bef84628eb3fcef"
+ integrity sha512-twmVoizEW7ylZSN32OgKdXRmo1qg+wT5/6C3xu5b9QsWzSFAhHLn2xd8ro0diCsKfCj1RdaTP/nrcW+vAoQPIw==
+
+commander@^8.3.0:
+ version "8.3.0"
+ resolved "https://registry.yarnpkg.com/commander/-/commander-8.3.0.tgz#4837ea1b2da67b9c616a67afbb0fafee567bca66"
+ integrity sha512-OkTL9umf+He2DZkUq8f8J9of7yL6RJKI24dVITBmNfZBmri9zYZQrKkuXiKhyfPSu8tUhnVBB1iKXevvnlR4Ww==
+
+comment-parser@1.4.5:
+ version "1.4.5"
+ resolved "https://registry.yarnpkg.com/comment-parser/-/comment-parser-1.4.5.tgz#6c595cd090737a1010fe5ff40d86e1d21b7bd6ce"
+ integrity sha512-aRDkn3uyIlCFfk5NUA+VdwMmMsh8JGhc4hapfV4yxymHGQ3BVskMQfoXGpCo5IoBuQ9tS5iiVKhCpTcB4pW4qw==
+
+comment-parser@1.4.6, comment-parser@^1.4.0:
+ version "1.4.6"
+ resolved "https://registry.yarnpkg.com/comment-parser/-/comment-parser-1.4.6.tgz#49a6b1d53fa563324f7577ab8c0b26db4e7d1f9a"
+ integrity sha512-ObxuY6vnbWTN6Od72xfwN9DbzC7Y2vv8u1Soi9ahRKL37gb6y1qk6/dgjs+3JWuXJHWvsg3BXIwzd/rkmAwavg==
+
+confbox@^0.1.8:
+ version "0.1.8"
+ resolved "https://registry.yarnpkg.com/confbox/-/confbox-0.1.8.tgz#820d73d3b3c82d9bd910652c5d4d599ef8ff8b06"
+ integrity sha512-RMtmw0iFkeR4YV+fUOSucriAQNb9g8zFR52MWCtl+cCZOFRNL6zeB395vPzFhEjjn4fMxXudmELnl/KF/WrK6w==
+
+confbox@^0.2.4:
+ version "0.2.4"
+ resolved "https://registry.yarnpkg.com/confbox/-/confbox-0.2.4.tgz#592e7be71f882a4a874e3c88f0ac1ef6f7da1ce5"
+ integrity sha512-ysOGlgTFbN2/Y6Cg3Iye8YKulHw+R2fNXHrgSmXISQdMnomY6eNDprVdW9R5xBguEqI954+S6709UyiO7B+6OQ==
+
+core-js-compat@^3.49.0:
+ version "3.49.0"
+ resolved "https://registry.yarnpkg.com/core-js-compat/-/core-js-compat-3.49.0.tgz#06145447d92f4aaf258a0c44f24b47afaeaffef6"
+ integrity sha512-VQXt1jr9cBz03b331DFDCCP90b3fanciLkgiOoy8SBHy06gNf+vQ1A3WFLqG7I8TipYIKeYK9wxd0tUrvHcOZA==
+ dependencies:
+ browserslist "^4.28.1"
+
+cross-spawn@^7.0.6:
+ version "7.0.6"
+ resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.6.tgz#8a58fe78f00dcd70c370451759dfbfaf03e8ee9f"
+ integrity sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==
+ dependencies:
+ path-key "^3.1.0"
+ shebang-command "^2.0.0"
+ which "^2.0.1"
+
+cssesc@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.yarnpkg.com/cssesc/-/cssesc-3.0.0.tgz#37741919903b868565e1c09ea747445cd18983ee"
+ integrity sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==
+
+csstype@3.2.3, csstype@^3.2.3:
+ version "3.2.3"
+ resolved "https://registry.yarnpkg.com/csstype/-/csstype-3.2.3.tgz#ec48c0f3e993e50648c86da559e2610995cf989a"
+ integrity sha512-z1HGKcYy2xA8AGQfwrn0PAy+PB7X/GSj3UVJW9qKyn43xWa+gl5nXmU4qqLMRzWVLFC8KusUX8T/0kCiOYpAIQ==
+
+debug@^4.0.0, debug@^4.1.1, debug@^4.3.1, debug@^4.3.2, debug@^4.4.0, debug@^4.4.3:
+ version "4.4.3"
+ resolved "https://registry.yarnpkg.com/debug/-/debug-4.4.3.tgz#c6ae432d9bd9662582fce08709b038c58e9e3d6a"
+ integrity sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==
+ dependencies:
+ ms "^2.1.3"
+
+decode-named-character-reference@^1.0.0:
+ version "1.3.0"
+ resolved "https://registry.yarnpkg.com/decode-named-character-reference/-/decode-named-character-reference-1.3.0.tgz#3e40603760874c2e5867691b599d73a7da25b53f"
+ integrity sha512-GtpQYB283KrPp6nRw50q3U9/VfOutZOe103qlN7BPP6Ad27xYnOIWv4lPzo8HCAL+mMZofJ9KEy30fq6MfaK6Q==
+ dependencies:
+ character-entities "^2.0.0"
+
+deep-is@^0.1.3:
+ version "0.1.4"
+ resolved "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.4.tgz#a6f2dce612fadd2ef1f519b73551f17e85199831"
+ integrity sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==
+
+dequal@^2.0.0:
+ version "2.0.3"
+ resolved "https://registry.yarnpkg.com/dequal/-/dequal-2.0.3.tgz#2644214f1997d39ed0ee0ece72335490a7ac67be"
+ integrity sha512-0je+qPKHEMohvfRTCEo3CrPG6cAzAYgmzKyxRiYSSDkS6eGJdyVJm7WaYA5ECaAD9wLB2T4EEeymA5aFVcYXCA==
+
+detect-libc@^2.0.3:
+ version "2.1.2"
+ resolved "https://registry.yarnpkg.com/detect-libc/-/detect-libc-2.1.2.tgz#689c5dcdc1900ef5583a4cb9f6d7b473742074ad"
+ integrity sha512-Btj2BOOO83o3WyH59e8MgXsxEQVcarkUOpEYrubB0urwnN10yQ364rsiByU11nZlqWYZm05i/of7io4mzihBtQ==
+
+devlop@^1.0.0, devlop@^1.1.0:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/devlop/-/devlop-1.1.0.tgz#4db7c2ca4dc6e0e834c30be70c94bbc976dc7018"
+ integrity sha512-RWmIqhcFf1lRYBvNmr7qTNuyCt/7/ns2jbpp1+PalgE/rDQcBT0fioSMUpJ93irlUhC5hrg4cYqe6U+0ImW0rA==
+ dependencies:
+ dequal "^2.0.0"
+
+diff-sequences@^29.0.0, diff-sequences@^29.6.3:
+ version "29.6.3"
+ resolved "https://registry.yarnpkg.com/diff-sequences/-/diff-sequences-29.6.3.tgz#4deaf894d11407c51efc8418012f9e70b84ea921"
+ integrity sha512-EjePK1srD3P08o2j4f0ExnylqRs5B9tJjcp9t1krH2qRi8CCdsYfwe9JgSLurFBWwq4uOlipzfk5fHNvwFKr8Q==
+
+electron-to-chromium@^1.5.328:
+ version "1.5.351"
+ resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.5.351.tgz#7314fbb5b4835a1869feaec09665541b6a84cd37"
+ integrity sha512-9D7Iqx8RImSvCnOsj86rCH6eQjZFQoM04Jn6HnZVM0Nu/G58/gmKYQ1d12MZTbjQbQSTGI8nwEy07ErsA2slLA==
+
+empathic@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/empathic/-/empathic-2.0.0.tgz#71d3c2b94fad49532ef98a6c34be0386659f6131"
+ integrity sha512-i6UzDscO/XfAcNYD75CfICkmfLedpyPDdozrLMmQc5ORaQcdMoc21OnlEylMIqI7U8eniKrPMxxtj8k0vhmJhA==
+
+enhanced-resolve@^5.17.1:
+ version "5.21.0"
+ resolved "https://registry.yarnpkg.com/enhanced-resolve/-/enhanced-resolve-5.21.0.tgz#bb8e6fabaf74930de70e61397798750429e5b1ae"
+ integrity sha512-otxSQPw4lkOZWkHpB3zaEQs6gWYEsmX4xQF68ElXC/TWvGxGMSGOvoNbaLXm6/cS/fSfHtsEdw90y20PCd+sCA==
+ dependencies:
+ graceful-fs "^4.2.4"
+ tapable "^2.3.3"
+
+entities@^7.0.1:
+ version "7.0.1"
+ resolved "https://registry.yarnpkg.com/entities/-/entities-7.0.1.tgz#26e8a88889db63417dcb9a1e79a3f1bc92b5976b"
+ integrity sha512-TWrgLOFUQTH994YUyl1yT4uyavY5nNB5muff+RtWaqNVCAK408b5ZnnbNAUEWLTCpum9w6arT70i1XdQ4UeOPA==
+
+escalade@^3.2.0:
+ version "3.2.0"
+ resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.2.0.tgz#011a3f69856ba189dffa7dc8fcce99d2a87903e5"
+ integrity sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==
+
+escape-string-regexp@5.0.0, escape-string-regexp@^5.0.0:
+ version "5.0.0"
+ resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-5.0.0.tgz#4683126b500b61762f2dbebace1806e8be31b1c8"
+ integrity sha512-/veY75JbMK4j1yjvuUxuVsiS/hr/4iHs9FTT6cgTexxdE0Ly/glccBAkloH/DofkjRbZU3bnoj38mOmhkZ0lHw==
+
+escape-string-regexp@^1.0.5:
+ version "1.0.5"
+ resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4"
+ integrity sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==
+
+escape-string-regexp@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz#14ba83a5d373e3d311e5afca29cf5bfad965bf34"
+ integrity sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==
+
+eslint-compat-utils@^0.5.1:
+ version "0.5.1"
+ resolved "https://registry.yarnpkg.com/eslint-compat-utils/-/eslint-compat-utils-0.5.1.tgz#7fc92b776d185a70c4070d03fd26fde3d59652e4"
+ integrity sha512-3z3vFexKIEnjHE3zCMRo6fn/e44U7T1khUjg+Hp0ZQMCigh28rALD0nPFBcGZuiLC5rLZa2ubQHDRln09JfU2Q==
+ dependencies:
+ semver "^7.5.4"
+
+eslint-config-flat-gitignore@^2.3.0:
+ version "2.3.0"
+ resolved "https://registry.yarnpkg.com/eslint-config-flat-gitignore/-/eslint-config-flat-gitignore-2.3.0.tgz#a5e5816acd0c54eb58c811621f220b07ee1b4012"
+ integrity sha512-bg4ZLGgoARg1naWfsINUUb/52Ksw/K22K+T16D38Y8v+/sGwwIYrGvH/JBjOin+RQtxxC9tzNNiy4shnGtGyyQ==
+ dependencies:
+ "@eslint/compat" "^2.0.3"
+
+eslint-flat-config-utils@^3.1.0:
+ version "3.2.0"
+ resolved "https://registry.yarnpkg.com/eslint-flat-config-utils/-/eslint-flat-config-utils-3.2.0.tgz#39ea0443d395e4aa6a965af88063e617e6978b29"
+ integrity sha512-PHgo1X5uqIorJONLVD9BIaOSdoYFD3z/AeJljdqDPlWVRpeCYkDbK9k0AXoYVqqNJr6FEYIEr5Rm2TSktLQcHw==
+ dependencies:
+ "@eslint/config-helpers" "^0.5.5"
+ pathe "^2.0.3"
+
+eslint-formatting-reporter@^0.0.0:
+ version "0.0.0"
+ resolved "https://registry.yarnpkg.com/eslint-formatting-reporter/-/eslint-formatting-reporter-0.0.0.tgz#e444c511527900dec3592e9f85876da821ab8ef7"
+ integrity sha512-k9RdyTqxqN/wNYVaTk/ds5B5rA8lgoAmvceYN7bcZMBwU7TuXx5ntewJv81eF3pIL/CiJE+pJZm36llG8yhyyw==
+ dependencies:
+ prettier-linter-helpers "^1.0.0"
+
+eslint-json-compat-utils@^0.2.3:
+ version "0.2.3"
+ resolved "https://registry.yarnpkg.com/eslint-json-compat-utils/-/eslint-json-compat-utils-0.2.3.tgz#f6ef27e80c750b56cbedb4de67a10b1d47f0a8a7"
+ integrity sha512-RbBmDFyu7FqnjE8F0ZxPNzx5UaptdeS9Uu50r7A+D7s/+FCX+ybiyViYEgFUaFIFqSWJgZRTpL5d8Kanxxl2lQ==
+ dependencies:
+ esquery "^1.6.0"
+
+eslint-merge-processors@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/eslint-merge-processors/-/eslint-merge-processors-2.0.0.tgz#f1e02bd863962fab7fd038c293979283e61b473c"
+ integrity sha512-sUuhSf3IrJdGooquEUB5TNpGNpBoQccbnaLHsb1XkBLUPPqCNivCpY05ZcpCOiV9uHwO2yxXEWVczVclzMxYlA==
+
+eslint-parser-plain@^0.1.1:
+ version "0.1.1"
+ resolved "https://registry.yarnpkg.com/eslint-parser-plain/-/eslint-parser-plain-0.1.1.tgz#14e92bba9f9a7f765b36967bd3f2f24c0a81c2b3"
+ integrity sha512-KRgd6wuxH4U8kczqPp+Oyk4irThIhHWxgFgLDtpgjUGVIS3wGrJntvZW/p6hHq1T4FOwnOtCNkvAI4Kr+mQ/Hw==
+
+eslint-plugin-antfu@^3.2.2:
+ version "3.2.2"
+ resolved "https://registry.yarnpkg.com/eslint-plugin-antfu/-/eslint-plugin-antfu-3.2.2.tgz#9515f624eefdec9e637feb098b5e3f510c885e7b"
+ integrity sha512-Qzixht2Dmd/pMbb5EnKqw2V8TiWHbotPlsORO8a+IzCLFwE0RxK8a9k4DCTFPzBwyxJzH+0m2Mn8IUGeGQkyUw==
+
+eslint-plugin-command@^3.5.2:
+ version "3.5.2"
+ resolved "https://registry.yarnpkg.com/eslint-plugin-command/-/eslint-plugin-command-3.5.2.tgz#f2d7299be7d8d5b04f8d88c84920cf0b4ade058d"
+ integrity sha512-PA59QAkQDwvcCMEt5lYLJLI3zDGVKJeC4id/pcRY2XdRYhSGW7iyYT1VC1N3bmpuvu6Qb/9QptiS3GJMjeGTJg==
+ dependencies:
+ "@es-joy/jsdoccomment" "^0.84.0"
+
+eslint-plugin-depend@^1.5.0:
+ version "1.5.0"
+ resolved "https://registry.yarnpkg.com/eslint-plugin-depend/-/eslint-plugin-depend-1.5.0.tgz#3bed81d2326b0c5a7f40a8146ae6eee8bdd74095"
+ integrity sha512-i3UeLYmclf1Icp35+6W7CR4Bp2PIpDgBuf/mpmXK5UeLkZlvYJ21VuQKKHHAIBKRTPivPGX/gZl5JGno1o9Y0A==
+ dependencies:
+ empathic "^2.0.0"
+ module-replacements "^2.10.1"
+ semver "^7.6.3"
+
+eslint-plugin-es-x@^7.8.0:
+ version "7.8.0"
+ resolved "https://registry.yarnpkg.com/eslint-plugin-es-x/-/eslint-plugin-es-x-7.8.0.tgz#a207aa08da37a7923f2a9599e6d3eb73f3f92b74"
+ integrity sha512-7Ds8+wAAoV3T+LAKeu39Y5BzXCrGKrcISfgKEqTS4BDN8SFEDQd0S43jiQ8vIa3wUKD07qitZdfzlenSi8/0qQ==
+ dependencies:
+ "@eslint-community/eslint-utils" "^4.1.2"
+ "@eslint-community/regexpp" "^4.11.0"
+ eslint-compat-utils "^0.5.1"
+
+eslint-plugin-format@^2.0.1:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/eslint-plugin-format/-/eslint-plugin-format-2.0.1.tgz#61ae7d9f23fb5de23759674982a57e214f88d987"
+ integrity sha512-0BA65p5DAiuKtx5MmMJfPk9WaTjoHHbyVW7ZXRhaZoA1fdiMHhay9QRiDL2wr0hJWZxdF7CRThOK/70VUKVg2g==
+ dependencies:
+ "@dprint/formatter" "^0.5.1"
+ "@dprint/markdown" "^0.21.1"
+ "@dprint/toml" "^0.7.0"
+ eslint-formatting-reporter "^0.0.0"
+ eslint-parser-plain "^0.1.1"
+ ohash "^2.0.11"
+ oxfmt "^0.35.0"
+ prettier "^3.8.1"
+ synckit "^0.11.12"
+
+eslint-plugin-import-lite@^0.6.0:
+ version "0.6.0"
+ resolved "https://registry.yarnpkg.com/eslint-plugin-import-lite/-/eslint-plugin-import-lite-0.6.0.tgz#dcb214c1833853623b6f2b8919729fce905d0833"
+ integrity sha512-80vevx2A7i3H7n1/6pqDO8cc5wRz6OwLDvIyVl9UflBV1N1f46e9Ihzi65IOLYoSxM6YykK2fTw1xm0Ixx6aTQ==
+
+eslint-plugin-jsdoc@^62.9.0:
+ version "62.9.0"
+ resolved "https://registry.yarnpkg.com/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-62.9.0.tgz#a4902f6978b1e7cc5c5d1a528ecf7d8c7ce716d9"
+ integrity sha512-PY7/X4jrVgoIDncUmITlUqK546Ltmx/Pd4Hdsu4CvSjryQZJI2mEV4vrdMufyTetMiZ5taNSqvK//BTgVUlNkA==
+ dependencies:
+ "@es-joy/jsdoccomment" "~0.86.0"
+ "@es-joy/resolve.exports" "1.2.0"
+ are-docs-informative "^0.0.2"
+ comment-parser "1.4.6"
+ debug "^4.4.3"
+ escape-string-regexp "^4.0.0"
+ espree "^11.2.0"
+ esquery "^1.7.0"
+ html-entities "^2.6.0"
+ object-deep-merge "^2.0.0"
+ parse-imports-exports "^0.2.4"
+ semver "^7.7.4"
+ spdx-expression-parse "^4.0.0"
+ to-valid-identifier "^1.0.0"
+
+eslint-plugin-jsonc@^3.1.2:
+ version "3.1.2"
+ resolved "https://registry.yarnpkg.com/eslint-plugin-jsonc/-/eslint-plugin-jsonc-3.1.2.tgz#b42e7745d644938e498fdbbbc818a3197b914ada"
+ integrity sha512-dopTxdB22iuOkgKyJCupEC5IYBItUT4J/teq1H5ddUObcaYhOURxtJElZczdcYnnKCghNU/vccuyPkliy2Wxsg==
+ dependencies:
+ "@eslint-community/eslint-utils" "^4.5.1"
+ "@eslint/core" "^1.0.1"
+ "@eslint/plugin-kit" "^0.6.0"
+ "@ota-meshi/ast-token-store" "^0.3.0"
+ diff-sequences "^29.6.3"
+ eslint-json-compat-utils "^0.2.3"
+ jsonc-eslint-parser "^3.1.0"
+ natural-compare "^1.4.0"
+ synckit "^0.11.12"
+
+eslint-plugin-n@^17.24.0:
+ version "17.24.0"
+ resolved "https://registry.yarnpkg.com/eslint-plugin-n/-/eslint-plugin-n-17.24.0.tgz#b66fa05f7a6c1ba16768f0921b8974147dddd060"
+ integrity sha512-/gC7/KAYmfNnPNOb3eu8vw+TdVnV0zhdQwexsw6FLXbhzroVj20vRn2qL8lDWDGnAQ2J8DhdfvXxX9EoxvERvw==
+ dependencies:
+ "@eslint-community/eslint-utils" "^4.5.0"
+ enhanced-resolve "^5.17.1"
+ eslint-plugin-es-x "^7.8.0"
+ get-tsconfig "^4.8.1"
+ globals "^15.11.0"
+ globrex "^0.1.2"
+ ignore "^5.3.2"
+ semver "^7.6.3"
+ ts-declaration-location "^1.0.6"
+
+eslint-plugin-no-only-tests@^3.3.0:
+ version "3.4.0"
+ resolved "https://registry.yarnpkg.com/eslint-plugin-no-only-tests/-/eslint-plugin-no-only-tests-3.4.0.tgz#a457d2c559bda3301ce5a75147b8ba447186e88a"
+ integrity sha512-4S3/9Nb7A2tiMcpzEQE9bQSlpeOz6WJkgryBuou/SA8W2x2c8Zf4j0NvTKBjv6qNhF9T79tmkecm/0CHqV0UGg==
+
+eslint-plugin-perfectionist@^5.8.0:
+ version "5.9.0"
+ resolved "https://registry.yarnpkg.com/eslint-plugin-perfectionist/-/eslint-plugin-perfectionist-5.9.0.tgz#d8844892fa4b1069df27910f41d7e7981df1ca4b"
+ integrity sha512-8TWzg02zmnBdZwCkWLi8jhzqXI+fE7Z/RwV8SL6xD45tJ8Bp3wGuYL2XtQgfe/Wd0eBqOUX+s6ey73IyszvKTA==
+ dependencies:
+ "@typescript-eslint/utils" "^8.58.2"
+ natural-orderby "^5.0.0"
+
+eslint-plugin-pnpm@^1.6.0:
+ version "1.6.0"
+ resolved "https://registry.yarnpkg.com/eslint-plugin-pnpm/-/eslint-plugin-pnpm-1.6.0.tgz#062dc0d52785112a74b7c865d6134e751053d754"
+ integrity sha512-dxmt9r3zvPaft6IugS4i0k16xag3fTbOvm/road5uV9Y8qUCQT0xzheSh3gMlYAlC6vXRpfArBDsTZ7H7JKCbg==
+ dependencies:
+ empathic "^2.0.0"
+ jsonc-eslint-parser "^3.1.0"
+ pathe "^2.0.3"
+ pnpm-workspace-yaml "1.6.0"
+ tinyglobby "^0.2.15"
+ yaml "^2.8.2"
+ yaml-eslint-parser "^2.0.0"
+
+eslint-plugin-regexp@^3.1.0:
+ version "3.1.0"
+ resolved "https://registry.yarnpkg.com/eslint-plugin-regexp/-/eslint-plugin-regexp-3.1.0.tgz#e6fede2919ae39cece0669e02259c0feb1718cd9"
+ integrity sha512-qGXIC3DIKZHcK1H9A9+Byz9gmndY6TTSRkSMTZpNXdyCw2ObSehRgccJv35n9AdUakEjQp5VFNLas6BMXizCZg==
+ dependencies:
+ "@eslint-community/eslint-utils" "^4.2.0"
+ "@eslint-community/regexpp" "^4.11.0"
+ comment-parser "^1.4.0"
+ jsdoc-type-pratt-parser "^7.0.0"
+ refa "^0.12.1"
+ regexp-ast-analysis "^0.7.1"
+ scslre "^0.3.0"
+
+eslint-plugin-toml@^1.3.1:
+ version "1.3.1"
+ resolved "https://registry.yarnpkg.com/eslint-plugin-toml/-/eslint-plugin-toml-1.3.1.tgz#754992b4d300da24b4bcc74ff9b96891b9c35160"
+ integrity sha512-1l00fBP03HIt9IPV7ZxBi7x0y0NMdEZmakL1jBD6N/FoKBvfKxPw5S8XkmzBecOnFBTn5Z8sNJtL5vdf9cpRMQ==
+ dependencies:
+ "@eslint/core" "^1.0.1"
+ "@eslint/plugin-kit" "^0.6.0"
+ "@ota-meshi/ast-token-store" "^0.3.0"
+ debug "^4.1.1"
+ toml-eslint-parser "^1.0.1"
+
+eslint-plugin-unicorn@^64.0.0:
+ version "64.0.0"
+ resolved "https://registry.yarnpkg.com/eslint-plugin-unicorn/-/eslint-plugin-unicorn-64.0.0.tgz#e1cd29155d7da42cd42180211f053ed9b68d11f5"
+ integrity sha512-rNZwalHh8i0UfPlhNwg5BTUO1CMdKNmjqe+TgzOTZnpKoi8VBgsW7u9qCHIdpxEzZ1uwrJrPF0uRb7l//K38gA==
+ dependencies:
+ "@babel/helper-validator-identifier" "^7.28.5"
+ "@eslint-community/eslint-utils" "^4.9.1"
+ change-case "^5.4.4"
+ ci-info "^4.4.0"
+ clean-regexp "^1.0.0"
+ core-js-compat "^3.49.0"
+ find-up-simple "^1.0.1"
+ globals "^17.4.0"
+ indent-string "^5.0.0"
+ is-builtin-module "^5.0.0"
+ jsesc "^3.1.0"
+ pluralize "^8.0.0"
+ regexp-tree "^0.1.27"
+ regjsparser "^0.13.0"
+ semver "^7.7.4"
+ strip-indent "^4.1.1"
+
+eslint-plugin-unused-imports@^4.4.1:
+ version "4.4.1"
+ resolved "https://registry.yarnpkg.com/eslint-plugin-unused-imports/-/eslint-plugin-unused-imports-4.4.1.tgz#a831f0a2937d7631eba30cb87091ab7d3a5da0e1"
+ integrity sha512-oZGYUz1X3sRMGUB+0cZyK2VcvRX5lm/vB56PgNNcU+7ficUCKm66oZWKUubXWnOuPjQ8PvmXtCViXBMONPe7tQ==
+
+eslint-plugin-vue@^10.8.0:
+ version "10.9.1"
+ resolved "https://registry.yarnpkg.com/eslint-plugin-vue/-/eslint-plugin-vue-10.9.1.tgz#18f5c63780123270eca4bf438c40c7b4186ab840"
+ integrity sha512-cHB0Tf4Duvzwecwd/AqWzZvF/QszE13BhjVUpVXWCy9AeMR5GjkAjP3i85vqgLgOuTmkHR1OJ5oMeqLHtuw8zg==
+ dependencies:
+ "@eslint-community/eslint-utils" "^4.4.0"
+ natural-compare "^1.4.0"
+ nth-check "^2.1.1"
+ postcss-selector-parser "^7.1.0"
+ semver "^7.6.3"
+ xml-name-validator "^4.0.0"
+
+eslint-plugin-yml@^3.3.1:
+ version "3.3.2"
+ resolved "https://registry.yarnpkg.com/eslint-plugin-yml/-/eslint-plugin-yml-3.3.2.tgz#b73907959518118498c9f7aee913dfa229cae6af"
+ integrity sha512-XjmOB/fLBwYHqevnpclPL938V+9ExX7xw1hPaM3IPePGyMFRV1giS16RjSTNhIyCv/Oh0G0PEdmmZPATJ02YCw==
+ dependencies:
+ "@eslint/core" "^1.0.1"
+ "@eslint/plugin-kit" "^0.7.0"
+ "@ota-meshi/ast-token-store" "^0.3.0"
+ diff-sequences "^29.0.0"
+ escape-string-regexp "5.0.0"
+ natural-compare "^1.4.0"
+ yaml-eslint-parser "^2.0.0"
+
+eslint-processor-vue-blocks@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/eslint-processor-vue-blocks/-/eslint-processor-vue-blocks-2.0.0.tgz#b06a2e2bdefda75792e9fc9f00a9de305e657472"
+ integrity sha512-u4W0CJwGoWY3bjXAuFpc/b6eK3NQEI8MoeW7ritKj3G3z/WtHrKjkqf+wk8mPEy5rlMGS+k6AZYOw2XBoN/02Q==
+
+"eslint-scope@^8.2.0 || ^9.0.0", eslint-scope@^9.1.2:
+ version "9.1.2"
+ resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-9.1.2.tgz#b9de6ace2fab1cff24d2e58d85b74c8fcea39802"
+ integrity sha512-xS90H51cKw0jltxmvmHy2Iai1LIqrfbw57b79w/J7MfvDfkIkFZ+kj6zC3BjtUwh150HsSSdxXZcsuv72miDFQ==
+ dependencies:
+ "@types/esrecurse" "^4.3.1"
+ "@types/estree" "^1.0.8"
+ esrecurse "^4.3.0"
+ estraverse "^5.2.0"
+
+eslint-visitor-keys@^3.4.3:
+ version "3.4.3"
+ resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz#0cd72fe8550e3c2eae156a96a4dddcd1c8ac5800"
+ integrity sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==
+
+"eslint-visitor-keys@^4.2.0 || ^5.0.0", eslint-visitor-keys@^5.0.0, eslint-visitor-keys@^5.0.1:
+ version "5.0.1"
+ resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-5.0.1.tgz#9e3c9489697824d2d4ce3a8ad12628f91e9f59be"
+ integrity sha512-tD40eHxA35h0PEIZNeIjkHoDR4YjjJp34biM0mDvplBe//mB+IHCqHDGV7pxF+7MklTvighcCPPZC7ynWyjdTA==
+
+eslint-visitor-keys@^4.2.1:
+ version "4.2.1"
+ resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-4.2.1.tgz#4cfea60fe7dd0ad8e816e1ed026c1d5251b512c1"
+ integrity sha512-Uhdk5sfqcee/9H/rCOJikYz67o0a2Tw2hGRPOG2Y1R2dg7brRe1uG0yaNQDHu+TO/uQPF/5eCapvYSmHUjt7JQ==
+
+eslint@^10.3.0:
+ version "10.3.0"
+ resolved "https://registry.yarnpkg.com/eslint/-/eslint-10.3.0.tgz#ed5b810eb8e0191bf24bddcf9cdb45b974e0a16d"
+ integrity sha512-XbEXaRva5cF0ZQB8w6MluHA0kZZfV2DuCMJ3ozyEOHLwDpZX2Lmm/7Pp0xdJmI0GL1W05VH5VwIFHEm1Vcw2gw==
+ dependencies:
+ "@eslint-community/eslint-utils" "^4.8.0"
+ "@eslint-community/regexpp" "^4.12.2"
+ "@eslint/config-array" "^0.23.5"
+ "@eslint/config-helpers" "^0.5.5"
+ "@eslint/core" "^1.2.1"
+ "@eslint/plugin-kit" "^0.7.1"
+ "@humanfs/node" "^0.16.6"
+ "@humanwhocodes/module-importer" "^1.0.1"
+ "@humanwhocodes/retry" "^0.4.2"
+ "@types/estree" "^1.0.6"
+ ajv "^6.14.0"
+ cross-spawn "^7.0.6"
+ debug "^4.3.2"
+ escape-string-regexp "^4.0.0"
+ eslint-scope "^9.1.2"
+ eslint-visitor-keys "^5.0.1"
+ espree "^11.2.0"
+ esquery "^1.7.0"
+ esutils "^2.0.2"
+ fast-deep-equal "^3.1.3"
+ file-entry-cache "^8.0.0"
+ find-up "^5.0.0"
+ glob-parent "^6.0.2"
+ ignore "^5.2.0"
+ imurmurhash "^0.1.4"
+ is-glob "^4.0.0"
+ json-stable-stringify-without-jsonify "^1.0.1"
+ minimatch "^10.2.4"
+ natural-compare "^1.4.0"
+ optionator "^0.9.3"
+
+"espree@^10.3.0 || ^11.0.0", espree@^11.2.0:
+ version "11.2.0"
+ resolved "https://registry.yarnpkg.com/espree/-/espree-11.2.0.tgz#01d5e47dc332aaba3059008362454a8cc34ccaa5"
+ integrity sha512-7p3DrVEIopW1B1avAGLuCSh1jubc01H2JHc8B4qqGblmg5gI9yumBgACjWo4JlIc04ufug4xJ3SQI8HkS/Rgzw==
+ dependencies:
+ acorn "^8.16.0"
+ acorn-jsx "^5.3.2"
+ eslint-visitor-keys "^5.0.1"
+
+espree@^10.4.0:
+ version "10.4.0"
+ resolved "https://registry.yarnpkg.com/espree/-/espree-10.4.0.tgz#d54f4949d4629005a1fa168d937c3ff1f7e2a837"
+ integrity sha512-j6PAQ2uUr79PZhBjP5C5fhl8e39FmRnOjsD5lGnWrFU8i2G776tBK7+nP8KuQUTTyAZUwfQqXAgrVH5MbH9CYQ==
+ dependencies:
+ acorn "^8.15.0"
+ acorn-jsx "^5.3.2"
+ eslint-visitor-keys "^4.2.1"
+
+esquery@^1.6.0, esquery@^1.7.0:
+ version "1.7.0"
+ resolved "https://registry.yarnpkg.com/esquery/-/esquery-1.7.0.tgz#08d048f261f0ddedb5bae95f46809463d9c9496d"
+ integrity sha512-Ap6G0WQwcU/LHsvLwON1fAQX9Zp0A2Y6Y/cJBl9r/JbW90Zyg4/zbG6zzKa2OTALELarYHmKu0GhpM5EO+7T0g==
+ dependencies:
+ estraverse "^5.1.0"
+
+esrecurse@^4.3.0:
+ version "4.3.0"
+ resolved "https://registry.yarnpkg.com/esrecurse/-/esrecurse-4.3.0.tgz#7ad7964d679abb28bee72cec63758b1c5d2c9921"
+ integrity sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==
+ dependencies:
+ estraverse "^5.2.0"
+
+estraverse@^5.1.0, estraverse@^5.2.0, estraverse@^5.3.0:
+ version "5.3.0"
+ resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-5.3.0.tgz#2eea5290702f26ab8fe5370370ff86c965d21123"
+ integrity sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==
+
+estree-walker@^2.0.2:
+ version "2.0.2"
+ resolved "https://registry.yarnpkg.com/estree-walker/-/estree-walker-2.0.2.tgz#52f010178c2a4c117a7757cfe942adb7d2da4cac"
+ integrity sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==
+
+esutils@^2.0.2:
+ version "2.0.3"
+ resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz#74d2eb4de0b8da1293711910d50775b9b710ef64"
+ integrity sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==
+
+exsolve@^1.0.8:
+ version "1.0.8"
+ resolved "https://registry.yarnpkg.com/exsolve/-/exsolve-1.0.8.tgz#7f5e34da61cd1116deda5136e62292c096f50613"
+ integrity sha512-LmDxfWXwcTArk8fUEnOfSZpHOJ6zOMUJKOtFLFqJLoKJetuQG874Uc7/Kki7zFLzYybmZhp1M7+98pfMqeX8yA==
+
+fast-deep-equal@^3.1.1, fast-deep-equal@^3.1.3:
+ version "3.1.3"
+ resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525"
+ integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==
+
+fast-diff@^1.1.2:
+ version "1.3.0"
+ resolved "https://registry.yarnpkg.com/fast-diff/-/fast-diff-1.3.0.tgz#ece407fa550a64d638536cd727e129c61616e0f0"
+ integrity sha512-VxPP4NqbUjj6MaAOafWeUn2cXWLcCtljklUtZf0Ind4XQ+QPtmA0b18zZy0jIQx+ExRVCR/ZQpBmik5lXshNsw==
+
+fast-json-stable-stringify@^2.0.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz#874bf69c6f404c2b5d99c481341399fd55892633"
+ integrity sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==
+
+fast-levenshtein@^2.0.6:
+ version "2.0.6"
+ resolved "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz#3d8a5c66883a16a30ca8643e851f19baa7797917"
+ integrity sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==
+
+fast-string-truncated-width@^3.0.2:
+ version "3.0.3"
+ resolved "https://registry.yarnpkg.com/fast-string-truncated-width/-/fast-string-truncated-width-3.0.3.tgz#23afe0da67d752ca0727538f1e6967759728ce49"
+ integrity sha512-0jjjIEL6+0jag3l2XWWizO64/aZVtpiGE3t0Zgqxv0DPuxiMjvB3M24fCyhZUO4KomJQPj3LTSUnDP3GpdwC0g==
+
+fast-string-width@^3.0.2:
+ version "3.0.2"
+ resolved "https://registry.yarnpkg.com/fast-string-width/-/fast-string-width-3.0.2.tgz#16dbabb491ce5585b5ecb675b65c165d71688eeb"
+ integrity sha512-gX8LrtNEI5hq8DVUfRQMbr5lpaS4nMIWV+7XEbXk2b8kiQIizgnlr12B4dA3ZEx3308ze0O4Q1R+cHts8kyUJg==
+ dependencies:
+ fast-string-truncated-width "^3.0.2"
+
+fast-wrap-ansi@^0.2.0:
+ version "0.2.0"
+ resolved "https://registry.yarnpkg.com/fast-wrap-ansi/-/fast-wrap-ansi-0.2.0.tgz#c0ae3f3982d061c3d657ec927196fbb47e22fe64"
+ integrity sha512-rLV8JHxTyhVmFYhBJuMujcrHqOT2cnO5Zxj37qROj23CP39GXubJRBUFF0z8KFK77Uc0SukZUf7JZhsVEQ6n8w==
+ dependencies:
+ fast-string-width "^3.0.2"
+
+fault@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/fault/-/fault-2.0.1.tgz#d47ca9f37ca26e4bd38374a7c500b5a384755b6c"
+ integrity sha512-WtySTkS4OKev5JtpHXnib4Gxiurzh5NCGvWrFaZ34m6JehfTUhKZvn9njTfw48t6JumVQOmrKqpmGcdwxnhqBQ==
+ dependencies:
+ format "^0.2.0"
+
+fdir@^6.5.0:
+ version "6.5.0"
+ resolved "https://registry.yarnpkg.com/fdir/-/fdir-6.5.0.tgz#ed2ab967a331ade62f18d077dae192684d50d350"
+ integrity sha512-tIbYtZbucOs0BRGqPJkshJUYdL+SDH7dVM8gjy+ERp3WAUjLEFJE+02kanyHtwjWOnwrKYBiwAmM0p4kLJAnXg==
+
+file-entry-cache@^8.0.0:
+ version "8.0.0"
+ resolved "https://registry.yarnpkg.com/file-entry-cache/-/file-entry-cache-8.0.0.tgz#7787bddcf1131bffb92636c69457bbc0edd6d81f"
+ integrity sha512-XXTUwCvisa5oacNGRP9SfNtYBNAMi+RPwBFmblZEF7N7swHYQS6/Zfk7SRwx4D5j3CH211YNRco1DEMNVfZCnQ==
+ dependencies:
+ flat-cache "^4.0.0"
+
+find-up-simple@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/find-up-simple/-/find-up-simple-1.0.1.tgz#18fb90ad49e45252c4d7fca56baade04fa3fca1e"
+ integrity sha512-afd4O7zpqHeRyg4PfDQsXmlDe2PfdHtJt6Akt8jOWaApLOZk5JXs6VMR29lz03pRe9mpykrRCYIYxaJYcfpncQ==
+
+find-up@^5.0.0:
+ version "5.0.0"
+ resolved "https://registry.yarnpkg.com/find-up/-/find-up-5.0.0.tgz#4c92819ecb7083561e4f4a240a86be5198f536fc"
+ integrity sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==
+ dependencies:
+ locate-path "^6.0.0"
+ path-exists "^4.0.0"
+
+flat-cache@^4.0.0:
+ version "4.0.1"
+ resolved "https://registry.yarnpkg.com/flat-cache/-/flat-cache-4.0.1.tgz#0ece39fcb14ee012f4b0410bd33dd9c1f011127c"
+ integrity sha512-f7ccFPK3SXFHpx15UIGyRJ/FJQctuKZ0zVuN3frBo4HnK3cay9VEW0R6yPYFHC0AgqhukPzKjq22t5DmAyqGyw==
+ dependencies:
+ flatted "^3.2.9"
+ keyv "^4.5.4"
+
+flatted@^3.2.9:
+ version "3.4.2"
+ resolved "https://registry.yarnpkg.com/flatted/-/flatted-3.4.2.tgz#f5c23c107f0f37de8dbdf24f13722b3b98d52726"
+ integrity sha512-PjDse7RzhcPkIJwy5t7KPWQSZ9cAbzQXcafsetQoD7sOJRQlGikNbx7yZp2OotDnJyrDcbyRq3Ttb18iYOqkxA==
+
+format@^0.2.0:
+ version "0.2.2"
+ resolved "https://registry.yarnpkg.com/format/-/format-0.2.2.tgz#d6170107e9efdc4ed30c9dc39016df942b5cb58b"
+ integrity sha512-wzsgA6WOq+09wrU1tsJ09udeR/YZRaeArL9e1wPbFg3GG2yDnC2ldKpxs4xunpFF9DgqCqOIra3bc1HWrJ37Ww==
+
+fsevents@~2.3.3:
+ version "2.3.3"
+ resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.3.tgz#cac6407785d03675a2a5e1a5305c697b347d90d6"
+ integrity sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==
+
+get-tsconfig@^4.8.1:
+ version "4.14.0"
+ resolved "https://registry.yarnpkg.com/get-tsconfig/-/get-tsconfig-4.14.0.tgz#985d85c52a9903864280ccc2448d413fbf1efed8"
+ integrity sha512-yTb+8DXzDREzgvYmh6s9vHsSVCHeC0G3PI5bEXNBHtmshPnO+S5O7qgLEOn0I5QvMy6kpZN8K1NKGyilLb93wA==
+ dependencies:
+ resolve-pkg-maps "^1.0.0"
+
+github-slugger@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/github-slugger/-/github-slugger-2.0.0.tgz#52cf2f9279a21eb6c59dd385b410f0c0adda8f1a"
+ integrity sha512-IaOQ9puYtjrkq7Y0Ygl9KDZnrf/aiUJYUpVf89y8kyaxbRG7Y1SrX/jaumrv81vc61+kiMempujsM3Yw7w5qcw==
+
+glob-parent@^6.0.2:
+ version "6.0.2"
+ resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-6.0.2.tgz#6d237d99083950c79290f24c7642a3de9a28f9e3"
+ integrity sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==
+ dependencies:
+ is-glob "^4.0.3"
+
+globals@^15.11.0:
+ version "15.15.0"
+ resolved "https://registry.yarnpkg.com/globals/-/globals-15.15.0.tgz#7c4761299d41c32b075715a4ce1ede7897ff72a8"
+ integrity sha512-7ACyT3wmyp3I61S4fG682L0VA2RGD9otkqGJIwNUMF1SWUombIIk+af1unuDYgMm082aHYwD+mzJvv9Iu8dsgg==
+
+globals@^17.4.0, globals@^17.5.0:
+ version "17.6.0"
+ resolved "https://registry.yarnpkg.com/globals/-/globals-17.6.0.tgz#0f0be018d5cca8690e6375ead1f65c4bb96191fc"
+ integrity sha512-sepffkT8stwnIYbsMBpoCHJuJM5l98FUF2AnE07hfvE0m/qp3R586hw4jF4uadbhvg1ooIdzuu7CsfD2jzCaNA==
+
+globrex@^0.1.2:
+ version "0.1.2"
+ resolved "https://registry.yarnpkg.com/globrex/-/globrex-0.1.2.tgz#dd5d9ec826232730cd6793a5e33a9302985e6098"
+ integrity sha512-uHJgbwAMwNFf5mLst7IWLNg14x1CkeqglJb/K3doi4dw6q2IvAAmM/Y81kevy83wP+Sst+nutFTYOGg3d1lsxg==
+
+graceful-fs@^4.2.4:
+ version "4.2.11"
+ resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.11.tgz#4183e4e8bf08bb6e05bbb2f7d2e0c8f712ca40e3"
+ integrity sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==
+
+has-flag@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b"
+ integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==
+
+hookable@^5.5.3:
+ version "5.5.3"
+ resolved "https://registry.yarnpkg.com/hookable/-/hookable-5.5.3.tgz#6cfc358984a1ef991e2518cb9ed4a778bbd3215d"
+ integrity sha512-Yc+BQe8SvoXH1643Qez1zqLRmbA5rCL+sSmk6TVos0LWVfNIB7PGncdlId77WzLGSIB5KaWgTaNTs2lNVEI6VQ==
+
+html-entities@^2.6.0:
+ version "2.6.0"
+ resolved "https://registry.yarnpkg.com/html-entities/-/html-entities-2.6.0.tgz#7c64f1ea3b36818ccae3d3fb48b6974208e984f8"
+ integrity sha512-kig+rMn/QOVRvr7c86gQ8lWXq+Hkv6CbAH1hLu+RG338StTpE8Z0b44SDVaqVu7HGKf27frdmUYEs9hTUX/cLQ==
+
+ignore@^5.2.0, ignore@^5.3.2:
+ version "5.3.2"
+ resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.3.2.tgz#3cd40e729f3643fd87cb04e50bf0eb722bc596f5"
+ integrity sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g==
+
+ignore@^7.0.5:
+ version "7.0.5"
+ resolved "https://registry.yarnpkg.com/ignore/-/ignore-7.0.5.tgz#4cb5f6cd7d4c7ab0365738c7aea888baa6d7efd9"
+ integrity sha512-Hs59xBNfUIunMFgWAbGX5cq6893IbWg4KnrjbYwX3tx0ztorVgTDA6B2sxf8ejHJ4wz8BqGUMYlnzNBer5NvGg==
+
+immutable@^5.1.5:
+ version "5.1.5"
+ resolved "https://registry.yarnpkg.com/immutable/-/immutable-5.1.5.tgz#93ee4db5c2a9ab42a4a783069f3c5d8847d40165"
+ integrity sha512-t7xcm2siw+hlUM68I+UEOK+z84RzmN59as9DZ7P1l0994DKUWV7UXBMQZVxaoMSRQ+PBZbHCOoBt7a2wxOMt+A==
+
+imurmurhash@^0.1.4:
+ version "0.1.4"
+ resolved "https://registry.yarnpkg.com/imurmurhash/-/imurmurhash-0.1.4.tgz#9218b9b2b928a238b13dc4fb6b6d576f231453ea"
+ integrity sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==
+
+indent-string@^5.0.0:
+ version "5.0.0"
+ resolved "https://registry.yarnpkg.com/indent-string/-/indent-string-5.0.0.tgz#4fd2980fccaf8622d14c64d694f4cf33c81951a5"
+ integrity sha512-m6FAo/spmsW2Ab2fU35JTYwtOKa2yAwXSwgjSv1TJzh4Mh7mC3lzAOVLBprb72XsTrgkEIsl7YrFNAiDiRhIGg==
+
+is-builtin-module@^5.0.0:
+ version "5.0.0"
+ resolved "https://registry.yarnpkg.com/is-builtin-module/-/is-builtin-module-5.0.0.tgz#19df4b9c7451149b68176b0e06d18646db6308dd"
+ integrity sha512-f4RqJKBUe5rQkJ2eJEJBXSticB3hGbN9j0yxxMQFqIW89Jp9WYFtzfTcRlstDKVUTRzSOTLKRfO9vIztenwtxA==
+ dependencies:
+ builtin-modules "^5.0.0"
+
+is-extglob@^2.1.1:
+ version "2.1.1"
+ resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2"
+ integrity sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==
+
+is-glob@^4.0.0, is-glob@^4.0.3:
+ version "4.0.3"
+ resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084"
+ integrity sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==
+ dependencies:
+ is-extglob "^2.1.1"
+
+isexe@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10"
+ integrity sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==
+
+jsdoc-type-pratt-parser@^7.0.0, jsdoc-type-pratt-parser@~7.2.0:
+ version "7.2.0"
+ resolved "https://registry.yarnpkg.com/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-7.2.0.tgz#0a29c27bd4e01e85e4617625e34e797be1486a9b"
+ integrity sha512-dh140MMgjyg3JhJZY/+iEzW+NO5xR2gpbDFKHqotCmexElVntw7GjWjt511+C/Ef02RU5TKYrJo/Xlzk+OLaTw==
+
+jsdoc-type-pratt-parser@~7.1.1:
+ version "7.1.1"
+ resolved "https://registry.yarnpkg.com/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-7.1.1.tgz#c67be3c812aaf1405bef3e965e8c3db50a5cad1b"
+ integrity sha512-/2uqY7x6bsrpi3i9LVU6J89352C0rpMk0as8trXxCtvd4kPk1ke/Eyif6wqfSLvoNJqcDG9Vk4UsXgygzCt2xA==
+
+jsesc@^3.0.2, jsesc@^3.1.0, jsesc@~3.1.0:
+ version "3.1.0"
+ resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-3.1.0.tgz#74d335a234f67ed19907fdadfac7ccf9d409825d"
+ integrity sha512-/sM3dO2FOzXjKQhJuo0Q173wf2KOo8t4I8vHy6lF9poUp7bKT0/NHE8fPX23PwfhnykfqnC2xRxOnVw5XuGIaA==
+
+json-buffer@3.0.1:
+ version "3.0.1"
+ resolved "https://registry.yarnpkg.com/json-buffer/-/json-buffer-3.0.1.tgz#9338802a30d3b6605fbe0613e094008ca8c05a13"
+ integrity sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==
+
+json-schema-traverse@^0.4.1:
+ version "0.4.1"
+ resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660"
+ integrity sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==
+
+json-stable-stringify-without-jsonify@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz#9db7b59496ad3f3cfef30a75142d2d930ad72651"
+ integrity sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==
+
+json5@^2.2.3:
+ version "2.2.3"
+ resolved "https://registry.yarnpkg.com/json5/-/json5-2.2.3.tgz#78cd6f1a19bdc12b73db5ad0c61efd66c1e29283"
+ integrity sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==
+
+jsonc-eslint-parser@^3.1.0:
+ version "3.1.0"
+ resolved "https://registry.yarnpkg.com/jsonc-eslint-parser/-/jsonc-eslint-parser-3.1.0.tgz#ecbd62bdfe8acc299812d0610bff938377987626"
+ integrity sha512-75EA7EWZExL/j+MDKQrRbdzcRI2HOkRlmUw8fZJc1ioqFEOvBsq7Rt+A6yCxOt9w/TYNpkt52gC6nm/g5tFIng==
+ dependencies:
+ acorn "^8.5.0"
+ eslint-visitor-keys "^5.0.0"
+ semver "^7.3.5"
+
+katex@^0.16.0:
+ version "0.16.45"
+ resolved "https://registry.yarnpkg.com/katex/-/katex-0.16.45.tgz#ba60d39c54746b6b8d39ce0e7f6eace07143149c"
+ integrity sha512-pQpZbdBu7wCTmQUh7ufPmLr0pFoObnGUoL/yhtwJDgmmQpbkg/0HSVti25Fu4rmd1oCR6NGWe9vqTWuWv3GcNA==
+ dependencies:
+ commander "^8.3.0"
+
+keyv@^4.5.4:
+ version "4.5.4"
+ resolved "https://registry.yarnpkg.com/keyv/-/keyv-4.5.4.tgz#a879a99e29452f942439f2a405e3af8b31d4de93"
+ integrity sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==
+ dependencies:
+ json-buffer "3.0.1"
+
+levn@^0.4.1:
+ version "0.4.1"
+ resolved "https://registry.yarnpkg.com/levn/-/levn-0.4.1.tgz#ae4562c007473b932a6200d403268dd2fffc6ade"
+ integrity sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==
+ dependencies:
+ prelude-ls "^1.2.1"
+ type-check "~0.4.0"
+
+lightningcss-android-arm64@1.32.0:
+ version "1.32.0"
+ resolved "https://registry.yarnpkg.com/lightningcss-android-arm64/-/lightningcss-android-arm64-1.32.0.tgz#f033885116dfefd9c6f54787523e3514b61e1968"
+ integrity sha512-YK7/ClTt4kAK0vo6w3X+Pnm0D2cf2vPHbhOXdoNti1Ga0al1P4TBZhwjATvjNwLEBCnKvjJc2jQgHXH0NEwlAg==
+
+lightningcss-darwin-arm64@1.32.0:
+ version "1.32.0"
+ resolved "https://registry.yarnpkg.com/lightningcss-darwin-arm64/-/lightningcss-darwin-arm64-1.32.0.tgz#50b71871b01c8199584b649e292547faea7af9b5"
+ integrity sha512-RzeG9Ju5bag2Bv1/lwlVJvBE3q6TtXskdZLLCyfg5pt+HLz9BqlICO7LZM7VHNTTn/5PRhHFBSjk5lc4cmscPQ==
+
+lightningcss-darwin-x64@1.32.0:
+ version "1.32.0"
+ resolved "https://registry.yarnpkg.com/lightningcss-darwin-x64/-/lightningcss-darwin-x64-1.32.0.tgz#35f3e97332d130b9ca181e11b568ded6aebc6d5e"
+ integrity sha512-U+QsBp2m/s2wqpUYT/6wnlagdZbtZdndSmut/NJqlCcMLTWp5muCrID+K5UJ6jqD2BFshejCYXniPDbNh73V8w==
+
+lightningcss-freebsd-x64@1.32.0:
+ version "1.32.0"
+ resolved "https://registry.yarnpkg.com/lightningcss-freebsd-x64/-/lightningcss-freebsd-x64-1.32.0.tgz#9777a76472b64ed6ff94342ad64c7bafd794a575"
+ integrity sha512-JCTigedEksZk3tHTTthnMdVfGf61Fky8Ji2E4YjUTEQX14xiy/lTzXnu1vwiZe3bYe0q+SpsSH/CTeDXK6WHig==
+
+lightningcss-linux-arm-gnueabihf@1.32.0:
+ version "1.32.0"
+ resolved "https://registry.yarnpkg.com/lightningcss-linux-arm-gnueabihf/-/lightningcss-linux-arm-gnueabihf-1.32.0.tgz#13ae652e1ab73b9135d7b7da172f666c410ad53d"
+ integrity sha512-x6rnnpRa2GL0zQOkt6rts3YDPzduLpWvwAF6EMhXFVZXD4tPrBkEFqzGowzCsIWsPjqSK+tyNEODUBXeeVHSkw==
+
+lightningcss-linux-arm64-gnu@1.32.0:
+ version "1.32.0"
+ resolved "https://registry.yarnpkg.com/lightningcss-linux-arm64-gnu/-/lightningcss-linux-arm64-gnu-1.32.0.tgz#417858795a94592f680123a1b1f9da8a0e1ef335"
+ integrity sha512-0nnMyoyOLRJXfbMOilaSRcLH3Jw5z9HDNGfT/gwCPgaDjnx0i8w7vBzFLFR1f6CMLKF8gVbebmkUN3fa/kQJpQ==
+
+lightningcss-linux-arm64-musl@1.32.0:
+ version "1.32.0"
+ resolved "https://registry.yarnpkg.com/lightningcss-linux-arm64-musl/-/lightningcss-linux-arm64-musl-1.32.0.tgz#6be36692e810b718040802fd809623cffe732133"
+ integrity sha512-UpQkoenr4UJEzgVIYpI80lDFvRmPVg6oqboNHfoH4CQIfNA+HOrZ7Mo7KZP02dC6LjghPQJeBsvXhJod/wnIBg==
+
+lightningcss-linux-x64-gnu@1.32.0:
+ version "1.32.0"
+ resolved "https://registry.yarnpkg.com/lightningcss-linux-x64-gnu/-/lightningcss-linux-x64-gnu-1.32.0.tgz#0b7803af4eb21cfd38dd39fe2abbb53c7dd091f6"
+ integrity sha512-V7Qr52IhZmdKPVr+Vtw8o+WLsQJYCTd8loIfpDaMRWGUZfBOYEJeyJIkqGIDMZPwPx24pUMfwSxxI8phr/MbOA==
+
+lightningcss-linux-x64-musl@1.32.0:
+ version "1.32.0"
+ resolved "https://registry.yarnpkg.com/lightningcss-linux-x64-musl/-/lightningcss-linux-x64-musl-1.32.0.tgz#88dc8ba865ddddb1ac5ef04b0f161804418c163b"
+ integrity sha512-bYcLp+Vb0awsiXg/80uCRezCYHNg1/l3mt0gzHnWV9XP1W5sKa5/TCdGWaR/zBM2PeF/HbsQv/j2URNOiVuxWg==
+
+lightningcss-win32-arm64-msvc@1.32.0:
+ version "1.32.0"
+ resolved "https://registry.yarnpkg.com/lightningcss-win32-arm64-msvc/-/lightningcss-win32-arm64-msvc-1.32.0.tgz#4f30ba3fa5e925f5b79f945e8cc0d176c3b1ab38"
+ integrity sha512-8SbC8BR40pS6baCM8sbtYDSwEVQd4JlFTOlaD3gWGHfThTcABnNDBda6eTZeqbofalIJhFx0qKzgHJmcPTnGdw==
+
+lightningcss-win32-x64-msvc@1.32.0:
+ version "1.32.0"
+ resolved "https://registry.yarnpkg.com/lightningcss-win32-x64-msvc/-/lightningcss-win32-x64-msvc-1.32.0.tgz#141aa5605645064928902bb4af045fa7d9f4220a"
+ integrity sha512-Amq9B/SoZYdDi1kFrojnoqPLxYhQ4Wo5XiL8EVJrVsB8ARoC1PWW6VGtT0WKCemjy8aC+louJnjS7U18x3b06Q==
+
+lightningcss@^1.32.0:
+ version "1.32.0"
+ resolved "https://registry.yarnpkg.com/lightningcss/-/lightningcss-1.32.0.tgz#b85aae96486dcb1bf49a7c8571221273f4f1e4a9"
+ integrity sha512-NXYBzinNrblfraPGyrbPoD19C1h9lfI/1mzgWYvXUTe414Gz/X1FD2XBZSZM7rRTrMA8JL3OtAaGifrIKhQ5yQ==
+ dependencies:
+ detect-libc "^2.0.3"
+ optionalDependencies:
+ lightningcss-android-arm64 "1.32.0"
+ lightningcss-darwin-arm64 "1.32.0"
+ lightningcss-darwin-x64 "1.32.0"
+ lightningcss-freebsd-x64 "1.32.0"
+ lightningcss-linux-arm-gnueabihf "1.32.0"
+ lightningcss-linux-arm64-gnu "1.32.0"
+ lightningcss-linux-arm64-musl "1.32.0"
+ lightningcss-linux-x64-gnu "1.32.0"
+ lightningcss-linux-x64-musl "1.32.0"
+ lightningcss-win32-arm64-msvc "1.32.0"
+ lightningcss-win32-x64-msvc "1.32.0"
+
+local-pkg@^1.1.2:
+ version "1.1.2"
+ resolved "https://registry.yarnpkg.com/local-pkg/-/local-pkg-1.1.2.tgz#c03d208787126445303f8161619dc701afa4abb5"
+ integrity sha512-arhlxbFRmoQHl33a0Zkle/YWlmNwoyt6QNZEIJcqNbdrsix5Lvc4HyyI3EnwxTYlZYc32EbYrQ8SzEZ7dqgg9A==
+ dependencies:
+ mlly "^1.7.4"
+ pkg-types "^2.3.0"
+ quansync "^0.2.11"
+
+locate-path@^6.0.0:
+ version "6.0.0"
+ resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-6.0.0.tgz#55321eb309febbc59c4801d931a72452a681d286"
+ integrity sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==
+ dependencies:
+ p-locate "^5.0.0"
+
+longest-streak@^3.0.0:
+ version "3.1.0"
+ resolved "https://registry.yarnpkg.com/longest-streak/-/longest-streak-3.1.0.tgz#62fa67cd958742a1574af9f39866364102d90cd4"
+ integrity sha512-9Ri+o0JYgehTaVBBDoMqIl8GXtbWg711O3srftcHhZ0dqnETqLaoIK0x17fUw9rFSlK/0NlsKe0Ahhyl5pXE2g==
+
+magic-string-ast@^1.0.2:
+ version "1.0.3"
+ resolved "https://registry.yarnpkg.com/magic-string-ast/-/magic-string-ast-1.0.3.tgz#51ef7832fd5c70a0188fb94627caa3b8c74ff9bf"
+ integrity sha512-CvkkH1i81zl7mmb94DsRiFeG9V2fR2JeuK8yDgS8oiZSFa++wWLEgZ5ufEOyLHbvSbD1gTRKv9NdX69Rnvr9JA==
+ dependencies:
+ magic-string "^0.30.19"
+
+magic-string@^0.30.19, magic-string@^0.30.21:
+ version "0.30.21"
+ resolved "https://registry.yarnpkg.com/magic-string/-/magic-string-0.30.21.tgz#56763ec09a0fa8091df27879fd94d19078c00d91"
+ integrity sha512-vd2F4YUyEXKGcLHoq+TEyCjxueSeHnFxyyjNp80yg0XV4vUhnDer/lvvlqM/arB5bXQN5K2/3oinyCRyx8T2CQ==
+ dependencies:
+ "@jridgewell/sourcemap-codec" "^1.5.5"
+
+markdown-table@^3.0.0:
+ version "3.0.4"
+ resolved "https://registry.yarnpkg.com/markdown-table/-/markdown-table-3.0.4.tgz#fe44d6d410ff9d6f2ea1797a3f60aa4d2b631c2a"
+ integrity sha512-wiYz4+JrLyb/DqW2hkFJxP7Vd7JuTDm77fvbM8VfEQdmSMqcImWeeRbHwZjBjIFki/VaMK2BhFi7oUUZeM5bqw==
+
+mdast-util-find-and-replace@^3.0.0:
+ version "3.0.2"
+ resolved "https://registry.yarnpkg.com/mdast-util-find-and-replace/-/mdast-util-find-and-replace-3.0.2.tgz#70a3174c894e14df722abf43bc250cbae44b11df"
+ integrity sha512-Tmd1Vg/m3Xz43afeNxDIhWRtFZgM2VLyaf4vSTYwudTyeuTneoL3qtWMA5jeLyz/O1vDJmmV4QuScFCA2tBPwg==
+ dependencies:
+ "@types/mdast" "^4.0.0"
+ escape-string-regexp "^5.0.0"
+ unist-util-is "^6.0.0"
+ unist-util-visit-parents "^6.0.0"
+
+mdast-util-from-markdown@^2.0.0, mdast-util-from-markdown@^2.0.2:
+ version "2.0.3"
+ resolved "https://registry.yarnpkg.com/mdast-util-from-markdown/-/mdast-util-from-markdown-2.0.3.tgz#c95822b91aab75f18a4cbe8b2f51b873ed2cf0c7"
+ integrity sha512-W4mAWTvSlKvf8L6J+VN9yLSqQ9AOAAvHuoDAmPkz4dHf553m5gVj2ejadHJhoJmcmxEnOv6Pa8XJhpxE93kb8Q==
+ dependencies:
+ "@types/mdast" "^4.0.0"
+ "@types/unist" "^3.0.0"
+ decode-named-character-reference "^1.0.0"
+ devlop "^1.0.0"
+ mdast-util-to-string "^4.0.0"
+ micromark "^4.0.0"
+ micromark-util-decode-numeric-character-reference "^2.0.0"
+ micromark-util-decode-string "^2.0.0"
+ micromark-util-normalize-identifier "^2.0.0"
+ micromark-util-symbol "^2.0.0"
+ micromark-util-types "^2.0.0"
+ unist-util-stringify-position "^4.0.0"
+
+mdast-util-frontmatter@^2.0.1:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/mdast-util-frontmatter/-/mdast-util-frontmatter-2.0.1.tgz#f5f929eb1eb36c8a7737475c7eb438261f964ee8"
+ integrity sha512-LRqI9+wdgC25P0URIJY9vwocIzCcksduHQ9OF2joxQoyTNVduwLAFUzjoopuRJbJAReaKrNQKAZKL3uCMugWJA==
+ dependencies:
+ "@types/mdast" "^4.0.0"
+ devlop "^1.0.0"
+ escape-string-regexp "^5.0.0"
+ mdast-util-from-markdown "^2.0.0"
+ mdast-util-to-markdown "^2.0.0"
+ micromark-extension-frontmatter "^2.0.0"
+
+mdast-util-gfm-autolink-literal@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/mdast-util-gfm-autolink-literal/-/mdast-util-gfm-autolink-literal-2.0.1.tgz#abd557630337bd30a6d5a4bd8252e1c2dc0875d5"
+ integrity sha512-5HVP2MKaP6L+G6YaxPNjuL0BPrq9orG3TsrZ9YXbA3vDw/ACI4MEsnoDpn6ZNm7GnZgtAcONJyPhOP8tNJQavQ==
+ dependencies:
+ "@types/mdast" "^4.0.0"
+ ccount "^2.0.0"
+ devlop "^1.0.0"
+ mdast-util-find-and-replace "^3.0.0"
+ micromark-util-character "^2.0.0"
+
+mdast-util-gfm-footnote@^2.0.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/mdast-util-gfm-footnote/-/mdast-util-gfm-footnote-2.1.0.tgz#7778e9d9ca3df7238cc2bd3fa2b1bf6a65b19403"
+ integrity sha512-sqpDWlsHn7Ac9GNZQMeUzPQSMzR6Wv0WKRNvQRg0KqHh02fpTz69Qc1QSseNX29bhz1ROIyNyxExfawVKTm1GQ==
+ dependencies:
+ "@types/mdast" "^4.0.0"
+ devlop "^1.1.0"
+ mdast-util-from-markdown "^2.0.0"
+ mdast-util-to-markdown "^2.0.0"
+ micromark-util-normalize-identifier "^2.0.0"
+
+mdast-util-gfm-strikethrough@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/mdast-util-gfm-strikethrough/-/mdast-util-gfm-strikethrough-2.0.0.tgz#d44ef9e8ed283ac8c1165ab0d0dfd058c2764c16"
+ integrity sha512-mKKb915TF+OC5ptj5bJ7WFRPdYtuHv0yTRxK2tJvi+BDqbkiG7h7u/9SI89nRAYcmap2xHQL9D+QG/6wSrTtXg==
+ dependencies:
+ "@types/mdast" "^4.0.0"
+ mdast-util-from-markdown "^2.0.0"
+ mdast-util-to-markdown "^2.0.0"
+
+mdast-util-gfm-table@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/mdast-util-gfm-table/-/mdast-util-gfm-table-2.0.0.tgz#7a435fb6223a72b0862b33afbd712b6dae878d38"
+ integrity sha512-78UEvebzz/rJIxLvE7ZtDd/vIQ0RHv+3Mh5DR96p7cS7HsBhYIICDBCu8csTNWNO6tBWfqXPWekRuj2FNOGOZg==
+ dependencies:
+ "@types/mdast" "^4.0.0"
+ devlop "^1.0.0"
+ markdown-table "^3.0.0"
+ mdast-util-from-markdown "^2.0.0"
+ mdast-util-to-markdown "^2.0.0"
+
+mdast-util-gfm-task-list-item@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/mdast-util-gfm-task-list-item/-/mdast-util-gfm-task-list-item-2.0.0.tgz#e68095d2f8a4303ef24094ab642e1047b991a936"
+ integrity sha512-IrtvNvjxC1o06taBAVJznEnkiHxLFTzgonUdy8hzFVeDun0uTjxxrRGVaNFqkU1wJR3RBPEfsxmU6jDWPofrTQ==
+ dependencies:
+ "@types/mdast" "^4.0.0"
+ devlop "^1.0.0"
+ mdast-util-from-markdown "^2.0.0"
+ mdast-util-to-markdown "^2.0.0"
+
+mdast-util-gfm@^3.1.0:
+ version "3.1.0"
+ resolved "https://registry.yarnpkg.com/mdast-util-gfm/-/mdast-util-gfm-3.1.0.tgz#2cdf63b92c2a331406b0fb0db4c077c1b0331751"
+ integrity sha512-0ulfdQOM3ysHhCJ1p06l0b0VKlhU0wuQs3thxZQagjcjPrlFRqY215uZGHHJan9GEAXd9MbfPjFJz+qMkVR6zQ==
+ dependencies:
+ mdast-util-from-markdown "^2.0.0"
+ mdast-util-gfm-autolink-literal "^2.0.0"
+ mdast-util-gfm-footnote "^2.0.0"
+ mdast-util-gfm-strikethrough "^2.0.0"
+ mdast-util-gfm-table "^2.0.0"
+ mdast-util-gfm-task-list-item "^2.0.0"
+ mdast-util-to-markdown "^2.0.0"
+
+mdast-util-math@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.yarnpkg.com/mdast-util-math/-/mdast-util-math-3.0.0.tgz#8d79dd3baf8ab8ac781f62b8853768190b9a00b0"
+ integrity sha512-Tl9GBNeG/AhJnQM221bJR2HPvLOSnLE/T9cJI9tlc6zwQk2nPk/4f0cHkOdEixQPC/j8UtKDdITswvLAy1OZ1w==
+ dependencies:
+ "@types/hast" "^3.0.0"
+ "@types/mdast" "^4.0.0"
+ devlop "^1.0.0"
+ longest-streak "^3.0.0"
+ mdast-util-from-markdown "^2.0.0"
+ mdast-util-to-markdown "^2.1.0"
+ unist-util-remove-position "^5.0.0"
+
+mdast-util-phrasing@^4.0.0:
+ version "4.1.0"
+ resolved "https://registry.yarnpkg.com/mdast-util-phrasing/-/mdast-util-phrasing-4.1.0.tgz#7cc0a8dec30eaf04b7b1a9661a92adb3382aa6e3"
+ integrity sha512-TqICwyvJJpBwvGAMZjj4J2n0X8QWp21b9l0o7eXyVJ25YNWYbJDVIyD1bZXE6WtV6RmKJVYmQAKWa0zWOABz2w==
+ dependencies:
+ "@types/mdast" "^4.0.0"
+ unist-util-is "^6.0.0"
+
+mdast-util-to-markdown@^2.0.0, mdast-util-to-markdown@^2.1.0:
+ version "2.1.2"
+ resolved "https://registry.yarnpkg.com/mdast-util-to-markdown/-/mdast-util-to-markdown-2.1.2.tgz#f910ffe60897f04bb4b7e7ee434486f76288361b"
+ integrity sha512-xj68wMTvGXVOKonmog6LwyJKrYXZPvlwabaryTjLh9LuvovB/KAH+kvi8Gjj+7rJjsFi23nkUxRQv1KqSroMqA==
+ dependencies:
+ "@types/mdast" "^4.0.0"
+ "@types/unist" "^3.0.0"
+ longest-streak "^3.0.0"
+ mdast-util-phrasing "^4.0.0"
+ mdast-util-to-string "^4.0.0"
+ micromark-util-classify-character "^2.0.0"
+ micromark-util-decode-string "^2.0.0"
+ unist-util-visit "^5.0.0"
+ zwitch "^2.0.0"
+
+mdast-util-to-string@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.yarnpkg.com/mdast-util-to-string/-/mdast-util-to-string-4.0.0.tgz#7a5121475556a04e7eddeb67b264aae79d312814"
+ integrity sha512-0H44vDimn51F0YwvxSJSm0eCDOJTRlmN0R1yBh4HLj9wiV1Dn0QoXGbvFAWj2hSItVTlCmBF1hqKlIyUBVFLPg==
+ dependencies:
+ "@types/mdast" "^4.0.0"
+
+micromark-core-commonmark@^2.0.0:
+ version "2.0.3"
+ resolved "https://registry.yarnpkg.com/micromark-core-commonmark/-/micromark-core-commonmark-2.0.3.tgz#c691630e485021a68cf28dbc2b2ca27ebf678cd4"
+ integrity sha512-RDBrHEMSxVFLg6xvnXmb1Ayr2WzLAWjeSATAoxwKYJV94TeNavgoIdA0a9ytzDSVzBy2YKFK+emCPOEibLeCrg==
+ dependencies:
+ decode-named-character-reference "^1.0.0"
+ devlop "^1.0.0"
+ micromark-factory-destination "^2.0.0"
+ micromark-factory-label "^2.0.0"
+ micromark-factory-space "^2.0.0"
+ micromark-factory-title "^2.0.0"
+ micromark-factory-whitespace "^2.0.0"
+ micromark-util-character "^2.0.0"
+ micromark-util-chunked "^2.0.0"
+ micromark-util-classify-character "^2.0.0"
+ micromark-util-html-tag-name "^2.0.0"
+ micromark-util-normalize-identifier "^2.0.0"
+ micromark-util-resolve-all "^2.0.0"
+ micromark-util-subtokenize "^2.0.0"
+ micromark-util-symbol "^2.0.0"
+ micromark-util-types "^2.0.0"
+
+micromark-extension-frontmatter@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/micromark-extension-frontmatter/-/micromark-extension-frontmatter-2.0.0.tgz#651c52ffa5d7a8eeed687c513cd869885882d67a"
+ integrity sha512-C4AkuM3dA58cgZha7zVnuVxBhDsbttIMiytjgsM2XbHAB2faRVaHRle40558FBN+DJcrLNCoqG5mlrpdU4cRtg==
+ dependencies:
+ fault "^2.0.0"
+ micromark-util-character "^2.0.0"
+ micromark-util-symbol "^2.0.0"
+ micromark-util-types "^2.0.0"
+
+micromark-extension-gfm-autolink-literal@^2.0.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/micromark-extension-gfm-autolink-literal/-/micromark-extension-gfm-autolink-literal-2.1.0.tgz#6286aee9686c4462c1e3552a9d505feddceeb935"
+ integrity sha512-oOg7knzhicgQ3t4QCjCWgTmfNhvQbDDnJeVu9v81r7NltNCVmhPy1fJRX27pISafdjL+SVc4d3l48Gb6pbRypw==
+ dependencies:
+ micromark-util-character "^2.0.0"
+ micromark-util-sanitize-uri "^2.0.0"
+ micromark-util-symbol "^2.0.0"
+ micromark-util-types "^2.0.0"
+
+micromark-extension-gfm-footnote@^2.0.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/micromark-extension-gfm-footnote/-/micromark-extension-gfm-footnote-2.1.0.tgz#4dab56d4e398b9853f6fe4efac4fc9361f3e0750"
+ integrity sha512-/yPhxI1ntnDNsiHtzLKYnE3vf9JZ6cAisqVDauhp4CEHxlb4uoOTxOCJ+9s51bIB8U1N1FJ1RXOKTIlD5B/gqw==
+ dependencies:
+ devlop "^1.0.0"
+ micromark-core-commonmark "^2.0.0"
+ micromark-factory-space "^2.0.0"
+ micromark-util-character "^2.0.0"
+ micromark-util-normalize-identifier "^2.0.0"
+ micromark-util-sanitize-uri "^2.0.0"
+ micromark-util-symbol "^2.0.0"
+ micromark-util-types "^2.0.0"
+
+micromark-extension-gfm-strikethrough@^2.0.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/micromark-extension-gfm-strikethrough/-/micromark-extension-gfm-strikethrough-2.1.0.tgz#86106df8b3a692b5f6a92280d3879be6be46d923"
+ integrity sha512-ADVjpOOkjz1hhkZLlBiYA9cR2Anf8F4HqZUO6e5eDcPQd0Txw5fxLzzxnEkSkfnD0wziSGiv7sYhk/ktvbf1uw==
+ dependencies:
+ devlop "^1.0.0"
+ micromark-util-chunked "^2.0.0"
+ micromark-util-classify-character "^2.0.0"
+ micromark-util-resolve-all "^2.0.0"
+ micromark-util-symbol "^2.0.0"
+ micromark-util-types "^2.0.0"
+
+micromark-extension-gfm-table@^2.0.0:
+ version "2.1.1"
+ resolved "https://registry.yarnpkg.com/micromark-extension-gfm-table/-/micromark-extension-gfm-table-2.1.1.tgz#fac70bcbf51fe65f5f44033118d39be8a9b5940b"
+ integrity sha512-t2OU/dXXioARrC6yWfJ4hqB7rct14e8f7m0cbI5hUmDyyIlwv5vEtooptH8INkbLzOatzKuVbQmAYcbWoyz6Dg==
+ dependencies:
+ devlop "^1.0.0"
+ micromark-factory-space "^2.0.0"
+ micromark-util-character "^2.0.0"
+ micromark-util-symbol "^2.0.0"
+ micromark-util-types "^2.0.0"
+
+micromark-extension-gfm-tagfilter@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/micromark-extension-gfm-tagfilter/-/micromark-extension-gfm-tagfilter-2.0.0.tgz#f26d8a7807b5985fba13cf61465b58ca5ff7dc57"
+ integrity sha512-xHlTOmuCSotIA8TW1mDIM6X2O1SiX5P9IuDtqGonFhEK0qgRI4yeC6vMxEV2dgyr2TiD+2PQ10o+cOhdVAcwfg==
+ dependencies:
+ micromark-util-types "^2.0.0"
+
+micromark-extension-gfm-task-list-item@^2.0.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/micromark-extension-gfm-task-list-item/-/micromark-extension-gfm-task-list-item-2.1.0.tgz#bcc34d805639829990ec175c3eea12bb5b781f2c"
+ integrity sha512-qIBZhqxqI6fjLDYFTBIa4eivDMnP+OZqsNwmQ3xNLE4Cxwc+zfQEfbs6tzAo2Hjq+bh6q5F+Z8/cksrLFYWQQw==
+ dependencies:
+ devlop "^1.0.0"
+ micromark-factory-space "^2.0.0"
+ micromark-util-character "^2.0.0"
+ micromark-util-symbol "^2.0.0"
+ micromark-util-types "^2.0.0"
+
+micromark-extension-gfm@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.yarnpkg.com/micromark-extension-gfm/-/micromark-extension-gfm-3.0.0.tgz#3e13376ab95dd7a5cfd0e29560dfe999657b3c5b"
+ integrity sha512-vsKArQsicm7t0z2GugkCKtZehqUm31oeGBV/KVSorWSy8ZlNAv7ytjFhvaryUiCUJYqs+NoE6AFhpQvBTM6Q4w==
+ dependencies:
+ micromark-extension-gfm-autolink-literal "^2.0.0"
+ micromark-extension-gfm-footnote "^2.0.0"
+ micromark-extension-gfm-strikethrough "^2.0.0"
+ micromark-extension-gfm-table "^2.0.0"
+ micromark-extension-gfm-tagfilter "^2.0.0"
+ micromark-extension-gfm-task-list-item "^2.0.0"
+ micromark-util-combine-extensions "^2.0.0"
+ micromark-util-types "^2.0.0"
+
+micromark-extension-math@^3.1.0:
+ version "3.1.0"
+ resolved "https://registry.yarnpkg.com/micromark-extension-math/-/micromark-extension-math-3.1.0.tgz#c42ee3b1dd5a9a03584e83dd8f08e3de510212c1"
+ integrity sha512-lvEqd+fHjATVs+2v/8kg9i5Q0AP2k85H0WUOwpIVvUML8BapsMvh1XAogmQjOCsLpoKRCVQqEkQBB3NhVBcsOg==
+ dependencies:
+ "@types/katex" "^0.16.0"
+ devlop "^1.0.0"
+ katex "^0.16.0"
+ micromark-factory-space "^2.0.0"
+ micromark-util-character "^2.0.0"
+ micromark-util-symbol "^2.0.0"
+ micromark-util-types "^2.0.0"
+
+micromark-factory-destination@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/micromark-factory-destination/-/micromark-factory-destination-2.0.1.tgz#8fef8e0f7081f0474fbdd92deb50c990a0264639"
+ integrity sha512-Xe6rDdJlkmbFRExpTOmRj9N3MaWmbAgdpSrBQvCFqhezUn4AHqJHbaEnfbVYYiexVSs//tqOdY/DxhjdCiJnIA==
+ dependencies:
+ micromark-util-character "^2.0.0"
+ micromark-util-symbol "^2.0.0"
+ micromark-util-types "^2.0.0"
+
+micromark-factory-label@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/micromark-factory-label/-/micromark-factory-label-2.0.1.tgz#5267efa97f1e5254efc7f20b459a38cb21058ba1"
+ integrity sha512-VFMekyQExqIW7xIChcXn4ok29YE3rnuyveW3wZQWWqF4Nv9Wk5rgJ99KzPvHjkmPXF93FXIbBp6YdW3t71/7Vg==
+ dependencies:
+ devlop "^1.0.0"
+ micromark-util-character "^2.0.0"
+ micromark-util-symbol "^2.0.0"
+ micromark-util-types "^2.0.0"
+
+micromark-factory-space@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/micromark-factory-space/-/micromark-factory-space-2.0.1.tgz#36d0212e962b2b3121f8525fc7a3c7c029f334fc"
+ integrity sha512-zRkxjtBxxLd2Sc0d+fbnEunsTj46SWXgXciZmHq0kDYGnck/ZSGj9/wULTV95uoeYiK5hRXP2mJ98Uo4cq/LQg==
+ dependencies:
+ micromark-util-character "^2.0.0"
+ micromark-util-types "^2.0.0"
+
+micromark-factory-title@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/micromark-factory-title/-/micromark-factory-title-2.0.1.tgz#237e4aa5d58a95863f01032d9ee9b090f1de6e94"
+ integrity sha512-5bZ+3CjhAd9eChYTHsjy6TGxpOFSKgKKJPJxr293jTbfry2KDoWkhBb6TcPVB4NmzaPhMs1Frm9AZH7OD4Cjzw==
+ dependencies:
+ micromark-factory-space "^2.0.0"
+ micromark-util-character "^2.0.0"
+ micromark-util-symbol "^2.0.0"
+ micromark-util-types "^2.0.0"
+
+micromark-factory-whitespace@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/micromark-factory-whitespace/-/micromark-factory-whitespace-2.0.1.tgz#06b26b2983c4d27bfcc657b33e25134d4868b0b1"
+ integrity sha512-Ob0nuZ3PKt/n0hORHyvoD9uZhr+Za8sFoP+OnMcnWK5lngSzALgQYKMr9RJVOWLqQYuyn6ulqGWSXdwf6F80lQ==
+ dependencies:
+ micromark-factory-space "^2.0.0"
+ micromark-util-character "^2.0.0"
+ micromark-util-symbol "^2.0.0"
+ micromark-util-types "^2.0.0"
+
+micromark-util-character@^2.0.0:
+ version "2.1.1"
+ resolved "https://registry.yarnpkg.com/micromark-util-character/-/micromark-util-character-2.1.1.tgz#2f987831a40d4c510ac261e89852c4e9703ccda6"
+ integrity sha512-wv8tdUTJ3thSFFFJKtpYKOYiGP2+v96Hvk4Tu8KpCAsTMs6yi+nVmGh1syvSCsaxz45J6Jbw+9DD6g97+NV67Q==
+ dependencies:
+ micromark-util-symbol "^2.0.0"
+ micromark-util-types "^2.0.0"
+
+micromark-util-chunked@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/micromark-util-chunked/-/micromark-util-chunked-2.0.1.tgz#47fbcd93471a3fccab86cff03847fc3552db1051"
+ integrity sha512-QUNFEOPELfmvv+4xiNg2sRYeS/P84pTW0TCgP5zc9FpXetHY0ab7SxKyAQCNCc1eK0459uoLI1y5oO5Vc1dbhA==
+ dependencies:
+ micromark-util-symbol "^2.0.0"
+
+micromark-util-classify-character@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/micromark-util-classify-character/-/micromark-util-classify-character-2.0.1.tgz#d399faf9c45ca14c8b4be98b1ea481bced87b629"
+ integrity sha512-K0kHzM6afW/MbeWYWLjoHQv1sgg2Q9EccHEDzSkxiP/EaagNzCm7T/WMKZ3rjMbvIpvBiZgwR3dKMygtA4mG1Q==
+ dependencies:
+ micromark-util-character "^2.0.0"
+ micromark-util-symbol "^2.0.0"
+ micromark-util-types "^2.0.0"
+
+micromark-util-combine-extensions@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/micromark-util-combine-extensions/-/micromark-util-combine-extensions-2.0.1.tgz#2a0f490ab08bff5cc2fd5eec6dd0ca04f89b30a9"
+ integrity sha512-OnAnH8Ujmy59JcyZw8JSbK9cGpdVY44NKgSM7E9Eh7DiLS2E9RNQf0dONaGDzEG9yjEl5hcqeIsj4hfRkLH/Bg==
+ dependencies:
+ micromark-util-chunked "^2.0.0"
+ micromark-util-types "^2.0.0"
+
+micromark-util-decode-numeric-character-reference@^2.0.0:
+ version "2.0.2"
+ resolved "https://registry.yarnpkg.com/micromark-util-decode-numeric-character-reference/-/micromark-util-decode-numeric-character-reference-2.0.2.tgz#fcf15b660979388e6f118cdb6bf7d79d73d26fe5"
+ integrity sha512-ccUbYk6CwVdkmCQMyr64dXz42EfHGkPQlBj5p7YVGzq8I7CtjXZJrubAYezf7Rp+bjPseiROqe7G6foFd+lEuw==
+ dependencies:
+ micromark-util-symbol "^2.0.0"
+
+micromark-util-decode-string@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/micromark-util-decode-string/-/micromark-util-decode-string-2.0.1.tgz#6cb99582e5d271e84efca8e61a807994d7161eb2"
+ integrity sha512-nDV/77Fj6eH1ynwscYTOsbK7rR//Uj0bZXBwJZRfaLEJ1iGBR6kIfNmlNqaqJf649EP0F3NWNdeJi03elllNUQ==
+ dependencies:
+ decode-named-character-reference "^1.0.0"
+ micromark-util-character "^2.0.0"
+ micromark-util-decode-numeric-character-reference "^2.0.0"
+ micromark-util-symbol "^2.0.0"
+
+micromark-util-encode@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/micromark-util-encode/-/micromark-util-encode-2.0.1.tgz#0d51d1c095551cfaac368326963cf55f15f540b8"
+ integrity sha512-c3cVx2y4KqUnwopcO9b/SCdo2O67LwJJ/UyqGfbigahfegL9myoEFoDYZgkT7f36T0bLrM9hZTAaAyH+PCAXjw==
+
+micromark-util-html-tag-name@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/micromark-util-html-tag-name/-/micromark-util-html-tag-name-2.0.1.tgz#e40403096481986b41c106627f98f72d4d10b825"
+ integrity sha512-2cNEiYDhCWKI+Gs9T0Tiysk136SnR13hhO8yW6BGNyhOC4qYFnwF1nKfD3HFAIXA5c45RrIG1ub11GiXeYd1xA==
+
+micromark-util-normalize-identifier@^2.0.0, micromark-util-normalize-identifier@^2.0.1:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/micromark-util-normalize-identifier/-/micromark-util-normalize-identifier-2.0.1.tgz#c30d77b2e832acf6526f8bf1aa47bc9c9438c16d"
+ integrity sha512-sxPqmo70LyARJs0w2UclACPUUEqltCkJ6PhKdMIDuJ3gSf/Q+/GIe3WKl0Ijb/GyH9lOpUkRAO2wp0GVkLvS9Q==
+ dependencies:
+ micromark-util-symbol "^2.0.0"
+
+micromark-util-resolve-all@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/micromark-util-resolve-all/-/micromark-util-resolve-all-2.0.1.tgz#e1a2d62cdd237230a2ae11839027b19381e31e8b"
+ integrity sha512-VdQyxFWFT2/FGJgwQnJYbe1jjQoNTS4RjglmSjTUlpUMa95Htx9NHeYW4rGDJzbjvCsl9eLjMQwGeElsqmzcHg==
+ dependencies:
+ micromark-util-types "^2.0.0"
+
+micromark-util-sanitize-uri@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/micromark-util-sanitize-uri/-/micromark-util-sanitize-uri-2.0.1.tgz#ab89789b818a58752b73d6b55238621b7faa8fd7"
+ integrity sha512-9N9IomZ/YuGGZZmQec1MbgxtlgougxTodVwDzzEouPKo3qFWvymFHWcnDi2vzV1ff6kas9ucW+o3yzJK9YB1AQ==
+ dependencies:
+ micromark-util-character "^2.0.0"
+ micromark-util-encode "^2.0.0"
+ micromark-util-symbol "^2.0.0"
+
+micromark-util-subtokenize@^2.0.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/micromark-util-subtokenize/-/micromark-util-subtokenize-2.1.0.tgz#d8ade5ba0f3197a1cf6a2999fbbfe6357a1a19ee"
+ integrity sha512-XQLu552iSctvnEcgXw6+Sx75GflAPNED1qx7eBJ+wydBb2KCbRZe+NwvIEEMM83uml1+2WSXpBAcp9IUCgCYWA==
+ dependencies:
+ devlop "^1.0.0"
+ micromark-util-chunked "^2.0.0"
+ micromark-util-symbol "^2.0.0"
+ micromark-util-types "^2.0.0"
+
+micromark-util-symbol@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/micromark-util-symbol/-/micromark-util-symbol-2.0.1.tgz#e5da494e8eb2b071a0d08fb34f6cefec6c0a19b8"
+ integrity sha512-vs5t8Apaud9N28kgCrRUdEed4UJ+wWNvicHLPxCa9ENlYuAY31M0ETy5y1vA33YoNPDFTghEbnh6efaE8h4x0Q==
+
+micromark-util-types@^2.0.0:
+ version "2.0.2"
+ resolved "https://registry.yarnpkg.com/micromark-util-types/-/micromark-util-types-2.0.2.tgz#f00225f5f5a0ebc3254f96c36b6605c4b393908e"
+ integrity sha512-Yw0ECSpJoViF1qTU4DC6NwtC4aWGt1EkzaQB8KPPyCRR8z9TWeV0HbEFGTO+ZY1wB22zmxnJqhPyTpOVCpeHTA==
+
+micromark@^4.0.0:
+ version "4.0.2"
+ resolved "https://registry.yarnpkg.com/micromark/-/micromark-4.0.2.tgz#91395a3e1884a198e62116e33c9c568e39936fdb"
+ integrity sha512-zpe98Q6kvavpCr1NPVSCMebCKfD7CA2NqZ+rykeNhONIJBpc1tFKt9hucLGwha3jNTNI8lHpctWJWoimVF4PfA==
+ dependencies:
+ "@types/debug" "^4.0.0"
+ debug "^4.0.0"
+ decode-named-character-reference "^1.0.0"
+ devlop "^1.0.0"
+ micromark-core-commonmark "^2.0.0"
+ micromark-factory-space "^2.0.0"
+ micromark-util-character "^2.0.0"
+ micromark-util-chunked "^2.0.0"
+ micromark-util-combine-extensions "^2.0.0"
+ micromark-util-decode-numeric-character-reference "^2.0.0"
+ micromark-util-encode "^2.0.0"
+ micromark-util-normalize-identifier "^2.0.0"
+ micromark-util-resolve-all "^2.0.0"
+ micromark-util-sanitize-uri "^2.0.0"
+ micromark-util-subtokenize "^2.0.0"
+ micromark-util-symbol "^2.0.0"
+ micromark-util-types "^2.0.0"
+
+minimatch@^10.2.2, minimatch@^10.2.4:
+ version "10.2.5"
+ resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-10.2.5.tgz#bd48687a0be38ed2961399105600f832095861d1"
+ integrity sha512-MULkVLfKGYDFYejP07QOurDLLQpcjk7Fw+7jXS2R2czRQzR56yHRveU5NDJEOviH+hETZKSkIk5c+T23GjFUMg==
+ dependencies:
+ brace-expansion "^5.0.5"
+
+mlly@^1.7.4, mlly@^1.8.0:
+ version "1.8.2"
+ resolved "https://registry.yarnpkg.com/mlly/-/mlly-1.8.2.tgz#e7f7919a82d13b174405613117249a3f449d78bb"
+ integrity sha512-d+ObxMQFmbt10sretNDytwt85VrbkhhUA/JBGm1MPaWJ65Cl4wOgLaB1NYvJSZ0Ef03MMEU/0xpPMXUIQ29UfA==
+ dependencies:
+ acorn "^8.16.0"
+ pathe "^2.0.3"
+ pkg-types "^1.3.1"
+ ufo "^1.6.3"
+
+module-replacements@^2.10.1:
+ version "2.11.0"
+ resolved "https://registry.yarnpkg.com/module-replacements/-/module-replacements-2.11.0.tgz#947ecd7a866301f3272f1a1649dd2607bb520dcc"
+ integrity sha512-j5sNQm3VCpQQ7nTqGeOZtoJtV3uKERgCBm9QRhmGRiXiqkf7iRFOkfxdJRZWLkqYY8PNf4cDQF/WfXUYLENrRA==
+
+ms@^2.1.3:
+ version "2.1.3"
+ resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2"
+ integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==
+
+muggle-string@^0.4.1:
+ version "0.4.1"
+ resolved "https://registry.yarnpkg.com/muggle-string/-/muggle-string-0.4.1.tgz#3b366bd43b32f809dc20659534dd30e7c8a0d328"
+ integrity sha512-VNTrAak/KhO2i8dqqnqnAHOa3cYBwXEZe9h+D5h/1ZqFSTEFHdM65lR7RoIqq3tBBYavsOXV84NoHXZ0AkPyqQ==
+
+nanoid@^3.3.11:
+ version "3.3.12"
+ resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.3.12.tgz#ab3d912e217a6d0a514f00a72a16543a28982c05"
+ integrity sha512-ZB9RH/39qpq5Vu6Y+NmUaFhQR6pp+M2Xt76XBnEwDaGcVAqhlvxrl3B2bKS5D3NH3QR76v3aSrKaF/Kiy7lEtQ==
+
+natural-compare@^1.4.0:
+ version "1.4.0"
+ resolved "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz#4abebfeed7541f2c27acfb29bdbbd15c8d5ba4f7"
+ integrity sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==
+
+natural-orderby@^5.0.0:
+ version "5.0.0"
+ resolved "https://registry.yarnpkg.com/natural-orderby/-/natural-orderby-5.0.0.tgz#bb655f669ee9c84e82cdc6cddbba25eb263cd9f4"
+ integrity sha512-kKHJhxwpR/Okycz4HhQKKlhWe4ASEfPgkSWNmKFHd7+ezuQlxkA5cM3+XkBPvm1gmHen3w53qsYAv+8GwRrBlg==
+
+node-addon-api@^7.0.0:
+ version "7.1.1"
+ resolved "https://registry.yarnpkg.com/node-addon-api/-/node-addon-api-7.1.1.tgz#1aba6693b0f255258a049d621329329322aad558"
+ integrity sha512-5m3bsyrjFWE1xf7nz7YXdN4udnVtXK6/Yfgn5qnahL6bCkf2yKt4k3nuTKAtT4r3IG8JNR2ncsIMdZuAzJjHQQ==
+
+node-releases@^2.0.36:
+ version "2.0.38"
+ resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.38.tgz#791569b9e4424a044e12c3abfad418ed83ce9947"
+ integrity sha512-3qT/88Y3FbH/Kx4szpQQ4HzUbVrHPKTLVpVocKiLfoYvw9XSGOX2FmD2d6DrXbVYyAQTF2HeF6My8jmzx7/CRw==
+
+nth-check@^2.1.1:
+ version "2.1.1"
+ resolved "https://registry.yarnpkg.com/nth-check/-/nth-check-2.1.1.tgz#c9eab428effce36cd6b92c924bdb000ef1f1ed1d"
+ integrity sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==
+ dependencies:
+ boolbase "^1.0.0"
+
+object-deep-merge@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/object-deep-merge/-/object-deep-merge-2.0.0.tgz#94d24cf713d4a7a143653500ff4488a2d494681f"
+ integrity sha512-3DC3UMpeffLTHiuXSy/UG4NOIYTLlY9u3V82+djSCLYClWobZiS4ivYzpIUWrRY/nfsJ8cWsKyG3QfyLePmhvg==
+
+ohash@^2.0.11:
+ version "2.0.11"
+ resolved "https://registry.yarnpkg.com/ohash/-/ohash-2.0.11.tgz#60b11e8cff62ca9dee88d13747a5baa145f5900b"
+ integrity sha512-RdR9FQrFwNBNXAr4GixM8YaRZRJ5PUWbKYbE5eOsrwAjJW0q2REGcf79oYPsLyskQCZG1PLN+S/K1V00joZAoQ==
+
+optionator@^0.9.3:
+ version "0.9.4"
+ resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.9.4.tgz#7ea1c1a5d91d764fb282139c88fe11e182a3a734"
+ integrity sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==
+ dependencies:
+ deep-is "^0.1.3"
+ fast-levenshtein "^2.0.6"
+ levn "^0.4.1"
+ prelude-ls "^1.2.1"
+ type-check "^0.4.0"
+ word-wrap "^1.2.5"
+
+oxfmt@^0.35.0:
+ version "0.35.0"
+ resolved "https://registry.yarnpkg.com/oxfmt/-/oxfmt-0.35.0.tgz#8e87f78a7249c553aa91c001b5745d58355bb6dc"
+ integrity sha512-QYeXWkP+aLt7utt5SLivNIk09glWx9QE235ODjgcEZ3sd1VMaUBSpLymh6ZRCA76gD2rMP4bXanUz/fx+nLM9Q==
+ dependencies:
+ tinypool "2.1.0"
+ optionalDependencies:
+ "@oxfmt/binding-android-arm-eabi" "0.35.0"
+ "@oxfmt/binding-android-arm64" "0.35.0"
+ "@oxfmt/binding-darwin-arm64" "0.35.0"
+ "@oxfmt/binding-darwin-x64" "0.35.0"
+ "@oxfmt/binding-freebsd-x64" "0.35.0"
+ "@oxfmt/binding-linux-arm-gnueabihf" "0.35.0"
+ "@oxfmt/binding-linux-arm-musleabihf" "0.35.0"
+ "@oxfmt/binding-linux-arm64-gnu" "0.35.0"
+ "@oxfmt/binding-linux-arm64-musl" "0.35.0"
+ "@oxfmt/binding-linux-ppc64-gnu" "0.35.0"
+ "@oxfmt/binding-linux-riscv64-gnu" "0.35.0"
+ "@oxfmt/binding-linux-riscv64-musl" "0.35.0"
+ "@oxfmt/binding-linux-s390x-gnu" "0.35.0"
+ "@oxfmt/binding-linux-x64-gnu" "0.35.0"
+ "@oxfmt/binding-linux-x64-musl" "0.35.0"
+ "@oxfmt/binding-openharmony-arm64" "0.35.0"
+ "@oxfmt/binding-win32-arm64-msvc" "0.35.0"
+ "@oxfmt/binding-win32-ia32-msvc" "0.35.0"
+ "@oxfmt/binding-win32-x64-msvc" "0.35.0"
+
+p-limit@^3.0.2:
+ version "3.1.0"
+ resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-3.1.0.tgz#e1daccbe78d0d1388ca18c64fea38e3e57e3706b"
+ integrity sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==
+ dependencies:
+ yocto-queue "^0.1.0"
+
+p-locate@^5.0.0:
+ version "5.0.0"
+ resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-5.0.0.tgz#83c8315c6785005e3bd021839411c9e110e6d834"
+ integrity sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==
+ dependencies:
+ p-limit "^3.0.2"
+
+package-manager-detector@^1.3.0:
+ version "1.6.0"
+ resolved "https://registry.yarnpkg.com/package-manager-detector/-/package-manager-detector-1.6.0.tgz#70d0cf0aa02c877eeaf66c4d984ede0be9130734"
+ integrity sha512-61A5ThoTiDG/C8s8UMZwSorAGwMJ0ERVGj2OjoW5pAalsNOg15+iQiPzrLJ4jhZ1HJzmC2PIHT2oEiH3R5fzNA==
+
+parse-gitignore@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/parse-gitignore/-/parse-gitignore-2.0.0.tgz#81156b265115c507129f3faea067b8476da3b642"
+ integrity sha512-RmVuCHWsfu0QPNW+mraxh/xjQVw/lhUCUru8Zni3Ctq3AoMhpDTq0OVdKS6iesd6Kqb7viCV3isAL43dciOSog==
+
+parse-imports-exports@^0.2.4:
+ version "0.2.4"
+ resolved "https://registry.yarnpkg.com/parse-imports-exports/-/parse-imports-exports-0.2.4.tgz#e3fb3b5e264cfb55c25b5dfcbe7f410f8dc4e7af"
+ integrity sha512-4s6vd6dx1AotCx/RCI2m7t7GCh5bDRUtGNvRfHSP2wbBQdMi67pPe7mtzmgwcaQ8VKK/6IB7Glfyu3qdZJPybQ==
+ dependencies:
+ parse-statements "1.0.11"
+
+parse-statements@1.0.11:
+ version "1.0.11"
+ resolved "https://registry.yarnpkg.com/parse-statements/-/parse-statements-1.0.11.tgz#8787c5d383ae5746568571614be72b0689584344"
+ integrity sha512-HlsyYdMBnbPQ9Jr/VgJ1YF4scnldvJpJxCVx6KgqPL4dxppsWrJHCIIxQXMJrqGnsRkNPATbeMJ8Yxu7JMsYcA==
+
+path-browserify@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/path-browserify/-/path-browserify-1.0.1.tgz#d98454a9c3753d5790860f16f68867b9e46be1fd"
+ integrity sha512-b7uo2UCUOYZcnF/3ID0lulOJi/bafxa1xPe7ZPsammBSpjSWQkjNxlt635YGS2MiR9GjvuXCtz2emr3jbsz98g==
+
+path-exists@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3"
+ integrity sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==
+
+path-key@^3.1.0:
+ version "3.1.1"
+ resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375"
+ integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==
+
+pathe@^2.0.1, pathe@^2.0.3:
+ version "2.0.3"
+ resolved "https://registry.yarnpkg.com/pathe/-/pathe-2.0.3.tgz#3ecbec55421685b70a9da872b2cff3e1cbed1716"
+ integrity sha512-WUjGcAqP1gQacoQe+OBJsFA7Ld4DyXuUIjZ5cc75cLHvJ7dtNsTugphxIADwspS+AraAUePCKrSVtPLFj/F88w==
+
+perfect-debounce@^2.0.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/perfect-debounce/-/perfect-debounce-2.1.0.tgz#e7078e38f231cb191855c3136a4423aef725d261"
+ integrity sha512-LjgdTytVFXeUgtHZr9WYViYSM/g8MkcTPYDlPa3cDqMirHjKiSZPYd6DoL7pK8AJQr+uWkQvCjHNdiMqsrJs+g==
+
+perfect-freehand@^1.2.3:
+ version "1.2.3"
+ resolved "https://registry.yarnpkg.com/perfect-freehand/-/perfect-freehand-1.2.3.tgz#f78b4f85464297e5861a9f6c3efd4c0abfa2f4be"
+ integrity sha512-bHZSfqDHGNlPpgH2yxXgPHlQSPpEbo+qg7li0M78J9vNAi2yjwLeA4x79BEQhX44lEWpCLSFCeRZwpw0niiXPA==
+
+picocolors@^1.1.1:
+ version "1.1.1"
+ resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.1.1.tgz#3d321af3eab939b083c8f929a1d12cda81c26b6b"
+ integrity sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==
+
+picomatch@^4.0.2, picomatch@^4.0.3, picomatch@^4.0.4:
+ version "4.0.4"
+ resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-4.0.4.tgz#fd6f5e00a143086e074dffe4c924b8fb293b0589"
+ integrity sha512-QP88BAKvMam/3NxH6vj2o21R6MjxZUAd6nlwAS/pnGvN9IVLocLHxGYIzFhg6fUQ+5th6P4dv4eW9jX3DSIj7A==
+
+pkg-types@^1.3.1:
+ version "1.3.1"
+ resolved "https://registry.yarnpkg.com/pkg-types/-/pkg-types-1.3.1.tgz#bd7cc70881192777eef5326c19deb46e890917df"
+ integrity sha512-/Jm5M4RvtBFVkKWRu2BLUTNP8/M2a+UwuAX+ae4770q1qVGtfjG+WTCupoZixokjmHiry8uI+dlY8KXYV5HVVQ==
+ dependencies:
+ confbox "^0.1.8"
+ mlly "^1.7.4"
+ pathe "^2.0.1"
+
+pkg-types@^2.3.0:
+ version "2.3.1"
+ resolved "https://registry.yarnpkg.com/pkg-types/-/pkg-types-2.3.1.tgz#fa27ed0940efcf40bba453b0e5cab41217b0d442"
+ integrity sha512-y+ichcgc2LrADuhLNAx8DFjVfgz91pRxfZdI3UDhxHvcVEZsenLO+7XaU5vOp0u/7V/wZ+plyuQxtrDlZJ+yeg==
+ dependencies:
+ confbox "^0.2.4"
+ exsolve "^1.0.8"
+ pathe "^2.0.3"
+
+pluralize@^8.0.0:
+ version "8.0.0"
+ resolved "https://registry.yarnpkg.com/pluralize/-/pluralize-8.0.0.tgz#1a6fa16a38d12a1901e0320fa017051c539ce3b1"
+ integrity sha512-Nc3IT5yHzflTfbjgqWcCPpo7DaKy4FnpB0l/zCAW0Tc7jxAiuqSxHasntB3D7887LSrA93kDJ9IXovxJYxyLCA==
+
+pnpm-workspace-yaml@1.6.0:
+ version "1.6.0"
+ resolved "https://registry.yarnpkg.com/pnpm-workspace-yaml/-/pnpm-workspace-yaml-1.6.0.tgz#8d070014c08cdb2291a11b64bb631843b1e19316"
+ integrity sha512-uUy4dK3E11sp7nK+hnT7uAWfkBMe00KaUw8OG3NuNlYQoTk4sc9pcdIy1+XIP85v9Tvr02mK3JPaNNrP0QyRaw==
+ dependencies:
+ yaml "^2.8.2"
+
+postcss-selector-parser@^7.1.0:
+ version "7.1.1"
+ resolved "https://registry.yarnpkg.com/postcss-selector-parser/-/postcss-selector-parser-7.1.1.tgz#e75d2e0d843f620e5df69076166f4e16f891cb9f"
+ integrity sha512-orRsuYpJVw8LdAwqqLykBj9ecS5/cRHlI5+nvTo8LcCKmzDmqVORXtOIYEEQuL9D4BxtA1lm5isAqzQZCoQ6Eg==
+ dependencies:
+ cssesc "^3.0.0"
+ util-deprecate "^1.0.2"
+
+postcss@^8.5.10, postcss@^8.5.14:
+ version "8.5.14"
+ resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.5.14.tgz#a66c2d7808fadf69ebb5b84a03f8bafd76c4919c"
+ integrity sha512-SoSL4+OSEtR99LHFZQiJLkT59C5B1amGO1NzTwj7TT1qCUgUO6hxOvzkOYxD+vMrXBM3XJIKzokoERdqQq/Zmg==
+ dependencies:
+ nanoid "^3.3.11"
+ picocolors "^1.1.1"
+ source-map-js "^1.2.1"
+
+prelude-ls@^1.2.1:
+ version "1.2.1"
+ resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.2.1.tgz#debc6489d7a6e6b0e7611888cec880337d316396"
+ integrity sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==
+
+prettier-linter-helpers@^1.0.0:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/prettier-linter-helpers/-/prettier-linter-helpers-1.0.1.tgz#6a31f88a4bad6c7adda253de12ba4edaea80ebcd"
+ integrity sha512-SxToR7P8Y2lWmv/kTzVLC1t/GDI2WGjMwNhLLE9qtH8Q13C+aEmuRlzDst4Up4s0Wc8sF2M+J57iB3cMLqftfg==
+ dependencies:
+ fast-diff "^1.1.2"
+
+prettier@^3.8.1:
+ version "3.8.3"
+ resolved "https://registry.yarnpkg.com/prettier/-/prettier-3.8.3.tgz#560f2de55bf01b4c0503bc629d5df99b9a1d09b0"
+ integrity sha512-7igPTM53cGHMW8xWuVTydi2KO233VFiTNyF5hLJqpilHfmn8C8gPf+PS7dUT64YcXFbiMGZxS9pCSxL/Dxm/Jw==
+
+primevue@^4.5.5:
+ version "4.5.5"
+ resolved "https://registry.yarnpkg.com/primevue/-/primevue-4.5.5.tgz#9bbaa59583418fab2d2d74bf3b6d30f4c9a851ad"
+ integrity sha512-Kv5REIewCdP806QaoU+4nBXfmpzOGFKkZ9qH4KsL6MjiAQVc4PUzypt8erl4r3Vzh3nr3aWZIxkxYRRsLGiX2A==
+ dependencies:
+ "@primeuix/styled" "^0.7.4"
+ "@primeuix/styles" "^2.0.3"
+ "@primeuix/utils" "^0.6.2"
+ "@primevue/core" "4.5.5"
+ "@primevue/icons" "4.5.5"
+
+proxy-compare@3.0.1, proxy-compare@^3.0.0:
+ version "3.0.1"
+ resolved "https://registry.yarnpkg.com/proxy-compare/-/proxy-compare-3.0.1.tgz#3262cff3a25a6dedeaa299f6cf2369d6f7588a94"
+ integrity sha512-V9plBAt3qjMlS1+nC8771KNf6oJ12gExvaxnNzN/9yVRLdTv/lc+oJlnSzrdYDAvBfTStPCoiaCOTmTs0adv7Q==
+
+proxy-memoize@3.0.1:
+ version "3.0.1"
+ resolved "https://registry.yarnpkg.com/proxy-memoize/-/proxy-memoize-3.0.1.tgz#75eed518778b282abb0bc55e748995214b7f74a9"
+ integrity sha512-VDdG/VYtOgdGkWJx7y0o7p+zArSf2383Isci8C+BP3YXgMYDoPd3cCBjw0JdWb6YBb9sFiOPbAADDVTPJnh+9g==
+ dependencies:
+ proxy-compare "^3.0.0"
+
+punycode@^2.1.0:
+ version "2.3.1"
+ resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.3.1.tgz#027422e2faec0b25e1549c3e1bd8309b9133b6e5"
+ integrity sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==
+
+quansync@^0.2.11:
+ version "0.2.11"
+ resolved "https://registry.yarnpkg.com/quansync/-/quansync-0.2.11.tgz#f9c3adda2e1272e4f8cf3f1457b04cbdb4ee692a"
+ integrity sha512-AifT7QEbW9Nri4tAwR5M/uzpBuqfZf+zwaEM/QkzEjj7NBuFD2rBuy0K3dE+8wltbezDV7JMA0WfnCPYRSYbXA==
+
+readdirp@^4.0.1:
+ version "4.1.2"
+ resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-4.1.2.tgz#eb85801435fbf2a7ee58f19e0921b068fc69948d"
+ integrity sha512-GDhwkLfywWL2s6vEjyhri+eXmfH6j1L7JE27WhqLeYzoh/A3DBaYGEj2H/HFZCn/kMfim73FXxEJTw06WtxQwg==
+
+readdirp@^5.0.0:
+ version "5.0.0"
+ resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-5.0.0.tgz#fbf1f71a727891d685bb1786f9ba74084f6e2f91"
+ integrity sha512-9u/XQ1pvrQtYyMpZe7DXKv2p5CNvyVwzUB6uhLAnQwHMSgKMBR62lc7AHljaeteeHXn11XTAaLLUVZYVZyuRBQ==
+
+refa@^0.12.0, refa@^0.12.1:
+ version "0.12.1"
+ resolved "https://registry.yarnpkg.com/refa/-/refa-0.12.1.tgz#dac13c4782dc22b6bae6cce81a2b863888ea39c6"
+ integrity sha512-J8rn6v4DBb2nnFqkqwy6/NnTYMcgLA+sLr0iIO41qpv0n+ngb7ksag2tMRl0inb1bbO/esUwzW1vbJi7K0sI0g==
+ dependencies:
+ "@eslint-community/regexpp" "^4.8.0"
+
+regexp-ast-analysis@^0.7.0, regexp-ast-analysis@^0.7.1:
+ version "0.7.1"
+ resolved "https://registry.yarnpkg.com/regexp-ast-analysis/-/regexp-ast-analysis-0.7.1.tgz#c0e24cb2a90f6eadd4cbaaba129317e29d29c482"
+ integrity sha512-sZuz1dYW/ZsfG17WSAG7eS85r5a0dDsvg+7BiiYR5o6lKCAtUrEwdmRmaGF6rwVj3LcmAeYkOWKEPlbPzN3Y3A==
+ dependencies:
+ "@eslint-community/regexpp" "^4.8.0"
+ refa "^0.12.1"
+
+regexp-tree@^0.1.27:
+ version "0.1.27"
+ resolved "https://registry.yarnpkg.com/regexp-tree/-/regexp-tree-0.1.27.tgz#2198f0ef54518ffa743fe74d983b56ffd631b6cd"
+ integrity sha512-iETxpjK6YoRWJG5o6hXLwvjYAoW+FEZn9os0PD/b6AP6xQwsa/Y7lCVgIixBbUPMfhu+i2LtdeAqVTgGlQarfA==
+
+regjsparser@^0.13.0:
+ version "0.13.1"
+ resolved "https://registry.yarnpkg.com/regjsparser/-/regjsparser-0.13.1.tgz#0593cbacb27527927692030928ae4d3b878d6f8d"
+ integrity sha512-dLsljMd9sqwRkby8zhO1gSg3PnJIBFid8f4CQj/sXx+7cKx+E7u0PKhZ+U4wmhx7EfmtvnA318oVaIkAB1lRJw==
+ dependencies:
+ jsesc "~3.1.0"
+
+reserved-identifiers@^1.0.0:
+ version "1.2.0"
+ resolved "https://registry.yarnpkg.com/reserved-identifiers/-/reserved-identifiers-1.2.0.tgz#d2982cd698e317dd3dced1ee1c52412dbd64fc64"
+ integrity sha512-yE7KUfFvaBFzGPs5H3Ops1RevfUEsDc5Iz65rOwWg4lE8HJSYtle77uul3+573457oHvBKuHYDl/xqUkKpEEdw==
+
+resolve-pkg-maps@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/resolve-pkg-maps/-/resolve-pkg-maps-1.0.0.tgz#616b3dc2c57056b5588c31cdf4b3d64db133720f"
+ integrity sha512-seS2Tj26TBVOC2NIc2rOe2y2ZO7efxITtLZcGSOnHHNOQ7CkiUBfw0Iw2ck6xkIhPwLhKNLS8BO+hEpngQlqzw==
+
+rolldown@1.0.0-rc.17:
+ version "1.0.0-rc.17"
+ resolved "https://registry.yarnpkg.com/rolldown/-/rolldown-1.0.0-rc.17.tgz#c524fc22f6bb37b5588aec862ab1ee11382610f3"
+ integrity sha512-ZrT53oAKrtA4+YtBWPQbtPOxIbVDbxT0orcYERKd63VJTF13zPcgXTvD4843L8pcsI7M6MErt8QtON6lrB9tyA==
+ dependencies:
+ "@oxc-project/types" "=0.127.0"
+ "@rolldown/pluginutils" "1.0.0-rc.17"
+ optionalDependencies:
+ "@rolldown/binding-android-arm64" "1.0.0-rc.17"
+ "@rolldown/binding-darwin-arm64" "1.0.0-rc.17"
+ "@rolldown/binding-darwin-x64" "1.0.0-rc.17"
+ "@rolldown/binding-freebsd-x64" "1.0.0-rc.17"
+ "@rolldown/binding-linux-arm-gnueabihf" "1.0.0-rc.17"
+ "@rolldown/binding-linux-arm64-gnu" "1.0.0-rc.17"
+ "@rolldown/binding-linux-arm64-musl" "1.0.0-rc.17"
+ "@rolldown/binding-linux-ppc64-gnu" "1.0.0-rc.17"
+ "@rolldown/binding-linux-s390x-gnu" "1.0.0-rc.17"
+ "@rolldown/binding-linux-x64-gnu" "1.0.0-rc.17"
+ "@rolldown/binding-linux-x64-musl" "1.0.0-rc.17"
+ "@rolldown/binding-openharmony-arm64" "1.0.0-rc.17"
+ "@rolldown/binding-wasm32-wasi" "1.0.0-rc.17"
+ "@rolldown/binding-win32-arm64-msvc" "1.0.0-rc.17"
+ "@rolldown/binding-win32-x64-msvc" "1.0.0-rc.17"
+
+rxjs@^7.4.0:
+ version "7.8.2"
+ resolved "https://registry.yarnpkg.com/rxjs/-/rxjs-7.8.2.tgz#955bc473ed8af11a002a2be52071bf475638607b"
+ integrity sha512-dhKf903U/PQZY6boNNtAGdWbG85WAbjT/1xYoZIC7FAY0yWapOBQVsVrDl58W86//e1VpMNBtRV4MaXfdMySFA==
+ dependencies:
+ tslib "^2.1.0"
+
+sass-embedded-all-unknown@1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass-embedded-all-unknown/-/sass-embedded-all-unknown-1.99.0.tgz#a17211a0e6862bc36eea063fbd0c55dc2a41c3a1"
+ integrity sha512-qPIRG8Uhjo6/OKyAKixTnwMliTz+t9K6Duk0mx5z+K7n0Ts38NSJz2sjDnc7cA/8V9Lb3q09H38dZ1CLwD+ssw==
+ dependencies:
+ sass "1.99.0"
+
+sass-embedded-android-arm64@1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass-embedded-android-arm64/-/sass-embedded-android-arm64-1.99.0.tgz#670907b907eef644d45c609b06d57c3659cf77a7"
+ integrity sha512-fNHhdnP23yqqieCbAdym4N47AleSwjbNt6OYIYx4DdACGdtERjQB4iOX/TaKsW034MupfF7SjnAAK8w7Ptldtg==
+
+sass-embedded-android-arm@1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass-embedded-android-arm/-/sass-embedded-android-arm-1.99.0.tgz#2c0d5719d2022578e97d0296bfc7771c4588a2e9"
+ integrity sha512-EHvJ0C7/VuP78Qr6f8gIUVUmCqIorEQpw2yp3cs3SMg02ZuumlhjXvkTcFBxHmFdFR23vTNk1WnhY6QSeV1nFQ==
+
+sass-embedded-android-riscv64@1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass-embedded-android-riscv64/-/sass-embedded-android-riscv64-1.99.0.tgz#7b9006c5921205c252d9928dabc41d93713b0ae6"
+ integrity sha512-4zqDFRvgGDTL5vTHuIhRxUpXFoh0Cy7Gm5Ywk19ASd8Settmd14YdPRZPmMxfgS1GH292PofV1fq1ifiSEJWBw==
+
+sass-embedded-android-x64@1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass-embedded-android-x64/-/sass-embedded-android-x64-1.99.0.tgz#cb0c4e0ec1991faab41a6d60c894ce12fcaaf339"
+ integrity sha512-Uk53k/dGYt04RjOL4gFjZ0Z9DH9DKh8IA8WsXUkNqsxerAygoy3zqRBS2zngfE9K2jiOM87q+1R1p87ory9oQQ==
+
+sass-embedded-darwin-arm64@1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass-embedded-darwin-arm64/-/sass-embedded-darwin-arm64-1.99.0.tgz#aa836ba0b2342f8d0fa03394781a9385fb8f222d"
+ integrity sha512-u61/7U3IGLqoO6gL+AHeiAtlTPFwJK1+964U8gp45ZN0hzh1yrARf5O1mivXv8NnNgJvbG2wWJbiNZP0lG/lTg==
+
+sass-embedded-darwin-x64@1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass-embedded-darwin-x64/-/sass-embedded-darwin-x64-1.99.0.tgz#47a8a95579f6b8b66f07d233d59d43a99f6000ac"
+ integrity sha512-j/kkk/NcXdIameLezSfXjgCiBkVcA+G60AXrX768/3g0miK1g7M9dj7xOhCb1i7/wQeiEI3rw2LLuO63xRIn4A==
+
+sass-embedded-linux-arm64@1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass-embedded-linux-arm64/-/sass-embedded-linux-arm64-1.99.0.tgz#201232294df6d119e89f12c1e35e0e9f316263bd"
+ integrity sha512-btNcFpItcB56L40n8hDeL7sRSMLDXQ56nB5h2deddJx1n60rpKSElJmkaDGHtpkrY+CTtDRV0FZDjHeTJddYew==
+
+sass-embedded-linux-arm@1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass-embedded-linux-arm/-/sass-embedded-linux-arm-1.99.0.tgz#013ac6f04dedbcbdd3f2d460d078809c5244d1eb"
+ integrity sha512-d4IjJZrX2+AwB2YCy1JySwdptJECNP/WfAQLUl8txI3ka8/d3TUI155GtelnoZUkio211PwIeFvvAeZ9RXPQnw==
+
+sass-embedded-linux-musl-arm64@1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass-embedded-linux-musl-arm64/-/sass-embedded-linux-musl-arm64-1.99.0.tgz#cc3cc0f4dcaf5072bc777719419a8fdf997910df"
+ integrity sha512-Hi2bt/IrM5P4FBKz6EcHAlniwfpoz9mnTdvSd58y+avA3SANM76upIkAdSayA8ZGwyL3gZokru1AKDPF9lJDNw==
+
+sass-embedded-linux-musl-arm@1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass-embedded-linux-musl-arm/-/sass-embedded-linux-musl-arm-1.99.0.tgz#4af04ac13b242253a276ccecc0905a4119501d16"
+ integrity sha512-2gvHOupgIw3ytatXT4nFUow71LFbuOZPEwG+HUzcNQDH8ue4Ez8cr03vsv5MDv3lIjOKcXwDvWD980t18MwkoQ==
+
+sass-embedded-linux-musl-riscv64@1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass-embedded-linux-musl-riscv64/-/sass-embedded-linux-musl-riscv64-1.99.0.tgz#5e6fb8d41a6280d9dfda2b636a3b1c3a7c3c2e53"
+ integrity sha512-mKqGvVaJ9rHMqyZsF0kikQe4NO0f4osb67+X6nLhBiVDKvyazQHJ3zJQreNefIE36yL2sjHIclSB//MprzaQDg==
+
+sass-embedded-linux-musl-x64@1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass-embedded-linux-musl-x64/-/sass-embedded-linux-musl-x64-1.99.0.tgz#e26a0d65cf5a488f24951ddce1842d6482c78a7d"
+ integrity sha512-huhgOMmOc30r7CH7qbRbT9LerSEGSnWuS4CYNOskr9BvNeQp4dIneFufNRGZ7hkOAxUM8DglxIZJN/cyAT95Ew==
+
+sass-embedded-linux-riscv64@1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass-embedded-linux-riscv64/-/sass-embedded-linux-riscv64-1.99.0.tgz#3a114700b58e4d0d8fb2191f29f873068bb42afc"
+ integrity sha512-mevFPIFAVhrH90THifxLfOntFmHtcEKOcdWnep2gJ0X4DVva4AiVIRlQe/7w9JFx5+gnDRE1oaJJkzuFUuYZsA==
+
+sass-embedded-linux-x64@1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass-embedded-linux-x64/-/sass-embedded-linux-x64-1.99.0.tgz#b23e34de696eeef621ada3671014208ae56b747b"
+ integrity sha512-9k7IkULqIZdCIVt4Mboryt6vN8Mjmm3EhI1P3mClU5y5i3wLK5ExC3cbVWk047KsID/fvB1RLslqghXJx5BoxA==
+
+sass-embedded-unknown-all@1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass-embedded-unknown-all/-/sass-embedded-unknown-all-1.99.0.tgz#202d955a376c413706224dd6f83ce8df2a5f71fe"
+ integrity sha512-P7MxiUtL/XzGo3PX0CaB8lNNEFLQWKikPA8pbKytx9ZCLZSDkt2NJcdAbblB/sqMs4AV3EK2NadV8rI/diq3xg==
+ dependencies:
+ sass "1.99.0"
+
+sass-embedded-win32-arm64@1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass-embedded-win32-arm64/-/sass-embedded-win32-arm64-1.99.0.tgz#1461a6a14cd3596ee122fc1b7ead25b039a066fc"
+ integrity sha512-8whpsW7S+uO8QApKfQuc36m3P9EISzbVZOgC79goob4qGy09u8Gz/rYvw8h1prJDSjltpHGhOzBE6LDz7WvzVw==
+
+sass-embedded-win32-x64@1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass-embedded-win32-x64/-/sass-embedded-win32-x64-1.99.0.tgz#3d08d273b268918647093fd7d0bf0fb84ac2c321"
+ integrity sha512-ipuOv1R2K4MHeuCEAZGpuUbAgma4gb0sdacyrTjJtMOy/OY9UvWfVlwErdB09KIkp4fPDpQJDJfvYN6bC8jeNg==
+
+sass-embedded@^1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass-embedded/-/sass-embedded-1.99.0.tgz#348fdb98b02694d8b193e7a0e1bfc47408f89d4f"
+ integrity sha512-gF/juR1aX02lZHkvwxdF80SapkQeg2fetoDF6gIQkNbSw5YEUFspMkyGTjPjgZSgIHuZpy+Wz4PlebKnLXMjdg==
+ dependencies:
+ "@bufbuild/protobuf" "^2.5.0"
+ colorjs.io "^0.5.0"
+ immutable "^5.1.5"
+ rxjs "^7.4.0"
+ supports-color "^8.1.1"
+ sync-child-process "^1.0.2"
+ varint "^6.0.0"
+ optionalDependencies:
+ sass-embedded-all-unknown "1.99.0"
+ sass-embedded-android-arm "1.99.0"
+ sass-embedded-android-arm64 "1.99.0"
+ sass-embedded-android-riscv64 "1.99.0"
+ sass-embedded-android-x64 "1.99.0"
+ sass-embedded-darwin-arm64 "1.99.0"
+ sass-embedded-darwin-x64 "1.99.0"
+ sass-embedded-linux-arm "1.99.0"
+ sass-embedded-linux-arm64 "1.99.0"
+ sass-embedded-linux-musl-arm "1.99.0"
+ sass-embedded-linux-musl-arm64 "1.99.0"
+ sass-embedded-linux-musl-riscv64 "1.99.0"
+ sass-embedded-linux-musl-x64 "1.99.0"
+ sass-embedded-linux-riscv64 "1.99.0"
+ sass-embedded-linux-x64 "1.99.0"
+ sass-embedded-unknown-all "1.99.0"
+ sass-embedded-win32-arm64 "1.99.0"
+ sass-embedded-win32-x64 "1.99.0"
+
+sass@1.99.0:
+ version "1.99.0"
+ resolved "https://registry.yarnpkg.com/sass/-/sass-1.99.0.tgz#ff9d1594da4886249dfaafabbeea2dea2dc74b26"
+ integrity sha512-kgW13M54DUB7IsIRM5LvJkNlpH+WhMpooUcaWGFARkF1Tc82v9mIWkCbCYf+MBvpIUBSeSOTilpZjEPr2VYE6Q==
+ dependencies:
+ chokidar "^4.0.0"
+ immutable "^5.1.5"
+ source-map-js ">=0.6.2 <2.0.0"
+ optionalDependencies:
+ "@parcel/watcher" "^2.4.1"
+
+scslre@^0.3.0:
+ version "0.3.0"
+ resolved "https://registry.yarnpkg.com/scslre/-/scslre-0.3.0.tgz#c3211e9bfc5547fc86b1eabaa34ed1a657060155"
+ integrity sha512-3A6sD0WYP7+QrjbfNA2FN3FsOaGGFoekCVgTyypy53gPxhbkCIjtO6YWgdrfM+n/8sI8JeXZOIxsHjMTNxQ4nQ==
+ dependencies:
+ "@eslint-community/regexpp" "^4.8.0"
+ refa "^0.12.0"
+ regexp-ast-analysis "^0.7.0"
+
+scule@^1.3.0:
+ version "1.3.0"
+ resolved "https://registry.yarnpkg.com/scule/-/scule-1.3.0.tgz#6efbd22fd0bb801bdcc585c89266a7d2daa8fbd3"
+ integrity sha512-6FtHJEvt+pVMIB9IBY+IcCJ6Z5f1iQnytgyfKMhDKgmzYG+TeH/wx1y3l27rshSbLiSanrR9ffZDrEsmjlQF2g==
+
+semver@^7.3.5, semver@^7.5.4, semver@^7.6.3, semver@^7.7.3, semver@^7.7.4:
+ version "7.7.4"
+ resolved "https://registry.yarnpkg.com/semver/-/semver-7.7.4.tgz#28464e36060e991fa7a11d0279d2d3f3b57a7e8a"
+ integrity sha512-vFKC2IEtQnVhpT78h1Yp8wzwrf8CM+MzKMHGJZfBtzhZNycRFnXsHk6E5TxIkkMsgNS7mdX3AGB7x2QM2di4lA==
+
+shebang-command@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-2.0.0.tgz#ccd0af4f8835fbdc265b82461aaf0c36663f34ea"
+ integrity sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==
+ dependencies:
+ shebang-regex "^3.0.0"
+
+shebang-regex@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-3.0.0.tgz#ae16f1644d873ecad843b0307b143362d4c42172"
+ integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==
+
+sisteransi@^1.0.5:
+ version "1.0.5"
+ resolved "https://registry.yarnpkg.com/sisteransi/-/sisteransi-1.0.5.tgz#134d681297756437cc05ca01370d3a7a571075ed"
+ integrity sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==
+
+"source-map-js@>=0.6.2 <2.0.0", source-map-js@^1.2.1:
+ version "1.2.1"
+ resolved "https://registry.yarnpkg.com/source-map-js/-/source-map-js-1.2.1.tgz#1ce5650fddd87abc099eda37dcff024c2667ae46"
+ integrity sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==
+
+spdx-exceptions@^2.1.0:
+ version "2.5.0"
+ resolved "https://registry.yarnpkg.com/spdx-exceptions/-/spdx-exceptions-2.5.0.tgz#5d607d27fc806f66d7b64a766650fa890f04ed66"
+ integrity sha512-PiU42r+xO4UbUS1buo3LPJkjlO7430Xn5SVAhdpzzsPHsjbYVflnnFdATgabnLude+Cqu25p6N+g2lw/PFsa4w==
+
+spdx-expression-parse@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.yarnpkg.com/spdx-expression-parse/-/spdx-expression-parse-4.0.0.tgz#a23af9f3132115465dac215c099303e4ceac5794"
+ integrity sha512-Clya5JIij/7C6bRR22+tnGXbc4VKlibKSVj2iHvVeX5iMW7s1SIQlqu699JkODJJIhh/pUu8L0/VLh8xflD+LQ==
+ dependencies:
+ spdx-exceptions "^2.1.0"
+ spdx-license-ids "^3.0.0"
+
+spdx-license-ids@^3.0.0:
+ version "3.0.23"
+ resolved "https://registry.yarnpkg.com/spdx-license-ids/-/spdx-license-ids-3.0.23.tgz#b069e687b1291a32f126893ed76a27a745ee2133"
+ integrity sha512-CWLcCCH7VLu13TgOH+r8p1O/Znwhqv/dbb6lqWy67G+pT1kHmeD/+V36AVb/vq8QMIQwVShJ6Ssl5FPh0fuSdw==
+
+strip-indent@^4.1.1:
+ version "4.1.1"
+ resolved "https://registry.yarnpkg.com/strip-indent/-/strip-indent-4.1.1.tgz#aba13de189d4ad9a17f6050e76554ac27585c7af"
+ integrity sha512-SlyRoSkdh1dYP0PzclLE7r0M9sgbFKKMFXpFRUMNuKhQSbC6VQIGzq3E0qsfvGJaUFJPGv6Ws1NZ/haTAjfbMA==
+
+supports-color@^8.1.1:
+ version "8.1.1"
+ resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-8.1.1.tgz#cd6fc17e28500cff56c1b86c0a7fd4a54a73005c"
+ integrity sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==
+ dependencies:
+ has-flag "^4.0.0"
+
+sync-child-process@^1.0.2:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/sync-child-process/-/sync-child-process-1.0.2.tgz#45e7c72e756d1243e80b547ea2e17957ab9e367f"
+ integrity sha512-8lD+t2KrrScJ/7KXCSyfhT3/hRq78rC0wBFqNJXv3mZyn6hW2ypM05JmlSvtqRbeq6jqA94oHbxAr2vYsJ8vDA==
+ dependencies:
+ sync-message-port "^1.0.0"
+
+sync-message-port@^1.0.0:
+ version "1.2.0"
+ resolved "https://registry.yarnpkg.com/sync-message-port/-/sync-message-port-1.2.0.tgz#4b0d622085f21496061037125dec61755d96e330"
+ integrity sha512-gAQ9qrUN/UCypHtGFbbe7Rc/f9bzO88IwrG8TDo/aMKAApKyD6E3W4Cm0EfhfBb6Z6SKt59tTCTfD+n1xmAvMg==
+
+synckit@^0.11.12:
+ version "0.11.12"
+ resolved "https://registry.yarnpkg.com/synckit/-/synckit-0.11.12.tgz#abe74124264fbc00a48011b0d98bdc1cffb64a7b"
+ integrity sha512-Bh7QjT8/SuKUIfObSXNHNSK6WHo6J1tHCqJsuaFDP7gP0fkzSfTxI8y85JrppZ0h8l0maIgc2tfuZQ6/t3GtnQ==
+ dependencies:
+ "@pkgr/core" "^0.2.9"
+
+tapable@^2.3.3:
+ version "2.3.3"
+ resolved "https://registry.yarnpkg.com/tapable/-/tapable-2.3.3.tgz#5da7c9992c46038221267985ab28421a8879f160"
+ integrity sha512-uxc/zpqFg6x7C8vOE7lh6Lbda8eEL9zmVm/PLeTPBRhh1xCgdWaQ+J1CUieGpIfm2HdtsUpRv+HshiasBMcc6A==
+
+tinyexec@^1.0.1:
+ version "1.1.2"
+ resolved "https://registry.yarnpkg.com/tinyexec/-/tinyexec-1.1.2.tgz#11feef204b706d4668ca4013db29f3bd64f5c4dc"
+ integrity sha512-dAqSqE/RabpBKI8+h26GfLq6Vb3JVXs30XYQjdMjaj/c2tS8IYYMbIzP599KtRj7c57/wYApb3QjgRgXmrCukA==
+
+tinyglobby@^0.2.15, tinyglobby@^0.2.16:
+ version "0.2.16"
+ resolved "https://registry.yarnpkg.com/tinyglobby/-/tinyglobby-0.2.16.tgz#1c3b7eb953fce42b226bc5a1ee06428281aff3d6"
+ integrity sha512-pn99VhoACYR8nFHhxqix+uvsbXineAasWm5ojXoN8xEwK5Kd3/TrhNn1wByuD52UxWRLy8pu+kRMniEi6Eq9Zg==
+ dependencies:
+ fdir "^6.5.0"
+ picomatch "^4.0.4"
+
+tinypool@2.1.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/tinypool/-/tinypool-2.1.0.tgz#303a671d6ef68d03c9512cdc9a47c86b8a85f20c"
+ integrity sha512-Pugqs6M0m7Lv1I7FtxN4aoyToKg1C4tu+/381vH35y8oENM/Ai7f7C4StcoK4/+BSw9ebcS8jRiVrORFKCALLw==
+
+to-valid-identifier@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/to-valid-identifier/-/to-valid-identifier-1.0.0.tgz#27337955333c3c517feb60bea533cf27ce54b79f"
+ integrity sha512-41wJyvKep3yT2tyPqX/4blcfybknGB4D+oETKLs7Q76UiPqRpUJK3hr1nxelyYO0PHKVzJwlu0aCeEAsGI6rpw==
+ dependencies:
+ "@sindresorhus/base62" "^1.0.0"
+ reserved-identifiers "^1.0.0"
+
+toml-eslint-parser@^1.0.1, toml-eslint-parser@^1.0.3:
+ version "1.0.3"
+ resolved "https://registry.yarnpkg.com/toml-eslint-parser/-/toml-eslint-parser-1.0.3.tgz#1b2615fb969a5a6b9cfbf60c1ecbd6dfa3ea4797"
+ integrity sha512-A5F0cM6+mDleacLIEUkmfpkBbnHJFV1d2rprHU2MXNk7mlxHq2zGojA+SRvQD1RoMo9gqjZPWEaKG4v1BQ48lw==
+ dependencies:
+ eslint-visitor-keys "^5.0.0"
+
+ts-api-utils@^2.5.0:
+ version "2.5.0"
+ resolved "https://registry.yarnpkg.com/ts-api-utils/-/ts-api-utils-2.5.0.tgz#4acd4a155e22734990a5ed1fe9e97f113bcb37c1"
+ integrity sha512-OJ/ibxhPlqrMM0UiNHJ/0CKQkoKF243/AEmplt3qpRgkW8VG7IfOS41h7V8TjITqdByHzrjcS/2si+y4lIh8NA==
+
+ts-declaration-location@^1.0.6:
+ version "1.0.7"
+ resolved "https://registry.yarnpkg.com/ts-declaration-location/-/ts-declaration-location-1.0.7.tgz#d4068fe9975828b3b453b3ab112b4711d8267688"
+ integrity sha512-EDyGAwH1gO0Ausm9gV6T2nUvBgXT5kGoCMJPllOaooZ+4VvJiKBdZE7wK18N1deEowhcUptS+5GXZK8U/fvpwA==
+ dependencies:
+ picomatch "^4.0.2"
+
+tslib@^2.1.0, tslib@^2.4.0, tslib@^2.8.0:
+ version "2.8.1"
+ resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.8.1.tgz#612efe4ed235d567e8aba5f2a5fab70280ade83f"
+ integrity sha512-oJFu94HQb+KVduSUQL7wnpmqnfmLsOA/nAh6b6EH0wCEoK0/mPeXU6c3wKDV83MkOuHPRHtSXKKU99IBazS/2w==
+
+type-check@^0.4.0, type-check@~0.4.0:
+ version "0.4.0"
+ resolved "https://registry.yarnpkg.com/type-check/-/type-check-0.4.0.tgz#07b8203bfa7056c0657050e3ccd2c37730bab8f1"
+ integrity sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==
+ dependencies:
+ prelude-ls "^1.2.1"
+
+typescript@~6.0.2:
+ version "6.0.3"
+ resolved "https://registry.yarnpkg.com/typescript/-/typescript-6.0.3.tgz#90251dc007916e972786cb94d74d15b185577d21"
+ integrity sha512-y2TvuxSZPDyQakkFRPZHKFm+KKVqIisdg9/CZwm9ftvKXLP8NRWj38/ODjNbr43SsoXqNuAisEf1GdCxqWcdBw==
+
+ufo@^1.6.3:
+ version "1.6.4"
+ resolved "https://registry.yarnpkg.com/ufo/-/ufo-1.6.4.tgz#7a8fb875fcc6382d2c7d0b3692738b0500a92467"
+ integrity sha512-JFNbkD1Svwe0KvGi8GOeLcP4kAWQ609twvCdcHxq1oSL8svv39ZuSvajcD8B+5D0eL4+s1Is2D/O6KN3qcTeRA==
+
+undici-types@~7.16.0:
+ version "7.16.0"
+ resolved "https://registry.yarnpkg.com/undici-types/-/undici-types-7.16.0.tgz#ffccdff36aea4884cbfce9a750a0580224f58a46"
+ integrity sha512-Zz+aZWSj8LE6zoxD+xrjh4VfkIG8Ya6LvYkZqtUQGJPZjYl53ypCaUwWqo7eI0x66KBGeRo+mlBEkMSeSZ38Nw==
+
+unist-util-is@^6.0.0:
+ version "6.0.1"
+ resolved "https://registry.yarnpkg.com/unist-util-is/-/unist-util-is-6.0.1.tgz#d0a3f86f2dd0db7acd7d8c2478080b5c67f9c6a9"
+ integrity sha512-LsiILbtBETkDz8I9p1dQ0uyRUWuaQzd/cuEeS1hoRSyW5E5XGmTzlwY1OrNzzakGowI9Dr/I8HVaw4hTtnxy8g==
+ dependencies:
+ "@types/unist" "^3.0.0"
+
+unist-util-remove-position@^5.0.0:
+ version "5.0.0"
+ resolved "https://registry.yarnpkg.com/unist-util-remove-position/-/unist-util-remove-position-5.0.0.tgz#fea68a25658409c9460408bc6b4991b965b52163"
+ integrity sha512-Hp5Kh3wLxv0PHj9m2yZhhLt58KzPtEYKQQ4yxfYFEO7EvHwzyDYnduhHnY1mDxoqr7VUwVuHXk9RXKIiYS1N8Q==
+ dependencies:
+ "@types/unist" "^3.0.0"
+ unist-util-visit "^5.0.0"
+
+unist-util-stringify-position@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.yarnpkg.com/unist-util-stringify-position/-/unist-util-stringify-position-4.0.0.tgz#449c6e21a880e0855bf5aabadeb3a740314abac2"
+ integrity sha512-0ASV06AAoKCDkS2+xw5RXJywruurpbC4JZSm7nr7MOt1ojAzvyyaO+UxZf18j8FCF6kmzCZKcAgN/yu2gm2XgQ==
+ dependencies:
+ "@types/unist" "^3.0.0"
+
+unist-util-visit-parents@^6.0.0:
+ version "6.0.2"
+ resolved "https://registry.yarnpkg.com/unist-util-visit-parents/-/unist-util-visit-parents-6.0.2.tgz#777df7fb98652ce16b4b7cd999d0a1a40efa3a02"
+ integrity sha512-goh1s1TBrqSqukSc8wrjwWhL0hiJxgA8m4kFxGlQ+8FYQ3C/m11FcTs4YYem7V664AhHVvgoQLk890Ssdsr2IQ==
+ dependencies:
+ "@types/unist" "^3.0.0"
+ unist-util-is "^6.0.0"
+
+unist-util-visit@^5.0.0:
+ version "5.1.0"
+ resolved "https://registry.yarnpkg.com/unist-util-visit/-/unist-util-visit-5.1.0.tgz#9a2a28b0aa76a15e0da70a08a5863a2f060e2468"
+ integrity sha512-m+vIdyeCOpdr/QeQCu2EzxX/ohgS8KbnPDgFni4dQsfSCtpz8UqDyY5GjRru8PDKuYn7Fq19j1CQ+nJSsGKOzg==
+ dependencies:
+ "@types/unist" "^3.0.0"
+ unist-util-is "^6.0.0"
+ unist-util-visit-parents "^6.0.0"
+
+unplugin-utils@^0.3.0, unplugin-utils@^0.3.1:
+ version "0.3.1"
+ resolved "https://registry.yarnpkg.com/unplugin-utils/-/unplugin-utils-0.3.1.tgz#ef2873670a6a2a21bd2c9d31307257cc863a709c"
+ integrity sha512-5lWVjgi6vuHhJ526bI4nlCOmkCIF3nnfXkCMDeMJrtdvxTs6ZFCM8oNufGTsDbKv/tJ/xj8RpvXjRuPBZJuJog==
+ dependencies:
+ pathe "^2.0.3"
+ picomatch "^4.0.3"
+
+unplugin@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.yarnpkg.com/unplugin/-/unplugin-3.0.0.tgz#01e40c474bf74d363744f4cb262569d26dd9bb43"
+ integrity sha512-0Mqk3AT2TZCXWKdcoaufeXNukv2mTrEZExeXlHIOZXdqYoHHr4n51pymnwV8x2BOVxwXbK2HLlI7usrqMpycdg==
+ dependencies:
+ "@jridgewell/remapping" "^2.3.5"
+ picomatch "^4.0.3"
+ webpack-virtual-modules "^0.6.2"
+
+update-browserslist-db@^1.2.3:
+ version "1.2.3"
+ resolved "https://registry.yarnpkg.com/update-browserslist-db/-/update-browserslist-db-1.2.3.tgz#64d76db58713136acbeb4c49114366cc6cc2e80d"
+ integrity sha512-Js0m9cx+qOgDxo0eMiFGEueWztz+d4+M3rGlmKPT+T4IS/jP4ylw3Nwpu6cpTTP8R1MAC1kF4VbdLt3ARf209w==
+ dependencies:
+ escalade "^3.2.0"
+ picocolors "^1.1.1"
+
+uqr@0.1.2:
+ version "0.1.2"
+ resolved "https://registry.yarnpkg.com/uqr/-/uqr-0.1.2.tgz#5c6cd5dcff9581f9bb35b982cb89e2c483a41d7d"
+ integrity sha512-MJu7ypHq6QasgF5YRTjqscSzQp/W11zoUk6kvmlH+fmWEs63Y0Eib13hYFwAzagRJcVY8WVnlV+eBDUGMJ5IbA==
+
+uri-js@^4.2.2:
+ version "4.4.1"
+ resolved "https://registry.yarnpkg.com/uri-js/-/uri-js-4.4.1.tgz#9b1a52595225859e55f669d928f88c6c57f2a77e"
+ integrity sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==
+ dependencies:
+ punycode "^2.1.0"
+
+util-deprecate@^1.0.2:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf"
+ integrity sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==
+
+varint@^6.0.0:
+ version "6.0.0"
+ resolved "https://registry.yarnpkg.com/varint/-/varint-6.0.0.tgz#9881eb0ce8feaea6512439d19ddf84bf551661d0"
+ integrity sha512-cXEIW6cfr15lFv563k4GuVuW/fiwjknytD37jIOLSdSWuOI6WnO/oKwmP2FQTU2l01LP8/M5TSAJpzUaGe3uWg==
+
+vite@^8.0.10:
+ version "8.0.10"
+ resolved "https://registry.yarnpkg.com/vite/-/vite-8.0.10.tgz#fb31868526ec874101fac084172a2cdc6776319b"
+ integrity sha512-rZuUu9j6J5uotLDs+cAA4O5H4K1SfPliUlQwqa6YEwSrWDZzP4rhm00oJR5snMewjxF5V/K3D4kctsUTsIU9Mw==
+ dependencies:
+ lightningcss "^1.32.0"
+ picomatch "^4.0.4"
+ postcss "^8.5.10"
+ rolldown "1.0.0-rc.17"
+ tinyglobby "^0.2.16"
+ optionalDependencies:
+ fsevents "~2.3.3"
+
+vscode-uri@^3.0.8:
+ version "3.1.0"
+ resolved "https://registry.yarnpkg.com/vscode-uri/-/vscode-uri-3.1.0.tgz#dd09ec5a66a38b5c3fffc774015713496d14e09c"
+ integrity sha512-/BpdSx+yCQGnCvecbyXdxHDkuk55/G3xwnC0GqY4gmQ3j+A+g8kzzgB4Nk/SINjqn6+waqw3EgbVF2QKExkRxQ==
+
+vue-eslint-parser@^10.4.0:
+ version "10.4.0"
+ resolved "https://registry.yarnpkg.com/vue-eslint-parser/-/vue-eslint-parser-10.4.0.tgz#fd7251d0e710a88a6618f50e8a27973bc3c8d69c"
+ integrity sha512-Vxi9pJdbN3ZnVGLODVtZ7y4Y2kzAAE2Cm0CZ3ZDRvydVYxZ6VrnBhLikBsRS+dpwj4Jv4UCv21PTEwF5rQ9WXg==
+ dependencies:
+ debug "^4.4.0"
+ eslint-scope "^8.2.0 || ^9.0.0"
+ eslint-visitor-keys "^4.2.0 || ^5.0.0"
+ espree "^10.3.0 || ^11.0.0"
+ esquery "^1.6.0"
+ semver "^7.6.3"
+
+vue-router@^5.0.6:
+ version "5.0.6"
+ resolved "https://registry.yarnpkg.com/vue-router/-/vue-router-5.0.6.tgz#2c8e10bc6f37fd7f0992552258601e418778ddaf"
+ integrity sha512-9+kmUTGbKMyW9Asoy98IXXYIzrTMT7JDAdpDDeEkorHvybpUvBI2wsrSM5jFOXrFydpzRFJ9vAh+80DN2PGu9w==
+ dependencies:
+ "@babel/generator" "^7.28.6"
+ "@vue-macros/common" "^3.1.1"
+ "@vue/devtools-api" "^8.0.6"
+ ast-walker-scope "^0.8.3"
+ chokidar "^5.0.0"
+ json5 "^2.2.3"
+ local-pkg "^1.1.2"
+ magic-string "^0.30.21"
+ mlly "^1.8.0"
+ muggle-string "^0.4.1"
+ pathe "^2.0.3"
+ picomatch "^4.0.3"
+ scule "^1.3.0"
+ tinyglobby "^0.2.15"
+ unplugin "^3.0.0"
+ unplugin-utils "^0.3.1"
+ yaml "^2.8.2"
+
+vue-tsc@^3.2.7:
+ version "3.2.8"
+ resolved "https://registry.yarnpkg.com/vue-tsc/-/vue-tsc-3.2.8.tgz#92e6190f198b460c92b35f4f66eb791e374f0c01"
+ integrity sha512-27vTLJ6Q2370obOd0PFYoYoKnmXJ521uUIedrs3Zhhhg/8YG10VOCMmwt+JQslatpAMTDbnWiitLnoD5VlIvog==
+ dependencies:
+ "@volar/typescript" "2.4.28"
+ "@vue/language-core" "3.2.8"
+
+vue@^3.5.32:
+ version "3.5.34"
+ resolved "https://registry.yarnpkg.com/vue/-/vue-3.5.34.tgz#3b256eb30964416af6406a795fcfd7a5773a93c5"
+ integrity sha512-WdLBG9gm02OgJIG9axd5Hpx0TFLdzVgfG2evFFu8Rur5O/IoGc5cMjnjh3tPL6GnRGsYvUhBSKVPYVcxRKpMCA==
+ dependencies:
+ "@vue/compiler-dom" "3.5.34"
+ "@vue/compiler-sfc" "3.5.34"
+ "@vue/runtime-dom" "3.5.34"
+ "@vue/server-renderer" "3.5.34"
+ "@vue/shared" "3.5.34"
+
+webpack-virtual-modules@^0.6.2:
+ version "0.6.2"
+ resolved "https://registry.yarnpkg.com/webpack-virtual-modules/-/webpack-virtual-modules-0.6.2.tgz#057faa9065c8acf48f24cb57ac0e77739ab9a7e8"
+ integrity sha512-66/V2i5hQanC51vBQKPH4aI8NMAcBW59FVBs+rC7eGHupMyfn34q7rZIE+ETlJ+XTevqfUhVVBgSUNSW2flEUQ==
+
+which@^2.0.1:
+ version "2.0.2"
+ resolved "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1"
+ integrity sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==
+ dependencies:
+ isexe "^2.0.0"
+
+word-wrap@^1.2.5:
+ version "1.2.5"
+ resolved "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.5.tgz#d2c45c6dd4fbce621a66f136cbe328afd0410b34"
+ integrity sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==
+
+xml-name-validator@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.yarnpkg.com/xml-name-validator/-/xml-name-validator-4.0.0.tgz#79a006e2e63149a8600f15430f0a4725d1524835"
+ integrity sha512-ICP2e+jsHvAj2E2lIHxa5tjXRlKDJo4IdvPvCXbXQGdzSfmSpNVyIKMvoZHjDY9DP0zV17iI85o90vRFXNccRw==
+
+yaml-eslint-parser@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/yaml-eslint-parser/-/yaml-eslint-parser-2.0.0.tgz#8cb63e3e28787557b9f295df0a8307c327b7fde4"
+ integrity sha512-h0uDm97wvT2bokfwwTmY6kJ1hp6YDFL0nRHwNKz8s/VD1FH/vvZjAKoMUE+un0eaYBSG7/c6h+lJTP+31tjgTw==
+ dependencies:
+ eslint-visitor-keys "^5.0.0"
+ yaml "^2.0.0"
+
+yaml@^2.0.0, yaml@^2.8.2:
+ version "2.8.4"
+ resolved "https://registry.yarnpkg.com/yaml/-/yaml-2.8.4.tgz#4b5f411dd25f9544914d8673d4da7f29248e5e2e"
+ integrity sha512-ml/JPOj9fOQK8RNnWojA67GbZ0ApXAUlN2UQclwv2eVgTgn7O9gg9o7paZWKMp4g0H3nTLtS9LVzhkpOFIKzog==
+
+yocto-queue@^0.1.0:
+ version "0.1.0"
+ resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-0.1.0.tgz#0294eb3dee05028d31ee1a5fa2c556a6aaf10a1b"
+ integrity sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==
+
+zwitch@^2.0.0:
+ version "2.0.4"
+ resolved "https://registry.yarnpkg.com/zwitch/-/zwitch-2.0.4.tgz#c827d4b0acb76fc3e685a4c6ec2902d51070e9d7"
+ integrity sha512-bXE4cR/kVZhKZX/RjPEflHaKVhUVl85noU3v6b8apfQEc1x4A+zBxjZ4lN8LqGd6WZ3dl98pY4o717VFmoPp+A==
diff --git a/server/.zed/settings.json b/server/.zed/settings.json
new file mode 100644
index 0000000..60af096
--- /dev/null
+++ b/server/.zed/settings.json
@@ -0,0 +1,54 @@
+{
+ // Use ESLint's --fix:
+ "code_actions_on_format": {
+ "source.fixAll.eslint": true,
+ },
+ "formatter": [],
+ // Enable eslint for all supported languages
+ // Defaults only include https://github.com/search?q=repo%3Azed-industries%2Fzed%20eslint_languages&type=code
+ "languages": {
+ "HTML": {
+ "language_servers": ["...", "eslint"],
+ },
+ "Markdown": {
+ "language_servers": ["...", "eslint"],
+ },
+ "Markdown-Inline": {
+ "language_servers": ["...", "eslint"],
+ },
+ "JSON": {
+ "language_servers": ["...", "eslint"],
+ },
+ "JSONC": {
+ "language_servers": ["...", "eslint"],
+ },
+ "YAML": {
+ "language_servers": ["...", "eslint"],
+ },
+ "CSS": {
+ "language_servers": ["...", "eslint"],
+ },
+ // Add other languages as needed
+ },
+ "lsp": {
+ "eslint": {
+ "settings": {
+ "workingDirectories": ["./"],
+
+ // Silent the stylistic rules in your IDE, but still auto fix them
+ "rulesCustomizations": [
+ { "rule": "style/*", "severity": "off", "fixable": true },
+ { "rule": "format/*", "severity": "off", "fixable": true },
+ { "rule": "*-indent", "severity": "off", "fixable": true },
+ { "rule": "*-spacing", "severity": "off", "fixable": true },
+ { "rule": "*-spaces", "severity": "off", "fixable": true },
+ { "rule": "*-order", "severity": "off", "fixable": true },
+ { "rule": "*-dangle", "severity": "off", "fixable": true },
+ { "rule": "*-newline", "severity": "off", "fixable": true },
+ { "rule": "*quotes", "severity": "off", "fixable": true },
+ { "rule": "*semi", "severity": "off", "fixable": true },
+ ],
+ },
+ },
+ },
+}
diff --git a/server/Api.ts b/server/Api.ts
index bd60361..7f4256c 100644
--- a/server/Api.ts
+++ b/server/Api.ts
@@ -10,6 +10,167 @@
* ---------------------------------------------------------------
*/
+/**
+ * Attachment
+ * Attachment
+ */
+export interface Attachment {
+ id: string;
+ name: string;
+ mimetype: string;
+ /** @min 0 */
+ size: number;
+ /** @format date-time */
+ createdAt: string;
+}
+
+/**
+ * Channel
+ * Channel
+ */
+export interface Channel {
+ id: string;
+ ownerId: string | null;
+ name: string;
+ persistent: boolean;
+}
+
+/**
+ * ChatMessage
+ * ChatMessage
+ */
+export interface ChatMessage {
+ /** @format uuid */
+ id: string;
+ /** @format uuid */
+ senderId: string;
+ /** @minLength 1 */
+ text: string;
+ /** @format date-time */
+ createdAt: string;
+ /** @format date-time */
+ updatedAt: string;
+ attachments: string[];
+}
+
+/**
+ * CreateChannelPayload
+ * CreateChannelPayload
+ */
+export interface CreateChannelPayload {
+ name: string;
+ persistent: boolean;
+}
+
+/**
+ * CreateUser
+ * CreateUser
+ */
+export interface CreateUser {
+ /** @minLength 1 */
+ username: string;
+ /** @minLength 6 */
+ password: string;
+}
+
+/**
+ * GetAttachmentParams
+ * GetAttachmentParams
+ */
+export interface GetAttachmentParams {
+ /** @format uuid */
+ id: string;
+}
+
+/**
+ * GetUserQuery
+ * GetUserQuery
+ */
+export interface GetUserQuery {
+ username?: string;
+}
+
+/**
+ * Login
+ * Login
+ */
+export interface Login {
+ /** @minLength 1 */
+ username: string;
+ /** @minLength 1 */
+ password: string;
+}
+
+/**
+ * NewChatMessagePayload
+ * NewChatMessagePayload
+ */
+export interface NewChatMessagePayload {
+ /** @minLength 1 */
+ text: string;
+ attachments?: string[];
+}
+
+/**
+ * Reply
+ * Reply
+ */
+export interface Reply {
+ /** @format uuid */
+ messageId: string;
+ /** @format uuid */
+ senderId: string;
+ text: string;
+}
+
+/**
+ * ResponseError
+ * ResponseError
+ */
+export interface ResponseError {
+ statusCode: number;
+ error: string;
+ message: string;
+}
+
+/**
+ * UpdateUserPayload
+ * UpdateUserPayload
+ */
+export interface UpdateUserPayload {
+ displayName: string;
+}
+
+/**
+ * UpdateUserPreferencesPayload
+ * UpdateUserPreferencesPayload
+ */
+export interface UpdateUserPreferencesPayload {
+ toggleInputHotkey?: string;
+ toggleOutputHotkey?: string;
+}
+
+/**
+ * UserPreferences
+ * UserPreferences
+ */
+export interface UserPreferences {
+ toggleInputHotkey: string;
+ toggleOutputHotkey: string;
+}
+
+/**
+ * User
+ * User
+ */
+export interface User {
+ id: string;
+ username: string;
+ displayName: string;
+ /** @format date-time */
+ createdAt: string;
+}
+
export type QueryParamsType = Record;
export type ResponseFormat = keyof Omit;
@@ -282,14 +443,7 @@ export class Api<
* @request POST:/chad/attachment/upload
*/
attachmentUpload: (params: RequestParams = {}) =>
- this.request<
- string,
- {
- statusCode: number;
- error: string;
- message: string;
- }
- >({
+ this.request({
path: `/chad/attachment/upload`,
method: "POST",
format: "json",
@@ -305,14 +459,7 @@ export class Api<
* @request GET:/chad/attachment/{id}
*/
attachmentGet: (id: string, params: RequestParams = {}) =>
- this.request<
- any,
- {
- statusCode: number;
- error: string;
- message: string;
- }
- >({
+ this.request({
path: `/chad/attachment/${id}`,
method: "GET",
format: "json",
@@ -327,29 +474,8 @@ export class Api<
* @summary Register
* @request POST:/chad/auth/register
*/
- authRegister: (
- data: {
- /** @minLength 1 */
- username: string;
- /** @minLength 6 */
- password: string;
- },
- params: RequestParams = {},
- ) =>
- this.request<
- {
- id: string;
- username: string;
- displayName: string;
- /** @format date-time */
- createdAt: string;
- },
- {
- statusCode: number;
- error: string;
- message: string;
- }
- >({
+ authRegister: (data: CreateUser, params: RequestParams = {}) =>
+ this.request({
path: `/chad/auth/register`,
method: "POST",
body: data,
@@ -366,29 +492,8 @@ export class Api<
* @summary Login
* @request POST:/chad/auth/login
*/
- authLogin: (
- data: {
- /** @minLength 1 */
- username: string;
- /** @minLength 1 */
- password: string;
- },
- params: RequestParams = {},
- ) =>
- this.request<
- {
- id: string;
- username: string;
- displayName: string;
- /** @format date-time */
- createdAt: string;
- },
- {
- statusCode: number;
- error: string;
- message: string;
- }
- >({
+ authLogin: (data: Login, params: RequestParams = {}) =>
+ this.request({
path: `/chad/auth/login`,
method: "POST",
body: data,
@@ -406,20 +511,7 @@ export class Api<
* @request GET:/chad/auth/me
*/
authMe: (params: RequestParams = {}) =>
- this.request<
- {
- id: string;
- username: string;
- displayName: string;
- /** @format date-time */
- createdAt: string;
- },
- {
- statusCode: number;
- error: string;
- message: string;
- }
- >({
+ this.request({
path: `/chad/auth/me`,
method: "GET",
format: "json",
@@ -435,19 +527,61 @@ export class Api<
* @request POST:/chad/auth/logout
*/
authLogout: (params: RequestParams = {}) =>
- this.request<
- any,
- {
- statusCode: number;
- error: string;
- message: string;
- }
- >({
+ this.request({
path: `/chad/auth/logout`,
method: "POST",
...params,
}),
+ /**
+ * No description
+ *
+ * @tags Channel
+ * @name ChannelList
+ * @summary Get channel list
+ * @request GET:/chad/channels
+ */
+ channelList: (params: RequestParams = {}) =>
+ this.request({
+ path: `/chad/channels`,
+ method: "GET",
+ format: "json",
+ ...params,
+ }),
+
+ /**
+ * No description
+ *
+ * @tags Channel
+ * @name ChannelCreate
+ * @summary Create channel
+ * @request POST:/chad/channels
+ */
+ channelCreate: (data: CreateChannelPayload, params: RequestParams = {}) =>
+ this.request({
+ path: `/chad/channels`,
+ method: "POST",
+ body: data,
+ type: ContentType.Json,
+ format: "json",
+ ...params,
+ }),
+
+ /**
+ * No description
+ *
+ * @tags Channel
+ * @name ChannelDelete
+ * @summary Delete channel
+ * @request DELETE:/chad/channels/{id}
+ */
+ channelDelete: (id: string, params: RequestParams = {}) =>
+ this.request({
+ path: `/chad/channels/${id}`,
+ method: "DELETE",
+ ...params,
+ }),
+
/**
* No description
*
@@ -460,6 +594,7 @@ export class Api<
data: {
/** @minLength 1 */
text: string;
+ attachments?: string[];
},
params: RequestParams = {},
) =>
@@ -475,12 +610,9 @@ export class Api<
createdAt: string;
/** @format date-time */
updatedAt: string;
+ attachments: string[];
},
- {
- statusCode: number;
- error: string;
- message: string;
- }
+ ResponseError
>({
path: `/chad/chat/send`,
method: "POST",
@@ -508,7 +640,7 @@ export class Api<
/**
* @min 1
* @max 100
- * @default 2
+ * @default 10
*/
limit: number;
},
@@ -527,6 +659,7 @@ export class Api<
createdAt: string;
/** @format date-time */
updatedAt: string;
+ attachments: string[];
}[];
/**
* Cursor to last message
@@ -534,11 +667,7 @@ export class Api<
*/
nextCursor?: string;
},
- {
- statusCode: number;
- error: string;
- message: string;
- }
+ ResponseError
>({
path: `/chad/chat`,
method: "GET",
@@ -561,20 +690,7 @@ export class Api<
},
params: RequestParams = {},
) =>
- this.request<
- {
- id: string;
- username: string;
- displayName: string;
- /** @format date-time */
- createdAt: string;
- },
- {
- statusCode: number;
- error: string;
- message: string;
- }
- >({
+ this.request({
path: `/chad/user`,
method: "GET",
query: query,
@@ -591,17 +707,7 @@ export class Api<
* @request GET:/chad/user/preferences
*/
userGetPreferences: (params: RequestParams = {}) =>
- this.request<
- {
- toggleInputHotkey: string;
- toggleOutputHotkey: string;
- },
- {
- statusCode: number;
- error: string;
- message: string;
- }
- >({
+ this.request({
path: `/chad/user/preferences`,
method: "GET",
format: "json",
@@ -617,20 +723,10 @@ export class Api<
* @request PATCH:/chad/user/preferences
*/
userUpdatePreferences: (
- data: {
- toggleInputHotkey?: string;
- toggleOutputHotkey?: string;
- },
+ data: UpdateUserPreferencesPayload,
params: RequestParams = {},
) =>
- this.request<
- any,
- {
- statusCode: number;
- error: string;
- message: string;
- }
- >({
+ this.request({
path: `/chad/user/preferences`,
method: "PATCH",
body: data,
@@ -646,26 +742,8 @@ export class Api<
* @summary Update profile
* @request PATCH:/chad/profile
*/
- userUpdateProfile: (
- data: {
- displayName: string;
- },
- params: RequestParams = {},
- ) =>
- this.request<
- {
- id: string;
- username: string;
- displayName: string;
- /** @format date-time */
- createdAt: string;
- },
- {
- statusCode: number;
- error: string;
- message: string;
- }
- >({
+ userUpdateProfile: (data: UpdateUserPayload, params: RequestParams = {}) =>
+ this.request({
path: `/chad/profile`,
method: "PATCH",
body: data,
diff --git a/server/nodemon.json b/server/nodemon.json
index 739cf7f..580ca86 100644
--- a/server/nodemon.json
+++ b/server/nodemon.json
@@ -2,5 +2,5 @@
"watch": ["."],
"ext": ".ts,.js",
"ignore": ["node_modules", ".idea", "dist"],
- "exec": "ts-node --transpile-only server.ts"
+ "exec": ""
}
\ No newline at end of file
diff --git a/server/package.json b/server/package.json
index 3664657..0208c22 100644
--- a/server/package.json
+++ b/server/package.json
@@ -1,12 +1,15 @@
{
"name": "server",
+ "type": "module",
+ "packageManager": "yarn@4.10.3",
+ "engines": {
+ "node": ">=22.18.0"
+ },
"scripts": {
"dev": "nodemon",
"start": "ts-node --transpile-only server.ts",
"db:deploy": "npx prisma migrate deploy && npx prisma generate"
},
- "type": "module",
- "packageManager": "yarn@4.10.3",
"dependencies": {
"@fastify/autoload": "^6.3.1",
"@fastify/cookie": "^11.0.2",
@@ -25,7 +28,7 @@
"fastify": "^5.6.1",
"fastify-plugin": "^5.1.0",
"lucia": "^3.2.2",
- "mediasoup": "^3.19.3",
+ "mediasoup": "^3.19.21",
"prisma": "7",
"socket.io": "^4.8.1",
"typebox": "^1.1.27",
@@ -42,8 +45,5 @@
"nodemon": "^3.1.14",
"ts-node": "^10.9.2",
"typescript": "^5.9.3"
- },
- "engines": {
- "node": ">=22.18.0"
}
}
diff --git a/server/plugins/event-bus.ts b/server/plugins/event-bus.ts
index c2d05b8..6886abd 100644
--- a/server/plugins/event-bus.ts
+++ b/server/plugins/event-bus.ts
@@ -1,7 +1,8 @@
import type { FastifyPluginAsync } from 'fastify'
import type { Type } from 'typebox'
-import type { UserSchema } from '../schemas/auth.ts'
-import type { ChatMessageSchema } from '../schemas/chat.ts'
+import type { Channel } from '../prisma/generated-client/client.ts'
+import type { UserSchema } from './schemas/auth.ts'
+import type { ChatMessageSchema } from './schemas/chat.ts'
import { EventEmitter } from 'node:events'
import fp from 'fastify-plugin'
@@ -14,6 +15,8 @@ declare module 'fastify' {
interface EventMap {
'chat:new-message': [Type.Static]
'user:profile-updated': [Type.Static]
+ 'channel:created': [Channel]
+ 'channel:removed': [Channel]
}
const plugin: FastifyPluginAsync = fp(async (fastify) => {
diff --git a/server/plugins/mediasoup-router.ts b/server/plugins/mediasoup-router.ts
index 784f967..ba5cc11 100644
--- a/server/plugins/mediasoup-router.ts
+++ b/server/plugins/mediasoup-router.ts
@@ -27,20 +27,9 @@ export const autoConfig: mediasoup.types.RouterOptions = {
},
{
kind: 'video',
- mimeType: 'video/VP8',
+ mimeType: 'video/AV1',
clockRate: 90000,
- parameters: {
- 'x-google-start-bitrate': 1000,
- },
- },
- {
- kind: 'video',
- mimeType: 'video/VP9',
- clockRate: 90000,
- parameters: {
- 'profile-id': 2,
- 'x-google-start-bitrate': 1000,
- },
+ parameters: {},
},
{
kind: 'video',
@@ -66,9 +55,20 @@ export const autoConfig: mediasoup.types.RouterOptions = {
},
{
kind: 'video',
- mimeType: 'video/AV1',
+ mimeType: 'video/VP8',
clockRate: 90000,
- parameters: {},
+ parameters: {
+ 'x-google-start-bitrate': 1000,
+ },
+ },
+ {
+ kind: 'video',
+ mimeType: 'video/VP9',
+ clockRate: 90000,
+ parameters: {
+ 'profile-id': 2,
+ 'x-google-start-bitrate': 1000,
+ },
},
],
}
diff --git a/server/plugins/mediasoup-worker.ts b/server/plugins/mediasoup-worker.ts
index cbb42e5..eab12c7 100644
--- a/server/plugins/mediasoup-worker.ts
+++ b/server/plugins/mediasoup-worker.ts
@@ -11,6 +11,7 @@ declare module 'fastify' {
export default fp(
async (fastify) => {
const worker = await mediasoup.createWorker()
+
worker.on('died', () => {
consola.error('[Mediasoup]', 'Worker died, exiting...')
diff --git a/server/plugins/prisma.ts b/server/plugins/prisma.ts
index 2a6e89b..ec6fc50 100644
--- a/server/plugins/prisma.ts
+++ b/server/plugins/prisma.ts
@@ -11,7 +11,7 @@ declare module 'fastify' {
const plugin: FastifyPluginAsync = fp(async (fastify) => {
const prisma = new PrismaClient({
- log: ['query', 'error', 'warn'],
+ log: ['error'],
adapter: new PrismaBetterSqlite3({
url: process.env.DATABASE_URL!,
}),
diff --git a/server/plugins/schemas.ts b/server/plugins/schemas.ts
new file mode 100644
index 0000000..645bc45
--- /dev/null
+++ b/server/plugins/schemas.ts
@@ -0,0 +1,11 @@
+import type { FastifyPluginAsync } from 'fastify'
+import fp from 'fastify-plugin'
+import * as schemas from './schemas/index.ts'
+
+const plugin: FastifyPluginAsync = fp(async (fastify) => {
+ for (const schema of Object.values(schemas)) {
+ fastify.addSchema(schema)
+ }
+})
+
+export default plugin
diff --git a/server/schemas/attachment.ts b/server/plugins/schemas/attachment.ts
similarity index 60%
rename from server/schemas/attachment.ts
rename to server/plugins/schemas/attachment.ts
index 25bdf36..805b12e 100644
--- a/server/schemas/attachment.ts
+++ b/server/plugins/schemas/attachment.ts
@@ -6,6 +6,8 @@ export const AttachmentSchema = Type.Object({
mimetype: Type.String(),
size: Type.Number({ minimum: 0 }),
createdAt: Type.String({ format: 'date-time' }),
+}, { $id: 'Attachment' })
- // message: Type.MessageAttachment(),
-}, { title: 'Attachment', description: 'Attachment' })
+export const GetAttachmentParamsSchema = Type.Object({
+ id: Type.String({ format: 'uuid' }),
+}, { $id: 'GetAttachmentParams' })
diff --git a/server/schemas/auth.ts b/server/plugins/schemas/auth.ts
similarity index 53%
rename from server/schemas/auth.ts
rename to server/plugins/schemas/auth.ts
index 84a86a1..45071a2 100644
--- a/server/schemas/auth.ts
+++ b/server/plugins/schemas/auth.ts
@@ -5,9 +5,14 @@ export const UserSchema = Type.Object({
username: Type.String(),
displayName: Type.String(),
createdAt: Type.String({ format: 'date-time' }),
-}, { title: 'User', description: 'User' })
+}, { $id: 'User' })
-export const CreateUserSchema = Type.Object({
+export const CreateUserPayloadSchema = Type.Object({
username: Type.String({ minLength: 1 }),
password: Type.String({ minLength: 6 }),
-}, { title: 'CreateUser' })
+}, { $id: 'CreateUser' })
+
+export const LoginPayloadSchema = Type.Object({
+ username: Type.String({ minLength: 1 }),
+ password: Type.String({ minLength: 1 }),
+}, { $id: 'Login' })
diff --git a/server/plugins/schemas/channel.ts b/server/plugins/schemas/channel.ts
new file mode 100644
index 0000000..fb55435
--- /dev/null
+++ b/server/plugins/schemas/channel.ts
@@ -0,0 +1,13 @@
+import { Type } from 'typebox'
+
+export const ChannelSchema = Type.Object({
+ id: Type.String(),
+ ownerId: Type.Union([Type.String(), Type.Null()]),
+ name: Type.String(),
+ persistent: Type.Boolean(),
+}, { $id: 'Channel' })
+
+export const CreateChannelPayloadSchema = Type.Object({
+ name: Type.String(),
+ persistent: Type.Boolean(),
+}, { $id: 'CreateChannelPayload' })
diff --git a/server/schemas/chat.ts b/server/plugins/schemas/chat.ts
similarity index 74%
rename from server/schemas/chat.ts
rename to server/plugins/schemas/chat.ts
index 2b2da65..5a97ddb 100644
--- a/server/schemas/chat.ts
+++ b/server/plugins/schemas/chat.ts
@@ -4,7 +4,7 @@ export const ReplySchema = Type.Object({
messageId: Type.String({ format: 'uuid' }),
senderId: Type.String({ format: 'uuid' }),
text: Type.String(),
-}, { title: 'Reply', description: 'Reply' })
+}, { $id: 'Reply' })
export const ChatMessageSchema = Type.Object({
id: Type.String({ format: 'uuid' }),
@@ -14,13 +14,12 @@ export const ChatMessageSchema = Type.Object({
updatedAt: Type.String({ format: 'date-time' }),
attachments: Type.Array(Type.String({ format: 'uuid' })),
- // replyTo: ReplySchema,
-}, { title: 'ChatMessage', description: 'ChatMessage' })
+}, { $id: 'ChatMessage' })
-export const NewChatMessageSchema = Type.Object({
+export const NewChatMessagePayloadSchema = Type.Object({
text: Type.String({ minLength: 1 }),
attachments: Type.Optional(Type.Array(Type.String({ format: 'uuid' }))),
// replyTo: Type.Object({
// messageId: Type.String({ format: 'uuid' }),
// }),
-}, { title: 'NewChatMessage', description: 'NewChatMessage' })
+}, { $id: 'NewChatMessagePayload' })
diff --git a/server/schemas/common.ts b/server/plugins/schemas/common.ts
similarity index 50%
rename from server/schemas/common.ts
rename to server/plugins/schemas/common.ts
index 141197d..c255d14 100644
--- a/server/schemas/common.ts
+++ b/server/plugins/schemas/common.ts
@@ -1,7 +1,7 @@
import { Type } from 'typebox'
-export const ErrorReplySchema = Type.Object({
+export const ResponseErrorSchema = Type.Object({
statusCode: Type.Number(),
error: Type.String(),
message: Type.String(),
-}, { title: 'ResponseError', description: 'Response Error' })
+}, { $id: 'ResponseError' })
diff --git a/server/plugins/schemas/index.ts b/server/plugins/schemas/index.ts
new file mode 100644
index 0000000..7e6d9cd
--- /dev/null
+++ b/server/plugins/schemas/index.ts
@@ -0,0 +1,6 @@
+export * from './attachment.ts'
+export * from './auth.ts'
+export * from './channel.ts'
+export * from './chat.ts'
+export * from './common.ts'
+export * from './user.ts'
diff --git a/server/plugins/schemas/user.ts b/server/plugins/schemas/user.ts
new file mode 100644
index 0000000..10c7130
--- /dev/null
+++ b/server/plugins/schemas/user.ts
@@ -0,0 +1,19 @@
+import { Type } from 'typebox'
+
+export const GetUserQuerySchema = Type.Partial(Type.Object({
+ username: Type.String(),
+}), { $id: 'GetUserQuery' })
+
+export const UserPreferencesSchema = Type.Object({
+ toggleInputHotkey: Type.String(),
+ toggleOutputHotkey: Type.String(),
+}, { $id: 'UserPreferences' })
+
+export const UpdateUserPreferencesPayloadSchema = Type.Partial(
+ UserPreferencesSchema,
+ { $id: 'UpdateUserPreferencesPayload' },
+)
+
+export const UpdateUserPayloadSchema = Type.Object({
+ displayName: Type.String(),
+}, { $id: 'UpdateUserPayload' })
diff --git a/server/plugins/socket.ts b/server/plugins/socket.ts
index e6265c9..e80b709 100644
--- a/server/plugins/socket.ts
+++ b/server/plugins/socket.ts
@@ -1,10 +1,9 @@
import type { FastifyInstance } from 'fastify'
import type { ServerOptions } from 'socket.io'
-import type { MessageSelect } from '../prisma/generated-client/models/Message.ts'
import fp from 'fastify-plugin'
import { Server } from 'socket.io'
-import registerChatSocket from '../socket/chat.ts'
-import registerWebrtcSocket from '../socket/webrtc.ts'
+import registerChatSocket from './socket/chat/index.ts'
+import registerWebrtcSocket from './socket/webrtc/index.ts'
declare module 'fastify' {
interface FastifyInstance {
@@ -24,12 +23,26 @@ export default fp>(
await fastify.io.close()
})
- await registerWebrtcSocket(fastify.io, fastify.mediasoupRouter, fastify.prisma)
- await registerChatSocket(fastify.io)
+ fastify.io.use(async (socket, next) => {
+ const sessionId = fastify.lucia.readSessionCookie(socket.handshake.headers.cookie ?? '')
- fastify.bus.on('chat:new-message', async (message: MessageSelect) => {
- fastify.io.emit('chat:new-message', message)
+ if (!sessionId) {
+ return next(fastify.httpErrors.unauthorized())
+ }
+
+ const { user } = await fastify.lucia.validateSession(sessionId)
+
+ if (!user) {
+ return next(fastify.httpErrors.unauthorized())
+ }
+
+ socket.data.user = user
+
+ next()
})
+
+ await registerWebrtcSocket(fastify)
+ await registerChatSocket(fastify)
},
{ name: 'socket-io', dependencies: ['mediasoup-worker', 'mediasoup-router', 'prisma', 'event-bus'] },
)
diff --git a/server/plugins/socket/chat/index.ts b/server/plugins/socket/chat/index.ts
new file mode 100644
index 0000000..3820309
--- /dev/null
+++ b/server/plugins/socket/chat/index.ts
@@ -0,0 +1,10 @@
+import type { FastifyInstance } from 'fastify'
+import type { MessageSelect } from '../../../prisma/generated-client/models.ts'
+
+export default async function (fastify: FastifyInstance) {
+ const { io, bus } = fastify
+
+ bus.on('chat:new-message', async (message: MessageSelect) => {
+ io.emit('chat:new-message', message)
+ })
+}
diff --git a/server/plugins/socket/types.ts b/server/plugins/socket/types.ts
new file mode 100644
index 0000000..84573ef
--- /dev/null
+++ b/server/plugins/socket/types.ts
@@ -0,0 +1,136 @@
+import type { types } from 'mediasoup'
+import type { Server, Socket } from 'socket.io'
+import type { Channel, User } from '../../prisma/generated-client/client.ts'
+
+export interface SerializedClient {
+ socketId: string
+ userId: User['id']
+ channelId: Channel['id']
+ inputMuted: boolean
+ outputMuted: boolean
+ streaming: boolean
+}
+
+export interface ProducerAppData extends types.AppData {
+ source: 'mic-video' | 'share'
+}
+
+export interface ErrorCallbackResult {
+ error: string
+}
+
+export interface SuccessCallbackResult {
+ ok: true
+}
+
+export type EventCallback = (result: T | ErrorCallbackResult) => void
+
+export interface ClientToServerEvents {
+ 'join-channel': (
+ options: { channelId: string },
+ cb?: EventCallback
+ ) => void
+ 'create-transport': (
+ options: {
+ producing: boolean
+ consuming: boolean
+ },
+ cb: EventCallback>
+ ) => void
+ 'connect-transport': (
+ options: {
+ transportId: types.WebRtcTransport['id']
+ dtlsParameters: types.WebRtcTransport['dtlsParameters']
+ },
+ cb: EventCallback
+ ) => void
+ 'produce': (
+ options: {
+ transportId: types.WebRtcTransport['id']
+ kind: types.MediaKind
+ rtpParameters: types.RtpParameters
+ appData: { source: 'share' | string }
+ },
+ cb: EventCallback<{ id: types.Producer['id'] }>
+ ) => void
+ 'close-producer': (
+ options: {
+ producerId: types.Producer['id']
+ },
+ cb: EventCallback
+ ) => void
+ 'pause-producer': (
+ options: {
+ producerId: types.Producer['id']
+ },
+ cb: EventCallback
+ ) => void
+ 'resume-producer': (
+ options: {
+ producerId: types.Producer['id']
+ },
+ cb: EventCallback
+ ) => void
+ 'pause-consumer': (
+ options: {
+ consumerId: types.Consumer['id']
+ },
+ cb: EventCallback
+ ) => void
+ 'resume-consumer': (
+ options: {
+ consumerId: types.Consumer['id']
+ },
+ cb: EventCallback
+ ) => void
+ 'update-client': (
+ options: Partial>,
+ cb: EventCallback
+ ) => void
+}
+
+export interface ServerToClientEvents {
+ 'initialized': (arg: {
+ rtpCapabilities: types.RtpCapabilities
+ channelId: string
+ clients: SerializedClient[]
+ }) => void
+ 'new-client': (arg: SerializedClient) => void
+ 'client-updated': (arg: SerializedClient) => void
+ 'client-switched-channel': (arg: SerializedClient) => void
+ 'client-disconnected': (arg: string) => void
+ 'producers': (arg: {
+ producerId: types.Producer['id']
+ kind: types.MediaKind
+ }[]) => void
+ 'new-consumer': (
+ arg: {
+ socketId: string
+ producerId: types.Producer['id']
+ id: types.Consumer['id']
+ kind: types.MediaKind
+ rtpParameters: types.RtpParameters
+ type: types.ConsumerType
+ appData: types.Producer['appData']
+ producerPaused: types.Consumer['producerPaused']
+ },
+ cb: EventCallback
+ ) => void
+ 'consumer-closed': (arg: { consumerId: string }) => void
+ 'consumer-paused': (arg: { consumerId: string }) => void
+ 'consumer-resumed': (arg: { consumerId: string }) => void
+ 'speaking-clients': (arg: { clientId: SerializedClient['socketId'], volume: types.AudioLevelObserverVolume['volume'] }[]) => void
+ 'active-speaker': (arg?: SerializedClient['socketId']) => void
+ 'channel-created': (arg: Channel) => void
+ 'channel-removed': (arg: Channel['id']) => void
+ 'channel-updated': (arg: Channel) => void
+}
+
+export interface InterServerEvent {}
+
+export interface SocketData {
+ user: User
+}
+
+export type ChadSocket = Socket
+export type ChadSocketServer = Server
diff --git a/server/plugins/socket/webrtc/Channel.ts b/server/plugins/socket/webrtc/Channel.ts
new file mode 100644
index 0000000..522190e
--- /dev/null
+++ b/server/plugins/socket/webrtc/Channel.ts
@@ -0,0 +1,119 @@
+import type { types } from 'mediasoup'
+import type { ActiveSpeakerObserverDominantSpeaker } from 'mediasoup/types'
+import type { Client } from './Client.ts'
+import { EventEmitter } from 'node:events'
+
+interface ChannelEvents {
+ 'speaking-peers': [{
+ socketId: string
+ volume: number
+ }[]]
+ 'silence': []
+ 'active-speaker': [socketId: string]
+ 'empty': []
+}
+
+export class Channel extends EventEmitter {
+ readonly id: string
+ readonly persistent: boolean
+ readonly #audioLevelObserver: types.AudioLevelObserver
+ readonly #activeSpeakerObserver: types.ActiveSpeakerObserver
+ readonly #clients = new Map()
+
+ private constructor(
+ id: string,
+ persistent: boolean,
+ audioLevelObserver: types.AudioLevelObserver,
+ activeSpeakerObserver: types.ActiveSpeakerObserver,
+ ) {
+ super()
+
+ this.id = id
+ this.persistent = persistent
+ this.#audioLevelObserver = audioLevelObserver
+ this.#activeSpeakerObserver = activeSpeakerObserver
+
+ this.#audioLevelObserver.on('volumes', (volumes: types.AudioLevelObserverVolume[]) => {
+ this.emit('speaking-peers', volumes.map(({ producer, volume }) => {
+ const { socketId } = producer.appData as { socketId: string }
+ return { socketId, volume }
+ }))
+ })
+
+ this.#audioLevelObserver.on('silence', () => {
+ this.emit('silence')
+ })
+
+ this.#activeSpeakerObserver.on('dominantspeaker', ({ producer }: ActiveSpeakerObserverDominantSpeaker) => {
+ const { socketId } = producer.appData as { socketId: string }
+ this.emit('active-speaker', socketId)
+ })
+ }
+
+ static async create(id: string, persistent: boolean, router: types.Router): Promise {
+ const audioLevelObserver = await router.createAudioLevelObserver({
+ maxEntries: 10,
+ threshold: -80,
+ interval: 800,
+ })
+
+ const activeSpeakerObserver = await router.createActiveSpeakerObserver()
+
+ return new Channel(id, persistent, audioLevelObserver, activeSpeakerObserver)
+ }
+
+ get clients(): Client[] {
+ return Array.from(this.#clients.values())
+ }
+
+ get size(): number {
+ return this.#clients.size
+ }
+
+ getClient(socketId: string): Client | undefined {
+ return this.#clients.get(socketId)
+ }
+
+ addClient(client: Client): void {
+ client.channelId = this.id
+ this.#clients.set(client.socketId, client)
+ }
+
+ kickClient(client: Client): void {
+ this.#clients.delete(client.socketId)
+
+ if (this.#clients.size === 0)
+ this.emit('empty')
+ }
+
+ async addAudioProducer(producer: types.Producer): Promise {
+ if (producer.kind !== 'audio')
+ return
+
+ await this.#audioLevelObserver.addProducer({ producerId: producer.id })
+ await this.#activeSpeakerObserver.addProducer({ producerId: producer.id })
+ }
+
+ async wireClient(client: Client): Promise {
+ for (const otherClient of this.#clients.values()) {
+ if (otherClient.socketId === client.socketId)
+ continue
+
+ for (const producer of otherClient.producers.values()) {
+ await client.createConsumerFor(producer, otherClient.socketId)
+ }
+
+ for (const producer of client.producers.values()) {
+ await otherClient.createConsumerFor(producer, client.socketId)
+ }
+ }
+ }
+
+ unwireClient(client: Client): void {
+ for (const otherClient of this.#clients.values()) {
+ for (const producerId of client.producers.keys()) {
+ otherClient.removeConsumersOf(producerId)
+ }
+ }
+ }
+}
diff --git a/server/plugins/socket/webrtc/ChannelManager.ts b/server/plugins/socket/webrtc/ChannelManager.ts
new file mode 100644
index 0000000..4e3d347
--- /dev/null
+++ b/server/plugins/socket/webrtc/ChannelManager.ts
@@ -0,0 +1,33 @@
+import type { Router } from 'mediasoup/types'
+import type { Channel as DbChannel } from '../../../prisma/generated-client/client.ts'
+import { Channel } from './Channel.ts'
+
+export class ChannelManager {
+ private channels = new Map()
+ private mediasoupRouter: Router
+
+ constructor(mediasoupRouter: Router) {
+ this.mediasoupRouter = mediasoupRouter
+ }
+
+ async create(newChannel: Channel | DbChannel) {
+ if (newChannel instanceof Channel) {
+ this.channels.set(newChannel.id, newChannel)
+ }
+ else {
+ this.channels.set(newChannel.id, await Channel.create(newChannel.id, newChannel.persistent, this.mediasoupRouter))
+ }
+ }
+
+ get(id: string) {
+ return this.channels.get(id)
+ }
+
+ delete(id: string) {
+ this.channels.delete(id)
+ }
+
+ get all() {
+ return Array.from(this.channels.values())
+ }
+}
diff --git a/server/plugins/socket/webrtc/Client.ts b/server/plugins/socket/webrtc/Client.ts
new file mode 100644
index 0000000..c5665a3
--- /dev/null
+++ b/server/plugins/socket/webrtc/Client.ts
@@ -0,0 +1,288 @@
+import type { types } from 'mediasoup'
+import type { SerializedClient } from '../types.ts'
+import { EventEmitter } from 'node:events'
+import { consola } from 'consola'
+
+export interface NewConsumerSignal {
+ socketId: string
+ producerId: string
+ id: string
+ kind: types.MediaKind
+ rtpParameters: types.RtpParameters
+ type: types.ConsumerType
+ appData: types.Producer['appData']
+ producerPaused: boolean
+}
+
+interface ClientEvents {
+ 'signal:new-consumer': [data: NewConsumerSignal, onAcked: () => Promise]
+ 'consumer:closed': [consumerId: string]
+ 'consumer:paused': [consumerId: string]
+ 'consumer:resumed': [consumerId: string]
+ 'transport:closed': []
+ 'closed': []
+ 'updated': []
+}
+
+export class Client extends EventEmitter {
+ readonly socketId: string
+ readonly userId: string
+
+ channelId: string = ''
+ #inputMuted = false
+ #outputMuted = false
+
+ readonly #router: types.Router
+
+ readonly #transports = new Map()
+ readonly #producers = new Map()
+ readonly #consumers = new Map()
+
+ constructor(socketId: string, userId: string, router: types.Router) {
+ super()
+
+ this.socketId = socketId
+ this.userId = userId
+ this.#router = router
+ }
+
+ get producers(): ReadonlyMap { return this.#producers }
+ get consumers(): ReadonlyMap { return this.#consumers }
+ get transports(): ReadonlyMap { return this.#transports }
+ get inputMuted(): boolean { return this.#inputMuted }
+ get outputMuted(): boolean { return this.#outputMuted }
+ get streaming(): boolean {
+ return Array.from(this.#producers.values()).some(
+ producer => producer.kind === 'video' && producer.appData.source === 'share',
+ )
+ }
+
+ async createTransport(options: { producing: boolean, consuming: boolean }) {
+ const transport = await this.#router.createWebRtcTransport({
+ listenInfos: [{
+ protocol: 'udp',
+ ip: '0.0.0.0',
+ announcedAddress: process.env.ANNOUNCED_ADDRESS || '127.0.0.1',
+ portRange: { min: 40000, max: 40100 },
+ }],
+ enableUdp: true,
+ preferUdp: true,
+ appData: options,
+ })
+
+ this.#transports.set(transport.id, transport)
+
+ transport.on('icestatechange', (iceState: types.IceState) => {
+ if (iceState === 'disconnected' || iceState === 'closed') {
+ consola.info('[Client]', `[${this.socketId}]`, `iceState=${iceState}`)
+ this.emit('transport:closed')
+ }
+ })
+
+ transport.on('dtlsstatechange', (dtlsState: types.DtlsState) => {
+ if (dtlsState === 'failed' || dtlsState === 'closed') {
+ consola.warn('[Client]', `[${this.socketId}]`, `dtlsState=${dtlsState}`)
+ this.emit('transport:closed')
+ }
+ })
+
+ return {
+ id: transport.id,
+ iceParameters: transport.iceParameters,
+ iceCandidates: transport.iceCandidates,
+ dtlsParameters: transport.dtlsParameters,
+ }
+ }
+
+ async connectTransport(transportId: string, dtlsParameters: types.DtlsParameters): Promise {
+ const transport = this.#transports.get(transportId)
+
+ if (!transport)
+ throw new Error(`Transport not found: ${transportId}`)
+
+ await transport.connect({ dtlsParameters })
+ }
+
+ async produce(
+ transportId: string,
+ kind: types.MediaKind,
+ rtpParameters: types.RtpParameters,
+ appData: object,
+ ): Promise {
+ const transport = this.#transports.get(transportId)
+ if (!transport)
+ throw new Error(`Transport not found: ${transportId}`)
+
+ const streamingBefore = this.streaming
+
+ const producer = await transport.produce({
+ kind,
+ rtpParameters,
+ appData: { ...appData, socketId: this.socketId },
+ })
+
+ this.#producers.set(producer.id, producer)
+
+ if (this.streaming !== streamingBefore)
+ this.emit('updated')
+
+ return producer
+ }
+
+ closeProducer(producerId: string): void {
+ const producer = this.#producers.get(producerId)
+
+ if (!producer)
+ throw new Error(`Producer not found: ${producerId}`)
+
+ const streamingBefore = this.streaming
+ producer.close()
+ this.#producers.delete(producerId)
+
+ if (this.streaming !== streamingBefore)
+ this.emit('updated')
+ }
+
+ async pauseProducer(producerId: string): Promise {
+ const producer = this.#producers.get(producerId)
+
+ if (!producer)
+ throw new Error(`Producer not found: ${producerId}`)
+
+ if (!producer.paused)
+ await producer.pause()
+ }
+
+ async resumeProducer(producerId: string): Promise {
+ const producer = this.#producers.get(producerId)
+
+ if (!producer)
+ throw new Error(`Producer not found: ${producerId}`)
+
+ await producer.resume()
+ }
+
+ async createConsumerFor(producer: types.Producer, producerSocketId: string): Promise {
+ const transport = Array.from(this.#transports.values()).find(t => t.appData.consuming)
+
+ if (!transport) {
+ consola.warn('[Client]', `[${this.socketId}]`, 'No consuming transport, skipping consumer creation')
+ return null
+ }
+
+ try {
+ const consumer = await transport.consume({
+ producerId: producer.id,
+ rtpCapabilities: this.#router.rtpCapabilities,
+ enableRtx: true,
+ paused: true,
+ ignoreDtx: true,
+ })
+
+ this.#consumers.set(consumer.id, consumer)
+
+ consumer.observer.on('close', () => {
+ this.#consumers.delete(consumer.id)
+ this.emit('consumer:closed', consumer.id)
+ })
+
+ consumer.on('transportclose', () => {
+ consumer.close()
+ })
+
+ consumer.on('producerclose', () => {
+ consumer.close()
+ })
+
+ consumer.on('producerpause', () => {
+ this.emit('consumer:paused', consumer.id)
+ })
+
+ consumer.on('producerresume', () => {
+ this.emit('consumer:resumed', consumer.id)
+ })
+
+ await new Promise((resolve) => {
+ this.emit('signal:new-consumer', {
+ socketId: producerSocketId,
+ producerId: producer.id,
+ id: consumer.id,
+ kind: consumer.kind,
+ rtpParameters: consumer.rtpParameters,
+ type: consumer.type,
+ appData: producer.appData,
+ producerPaused: consumer.producerPaused,
+ }, async () => { resolve() })
+ })
+
+ await consumer.resume()
+
+ return consumer
+ }
+ catch (error) {
+ consola.error('[Client]', `[${this.socketId}]`, 'createConsumerFor() failed:', error)
+ return null
+ }
+ }
+
+ removeConsumersOf(producerId: string): void {
+ for (const consumer of this.#consumers.values()) {
+ if (consumer.producerId === producerId)
+ consumer.close()
+ }
+ }
+
+ clearConsumers(): void {
+ for (const consumer of this.#consumers.values()) {
+ consumer.close()
+ }
+
+ this.#consumers.clear()
+ }
+
+ async pauseConsumer(consumerId: string): Promise {
+ const consumer = this.#consumers.get(consumerId)
+
+ if (!consumer)
+ throw new Error(`Consumer not found: ${consumerId}`)
+
+ await consumer.pause()
+ }
+
+ async resumeConsumer(consumerId: string): Promise {
+ const consumer = this.#consumers.get(consumerId)
+
+ if (!consumer)
+ throw new Error(`Consumer not found: ${consumerId}`)
+
+ await consumer.resume()
+ }
+
+ update(patch: { inputMuted?: boolean, outputMuted?: boolean }): void {
+ if (typeof patch.inputMuted === 'boolean')
+ this.#inputMuted = patch.inputMuted
+ if (typeof patch.outputMuted === 'boolean')
+ this.#outputMuted = patch.outputMuted
+
+ this.emit('updated')
+ }
+
+ close(): void {
+ for (const transport of this.#transports.values()) {
+ transport.close()
+ }
+
+ this.emit('closed')
+ }
+
+ serialize(): SerializedClient {
+ return {
+ socketId: this.socketId,
+ userId: this.userId,
+ channelId: this.channelId,
+ inputMuted: this.#inputMuted,
+ outputMuted: this.#outputMuted,
+ streaming: this.streaming,
+ }
+ }
+}
diff --git a/server/plugins/socket/webrtc/Gateway.ts b/server/plugins/socket/webrtc/Gateway.ts
new file mode 100644
index 0000000..4c1e89a
--- /dev/null
+++ b/server/plugins/socket/webrtc/Gateway.ts
@@ -0,0 +1,254 @@
+import type { types } from 'mediasoup'
+import type { ChadSocket, ChadSocketServer } from '../types.ts'
+import type { Channel } from './Channel.ts'
+import type { ChannelManager } from './ChannelManager.ts'
+import type { Client } from './Client.ts'
+import { consola } from 'consola'
+
+export class WebRtcGateway {
+ readonly #io: ChadSocketServer
+ readonly #socket: ChadSocket
+ readonly #client: Client
+ readonly #channels: ChannelManager
+
+ constructor(
+ io: ChadSocketServer,
+ socket: ChadSocket,
+ client: Client,
+ channels: ChannelManager,
+ ) {
+ this.#io = io
+ this.#socket = socket
+ this.#client = client
+ this.#channels = channels
+
+ this.register()
+ }
+
+ register(): void {
+ this.#client.on('signal:new-consumer', async (data, onAcked) => {
+ await this.#socket.emitWithAck('new-consumer', data)
+ await onAcked()
+ })
+ this.#client.on('consumer:closed', consumerId => this.#socket.emit('consumer-closed', { consumerId }))
+ this.#client.on('consumer:paused', consumerId => this.#socket.emit('consumer-paused', { consumerId }))
+ this.#client.on('consumer:resumed', consumerId => this.#socket.emit('consumer-resumed', { consumerId }))
+ this.#client.on('transport:closed', () => this.#socket.disconnect())
+ this.#client.on('updated', () => this.#io.emit('client-updated', this.#client.serialize()))
+
+ this.#socket.on('join-channel', this.#onJoinChannel.bind(this))
+ this.#socket.on('create-transport', this.#onCreateTransport.bind(this))
+ this.#socket.on('connect-transport', this.#onConnectTransport.bind(this))
+ this.#socket.on('produce', this.#onProduce.bind(this))
+ this.#socket.on('close-producer', this.#onCloseProducer.bind(this))
+ this.#socket.on('pause-producer', this.#onPauseProducer.bind(this))
+ this.#socket.on('resume-producer', this.#onResumeProducer.bind(this))
+ this.#socket.on('pause-consumer', this.#onPauseConsumer.bind(this))
+ this.#socket.on('resume-consumer', this.#onResumeConsumer.bind(this))
+ this.#socket.on('update-client', this.#onUpdateClient.bind(this))
+ this.#socket.on('disconnect', this.#onDisconnect.bind(this))
+ }
+
+ async #onJoinChannel({ channelId }: { channelId: string }): Promise {
+ if (this.#client.channelId === channelId)
+ return
+
+ const newChannel = this.#channels.get(channelId)
+
+ if (!newChannel) {
+ consola.error('[Gateway]', `Channel not found: ${channelId}`)
+ return
+ }
+
+ const oldChannel = this.#channels.get(this.#client.channelId)
+
+ if (oldChannel)
+ this.#leaveChannel(oldChannel)
+
+ this.#client.clearConsumers()
+
+ this.#socket.join(newChannel.id)
+ newChannel.addClient(this.#client)
+ await newChannel.wireClient(this.#client)
+
+ this.#io.emit('client-switched-channel', this.#client.serialize())
+ }
+
+ async #onCreateTransport(
+ { producing, consuming }: { producing: boolean, consuming: boolean },
+ cb: (result: any) => void,
+ ): Promise {
+ try {
+ const transportData = await this.#client.createTransport({ producing, consuming })
+ cb(transportData)
+
+ if (consuming) {
+ const channel = this.#channels.get(this.#client.channelId)
+
+ if (channel)
+ await channel.wireClient(this.#client)
+ }
+ }
+ catch (error) {
+ if (error instanceof Error) {
+ consola.error('[Gateway]', '[createTransport]', error.message)
+ cb({ error: error.message })
+ }
+ }
+ }
+
+ async #onConnectTransport(
+ { transportId, dtlsParameters }: { transportId: string, dtlsParameters: types.DtlsParameters },
+ cb: (result: any) => void,
+ ): Promise {
+ try {
+ await this.#client.connectTransport(transportId, dtlsParameters)
+ cb({ ok: true })
+ }
+ catch (error) {
+ if (error instanceof Error) {
+ consola.error('[Gateway]', '[connectTransport]', error.message)
+ cb({ error: error.message })
+ }
+ }
+ }
+
+ async #onProduce(
+ { transportId, kind, rtpParameters, appData }: {
+ transportId: string
+ kind: types.MediaKind
+ rtpParameters: types.RtpParameters
+ appData: { source: string }
+ },
+ cb: (result: any) => void,
+ ): Promise {
+ try {
+ const producer = await this.#client.produce(transportId, kind, rtpParameters, appData)
+ cb({ id: producer.id })
+
+ const channel = this.#channels.get(this.#client.channelId)
+ if (channel) {
+ for (const peer of channel.clients) {
+ if (peer.socketId !== this.#client.socketId)
+ await peer.createConsumerFor(producer, this.#client.socketId)
+ }
+
+ if (kind === 'audio')
+ await channel.addAudioProducer(producer)
+ }
+ }
+ catch (error) {
+ if (error instanceof Error) {
+ consola.error('[Gateway]', '[produce]', error.message)
+ cb({ error: error.message })
+ }
+ }
+ }
+
+ #onCloseProducer(
+ { producerId }: { producerId: string },
+ cb: (result: any) => void,
+ ): void {
+ try {
+ this.#client.closeProducer(producerId)
+ cb({ ok: true })
+ }
+ catch (error) {
+ if (error instanceof Error) {
+ consola.error('[Gateway]', '[closeProducer]', error.message)
+ cb({ error: error.message })
+ }
+ }
+ }
+
+ async #onPauseProducer(
+ { producerId }: { producerId: string },
+ cb: (result: any) => void,
+ ): Promise {
+ try {
+ await this.#client.pauseProducer(producerId)
+ cb({ ok: true })
+ }
+ catch (error) {
+ if (error instanceof Error) {
+ consola.error('[Gateway]', '[pauseProducer]', error.message)
+ cb({ error: error.message })
+ }
+ }
+ }
+
+ async #onResumeProducer(
+ { producerId }: { producerId: string },
+ cb: (result: any) => void,
+ ): Promise {
+ try {
+ await this.#client.resumeProducer(producerId)
+ cb({ ok: true })
+ }
+ catch (error) {
+ if (error instanceof Error) {
+ consola.error('[Gateway]', '[resumeProducer]', error.message)
+ cb({ error: error.message })
+ }
+ }
+ }
+
+ async #onPauseConsumer(
+ { consumerId }: { consumerId: string },
+ cb: (result: any) => void,
+ ): Promise {
+ try {
+ await this.#client.pauseConsumer(consumerId)
+ cb({ ok: true })
+ }
+ catch (error) {
+ if (error instanceof Error) {
+ consola.error('[Gateway]', '[pauseConsumer]', error.message)
+ cb({ error: error.message })
+ }
+ }
+ }
+
+ async #onResumeConsumer(
+ { consumerId }: { consumerId: string },
+ cb: (result: any) => void,
+ ): Promise {
+ try {
+ await this.#client.resumeConsumer(consumerId)
+ cb({ ok: true })
+ }
+ catch (error) {
+ if (error instanceof Error) {
+ consola.error('[Gateway]', '[resumeConsumer]', error.message)
+ cb({ error: error.message })
+ }
+ }
+ }
+
+ #onUpdateClient(
+ patch: { inputMuted?: boolean, outputMuted?: boolean },
+ cb: (result: any) => void,
+ ): void {
+ this.#client.update(patch)
+ cb(this.#client.serialize())
+ }
+
+ #leaveChannel(channel: Channel): void {
+ channel.unwireClient(this.#client)
+ channel.kickClient(this.#client)
+ this.#socket.leave(channel.id)
+ }
+
+ #onDisconnect(): void {
+ consola.info('[Gateway]', 'Client disconnected:', this.#client.socketId)
+
+ this.#socket.broadcast.emit('client-disconnected', this.#client.socketId)
+
+ const channel = this.#channels.get(this.#client.channelId)
+
+ if (channel)
+ this.#leaveChannel(channel)
+
+ this.#client.close()
+ }
+}
diff --git a/server/plugins/socket/webrtc/MessagingService.ts b/server/plugins/socket/webrtc/MessagingService.ts
new file mode 100644
index 0000000..87cff4b
--- /dev/null
+++ b/server/plugins/socket/webrtc/MessagingService.ts
@@ -0,0 +1,14 @@
+import type { Channel } from '../../../prisma/generated-client/browser.ts'
+import type { ChannelManager } from './ChannelManager.ts'
+import type { Client } from './Client.ts'
+
+export class MessagingService {
+ private channels: ChannelManager
+
+ constructor(channels: ChannelManager) {
+ this.channels = channels
+ }
+
+ joinChannel(client: Client, channel: Channel) {
+ }
+}
diff --git a/server/plugins/socket/webrtc/index.ts b/server/plugins/socket/webrtc/index.ts
new file mode 100644
index 0000000..db3f648
--- /dev/null
+++ b/server/plugins/socket/webrtc/index.ts
@@ -0,0 +1,96 @@
+import type { FastifyInstance } from 'fastify'
+import { consola } from 'consola'
+import { Channel } from './Channel.ts'
+import { ChannelManager } from './ChannelManager.ts'
+import { Client } from './Client.ts'
+import { WebRtcGateway } from './Gateway.ts'
+
+export default async function (fastify: FastifyInstance) {
+ const { io, bus, mediasoupRouter, prisma } = fastify
+
+ const channels = new ChannelManager(mediasoupRouter)
+
+ const dbChannels = await prisma.channel.findMany()
+
+ for (const dbChannel of dbChannels) {
+ const channel = await Channel.create(dbChannel.id, dbChannel.persistent, mediasoupRouter)
+ channels.create(channel)
+ setupChannelEvents(channel)
+ }
+
+ const defaultChannel = channels.get('default')!
+
+ io.on('connection', async (socket) => {
+ consola.info('[WebRtc]', 'Client connected', socket.id)
+
+ const client = new Client(socket.id, socket.data.user.id, mediasoupRouter)
+
+ defaultChannel.addClient(client)
+ socket.join(defaultChannel.id)
+
+ const _gateway = new WebRtcGateway(io, socket, client, channels)
+
+ socket.emit('initialized', {
+ rtpCapabilities: mediasoupRouter.rtpCapabilities,
+ channelId: client.channelId,
+ clients: channels.all.flatMap(c => c.clients).map(c => c.serialize()),
+ })
+
+ socket.broadcast.emit('new-client', client.serialize())
+ })
+
+ bus.on('channel:created', async (dbChannel) => {
+ io.emit('channel-created', dbChannel)
+
+ const channel = await Channel.create(dbChannel.id, dbChannel.persistent, mediasoupRouter)
+
+ channels.create(channel)
+ setupChannelEvents(channel)
+ })
+
+ bus.on('channel:removed', async (dbChannel) => {
+ io.emit('channel-removed', dbChannel.id)
+
+ const channel = channels.get(dbChannel.id)
+
+ if (!channel)
+ return
+
+ for (const client of channel.clients) {
+ channel.unwireClient(client)
+ client.clearConsumers()
+
+ const socket = io.sockets.sockets.get(client.socketId)
+ if (socket) {
+ socket.leave(dbChannel.id)
+ defaultChannel.addClient(client)
+ socket.join(defaultChannel.id)
+ await defaultChannel.wireClient(client)
+ io.emit('client-switched-channel', client.serialize())
+ }
+ }
+
+ channels.delete(dbChannel.id)
+ })
+
+ function setupChannelEvents(channel: Channel): void {
+ channel.on('speaking-peers', peers => io.to(channel.id).emit('speaking-clients', peers))
+
+ channel.on('silence', () => {
+ io.to(channel.id).emit('speaking-clients', [])
+ io.to(channel.id).emit('active-speaker', undefined)
+ })
+
+ channel.on('active-speaker', socketId => io.to(channel.id).emit('active-speaker', socketId))
+
+ channel.on('empty', async () => {
+ if (channel.persistent)
+ return
+
+ channels.delete(channel.id)
+ await prisma.channel.delete({ where: { id: channel.id } })
+ consola.info('[WebRtc]', `Non-persistent channel "${channel.id}" deleted`)
+ io.emit('channel-removed', channel.id)
+ })
+ }
+}
diff --git a/server/prisma/generated-client/browser.ts b/server/prisma/generated-client/browser.ts
index 56e11fe..dffa888 100644
--- a/server/prisma/generated-client/browser.ts
+++ b/server/prisma/generated-client/browser.ts
@@ -1,4 +1,3 @@
-
/* !!! This is code generated by Prisma. Do not edit directly. !!! */
/* eslint-disable */
// biome-ignore-all lint: generated file
@@ -8,7 +7,7 @@
* Use it to get access to models, enums, and input types.
*
* This file does not contain a `PrismaClient` class, nor several other helpers that are intended as server-side only.
- * See `client.ts` for the standard, server-side entry point.
+ * See `Client.ts` for the standard, server-side entry point.
*
* 🟢 You can import this file directly.
*/
diff --git a/server/prisma/generated-client/internal/class.ts b/server/prisma/generated-client/internal/class.ts
index 741427a..3bf4859 100644
--- a/server/prisma/generated-client/internal/class.ts
+++ b/server/prisma/generated-client/internal/class.ts
@@ -1,4 +1,3 @@
-
/* !!! This is code generated by Prisma. Do not edit directly. !!! */
/* eslint-disable */
// biome-ignore-all lint: generated file
@@ -8,7 +7,7 @@
*
* 🛑 Under no circumstances should you import this file directly! 🛑
*
- * Please import the `PrismaClient` class from the `client.ts` file instead.
+ * Please import the `PrismaClient` class from the `Client.ts` file instead.
*/
import * as runtime from "@prisma/client/runtime/client"
@@ -20,7 +19,7 @@ const config: runtime.GetPrismaClientConfig = {
"clientVersion": "7.7.0",
"engineVersion": "75cbdc1eb7150937890ad5465d861175c6624711",
"activeProvider": "sqlite",
- "inlineSchema": "datasource db {\n provider = \"sqlite\"\n}\n\ngenerator client {\n provider = \"prisma-client\"\n output = \"./generated-client\"\n}\n\nmodel User {\n id String @id @default(cuid())\n username String @unique\n password String\n displayName String\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n\n Session Session[]\n UserPreferences UserPreferences?\n Messages Message[]\n}\n\nmodel Session {\n id String @id\n userId String\n expiresAt DateTime\n\n user User @relation(references: [id], fields: [userId], onDelete: Cascade)\n\n @@index([userId])\n}\n\nmodel UserPreferences {\n userId String @id @unique\n toggleInputHotkey String? @default(\"\")\n toggleOutputHotkey String? @default(\"\")\n\n user User @relation(references: [id], fields: [userId], onDelete: Cascade)\n}\n\nmodel Attachment {\n id String @id @default(uuid())\n name String\n mimetype String\n size Int\n createdAt DateTime @default(now())\n\n message MessageAttachment[]\n}\n\nmodel Message {\n id String @id @default(uuid())\n text String\n senderId String?\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n\n sender User? @relation(references: [id], fields: [senderId], onDelete: SetNull)\n attachments MessageAttachment[]\n}\n\nmodel MessageAttachment {\n messageId String\n attachmentId String\n\n message Message @relation(fields: [messageId], references: [id])\n attachment Attachment @relation(fields: [attachmentId], references: [id])\n\n @@id([messageId, attachmentId])\n}\n\nmodel Channel {\n id String @id @default(uuid())\n name String\n persistent Boolean\n}\n",
+ "inlineSchema": "datasource db {\n provider = \"sqlite\"\n}\n\ngenerator client {\n provider = \"prisma-client\"\n output = \"./generated-client\"\n}\n\nmodel User {\n id String @id @default(cuid())\n username String @unique\n password String\n displayName String\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n\n Session Session[]\n UserPreferences UserPreferences?\n Messages Message[]\n Channels Channel[]\n}\n\nmodel Session {\n id String @id\n userId String\n expiresAt DateTime\n\n user User @relation(references: [id], fields: [userId], onDelete: Cascade)\n\n @@index([userId])\n}\n\nmodel UserPreferences {\n userId String @id @unique\n toggleInputHotkey String? @default(\"\")\n toggleOutputHotkey String? @default(\"\")\n\n user User @relation(references: [id], fields: [userId], onDelete: Cascade)\n}\n\nmodel Attachment {\n id String @id @default(uuid())\n name String\n mimetype String\n size Int\n createdAt DateTime @default(now())\n\n message MessageAttachment[]\n}\n\nmodel Message {\n id String @id @default(uuid())\n text String\n senderId String?\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n\n sender User? @relation(references: [id], fields: [senderId], onDelete: SetNull)\n attachments MessageAttachment[]\n}\n\nmodel MessageAttachment {\n messageId String\n attachmentId String\n\n message Message @relation(fields: [messageId], references: [id])\n attachment Attachment @relation(fields: [attachmentId], references: [id])\n\n @@id([messageId, attachmentId])\n}\n\nmodel Channel {\n id String @id @default(uuid())\n ownerId String?\n name String\n persistent Boolean\n\n owner User? @relation(references: [id], fields: [ownerId], onDelete: Cascade)\n}\n",
"runtimeDataModel": {
"models": {},
"enums": {},
@@ -32,10 +31,10 @@ const config: runtime.GetPrismaClientConfig = {
}
}
-config.runtimeDataModel = JSON.parse("{\"models\":{\"User\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"username\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"password\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"displayName\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"Session\",\"kind\":\"object\",\"type\":\"Session\",\"relationName\":\"SessionToUser\"},{\"name\":\"UserPreferences\",\"kind\":\"object\",\"type\":\"UserPreferences\",\"relationName\":\"UserToUserPreferences\"},{\"name\":\"Messages\",\"kind\":\"object\",\"type\":\"Message\",\"relationName\":\"MessageToUser\"}],\"dbName\":null},\"Session\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"expiresAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"SessionToUser\"}],\"dbName\":null},\"UserPreferences\":{\"fields\":[{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"toggleInputHotkey\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"toggleOutputHotkey\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"UserToUserPreferences\"}],\"dbName\":null},\"Attachment\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"name\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"mimetype\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"size\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"message\",\"kind\":\"object\",\"type\":\"MessageAttachment\",\"relationName\":\"AttachmentToMessageAttachment\"}],\"dbName\":null},\"Message\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"text\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"senderId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"sender\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"MessageToUser\"},{\"name\":\"attachments\",\"kind\":\"object\",\"type\":\"MessageAttachment\",\"relationName\":\"MessageToMessageAttachment\"}],\"dbName\":null},\"MessageAttachment\":{\"fields\":[{\"name\":\"messageId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"attachmentId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"message\",\"kind\":\"object\",\"type\":\"Message\",\"relationName\":\"MessageToMessageAttachment\"},{\"name\":\"attachment\",\"kind\":\"object\",\"type\":\"Attachment\",\"relationName\":\"AttachmentToMessageAttachment\"}],\"dbName\":null},\"Channel\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"name\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"persistent\",\"kind\":\"scalar\",\"type\":\"Boolean\"}],\"dbName\":null}},\"enums\":{},\"types\":{}}")
+config.runtimeDataModel = JSON.parse("{\"models\":{\"User\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"username\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"password\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"displayName\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"Session\",\"kind\":\"object\",\"type\":\"Session\",\"relationName\":\"SessionToUser\"},{\"name\":\"UserPreferences\",\"kind\":\"object\",\"type\":\"UserPreferences\",\"relationName\":\"UserToUserPreferences\"},{\"name\":\"Messages\",\"kind\":\"object\",\"type\":\"Message\",\"relationName\":\"MessageToUser\"},{\"name\":\"Channels\",\"kind\":\"object\",\"type\":\"Channel\",\"relationName\":\"ChannelToUser\"}],\"dbName\":null},\"Session\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"expiresAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"SessionToUser\"}],\"dbName\":null},\"UserPreferences\":{\"fields\":[{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"toggleInputHotkey\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"toggleOutputHotkey\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"UserToUserPreferences\"}],\"dbName\":null},\"Attachment\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"name\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"mimetype\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"size\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"message\",\"kind\":\"object\",\"type\":\"MessageAttachment\",\"relationName\":\"AttachmentToMessageAttachment\"}],\"dbName\":null},\"Message\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"text\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"senderId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"sender\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"MessageToUser\"},{\"name\":\"attachments\",\"kind\":\"object\",\"type\":\"MessageAttachment\",\"relationName\":\"MessageToMessageAttachment\"}],\"dbName\":null},\"MessageAttachment\":{\"fields\":[{\"name\":\"messageId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"attachmentId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"message\",\"kind\":\"object\",\"type\":\"Message\",\"relationName\":\"MessageToMessageAttachment\"},{\"name\":\"attachment\",\"kind\":\"object\",\"type\":\"Attachment\",\"relationName\":\"AttachmentToMessageAttachment\"}],\"dbName\":null},\"Channel\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"ownerId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"name\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"persistent\",\"kind\":\"scalar\",\"type\":\"Boolean\"},{\"name\":\"owner\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"ChannelToUser\"}],\"dbName\":null}},\"enums\":{},\"types\":{}}")
config.parameterizationSchema = {
- strings: JSON.parse("[\"where\",\"orderBy\",\"cursor\",\"user\",\"Session\",\"UserPreferences\",\"sender\",\"message\",\"_count\",\"attachment\",\"attachments\",\"Messages\",\"User.findUnique\",\"User.findUniqueOrThrow\",\"User.findFirst\",\"User.findFirstOrThrow\",\"User.findMany\",\"data\",\"User.createOne\",\"User.createMany\",\"User.createManyAndReturn\",\"User.updateOne\",\"User.updateMany\",\"User.updateManyAndReturn\",\"create\",\"update\",\"User.upsertOne\",\"User.deleteOne\",\"User.deleteMany\",\"having\",\"_min\",\"_max\",\"User.groupBy\",\"User.aggregate\",\"Session.findUnique\",\"Session.findUniqueOrThrow\",\"Session.findFirst\",\"Session.findFirstOrThrow\",\"Session.findMany\",\"Session.createOne\",\"Session.createMany\",\"Session.createManyAndReturn\",\"Session.updateOne\",\"Session.updateMany\",\"Session.updateManyAndReturn\",\"Session.upsertOne\",\"Session.deleteOne\",\"Session.deleteMany\",\"Session.groupBy\",\"Session.aggregate\",\"UserPreferences.findUnique\",\"UserPreferences.findUniqueOrThrow\",\"UserPreferences.findFirst\",\"UserPreferences.findFirstOrThrow\",\"UserPreferences.findMany\",\"UserPreferences.createOne\",\"UserPreferences.createMany\",\"UserPreferences.createManyAndReturn\",\"UserPreferences.updateOne\",\"UserPreferences.updateMany\",\"UserPreferences.updateManyAndReturn\",\"UserPreferences.upsertOne\",\"UserPreferences.deleteOne\",\"UserPreferences.deleteMany\",\"UserPreferences.groupBy\",\"UserPreferences.aggregate\",\"Attachment.findUnique\",\"Attachment.findUniqueOrThrow\",\"Attachment.findFirst\",\"Attachment.findFirstOrThrow\",\"Attachment.findMany\",\"Attachment.createOne\",\"Attachment.createMany\",\"Attachment.createManyAndReturn\",\"Attachment.updateOne\",\"Attachment.updateMany\",\"Attachment.updateManyAndReturn\",\"Attachment.upsertOne\",\"Attachment.deleteOne\",\"Attachment.deleteMany\",\"_avg\",\"_sum\",\"Attachment.groupBy\",\"Attachment.aggregate\",\"Message.findUnique\",\"Message.findUniqueOrThrow\",\"Message.findFirst\",\"Message.findFirstOrThrow\",\"Message.findMany\",\"Message.createOne\",\"Message.createMany\",\"Message.createManyAndReturn\",\"Message.updateOne\",\"Message.updateMany\",\"Message.updateManyAndReturn\",\"Message.upsertOne\",\"Message.deleteOne\",\"Message.deleteMany\",\"Message.groupBy\",\"Message.aggregate\",\"MessageAttachment.findUnique\",\"MessageAttachment.findUniqueOrThrow\",\"MessageAttachment.findFirst\",\"MessageAttachment.findFirstOrThrow\",\"MessageAttachment.findMany\",\"MessageAttachment.createOne\",\"MessageAttachment.createMany\",\"MessageAttachment.createManyAndReturn\",\"MessageAttachment.updateOne\",\"MessageAttachment.updateMany\",\"MessageAttachment.updateManyAndReturn\",\"MessageAttachment.upsertOne\",\"MessageAttachment.deleteOne\",\"MessageAttachment.deleteMany\",\"MessageAttachment.groupBy\",\"MessageAttachment.aggregate\",\"Channel.findUnique\",\"Channel.findUniqueOrThrow\",\"Channel.findFirst\",\"Channel.findFirstOrThrow\",\"Channel.findMany\",\"Channel.createOne\",\"Channel.createMany\",\"Channel.createManyAndReturn\",\"Channel.updateOne\",\"Channel.updateMany\",\"Channel.updateManyAndReturn\",\"Channel.upsertOne\",\"Channel.deleteOne\",\"Channel.deleteMany\",\"Channel.groupBy\",\"Channel.aggregate\",\"AND\",\"OR\",\"NOT\",\"id\",\"name\",\"persistent\",\"equals\",\"not\",\"in\",\"notIn\",\"lt\",\"lte\",\"gt\",\"gte\",\"contains\",\"startsWith\",\"endsWith\",\"messageId\",\"attachmentId\",\"text\",\"senderId\",\"createdAt\",\"updatedAt\",\"mimetype\",\"size\",\"every\",\"some\",\"none\",\"userId\",\"toggleInputHotkey\",\"toggleOutputHotkey\",\"expiresAt\",\"username\",\"password\",\"displayName\",\"messageId_attachmentId\",\"is\",\"isNot\",\"connectOrCreate\",\"upsert\",\"createMany\",\"set\",\"disconnect\",\"delete\",\"connect\",\"updateMany\",\"deleteMany\",\"increment\",\"decrement\",\"multiply\",\"divide\"]"),
- graph: "7wI-cAwEAADjAQAgBQAA5AEAIAsAAOUBACCEAQAA4gEAMIUBAAANABCGAQAA4gEAMIcBAQAAAAGZAUAA1gEAIZoBQADWAQAhpAEBAAAAAaUBAQDFAQAhpgEBAMUBACEBAAAAAQAgBwMAANsBACCEAQAA6AEAMIUBAAADABCGAQAA6AEAMIcBAQDFAQAhoAEBAMUBACGjAUAA1gEAIQEDAACiAgAgBwMAANsBACCEAQAA6AEAMIUBAAADABCGAQAA6AEAMIcBAQAAAAGgAQEAxQEAIaMBQADWAQAhAwAAAAMAIAEAAAQAMAIAAAUAIAcDAADbAQAghAEAANkBADCFAQAABwAQhgEAANkBADCgAQEAxQEAIaEBAQDaAQAhogEBANoBACEBAAAABwAgCgYAAOcBACAKAADXAQAghAEAAOYBADCFAQAACQAQhgEAAOYBADCHAQEAxQEAIZcBAQDFAQAhmAEBANoBACGZAUAA1gEAIZoBQADWAQAhAwYAAKICACAKAACcAgAgmAEAAPUBACAKBgAA5wEAIAoAANcBACCEAQAA5gEAMIUBAAAJABCGAQAA5gEAMIcBAQAAAAGXAQEAxQEAIZgBAQDaAQAhmQFAANYBACGaAUAA1gEAIQMAAAAJACABAAAKADACAAALACAMBAAA4wEAIAUAAOQBACALAADlAQAghAEAAOIBADCFAQAADQAQhgEAAOIBADCHAQEAxQEAIZkBQADWAQAhmgFAANYBACGkAQEAxQEAIaUBAQDFAQAhpgEBAMUBACEBAAAADQAgBwcAAOABACAJAADhAQAghAEAAN8BADCFAQAADwAQhgEAAN8BADCVAQEAxQEAIZYBAQDFAQAhAgcAANECACAJAADSAgAgCAcAAOABACAJAADhAQAghAEAAN8BADCFAQAADwAQhgEAAN8BADCVAQEAxQEAIZYBAQDFAQAhpwEAAN4BACADAAAADwAgAQAAEAAwAgAAEQAgAwAAAA8AIAEAABAAMAIAABEAIAEAAAAPACABAAAADwAgAQAAAAMAIAEAAAAJACABAAAAAQAgAwQAAM4CACAFAADPAgAgCwAA0AIAIAMAAAANACABAAAZADACAAABACADAAAADQAgAQAAGQAwAgAAAQAgAwAAAA0AIAEAABkAMAIAAAEAIAkEAADLAgAgBQAAzAIAIAsAAM0CACCHAQEAAAABmQFAAAAAAZoBQAAAAAGkAQEAAAABpQEBAAAAAaYBAQAAAAEBEQAAHQAgBocBAQAAAAGZAUAAAAABmgFAAAAAAaQBAQAAAAGlAQEAAAABpgEBAAAAAQERAAAfADABEQAAHwAwCQQAAKsCACAFAACsAgAgCwAArQIAIIcBAQDsAQAhmQFAAPkBACGaAUAA-QEAIaQBAQDsAQAhpQEBAOwBACGmAQEA7AEAIQIAAAABACARAAAiACAGhwEBAOwBACGZAUAA-QEAIZoBQAD5AQAhpAEBAOwBACGlAQEA7AEAIaYBAQDsAQAhAgAAAA0AIBEAACQAIAIAAAANACARAAAkACADAAAAAQAgGAAAHQAgGQAAIgAgAQAAAAEAIAEAAAANACADCAAAqAIAIB4AAKoCACAfAACpAgAgCYQBAADdAQAwhQEAACsAEIYBAADdAQAwhwEBAL0BACGZAUAAygEAIZoBQADKAQAhpAEBAL0BACGlAQEAvQEAIaYBAQC9AQAhAwAAAA0AIAEAACoAMB0AACsAIAMAAAANACABAAAZADACAAABACABAAAABQAgAQAAAAUAIAMAAAADACABAAAEADACAAAFACADAAAAAwAgAQAABAAwAgAABQAgAwAAAAMAIAEAAAQAMAIAAAUAIAQDAACnAgAghwEBAAAAAaABAQAAAAGjAUAAAAABAREAADMAIAOHAQEAAAABoAEBAAAAAaMBQAAAAAEBEQAANQAwAREAADUAMAQDAACmAgAghwEBAOwBACGgAQEA7AEAIaMBQAD5AQAhAgAAAAUAIBEAADgAIAOHAQEA7AEAIaABAQDsAQAhowFAAPkBACECAAAAAwAgEQAAOgAgAgAAAAMAIBEAADoAIAMAAAAFACAYAAAzACAZAAA4ACABAAAABQAgAQAAAAMAIAMIAACjAgAgHgAApQIAIB8AAKQCACAGhAEAANwBADCFAQAAQQAQhgEAANwBADCHAQEAvQEAIaABAQC9AQAhowFAAMoBACEDAAAAAwAgAQAAQAAwHQAAQQAgAwAAAAMAIAEAAAQAMAIAAAUAIAcDAADbAQAghAEAANkBADCFAQAABwAQhgEAANkBADCgAQEAAAABoQEBANoBACGiAQEA2gEAIQEAAABEACABAAAARAAgAwMAAKICACChAQAA9QEAIKIBAAD1AQAgAwAAAAcAIAEAAEcAMAIAAEQAIAMAAAAHACABAABHADACAABEACADAAAABwAgAQAARwAwAgAARAAgBAMAAKECACCgAQEAAAABoQEBAAAAAaIBAQAAAAEBEQAASwAgA6ABAQAAAAGhAQEAAAABogEBAAAAAQERAABNADABEQAATQAwBAMAAKACACCgAQEA7AEAIaEBAQD6AQAhogEBAPoBACECAAAARAAgEQAAUAAgA6ABAQDsAQAhoQEBAPoBACGiAQEA-gEAIQIAAAAHACARAABSACACAAAABwAgEQAAUgAgAwAAAEQAIBgAAEsAIBkAAFAAIAEAAABEACABAAAABwAgBQgAAJ0CACAeAACfAgAgHwAAngIAIKEBAAD1AQAgogEAAPUBACAGhAEAANgBADCFAQAAWQAQhgEAANgBADCgAQEAvQEAIaEBAQDJAQAhogEBAMkBACEDAAAABwAgAQAAWAAwHQAAWQAgAwAAAAcAIAEAAEcAMAIAAEQAIAkHAADXAQAghAEAANQBADCFAQAAXwAQhgEAANQBADCHAQEAAAABiAEBAMUBACGZAUAA1gEAIZsBAQDFAQAhnAECANUBACEBAAAAXAAgAQAAAFwAIAkHAADXAQAghAEAANQBADCFAQAAXwAQhgEAANQBADCHAQEAxQEAIYgBAQDFAQAhmQFAANYBACGbAQEAxQEAIZwBAgDVAQAhAQcAAJwCACADAAAAXwAgAQAAYAAwAgAAXAAgAwAAAF8AIAEAAGAAMAIAAFwAIAMAAABfACABAABgADACAABcACAGBwAAmwIAIIcBAQAAAAGIAQEAAAABmQFAAAAAAZsBAQAAAAGcAQIAAAABAREAAGQAIAWHAQEAAAABiAEBAAAAAZkBQAAAAAGbAQEAAAABnAECAAAAAQERAABmADABEQAAZgAwBgcAAJECACCHAQEA7AEAIYgBAQDsAQAhmQFAAPkBACGbAQEA7AEAIZwBAgCQAgAhAgAAAFwAIBEAAGkAIAWHAQEA7AEAIYgBAQDsAQAhmQFAAPkBACGbAQEA7AEAIZwBAgCQAgAhAgAAAF8AIBEAAGsAIAIAAABfACARAABrACADAAAAXAAgGAAAZAAgGQAAaQAgAQAAAFwAIAEAAABfACAFCAAAiwIAIB4AAI4CACAfAACNAgAgUAAAjAIAIFEAAI8CACAIhAEAANABADCFAQAAcgAQhgEAANABADCHAQEAvQEAIYgBAQC9AQAhmQFAAMoBACGbAQEAvQEAIZwBAgDRAQAhAwAAAF8AIAEAAHEAMB0AAHIAIAMAAABfACABAABgADACAABcACABAAAACwAgAQAAAAsAIAMAAAAJACABAAAKADACAAALACADAAAACQAgAQAACgAwAgAACwAgAwAAAAkAIAEAAAoAMAIAAAsAIAcGAACJAgAgCgAAigIAIIcBAQAAAAGXAQEAAAABmAEBAAAAAZkBQAAAAAGaAUAAAAABAREAAHoAIAWHAQEAAAABlwEBAAAAAZgBAQAAAAGZAUAAAAABmgFAAAAAAQERAAB8ADABEQAAfAAwAQAAAA0AIAcGAAD7AQAgCgAA_AEAIIcBAQDsAQAhlwEBAOwBACGYAQEA-gEAIZkBQAD5AQAhmgFAAPkBACECAAAACwAgEQAAgAEAIAWHAQEA7AEAIZcBAQDsAQAhmAEBAPoBACGZAUAA-QEAIZoBQAD5AQAhAgAAAAkAIBEAAIIBACACAAAACQAgEQAAggEAIAEAAAANACADAAAACwAgGAAAegAgGQAAgAEAIAEAAAALACABAAAACQAgBAgAAPYBACAeAAD4AQAgHwAA9wEAIJgBAAD1AQAgCIQBAADIAQAwhQEAAIoBABCGAQAAyAEAMIcBAQC9AQAhlwEBAL0BACGYAQEAyQEAIZkBQADKAQAhmgFAAMoBACEDAAAACQAgAQAAiQEAMB0AAIoBACADAAAACQAgAQAACgAwAgAACwAgAQAAABEAIAEAAAARACADAAAADwAgAQAAEAAwAgAAEQAgAwAAAA8AIAEAABAAMAIAABEAIAMAAAAPACABAAAQADACAAARACAEBwAA8wEAIAkAAPQBACCVAQEAAAABlgEBAAAAAQERAACSAQAgApUBAQAAAAGWAQEAAAABAREAAJQBADABEQAAlAEAMAQHAADxAQAgCQAA8gEAIJUBAQDsAQAhlgEBAOwBACECAAAAEQAgEQAAlwEAIAKVAQEA7AEAIZYBAQDsAQAhAgAAAA8AIBEAAJkBACACAAAADwAgEQAAmQEAIAMAAAARACAYAACSAQAgGQAAlwEAIAEAAAARACABAAAADwAgAwgAAO4BACAeAADwAQAgHwAA7wEAIAWEAQAAxwEAMIUBAACgAQAQhgEAAMcBADCVAQEAvQEAIZYBAQC9AQAhAwAAAA8AIAEAAJ8BADAdAACgAQAgAwAAAA8AIAEAABAAMAIAABEAIAaEAQAAxAEAMIUBAACmAQAQhgEAAMQBADCHAQEAAAABiAEBAMUBACGJASAAxgEAIQEAAACjAQAgAQAAAKMBACAGhAEAAMQBADCFAQAApgEAEIYBAADEAQAwhwEBAMUBACGIAQEAxQEAIYkBIADGAQAhAAMAAACmAQAgAQAApwEAMAIAAKMBACADAAAApgEAIAEAAKcBADACAACjAQAgAwAAAKYBACABAACnAQAwAgAAowEAIAOHAQEAAAABiAEBAAAAAYkBIAAAAAEBEQAAqwEAIAOHAQEAAAABiAEBAAAAAYkBIAAAAAEBEQAArQEAMAERAACtAQAwA4cBAQDsAQAhiAEBAOwBACGJASAA7QEAIQIAAACjAQAgEQAAsAEAIAOHAQEA7AEAIYgBAQDsAQAhiQEgAO0BACECAAAApgEAIBEAALIBACACAAAApgEAIBEAALIBACADAAAAowEAIBgAAKsBACAZAACwAQAgAQAAAKMBACABAAAApgEAIAMIAADpAQAgHgAA6wEAIB8AAOoBACAGhAEAALwBADCFAQAAuQEAEIYBAAC8AQAwhwEBAL0BACGIAQEAvQEAIYkBIAC-AQAhAwAAAKYBACABAAC4AQAwHQAAuQEAIAMAAACmAQAgAQAApwEAMAIAAKMBACAGhAEAALwBADCFAQAAuQEAEIYBAAC8AQAwhwEBAL0BACGIAQEAvQEAIYkBIAC-AQAhDggAAMABACAeAADDAQAgHwAAwwEAIIoBAQAAAAGLAQEAwgEAIYwBAQAAAASNAQEAAAAEjgEBAAAAAY8BAQAAAAGQAQEAAAABkQEBAAAAAZIBAQAAAAGTAQEAAAABlAEBAAAAAQUIAADAAQAgHgAAwQEAIB8AAMEBACCKASAAAAABiwEgAL8BACEFCAAAwAEAIB4AAMEBACAfAADBAQAgigEgAAAAAYsBIAC_AQAhCIoBAgAAAAGLAQIAwAEAIYwBAgAAAASNAQIAAAAEjgECAAAAAY8BAgAAAAGQAQIAAAABkQECAAAAAQKKASAAAAABiwEgAMEBACEOCAAAwAEAIB4AAMMBACAfAADDAQAgigEBAAAAAYsBAQDCAQAhjAEBAAAABI0BAQAAAASOAQEAAAABjwEBAAAAAZABAQAAAAGRAQEAAAABkgEBAAAAAZMBAQAAAAGUAQEAAAABC4oBAQAAAAGLAQEAwwEAIYwBAQAAAASNAQEAAAAEjgEBAAAAAY8BAQAAAAGQAQEAAAABkQEBAAAAAZIBAQAAAAGTAQEAAAABlAEBAAAAAQaEAQAAxAEAMIUBAACmAQAQhgEAAMQBADCHAQEAxQEAIYgBAQDFAQAhiQEgAMYBACELigEBAAAAAYsBAQDDAQAhjAEBAAAABI0BAQAAAASOAQEAAAABjwEBAAAAAZABAQAAAAGRAQEAAAABkgEBAAAAAZMBAQAAAAGUAQEAAAABAooBIAAAAAGLASAAwQEAIQWEAQAAxwEAMIUBAACgAQAQhgEAAMcBADCVAQEAvQEAIZYBAQC9AQAhCIQBAADIAQAwhQEAAIoBABCGAQAAyAEAMIcBAQC9AQAhlwEBAL0BACGYAQEAyQEAIZkBQADKAQAhmgFAAMoBACEOCAAAzgEAIB4AAM8BACAfAADPAQAgigEBAAAAAYsBAQDNAQAhjAEBAAAABY0BAQAAAAWOAQEAAAABjwEBAAAAAZABAQAAAAGRAQEAAAABkgEBAAAAAZMBAQAAAAGUAQEAAAABCwgAAMABACAeAADMAQAgHwAAzAEAIIoBQAAAAAGLAUAAywEAIYwBQAAAAASNAUAAAAAEjgFAAAAAAY8BQAAAAAGQAUAAAAABkQFAAAAAAQsIAADAAQAgHgAAzAEAIB8AAMwBACCKAUAAAAABiwFAAMsBACGMAUAAAAAEjQFAAAAABI4BQAAAAAGPAUAAAAABkAFAAAAAAZEBQAAAAAEIigFAAAAAAYsBQADMAQAhjAFAAAAABI0BQAAAAASOAUAAAAABjwFAAAAAAZABQAAAAAGRAUAAAAABDggAAM4BACAeAADPAQAgHwAAzwEAIIoBAQAAAAGLAQEAzQEAIYwBAQAAAAWNAQEAAAAFjgEBAAAAAY8BAQAAAAGQAQEAAAABkQEBAAAAAZIBAQAAAAGTAQEAAAABlAEBAAAAAQiKAQIAAAABiwECAM4BACGMAQIAAAAFjQECAAAABY4BAgAAAAGPAQIAAAABkAECAAAAAZEBAgAAAAELigEBAAAAAYsBAQDPAQAhjAEBAAAABY0BAQAAAAWOAQEAAAABjwEBAAAAAZABAQAAAAGRAQEAAAABkgEBAAAAAZMBAQAAAAGUAQEAAAABCIQBAADQAQAwhQEAAHIAEIYBAADQAQAwhwEBAL0BACGIAQEAvQEAIZkBQADKAQAhmwEBAL0BACGcAQIA0QEAIQ0IAADAAQAgHgAAwAEAIB8AAMABACBQAADTAQAgUQAAwAEAIIoBAgAAAAGLAQIA0gEAIYwBAgAAAASNAQIAAAAEjgECAAAAAY8BAgAAAAGQAQIAAAABkQECAAAAAQ0IAADAAQAgHgAAwAEAIB8AAMABACBQAADTAQAgUQAAwAEAIIoBAgAAAAGLAQIA0gEAIYwBAgAAAASNAQIAAAAEjgECAAAAAY8BAgAAAAGQAQIAAAABkQECAAAAAQiKAQgAAAABiwEIANMBACGMAQgAAAAEjQEIAAAABI4BCAAAAAGPAQgAAAABkAEIAAAAAZEBCAAAAAEJBwAA1wEAIIQBAADUAQAwhQEAAF8AEIYBAADUAQAwhwEBAMUBACGIAQEAxQEAIZkBQADWAQAhmwEBAMUBACGcAQIA1QEAIQiKAQIAAAABiwECAMABACGMAQIAAAAEjQECAAAABI4BAgAAAAGPAQIAAAABkAECAAAAAZEBAgAAAAEIigFAAAAAAYsBQADMAQAhjAFAAAAABI0BQAAAAASOAUAAAAABjwFAAAAAAZABQAAAAAGRAUAAAAABA50BAAAPACCeAQAADwAgnwEAAA8AIAaEAQAA2AEAMIUBAABZABCGAQAA2AEAMKABAQC9AQAhoQEBAMkBACGiAQEAyQEAIQcDAADbAQAghAEAANkBADCFAQAABwAQhgEAANkBADCgAQEAxQEAIaEBAQDaAQAhogEBANoBACELigEBAAAAAYsBAQDPAQAhjAEBAAAABY0BAQAAAAWOAQEAAAABjwEBAAAAAZABAQAAAAGRAQEAAAABkgEBAAAAAZMBAQAAAAGUAQEAAAABDgQAAOMBACAFAADkAQAgCwAA5QEAIIQBAADiAQAwhQEAAA0AEIYBAADiAQAwhwEBAMUBACGZAUAA1gEAIZoBQADWAQAhpAEBAMUBACGlAQEAxQEAIaYBAQDFAQAhqAEAAA0AIKkBAAANACAGhAEAANwBADCFAQAAQQAQhgEAANwBADCHAQEAvQEAIaABAQC9AQAhowFAAMoBACEJhAEAAN0BADCFAQAAKwAQhgEAAN0BADCHAQEAvQEAIZkBQADKAQAhmgFAAMoBACGkAQEAvQEAIaUBAQC9AQAhpgEBAL0BACEClQEBAAAAAZYBAQAAAAEHBwAA4AEAIAkAAOEBACCEAQAA3wEAMIUBAAAPABCGAQAA3wEAMJUBAQDFAQAhlgEBAMUBACEMBgAA5wEAIAoAANcBACCEAQAA5gEAMIUBAAAJABCGAQAA5gEAMIcBAQDFAQAhlwEBAMUBACGYAQEA2gEAIZkBQADWAQAhmgFAANYBACGoAQAACQAgqQEAAAkAIAsHAADXAQAghAEAANQBADCFAQAAXwAQhgEAANQBADCHAQEAxQEAIYgBAQDFAQAhmQFAANYBACGbAQEAxQEAIZwBAgDVAQAhqAEAAF8AIKkBAABfACAMBAAA4wEAIAUAAOQBACALAADlAQAghAEAAOIBADCFAQAADQAQhgEAAOIBADCHAQEAxQEAIZkBQADWAQAhmgFAANYBACGkAQEAxQEAIaUBAQDFAQAhpgEBAMUBACEDnQEAAAMAIJ4BAAADACCfAQAAAwAgCQMAANsBACCEAQAA2QEAMIUBAAAHABCGAQAA2QEAMKABAQDFAQAhoQEBANoBACGiAQEA2gEAIagBAAAHACCpAQAABwAgA50BAAAJACCeAQAACQAgnwEAAAkAIAoGAADnAQAgCgAA1wEAIIQBAADmAQAwhQEAAAkAEIYBAADmAQAwhwEBAMUBACGXAQEAxQEAIZgBAQDaAQAhmQFAANYBACGaAUAA1gEAIQ4EAADjAQAgBQAA5AEAIAsAAOUBACCEAQAA4gEAMIUBAAANABCGAQAA4gEAMIcBAQDFAQAhmQFAANYBACGaAUAA1gEAIaQBAQDFAQAhpQEBAMUBACGmAQEAxQEAIagBAAANACCpAQAADQAgBwMAANsBACCEAQAA6AEAMIUBAAADABCGAQAA6AEAMIcBAQDFAQAhoAEBAMUBACGjAUAA1gEAIQAAAAGtAQEAAAABAa0BIAAAAAEAAAAFGAAA6AIAIBkAAO4CACCqAQAA6QIAIKsBAADtAgAgsAEAAAsAIAUYAADmAgAgGQAA6wIAIKoBAADnAgAgqwEAAOoCACCwAQAAXAAgAxgAAOgCACCqAQAA6QIAILABAAALACADGAAA5gIAIKoBAADnAgAgsAEAAFwAIAAAAAABrQFAAAAAAQGtAQEAAAABBxgAAOACACAZAADkAgAgqgEAAOECACCrAQAA4wIAIK4BAAANACCvAQAADQAgsAEAAAEAIAsYAAD9AQAwGQAAggIAMKoBAAD-AQAwqwEAAP8BADCsAQAAgAIAIK0BAACBAgAwrgEAAIECADCvAQAAgQIAMLABAACBAgAwsQEAAIMCADCyAQAAhAIAMAIJAAD0AQAglgEBAAAAAQIAAAARACAYAACIAgAgAwAAABEAIBgAAIgCACAZAACHAgAgAREAAOICADAIBwAA4AEAIAkAAOEBACCEAQAA3wEAMIUBAAAPABCGAQAA3wEAMJUBAQDFAQAhlgEBAMUBACGnAQAA3gEAIAIAAAARACARAACHAgAgAgAAAIUCACARAACGAgAgBYQBAACEAgAwhQEAAIUCABCGAQAAhAIAMJUBAQDFAQAhlgEBAMUBACEFhAEAAIQCADCFAQAAhQIAEIYBAACEAgAwlQEBAMUBACGWAQEAxQEAIQGWAQEA7AEAIQIJAADyAQAglgEBAOwBACECCQAA9AEAIJYBAQAAAAEDGAAA4AIAIKoBAADhAgAgsAEAAAEAIAQYAAD9AQAwqgEAAP4BADCsAQAAgAIAILABAACBAgAwAAAAAAAFrQECAAAAAbMBAgAAAAG0AQIAAAABtQECAAAAAbYBAgAAAAELGAAAkgIAMBkAAJYCADCqAQAAkwIAMKsBAACUAgAwrAEAAJUCACCtAQAAgQIAMK4BAACBAgAwrwEAAIECADCwAQAAgQIAMLEBAACXAgAwsgEAAIQCADACBwAA8wEAIJUBAQAAAAECAAAAEQAgGAAAmgIAIAMAAAARACAYAACaAgAgGQAAmQIAIAERAADfAgAwAgAAABEAIBEAAJkCACACAAAAhQIAIBEAAJgCACABlQEBAOwBACECBwAA8QEAIJUBAQDsAQAhAgcAAPMBACCVAQEAAAABBBgAAJICADCqAQAAkwIAMKwBAACVAgAgsAEAAIECADAAAAAABRgAANoCACAZAADdAgAgqgEAANsCACCrAQAA3AIAILABAAABACADGAAA2gIAIKoBAADbAgAgsAEAAAEAIAMEAADOAgAgBQAAzwIAIAsAANACACAAAAAFGAAA1QIAIBkAANgCACCqAQAA1gIAIKsBAADXAgAgsAEAAAEAIAMYAADVAgAgqgEAANYCACCwAQAAAQAgAAAACxgAAL8CADAZAADEAgAwqgEAAMACADCrAQAAwQIAMKwBAADCAgAgrQEAAMMCADCuAQAAwwIAMK8BAADDAgAwsAEAAMMCADCxAQAAxQIAMLIBAADGAgAwBxgAALoCACAZAAC9AgAgqgEAALsCACCrAQAAvAIAIK4BAAAHACCvAQAABwAgsAEAAEQAIAsYAACuAgAwGQAAswIAMKoBAACvAgAwqwEAALACADCsAQAAsQIAIK0BAACyAgAwrgEAALICADCvAQAAsgIAMLABAACyAgAwsQEAALQCADCyAQAAtQIAMAUKAACKAgAghwEBAAAAAZcBAQAAAAGZAUAAAAABmgFAAAAAAQIAAAALACAYAAC5AgAgAwAAAAsAIBgAALkCACAZAAC4AgAgAREAANQCADAKBgAA5wEAIAoAANcBACCEAQAA5gEAMIUBAAAJABCGAQAA5gEAMIcBAQAAAAGXAQEAxQEAIZgBAQDaAQAhmQFAANYBACGaAUAA1gEAIQIAAAALACARAAC4AgAgAgAAALYCACARAAC3AgAgCIQBAAC1AgAwhQEAALYCABCGAQAAtQIAMIcBAQDFAQAhlwEBAMUBACGYAQEA2gEAIZkBQADWAQAhmgFAANYBACEIhAEAALUCADCFAQAAtgIAEIYBAAC1AgAwhwEBAMUBACGXAQEAxQEAIZgBAQDaAQAhmQFAANYBACGaAUAA1gEAIQSHAQEA7AEAIZcBAQDsAQAhmQFAAPkBACGaAUAA-QEAIQUKAAD8AQAghwEBAOwBACGXAQEA7AEAIZkBQAD5AQAhmgFAAPkBACEFCgAAigIAIIcBAQAAAAGXAQEAAAABmQFAAAAAAZoBQAAAAAECoQEBAAAAAaIBAQAAAAECAAAARAAgGAAAugIAIAMAAAAHACAYAAC6AgAgGQAAvgIAIAQAAAAHACARAAC-AgAgoQEBAPoBACGiAQEA-gEAIQKhAQEA-gEAIaIBAQD6AQAhAocBAQAAAAGjAUAAAAABAgAAAAUAIBgAAMoCACADAAAABQAgGAAAygIAIBkAAMkCACABEQAA0wIAMAcDAADbAQAghAEAAOgBADCFAQAAAwAQhgEAAOgBADCHAQEAAAABoAEBAMUBACGjAUAA1gEAIQIAAAAFACARAADJAgAgAgAAAMcCACARAADIAgAgBoQBAADGAgAwhQEAAMcCABCGAQAAxgIAMIcBAQDFAQAhoAEBAMUBACGjAUAA1gEAIQaEAQAAxgIAMIUBAADHAgAQhgEAAMYCADCHAQEAxQEAIaABAQDFAQAhowFAANYBACEChwEBAOwBACGjAUAA-QEAIQKHAQEA7AEAIaMBQAD5AQAhAocBAQAAAAGjAUAAAAABBBgAAL8CADCqAQAAwAIAMKwBAADCAgAgsAEAAMMCADADGAAAugIAIKoBAAC7AgAgsAEAAEQAIAQYAACuAgAwqgEAAK8CADCsAQAAsQIAILABAACyAgAwAAMDAACiAgAgoQEAAPUBACCiAQAA9QEAIAADBgAAogIAIAoAAJwCACCYAQAA9QEAIAEHAACcAgAgAocBAQAAAAGjAUAAAAABBIcBAQAAAAGXAQEAAAABmQFAAAAAAZoBQAAAAAEIBQAAzAIAIAsAAM0CACCHAQEAAAABmQFAAAAAAZoBQAAAAAGkAQEAAAABpQEBAAAAAaYBAQAAAAECAAAAAQAgGAAA1QIAIAMAAAANACAYAADVAgAgGQAA2QIAIAoAAAANACAFAACsAgAgCwAArQIAIBEAANkCACCHAQEA7AEAIZkBQAD5AQAhmgFAAPkBACGkAQEA7AEAIaUBAQDsAQAhpgEBAOwBACEIBQAArAIAIAsAAK0CACCHAQEA7AEAIZkBQAD5AQAhmgFAAPkBACGkAQEA7AEAIaUBAQDsAQAhpgEBAOwBACEIBAAAywIAIAsAAM0CACCHAQEAAAABmQFAAAAAAZoBQAAAAAGkAQEAAAABpQEBAAAAAaYBAQAAAAECAAAAAQAgGAAA2gIAIAMAAAANACAYAADaAgAgGQAA3gIAIAoAAAANACAEAACrAgAgCwAArQIAIBEAAN4CACCHAQEA7AEAIZkBQAD5AQAhmgFAAPkBACGkAQEA7AEAIaUBAQDsAQAhpgEBAOwBACEIBAAAqwIAIAsAAK0CACCHAQEA7AEAIZkBQAD5AQAhmgFAAPkBACGkAQEA7AEAIaUBAQDsAQAhpgEBAOwBACEBlQEBAAAAAQgEAADLAgAgBQAAzAIAIIcBAQAAAAGZAUAAAAABmgFAAAAAAaQBAQAAAAGlAQEAAAABpgEBAAAAAQIAAAABACAYAADgAgAgAZYBAQAAAAEDAAAADQAgGAAA4AIAIBkAAOUCACAKAAAADQAgBAAAqwIAIAUAAKwCACARAADlAgAghwEBAOwBACGZAUAA-QEAIZoBQAD5AQAhpAEBAOwBACGlAQEA7AEAIaYBAQDsAQAhCAQAAKsCACAFAACsAgAghwEBAOwBACGZAUAA-QEAIZoBQAD5AQAhpAEBAOwBACGlAQEA7AEAIaYBAQDsAQAhBYcBAQAAAAGIAQEAAAABmQFAAAAAAZsBAQAAAAGcAQIAAAABAgAAAFwAIBgAAOYCACAGBgAAiQIAIIcBAQAAAAGXAQEAAAABmAEBAAAAAZkBQAAAAAGaAUAAAAABAgAAAAsAIBgAAOgCACADAAAAXwAgGAAA5gIAIBkAAOwCACAHAAAAXwAgEQAA7AIAIIcBAQDsAQAhiAEBAOwBACGZAUAA-QEAIZsBAQDsAQAhnAECAJACACEFhwEBAOwBACGIAQEA7AEAIZkBQAD5AQAhmwEBAOwBACGcAQIAkAIAIQMAAAAJACAYAADoAgAgGQAA7wIAIAgAAAAJACAGAAD7AQAgEQAA7wIAIIcBAQDsAQAhlwEBAOwBACGYAQEA-gEAIZkBQAD5AQAhmgFAAPkBACEGBgAA-wEAIIcBAQDsAQAhlwEBAOwBACGYAQEA-gEAIZkBQAD5AQAhmgFAAPkBACEEBAYCBQgDCAAJCwwEAQMAAQEDAAEDBg4BCAAIChIFAgcABAkABgIHEwUIAAcBBxQAAQoVAAIEFgALFwAAAAADCAAOHgAPHwAQAAAAAwgADh4ADx8AEAEDAAEBAwABAwgAFR4AFh8AFwAAAAMIABUeABYfABcBAwABAQMAAQMIABweAB0fAB4AAAADCAAcHgAdHwAeAAAFCAAjHgAmHwAnUAAkUQAlAAAAAAAFCAAjHgAmHwAnUAAkUQAlAQZ_AQEGhQEBAwgALB4ALR8ALgAAAAMIACweAC0fAC4CBwAECQAGAgcABAkABgMIADMeADQfADUAAAADCAAzHgA0HwA1AAAAAwgAOx4APB8APQAAAAMIADseADwfAD0MAgENGAEOGgEPGwEQHAESHgETIAoUIQsVIwEWJQoXJgwaJwEbKAEcKQogLA0hLREiLgIjLwIkMAIlMQImMgInNAIoNgopNxIqOQIrOwosPBMtPQIuPgIvPwowQhQxQxgyRQMzRgM0SAM1SQM2SgM3TAM4Tgo5Txk6UQM7Uwo8VBo9VQM-VgM_VwpAWhtBWx9CXQZDXgZEYQZFYgZGYwZHZQZIZwpJaCBKagZLbApMbSFNbgZObwZPcApScyJTdChUdQRVdgRWdwRXeARYeQRZewRafQpbfilcgQEEXYMBCl6EASpfhgEEYIcBBGGIAQpiiwErY4wBL2SNAQVljgEFZo8BBWeQAQVokQEFaZMBBWqVAQprlgEwbJgBBW2aAQpumwExb5wBBXCdAQVxngEKcqEBMnOiATZ0pAE3daUBN3aoATd3qQE3eKoBN3msATd6rgEKe68BOHyxATd9swEKfrQBOX-1ATeAAbYBN4EBtwEKggG6ATqDAbsBPg"
+ strings: JSON.parse("[\"where\",\"orderBy\",\"cursor\",\"user\",\"Session\",\"UserPreferences\",\"sender\",\"message\",\"_count\",\"attachment\",\"attachments\",\"Messages\",\"owner\",\"Channels\",\"User.findUnique\",\"User.findUniqueOrThrow\",\"User.findFirst\",\"User.findFirstOrThrow\",\"User.findMany\",\"data\",\"User.createOne\",\"User.createMany\",\"User.createManyAndReturn\",\"User.updateOne\",\"User.updateMany\",\"User.updateManyAndReturn\",\"create\",\"update\",\"User.upsertOne\",\"User.deleteOne\",\"User.deleteMany\",\"having\",\"_min\",\"_max\",\"User.groupBy\",\"User.aggregate\",\"Session.findUnique\",\"Session.findUniqueOrThrow\",\"Session.findFirst\",\"Session.findFirstOrThrow\",\"Session.findMany\",\"Session.createOne\",\"Session.createMany\",\"Session.createManyAndReturn\",\"Session.updateOne\",\"Session.updateMany\",\"Session.updateManyAndReturn\",\"Session.upsertOne\",\"Session.deleteOne\",\"Session.deleteMany\",\"Session.groupBy\",\"Session.aggregate\",\"UserPreferences.findUnique\",\"UserPreferences.findUniqueOrThrow\",\"UserPreferences.findFirst\",\"UserPreferences.findFirstOrThrow\",\"UserPreferences.findMany\",\"UserPreferences.createOne\",\"UserPreferences.createMany\",\"UserPreferences.createManyAndReturn\",\"UserPreferences.updateOne\",\"UserPreferences.updateMany\",\"UserPreferences.updateManyAndReturn\",\"UserPreferences.upsertOne\",\"UserPreferences.deleteOne\",\"UserPreferences.deleteMany\",\"UserPreferences.groupBy\",\"UserPreferences.aggregate\",\"Attachment.findUnique\",\"Attachment.findUniqueOrThrow\",\"Attachment.findFirst\",\"Attachment.findFirstOrThrow\",\"Attachment.findMany\",\"Attachment.createOne\",\"Attachment.createMany\",\"Attachment.createManyAndReturn\",\"Attachment.updateOne\",\"Attachment.updateMany\",\"Attachment.updateManyAndReturn\",\"Attachment.upsertOne\",\"Attachment.deleteOne\",\"Attachment.deleteMany\",\"_avg\",\"_sum\",\"Attachment.groupBy\",\"Attachment.aggregate\",\"Message.findUnique\",\"Message.findUniqueOrThrow\",\"Message.findFirst\",\"Message.findFirstOrThrow\",\"Message.findMany\",\"Message.createOne\",\"Message.createMany\",\"Message.createManyAndReturn\",\"Message.updateOne\",\"Message.updateMany\",\"Message.updateManyAndReturn\",\"Message.upsertOne\",\"Message.deleteOne\",\"Message.deleteMany\",\"Message.groupBy\",\"Message.aggregate\",\"MessageAttachment.findUnique\",\"MessageAttachment.findUniqueOrThrow\",\"MessageAttachment.findFirst\",\"MessageAttachment.findFirstOrThrow\",\"MessageAttachment.findMany\",\"MessageAttachment.createOne\",\"MessageAttachment.createMany\",\"MessageAttachment.createManyAndReturn\",\"MessageAttachment.updateOne\",\"MessageAttachment.updateMany\",\"MessageAttachment.updateManyAndReturn\",\"MessageAttachment.upsertOne\",\"MessageAttachment.deleteOne\",\"MessageAttachment.deleteMany\",\"MessageAttachment.groupBy\",\"MessageAttachment.aggregate\",\"Channel.findUnique\",\"Channel.findUniqueOrThrow\",\"Channel.findFirst\",\"Channel.findFirstOrThrow\",\"Channel.findMany\",\"Channel.createOne\",\"Channel.createMany\",\"Channel.createManyAndReturn\",\"Channel.updateOne\",\"Channel.updateMany\",\"Channel.updateManyAndReturn\",\"Channel.upsertOne\",\"Channel.deleteOne\",\"Channel.deleteMany\",\"Channel.groupBy\",\"Channel.aggregate\",\"AND\",\"OR\",\"NOT\",\"id\",\"ownerId\",\"name\",\"persistent\",\"equals\",\"not\",\"in\",\"notIn\",\"lt\",\"lte\",\"gt\",\"gte\",\"contains\",\"startsWith\",\"endsWith\",\"messageId\",\"attachmentId\",\"text\",\"senderId\",\"createdAt\",\"updatedAt\",\"mimetype\",\"size\",\"every\",\"some\",\"none\",\"userId\",\"toggleInputHotkey\",\"toggleOutputHotkey\",\"expiresAt\",\"username\",\"password\",\"displayName\",\"messageId_attachmentId\",\"is\",\"isNot\",\"connectOrCreate\",\"upsert\",\"createMany\",\"set\",\"disconnect\",\"delete\",\"connect\",\"updateMany\",\"deleteMany\",\"increment\",\"decrement\",\"multiply\",\"divide\"]"),
+ graph: "jAM-cA0EAADpAQAgBQAA6gEAIAsAAOsBACANAADsAQAghgEAAOgBADCHAQAADQAQiAEAAOgBADCJAQEAAAABnAFAANkBACGdAUAA2QEAIacBAQAAAAGoAQEA1wEAIakBAQDXAQAhAQAAAAEAIAcDAADeAQAghgEAAO4BADCHAQAAAwAQiAEAAO4BADCJAQEA1wEAIaMBAQDXAQAhpgFAANkBACEBAwAAqgIAIAcDAADeAQAghgEAAO4BADCHAQAAAwAQiAEAAO4BADCJAQEAAAABowEBANcBACGmAUAA2QEAIQMAAAADACABAAAEADACAAAFACAHAwAA3gEAIIYBAADcAQAwhwEAAAcAEIgBAADcAQAwowEBANcBACGkAQEA3QEAIaUBAQDdAQAhAQAAAAcAIAoGAADjAQAgCgAA2gEAIIYBAADtAQAwhwEAAAkAEIgBAADtAQAwiQEBANcBACGaAQEA1wEAIZsBAQDdAQAhnAFAANkBACGdAUAA2QEAIQMGAACqAgAgCgAApAIAIJsBAADvAQAgCgYAAOMBACAKAADaAQAghgEAAO0BADCHAQAACQAQiAEAAO0BADCJAQEAAAABmgEBANcBACGbAQEA3QEAIZwBQADZAQAhnQFAANkBACEDAAAACQAgAQAACgAwAgAACwAgDQQAAOkBACAFAADqAQAgCwAA6wEAIA0AAOwBACCGAQAA6AEAMIcBAAANABCIAQAA6AEAMIkBAQDXAQAhnAFAANkBACGdAUAA2QEAIacBAQDXAQAhqAEBANcBACGpAQEA1wEAIQEAAAANACAHBwAA5gEAIAkAAOcBACCGAQAA5QEAMIcBAAAPABCIAQAA5QEAMJgBAQDXAQAhmQEBANcBACECBwAA6AIAIAkAAOkCACAIBwAA5gEAIAkAAOcBACCGAQAA5QEAMIcBAAAPABCIAQAA5QEAMJgBAQDXAQAhmQEBANcBACGqAQAA5AEAIAMAAAAPACABAAAQADACAAARACADAAAADwAgAQAAEAAwAgAAEQAgAQAAAA8AIAEAAAAPACAIDAAA4wEAIIYBAADhAQAwhwEAABYAEIgBAADhAQAwiQEBANcBACGKAQEA3QEAIYsBAQDXAQAhjAEgAOIBACECDAAAqgIAIIoBAADvAQAgCAwAAOMBACCGAQAA4QEAMIcBAAAWABCIAQAA4QEAMIkBAQAAAAGKAQEA3QEAIYsBAQDXAQAhjAEgAOIBACEDAAAAFgAgAQAAFwAwAgAAGAAgAQAAAA0AIAEAAAADACABAAAACQAgAQAAABYAIAEAAAABACAEBAAA5AIAIAUAAOUCACALAADmAgAgDQAA5wIAIAMAAAANACABAAAfADACAAABACADAAAADQAgAQAAHwAwAgAAAQAgAwAAAA0AIAEAAB8AMAIAAAEAIAoEAADgAgAgBQAA4QIAIAsAAOICACANAADjAgAgiQEBAAAAAZwBQAAAAAGdAUAAAAABpwEBAAAAAagBAQAAAAGpAQEAAAABARMAACMAIAaJAQEAAAABnAFAAAAAAZ0BQAAAAAGnAQEAAAABqAEBAAAAAakBAQAAAAEBEwAAJQAwARMAACUAMAoEAACzAgAgBQAAtAIAIAsAALUCACANAAC2AgAgiQEBAPMBACGcAUAAggIAIZ0BQACCAgAhpwEBAPMBACGoAQEA8wEAIakBAQDzAQAhAgAAAAEAIBMAACgAIAaJAQEA8wEAIZwBQACCAgAhnQFAAIICACGnAQEA8wEAIagBAQDzAQAhqQEBAPMBACECAAAADQAgEwAAKgAgAgAAAA0AIBMAACoAIAMAAAABACAaAAAjACAbAAAoACABAAAAAQAgAQAAAA0AIAMIAACwAgAgIAAAsgIAICEAALECACAJhgEAAOABADCHAQAAMQAQiAEAAOABADCJAQEAwgEAIZwBQADPAQAhnQFAAM8BACGnAQEAwgEAIagBAQDCAQAhqQEBAMIBACEDAAAADQAgAQAAMAAwHwAAMQAgAwAAAA0AIAEAAB8AMAIAAAEAIAEAAAAFACABAAAABQAgAwAAAAMAIAEAAAQAMAIAAAUAIAMAAAADACABAAAEADACAAAFACADAAAAAwAgAQAABAAwAgAABQAgBAMAAK8CACCJAQEAAAABowEBAAAAAaYBQAAAAAEBEwAAOQAgA4kBAQAAAAGjAQEAAAABpgFAAAAAAQETAAA7ADABEwAAOwAwBAMAAK4CACCJAQEA8wEAIaMBAQDzAQAhpgFAAIICACECAAAABQAgEwAAPgAgA4kBAQDzAQAhowEBAPMBACGmAUAAggIAIQIAAAADACATAABAACACAAAAAwAgEwAAQAAgAwAAAAUAIBoAADkAIBsAAD4AIAEAAAAFACABAAAAAwAgAwgAAKsCACAgAACtAgAgIQAArAIAIAaGAQAA3wEAMIcBAABHABCIAQAA3wEAMIkBAQDCAQAhowEBAMIBACGmAUAAzwEAIQMAAAADACABAABGADAfAABHACADAAAAAwAgAQAABAAwAgAABQAgBwMAAN4BACCGAQAA3AEAMIcBAAAHABCIAQAA3AEAMKMBAQAAAAGkAQEA3QEAIaUBAQDdAQAhAQAAAEoAIAEAAABKACADAwAAqgIAIKQBAADvAQAgpQEAAO8BACADAAAABwAgAQAATQAwAgAASgAgAwAAAAcAIAEAAE0AMAIAAEoAIAMAAAAHACABAABNADACAABKACAEAwAAqQIAIKMBAQAAAAGkAQEAAAABpQEBAAAAAQETAABRACADowEBAAAAAaQBAQAAAAGlAQEAAAABARMAAFMAMAETAABTADAEAwAAqAIAIKMBAQDzAQAhpAEBAPUBACGlAQEA9QEAIQIAAABKACATAABWACADowEBAPMBACGkAQEA9QEAIaUBAQD1AQAhAgAAAAcAIBMAAFgAIAIAAAAHACATAABYACADAAAASgAgGgAAUQAgGwAAVgAgAQAAAEoAIAEAAAAHACAFCAAApQIAICAAAKcCACAhAACmAgAgpAEAAO8BACClAQAA7wEAIAaGAQAA2wEAMIcBAABfABCIAQAA2wEAMKMBAQDCAQAhpAEBAMMBACGlAQEAwwEAIQMAAAAHACABAABeADAfAABfACADAAAABwAgAQAATQAwAgAASgAgCQcAANoBACCGAQAA1gEAMIcBAABlABCIAQAA1gEAMIkBAQAAAAGLAQEA1wEAIZwBQADZAQAhngEBANcBACGfAQIA2AEAIQEAAABiACABAAAAYgAgCQcAANoBACCGAQAA1gEAMIcBAABlABCIAQAA1gEAMIkBAQDXAQAhiwEBANcBACGcAUAA2QEAIZ4BAQDXAQAhnwECANgBACEBBwAApAIAIAMAAABlACABAABmADACAABiACADAAAAZQAgAQAAZgAwAgAAYgAgAwAAAGUAIAEAAGYAMAIAAGIAIAYHAACjAgAgiQEBAAAAAYsBAQAAAAGcAUAAAAABngEBAAAAAZ8BAgAAAAEBEwAAagAgBYkBAQAAAAGLAQEAAAABnAFAAAAAAZ4BAQAAAAGfAQIAAAABARMAAGwAMAETAABsADAGBwAAmQIAIIkBAQDzAQAhiwEBAPMBACGcAUAAggIAIZ4BAQDzAQAhnwECAJgCACECAAAAYgAgEwAAbwAgBYkBAQDzAQAhiwEBAPMBACGcAUAAggIAIZ4BAQDzAQAhnwECAJgCACECAAAAZQAgEwAAcQAgAgAAAGUAIBMAAHEAIAMAAABiACAaAABqACAbAABvACABAAAAYgAgAQAAAGUAIAUIAACTAgAgIAAAlgIAICEAAJUCACBSAACUAgAgUwAAlwIAIAiGAQAA0gEAMIcBAAB4ABCIAQAA0gEAMIkBAQDCAQAhiwEBAMIBACGcAUAAzwEAIZ4BAQDCAQAhnwECANMBACEDAAAAZQAgAQAAdwAwHwAAeAAgAwAAAGUAIAEAAGYAMAIAAGIAIAEAAAALACABAAAACwAgAwAAAAkAIAEAAAoAMAIAAAsAIAMAAAAJACABAAAKADACAAALACADAAAACQAgAQAACgAwAgAACwAgBwYAAJECACAKAACSAgAgiQEBAAAAAZoBAQAAAAGbAQEAAAABnAFAAAAAAZ0BQAAAAAEBEwAAgAEAIAWJAQEAAAABmgEBAAAAAZsBAQAAAAGcAUAAAAABnQFAAAAAAQETAACCAQAwARMAAIIBADABAAAADQAgBwYAAIMCACAKAACEAgAgiQEBAPMBACGaAQEA8wEAIZsBAQD1AQAhnAFAAIICACGdAUAAggIAIQIAAAALACATAACGAQAgBYkBAQDzAQAhmgEBAPMBACGbAQEA9QEAIZwBQACCAgAhnQFAAIICACECAAAACQAgEwAAiAEAIAIAAAAJACATAACIAQAgAQAAAA0AIAMAAAALACAaAACAAQAgGwAAhgEAIAEAAAALACABAAAACQAgBAgAAP8BACAgAACBAgAgIQAAgAIAIJsBAADvAQAgCIYBAADOAQAwhwEAAJABABCIAQAAzgEAMIkBAQDCAQAhmgEBAMIBACGbAQEAwwEAIZwBQADPAQAhnQFAAM8BACEDAAAACQAgAQAAjwEAMB8AAJABACADAAAACQAgAQAACgAwAgAACwAgAQAAABEAIAEAAAARACADAAAADwAgAQAAEAAwAgAAEQAgAwAAAA8AIAEAABAAMAIAABEAIAMAAAAPACABAAAQADACAAARACAEBwAA_QEAIAkAAP4BACCYAQEAAAABmQEBAAAAAQETAACYAQAgApgBAQAAAAGZAQEAAAABARMAAJoBADABEwAAmgEAMAQHAAD7AQAgCQAA_AEAIJgBAQDzAQAhmQEBAPMBACECAAAAEQAgEwAAnQEAIAKYAQEA8wEAIZkBAQDzAQAhAgAAAA8AIBMAAJ8BACACAAAADwAgEwAAnwEAIAMAAAARACAaAACYAQAgGwAAnQEAIAEAAAARACABAAAADwAgAwgAAPgBACAgAAD6AQAgIQAA-QEAIAWGAQAAzQEAMIcBAACmAQAQiAEAAM0BADCYAQEAwgEAIZkBAQDCAQAhAwAAAA8AIAEAAKUBADAfAACmAQAgAwAAAA8AIAEAABAAMAIAABEAIAEAAAAYACABAAAAGAAgAwAAABYAIAEAABcAMAIAABgAIAMAAAAWACABAAAXADACAAAYACADAAAAFgAgAQAAFwAwAgAAGAAgBQwAAPcBACCJAQEAAAABigEBAAAAAYsBAQAAAAGMASAAAAABARMAAK4BACAEiQEBAAAAAYoBAQAAAAGLAQEAAAABjAEgAAAAAQETAACwAQAwARMAALABADABAAAADQAgBQwAAPYBACCJAQEA8wEAIYoBAQD1AQAhiwEBAPMBACGMASAA9AEAIQIAAAAYACATAAC0AQAgBIkBAQDzAQAhigEBAPUBACGLAQEA8wEAIYwBIAD0AQAhAgAAABYAIBMAALYBACACAAAAFgAgEwAAtgEAIAEAAAANACADAAAAGAAgGgAArgEAIBsAALQBACABAAAAGAAgAQAAABYAIAQIAADwAQAgIAAA8gEAICEAAPEBACCKAQAA7wEAIAeGAQAAwQEAMIcBAAC-AQAQiAEAAMEBADCJAQEAwgEAIYoBAQDDAQAhiwEBAMIBACGMASAAxAEAIQMAAAAWACABAAC9AQAwHwAAvgEAIAMAAAAWACABAAAXADACAAAYACAHhgEAAMEBADCHAQAAvgEAEIgBAADBAQAwiQEBAMIBACGKAQEAwwEAIYsBAQDCAQAhjAEgAMQBACEOCAAAxgEAICAAAMwBACAhAADMAQAgjQEBAAAAAY4BAQDLAQAhjwEBAAAABJABAQAAAASRAQEAAAABkgEBAAAAAZMBAQAAAAGUAQEAAAABlQEBAAAAAZYBAQAAAAGXAQEAAAABDggAAMkBACAgAADKAQAgIQAAygEAII0BAQAAAAGOAQEAyAEAIY8BAQAAAAWQAQEAAAAFkQEBAAAAAZIBAQAAAAGTAQEAAAABlAEBAAAAAZUBAQAAAAGWAQEAAAABlwEBAAAAAQUIAADGAQAgIAAAxwEAICEAAMcBACCNASAAAAABjgEgAMUBACEFCAAAxgEAICAAAMcBACAhAADHAQAgjQEgAAAAAY4BIADFAQAhCI0BAgAAAAGOAQIAxgEAIY8BAgAAAASQAQIAAAAEkQECAAAAAZIBAgAAAAGTAQIAAAABlAECAAAAAQKNASAAAAABjgEgAMcBACEOCAAAyQEAICAAAMoBACAhAADKAQAgjQEBAAAAAY4BAQDIAQAhjwEBAAAABZABAQAAAAWRAQEAAAABkgEBAAAAAZMBAQAAAAGUAQEAAAABlQEBAAAAAZYBAQAAAAGXAQEAAAABCI0BAgAAAAGOAQIAyQEAIY8BAgAAAAWQAQIAAAAFkQECAAAAAZIBAgAAAAGTAQIAAAABlAECAAAAAQuNAQEAAAABjgEBAMoBACGPAQEAAAAFkAEBAAAABZEBAQAAAAGSAQEAAAABkwEBAAAAAZQBAQAAAAGVAQEAAAABlgEBAAAAAZcBAQAAAAEOCAAAxgEAICAAAMwBACAhAADMAQAgjQEBAAAAAY4BAQDLAQAhjwEBAAAABJABAQAAAASRAQEAAAABkgEBAAAAAZMBAQAAAAGUAQEAAAABlQEBAAAAAZYBAQAAAAGXAQEAAAABC40BAQAAAAGOAQEAzAEAIY8BAQAAAASQAQEAAAAEkQEBAAAAAZIBAQAAAAGTAQEAAAABlAEBAAAAAZUBAQAAAAGWAQEAAAABlwEBAAAAAQWGAQAAzQEAMIcBAACmAQAQiAEAAM0BADCYAQEAwgEAIZkBAQDCAQAhCIYBAADOAQAwhwEAAJABABCIAQAAzgEAMIkBAQDCAQAhmgEBAMIBACGbAQEAwwEAIZwBQADPAQAhnQFAAM8BACELCAAAxgEAICAAANEBACAhAADRAQAgjQFAAAAAAY4BQADQAQAhjwFAAAAABJABQAAAAASRAUAAAAABkgFAAAAAAZMBQAAAAAGUAUAAAAABCwgAAMYBACAgAADRAQAgIQAA0QEAII0BQAAAAAGOAUAA0AEAIY8BQAAAAASQAUAAAAAEkQFAAAAAAZIBQAAAAAGTAUAAAAABlAFAAAAAAQiNAUAAAAABjgFAANEBACGPAUAAAAAEkAFAAAAABJEBQAAAAAGSAUAAAAABkwFAAAAAAZQBQAAAAAEIhgEAANIBADCHAQAAeAAQiAEAANIBADCJAQEAwgEAIYsBAQDCAQAhnAFAAM8BACGeAQEAwgEAIZ8BAgDTAQAhDQgAAMYBACAgAADGAQAgIQAAxgEAIFIAANUBACBTAADGAQAgjQECAAAAAY4BAgDUAQAhjwECAAAABJABAgAAAASRAQIAAAABkgECAAAAAZMBAgAAAAGUAQIAAAABDQgAAMYBACAgAADGAQAgIQAAxgEAIFIAANUBACBTAADGAQAgjQECAAAAAY4BAgDUAQAhjwECAAAABJABAgAAAASRAQIAAAABkgECAAAAAZMBAgAAAAGUAQIAAAABCI0BCAAAAAGOAQgA1QEAIY8BCAAAAASQAQgAAAAEkQEIAAAAAZIBCAAAAAGTAQgAAAABlAEIAAAAAQkHAADaAQAghgEAANYBADCHAQAAZQAQiAEAANYBADCJAQEA1wEAIYsBAQDXAQAhnAFAANkBACGeAQEA1wEAIZ8BAgDYAQAhC40BAQAAAAGOAQEAzAEAIY8BAQAAAASQAQEAAAAEkQEBAAAAAZIBAQAAAAGTAQEAAAABlAEBAAAAAZUBAQAAAAGWAQEAAAABlwEBAAAAAQiNAQIAAAABjgECAMYBACGPAQIAAAAEkAECAAAABJEBAgAAAAGSAQIAAAABkwECAAAAAZQBAgAAAAEIjQFAAAAAAY4BQADRAQAhjwFAAAAABJABQAAAAASRAUAAAAABkgFAAAAAAZMBQAAAAAGUAUAAAAABA6ABAAAPACChAQAADwAgogEAAA8AIAaGAQAA2wEAMIcBAABfABCIAQAA2wEAMKMBAQDCAQAhpAEBAMMBACGlAQEAwwEAIQcDAADeAQAghgEAANwBADCHAQAABwAQiAEAANwBADCjAQEA1wEAIaQBAQDdAQAhpQEBAN0BACELjQEBAAAAAY4BAQDKAQAhjwEBAAAABZABAQAAAAWRAQEAAAABkgEBAAAAAZMBAQAAAAGUAQEAAAABlQEBAAAAAZYBAQAAAAGXAQEAAAABDwQAAOkBACAFAADqAQAgCwAA6wEAIA0AAOwBACCGAQAA6AEAMIcBAAANABCIAQAA6AEAMIkBAQDXAQAhnAFAANkBACGdAUAA2QEAIacBAQDXAQAhqAEBANcBACGpAQEA1wEAIasBAAANACCsAQAADQAgBoYBAADfAQAwhwEAAEcAEIgBAADfAQAwiQEBAMIBACGjAQEAwgEAIaYBQADPAQAhCYYBAADgAQAwhwEAADEAEIgBAADgAQAwiQEBAMIBACGcAUAAzwEAIZ0BQADPAQAhpwEBAMIBACGoAQEAwgEAIakBAQDCAQAhCAwAAOMBACCGAQAA4QEAMIcBAAAWABCIAQAA4QEAMIkBAQDXAQAhigEBAN0BACGLAQEA1wEAIYwBIADiAQAhAo0BIAAAAAGOASAAxwEAIQ8EAADpAQAgBQAA6gEAIAsAAOsBACANAADsAQAghgEAAOgBADCHAQAADQAQiAEAAOgBADCJAQEA1wEAIZwBQADZAQAhnQFAANkBACGnAQEA1wEAIagBAQDXAQAhqQEBANcBACGrAQAADQAgrAEAAA0AIAKYAQEAAAABmQEBAAAAAQcHAADmAQAgCQAA5wEAIIYBAADlAQAwhwEAAA8AEIgBAADlAQAwmAEBANcBACGZAQEA1wEAIQwGAADjAQAgCgAA2gEAIIYBAADtAQAwhwEAAAkAEIgBAADtAQAwiQEBANcBACGaAQEA1wEAIZsBAQDdAQAhnAFAANkBACGdAUAA2QEAIasBAAAJACCsAQAACQAgCwcAANoBACCGAQAA1gEAMIcBAABlABCIAQAA1gEAMIkBAQDXAQAhiwEBANcBACGcAUAA2QEAIZ4BAQDXAQAhnwECANgBACGrAQAAZQAgrAEAAGUAIA0EAADpAQAgBQAA6gEAIAsAAOsBACANAADsAQAghgEAAOgBADCHAQAADQAQiAEAAOgBADCJAQEA1wEAIZwBQADZAQAhnQFAANkBACGnAQEA1wEAIagBAQDXAQAhqQEBANcBACEDoAEAAAMAIKEBAAADACCiAQAAAwAgCQMAAN4BACCGAQAA3AEAMIcBAAAHABCIAQAA3AEAMKMBAQDXAQAhpAEBAN0BACGlAQEA3QEAIasBAAAHACCsAQAABwAgA6ABAAAJACChAQAACQAgogEAAAkAIAOgAQAAFgAgoQEAABYAIKIBAAAWACAKBgAA4wEAIAoAANoBACCGAQAA7QEAMIcBAAAJABCIAQAA7QEAMIkBAQDXAQAhmgEBANcBACGbAQEA3QEAIZwBQADZAQAhnQFAANkBACEHAwAA3gEAIIYBAADuAQAwhwEAAAMAEIgBAADuAQAwiQEBANcBACGjAQEA1wEAIaYBQADZAQAhAAAAAAGwAQEAAAABAbABIAAAAAEBsAEBAAAAAQcaAACIAwAgGwAAiwMAIK0BAACJAwAgrgEAAIoDACCxAQAADQAgsgEAAA0AILMBAAABACADGgAAiAMAIK0BAACJAwAgswEAAAEAIAAAAAUaAACAAwAgGwAAhgMAIK0BAACBAwAgrgEAAIUDACCzAQAACwAgBRoAAP4CACAbAACDAwAgrQEAAP8CACCuAQAAggMAILMBAABiACADGgAAgAMAIK0BAACBAwAgswEAAAsAIAMaAAD-AgAgrQEAAP8CACCzAQAAYgAgAAAAAbABQAAAAAEHGgAA-AIAIBsAAPwCACCtAQAA-QIAIK4BAAD7AgAgsQEAAA0AILIBAAANACCzAQAAAQAgCxoAAIUCADAbAACKAgAwrQEAAIYCADCuAQAAhwIAMK8BAACIAgAgsAEAAIkCADCxAQAAiQIAMLIBAACJAgAwswEAAIkCADC0AQAAiwIAMLUBAACMAgAwAgkAAP4BACCZAQEAAAABAgAAABEAIBoAAJACACADAAAAEQAgGgAAkAIAIBsAAI8CACABEwAA-gIAMAgHAADmAQAgCQAA5wEAIIYBAADlAQAwhwEAAA8AEIgBAADlAQAwmAEBANcBACGZAQEA1wEAIaoBAADkAQAgAgAAABEAIBMAAI8CACACAAAAjQIAIBMAAI4CACAFhgEAAIwCADCHAQAAjQIAEIgBAACMAgAwmAEBANcBACGZAQEA1wEAIQWGAQAAjAIAMIcBAACNAgAQiAEAAIwCADCYAQEA1wEAIZkBAQDXAQAhAZkBAQDzAQAhAgkAAPwBACCZAQEA8wEAIQIJAAD-AQAgmQEBAAAAAQMaAAD4AgAgrQEAAPkCACCzAQAAAQAgBBoAAIUCADCtAQAAhgIAMK8BAACIAgAgswEAAIkCADAAAAAAAAWwAQIAAAABtgECAAAAAbcBAgAAAAG4AQIAAAABuQECAAAAAQsaAACaAgAwGwAAngIAMK0BAACbAgAwrgEAAJwCADCvAQAAnQIAILABAACJAgAwsQEAAIkCADCyAQAAiQIAMLMBAACJAgAwtAEAAJ8CADC1AQAAjAIAMAIHAAD9AQAgmAEBAAAAAQIAAAARACAaAACiAgAgAwAAABEAIBoAAKICACAbAAChAgAgARMAAPcCADACAAAAEQAgEwAAoQIAIAIAAACNAgAgEwAAoAIAIAGYAQEA8wEAIQIHAAD7AQAgmAEBAPMBACECBwAA_QEAIJgBAQAAAAEEGgAAmgIAMK0BAACbAgAwrwEAAJ0CACCzAQAAiQIAMAAAAAAFGgAA8gIAIBsAAPUCACCtAQAA8wIAIK4BAAD0AgAgswEAAAEAIAMaAADyAgAgrQEAAPMCACCzAQAAAQAgBAQAAOQCACAFAADlAgAgCwAA5gIAIA0AAOcCACAAAAAFGgAA7QIAIBsAAPACACCtAQAA7gIAIK4BAADvAgAgswEAAAEAIAMaAADtAgAgrQEAAO4CACCzAQAAAQAgAAAACxoAANQCADAbAADZAgAwrQEAANUCADCuAQAA1gIAMK8BAADXAgAgsAEAANgCADCxAQAA2AIAMLIBAADYAgAwswEAANgCADC0AQAA2gIAMLUBAADbAgAwBxoAAM8CACAbAADSAgAgrQEAANACACCuAQAA0QIAILEBAAAHACCyAQAABwAgswEAAEoAIAsaAADDAgAwGwAAyAIAMK0BAADEAgAwrgEAAMUCADCvAQAAxgIAILABAADHAgAwsQEAAMcCADCyAQAAxwIAMLMBAADHAgAwtAEAAMkCADC1AQAAygIAMAsaAAC3AgAwGwAAvAIAMK0BAAC4AgAwrgEAALkCADCvAQAAugIAILABAAC7AgAwsQEAALsCADCyAQAAuwIAMLMBAAC7AgAwtAEAAL0CADC1AQAAvgIAMAOJAQEAAAABiwEBAAAAAYwBIAAAAAECAAAAGAAgGgAAwgIAIAMAAAAYACAaAADCAgAgGwAAwQIAIAETAADsAgAwCAwAAOMBACCGAQAA4QEAMIcBAAAWABCIAQAA4QEAMIkBAQAAAAGKAQEA3QEAIYsBAQDXAQAhjAEgAOIBACECAAAAGAAgEwAAwQIAIAIAAAC_AgAgEwAAwAIAIAeGAQAAvgIAMIcBAAC_AgAQiAEAAL4CADCJAQEA1wEAIYoBAQDdAQAhiwEBANcBACGMASAA4gEAIQeGAQAAvgIAMIcBAAC_AgAQiAEAAL4CADCJAQEA1wEAIYoBAQDdAQAhiwEBANcBACGMASAA4gEAIQOJAQEA8wEAIYsBAQDzAQAhjAEgAPQBACEDiQEBAPMBACGLAQEA8wEAIYwBIAD0AQAhA4kBAQAAAAGLAQEAAAABjAEgAAAAAQUKAACSAgAgiQEBAAAAAZoBAQAAAAGcAUAAAAABnQFAAAAAAQIAAAALACAaAADOAgAgAwAAAAsAIBoAAM4CACAbAADNAgAgARMAAOsCADAKBgAA4wEAIAoAANoBACCGAQAA7QEAMIcBAAAJABCIAQAA7QEAMIkBAQAAAAGaAQEA1wEAIZsBAQDdAQAhnAFAANkBACGdAUAA2QEAIQIAAAALACATAADNAgAgAgAAAMsCACATAADMAgAgCIYBAADKAgAwhwEAAMsCABCIAQAAygIAMIkBAQDXAQAhmgEBANcBACGbAQEA3QEAIZwBQADZAQAhnQFAANkBACEIhgEAAMoCADCHAQAAywIAEIgBAADKAgAwiQEBANcBACGaAQEA1wEAIZsBAQDdAQAhnAFAANkBACGdAUAA2QEAIQSJAQEA8wEAIZoBAQDzAQAhnAFAAIICACGdAUAAggIAIQUKAACEAgAgiQEBAPMBACGaAQEA8wEAIZwBQACCAgAhnQFAAIICACEFCgAAkgIAIIkBAQAAAAGaAQEAAAABnAFAAAAAAZ0BQAAAAAECpAEBAAAAAaUBAQAAAAECAAAASgAgGgAAzwIAIAMAAAAHACAaAADPAgAgGwAA0wIAIAQAAAAHACATAADTAgAgpAEBAPUBACGlAQEA9QEAIQKkAQEA9QEAIaUBAQD1AQAhAokBAQAAAAGmAUAAAAABAgAAAAUAIBoAAN8CACADAAAABQAgGgAA3wIAIBsAAN4CACABEwAA6gIAMAcDAADeAQAghgEAAO4BADCHAQAAAwAQiAEAAO4BADCJAQEAAAABowEBANcBACGmAUAA2QEAIQIAAAAFACATAADeAgAgAgAAANwCACATAADdAgAgBoYBAADbAgAwhwEAANwCABCIAQAA2wIAMIkBAQDXAQAhowEBANcBACGmAUAA2QEAIQaGAQAA2wIAMIcBAADcAgAQiAEAANsCADCJAQEA1wEAIaMBAQDXAQAhpgFAANkBACECiQEBAPMBACGmAUAAggIAIQKJAQEA8wEAIaYBQACCAgAhAokBAQAAAAGmAUAAAAABBBoAANQCADCtAQAA1QIAMK8BAADXAgAgswEAANgCADADGgAAzwIAIK0BAADQAgAgswEAAEoAIAQaAADDAgAwrQEAAMQCADCvAQAAxgIAILMBAADHAgAwBBoAALcCADCtAQAAuAIAMK8BAAC6AgAgswEAALsCADAAAwMAAKoCACCkAQAA7wEAIKUBAADvAQAgAAADBgAAqgIAIAoAAKQCACCbAQAA7wEAIAEHAACkAgAgAokBAQAAAAGmAUAAAAABBIkBAQAAAAGaAQEAAAABnAFAAAAAAZ0BQAAAAAEDiQEBAAAAAYsBAQAAAAGMASAAAAABCQUAAOECACALAADiAgAgDQAA4wIAIIkBAQAAAAGcAUAAAAABnQFAAAAAAacBAQAAAAGoAQEAAAABqQEBAAAAAQIAAAABACAaAADtAgAgAwAAAA0AIBoAAO0CACAbAADxAgAgCwAAAA0AIAUAALQCACALAAC1AgAgDQAAtgIAIBMAAPECACCJAQEA8wEAIZwBQACCAgAhnQFAAIICACGnAQEA8wEAIagBAQDzAQAhqQEBAPMBACEJBQAAtAIAIAsAALUCACANAAC2AgAgiQEBAPMBACGcAUAAggIAIZ0BQACCAgAhpwEBAPMBACGoAQEA8wEAIakBAQDzAQAhCQQAAOACACALAADiAgAgDQAA4wIAIIkBAQAAAAGcAUAAAAABnQFAAAAAAacBAQAAAAGoAQEAAAABqQEBAAAAAQIAAAABACAaAADyAgAgAwAAAA0AIBoAAPICACAbAAD2AgAgCwAAAA0AIAQAALMCACALAAC1AgAgDQAAtgIAIBMAAPYCACCJAQEA8wEAIZwBQACCAgAhnQFAAIICACGnAQEA8wEAIagBAQDzAQAhqQEBAPMBACEJBAAAswIAIAsAALUCACANAAC2AgAgiQEBAPMBACGcAUAAggIAIZ0BQACCAgAhpwEBAPMBACGoAQEA8wEAIakBAQDzAQAhAZgBAQAAAAEJBAAA4AIAIAUAAOECACANAADjAgAgiQEBAAAAAZwBQAAAAAGdAUAAAAABpwEBAAAAAagBAQAAAAGpAQEAAAABAgAAAAEAIBoAAPgCACABmQEBAAAAAQMAAAANACAaAAD4AgAgGwAA_QIAIAsAAAANACAEAACzAgAgBQAAtAIAIA0AALYCACATAAD9AgAgiQEBAPMBACGcAUAAggIAIZ0BQACCAgAhpwEBAPMBACGoAQEA8wEAIakBAQDzAQAhCQQAALMCACAFAAC0AgAgDQAAtgIAIIkBAQDzAQAhnAFAAIICACGdAUAAggIAIacBAQDzAQAhqAEBAPMBACGpAQEA8wEAIQWJAQEAAAABiwEBAAAAAZwBQAAAAAGeAQEAAAABnwECAAAAAQIAAABiACAaAAD-AgAgBgYAAJECACCJAQEAAAABmgEBAAAAAZsBAQAAAAGcAUAAAAABnQFAAAAAAQIAAAALACAaAACAAwAgAwAAAGUAIBoAAP4CACAbAACEAwAgBwAAAGUAIBMAAIQDACCJAQEA8wEAIYsBAQDzAQAhnAFAAIICACGeAQEA8wEAIZ8BAgCYAgAhBYkBAQDzAQAhiwEBAPMBACGcAUAAggIAIZ4BAQDzAQAhnwECAJgCACEDAAAACQAgGgAAgAMAIBsAAIcDACAIAAAACQAgBgAAgwIAIBMAAIcDACCJAQEA8wEAIZoBAQDzAQAhmwEBAPUBACGcAUAAggIAIZ0BQACCAgAhBgYAAIMCACCJAQEA8wEAIZoBAQDzAQAhmwEBAPUBACGcAUAAggIAIZ0BQACCAgAhCQQAAOACACAFAADhAgAgCwAA4gIAIIkBAQAAAAGcAUAAAAABnQFAAAAAAacBAQAAAAGoAQEAAAABqQEBAAAAAQIAAAABACAaAACIAwAgAwAAAA0AIBoAAIgDACAbAACMAwAgCwAAAA0AIAQAALMCACAFAAC0AgAgCwAAtQIAIBMAAIwDACCJAQEA8wEAIZwBQACCAgAhnQFAAIICACGnAQEA8wEAIagBAQDzAQAhqQEBAPMBACEJBAAAswIAIAUAALQCACALAAC1AgAgiQEBAPMBACGcAUAAggIAIZ0BQACCAgAhpwEBAPMBACGoAQEA8wEAIakBAQDzAQAhBQQGAgUIAwgACgsMBA0ZCQEDAAEBAwABAwYOAQgACAoSBQIHAAQJAAYCBxMFCAAHAQcUAAEKFQABDBoBAwQbAAscAA0dAAAAAAMIAA8gABAhABEAAAADCAAPIAAQIQARAQMAAQEDAAEDCAAWIAAXIQAYAAAAAwgAFiAAFyEAGAEDAAEBAwABAwgAHSAAHiEAHwAAAAMIAB0gAB4hAB8AAAUIACQgACchAChSACVTACYAAAAAAAUIACQgACchAChSACVTACYBBoUBAQEGiwEBAwgALSAALiEALwAAAAMIAC0gAC4hAC8CBwAECQAGAgcABAkABgMIADQgADUhADYAAAADCAA0IAA1IQA2AQyzAQEBDLkBAQMIADsgADwhAD0AAAADCAA7IAA8IQA9DgIBDx4BECABESEBEiIBFCQBFSYLFicMFykBGCsLGSwNHC0BHS4BHi8LIjIOIzMSJDQCJTUCJjYCJzcCKDgCKToCKjwLKz0TLD8CLUELLkIUL0MCMEQCMUULMkgVM0kZNEsDNUwDNk4DN08DOFADOVIDOlQLO1UaPFcDPVkLPlobP1sDQFwDQV0LQmAcQ2EgRGMGRWQGRmcGR2gGSGkGSWsGSm0LS24hTHAGTXILTnMiT3QGUHUGUXYLVHkjVXopVnsEV3wEWH0EWX4EWn8EW4EBBFyDAQtdhAEqXocBBF-JAQtgigErYYwBBGKNAQRjjgELZJEBLGWSATBmkwEFZ5QBBWiVAQVplgEFapcBBWuZAQVsmwELbZwBMW6eAQVvoAELcKEBMnGiAQVyowEFc6QBC3SnATN1qAE3dqkBCXeqAQl4qwEJeawBCXqtAQl7rwEJfLEBC32yATh-tQEJf7cBC4ABuAE5gQG6AQmCAbsBCYMBvAELhAG_ATqFAcABPg"
}
async function decodeBase64AsWasm(wasmBase64: string): Promise {
diff --git a/server/prisma/generated-client/internal/prismaNamespace.ts b/server/prisma/generated-client/internal/prismaNamespace.ts
index d31767e..c5c5f1e 100644
--- a/server/prisma/generated-client/internal/prismaNamespace.ts
+++ b/server/prisma/generated-client/internal/prismaNamespace.ts
@@ -1,4 +1,3 @@
-
/* !!! This is code generated by Prisma. Do not edit directly. !!! */
/* eslint-disable */
// biome-ignore-all lint: generated file
@@ -8,7 +7,7 @@
*
* 🛑 Under no circumstances should you import this file directly! 🛑
*
- * All exports from this file are wrapped under a `Prisma` namespace object in the client.ts file.
+ * All exports from this file are wrapped under a `Prisma` namespace object in the Client.ts file.
* While this enables partial backward compatibility, it is not part of the stable public API.
*
* If you are looking for your Models, Enums, and Input Types, please import them from the respective
@@ -1026,6 +1025,7 @@ export type MessageAttachmentScalarFieldEnum = (typeof MessageAttachmentScalarFi
export const ChannelScalarFieldEnum = {
id: 'id',
+ ownerId: 'ownerId',
name: 'name',
persistent: 'persistent'
} as const
diff --git a/server/prisma/generated-client/internal/prismaNamespaceBrowser.ts b/server/prisma/generated-client/internal/prismaNamespaceBrowser.ts
index 686f044..d5cce3a 100644
--- a/server/prisma/generated-client/internal/prismaNamespaceBrowser.ts
+++ b/server/prisma/generated-client/internal/prismaNamespaceBrowser.ts
@@ -135,6 +135,7 @@ export type MessageAttachmentScalarFieldEnum = (typeof MessageAttachmentScalarFi
export const ChannelScalarFieldEnum = {
id: 'id',
+ ownerId: 'ownerId',
name: 'name',
persistent: 'persistent'
} as const
diff --git a/server/prisma/generated-client/models/Channel.ts b/server/prisma/generated-client/models/Channel.ts
index beed861..483aba2 100644
--- a/server/prisma/generated-client/models/Channel.ts
+++ b/server/prisma/generated-client/models/Channel.ts
@@ -26,18 +26,21 @@ export type AggregateChannel = {
export type ChannelMinAggregateOutputType = {
id: string | null
+ ownerId: string | null
name: string | null
persistent: boolean | null
}
export type ChannelMaxAggregateOutputType = {
id: string | null
+ ownerId: string | null
name: string | null
persistent: boolean | null
}
export type ChannelCountAggregateOutputType = {
id: number
+ ownerId: number
name: number
persistent: number
_all: number
@@ -46,18 +49,21 @@ export type ChannelCountAggregateOutputType = {
export type ChannelMinAggregateInputType = {
id?: true
+ ownerId?: true
name?: true
persistent?: true
}
export type ChannelMaxAggregateInputType = {
id?: true
+ ownerId?: true
name?: true
persistent?: true
}
export type ChannelCountAggregateInputType = {
id?: true
+ ownerId?: true
name?: true
persistent?: true
_all?: true
@@ -137,6 +143,7 @@ export type ChannelGroupByArgs | string
+ ownerId?: Prisma.StringNullableFilter<"Channel"> | string | null
name?: Prisma.StringFilter<"Channel"> | string
persistent?: Prisma.BoolFilter<"Channel"> | boolean
+ owner?: Prisma.XOR | null
}
export type ChannelOrderByWithRelationInput = {
id?: Prisma.SortOrder
+ ownerId?: Prisma.SortOrderInput | Prisma.SortOrder
name?: Prisma.SortOrder
persistent?: Prisma.SortOrder
+ owner?: Prisma.UserOrderByWithRelationInput
}
export type ChannelWhereUniqueInput = Prisma.AtLeast<{
@@ -179,12 +190,15 @@ export type ChannelWhereUniqueInput = Prisma.AtLeast<{
AND?: Prisma.ChannelWhereInput | Prisma.ChannelWhereInput[]
OR?: Prisma.ChannelWhereInput[]
NOT?: Prisma.ChannelWhereInput | Prisma.ChannelWhereInput[]
+ ownerId?: Prisma.StringNullableFilter<"Channel"> | string | null
name?: Prisma.StringFilter<"Channel"> | string
persistent?: Prisma.BoolFilter<"Channel"> | boolean
+ owner?: Prisma.XOR | null
}, "id">
export type ChannelOrderByWithAggregationInput = {
id?: Prisma.SortOrder
+ ownerId?: Prisma.SortOrderInput | Prisma.SortOrder
name?: Prisma.SortOrder
persistent?: Prisma.SortOrder
_count?: Prisma.ChannelCountOrderByAggregateInput
@@ -197,6 +211,7 @@ export type ChannelScalarWhereWithAggregatesInput = {
OR?: Prisma.ChannelScalarWhereWithAggregatesInput[]
NOT?: Prisma.ChannelScalarWhereWithAggregatesInput | Prisma.ChannelScalarWhereWithAggregatesInput[]
id?: Prisma.StringWithAggregatesFilter<"Channel"> | string
+ ownerId?: Prisma.StringNullableWithAggregatesFilter<"Channel"> | string | null
name?: Prisma.StringWithAggregatesFilter<"Channel"> | string
persistent?: Prisma.BoolWithAggregatesFilter<"Channel"> | boolean
}
@@ -205,10 +220,12 @@ export type ChannelCreateInput = {
id?: string
name: string
persistent: boolean
+ owner?: Prisma.UserCreateNestedOneWithoutChannelsInput
}
export type ChannelUncheckedCreateInput = {
id?: string
+ ownerId?: string | null
name: string
persistent: boolean
}
@@ -217,16 +234,19 @@ export type ChannelUpdateInput = {
id?: Prisma.StringFieldUpdateOperationsInput | string
name?: Prisma.StringFieldUpdateOperationsInput | string
persistent?: Prisma.BoolFieldUpdateOperationsInput | boolean
+ owner?: Prisma.UserUpdateOneWithoutChannelsNestedInput
}
export type ChannelUncheckedUpdateInput = {
id?: Prisma.StringFieldUpdateOperationsInput | string
+ ownerId?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
name?: Prisma.StringFieldUpdateOperationsInput | string
persistent?: Prisma.BoolFieldUpdateOperationsInput | boolean
}
export type ChannelCreateManyInput = {
id?: string
+ ownerId?: string | null
name: string
persistent: boolean
}
@@ -239,65 +259,211 @@ export type ChannelUpdateManyMutationInput = {
export type ChannelUncheckedUpdateManyInput = {
id?: Prisma.StringFieldUpdateOperationsInput | string
+ ownerId?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
name?: Prisma.StringFieldUpdateOperationsInput | string
persistent?: Prisma.BoolFieldUpdateOperationsInput | boolean
}
+export type ChannelListRelationFilter = {
+ every?: Prisma.ChannelWhereInput
+ some?: Prisma.ChannelWhereInput
+ none?: Prisma.ChannelWhereInput
+}
+
+export type ChannelOrderByRelationAggregateInput = {
+ _count?: Prisma.SortOrder
+}
+
export type ChannelCountOrderByAggregateInput = {
id?: Prisma.SortOrder
+ ownerId?: Prisma.SortOrder
name?: Prisma.SortOrder
persistent?: Prisma.SortOrder
}
export type ChannelMaxOrderByAggregateInput = {
id?: Prisma.SortOrder
+ ownerId?: Prisma.SortOrder
name?: Prisma.SortOrder
persistent?: Prisma.SortOrder
}
export type ChannelMinOrderByAggregateInput = {
id?: Prisma.SortOrder
+ ownerId?: Prisma.SortOrder
name?: Prisma.SortOrder
persistent?: Prisma.SortOrder
}
+export type ChannelCreateNestedManyWithoutOwnerInput = {
+ create?: Prisma.XOR | Prisma.ChannelCreateWithoutOwnerInput[] | Prisma.ChannelUncheckedCreateWithoutOwnerInput[]
+ connectOrCreate?: Prisma.ChannelCreateOrConnectWithoutOwnerInput | Prisma.ChannelCreateOrConnectWithoutOwnerInput[]
+ createMany?: Prisma.ChannelCreateManyOwnerInputEnvelope
+ connect?: Prisma.ChannelWhereUniqueInput | Prisma.ChannelWhereUniqueInput[]
+}
+
+export type ChannelUncheckedCreateNestedManyWithoutOwnerInput = {
+ create?: Prisma.XOR | Prisma.ChannelCreateWithoutOwnerInput[] | Prisma.ChannelUncheckedCreateWithoutOwnerInput[]
+ connectOrCreate?: Prisma.ChannelCreateOrConnectWithoutOwnerInput | Prisma.ChannelCreateOrConnectWithoutOwnerInput[]
+ createMany?: Prisma.ChannelCreateManyOwnerInputEnvelope
+ connect?: Prisma.ChannelWhereUniqueInput | Prisma.ChannelWhereUniqueInput[]
+}
+
+export type ChannelUpdateManyWithoutOwnerNestedInput = {
+ create?: Prisma.XOR | Prisma.ChannelCreateWithoutOwnerInput[] | Prisma.ChannelUncheckedCreateWithoutOwnerInput[]
+ connectOrCreate?: Prisma.ChannelCreateOrConnectWithoutOwnerInput | Prisma.ChannelCreateOrConnectWithoutOwnerInput[]
+ upsert?: Prisma.ChannelUpsertWithWhereUniqueWithoutOwnerInput | Prisma.ChannelUpsertWithWhereUniqueWithoutOwnerInput[]
+ createMany?: Prisma.ChannelCreateManyOwnerInputEnvelope
+ set?: Prisma.ChannelWhereUniqueInput | Prisma.ChannelWhereUniqueInput[]
+ disconnect?: Prisma.ChannelWhereUniqueInput | Prisma.ChannelWhereUniqueInput[]
+ delete?: Prisma.ChannelWhereUniqueInput | Prisma.ChannelWhereUniqueInput[]
+ connect?: Prisma.ChannelWhereUniqueInput | Prisma.ChannelWhereUniqueInput[]
+ update?: Prisma.ChannelUpdateWithWhereUniqueWithoutOwnerInput | Prisma.ChannelUpdateWithWhereUniqueWithoutOwnerInput[]
+ updateMany?: Prisma.ChannelUpdateManyWithWhereWithoutOwnerInput | Prisma.ChannelUpdateManyWithWhereWithoutOwnerInput[]
+ deleteMany?: Prisma.ChannelScalarWhereInput | Prisma.ChannelScalarWhereInput[]
+}
+
+export type ChannelUncheckedUpdateManyWithoutOwnerNestedInput = {
+ create?: Prisma.XOR | Prisma.ChannelCreateWithoutOwnerInput[] | Prisma.ChannelUncheckedCreateWithoutOwnerInput[]
+ connectOrCreate?: Prisma.ChannelCreateOrConnectWithoutOwnerInput | Prisma.ChannelCreateOrConnectWithoutOwnerInput[]
+ upsert?: Prisma.ChannelUpsertWithWhereUniqueWithoutOwnerInput | Prisma.ChannelUpsertWithWhereUniqueWithoutOwnerInput[]
+ createMany?: Prisma.ChannelCreateManyOwnerInputEnvelope
+ set?: Prisma.ChannelWhereUniqueInput | Prisma.ChannelWhereUniqueInput[]
+ disconnect?: Prisma.ChannelWhereUniqueInput | Prisma.ChannelWhereUniqueInput[]
+ delete?: Prisma.ChannelWhereUniqueInput | Prisma.ChannelWhereUniqueInput[]
+ connect?: Prisma.ChannelWhereUniqueInput | Prisma.ChannelWhereUniqueInput[]
+ update?: Prisma.ChannelUpdateWithWhereUniqueWithoutOwnerInput | Prisma.ChannelUpdateWithWhereUniqueWithoutOwnerInput[]
+ updateMany?: Prisma.ChannelUpdateManyWithWhereWithoutOwnerInput | Prisma.ChannelUpdateManyWithWhereWithoutOwnerInput[]
+ deleteMany?: Prisma.ChannelScalarWhereInput | Prisma.ChannelScalarWhereInput[]
+}
+
export type BoolFieldUpdateOperationsInput = {
set?: boolean
}
+export type ChannelCreateWithoutOwnerInput = {
+ id?: string
+ name: string
+ persistent: boolean
+}
+
+export type ChannelUncheckedCreateWithoutOwnerInput = {
+ id?: string
+ name: string
+ persistent: boolean
+}
+
+export type ChannelCreateOrConnectWithoutOwnerInput = {
+ where: Prisma.ChannelWhereUniqueInput
+ create: Prisma.XOR
+}
+
+export type ChannelCreateManyOwnerInputEnvelope = {
+ data: Prisma.ChannelCreateManyOwnerInput | Prisma.ChannelCreateManyOwnerInput[]
+}
+
+export type ChannelUpsertWithWhereUniqueWithoutOwnerInput = {
+ where: Prisma.ChannelWhereUniqueInput
+ update: Prisma.XOR
+ create: Prisma.XOR
+}
+
+export type ChannelUpdateWithWhereUniqueWithoutOwnerInput = {
+ where: Prisma.ChannelWhereUniqueInput
+ data: Prisma.XOR
+}
+
+export type ChannelUpdateManyWithWhereWithoutOwnerInput = {
+ where: Prisma.ChannelScalarWhereInput
+ data: Prisma.XOR
+}
+
+export type ChannelScalarWhereInput = {
+ AND?: Prisma.ChannelScalarWhereInput | Prisma.ChannelScalarWhereInput[]
+ OR?: Prisma.ChannelScalarWhereInput[]
+ NOT?: Prisma.ChannelScalarWhereInput | Prisma.ChannelScalarWhereInput[]
+ id?: Prisma.StringFilter<"Channel"> | string
+ ownerId?: Prisma.StringNullableFilter<"Channel"> | string | null
+ name?: Prisma.StringFilter<"Channel"> | string
+ persistent?: Prisma.BoolFilter<"Channel"> | boolean
+}
+
+export type ChannelCreateManyOwnerInput = {
+ id?: string
+ name: string
+ persistent: boolean
+}
+
+export type ChannelUpdateWithoutOwnerInput = {
+ id?: Prisma.StringFieldUpdateOperationsInput | string
+ name?: Prisma.StringFieldUpdateOperationsInput | string
+ persistent?: Prisma.BoolFieldUpdateOperationsInput | boolean
+}
+
+export type ChannelUncheckedUpdateWithoutOwnerInput = {
+ id?: Prisma.StringFieldUpdateOperationsInput | string
+ name?: Prisma.StringFieldUpdateOperationsInput | string
+ persistent?: Prisma.BoolFieldUpdateOperationsInput | boolean
+}
+
+export type ChannelUncheckedUpdateManyWithoutOwnerInput = {
+ id?: Prisma.StringFieldUpdateOperationsInput | string
+ name?: Prisma.StringFieldUpdateOperationsInput | string
+ persistent?: Prisma.BoolFieldUpdateOperationsInput | boolean
+}
+
export type ChannelSelect = runtime.Types.Extensions.GetSelect<{
id?: boolean
+ ownerId?: boolean
name?: boolean
persistent?: boolean
+ owner?: boolean | Prisma.Channel$ownerArgs
}, ExtArgs["result"]["channel"]>
export type ChannelSelectCreateManyAndReturn = runtime.Types.Extensions.GetSelect<{
id?: boolean
+ ownerId?: boolean
name?: boolean
persistent?: boolean
+ owner?: boolean | Prisma.Channel$ownerArgs
}, ExtArgs["result"]["channel"]>
export type ChannelSelectUpdateManyAndReturn = runtime.Types.Extensions.GetSelect<{
id?: boolean
+ ownerId?: boolean
name?: boolean
persistent?: boolean
+ owner?: boolean | Prisma.Channel$ownerArgs
}, ExtArgs["result"]["channel"]>
export type ChannelSelectScalar = {
id?: boolean
+ ownerId?: boolean
name?: boolean
persistent?: boolean
}
-export type ChannelOmit = runtime.Types.Extensions.GetOmit<"id" | "name" | "persistent", ExtArgs["result"]["channel"]>
+export type ChannelOmit = runtime.Types.Extensions.GetOmit<"id" | "ownerId" | "name" | "persistent", ExtArgs["result"]["channel"]>
+export type ChannelInclude = {
+ owner?: boolean | Prisma.Channel$ownerArgs
+}
+export type ChannelIncludeCreateManyAndReturn = {
+ owner?: boolean | Prisma.Channel$ownerArgs
+}
+export type ChannelIncludeUpdateManyAndReturn = {
+ owner?: boolean | Prisma.Channel$ownerArgs
+}
export type $ChannelPayload = {
name: "Channel"
- objects: {}
+ objects: {
+ owner: Prisma.$UserPayload | null
+ }
scalars: runtime.Types.Extensions.GetPayloadResult<{
id: string
+ ownerId: string | null
name: string
persistent: boolean
}, ExtArgs["result"]["channel"]>
@@ -694,6 +860,7 @@ readonly fields: ChannelFieldRefs;
*/
export interface Prisma__ChannelClient extends Prisma.PrismaPromise {
readonly [Symbol.toStringTag]: "PrismaPromise"
+ owner = {}>(args?: Prisma.Subset>): Prisma.Prisma__UserClient, T, "findUniqueOrThrow", GlobalOmitOptions> | null, null, ExtArgs, GlobalOmitOptions>
/**
* Attaches callbacks for the resolution and/or rejection of the Promise.
* @param onfulfilled The callback to execute when the Promise is resolved.
@@ -724,6 +891,7 @@ export interface Prisma__ChannelClient
+ readonly ownerId: Prisma.FieldRef<"Channel", 'String'>
readonly name: Prisma.FieldRef<"Channel", 'String'>
readonly persistent: Prisma.FieldRef<"Channel", 'Boolean'>
}
@@ -742,6 +910,10 @@ export type ChannelFindUniqueArgs | null
+ /**
+ * Choose, which related nodes to fetch as well
+ */
+ include?: Prisma.ChannelInclude | null
/**
* Filter, which Channel to fetch.
*/
@@ -760,6 +932,10 @@ export type ChannelFindUniqueOrThrowArgs | null
+ /**
+ * Choose, which related nodes to fetch as well
+ */
+ include?: Prisma.ChannelInclude | null
/**
* Filter, which Channel to fetch.
*/
@@ -778,6 +954,10 @@ export type ChannelFindFirstArgs | null
+ /**
+ * Choose, which related nodes to fetch as well
+ */
+ include?: Prisma.ChannelInclude | null
/**
* Filter, which Channel to fetch.
*/
@@ -826,6 +1006,10 @@ export type ChannelFindFirstOrThrowArgs | null
+ /**
+ * Choose, which related nodes to fetch as well
+ */
+ include?: Prisma.ChannelInclude | null
/**
* Filter, which Channel to fetch.
*/
@@ -874,6 +1058,10 @@ export type ChannelFindManyArgs | null
+ /**
+ * Choose, which related nodes to fetch as well
+ */
+ include?: Prisma.ChannelInclude | null
/**
* Filter, which Channels to fetch.
*/
@@ -922,6 +1110,10 @@ export type ChannelCreateArgs | null
+ /**
+ * Choose, which related nodes to fetch as well
+ */
+ include?: Prisma.ChannelInclude | null
/**
* The data needed to create a Channel.
*/
@@ -954,6 +1146,10 @@ export type ChannelCreateManyAndReturnArgs | null
}
/**
@@ -968,6 +1164,10 @@ export type ChannelUpdateArgs | null
+ /**
+ * Choose, which related nodes to fetch as well
+ */
+ include?: Prisma.ChannelInclude | null
/**
* The data needed to update a Channel.
*/
@@ -1020,6 +1220,10 @@ export type ChannelUpdateManyAndReturnArgs | null
}
/**
@@ -1034,6 +1238,10 @@ export type ChannelUpsertArgs | null
+ /**
+ * Choose, which related nodes to fetch as well
+ */
+ include?: Prisma.ChannelInclude | null
/**
* The filter to search for the Channel to update in case it exists.
*/
@@ -1060,6 +1268,10 @@ export type ChannelDeleteArgs | null
+ /**
+ * Choose, which related nodes to fetch as well
+ */
+ include?: Prisma.ChannelInclude | null
/**
* Filter which Channel to delete.
*/
@@ -1080,6 +1292,25 @@ export type ChannelDeleteManyArgs = {
+ /**
+ * Select specific fields to fetch from the User
+ */
+ select?: Prisma.UserSelect | null
+ /**
+ * Omit specific fields from the User
+ */
+ omit?: Prisma.UserOmit | null
+ /**
+ * Choose, which related nodes to fetch as well
+ */
+ include?: Prisma.UserInclude | null
+ where?: Prisma.UserWhereInput
+}
+
/**
* Channel without action
*/
@@ -1092,4 +1323,8 @@ export type ChannelDefaultArgs | null
+ /**
+ * Choose, which related nodes to fetch as well
+ */
+ include?: Prisma.ChannelInclude | null
}
diff --git a/server/prisma/generated-client/models/User.ts b/server/prisma/generated-client/models/User.ts
index 79bc323..87c64e1 100644
--- a/server/prisma/generated-client/models/User.ts
+++ b/server/prisma/generated-client/models/User.ts
@@ -193,6 +193,7 @@ export type UserWhereInput = {
Session?: Prisma.SessionListRelationFilter
UserPreferences?: Prisma.XOR | null
Messages?: Prisma.MessageListRelationFilter
+ Channels?: Prisma.ChannelListRelationFilter
}
export type UserOrderByWithRelationInput = {
@@ -205,6 +206,7 @@ export type UserOrderByWithRelationInput = {
Session?: Prisma.SessionOrderByRelationAggregateInput
UserPreferences?: Prisma.UserPreferencesOrderByWithRelationInput
Messages?: Prisma.MessageOrderByRelationAggregateInput
+ Channels?: Prisma.ChannelOrderByRelationAggregateInput
}
export type UserWhereUniqueInput = Prisma.AtLeast<{
@@ -220,6 +222,7 @@ export type UserWhereUniqueInput = Prisma.AtLeast<{
Session?: Prisma.SessionListRelationFilter
UserPreferences?: Prisma.XOR | null
Messages?: Prisma.MessageListRelationFilter
+ Channels?: Prisma.ChannelListRelationFilter
}, "id" | "username">
export type UserOrderByWithAggregationInput = {
@@ -256,6 +259,7 @@ export type UserCreateInput = {
Session?: Prisma.SessionCreateNestedManyWithoutUserInput
UserPreferences?: Prisma.UserPreferencesCreateNestedOneWithoutUserInput
Messages?: Prisma.MessageCreateNestedManyWithoutSenderInput
+ Channels?: Prisma.ChannelCreateNestedManyWithoutOwnerInput
}
export type UserUncheckedCreateInput = {
@@ -268,6 +272,7 @@ export type UserUncheckedCreateInput = {
Session?: Prisma.SessionUncheckedCreateNestedManyWithoutUserInput
UserPreferences?: Prisma.UserPreferencesUncheckedCreateNestedOneWithoutUserInput
Messages?: Prisma.MessageUncheckedCreateNestedManyWithoutSenderInput
+ Channels?: Prisma.ChannelUncheckedCreateNestedManyWithoutOwnerInput
}
export type UserUpdateInput = {
@@ -280,6 +285,7 @@ export type UserUpdateInput = {
Session?: Prisma.SessionUpdateManyWithoutUserNestedInput
UserPreferences?: Prisma.UserPreferencesUpdateOneWithoutUserNestedInput
Messages?: Prisma.MessageUpdateManyWithoutSenderNestedInput
+ Channels?: Prisma.ChannelUpdateManyWithoutOwnerNestedInput
}
export type UserUncheckedUpdateInput = {
@@ -292,6 +298,7 @@ export type UserUncheckedUpdateInput = {
Session?: Prisma.SessionUncheckedUpdateManyWithoutUserNestedInput
UserPreferences?: Prisma.UserPreferencesUncheckedUpdateOneWithoutUserNestedInput
Messages?: Prisma.MessageUncheckedUpdateManyWithoutSenderNestedInput
+ Channels?: Prisma.ChannelUncheckedUpdateManyWithoutOwnerNestedInput
}
export type UserCreateManyInput = {
@@ -410,6 +417,22 @@ export type UserUpdateOneWithoutMessagesNestedInput = {
update?: Prisma.XOR, Prisma.UserUncheckedUpdateWithoutMessagesInput>
}
+export type UserCreateNestedOneWithoutChannelsInput = {
+ create?: Prisma.XOR
+ connectOrCreate?: Prisma.UserCreateOrConnectWithoutChannelsInput
+ connect?: Prisma.UserWhereUniqueInput
+}
+
+export type UserUpdateOneWithoutChannelsNestedInput = {
+ create?: Prisma.XOR
+ connectOrCreate?: Prisma.UserCreateOrConnectWithoutChannelsInput
+ upsert?: Prisma.UserUpsertWithoutChannelsInput
+ disconnect?: Prisma.UserWhereInput | boolean
+ delete?: Prisma.UserWhereInput | boolean
+ connect?: Prisma.UserWhereUniqueInput
+ update?: Prisma.XOR, Prisma.UserUncheckedUpdateWithoutChannelsInput>
+}
+
export type UserCreateWithoutSessionInput = {
id?: string
username: string
@@ -419,6 +442,7 @@ export type UserCreateWithoutSessionInput = {
updatedAt?: Date | string
UserPreferences?: Prisma.UserPreferencesCreateNestedOneWithoutUserInput
Messages?: Prisma.MessageCreateNestedManyWithoutSenderInput
+ Channels?: Prisma.ChannelCreateNestedManyWithoutOwnerInput
}
export type UserUncheckedCreateWithoutSessionInput = {
@@ -430,6 +454,7 @@ export type UserUncheckedCreateWithoutSessionInput = {
updatedAt?: Date | string
UserPreferences?: Prisma.UserPreferencesUncheckedCreateNestedOneWithoutUserInput
Messages?: Prisma.MessageUncheckedCreateNestedManyWithoutSenderInput
+ Channels?: Prisma.ChannelUncheckedCreateNestedManyWithoutOwnerInput
}
export type UserCreateOrConnectWithoutSessionInput = {
@@ -457,6 +482,7 @@ export type UserUpdateWithoutSessionInput = {
updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
UserPreferences?: Prisma.UserPreferencesUpdateOneWithoutUserNestedInput
Messages?: Prisma.MessageUpdateManyWithoutSenderNestedInput
+ Channels?: Prisma.ChannelUpdateManyWithoutOwnerNestedInput
}
export type UserUncheckedUpdateWithoutSessionInput = {
@@ -468,6 +494,7 @@ export type UserUncheckedUpdateWithoutSessionInput = {
updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
UserPreferences?: Prisma.UserPreferencesUncheckedUpdateOneWithoutUserNestedInput
Messages?: Prisma.MessageUncheckedUpdateManyWithoutSenderNestedInput
+ Channels?: Prisma.ChannelUncheckedUpdateManyWithoutOwnerNestedInput
}
export type UserCreateWithoutUserPreferencesInput = {
@@ -479,6 +506,7 @@ export type UserCreateWithoutUserPreferencesInput = {
updatedAt?: Date | string
Session?: Prisma.SessionCreateNestedManyWithoutUserInput
Messages?: Prisma.MessageCreateNestedManyWithoutSenderInput
+ Channels?: Prisma.ChannelCreateNestedManyWithoutOwnerInput
}
export type UserUncheckedCreateWithoutUserPreferencesInput = {
@@ -490,6 +518,7 @@ export type UserUncheckedCreateWithoutUserPreferencesInput = {
updatedAt?: Date | string
Session?: Prisma.SessionUncheckedCreateNestedManyWithoutUserInput
Messages?: Prisma.MessageUncheckedCreateNestedManyWithoutSenderInput
+ Channels?: Prisma.ChannelUncheckedCreateNestedManyWithoutOwnerInput
}
export type UserCreateOrConnectWithoutUserPreferencesInput = {
@@ -517,6 +546,7 @@ export type UserUpdateWithoutUserPreferencesInput = {
updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
Session?: Prisma.SessionUpdateManyWithoutUserNestedInput
Messages?: Prisma.MessageUpdateManyWithoutSenderNestedInput
+ Channels?: Prisma.ChannelUpdateManyWithoutOwnerNestedInput
}
export type UserUncheckedUpdateWithoutUserPreferencesInput = {
@@ -528,6 +558,7 @@ export type UserUncheckedUpdateWithoutUserPreferencesInput = {
updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
Session?: Prisma.SessionUncheckedUpdateManyWithoutUserNestedInput
Messages?: Prisma.MessageUncheckedUpdateManyWithoutSenderNestedInput
+ Channels?: Prisma.ChannelUncheckedUpdateManyWithoutOwnerNestedInput
}
export type UserCreateWithoutMessagesInput = {
@@ -539,6 +570,7 @@ export type UserCreateWithoutMessagesInput = {
updatedAt?: Date | string
Session?: Prisma.SessionCreateNestedManyWithoutUserInput
UserPreferences?: Prisma.UserPreferencesCreateNestedOneWithoutUserInput
+ Channels?: Prisma.ChannelCreateNestedManyWithoutOwnerInput
}
export type UserUncheckedCreateWithoutMessagesInput = {
@@ -550,6 +582,7 @@ export type UserUncheckedCreateWithoutMessagesInput = {
updatedAt?: Date | string
Session?: Prisma.SessionUncheckedCreateNestedManyWithoutUserInput
UserPreferences?: Prisma.UserPreferencesUncheckedCreateNestedOneWithoutUserInput
+ Channels?: Prisma.ChannelUncheckedCreateNestedManyWithoutOwnerInput
}
export type UserCreateOrConnectWithoutMessagesInput = {
@@ -577,6 +610,7 @@ export type UserUpdateWithoutMessagesInput = {
updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
Session?: Prisma.SessionUpdateManyWithoutUserNestedInput
UserPreferences?: Prisma.UserPreferencesUpdateOneWithoutUserNestedInput
+ Channels?: Prisma.ChannelUpdateManyWithoutOwnerNestedInput
}
export type UserUncheckedUpdateWithoutMessagesInput = {
@@ -588,6 +622,71 @@ export type UserUncheckedUpdateWithoutMessagesInput = {
updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
Session?: Prisma.SessionUncheckedUpdateManyWithoutUserNestedInput
UserPreferences?: Prisma.UserPreferencesUncheckedUpdateOneWithoutUserNestedInput
+ Channels?: Prisma.ChannelUncheckedUpdateManyWithoutOwnerNestedInput
+}
+
+export type UserCreateWithoutChannelsInput = {
+ id?: string
+ username: string
+ password: string
+ displayName: string
+ createdAt?: Date | string
+ updatedAt?: Date | string
+ Session?: Prisma.SessionCreateNestedManyWithoutUserInput
+ UserPreferences?: Prisma.UserPreferencesCreateNestedOneWithoutUserInput
+ Messages?: Prisma.MessageCreateNestedManyWithoutSenderInput
+}
+
+export type UserUncheckedCreateWithoutChannelsInput = {
+ id?: string
+ username: string
+ password: string
+ displayName: string
+ createdAt?: Date | string
+ updatedAt?: Date | string
+ Session?: Prisma.SessionUncheckedCreateNestedManyWithoutUserInput
+ UserPreferences?: Prisma.UserPreferencesUncheckedCreateNestedOneWithoutUserInput
+ Messages?: Prisma.MessageUncheckedCreateNestedManyWithoutSenderInput
+}
+
+export type UserCreateOrConnectWithoutChannelsInput = {
+ where: Prisma.UserWhereUniqueInput
+ create: Prisma.XOR
+}
+
+export type UserUpsertWithoutChannelsInput = {
+ update: Prisma.XOR
+ create: Prisma.XOR
+ where?: Prisma.UserWhereInput
+}
+
+export type UserUpdateToOneWithWhereWithoutChannelsInput = {
+ where?: Prisma.UserWhereInput
+ data: Prisma.XOR
+}
+
+export type UserUpdateWithoutChannelsInput = {
+ id?: Prisma.StringFieldUpdateOperationsInput | string
+ username?: Prisma.StringFieldUpdateOperationsInput | string
+ password?: Prisma.StringFieldUpdateOperationsInput | string
+ displayName?: Prisma.StringFieldUpdateOperationsInput | string
+ createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
+ updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
+ Session?: Prisma.SessionUpdateManyWithoutUserNestedInput
+ UserPreferences?: Prisma.UserPreferencesUpdateOneWithoutUserNestedInput
+ Messages?: Prisma.MessageUpdateManyWithoutSenderNestedInput
+}
+
+export type UserUncheckedUpdateWithoutChannelsInput = {
+ id?: Prisma.StringFieldUpdateOperationsInput | string
+ username?: Prisma.StringFieldUpdateOperationsInput | string
+ password?: Prisma.StringFieldUpdateOperationsInput | string
+ displayName?: Prisma.StringFieldUpdateOperationsInput | string
+ createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
+ updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
+ Session?: Prisma.SessionUncheckedUpdateManyWithoutUserNestedInput
+ UserPreferences?: Prisma.UserPreferencesUncheckedUpdateOneWithoutUserNestedInput
+ Messages?: Prisma.MessageUncheckedUpdateManyWithoutSenderNestedInput
}
@@ -598,11 +697,13 @@ export type UserUncheckedUpdateWithoutMessagesInput = {
export type UserCountOutputType = {
Session: number
Messages: number
+ Channels: number
}
export type UserCountOutputTypeSelect = {
Session?: boolean | UserCountOutputTypeCountSessionArgs
Messages?: boolean | UserCountOutputTypeCountMessagesArgs
+ Channels?: boolean | UserCountOutputTypeCountChannelsArgs
}
/**
@@ -629,6 +730,13 @@ export type UserCountOutputTypeCountMessagesArgs = {
+ where?: Prisma.ChannelWhereInput
+}
+
export type UserSelect = runtime.Types.Extensions.GetSelect<{
id?: boolean
@@ -640,6 +748,7 @@ export type UserSelect
UserPreferences?: boolean | Prisma.User$UserPreferencesArgs
Messages?: boolean | Prisma.User$MessagesArgs
+ Channels?: boolean | Prisma.User$ChannelsArgs
_count?: boolean | Prisma.UserCountOutputTypeDefaultArgs
}, ExtArgs["result"]["user"]>
@@ -675,6 +784,7 @@ export type UserInclude
UserPreferences?: boolean | Prisma.User$UserPreferencesArgs
Messages?: boolean | Prisma.User$MessagesArgs
+ Channels?: boolean | Prisma.User$ChannelsArgs
_count?: boolean | Prisma.UserCountOutputTypeDefaultArgs
}
export type UserIncludeCreateManyAndReturn = {}
@@ -686,6 +796,7 @@ export type $UserPayload[]
UserPreferences: Prisma.$UserPreferencesPayload | null
Messages: Prisma.$MessagePayload[]
+ Channels: Prisma.$ChannelPayload[]
}
scalars: runtime.Types.Extensions.GetPayloadResult<{
id: string
@@ -1091,6 +1202,7 @@ export interface Prisma__UserClient = {}>(args?: Prisma.Subset>): Prisma.PrismaPromise, T, "findMany", GlobalOmitOptions> | Null>
UserPreferences = {}>(args?: Prisma.Subset>): Prisma.Prisma__UserPreferencesClient, T, "findUniqueOrThrow", GlobalOmitOptions> | null, null, ExtArgs, GlobalOmitOptions>
Messages = {}>(args?: Prisma.Subset>): Prisma.PrismaPromise, T, "findMany", GlobalOmitOptions> | Null>
+ Channels = {}>(args?: Prisma.Subset>): Prisma.PrismaPromise, T, "findMany", GlobalOmitOptions> | Null>
/**
* Attaches callbacks for the resolution and/or rejection of the Promise.
* @param onfulfilled The callback to execute when the Promise is resolved.
@@ -1583,6 +1695,30 @@ export type User$MessagesArgs = {
+ /**
+ * Select specific fields to fetch from the Channel
+ */
+ select?: Prisma.ChannelSelect | null
+ /**
+ * Omit specific fields from the Channel
+ */
+ omit?: Prisma.ChannelOmit | null
+ /**
+ * Choose, which related nodes to fetch as well
+ */
+ include?: Prisma.ChannelInclude | null
+ where?: Prisma.ChannelWhereInput
+ orderBy?: Prisma.ChannelOrderByWithRelationInput | Prisma.ChannelOrderByWithRelationInput[]
+ cursor?: Prisma.ChannelWhereUniqueInput
+ take?: number
+ skip?: number
+ distinct?: Prisma.ChannelScalarFieldEnum | Prisma.ChannelScalarFieldEnum[]
+}
+
/**
* User without action
*/
diff --git a/server/prisma/migrations/20260426081554_channel_owner/migration.sql b/server/prisma/migrations/20260426081554_channel_owner/migration.sql
new file mode 100644
index 0000000..aa37587
--- /dev/null
+++ b/server/prisma/migrations/20260426081554_channel_owner/migration.sql
@@ -0,0 +1,20 @@
+/*
+ Warnings:
+
+ - Added the required column `ownerId` to the `Channel` table without a default value. This is not possible if the table is not empty.
+
+*/
+-- RedefineTables
+PRAGMA defer_foreign_keys=ON;
+PRAGMA foreign_keys=OFF;
+CREATE TABLE "new_Channel" (
+ "id" TEXT NOT NULL PRIMARY KEY,
+ "ownerId" TEXT NOT NULL,
+ "name" TEXT NOT NULL,
+ "persistent" BOOLEAN NOT NULL
+);
+INSERT INTO "new_Channel" ("id", "name", "persistent") SELECT "id", "name", "persistent" FROM "Channel";
+DROP TABLE "Channel";
+ALTER TABLE "new_Channel" RENAME TO "Channel";
+PRAGMA foreign_keys=ON;
+PRAGMA defer_foreign_keys=OFF;
diff --git a/server/prisma/migrations/20260426090520_channel_owner_relation/migration.sql b/server/prisma/migrations/20260426090520_channel_owner_relation/migration.sql
new file mode 100644
index 0000000..3ecc818
--- /dev/null
+++ b/server/prisma/migrations/20260426090520_channel_owner_relation/migration.sql
@@ -0,0 +1,15 @@
+-- RedefineTables
+PRAGMA defer_foreign_keys=ON;
+PRAGMA foreign_keys=OFF;
+CREATE TABLE "new_Channel" (
+ "id" TEXT NOT NULL PRIMARY KEY,
+ "ownerId" TEXT NOT NULL,
+ "name" TEXT NOT NULL,
+ "persistent" BOOLEAN NOT NULL,
+ CONSTRAINT "Channel_ownerId_fkey" FOREIGN KEY ("ownerId") REFERENCES "User" ("id") ON DELETE CASCADE ON UPDATE CASCADE
+);
+INSERT INTO "new_Channel" ("id", "name", "ownerId", "persistent") SELECT "id", "name", "ownerId", "persistent" FROM "Channel";
+DROP TABLE "Channel";
+ALTER TABLE "new_Channel" RENAME TO "Channel";
+PRAGMA foreign_keys=ON;
+PRAGMA defer_foreign_keys=OFF;
diff --git a/server/prisma/migrations/20260426090608_optional_channel_owner/migration.sql b/server/prisma/migrations/20260426090608_optional_channel_owner/migration.sql
new file mode 100644
index 0000000..9c9073a
--- /dev/null
+++ b/server/prisma/migrations/20260426090608_optional_channel_owner/migration.sql
@@ -0,0 +1,15 @@
+-- RedefineTables
+PRAGMA defer_foreign_keys=ON;
+PRAGMA foreign_keys=OFF;
+CREATE TABLE "new_Channel" (
+ "id" TEXT NOT NULL PRIMARY KEY,
+ "ownerId" TEXT,
+ "name" TEXT NOT NULL,
+ "persistent" BOOLEAN NOT NULL,
+ CONSTRAINT "Channel_ownerId_fkey" FOREIGN KEY ("ownerId") REFERENCES "User" ("id") ON DELETE CASCADE ON UPDATE CASCADE
+);
+INSERT INTO "new_Channel" ("id", "name", "ownerId", "persistent") SELECT "id", "name", "ownerId", "persistent" FROM "Channel";
+DROP TABLE "Channel";
+ALTER TABLE "new_Channel" RENAME TO "Channel";
+PRAGMA foreign_keys=ON;
+PRAGMA defer_foreign_keys=OFF;
diff --git a/server/prisma/schema.prisma b/server/prisma/schema.prisma
index f3ee444..c28a4d4 100644
--- a/server/prisma/schema.prisma
+++ b/server/prisma/schema.prisma
@@ -18,6 +18,7 @@ model User {
Session Session[]
UserPreferences UserPreferences?
Messages Message[]
+ Channels Channel[]
}
model Session {
@@ -70,7 +71,10 @@ model MessageAttachment {
}
model Channel {
- id String @id @default(uuid())
+ id String @id @default(uuid())
+ ownerId String?
name String
persistent Boolean
+
+ owner User? @relation(references: [id], fields: [ownerId], onDelete: Cascade)
}
\ No newline at end of file
diff --git a/server/routes/attachment.ts b/server/routes/attachment.ts
index a18ac18..b87d782 100644
--- a/server/routes/attachment.ts
+++ b/server/routes/attachment.ts
@@ -2,6 +2,8 @@ import type { FastifyPluginAsyncTypebox } from '@fastify/type-provider-typebox'
import * as fs from 'node:fs'
import * as path from 'node:path'
import { Type } from 'typebox'
+import { GetAttachmentParamsSchema } from '../plugins/schemas/attachment.ts'
+import { TypeboxRef } from '../utils/typebox-ref.ts'
const plugin: FastifyPluginAsyncTypebox = async (fastify) => {
const uploadDir = path.join(process.cwd(), 'uploads')
@@ -18,6 +20,7 @@ const plugin: FastifyPluginAsyncTypebox = async (fastify) => {
tags: ['Attachment'],
operationId: 'attachment.upload',
description: 'Pass file to multipart/form-data',
+ consumes: ['multipart/form-data'],
response: {
200: Type.String({ format: 'uuid', description: 'Attachment UUID' }),
},
@@ -62,9 +65,7 @@ const plugin: FastifyPluginAsyncTypebox = async (fastify) => {
summary: 'Get attachment',
tags: ['Attachment'],
operationId: 'attachment.get',
- params: Type.Object({
- id: Type.String({ format: 'uuid' }),
- }),
+ params: TypeboxRef(GetAttachmentParamsSchema),
response: {
200: Type.Any({ description: 'Attachment content' }),
},
diff --git a/server/routes/auth.ts b/server/routes/auth.ts
index a1c798f..fec8c27 100644
--- a/server/routes/auth.ts
+++ b/server/routes/auth.ts
@@ -1,7 +1,7 @@
import type { FastifyPluginAsyncTypebox } from '@fastify/type-provider-typebox'
import bcrypt from 'bcrypt'
-import { Type } from 'typebox'
-import { CreateUserSchema, UserSchema } from '../schemas/auth.ts'
+import { CreateUserPayloadSchema, LoginPayloadSchema, UserSchema } from '../plugins/schemas/auth.ts'
+import { TypeboxRef } from '../utils/typebox-ref.ts'
const plugin: FastifyPluginAsyncTypebox = async (fastify) => {
fastify.post(
@@ -11,9 +11,9 @@ const plugin: FastifyPluginAsyncTypebox = async (fastify) => {
summary: 'Register',
tags: ['Auth'],
operationId: 'auth.register',
- body: CreateUserSchema,
+ body: TypeboxRef(CreateUserPayloadSchema),
response: {
- 200: UserSchema,
+ 200: TypeboxRef(UserSchema),
},
},
config: {
@@ -54,12 +54,9 @@ const plugin: FastifyPluginAsyncTypebox = async (fastify) => {
summary: 'Login',
tags: ['Auth'],
operationId: 'auth.login',
- body: Type.Object({
- username: Type.String({ minLength: 1 }),
- password: Type.String({ minLength: 1 }),
- }),
+ body: TypeboxRef(LoginPayloadSchema),
response: {
- 200: UserSchema,
+ 200: TypeboxRef(UserSchema),
},
},
config: {
@@ -107,7 +104,7 @@ const plugin: FastifyPluginAsyncTypebox = async (fastify) => {
tags: ['Auth'],
operationId: 'auth.me',
response: {
- 200: UserSchema,
+ 200: TypeboxRef(UserSchema),
},
},
},
diff --git a/server/routes/channel.ts b/server/routes/channel.ts
new file mode 100644
index 0000000..a1e4384
--- /dev/null
+++ b/server/routes/channel.ts
@@ -0,0 +1,90 @@
+import type { FastifyPluginAsyncTypebox } from '@fastify/type-provider-typebox'
+import { Type } from 'typebox'
+import { ChannelSchema, CreateChannelPayloadSchema } from '../plugins/schemas/channel.ts'
+import { PrismaClientKnownRequestError } from '../prisma/generated-client/internal/prismaNamespace.ts'
+import { TypeboxRef } from '../utils/typebox-ref.ts'
+
+const plugin: FastifyPluginAsyncTypebox = async (fastify) => {
+ fastify.get(
+ '/channels',
+ {
+ schema: {
+ summary: 'Get channel list',
+ tags: ['Channel'],
+ operationId: 'channel.list',
+ response: {
+ 200: Type.Array(TypeboxRef(ChannelSchema)),
+ },
+ },
+ },
+ async () => {
+ return await fastify.prisma.channel.findMany()
+ },
+ )
+
+ fastify.post(
+ '/channels',
+ {
+ schema: {
+ summary: 'Create channel',
+ tags: ['Channel'],
+ operationId: 'channel.create',
+ body: TypeboxRef(CreateChannelPayloadSchema),
+ response: {
+ 200: TypeboxRef(ChannelSchema),
+ },
+ },
+ },
+ async (req, reply) => {
+ const user = req.user!
+
+ const channel = await fastify.prisma.channel.create({
+ data: {
+ name: req.body.name,
+ ownerId: user.id,
+ persistent: req.body.persistent,
+ },
+ })
+
+ if (!channel) {
+ return reply.unprocessableEntity()
+ }
+
+ fastify.bus.emit('channel:created', channel)
+
+ return channel
+ },
+ )
+
+ fastify.delete(
+ '/channels/:id',
+ {
+ schema: {
+ summary: 'Delete channel',
+ tags: ['Channel'],
+ operationId: 'channel.delete',
+ params: Type.Object({
+ id: Type.String(),
+ }),
+ },
+ },
+ async (req, reply) => {
+ const user = req.user!
+
+ try {
+ const channel = await fastify.prisma.channel.delete({
+ where: { id: req.params.id, ownerId: user.id },
+ })
+
+ fastify.bus.emit('channel:removed', channel)
+ }
+ catch (e) {
+ if (e instanceof PrismaClientKnownRequestError && e.code === 'P2025') {
+ return reply.notFound()
+ }
+ }
+ },
+ )
+}
+
+export default plugin
diff --git a/server/routes/chat.ts b/server/routes/chat.ts
index b5d7c12..19692f8 100644
--- a/server/routes/chat.ts
+++ b/server/routes/chat.ts
@@ -1,6 +1,6 @@
import type { FastifyPluginAsyncTypebox } from '@fastify/type-provider-typebox'
import { Type } from 'typebox'
-import { ChatMessageSchema, NewChatMessageSchema } from '../schemas/chat.ts'
+import { ChatMessageSchema, NewChatMessagePayloadSchema } from '../plugins/schemas/chat.ts'
const plugin: FastifyPluginAsyncTypebox = async (fastify) => {
fastify.post(
@@ -10,7 +10,7 @@ const plugin: FastifyPluginAsyncTypebox = async (fastify) => {
summary: 'Send message',
tags: ['Chat'],
operationId: 'chat.send',
- body: NewChatMessageSchema,
+ body: NewChatMessagePayloadSchema,
response: {
200: ChatMessageSchema,
},
diff --git a/server/routes/user.ts b/server/routes/user.ts
index 340ae9e..f11d873 100644
--- a/server/routes/user.ts
+++ b/server/routes/user.ts
@@ -1,7 +1,7 @@
import type { FastifyPluginAsyncTypebox } from '@fastify/type-provider-typebox'
-import { Type } from 'typebox'
-import { UserSchema } from '../schemas/auth.ts'
-import { UpdateUserPreferencesSchema, UserPreferencesSchema } from '../schemas/user.ts'
+import { UserSchema } from '../plugins/schemas/auth.ts'
+import { GetUserQuerySchema, UpdateUserPayloadSchema, UpdateUserPreferencesPayloadSchema, UserPreferencesSchema } from '../plugins/schemas/user.ts'
+import { TypeboxRef } from '../utils/typebox-ref.ts'
const plugin: FastifyPluginAsyncTypebox = async (fastify) => {
fastify.get(
@@ -11,11 +11,9 @@ const plugin: FastifyPluginAsyncTypebox = async (fastify) => {
summary: 'Get user',
tags: ['User'],
operationId: 'user.get',
- querystring: Type.Partial(Type.Object({
- username: Type.String(),
- })),
+ querystring: TypeboxRef(GetUserQuerySchema),
response: {
- 200: UserSchema,
+ 200: TypeboxRef(UserSchema),
},
},
},
@@ -49,11 +47,11 @@ const plugin: FastifyPluginAsyncTypebox = async (fastify) => {
tags: ['User'],
operationId: 'user.getPreferences',
response: {
- 200: UserPreferencesSchema,
+ 200: TypeboxRef(UserPreferencesSchema),
},
},
},
- async (req, reply) => {
+ async (req) => {
const user = req.user!
const preferences = await fastify.prisma.userPreferences.upsert({
@@ -62,10 +60,6 @@ const plugin: FastifyPluginAsyncTypebox = async (fastify) => {
update: {},
})
- if (!preferences) {
- return reply.notFound('User preferences not found')
- }
-
return {
toggleInputHotkey: preferences.toggleInputHotkey || '',
toggleOutputHotkey: preferences.toggleOutputHotkey || '',
@@ -80,7 +74,7 @@ const plugin: FastifyPluginAsyncTypebox = async (fastify) => {
summary: 'Update preferences',
tags: ['User'],
operationId: 'user.updatePreferences',
- body: UpdateUserPreferencesSchema,
+ body: TypeboxRef(UpdateUserPreferencesPayloadSchema),
},
},
async (req) => {
@@ -104,11 +98,9 @@ const plugin: FastifyPluginAsyncTypebox = async (fastify) => {
summary: 'Update profile',
tags: ['User'],
operationId: 'user.updateProfile',
- body: Type.Object({
- displayName: Type.String(),
- }),
+ body: TypeboxRef(UpdateUserPayloadSchema),
response: {
- 200: UserSchema,
+ 200: TypeboxRef(UserSchema),
},
},
},
diff --git a/server/schemas/user.ts b/server/schemas/user.ts
deleted file mode 100644
index f9c0a5e..0000000
--- a/server/schemas/user.ts
+++ /dev/null
@@ -1,11 +0,0 @@
-import { Type } from 'typebox'
-
-export const UserPreferencesSchema = Type.Object({
- toggleInputHotkey: Type.String(),
- toggleOutputHotkey: Type.String(),
-}, { title: 'UserPreferences', description: 'UserPreferences' })
-
-export const UpdateUserPreferencesSchema = Type.Partial(
- UserPreferencesSchema,
- { title: 'UpdateUserPreferences', description: 'UpdateUserPreferences' },
-)
diff --git a/server/server.ts b/server/server.ts
index 6a6242c..ef95bcb 100644
--- a/server/server.ts
+++ b/server/server.ts
@@ -10,7 +10,6 @@ import FastifySwagger from '@fastify/swagger'
import FastifyApiReference from '@scalar/fastify-api-reference'
import Fastify from 'fastify'
import { Prisma } from './prisma/generated-client/client.ts'
-import { ErrorReplySchema } from './schemas/common.ts'
import 'dotenv/config'
const __filename = fileURLToPath(import.meta.url)
@@ -52,13 +51,30 @@ fastify.register(FastifySwagger, {
const transformedSchema: typeof schema = schema ?? {}
const responseSchema: any = transformedSchema.response ?? {}
- responseSchema['4xx'] ??= ErrorReplySchema
- responseSchema['5xx'] ??= ErrorReplySchema
+ responseSchema['4xx'] ??= { $ref: 'ResponseError' }
+ responseSchema['5xx'] ??= { $ref: 'ResponseError' }
transformedSchema.response = responseSchema
return { schema: transformedSchema, url }
},
+ refResolver: {
+ buildLocalReference(json, _baseUri, _fragment, i) {
+ if (!json.title && json.$id) {
+ json.title = json.$id
+ }
+
+ if (!json.description) {
+ json.description = json.title
+ }
+
+ if (!json.$id) {
+ return `def-${i}`
+ }
+
+ return json.$id.toString()
+ },
+ },
})
fastify.register(FastifyApiReference, {
@@ -68,10 +84,10 @@ fastify.register(FastifyApiReference, {
showDeveloperTools: 'never',
pageTitle: 'Chad API',
customCss: `
- .scalar-mcp-layer,
- .agent-button-container,
- .t-doc__sidebar > div > button:last-child {
- display: none !important;
+ .scalar-mcp-layer,
+ .agent-button-container,
+ .t-doc__sidebar > div > button:last-child {
+ display: none !important;
}
`,
},
@@ -93,6 +109,7 @@ fastify.register(FastifyMultipart)
fastify.register(FastifyAutoLoad, {
dir: join(__dirname, 'plugins'),
+ maxDepth: 1,
})
fastify.register(FastifyAutoLoad, {
diff --git a/server/socket/chat.ts b/server/socket/chat.ts
deleted file mode 100644
index 96900ac..0000000
--- a/server/socket/chat.ts
+++ /dev/null
@@ -1,7 +0,0 @@
-import type { Server as SocketServer } from 'socket.io'
-
-export default async function (io: SocketServer) {
- io.on('connection', async (socket) => {
-
- })
-}
diff --git a/server/socket/webrtc.ts b/server/socket/webrtc.ts
deleted file mode 100644
index 09282af..0000000
--- a/server/socket/webrtc.ts
+++ /dev/null
@@ -1,471 +0,0 @@
-import type { types } from 'mediasoup'
-import type { Server as SocketServer } from 'socket.io'
-import type { PrismaClient } from '../prisma/generated-client/client.ts'
-import type {
- ChadClient,
- SomeSocket,
-} from '../types/webrtc.ts'
-import { consola } from 'consola'
-import { socketToClient } from '../utils/socket-to-client.ts'
-
-export default async function (io: SocketServer, router: types.Router, prisma: PrismaClient) {
- const audioLevelObserver = await router.createAudioLevelObserver({
- maxEntries: 10,
- threshold: -80,
- interval: 800,
- })
-
- const activeSpeakerObserver = await router.createActiveSpeakerObserver()
-
- audioLevelObserver.on('volumes', async (volumes: types.AudioLevelObserverVolume[]) => {
- io.emit('speakingPeers', volumes.map(({ producer, volume }) => {
- const { socketId } = producer.appData as { socketId: ChadClient['socketId'] }
-
- return {
- clientId: socketId,
- volume,
- }
- }))
- })
-
- audioLevelObserver.on('silence', () => {
- io.emit('speakingPeers', [])
- io.emit('activeSpeaker', undefined)
- })
-
- activeSpeakerObserver.on('dominantspeaker', ({ producer }) => {
- const { socketId } = producer.appData as { socketId: ChadClient['socketId'] }
-
- io.emit('activeSpeaker', socketId)
- })
-
- io.on('connection', async (socket) => {
- consola.info('[WebRtc]', 'Client connected', socket.id)
-
- socket.data.joined = false
-
- socket.data.inputMuted = false
- socket.data.outputMuted = false
-
- socket.data.transports = new Map()
- socket.data.producers = new Map()
- socket.data.consumers = new Map()
-
- const { id, username, displayName } = await prisma.user.findUnique({
- where: {
- id: socket.handshake.auth.userId,
- },
- select: {
- id: true,
- username: true,
- displayName: true,
- },
- })
-
- socket.data.userId = id
- socket.data.username = username
- socket.data.displayName = displayName
-
- socket.emit('authenticated')
-
- socket.on('join', async ({ rtpCapabilities }, cb) => {
- if (socket.data.joined) {
- consola.error('[WebRtc]', 'Already joined')
- cb({ error: 'Already joined' })
- }
-
- socket.data.joined = true
- socket.data.rtpCapabilities = rtpCapabilities
-
- const joinedSockets = await getJoinedSockets()
-
- cb(joinedSockets.map(socketToClient))
-
- for (const joinedSocket of joinedSockets.filter(joinedSocket => joinedSocket.id !== socket.id)) {
- for (const producer of joinedSocket.data.producers.values()) {
- createConsumer(
- socket,
- joinedSocket,
- producer,
- )
- }
- }
-
- socket.broadcast.emit('newPeer', socketToClient(socket))
- })
-
- socket.on('getRtpCapabilities', (cb) => {
- cb(router.rtpCapabilities)
- })
-
- socket.on('createTransport', async ({ producing, consuming }, cb) => {
- try {
- const transport = await router.createWebRtcTransport({
- listenInfos: [
- {
- protocol: 'udp',
- ip: '0.0.0.0',
- announcedAddress: process.env.ANNOUNCED_ADDRESS || '127.0.0.1',
- portRange: {
- min: 40000,
- max: 40100,
- },
- },
- ],
- enableUdp: true,
- preferUdp: true,
- appData: {
- producing,
- consuming,
- },
- })
-
- socket.data.transports.set(transport.id, transport)
-
- cb({
- id: transport.id,
- iceParameters: transport.iceParameters,
- iceCandidates: transport.iceCandidates,
- dtlsParameters: transport.dtlsParameters,
- })
-
- transport.on('icestatechange', (iceState: types.IceState) => {
- if (iceState === 'disconnected' || iceState === 'closed') {
- consola.info('[WebRtc]', '[WebRtcTransport]', `"icestatechange" event [iceState:${iceState}], closing peer`, transport.id)
-
- socket.disconnect()
- }
- })
-
- transport.on('dtlsstatechange', (dtlsState: types.DtlsState) => {
- if (dtlsState === 'failed' || dtlsState === 'closed') {
- consola.warn('WebRtcTransport "dtlsstatechange" event [dtlsState:%s], closing peer', dtlsState)
-
- socket.disconnect()
- }
- })
- }
- catch (error) {
- if (error instanceof Error) {
- consola.error('[WebRtc]', '[createTransport]', error.message)
- cb({ error: error.message })
- }
- }
- })
-
- socket.on('connectTransport', async ({ transportId, dtlsParameters }, cb) => {
- const transport = socket.data.transports.get(transportId)
-
- if (!transport) {
- consola.error('[WebRtc]', '[connectTransport]', `Transport with id ${transportId} not found`)
- cb({ error: 'Transport not found' })
-
- return
- }
-
- try {
- await transport.connect({ dtlsParameters })
-
- cb({ ok: true })
- }
- catch (error) {
- if (error instanceof Error) {
- consola.error('[WebRtc]', '[connectTransport]', error.message)
- cb({ error: error.message })
- }
- }
- })
-
- socket.on('produce', async ({ transportId, kind, rtpParameters, appData }, cb) => {
- if (!socket.data.joined) {
- consola.error('Peer not joined yet')
- cb({ error: 'Peer not joined yet' })
-
- return
- }
-
- const transport = socket.data.transports.get(transportId)
-
- if (!transport) {
- consola.error('[WebRtc]', '[produce]', `Transport with id ${transportId} not found`)
- cb({ error: 'Transport not found' })
-
- return
- }
-
- try {
- const producer = await transport.produce({ kind, rtpParameters, appData: { ...appData, socketId: socket.id } })
-
- socket.data.producers.set(producer.id, producer)
-
- cb({ id: producer.id })
-
- const otherSockets = await getJoinedSockets(socket.id)
-
- for (const otherSocket of otherSockets) {
- createConsumer(
- otherSocket,
- socket,
- producer,
- )
- }
-
- await audioLevelObserver.addProducer({ producerId: producer.id })
- await activeSpeakerObserver.addProducer({ producerId: producer.id })
- }
- catch (error) {
- if (error instanceof Error) {
- consola.error('[WebRtc]', '[produce]', error.message)
- cb({ error: error.message })
- }
- }
- })
-
- socket.on('closeProducer', async ({ producerId }, cb) => {
- if (!socket.data.joined) {
- consola.error('Peer not joined yet')
- cb({ error: 'Peer not joined yet' })
-
- return
- }
-
- const producer = socket.data.producers.get(producerId)
-
- if (!producer) {
- consola.error(`producer with id "${producerId}" not found`)
- cb({ error: `producer with id "${producerId}" not found` })
-
- return
- }
-
- producer.close()
-
- socket.data.producers.delete(producerId)
-
- cb({ ok: true })
- })
-
- socket.on('pauseProducer', async ({ producerId }, cb) => {
- if (!socket.data.joined) {
- consola.error('Peer not joined yet')
- cb({ error: 'Peer not joined yet' })
-
- return
- }
-
- const producer = socket.data.producers.get(producerId)
-
- if (!producer) {
- consola.error(`producer with id "${producerId}" not found`)
- cb({ error: `producer with id "${producerId}" not found` })
-
- return
- }
-
- if (producer.paused)
- return
-
- await producer.pause()
-
- cb({ ok: true })
- })
-
- socket.on('resumeProducer', async ({ producerId }, cb) => {
- if (!socket.data.joined) {
- consola.error('Peer not joined yet')
- cb({ error: 'Peer not joined yet' })
-
- return
- }
-
- const producer = socket.data.producers.get(producerId)
-
- if (!producer) {
- consola.error(`producer with id "${producerId}" not found`)
- cb({ error: `producer with id "${producerId}" not found` })
-
- return
- }
-
- await producer.resume()
-
- cb({ ok: true })
- })
-
- socket.on('pauseConsumer', async ({ consumerId }, cb) => {
- if (!socket.data.joined) {
- consola.error('Peer not joined yet')
- cb({ error: 'Peer not joined yet' })
-
- return
- }
-
- const consumer = socket.data.consumers.get(consumerId)
-
- if (!consumer) {
- consola.error(`consumer with id "${consumerId}" not found`)
- cb({ error: `consumer with id "${consumerId}" not found` })
-
- return
- }
-
- await consumer.pause()
-
- cb({ ok: true })
- })
-
- socket.on('resumeConsumer', async ({ consumerId }, cb) => {
- if (!socket.data.joined) {
- consola.error('Peer not joined yet')
- cb({ error: 'Peer not joined yet' })
-
- return
- }
-
- const consumer = socket.data.consumers.get(consumerId)
-
- if (!consumer) {
- consola.error(`consumer with id "${consumerId}" not found`)
- cb({ error: `consumer with id "${consumerId}" not found` })
-
- return
- }
-
- await consumer.resume()
-
- cb({ ok: true })
- })
-
- socket.on('updateClient', async (updatedClient, cb) => {
- if (typeof updatedClient.inputMuted === 'boolean') {
- socket.data.inputMuted = updatedClient.inputMuted
- }
-
- if (typeof updatedClient.outputMuted === 'boolean') {
- socket.data.outputMuted = updatedClient.outputMuted
- }
-
- cb(socketToClient(socket))
-
- io.emit('clientChanged', socket.id, socketToClient(socket))
- })
-
- socket.on('disconnect', () => {
- consola.info('Client disconnected:', socket.id)
-
- if (socket.data.joined) {
- socket.broadcast.emit('peerClosed', socket.id)
- }
-
- for (const transport of socket.data.transports.values()) {
- transport.close()
- }
- })
- })
-
- async function getJoinedSockets(excludeId?: string) {
- const sockets = await io.fetchSockets()
-
- return sockets.filter(socket => socket.data.joined && (excludeId ? excludeId !== socket.id : true))
- }
-
- async function createConsumer(
- consumerSocket: SomeSocket,
- producerSocket: SomeSocket,
- producer: types.Producer,
- ) {
- if (
- !consumerSocket.data.rtpCapabilities
- || !router.canConsume(
- {
- producerId: producer.id,
- rtpCapabilities: consumerSocket.data.rtpCapabilities,
- },
- )
- ) {
- return
- }
-
- const transport = Array.from(consumerSocket.data.transports.values())
- .find(t => t.appData.consuming)
-
- if (!transport) {
- consola.error('createConsumer() | Transport for consuming not found')
-
- return
- }
-
- let consumer: types.Consumer
-
- try {
- consumer = await transport.consume(
- {
- producerId: producer.id,
- rtpCapabilities: consumerSocket.data.rtpCapabilities,
- // Enable NACK for OPUS.
- enableRtx: true,
- paused: true,
- ignoreDtx: true,
- },
- )
- }
- catch (error) {
- consola.error('_createConsumer() | transport.consume():%o', error)
-
- return
- }
-
- consumerSocket.data.consumers.set(consumer.id, consumer)
-
- consumer.on('transportclose', () => {
- consumerSocket.data.consumers.delete(consumer.id)
- })
-
- consumer.on('producerclose', () => {
- consumerSocket.data.consumers.delete(consumer.id)
-
- consumerSocket.emit('consumerClosed', { consumerId: consumer.id })
- })
-
- consumer.on('producerpause', () => {
- consumerSocket.emit('consumerPaused', { consumerId: consumer.id })
- })
-
- consumer.on('producerresume', () => {
- consumerSocket.emit('consumerResumed', { consumerId: consumer.id })
- })
-
- consumer.on('score', (score: types.ConsumerScore) => {
- consumerSocket.emit('consumerScore', { consumerId: consumer.id, score })
- })
-
- try {
- await consumerSocket.emitWithAck(
- 'newConsumer',
- {
- socketId: producerSocket.id,
- producerId: producer.id,
- id: consumer.id,
- kind: consumer.kind,
- rtpParameters: consumer.rtpParameters,
- type: consumer.type,
- appData: producer.appData,
- producerPaused: consumer.producerPaused,
- },
- )
-
- await consumer.resume()
-
- consumerSocket.emit(
- 'consumerScore',
- {
- consumerId: consumer.id,
- score: consumer.score,
- },
- )
- }
- catch (error) {
- consola.error('_createConsumer() | failed:%o', error)
- }
- }
-}
diff --git a/server/tsconfig.json b/server/tsconfig.json
index 14fbc8b..895d3e3 100644
--- a/server/tsconfig.json
+++ b/server/tsconfig.json
@@ -1,12 +1,12 @@
{
"compilerOptions": {
"target": "es2016",
- "module": "ESNext",
+ "module": "NodeNext",
"moduleResolution": "nodenext",
+ "allowImportingTsExtensions": true,
+ "strict": true,
"esModuleInterop": true,
"forceConsistentCasingInFileNames": true,
- "strict": true,
- "skipLibCheck": true,
- "allowImportingTsExtensions": true
+ "skipLibCheck": true
}
}
diff --git a/server/types/chat.ts b/server/types/chat.ts
deleted file mode 100644
index cca755b..0000000
--- a/server/types/chat.ts
+++ /dev/null
@@ -1,18 +0,0 @@
-export interface ChatClientMessage {
- text: string
- replyTo?: {
- messageId: string
- }
-}
-
-export interface ChatMessage {
- id: string
- sender: string
- text: string
- createdAt: string
- replyTo?: {
- messageId: string
- sender: string
- text: string
- }
-}
diff --git a/server/types/webrtc.ts b/server/types/webrtc.ts
deleted file mode 100644
index 401f3a4..0000000
--- a/server/types/webrtc.ts
+++ /dev/null
@@ -1,142 +0,0 @@
-import type { types } from 'mediasoup'
-import type { RemoteSocket, Socket, Namespace as SocketNamespace } from 'socket.io'
-import type { User } from '../prisma/client'
-
-export interface ChadClient {
- socketId: string
- userId: User['id']
- username: User['username']
- displayName: User['displayName']
- inputMuted: boolean
- outputMuted: boolean
-}
-
-export interface ProducerShort {
- producerId: types.Producer['id']
- kind: types.MediaKind
-}
-
-export interface ErrorCallbackResult {
- error: string
-}
-
-export interface SuccessCallbackResult {
- ok: true
-}
-
-export type EventCallback = (result: T | ErrorCallbackResult) => void
-
-export interface ClientToServerEvents {
- join: (
- options: {
- rtpCapabilities: types.RtpCapabilities
- },
- cb: EventCallback
- ) => void
- getRtpCapabilities: (
- cb: EventCallback
- ) => void
- createTransport: (
- options: {
- producing: boolean
- consuming: boolean
- },
- cb: EventCallback>
- ) => void
- connectTransport: (
- options: {
- transportId: types.WebRtcTransport['id']
- dtlsParameters: types.WebRtcTransport['dtlsParameters']
- },
- cb: EventCallback
- ) => void
- produce: (
- options: {
- transportId: types.WebRtcTransport['id']
- kind: types.MediaKind
- rtpParameters: types.RtpParameters
- appData: { source: 'share' | string }
- },
- cb: EventCallback<{ id: types.Producer['id'] }>
- ) => void
- closeProducer: (
- options: {
- producerId: types.Producer['id']
- },
- cb: EventCallback
- ) => void
- pauseProducer: (
- options: {
- producerId: types.Producer['id']
- },
- cb: EventCallback
- ) => void
- resumeProducer: (
- options: {
- producerId: types.Producer['id']
- },
- cb: EventCallback
- ) => void
- pauseConsumer: (
- options: {
- consumerId: types.Consumer['id']
- },
- cb: EventCallback
- ) => void
- resumeConsumer: (
- options: {
- consumerId: types.Consumer['id']
- },
- cb: EventCallback
- ) => void
- updateClient: (
- options: Partial>,
- cb: EventCallback
- ) => void
-}
-
-export interface ServerToClientEvents {
- authenticated: () => void
- newPeer: (arg: ChadClient) => void
- producers: (arg: ProducerShort[]) => void
- newConsumer: (
- arg: {
- socketId: string
- producerId: types.Producer['id']
- id: types.Consumer['id']
- kind: types.MediaKind
- rtpParameters: types.RtpParameters
- type: types.ConsumerType
- appData: types.Producer['appData']
- producerPaused: types.Consumer['producerPaused']
- },
- cb: EventCallback
- ) => void
- peerClosed: (arg: string) => void
- consumerClosed: (arg: { consumerId: string }) => void
- consumerPaused: (arg: { consumerId: string }) => void
- consumerResumed: (arg: { consumerId: string }) => void
- consumerScore: (arg: { consumerId: string, score: types.ConsumerScore }) => void
- clientChanged: (clientId: ChadClient['socketId'], client: ChadClient) => void
- speakingPeers: (arg: { clientId: ChadClient['socketId'], volume: types.AudioLevelObserverVolume['volume'] }[]) => void
- activeSpeaker: (clientId?: ChadClient['socketId']) => void
-}
-
-export interface InterServerEvent {}
-
-export interface SocketData {
- joined: boolean
- userId: User['id']
- username: User['username']
- displayName: User['displayName']
- inputMuted: boolean
- outputMuted: boolean
- rtpCapabilities: types.RtpCapabilities
- transports: Map
- producers: Map
- consumers: Map
-}
-
-export type SomeSocket = Socket | RemoteSocket
-
-export type Namespace = SocketNamespace
diff --git a/server/utils/socket-to-client.ts b/server/utils/socket-to-client.ts
deleted file mode 100644
index 7d024be..0000000
--- a/server/utils/socket-to-client.ts
+++ /dev/null
@@ -1,12 +0,0 @@
-import type { ChadClient, SomeSocket } from '../types/webrtc.ts'
-
-export function socketToClient(socket: SomeSocket): ChadClient {
- return {
- socketId: socket.id,
- userId: socket.data.userId,
- username: socket.data.username,
- displayName: socket.data.displayName,
- inputMuted: socket.data.inputMuted,
- outputMuted: socket.data.outputMuted,
- }
-}
diff --git a/server/utils/typebox-ref.ts b/server/utils/typebox-ref.ts
new file mode 100644
index 0000000..8b016c3
--- /dev/null
+++ b/server/utils/typebox-ref.ts
@@ -0,0 +1,12 @@
+import type { Static, TSchema, TSchemaOptions, TUnsafe } from 'typebox'
+import { Unsafe } from 'typebox'
+
+export function TypeboxRef(t: T, options: TSchemaOptions = {}): TUnsafe> {
+ const id = (t as unknown as Record).$id
+
+ if (!id) {
+ throw new Error('missing ID on schema')
+ }
+
+ return Unsafe>({ ...t, $ref: id, $id: undefined, ...options })
+}
diff --git a/server/yarn.lock b/server/yarn.lock
index f9c6ae9..e6ccc99 100644
--- a/server/yarn.lock
+++ b/server/yarn.lock
@@ -1172,13 +1172,6 @@ __metadata:
languageName: node
linkType: hard
-"@types/ini@npm:^4.1.1":
- version: 4.1.1
- resolution: "@types/ini@npm:4.1.1"
- checksum: 10c0/a060753a39f8bd73b615186018f7aded0eeb5698c0cb00e2f92ae495aa44b6351260e27f938891eeb304e28c2d42036bac5793a4e2031eff1df1a47de8cc8a97
- languageName: node
- linkType: hard
-
"@types/json-schema@npm:^7.0.15":
version: 7.0.15
resolution: "@types/json-schema@npm:7.0.15"
@@ -3042,7 +3035,7 @@ __metadata:
languageName: node
linkType: hard
-"flatbuffers@npm:^25.2.10":
+"flatbuffers@npm:^25.9.23":
version: 25.9.23
resolution: "flatbuffers@npm:25.9.23"
checksum: 10c0/957c4ae2a02be1703c98b36b4dc8ceb81613cf8e2333026afc95a7b68b088bed5458056dc29d0ab7ce8bc403b8c003732b0968d24aba46f5e7c8f71789a6bd9e
@@ -3269,12 +3262,12 @@ __metadata:
languageName: node
linkType: hard
-"h264-profile-level-id@npm:^2.2.3":
- version: 2.3.1
- resolution: "h264-profile-level-id@npm:2.3.1"
+"h264-profile-level-id@npm:^2.3.2":
+ version: 2.3.2
+ resolution: "h264-profile-level-id@npm:2.3.2"
dependencies:
debug: "npm:^4.4.3"
- checksum: 10c0/c3459549bb28e456db62428c79885cffd4958ce282099c4181b09576f8e5ad90b42395a77209fff4f20a7cb920aaeb660f73902f08343daead0f5527faeb4015
+ checksum: 10c0/75bd12ff36707ffacf379c31c403d4508f3116ef2065e375deadcfafd4f7d163521cf0c70ae5385ebac970fa0acc07f9dd497c4248cfc1ee5623b4533707731d
languageName: node
linkType: hard
@@ -3423,13 +3416,6 @@ __metadata:
languageName: node
linkType: hard
-"ini@npm:^5.0.0":
- version: 5.0.0
- resolution: "ini@npm:5.0.0"
- checksum: 10c0/657491ce766cbb4b335ab221ee8f72b9654d9f0e35c32fe5ff2eb7ab8c5ce72237ff6456555b50cde88e6507a719a70e28e327b450782b4fc20c90326ec8c1a8
- languageName: node
- linkType: hard
-
"ini@npm:~1.3.0":
version: 1.3.8
resolution: "ini@npm:1.3.8"
@@ -3967,19 +3953,17 @@ __metadata:
languageName: node
linkType: hard
-"mediasoup@npm:^3.19.3":
- version: 3.19.3
- resolution: "mediasoup@npm:3.19.3"
+"mediasoup@npm:^3.19.21":
+ version: 3.19.21
+ resolution: "mediasoup@npm:3.19.21"
dependencies:
- "@types/ini": "npm:^4.1.1"
debug: "npm:^4.4.3"
- flatbuffers: "npm:^25.2.10"
- h264-profile-level-id: "npm:^2.2.3"
- ini: "npm:^5.0.0"
+ flatbuffers: "npm:^25.9.23"
+ h264-profile-level-id: "npm:^2.3.2"
node-fetch: "npm:^3.3.2"
supports-color: "npm:^10.2.2"
- tar: "npm:^7.4.4"
- checksum: 10c0/957ab3de4e7419eff3e76767511505f007fcd348b431acc2aa5ffcc2d9917cb83aa22f21f1f0004cb10ad65b46219b58fcf009b3b850719c09d5578aa6545f78
+ tar: "npm:^7.5.13"
+ checksum: 10c0/da37e478540002bae8350dda138eb9c54bb4b67f04c45386fd13205401e1bcd054043189664f35b03b466f8a4dc7df2d9b9a9fa022d0377d5602da4be6db4091
languageName: node
linkType: hard
@@ -5426,7 +5410,7 @@ __metadata:
fastify: "npm:^5.6.1"
fastify-plugin: "npm:^5.1.0"
lucia: "npm:^3.2.2"
- mediasoup: "npm:^3.19.3"
+ mediasoup: "npm:^3.19.21"
nodemon: "npm:^3.1.14"
prisma: "npm:7"
socket.io: "npm:^4.8.1"
@@ -5800,7 +5784,7 @@ __metadata:
languageName: node
linkType: hard
-"tar@npm:^7.4.3, tar@npm:^7.4.4":
+"tar@npm:^7.4.3":
version: 7.5.1
resolution: "tar@npm:7.5.1"
dependencies:
@@ -5813,6 +5797,19 @@ __metadata:
languageName: node
linkType: hard
+"tar@npm:^7.5.13":
+ version: 7.5.13
+ resolution: "tar@npm:7.5.13"
+ dependencies:
+ "@isaacs/fs-minipass": "npm:^4.0.0"
+ chownr: "npm:^3.0.0"
+ minipass: "npm:^7.1.2"
+ minizlib: "npm:^3.1.0"
+ yallist: "npm:^5.0.0"
+ checksum: 10c0/5c65b8084799bde7a791593a1c1a45d3d6ee98182e3700b24c247b7b8f8654df4191642abbdb07ff25043d45dcff35620827c3997b88ae6c12040f64bed5076b
+ languageName: node
+ linkType: hard
+
"thread-stream@npm:^3.0.0":
version: 3.1.0
resolution: "thread-stream@npm:3.1.0"