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 @@
- + +
+
+
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 @@ + + + + + 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 @@ + + + + + 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 @@ + + + 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 @@ + + + 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 @@ + + + + + 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 @@ + + + + + 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 @@ + + + + + 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"