From 08ed9a25bcf42bac18125130d7014d48529e92b3 Mon Sep 17 00:00:00 2001 From: Natsumi Date: Mon, 9 Feb 2026 19:58:58 +1300 Subject: [PATCH] Fixes --- src/components/LocationWorld.vue | 2 +- src/stores/avatarProvider.js | 3 ++- src/stores/vrcx.js | 24 +++++++++++++++++++++--- 3 files changed, 24 insertions(+), 5 deletions(-) diff --git a/src/components/LocationWorld.vue b/src/components/LocationWorld.vue index 61562d20..515b4491 100644 --- a/src/components/LocationWorld.vue +++ b/src/components/LocationWorld.vue @@ -7,7 +7,7 @@ ({{ groupName }}) - + diff --git a/src/stores/avatarProvider.js b/src/stores/avatarProvider.js index cb1c854e..1cf0353c 100644 --- a/src/stores/avatarProvider.js +++ b/src/stores/avatarProvider.js @@ -1,7 +1,7 @@ import { ref, watch } from 'vue'; import { defineStore } from 'pinia'; -import { removeFromArray } from '../shared/utils'; +import { router } from '../plugin/router'; import { useAdvancedSettingsStore } from './settings/advanced'; import { watchState } from '../service/watchState'; @@ -132,6 +132,7 @@ export const useAvatarProviderStore = defineStore('AvatarProvider', () => { } function showAvatarProviderDialog() { + router.push({ name: 'settings' }); isAvatarProviderDialogVisible.value = true; } diff --git a/src/stores/vrcx.js b/src/stores/vrcx.js index f6306a5f..9eaf6804 100644 --- a/src/stores/vrcx.js +++ b/src/stores/vrcx.js @@ -13,6 +13,7 @@ import { SEARCH_LIMIT_MIN, TABLE_MAX_SIZE_MAX } from '../shared/constants'; +import { avatarRequest, worldRequest } from '../api'; import { clearPiniaActionTrail, getPiniaActionTrail @@ -42,7 +43,6 @@ import { useUserStore } from './user'; import { useVrcStatusStore } from './vrcStatus'; import { useWorldStore } from './world'; import { watchState } from '../service/watchState'; -import { worldRequest } from '../api'; import configRepository from '../service/config'; @@ -639,10 +639,28 @@ export const useVrcxStore = defineStore('Vrcx', () => { case 'local-favorite-world': console.log('local-favorite-world', commandArg); const [id, group] = commandArg.split(':'); - worldRequest.getCachedWorld({ worldId: id }).then((args1) => { + if (!id || !group) { + toast.error('Invalid local favorite world command'); + break; + } + worldRequest.getCachedWorld({ worldId: id }).then(() => { searchStore.directAccessWorld(id); favoriteStore.addLocalWorldFavorite(id, group); - return args1; + }); + break; + case 'local-favorite-avatar': + console.log('local-favorite-avatar', commandArg); + const [avatarIdFav, avatarGroup] = commandArg.split(':'); + if (!avatarIdFav || !avatarGroup) { + toast.error('Invalid local favorite avatar command'); + break; + } + avatarRequest.getAvatar({ avatarId: avatarIdFav }).then(() => { + avatarStore.showAvatarDialog(avatarIdFav); + favoriteStore.addLocalAvatarFavorite( + avatarIdFav, + avatarGroup + ); }); break; case 'addavatardb':