mirror of
https://github.com/kunkunsh/kunkun.git
synced 2025-04-03 22:26:43 +00:00
Fix: kkrpc serialization backward compatibility (#256)
* update deno lock * chore: update kkrpc and tauri-api-adapter versions, enhance serialization handling - Bump kkrpc version to 0.2.2 in multiple packages including desktop and api. - Update tauri-api-adapter version to 0.3.27. - Introduce a new utility function to determine kkrpc serialization based on API version. - Refactor RPC channel initialization to include serialization version in desktop extension handling. - Increment desktop package version to 0.1.36 and api package version to 0.1.7. * chore: update dependencies in pnpm-lock and package.json - Upgrade postcss version for autoprefixer to 8.5.3 in pnpm-lock.yaml. - Add semver package with version 7.7.1 in package.json. - Update CHANGELOG.md to reflect recent kkrpc upgrades and changes.
This commit is contained in:
parent
d27731d0e6
commit
c39e98258c
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@kksh/desktop",
|
||||
"version": "0.1.35",
|
||||
"version": "0.1.36",
|
||||
"description": "",
|
||||
"type": "module",
|
||||
"scripts": {
|
||||
@ -33,7 +33,7 @@
|
||||
"eslint": "^9.21.0",
|
||||
"fuse.js": "^7.1.0",
|
||||
"gsap": "^3.12.7",
|
||||
"kkrpc": "^0.2.1",
|
||||
"kkrpc": "^0.2.2",
|
||||
"lz-string": "^1.5.0",
|
||||
"pretty-bytes": "^6.1.1",
|
||||
"semver": "^7.7.1",
|
||||
|
@ -3,6 +3,7 @@ import { appState } from "@/stores"
|
||||
import { winExtMap } from "@/stores/winExtMap"
|
||||
import { helperAPI } from "@/utils/helper"
|
||||
import { paste } from "@/utils/hotkey"
|
||||
import { decideKkrpcSerialization } from "@/utils/kkrpc"
|
||||
import { sleep } from "@/utils/time"
|
||||
import { trimSlash } from "@/utils/url"
|
||||
import { constructExtensionSupportDir } from "@kksh/api"
|
||||
@ -16,6 +17,7 @@ import { convertFileSrc } from "@tauri-apps/api/core"
|
||||
import * as path from "@tauri-apps/api/path"
|
||||
import { getCurrentWindow } from "@tauri-apps/api/window"
|
||||
import * as fs from "@tauri-apps/plugin-fs"
|
||||
import { info } from "@tauri-apps/plugin-log"
|
||||
import { platform } from "@tauri-apps/plugin-os"
|
||||
import { goto } from "$app/navigation"
|
||||
import { RPCChannel, WorkerParentIO } from "kkrpc/browser"
|
||||
@ -85,6 +87,7 @@ export async function onHeadlessCmdSelect(
|
||||
const loadedExt = await loadExtensionManifestFromDisk(
|
||||
await path.join(ext.extPath, "package.json")
|
||||
)
|
||||
|
||||
const scriptPath = await path.join(loadedExt.extPath, cmd.main)
|
||||
const workerScript = await fs.readTextFile(scriptPath)
|
||||
const blob = new Blob([workerScript], { type: "application/javascript" })
|
||||
@ -124,8 +127,15 @@ export async function onHeadlessCmdSelect(
|
||||
} satisfies IApp
|
||||
}
|
||||
const io = new WorkerParentIO(worker)
|
||||
const kkrpcSerialization = decideKkrpcSerialization(loadedExt)
|
||||
info(
|
||||
`Establishing kkrpc connection for ${loadedExt.kunkun.identifier} with serialization: ${kkrpcSerialization}`
|
||||
)
|
||||
const rpc = new RPCChannel<typeof serverAPI2, HeadlessCommand>(io, {
|
||||
expose: serverAPI2
|
||||
expose: serverAPI2,
|
||||
serialization: {
|
||||
version: kkrpcSerialization
|
||||
}
|
||||
})
|
||||
const workerAPI = rpc.getAPI()
|
||||
await workerAPI.load()
|
||||
|
19
apps/desktop/src/lib/utils/kkrpc.ts
Normal file
19
apps/desktop/src/lib/utils/kkrpc.ts
Normal file
@ -0,0 +1,19 @@
|
||||
import { parseAPIVersion } from "@kksh/extension/load"
|
||||
import type { ExtPackageJsonExtra } from "@kunkunapi/src/models/manifest"
|
||||
import semver from "semver"
|
||||
|
||||
/**
|
||||
* Decide the serialization method for kkrpc based on the api version
|
||||
* apiVersion is populated in loadExtensionManifestFromDisk, but we parse it again
|
||||
* @param apiVersion - The version of the @kksh/api
|
||||
* @returns "superjson" or "json"
|
||||
*/
|
||||
export function decideKkrpcSerialization(ext: ExtPackageJsonExtra): "superjson" | "json" {
|
||||
const apiVersion = parseAPIVersion(ext.dependencies || {})
|
||||
if (apiVersion && semver.lte(apiVersion, "0.1.5")) {
|
||||
// 0.1.6 is the first version that supports superjson and default to use superjson
|
||||
return "json"
|
||||
}
|
||||
// fallback default to use superjson, some extensions might not install @kksh/api
|
||||
return "superjson"
|
||||
}
|
@ -5,6 +5,7 @@
|
||||
import { helperAPI } from "@/utils/helper"
|
||||
import { paste } from "@/utils/hotkey"
|
||||
import { goBackOnEscape } from "@/utils/key"
|
||||
import { decideKkrpcSerialization } from "@/utils/kkrpc"
|
||||
import { goHome } from "@/utils/route"
|
||||
import { positionToCssStyleString, positionToTailwindClasses } from "@/utils/style"
|
||||
import { sleep } from "@/utils/time"
|
||||
@ -27,6 +28,7 @@
|
||||
} from "@kunkunapi/src/events"
|
||||
import { emitTo } from "@tauri-apps/api/event"
|
||||
import { getCurrentWindow } from "@tauri-apps/api/window"
|
||||
import { info } from "@tauri-apps/plugin-log"
|
||||
import { goto } from "$app/navigation"
|
||||
import { IframeParentIO, RPCChannel } from "kkrpc/browser"
|
||||
import { ArrowLeftIcon, MoveIcon, RefreshCcwIcon, XIcon } from "lucide-svelte"
|
||||
@ -170,7 +172,16 @@
|
||||
}, 200)
|
||||
if (iframeRef?.contentWindow) {
|
||||
const io = new IframeParentIO(iframeRef.contentWindow)
|
||||
const rpc = new RPCChannel(io, { expose: serverAPI2 })
|
||||
const kkrpcSerialization = decideKkrpcSerialization(loadedExt)
|
||||
info(
|
||||
`Establishing kkrpc connection for ${loadedExt.kunkun.identifier} with serialization: ${kkrpcSerialization}`
|
||||
)
|
||||
const rpc = new RPCChannel(io, {
|
||||
expose: serverAPI2,
|
||||
serialization: {
|
||||
version: kkrpcSerialization
|
||||
}
|
||||
})
|
||||
} else {
|
||||
toast.warning("iframeRef.contentWindow not available")
|
||||
}
|
||||
|
@ -5,6 +5,7 @@
|
||||
import { winExtMap } from "@/stores/winExtMap.js"
|
||||
import { helperAPI } from "@/utils/helper.js"
|
||||
import { paste } from "@/utils/hotkey"
|
||||
import { decideKkrpcSerialization } from "@/utils/kkrpc.js"
|
||||
import {
|
||||
emitReloadOneExtension,
|
||||
listenToFileDrop,
|
||||
@ -43,7 +44,7 @@
|
||||
import { getCurrentWindow } from "@tauri-apps/api/window"
|
||||
import * as fs from "@tauri-apps/plugin-fs"
|
||||
import { readTextFile } from "@tauri-apps/plugin-fs"
|
||||
import { debug } from "@tauri-apps/plugin-log"
|
||||
import { debug, info } from "@tauri-apps/plugin-log"
|
||||
import { platform } from "@tauri-apps/plugin-os"
|
||||
import { goto } from "$app/navigation"
|
||||
import { RPCChannel, WorkerParentIO } from "kkrpc/browser"
|
||||
@ -270,8 +271,15 @@
|
||||
} satisfies IApp
|
||||
}
|
||||
const io = new WorkerParentIO(worker)
|
||||
const kkrpcSerialization = decideKkrpcSerialization(loadedExt)
|
||||
info(
|
||||
`Establishing kkrpc connection for ${loadedExt.kunkun.identifier} with serialization: ${kkrpcSerialization}`
|
||||
)
|
||||
const rpc = new RPCChannel<typeof serverAPI2, TemplateUiCommand>(io, {
|
||||
expose: serverAPI2
|
||||
expose: serverAPI2,
|
||||
serialization: {
|
||||
version: kkrpcSerialization
|
||||
}
|
||||
})
|
||||
workerAPI = rpc.getAPI()
|
||||
await workerAPI.load()
|
||||
|
217
deno.lock
generated
217
deno.lock
generated
@ -24,6 +24,7 @@
|
||||
"npm:@jsr/std__semver@^1.0.3": "1.0.3",
|
||||
"npm:@jsr/std__semver@^1.0.4": "1.0.4",
|
||||
"npm:@kksh/react@0.1.1": "0.1.1_react@18.3.1_react-dom@18.3.1__react@18.3.1_react-hook-form@7.54.2__react@18.3.1_@types+react@18.3.18_@types+react-dom@18.3.5__@types+react@18.3.18_date-fns@3.6.0_tailwindcss@3.4.17__postcss@8.5.1",
|
||||
"npm:@kksh/svelte5@0.1.15": "0.1.15_lucide-svelte@0.469.0__svelte@5.19.6___acorn@8.14.0_svelte@5.19.6__acorn@8.14.0_svelte-sonner@0.3.28__svelte@5.19.6___acorn@8.14.0_typescript@5.6.3_sveltekit-superforms@2.24.0__@sveltejs+kit@2.17.3___@sveltejs+vite-plugin-svelte@5.0.3____svelte@5.19.6_____acorn@8.14.0____vite@6.0.11_____@types+node@20.17.16_____jiti@2.4.2____@types+node@20.17.16___svelte@5.19.6____acorn@8.14.0___vite@5.4.14____@types+node@20.17.16___vite@6.0.11____@types+node@20.17.16____jiti@2.4.2___@types+node@20.17.16__svelte@5.19.6___acorn@8.14.0__valibot@1.0.0-rc.4___typescript@5.6.3__zod@3.24.2__@sveltejs+vite-plugin-svelte@5.0.3___svelte@5.19.6____acorn@8.14.0___vite@6.0.11____@types+node@20.17.16____jiti@2.4.2___@types+node@20.17.16__vite@5.4.14___@types+node@20.17.16__typescript@5.6.3__vite@6.0.11___@types+node@20.17.16___jiti@2.4.2__@types+node@20.17.16_@sveltejs+kit@2.17.3__@sveltejs+vite-plugin-svelte@5.0.3___svelte@5.19.6____acorn@8.14.0___vite@6.0.11____@types+node@20.17.16____jiti@2.4.2___@types+node@20.17.16__svelte@5.19.6___acorn@8.14.0__vite@5.4.14___@types+node@20.17.16__vite@6.0.11___@types+node@20.17.16___jiti@2.4.2__@types+node@20.17.16_valibot@1.0.0-rc.4__typescript@5.6.3_zod@3.24.2_@sveltejs+vite-plugin-svelte@5.0.3__svelte@5.19.6___acorn@8.14.0__vite@6.0.11___@types+node@20.17.16___jiti@2.4.2__@types+node@20.17.16_vite@5.4.14__@types+node@20.17.16_vite@6.0.11__@types+node@20.17.16__jiti@2.4.2_@types+node@20.17.16",
|
||||
"npm:@kksh/svelte5@~0.1.15": "0.1.16_lucide-svelte@0.469.0__svelte@5.19.6___acorn@8.14.0_svelte@5.19.6__acorn@8.14.0_svelte-sonner@0.3.28__svelte@5.19.6___acorn@8.14.0_typescript@5.6.3",
|
||||
"npm:@kksh/vue@0.1.3": "0.1.3_vue@3.5.13__typescript@5.6.3_nanostores@0.10.3_@unovis+ts@1.5.0_zod@3.24.1_tailwindcss@3.4.17__postcss@8.5.1_radix-vue@1.9.13__vue@3.5.13___typescript@5.6.3__typescript@5.6.3_typescript@5.6.3",
|
||||
"npm:@nuxtjs/tailwindcss@6.12.1": "6.12.1_postcss@8.5.1_tailwindcss@3.4.17__postcss@8.5.1_rollup@4.34.0",
|
||||
@ -98,6 +99,7 @@
|
||||
"npm:@typescript-eslint/parser@^7.15.0": "7.18.0_eslint@8.57.1_typescript@5.6.3",
|
||||
"npm:@typescript-eslint/parser@^8.20.0": "8.22.0_eslint@8.57.1_typescript@5.6.3",
|
||||
"npm:@typescript-eslint/parser@^8.25.0": "8.25.0_eslint@8.57.1_typescript@5.6.3",
|
||||
"npm:@valibot/to-json-schema@1.0.0-beta.4": "1.0.0-beta.4_valibot@1.0.0-beta.14__typescript@5.6.3_typescript@5.6.3",
|
||||
"npm:@vitejs/plugin-react@^4.3.1": "4.3.4_vite@5.4.14__@types+node@20.17.16_@babel+core@7.26.7_@types+node@20.17.16",
|
||||
"npm:@vitejs/plugin-vue@^5.1.4": "5.2.1_vite@5.4.14__@types+node@20.17.16_vue@3.5.13__typescript@5.6.3_@types+node@20.17.16_typescript@5.6.3",
|
||||
"npm:autoprefixer@^10.4.19": "10.4.20_postcss@8.5.1",
|
||||
@ -128,6 +130,7 @@
|
||||
"npm:eslint@^8.57.0": "8.57.1",
|
||||
"npm:eslint@^9.17.0": "9.19.0",
|
||||
"npm:eslint@^9.21.0": "9.21.0",
|
||||
"npm:formsnap@2.0.0-next.1": "2.0.0-next.1_svelte@5.19.6__acorn@8.14.0_sveltekit-superforms@2.24.0__@sveltejs+kit@2.17.3___@sveltejs+vite-plugin-svelte@5.0.3____svelte@5.19.6_____acorn@8.14.0____vite@6.0.11_____@types+node@20.17.16_____jiti@2.4.2____@types+node@20.17.16___svelte@5.19.6____acorn@8.14.0___vite@5.4.14____@types+node@20.17.16___vite@6.0.11____@types+node@20.17.16____jiti@2.4.2___@types+node@20.17.16__svelte@5.19.6___acorn@8.14.0__valibot@1.0.0-rc.4___typescript@5.6.3__zod@3.24.2__@sveltejs+vite-plugin-svelte@5.0.3___svelte@5.19.6____acorn@8.14.0___vite@6.0.11____@types+node@20.17.16____jiti@2.4.2___@types+node@20.17.16__vite@5.4.14___@types+node@20.17.16__typescript@5.6.3__vite@6.0.11___@types+node@20.17.16___jiti@2.4.2__@types+node@20.17.16_@sveltejs+kit@2.17.3__@sveltejs+vite-plugin-svelte@5.0.3___svelte@5.19.6____acorn@8.14.0___vite@6.0.11____@types+node@20.17.16____jiti@2.4.2___@types+node@20.17.16__svelte@5.19.6___acorn@8.14.0__vite@5.4.14___@types+node@20.17.16__vite@6.0.11___@types+node@20.17.16___jiti@2.4.2__@types+node@20.17.16_valibot@1.0.0-rc.4__typescript@5.6.3_zod@3.24.2_@sveltejs+vite-plugin-svelte@5.0.3__svelte@5.19.6___acorn@8.14.0__vite@6.0.11___@types+node@20.17.16___jiti@2.4.2__@types+node@20.17.16_vite@5.4.14__@types+node@20.17.16_typescript@5.6.3_vite@6.0.11__@types+node@20.17.16__jiti@2.4.2_@types+node@20.17.16",
|
||||
"npm:fs-extra@^11.2.0": "11.3.0",
|
||||
"npm:fuse.js@^7.1.0": "7.1.0",
|
||||
"npm:get-folder-size@5": "5.0.0",
|
||||
@ -138,6 +141,7 @@
|
||||
"npm:i18next@^23.15.1": "23.16.8",
|
||||
"npm:inquirer@^10.1.2": "10.2.2",
|
||||
"npm:katex@~0.16.21": "0.16.21",
|
||||
"npm:kkrpc@~0.2.2": "0.2.2_typescript@5.6.3",
|
||||
"npm:lodash@^4.17.21": "4.17.21",
|
||||
"npm:lucide-svelte@0.469": "0.469.0_svelte@5.19.6__acorn@8.14.0",
|
||||
"npm:lucide-svelte@0.471": "0.471.0_svelte@5.19.6__acorn@8.14.0",
|
||||
@ -188,6 +192,8 @@
|
||||
"npm:svelte-sonner@~0.3.28": "0.3.28_svelte@5.19.6__acorn@8.14.0",
|
||||
"npm:svelte@^5.16.6": "5.19.6_acorn@8.14.0",
|
||||
"npm:svelte@^5.20.5": "5.20.5_acorn@8.14.0",
|
||||
"npm:sveltekit-superforms@^2.22.1": "2.24.0_@sveltejs+kit@2.17.3__@sveltejs+vite-plugin-svelte@5.0.3___svelte@5.19.6____acorn@8.14.0___vite@6.0.11____@types+node@20.17.16____jiti@2.4.2___@types+node@20.17.16__svelte@5.19.6___acorn@8.14.0__vite@5.4.14___@types+node@20.17.16__vite@6.0.11___@types+node@20.17.16___jiti@2.4.2__@types+node@20.17.16_svelte@5.19.6__acorn@8.14.0_valibot@1.0.0-rc.4__typescript@5.6.3_zod@3.24.2_@sveltejs+vite-plugin-svelte@5.0.3__svelte@5.19.6___acorn@8.14.0__vite@6.0.11___@types+node@20.17.16___jiti@2.4.2__@types+node@20.17.16_vite@5.4.14__@types+node@20.17.16_typescript@5.6.3_vite@6.0.11__@types+node@20.17.16__jiti@2.4.2_@types+node@20.17.16",
|
||||
"npm:sveltekit-superforms@^2.23.1": "2.24.0_@sveltejs+kit@2.17.3__@sveltejs+vite-plugin-svelte@5.0.3___svelte@5.19.6____acorn@8.14.0___vite@6.0.11____@types+node@20.17.16____jiti@2.4.2___@types+node@20.17.16__svelte@5.19.6___acorn@8.14.0__vite@5.4.14___@types+node@20.17.16__vite@6.0.11___@types+node@20.17.16___jiti@2.4.2__@types+node@20.17.16_svelte@5.19.6__acorn@8.14.0_valibot@1.0.0-rc.4__typescript@5.6.3_zod@3.24.2_@sveltejs+vite-plugin-svelte@5.0.3__svelte@5.19.6___acorn@8.14.0__vite@6.0.11___@types+node@20.17.16___jiti@2.4.2__@types+node@20.17.16_vite@5.4.14__@types+node@20.17.16_typescript@5.6.3_vite@6.0.11__@types+node@20.17.16__jiti@2.4.2_@types+node@20.17.16",
|
||||
"npm:tailwind-merge@^2.4.0": "2.6.0",
|
||||
"npm:tailwind-merge@^2.5.5": "2.6.0",
|
||||
"npm:tailwind-merge@^2.6.0": "2.6.0",
|
||||
@ -200,9 +206,11 @@
|
||||
"npm:tailwindcss@^3.4.6": "3.4.17_postcss@8.5.1",
|
||||
"npm:tailwindcss@^3.4.7": "3.4.17_postcss@8.5.1",
|
||||
"npm:tar@^7.4.3": "7.4.3",
|
||||
"npm:tauri-api-adapter@~0.3.27": "0.3.27_typescript@5.6.3",
|
||||
"npm:tauri-plugin-clipboard-api@^2.1.11": "2.1.11_typescript@5.6.3",
|
||||
"npm:tauri-plugin-shellx-api@^2.0.14": "2.0.14",
|
||||
"npm:tauri-plugin-shellx-api@^2.0.16": "2.0.16",
|
||||
"npm:tauri-plugin-svelte@1.2.1": "1.2.1",
|
||||
"npm:tauri-plugin-system-info-api@2.0.8": "2.0.8_typescript@5.6.3",
|
||||
"npm:ts-proto@^2.3.0": "2.6.1",
|
||||
"npm:tslib@^2.8.1": "2.8.1",
|
||||
@ -223,6 +231,7 @@
|
||||
"npm:uuid@^11.1.0": "11.1.0",
|
||||
"npm:valibot@^1.0.0-beta.10": "1.0.0-beta.14_typescript@5.6.3",
|
||||
"npm:valibot@^1.0.0-beta.11": "1.0.0-beta.14_typescript@5.6.3",
|
||||
"npm:valibot@^1.0.0-rc.4": "1.0.0-rc.4_typescript@5.6.3",
|
||||
"npm:verify-package-export@^0.0.3": "0.0.3_typescript@5.6.3",
|
||||
"npm:vite@^5.4.10": "5.4.14_@types+node@20.17.16",
|
||||
"npm:vite@^5.4.9": "5.4.14_@types+node@20.17.16",
|
||||
@ -1677,6 +1686,15 @@
|
||||
"@formkit/auto-animate@0.8.2": {
|
||||
"integrity": "sha512-SwPWfeRa5veb1hOIBMdzI+73te5puUBHmqqaF1Bu7FjvxlYSz/kJcZKSa9Cg60zL0uRNeJL2SbRxV6Jp6Q1nFQ=="
|
||||
},
|
||||
"@gcornut/valibot-json-schema@0.31.0_esbuild@0.25.0": {
|
||||
"integrity": "sha512-3xGptCurm23e7nuPQkdrE5rEs1FeTPHhAUsBuwwqG4/YeZLwJOoYZv+fmsppUEfo5y9lzUwNQrNqLS/q7HMc7g==",
|
||||
"dependencies": [
|
||||
"@types/json-schema",
|
||||
"esbuild@0.25.0",
|
||||
"esbuild-runner",
|
||||
"valibot@0.31.1"
|
||||
]
|
||||
},
|
||||
"@gerrit0/mini-shiki@1.27.2": {
|
||||
"integrity": "sha512-GeWyHz8ao2gBiUW4OJnQDxXQnFgZQwwQk05t/CVVgNBN7/rK8XZ7xY6YhLVv9tH3VppWWmr9DCl3MwemB/i+Og==",
|
||||
"dependencies": [
|
||||
@ -2353,7 +2371,7 @@
|
||||
"lodash",
|
||||
"minimatch@10.0.1",
|
||||
"semver@7.7.0",
|
||||
"tauri-api-adapter",
|
||||
"tauri-api-adapter@0.3.8_typescript@5.6.3_rollup@4.34.0_tslib@2.8.1",
|
||||
"tauri-plugin-shellx-api@2.0.14",
|
||||
"valibot@0.40.0_typescript@5.6.3",
|
||||
"vue-sonner"
|
||||
@ -2422,6 +2440,24 @@
|
||||
"zod@3.24.1"
|
||||
]
|
||||
},
|
||||
"@kksh/svelte5@0.1.15_lucide-svelte@0.469.0__svelte@5.19.6___acorn@8.14.0_svelte@5.19.6__acorn@8.14.0_svelte-sonner@0.3.28__svelte@5.19.6___acorn@8.14.0_typescript@5.6.3_sveltekit-superforms@2.24.0__@sveltejs+kit@2.17.3___@sveltejs+vite-plugin-svelte@5.0.3____svelte@5.19.6_____acorn@8.14.0____vite@6.0.11_____@types+node@20.17.16_____jiti@2.4.2____@types+node@20.17.16___svelte@5.19.6____acorn@8.14.0___vite@5.4.14____@types+node@20.17.16___vite@6.0.11____@types+node@20.17.16____jiti@2.4.2___@types+node@20.17.16__svelte@5.19.6___acorn@8.14.0__valibot@1.0.0-rc.4___typescript@5.6.3__zod@3.24.2__@sveltejs+vite-plugin-svelte@5.0.3___svelte@5.19.6____acorn@8.14.0___vite@6.0.11____@types+node@20.17.16____jiti@2.4.2___@types+node@20.17.16__vite@5.4.14___@types+node@20.17.16__typescript@5.6.3__vite@6.0.11___@types+node@20.17.16___jiti@2.4.2__@types+node@20.17.16_@sveltejs+kit@2.17.3__@sveltejs+vite-plugin-svelte@5.0.3___svelte@5.19.6____acorn@8.14.0___vite@6.0.11____@types+node@20.17.16____jiti@2.4.2___@types+node@20.17.16__svelte@5.19.6___acorn@8.14.0__vite@5.4.14___@types+node@20.17.16__vite@6.0.11___@types+node@20.17.16___jiti@2.4.2__@types+node@20.17.16_valibot@1.0.0-rc.4__typescript@5.6.3_zod@3.24.2_@sveltejs+vite-plugin-svelte@5.0.3__svelte@5.19.6___acorn@8.14.0__vite@6.0.11___@types+node@20.17.16___jiti@2.4.2__@types+node@20.17.16_vite@5.4.14__@types+node@20.17.16_vite@6.0.11__@types+node@20.17.16__jiti@2.4.2_@types+node@20.17.16": {
|
||||
"integrity": "sha512-Cr/gSWsnRtQIQLpQAkGBODujWn5g4LlhDp865skRV95tkrOuAwbbWGjG5+oWx1fK+fiDu+rhe2UCqw61SW2B/Q==",
|
||||
"dependencies": [
|
||||
"@tanstack/table-core",
|
||||
"bits-ui@1.0.0-next.77_svelte@5.19.6__acorn@8.14.0",
|
||||
"embla-carousel-svelte",
|
||||
"formsnap",
|
||||
"lucide-svelte@0.469.0_svelte@5.19.6__acorn@8.14.0",
|
||||
"mode-watcher",
|
||||
"paneforge",
|
||||
"svelte@5.19.6_acorn@8.14.0",
|
||||
"svelte-persisted-store",
|
||||
"svelte-radix",
|
||||
"svelte-sonner",
|
||||
"typescript@5.6.3",
|
||||
"vaul-svelte"
|
||||
]
|
||||
},
|
||||
"@kksh/svelte5@0.1.16_lucide-svelte@0.469.0__svelte@5.19.6___acorn@8.14.0_svelte@5.19.6__acorn@8.14.0_svelte-sonner@0.3.28__svelte@5.19.6___acorn@8.14.0_typescript@5.6.3": {
|
||||
"integrity": "sha512-X0WvM9droAwZPwkZnDfMIvZO2sLBmR+wY9H3gLSmT4RR+ZugDDo3iejtkK6jDKyACVDh2sAZQOrbCqqkxR8GTg==",
|
||||
"dependencies": [
|
||||
@ -2907,7 +2943,7 @@
|
||||
"vite-plugin-inspect",
|
||||
"vite-plugin-vue-inspector",
|
||||
"which@3.0.1",
|
||||
"ws"
|
||||
"ws@8.18.0"
|
||||
]
|
||||
},
|
||||
"@nuxt/kit@3.15.4_magicast@0.3.5_rollup@4.34.0": {
|
||||
@ -5043,7 +5079,7 @@
|
||||
"@supabase/node-fetch",
|
||||
"@types/phoenix",
|
||||
"@types/ws",
|
||||
"ws"
|
||||
"ws@8.18.0"
|
||||
]
|
||||
},
|
||||
"@supabase/ssr@0.5.2_@supabase+supabase-js@2.48.1": {
|
||||
@ -5481,6 +5517,12 @@
|
||||
"@tauri-apps/api@2.2.0"
|
||||
]
|
||||
},
|
||||
"@tauri-store/shared@0.6.0": {
|
||||
"integrity": "sha512-2KBezqqkw68HvvXHEtbbpxyQHDjymBUZl10YuAsNRI8DHFIA0n18WE7NRyQ93+H7IzDP1/B41m2/rcMDHBSiKw==",
|
||||
"dependencies": [
|
||||
"@tauri-apps/api@2.3.0"
|
||||
]
|
||||
},
|
||||
"@trysound/sax@0.2.0": {
|
||||
"integrity": "sha512-L7z9BgrNEcYyUYtF+HaEfiS5ebkh9jXqbszz7pC0hRBPaatV0XjSD3+eHrpqFemQfgwiFF0QPIarnIihIDn7OA=="
|
||||
},
|
||||
@ -6348,6 +6390,12 @@
|
||||
"vue"
|
||||
]
|
||||
},
|
||||
"@valibot/to-json-schema@1.0.0-beta.4_valibot@1.0.0-beta.14__typescript@5.6.3_typescript@5.6.3": {
|
||||
"integrity": "sha512-wXBdCyoqec+NLCl5ihitXzZXD4JAjPK3+HfskSXzfhiNFvKje0A/v1LygqKidUgIbaJtREmq/poJGbaS/0MKuQ==",
|
||||
"dependencies": [
|
||||
"valibot@1.0.0-beta.14_typescript@5.6.3"
|
||||
]
|
||||
},
|
||||
"@vee-validate/zod@4.15.0_zod@3.24.1_vue@3.5.13__typescript@5.6.3_typescript@5.6.3": {
|
||||
"integrity": "sha512-MpvIKiyg9X5yD8bJW0no2AU7wtR2T5mrvD9tuPRiie951sU2n6QKgMV38qKKOiqFBCxsMSjIuLLLV3V5kVE4nQ==",
|
||||
"dependencies": [
|
||||
@ -8591,6 +8639,14 @@
|
||||
"is-symbol"
|
||||
]
|
||||
},
|
||||
"esbuild-runner@2.2.2_esbuild@0.25.0": {
|
||||
"integrity": "sha512-fRFVXcmYVmSmtYm2mL8RlUASt2TDkGh3uRcvHFOKNr/T58VrfVeKD9uT9nlgxk96u0LS0ehS/GY7Da/bXWKkhw==",
|
||||
"dependencies": [
|
||||
"esbuild@0.25.0",
|
||||
"source-map-support",
|
||||
"tslib@2.4.0"
|
||||
]
|
||||
},
|
||||
"esbuild@0.21.5": {
|
||||
"integrity": "sha512-mg3OPMV4hXywwpoDxu3Qda5xCKQi+vCTZq8S9J/EpkhB2HzKXq4SNFZE3+NK93JYxc8VMSep+lOUSC/RVKaBqw==",
|
||||
"dependencies": [
|
||||
@ -9338,6 +9394,14 @@
|
||||
"fetch-blob"
|
||||
]
|
||||
},
|
||||
"formsnap@2.0.0-next.1_svelte@5.19.6__acorn@8.14.0_sveltekit-superforms@2.24.0__@sveltejs+kit@2.17.3___@sveltejs+vite-plugin-svelte@5.0.3____svelte@5.19.6_____acorn@8.14.0____vite@6.0.11_____@types+node@20.17.16_____jiti@2.4.2____@types+node@20.17.16___svelte@5.19.6____acorn@8.14.0___vite@5.4.14____@types+node@20.17.16___vite@6.0.11____@types+node@20.17.16____jiti@2.4.2___@types+node@20.17.16__svelte@5.19.6___acorn@8.14.0__valibot@1.0.0-rc.4___typescript@5.6.3__zod@3.24.2__@sveltejs+vite-plugin-svelte@5.0.3___svelte@5.19.6____acorn@8.14.0___vite@6.0.11____@types+node@20.17.16____jiti@2.4.2___@types+node@20.17.16__vite@5.4.14___@types+node@20.17.16__typescript@5.6.3__vite@6.0.11___@types+node@20.17.16___jiti@2.4.2__@types+node@20.17.16_@sveltejs+kit@2.17.3__@sveltejs+vite-plugin-svelte@5.0.3___svelte@5.19.6____acorn@8.14.0___vite@6.0.11____@types+node@20.17.16____jiti@2.4.2___@types+node@20.17.16__svelte@5.19.6___acorn@8.14.0__vite@5.4.14___@types+node@20.17.16__vite@6.0.11___@types+node@20.17.16___jiti@2.4.2__@types+node@20.17.16_valibot@1.0.0-rc.4__typescript@5.6.3_zod@3.24.2_@sveltejs+vite-plugin-svelte@5.0.3__svelte@5.19.6___acorn@8.14.0__vite@6.0.11___@types+node@20.17.16___jiti@2.4.2__@types+node@20.17.16_vite@5.4.14__@types+node@20.17.16_typescript@5.6.3_vite@6.0.11__@types+node@20.17.16__jiti@2.4.2_@types+node@20.17.16": {
|
||||
"integrity": "sha512-ha8r9eMmsGEGMY+ljV3FEyTtB72E7dt95y9HHUbCcaDnjbz3Q6n00BHLz7dfBZ9rqyaMeIO200EmP1IcYMExeg==",
|
||||
"dependencies": [
|
||||
"svelte@5.19.6_acorn@8.14.0",
|
||||
"svelte-toolbelt@0.4.6_svelte@5.19.6__acorn@8.14.0",
|
||||
"sveltekit-superforms"
|
||||
]
|
||||
},
|
||||
"fraction.js@4.3.7": {
|
||||
"integrity": "sha512-ZsDfxO51wGAXREY55a7la9LScWpwv9RxIrYABrlvOFBlH/ShPnrtsXeuUIfXKKOVicNxQ+o8JTbJvjS4M89yew=="
|
||||
},
|
||||
@ -9556,11 +9620,22 @@
|
||||
"integrity": "sha512-7Bv8RF0k6xjo7d4A/PxYLbUCfb6c+Vpd2/mB2yRDlew7Jb5hEXiCD9ibfO7wpk8i4sevK6DFny9h7EYbM3/sHg==",
|
||||
"dependencies": [
|
||||
"foreground-child",
|
||||
"jackspeak",
|
||||
"jackspeak@3.4.3",
|
||||
"minimatch@9.0.5",
|
||||
"minipass@7.1.2",
|
||||
"package-json-from-dist",
|
||||
"path-scurry"
|
||||
"path-scurry@1.11.1"
|
||||
]
|
||||
},
|
||||
"glob@11.0.1": {
|
||||
"integrity": "sha512-zrQDm8XPnYEKawJScsnM0QzobJxlT/kHOOlRTio8IH/GrmxRE5fjllkzdaHclIuNjUQTJYH2xHNIGfdpJkDJUw==",
|
||||
"dependencies": [
|
||||
"foreground-child",
|
||||
"jackspeak@4.1.0",
|
||||
"minimatch@10.0.1",
|
||||
"minipass@7.1.2",
|
||||
"package-json-from-dist",
|
||||
"path-scurry@2.0.0"
|
||||
]
|
||||
},
|
||||
"glob@7.2.3": {
|
||||
@ -10473,6 +10548,12 @@
|
||||
"@pkgjs/parseargs"
|
||||
]
|
||||
},
|
||||
"jackspeak@4.1.0": {
|
||||
"integrity": "sha512-9DDdhb5j6cpeitCbvLO7n7J4IxnbM6hoF6O1g4HQ5TfhvvKN8ywDM7668ZhMHRqVmxqhps/F6syWK2KcPxYlkw==",
|
||||
"dependencies": [
|
||||
"@isaacs/cliui"
|
||||
]
|
||||
},
|
||||
"jake@10.9.2": {
|
||||
"integrity": "sha512-2P4SQ0HrLQ+fw6llpLnOaGAvN2Zu6778SJMrCUwns4fOoG9ayrTiZk3VV8sCPkVZF8ab0zksVpS8FDY5pRCNBA==",
|
||||
"dependencies": [
|
||||
@ -10532,6 +10613,13 @@
|
||||
"json-parse-even-better-errors@4.0.0": {
|
||||
"integrity": "sha512-lR4MXjGNgkJc7tkQ97kb2nuEMnNCyU//XYVH0MKTGcXEiSudQ5MKGKen3C5QubYy0vmq+JGitUg92uuywGEwIA=="
|
||||
},
|
||||
"json-schema-to-ts@3.1.1": {
|
||||
"integrity": "sha512-+DWg8jCJG2TEnpy7kOm/7/AxaYoaRbjVB4LFZLySZlWn8exGs3A4OLJR966cVvU26N7X9TWxl+Jsw7dzAqKT6g==",
|
||||
"dependencies": [
|
||||
"@babel/runtime",
|
||||
"ts-algebra"
|
||||
]
|
||||
},
|
||||
"json-schema-traverse@0.4.1": {
|
||||
"integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg=="
|
||||
},
|
||||
@ -10638,6 +10726,15 @@
|
||||
"kind-of@6.0.3": {
|
||||
"integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw=="
|
||||
},
|
||||
"kkrpc@0.2.2_typescript@5.6.3": {
|
||||
"integrity": "sha512-EliGFPRf+dplMiqNipPUUj89WX9vEWfQkQU05ztbMfdK/SSgnHBbvm7QySGlEIlUb9Y55dSXPkROuxjHz2JbfA==",
|
||||
"dependencies": [
|
||||
"@tauri-apps/plugin-shell@2.2.0",
|
||||
"superjson",
|
||||
"typescript@5.6.3",
|
||||
"ws@8.18.1"
|
||||
]
|
||||
},
|
||||
"kleur@3.0.3": {
|
||||
"integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w=="
|
||||
},
|
||||
@ -10984,6 +11081,9 @@
|
||||
"lru-cache@10.4.3": {
|
||||
"integrity": "sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ=="
|
||||
},
|
||||
"lru-cache@11.0.2": {
|
||||
"integrity": "sha512-123qHRfJBmo2jXDbo/a5YOQrJoHF/GNQTLzQ5+IdK5pWpceK17yRc6ozlWd25FxvGKQbIUs91fDFkXmDHTKcyA=="
|
||||
},
|
||||
"lru-cache@5.1.1": {
|
||||
"integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==",
|
||||
"dependencies": [
|
||||
@ -11276,6 +11376,9 @@
|
||||
"media-typer@0.3.0": {
|
||||
"integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ=="
|
||||
},
|
||||
"memoize-weak@1.0.2": {
|
||||
"integrity": "sha512-gj39xkrjEw7nCn4nJ1M5ms6+MyMlyiGmttzsqAUsAKn6bYKwuTHh/AO3cKPF8IBrTIYTxb0wWXFs3E//Y8VoWQ=="
|
||||
},
|
||||
"merge-stream@2.0.0": {
|
||||
"integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w=="
|
||||
},
|
||||
@ -12658,6 +12761,13 @@
|
||||
"minipass@7.1.2"
|
||||
]
|
||||
},
|
||||
"path-scurry@2.0.0": {
|
||||
"integrity": "sha512-ypGJsmGtdXUOeM5u93TyeIEfEhM6s+ljAhrk5vAvSx8uyY/02OvrZnA0YNGUrPXfpJMgI1ODd3nwz8Npx4O4cg==",
|
||||
"dependencies": [
|
||||
"lru-cache@11.0.2",
|
||||
"minipass@7.1.2"
|
||||
]
|
||||
},
|
||||
"path-to-regexp@6.3.0": {
|
||||
"integrity": "sha512-Yhpw4T9C6hPpgPeA28us07OJeqZ5EzQTkbfwuhsUg0c237RomFoETJgmp2sa3F/41gfLE6G5cqcYwznmeEeOlQ=="
|
||||
},
|
||||
@ -13718,6 +13828,13 @@
|
||||
"glob@10.4.5"
|
||||
]
|
||||
},
|
||||
"rimraf@6.0.1": {
|
||||
"integrity": "sha512-9dkvaxAsk/xNXSJzMgFqqMCuFgt2+KsOFek3TMLfo8NCPfWpBmqwyNn5Y+NX56QUYfCtsyhF3ayiboEoUmJk/A==",
|
||||
"dependencies": [
|
||||
"glob@11.0.1",
|
||||
"package-json-from-dist"
|
||||
]
|
||||
},
|
||||
"robust-predicates@3.0.2": {
|
||||
"integrity": "sha512-IXgzBWvWQwE6PrDI05OvmXUIruQTcoMDzRsOd5CDvHCVLcLHMTSYvOK5Cm46kWqlV3yAbuSpBZdJ5oP5OUoStg=="
|
||||
},
|
||||
@ -14589,6 +14706,21 @@
|
||||
"zimmerframe"
|
||||
]
|
||||
},
|
||||
"sveltekit-superforms@2.24.0_@sveltejs+kit@2.17.3__@sveltejs+vite-plugin-svelte@5.0.3___svelte@5.19.6____acorn@8.14.0___vite@6.0.11____@types+node@20.17.16____jiti@2.4.2___@types+node@20.17.16__svelte@5.19.6___acorn@8.14.0__vite@5.4.14___@types+node@20.17.16__vite@6.0.11___@types+node@20.17.16___jiti@2.4.2__@types+node@20.17.16_svelte@5.19.6__acorn@8.14.0_valibot@1.0.0-rc.4__typescript@5.6.3_zod@3.24.2_@sveltejs+vite-plugin-svelte@5.0.3__svelte@5.19.6___acorn@8.14.0__vite@6.0.11___@types+node@20.17.16___jiti@2.4.2__@types+node@20.17.16_vite@5.4.14__@types+node@20.17.16_typescript@5.6.3_vite@6.0.11__@types+node@20.17.16__jiti@2.4.2_@types+node@20.17.16": {
|
||||
"integrity": "sha512-JuuaaPDn9OHUKc0Uy8jzv1jUZNfO4AHUE0JLcXjiuJNRokYLqC+RsPDL4/jUkqia97aZzrfTgB/meQ8iS5nNJg==",
|
||||
"dependencies": [
|
||||
"@gcornut/valibot-json-schema",
|
||||
"@sveltejs/kit@2.17.3_@sveltejs+vite-plugin-svelte@5.0.3__svelte@5.19.6___acorn@8.14.0__vite@6.0.11___@types+node@20.17.16___jiti@2.4.2__@types+node@20.17.16_svelte@5.19.6__acorn@8.14.0_vite@5.4.14__@types+node@20.17.16_vite@6.0.11__@types+node@20.17.16__jiti@2.4.2_@types+node@20.17.16",
|
||||
"devalue@5.1.1",
|
||||
"json-schema-to-ts",
|
||||
"memoize-weak",
|
||||
"svelte@5.19.6_acorn@8.14.0",
|
||||
"ts-deepmerge",
|
||||
"valibot@1.0.0-rc.4_typescript@5.6.3",
|
||||
"zod@3.24.2",
|
||||
"zod-to-json-schema"
|
||||
]
|
||||
},
|
||||
"svg-tags@1.0.0": {
|
||||
"integrity": "sha512-ovssysQTa+luh7A5Weu3Rta6FJlFBBbInjOh722LIt6klpU2/HtdUbszju/G4devcvk8PGt7FCLv5wftu3THUA=="
|
||||
},
|
||||
@ -14707,6 +14839,30 @@
|
||||
"yallist@5.0.0"
|
||||
]
|
||||
},
|
||||
"tauri-api-adapter@0.3.27_typescript@5.6.3": {
|
||||
"integrity": "sha512-YzfdVlOdwlRqjRRPxvXNTb6acclbrfHC4FtotzAXcbZv7UckEE3Orzvg4AteP5Gb1veyam+NW0MFMU5Ime5vWw==",
|
||||
"dependencies": [
|
||||
"@tauri-apps/api@2.3.0",
|
||||
"@tauri-apps/plugin-dialog@2.2.0",
|
||||
"@tauri-apps/plugin-fs@2.2.0",
|
||||
"@tauri-apps/plugin-http@2.3.0",
|
||||
"@tauri-apps/plugin-log@2.2.3",
|
||||
"@tauri-apps/plugin-notification@2.2.1",
|
||||
"@tauri-apps/plugin-os@2.2.0",
|
||||
"@tauri-apps/plugin-shell@2.2.0",
|
||||
"@tauri-apps/plugin-upload@2.2.1",
|
||||
"kkrpc",
|
||||
"rimraf@6.0.1",
|
||||
"shx",
|
||||
"tauri-plugin-clipboard-api",
|
||||
"tauri-plugin-network-api",
|
||||
"tauri-plugin-shellx-api@2.0.16",
|
||||
"tauri-plugin-system-info-api@2.0.10_typescript@5.6.3",
|
||||
"tsc-alias",
|
||||
"typescript@5.6.3",
|
||||
"valibot@1.0.0-rc.4_typescript@5.6.3"
|
||||
]
|
||||
},
|
||||
"tauri-api-adapter@0.3.8_typescript@5.6.3_rollup@4.34.0_tslib@2.8.1": {
|
||||
"integrity": "sha512-HX6VMCWLzMIhTVuEaKbgLbQXR3YpIrzAgZGPv0Nge7zIn352G5vA/QJxQ9rlpFO4Y8S+Ro7VXR7DpVPMisTHaQ==",
|
||||
"dependencies": [
|
||||
@ -14728,7 +14884,7 @@
|
||||
"tauri-plugin-clipboard-api",
|
||||
"tauri-plugin-network-api",
|
||||
"tauri-plugin-shellx-api@2.0.14",
|
||||
"tauri-plugin-system-info-api",
|
||||
"tauri-plugin-system-info-api@2.0.8_typescript@5.6.3",
|
||||
"tsc-alias",
|
||||
"typescript@5.6.3",
|
||||
"valibot@0.40.0_typescript@5.6.3"
|
||||
@ -14744,8 +14900,8 @@
|
||||
"tauri-plugin-network-api@2.0.5_typescript@5.6.3": {
|
||||
"integrity": "sha512-u7CTvmgP4Lt3fK0/mVMD/pcWlXsWenC0YYlJUE2VQCThx8VQzxSAXgyPhcg0+CT5iIoPt5mkfixMfamM8e6v/w==",
|
||||
"dependencies": [
|
||||
"@tauri-apps/api@2.2.0",
|
||||
"valibot@1.0.0-beta.14_typescript@5.6.3"
|
||||
"@tauri-apps/api@2.3.0",
|
||||
"valibot@1.0.0-rc.4_typescript@5.6.3"
|
||||
]
|
||||
},
|
||||
"tauri-plugin-shellx-api@2.0.14": {
|
||||
@ -14760,6 +14916,21 @@
|
||||
"@tauri-apps/api@2.3.0"
|
||||
]
|
||||
},
|
||||
"tauri-plugin-svelte@1.2.1": {
|
||||
"integrity": "sha512-xusgcHpnXqRt4RO+3UjqAlOCTh5PcxzDEa11Qd8Z3cHz6MMl0PLE6j0ExeAur+dTiZVLEGFsIm6Qd0LY9ED/wA==",
|
||||
"dependencies": [
|
||||
"@tauri-apps/api@2.3.0",
|
||||
"@tauri-store/shared",
|
||||
"svelte@5.20.5_acorn@8.14.0"
|
||||
]
|
||||
},
|
||||
"tauri-plugin-system-info-api@2.0.10_typescript@5.6.3": {
|
||||
"integrity": "sha512-QalL92OgjARjyBoK4RFMV1+JRdWKyWBqv+kMi2Y7rnLkIGQUvsMQwvyCcbjdV3qoDbeAdU97G7qu7uPoO+c+OQ==",
|
||||
"dependencies": [
|
||||
"@tauri-apps/api@2.3.0",
|
||||
"valibot@1.0.0-rc.4_typescript@5.6.3"
|
||||
]
|
||||
},
|
||||
"tauri-plugin-system-info-api@2.0.8_typescript@5.6.3": {
|
||||
"integrity": "sha512-EFdLXNGp6Zu9SNsZCkU+55A8027OnrVw/TQrd0oJHgfZzs4qvm1iMmSvyid4MLftt33iZDhjCzxYijaaOxeKSg==",
|
||||
"dependencies": [
|
||||
@ -14879,6 +15050,9 @@
|
||||
"trough@2.2.0": {
|
||||
"integrity": "sha512-tmMpK00BjZiUyVyvrBK7knerNgmgvcV/KLVyuma/SC+TQN167GrMRciANTz09+k3zW8L8t60jWO1GpfkZdjTaw=="
|
||||
},
|
||||
"ts-algebra@2.0.0": {
|
||||
"integrity": "sha512-FPAhNPFMrkwz76P7cdjdmiShwMynZYN6SgOujD1urY4oNm80Ou9oMdmbR45LotcKOXoy7wSmHkRFE6Mxbrhefw=="
|
||||
},
|
||||
"ts-api-utils@1.4.3_typescript@5.6.3": {
|
||||
"integrity": "sha512-i3eMG77UTMD0hZhgRS562pv83RC6ukSAC2GMNWc+9dieh/+jDM5u5YG+NHX6VNDRHQcHwmsTHctP9LhbC3WxVw==",
|
||||
"dependencies": [
|
||||
@ -14897,6 +15071,9 @@
|
||||
"typescript@5.6.3"
|
||||
]
|
||||
},
|
||||
"ts-deepmerge@7.0.2": {
|
||||
"integrity": "sha512-akcpDTPuez4xzULo5NwuoKwYRtjQJ9eoNfBACiBMaXwNAx7B1PKfe5wqUFJuW5uKzQ68YjDFwPaWHDG1KnFGsA=="
|
||||
},
|
||||
"ts-graphviz@2.1.6": {
|
||||
"integrity": "sha512-XyLVuhBVvdJTJr2FJJV2L1pc4MwSjMhcunRVgDE9k4wbb2ee7ORYnPewxMWUav12vxyfUM686MSGsqnVRIInuw==",
|
||||
"dependencies": [
|
||||
@ -15460,6 +15637,9 @@
|
||||
"vue-screen-utils"
|
||||
]
|
||||
},
|
||||
"valibot@0.31.1": {
|
||||
"integrity": "sha512-2YYIhPrnVSz/gfT2/iXVTrSj92HwchCt9Cga/6hX4B26iCz9zkIsGTS0HjDYTZfTi1Un0X6aRvhBi1cfqs/i0Q=="
|
||||
},
|
||||
"valibot@0.40.0_typescript@5.6.3": {
|
||||
"integrity": "sha512-XHKnaVtwHqxPwnGOsLrwka9CEaL7yNeLNp707OKv/bmT29GnPVdl6PxBOZ6BW7hF66/6QT6iVbOlnW7qVPmoKw==",
|
||||
"dependencies": [
|
||||
@ -15478,6 +15658,12 @@
|
||||
"typescript@5.6.3"
|
||||
]
|
||||
},
|
||||
"valibot@1.0.0-rc.4_typescript@5.6.3": {
|
||||
"integrity": "sha512-VRaChgFv7Ab0P54AMLu7+GqoexdTPQ54Plj59X9qV0AFozI3j9CGH43skg+TqgMpXnrW8jxlJ2TTHAtAD3t4qA==",
|
||||
"dependencies": [
|
||||
"typescript@5.6.3"
|
||||
]
|
||||
},
|
||||
"validate-npm-package-license@3.0.4": {
|
||||
"integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==",
|
||||
"dependencies": [
|
||||
@ -15979,6 +16165,9 @@
|
||||
"ws@8.18.0": {
|
||||
"integrity": "sha512-8VbfWfHLbbwu3+N6OKsOMpBdT4kXPDDB9cJk2bJ6mh9ucxdlnNvH1e+roYkKmN9Nxw2yjz7VzeO9oOz2zJ04Pw=="
|
||||
},
|
||||
"ws@8.18.1": {
|
||||
"integrity": "sha512-RKW2aJZMXeMxVpnZ6bck+RswznaxmzdULiBr6KY7XkTnW8uvt0iT9H5DkHUChXrc+uurzwa0rVI16n/Xzjdz1w=="
|
||||
},
|
||||
"y18n@5.0.8": {
|
||||
"integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA=="
|
||||
},
|
||||
@ -16041,6 +16230,12 @@
|
||||
"readable-stream@4.7.0"
|
||||
]
|
||||
},
|
||||
"zod-to-json-schema@3.24.4_zod@3.24.2": {
|
||||
"integrity": "sha512-0uNlcvgabyrni9Ag8Vghj21drk7+7tp7VTwwR7KxxXXc/3pbXz2PHlDgj3cICahgF1kHm4dExBFj7BXrZJXzig==",
|
||||
"dependencies": [
|
||||
"zod@3.24.2"
|
||||
]
|
||||
},
|
||||
"zod@3.24.1": {
|
||||
"integrity": "sha512-muH7gBL9sI1nciMZV67X5fTKKBLtwpZ5VBp1vsOQzj1MhrBZ4wlVCm3gedKZWLp0Oyel8sIGfeiz54Su+OVT+A=="
|
||||
},
|
||||
@ -16158,7 +16353,7 @@
|
||||
"npm:fuse.js@^7.1.0",
|
||||
"npm:globals@^15.14.0",
|
||||
"npm:gsap@^3.12.7",
|
||||
"npm:kkrpc@~0.2.1",
|
||||
"npm:kkrpc@~0.2.2",
|
||||
"npm:lucide-svelte@0.474",
|
||||
"npm:lz-string@^1.5.0",
|
||||
"npm:prettier@^3.5.2",
|
||||
@ -16209,14 +16404,14 @@
|
||||
"npm:@types/node@^22.10.5",
|
||||
"npm:@types/semver@^7.5.8",
|
||||
"npm:fs-extra@^11.2.0",
|
||||
"npm:kkrpc@~0.2.1",
|
||||
"npm:kkrpc@~0.2.2",
|
||||
"npm:lodash@^4.17.21",
|
||||
"npm:madge@8",
|
||||
"npm:minimatch@^10.0.1",
|
||||
"npm:node-fetch@^3.3.2",
|
||||
"npm:semver@^7.6.3",
|
||||
"npm:svelte-sonner@~0.3.28",
|
||||
"npm:tauri-api-adapter@~0.3.26",
|
||||
"npm:tauri-api-adapter@~0.3.27",
|
||||
"npm:tauri-plugin-network-api@2.0.5",
|
||||
"npm:tauri-plugin-shellx-api@^2.0.16",
|
||||
"npm:tauri-plugin-system-info-api@2.0.8",
|
||||
|
@ -53,3 +53,16 @@
|
||||
### Patch Changes
|
||||
|
||||
- More Icon Options
|
||||
|
||||
## 0.1.6
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- Upgrade kkrpc to 0.2.1, which uses superjson for serialization
|
||||
|
||||
## 0.1.7
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- Upgrade kkrpc to 0.2.2, supports both json and superjson serialization, for backward compatibility
|
||||
- The previous version breaks extension compatibility.
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@kksh/api",
|
||||
"version": "0.1.6",
|
||||
"version": "0.1.7",
|
||||
"type": "module",
|
||||
"repository": {
|
||||
"type": "git",
|
||||
@ -65,13 +65,13 @@
|
||||
"@tauri-apps/plugin-store": "^2.2.0",
|
||||
"@tauri-apps/plugin-updater": "^2.3.0",
|
||||
"@tauri-apps/plugin-upload": "^2.2.1",
|
||||
"kkrpc": "^0.2.1",
|
||||
"kkrpc": "^0.2.2",
|
||||
"lodash": "^4.17.21",
|
||||
"minimatch": "^10.0.1",
|
||||
"node-fetch": "^3.3.2",
|
||||
"semver": "^7.6.3",
|
||||
"svelte-sonner": "^0.3.28",
|
||||
"tauri-api-adapter": "^0.3.26",
|
||||
"tauri-api-adapter": "^0.3.27",
|
||||
"tauri-plugin-network-api": "2.0.5",
|
||||
"tauri-plugin-shellx-api": "^2.0.16",
|
||||
"tauri-plugin-system-info-api": "2.0.8",
|
||||
|
@ -195,7 +195,8 @@ export const ExtPackageJsonExtra = v.object({
|
||||
...ExtPackageJson.entries,
|
||||
...{
|
||||
extPath: v.string(),
|
||||
extFolderName: v.string()
|
||||
extFolderName: v.string(),
|
||||
apiVersion: v.optional(v.string("API version of the extension"))
|
||||
}
|
||||
})
|
||||
|
||||
|
@ -21,7 +21,7 @@ export const breakingChangesVersionCheckpoints = [
|
||||
const checkpointVersions = breakingChangesVersionCheckpoints.map((c) => c.version)
|
||||
const sortedCheckpointVersions = sort(checkpointVersions)
|
||||
|
||||
export const version = "0.1.6"
|
||||
export const version = "0.1.7"
|
||||
|
||||
export function isVersionBetween(v: string, start: string, end: string) {
|
||||
const vCleaned = clean(v)
|
||||
|
@ -18,6 +18,7 @@
|
||||
"@kksh/supabase": "workspace:*",
|
||||
"@std/semver": "npm:@jsr/std__semver@^1.0.3",
|
||||
"@tauri-apps/plugin-upload": "^2.2.1",
|
||||
"semver": "^7.7.1",
|
||||
"uuid": "^11.0.3"
|
||||
},
|
||||
"peerDependencies": {
|
||||
|
@ -3,6 +3,7 @@ import { ExtPackageJson, ExtPackageJsonExtra, License } from "@kksh/api/models"
|
||||
import { basename, dirname, join } from "@tauri-apps/api/path"
|
||||
import { readDir, readTextFile } from "@tauri-apps/plugin-fs"
|
||||
import { debug, error } from "@tauri-apps/plugin-log"
|
||||
import semver from "semver"
|
||||
import * as v from "valibot"
|
||||
import { upsertExtension } from "./db"
|
||||
|
||||
@ -11,6 +12,15 @@ const OptionalExtPackageJson = v.object({
|
||||
license: v.optional(License, "MIT") // TODO: remove this optional package json later
|
||||
})
|
||||
|
||||
export function parseAPIVersion(dependencies: Record<string, string>) {
|
||||
const stripPrefix = (version: string) => version.replace(/^[^0-9]+/, "") // Remove leading ^, ~, etc.
|
||||
const apiVersion = dependencies["@kksh/api"]
|
||||
if (apiVersion) {
|
||||
return semver.clean(stripPrefix(apiVersion)) ?? undefined
|
||||
}
|
||||
return undefined
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
* @param manifestPath absolute path to package.json
|
||||
@ -26,12 +36,13 @@ export function loadExtensionManifestFromDisk(manifestPath: string): Promise<Ext
|
||||
console.error("Parse Error:", v.flatten<typeof OptionalExtPackageJson>(parse.issues))
|
||||
throw new Error(`Invalid manifest: ${manifestPath}`)
|
||||
} else {
|
||||
// debug(`Loaded extension ${parse.output.kunkun.identifier} from ${manifestPath}`)
|
||||
const apiVersion = parseAPIVersion(parse.output.dependencies || {})
|
||||
const extPath = await dirname(manifestPath)
|
||||
const extFolderName = await basename(extPath)
|
||||
return Object.assign(parse.output, {
|
||||
extPath,
|
||||
extFolderName
|
||||
extFolderName,
|
||||
apiVersion
|
||||
})
|
||||
}
|
||||
})
|
||||
|
55
pnpm-lock.yaml
generated
55
pnpm-lock.yaml
generated
@ -255,8 +255,8 @@ importers:
|
||||
specifier: ^3.12.7
|
||||
version: 3.12.7
|
||||
kkrpc:
|
||||
specifier: ^0.2.1
|
||||
version: 0.2.1(typescript@5.6.3)
|
||||
specifier: ^0.2.2
|
||||
version: 0.2.2(typescript@5.6.3)
|
||||
lz-string:
|
||||
specifier: ^1.5.0
|
||||
version: 1.5.0
|
||||
@ -338,7 +338,7 @@ importers:
|
||||
version: 8.25.0(eslint@9.21.0(jiti@2.4.0))(typescript@5.6.3)
|
||||
autoprefixer:
|
||||
specifier: ^10.4.20
|
||||
version: 10.4.20(postcss@8.4.49)
|
||||
version: 10.4.20(postcss@8.5.3)
|
||||
bits-ui:
|
||||
specifier: 1.0.0-next.86
|
||||
version: 1.0.0-next.86(svelte@5.20.5)
|
||||
@ -442,8 +442,8 @@ importers:
|
||||
specifier: ^2.2.1
|
||||
version: 2.2.1
|
||||
kkrpc:
|
||||
specifier: ^0.2.1
|
||||
version: 0.2.1(typescript@5.7.2)
|
||||
specifier: ^0.2.2
|
||||
version: 0.2.2(typescript@5.7.2)
|
||||
lodash:
|
||||
specifier: ^4.17.21
|
||||
version: 4.17.21
|
||||
@ -460,8 +460,8 @@ importers:
|
||||
specifier: ^0.3.28
|
||||
version: 0.3.28(svelte@5.20.5)
|
||||
tauri-api-adapter:
|
||||
specifier: ^0.3.26
|
||||
version: 0.3.26(typescript@5.7.2)
|
||||
specifier: ^0.3.27
|
||||
version: 0.3.27(typescript@5.7.2)
|
||||
tauri-plugin-network-api:
|
||||
specifier: 2.0.5
|
||||
version: 2.0.5(typescript@5.7.2)
|
||||
@ -551,6 +551,9 @@ importers:
|
||||
'@tauri-apps/plugin-upload':
|
||||
specifier: ^2.2.1
|
||||
version: 2.2.1
|
||||
semver:
|
||||
specifier: ^7.7.1
|
||||
version: 7.7.1
|
||||
typescript:
|
||||
specifier: ^5.0.0
|
||||
version: 5.5.4
|
||||
@ -8799,8 +8802,8 @@ packages:
|
||||
resolution: {integrity: sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==}
|
||||
engines: {node: '>=0.10.0'}
|
||||
|
||||
kkrpc@0.2.1:
|
||||
resolution: {integrity: sha512-LjB7OMMJYA5W+g7LcyCvYuskwMKOaF/TmeAkmHYZIEp1BUor69I/P7hNOZYAf2oAwpTbhSGOR7Bso+QhkjqxGA==}
|
||||
kkrpc@0.2.2:
|
||||
resolution: {integrity: sha512-EliGFPRf+dplMiqNipPUUj89WX9vEWfQkQU05ztbMfdK/SSgnHBbvm7QySGlEIlUb9Y55dSXPkROuxjHz2JbfA==}
|
||||
peerDependencies:
|
||||
typescript: ^5.0.0
|
||||
|
||||
@ -11173,10 +11176,6 @@ packages:
|
||||
supercluster@7.1.5:
|
||||
resolution: {integrity: sha512-EulshI3pGUM66o6ZdH3ReiFcvHpM3vAigyK+vcxdjpJyEbIIrtbmBdY23mGgnI24uXiGFvrGq9Gkum/8U7vJWg==}
|
||||
|
||||
superjson@2.2.1:
|
||||
resolution: {integrity: sha512-8iGv75BYOa0xRJHK5vRLEjE2H/i4lulTjzpUXic3Eg8akftYjkmQDa8JARQ42rlczXyFR3IeRoeFCc7RxHsYZA==}
|
||||
engines: {node: '>=16'}
|
||||
|
||||
superjson@2.2.2:
|
||||
resolution: {integrity: sha512-5JRxVqC8I8NuOUjzBbvVJAKNM8qoVuH0O77h4WInc/qC2q5IreqKxYwgkga3PfA22OayK2ikceb/B26dztPl+Q==}
|
||||
engines: {node: '>=16'}
|
||||
@ -11366,8 +11365,8 @@ packages:
|
||||
resolution: {integrity: sha512-5S7Va8hKfV7W5U6g3aYxXmlPoZVAwUMy9AOKyF2fVuZa2UD3qZjg578OrLRt8PcNN1PleVaL/5/yYATNL0ICUw==}
|
||||
engines: {node: '>=18'}
|
||||
|
||||
tauri-api-adapter@0.3.26:
|
||||
resolution: {integrity: sha512-AfdxF6EIBrpkhciySkLheYBlpFkUG3dIXHTJXLhhn00fibKBZBSiLps7u9s1WVGcSonGrqXzqgsAjRX1nOHyhQ==}
|
||||
tauri-api-adapter@0.3.27:
|
||||
resolution: {integrity: sha512-YzfdVlOdwlRqjRRPxvXNTb6acclbrfHC4FtotzAXcbZv7UckEE3Orzvg4AteP5Gb1veyam+NW0MFMU5Ime5vWw==}
|
||||
peerDependencies:
|
||||
typescript: ^5.0.0
|
||||
|
||||
@ -18526,7 +18525,7 @@ snapshots:
|
||||
mitt: 3.0.1
|
||||
perfect-debounce: 1.0.0
|
||||
speakingurl: 14.0.1
|
||||
superjson: 2.2.1
|
||||
superjson: 2.2.2
|
||||
|
||||
'@vue/devtools-kit@7.6.4':
|
||||
dependencies:
|
||||
@ -18536,7 +18535,7 @@ snapshots:
|
||||
mitt: 3.0.1
|
||||
perfect-debounce: 1.0.0
|
||||
speakingurl: 14.0.1
|
||||
superjson: 2.2.1
|
||||
superjson: 2.2.2
|
||||
|
||||
'@vue/devtools-shared@7.6.4':
|
||||
dependencies:
|
||||
@ -18884,6 +18883,16 @@ snapshots:
|
||||
postcss: 8.5.1
|
||||
postcss-value-parser: 4.2.0
|
||||
|
||||
autoprefixer@10.4.20(postcss@8.5.3):
|
||||
dependencies:
|
||||
browserslist: 4.24.2
|
||||
caniuse-lite: 1.0.30001676
|
||||
fraction.js: 4.3.7
|
||||
normalize-range: 0.1.2
|
||||
picocolors: 1.1.1
|
||||
postcss: 8.5.3
|
||||
postcss-value-parser: 4.2.0
|
||||
|
||||
available-typed-arrays@1.0.7:
|
||||
dependencies:
|
||||
possible-typed-array-names: 1.0.0
|
||||
@ -21836,7 +21845,7 @@ snapshots:
|
||||
|
||||
kind-of@6.0.3: {}
|
||||
|
||||
kkrpc@0.2.1(typescript@5.6.3):
|
||||
kkrpc@0.2.2(typescript@5.6.3):
|
||||
dependencies:
|
||||
'@tauri-apps/plugin-shell': 2.2.0
|
||||
superjson: 2.2.2
|
||||
@ -21846,7 +21855,7 @@ snapshots:
|
||||
- bufferutil
|
||||
- utf-8-validate
|
||||
|
||||
kkrpc@0.2.1(typescript@5.7.2):
|
||||
kkrpc@0.2.2(typescript@5.7.2):
|
||||
dependencies:
|
||||
'@tauri-apps/plugin-shell': 2.2.0
|
||||
superjson: 2.2.2
|
||||
@ -24655,10 +24664,6 @@ snapshots:
|
||||
dependencies:
|
||||
kdbush: 3.0.0
|
||||
|
||||
superjson@2.2.1:
|
||||
dependencies:
|
||||
copy-anything: 3.0.5
|
||||
|
||||
superjson@2.2.2:
|
||||
dependencies:
|
||||
copy-anything: 3.0.5
|
||||
@ -25089,7 +25094,7 @@ snapshots:
|
||||
mkdirp: 3.0.1
|
||||
yallist: 5.0.0
|
||||
|
||||
tauri-api-adapter@0.3.26(typescript@5.7.2):
|
||||
tauri-api-adapter@0.3.27(typescript@5.7.2):
|
||||
dependencies:
|
||||
'@tauri-apps/api': 2.3.0
|
||||
'@tauri-apps/plugin-dialog': 2.2.0
|
||||
@ -25100,7 +25105,7 @@ snapshots:
|
||||
'@tauri-apps/plugin-os': 2.2.0
|
||||
'@tauri-apps/plugin-shell': 2.2.0
|
||||
'@tauri-apps/plugin-upload': 2.2.1
|
||||
kkrpc: 0.2.1(typescript@5.7.2)
|
||||
kkrpc: 0.2.2(typescript@5.7.2)
|
||||
rimraf: 6.0.1
|
||||
shx: 0.3.4
|
||||
tauri-plugin-clipboard-api: 2.1.11(typescript@5.7.2)
|
||||
|
Loading…
x
Reference in New Issue
Block a user