This commit is contained in:
pa
2026-03-10 17:44:15 +09:00
parent 17b582c904
commit ff1529920b
237 changed files with 419 additions and 419 deletions
+1 -1
View File
@@ -25,7 +25,7 @@
import { Toaster } from './components/ui/sonner'; import { Toaster } from './components/ui/sonner';
import { TooltipProvider } from './components/ui/tooltip'; import { TooltipProvider } from './components/ui/tooltip';
import { createGlobalStores } from './stores'; import { createGlobalStores } from './stores';
import { initNoty } from './plugin/noty'; import { initNoty } from './plugins/noty';
import { getGameLogTable } from './coordinators/gameLogCoordinator'; import { getGameLogTable } from './coordinators/gameLogCoordinator';
import { runCheckVRChatDebugLoggingFlow } from './coordinators/gameCoordinator'; import { runCheckVRChatDebugLoggingFlow } from './coordinators/gameCoordinator';
+1 -1
View File
@@ -7,7 +7,7 @@ const mockApplyCurrentUser = vi.fn((json) => ({ id: json.id || 'usr_me', ...json
const mockApplyUser = vi.fn((json) => ({ ...json })); const mockApplyUser = vi.fn((json) => ({ ...json }));
const mockApplyWorld = vi.fn((json) => ({ ...json })); const mockApplyWorld = vi.fn((json) => ({ ...json }));
vi.mock('../../service/request', () => ({ vi.mock('../../services/request', () => ({
request: (...args) => mockRequest(...args) request: (...args) => mockRequest(...args)
})); }));
+1 -1
View File
@@ -6,7 +6,7 @@ const mockHandleFavoriteAdd = vi.fn();
const mockHandleFavoriteDelete = vi.fn(); const mockHandleFavoriteDelete = vi.fn();
const mockHandleFavoriteGroupClear = vi.fn(); const mockHandleFavoriteGroupClear = vi.fn();
vi.mock('../../service/request', () => ({ vi.mock('../../services/request', () => ({
request: (...args) => mockRequest(...args) request: (...args) => mockRequest(...args)
})); }));
+1 -1
View File
@@ -4,7 +4,7 @@ const mockRequest = vi.fn();
const mockInvalidateQueries = vi.fn().mockResolvedValue(); const mockInvalidateQueries = vi.fn().mockResolvedValue();
const mockApplyUser = vi.fn((json) => json); const mockApplyUser = vi.fn((json) => json);
vi.mock('../../service/request', () => ({ vi.mock('../../services/request', () => ({
request: (...args) => mockRequest(...args) request: (...args) => mockRequest(...args)
})); }));
+1 -1
View File
@@ -4,7 +4,7 @@ const mockRequest = vi.fn();
const mockInvalidateQueries = vi.fn().mockResolvedValue(); const mockInvalidateQueries = vi.fn().mockResolvedValue();
const mockApplyGroup = vi.fn((json) => json); const mockApplyGroup = vi.fn((json) => json);
vi.mock('../../service/request', () => ({ vi.mock('../../services/request', () => ({
request: (...args) => mockRequest(...args) request: (...args) => mockRequest(...args)
})); }));
+1 -1
View File
@@ -4,7 +4,7 @@ const mockRequest = vi.fn();
const mockInvalidateQueries = vi.fn().mockResolvedValue(); const mockInvalidateQueries = vi.fn().mockResolvedValue();
const mockRemoveQueries = vi.fn(); const mockRemoveQueries = vi.fn();
vi.mock('../../service/request', () => ({ vi.mock('../../services/request', () => ({
request: (...args) => mockRequest(...args) request: (...args) => mockRequest(...args)
})); }));
+1 -1
View File
@@ -1,4 +1,4 @@
import { request } from '../service/request'; import { request } from '../services/request';
import { handleConfig } from '../coordinators/userCoordinator'; import { handleConfig } from '../coordinators/userCoordinator';
const loginReq = { const loginReq = {
+1 -1
View File
@@ -1,5 +1,5 @@
import { patchAndRefetchActiveQuery, queryKeys } from '../queries'; import { patchAndRefetchActiveQuery, queryKeys } from '../queries';
import { request } from '../service/request'; import { request } from '../services/request';
import { useUserStore } from '../stores'; import { useUserStore } from '../stores';
import { applyCurrentUser } from '../coordinators/userCoordinator'; import { applyCurrentUser } from '../coordinators/userCoordinator';
+1 -1
View File
@@ -1,4 +1,4 @@
import { request } from '../service/request'; import { request } from '../services/request';
const avatarModerationReq = { const avatarModerationReq = {
getAvatarModerations() { getAvatarModerations() {
+1 -1
View File
@@ -5,7 +5,7 @@ import {
handleFavoriteGroupClear handleFavoriteGroupClear
} from '../coordinators/favoriteCoordinator'; } from '../coordinators/favoriteCoordinator';
import { queryClient } from '../queries'; import { queryClient } from '../queries';
import { request } from '../service/request'; import { request } from '../services/request';
/** /**
* *
+1 -1
View File
@@ -1,5 +1,5 @@
import { queryClient } from '../queries'; import { queryClient } from '../queries';
import { request } from '../service/request'; import { request } from '../services/request';
import { useUserStore } from '../stores/user'; import { useUserStore } from '../stores/user';
import { applyUser } from '../coordinators/userCoordinator'; import { applyUser } from '../coordinators/userCoordinator';
+1 -1
View File
@@ -1,7 +1,7 @@
import { useUserStore } from '../stores'; import { useUserStore } from '../stores';
import { applyGroup } from '../coordinators/groupCoordinator'; import { applyGroup } from '../coordinators/groupCoordinator';
import { queryClient } from '../queries'; import { queryClient } from '../queries';
import { request } from '../service/request'; import { request } from '../services/request';
/** /**
* *
+1 -1
View File
@@ -1,6 +1,6 @@
import { useAvatarStore, useWorldStore } from '../stores'; import { useAvatarStore, useWorldStore } from '../stores';
import { applyWorld } from '../coordinators/worldCoordinator'; import { applyWorld } from '../coordinators/worldCoordinator';
import { request } from '../service/request'; import { request } from '../services/request';
const imageReq = { const imageReq = {
async uploadAvatarFailCleanup(id) { async uploadAvatarFailCleanup(id) {
+1 -1
View File
@@ -3,7 +3,7 @@
* Export all API requests from here * Export all API requests from here
*/ */
import { request } from '../service/request'; import { request } from '../services/request';
import authRequest from './auth'; import authRequest from './auth';
import avatarModerationRequest from './avatarModeration'; import avatarModerationRequest from './avatarModeration';
+2 -2
View File
@@ -1,7 +1,7 @@
import { toast } from 'vue-sonner'; import { toast } from 'vue-sonner';
import { i18n } from '../plugin/i18n'; import { i18n } from '../plugins/i18n';
import { request } from '../service/request'; import { request } from '../services/request';
import { useInstanceStore } from '../stores'; import { useInstanceStore } from '../stores';
const instanceReq = { const instanceReq = {
+1 -1
View File
@@ -1,5 +1,5 @@
import { queryClient } from '../queries'; import { queryClient } from '../queries';
import { request } from '../service/request'; import { request } from '../services/request';
/** /**
* *
+1 -1
View File
@@ -1,4 +1,4 @@
import { request } from '../service/request'; import { request } from '../services/request';
import { useUserStore } from '../stores'; import { useUserStore } from '../stores';
function getCurrentUserId() { function getCurrentUserId() {
+1 -1
View File
@@ -1,5 +1,5 @@
import { queryClient, queryKeys } from '../queries'; import { queryClient, queryKeys } from '../queries';
import { request } from '../service/request'; import { request } from '../services/request';
import { useUserStore } from '../stores'; import { useUserStore } from '../stores';
/** /**
+1 -1
View File
@@ -1,4 +1,4 @@
import { request } from '../service/request'; import { request } from '../services/request';
import { useGalleryStore } from '../stores'; import { useGalleryStore } from '../stores';
const notificationReq = { const notificationReq = {
+1 -1
View File
@@ -1,4 +1,4 @@
import { request } from '../service/request'; import { request } from '../services/request';
const playerModerationReq = { const playerModerationReq = {
getPlayerModerations() { getPlayerModerations() {
+1 -1
View File
@@ -1,4 +1,4 @@
import { request } from '../service/request'; import { request } from '../services/request';
const propReq = { const propReq = {
/** /**
+1 -1
View File
@@ -1,5 +1,5 @@
import { patchAndRefetchActiveQuery, queryKeys } from '../queries'; import { patchAndRefetchActiveQuery, queryKeys } from '../queries';
import { request } from '../service/request'; import { request } from '../services/request';
import { useUserStore } from '../stores'; import { useUserStore } from '../stores';
import { applyUser, applyCurrentUser } from '../coordinators/userCoordinator'; import { applyUser, applyCurrentUser } from '../coordinators/userCoordinator';
+1 -1
View File
@@ -1,5 +1,5 @@
import { queryClient } from '../queries'; import { queryClient } from '../queries';
import { request } from '../service/request'; import { request } from '../services/request';
/** /**
* *
+1 -1
View File
@@ -1,5 +1,5 @@
import { queryClient } from '../queries'; import { queryClient } from '../queries';
import { request } from '../service/request'; import { request } from '../services/request';
import { useUserStore } from '../stores'; import { useUserStore } from '../stores';
/** /**
+1 -1
View File
@@ -1,5 +1,5 @@
import { patchAndRefetchActiveQuery, queryKeys } from '../queries'; import { patchAndRefetchActiveQuery, queryKeys } from '../queries';
import { request } from '../service/request'; import { request } from '../services/request';
import { applyWorld } from '../coordinators/worldCoordinator'; import { applyWorld } from '../coordinators/worldCoordinator';
const worldReq = { const worldReq = {
+1 -1
View File
@@ -7,7 +7,7 @@ import {
initPlugins, initPlugins,
initRouter, initRouter,
initSentry initSentry
} from './plugin'; } from './plugins';
import { initPiniaPlugins, pinia } from './stores'; import { initPiniaPlugins, pinia } from './stores';
import { queryClient } from './queries'; import { queryClient } from './queries';
+1 -1
View File
@@ -399,7 +399,7 @@
import { THEME_CONFIG, links, navDefinitions } from '../shared/constants'; import { THEME_CONFIG, links, navDefinitions } from '../shared/constants';
import { openExternalLink } from '../shared/utils'; import { openExternalLink } from '../shared/utils';
import configRepository from '../service/config'; import configRepository from '../services/config';
const CustomNavDialog = defineAsyncComponent(() => import('./dialogs/CustomNavDialog.vue')); const CustomNavDialog = defineAsyncComponent(() => import('./dialogs/CustomNavDialog.vue'));
+2 -2
View File
@@ -284,7 +284,7 @@
import { useIntervalFn, useNow } from '@vueuse/core'; import { useIntervalFn, useNow } from '@vueuse/core';
import { TooltipWrapper } from '@/components/ui/tooltip'; import { TooltipWrapper } from '@/components/ui/tooltip';
import { useI18n } from 'vue-i18n'; import { useI18n } from 'vue-i18n';
import { wsState } from '@/service/websocket'; import { wsState } from '@/services/websocket';
import dayjs from 'dayjs'; import dayjs from 'dayjs';
import timezone from 'dayjs/plugin/timezone'; import timezone from 'dayjs/plugin/timezone';
@@ -299,7 +299,7 @@
parseClockOffset parseClockOffset
} from './statusBarUtils'; } from './statusBarUtils';
import configRepository from '../service/config'; import configRepository from '../services/config';
dayjs.extend(utc); dayjs.extend(utc);
dayjs.extend(timezone); dayjs.extend(timezone);
+6 -6
View File
@@ -13,7 +13,7 @@ vi.mock('../../views/Feed/Feed.vue', () => ({
vi.mock('../../views/Feed/columns.jsx', () => ({ vi.mock('../../views/Feed/columns.jsx', () => ({
columns: [] columns: []
})); }));
vi.mock('../../plugin/router', () => ({ vi.mock('../../plugins/router', () => ({
router: { router: {
beforeEach: vi.fn(), beforeEach: vi.fn(),
push: vi.fn(), push: vi.fn(),
@@ -34,10 +34,10 @@ vi.mock('vue-router', async (importOriginal) => {
})) }))
}; };
}); });
vi.mock('../../plugin/interopApi', () => ({ vi.mock('../../plugins/interopApi', () => ({
initInteropApi: vi.fn() initInteropApi: vi.fn()
})); }));
vi.mock('../../service/database', () => ({ vi.mock('../../services/database', () => ({
database: new Proxy( database: new Proxy(
{}, {},
{ {
@@ -48,7 +48,7 @@ vi.mock('../../service/database', () => ({
} }
) )
})); }));
vi.mock('../../service/config', () => ({ vi.mock('../../services/config', () => ({
default: { default: {
init: vi.fn(), init: vi.fn(),
getString: vi getString: vi
@@ -74,10 +74,10 @@ vi.mock('../../service/config', () => ({
remove: vi.fn() remove: vi.fn()
} }
})); }));
vi.mock('../../service/jsonStorage', () => ({ vi.mock('../../services/jsonStorage', () => ({
default: vi.fn() default: vi.fn()
})); }));
vi.mock('../../service/watchState', () => ({ vi.mock('../../services/watchState', () => ({
watchState: { isLoggedIn: false } watchState: { isLoggedIn: false }
})); }));
+6 -6
View File
@@ -16,7 +16,7 @@ vi.mock('../../views/Feed/Feed.vue', () => ({
vi.mock('../../views/Feed/columns.jsx', () => ({ vi.mock('../../views/Feed/columns.jsx', () => ({
columns: [] columns: []
})); }));
vi.mock('../../plugin/router', () => ({ vi.mock('../../plugins/router', () => ({
router: { router: {
beforeEach: vi.fn(), beforeEach: vi.fn(),
push: vi.fn(), push: vi.fn(),
@@ -39,11 +39,11 @@ vi.mock('vue-router', async (importOriginal) => {
}; };
}); });
vi.mock('../../plugin/interopApi', () => ({ vi.mock('../../plugins/interopApi', () => ({
initInteropApi: vi.fn() initInteropApi: vi.fn()
})); }));
vi.mock('../../service/database', () => ({ vi.mock('../../services/database', () => ({
database: new Proxy( database: new Proxy(
{}, {},
{ {
@@ -55,7 +55,7 @@ vi.mock('../../service/database', () => ({
) )
})); }));
vi.mock('../../service/config', () => ({ vi.mock('../../services/config', () => ({
default: { default: {
init: vi.fn(), init: vi.fn(),
getString: vi getString: vi
@@ -81,10 +81,10 @@ vi.mock('../../service/config', () => ({
remove: vi.fn() remove: vi.fn()
} }
})); }));
vi.mock('../../service/jsonStorage', () => ({ vi.mock('../../services/jsonStorage', () => ({
default: vi.fn() default: vi.fn()
})); }));
vi.mock('../../service/watchState', () => ({ vi.mock('../../services/watchState', () => ({
watchState: { isLoggedIn: false } watchState: { isLoggedIn: false }
})); }));
@@ -12,7 +12,7 @@ vi.mock('../../views/Feed/Feed.vue', () => ({
default: { template: '<div />' } default: { template: '<div />' }
})); }));
vi.mock('../../views/Feed/columns.jsx', () => ({ columns: [] })); vi.mock('../../views/Feed/columns.jsx', () => ({ columns: [] }));
vi.mock('../../plugin/router', () => ({ vi.mock('../../plugins/router', () => ({
router: { router: {
beforeEach: vi.fn(), beforeEach: vi.fn(),
push: vi.fn(), push: vi.fn(),
@@ -33,8 +33,8 @@ vi.mock('vue-router', async (importOriginal) => {
})) }))
}; };
}); });
vi.mock('../../plugin/interopApi', () => ({ initInteropApi: vi.fn() })); vi.mock('../../plugins/interopApi', () => ({ initInteropApi: vi.fn() }));
vi.mock('../../service/database', () => ({ vi.mock('../../services/database', () => ({
database: new Proxy( database: new Proxy(
{}, {},
{ {
@@ -45,7 +45,7 @@ vi.mock('../../service/database', () => ({
} }
) )
})); }));
vi.mock('../../service/config', () => ({ vi.mock('../../services/config', () => ({
default: { default: {
init: vi.fn(), init: vi.fn(),
getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'), getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'),
@@ -63,8 +63,8 @@ vi.mock('../../service/config', () => ({
remove: vi.fn() remove: vi.fn()
} }
})); }));
vi.mock('../../service/jsonStorage', () => ({ default: vi.fn() })); vi.mock('../../services/jsonStorage', () => ({ default: vi.fn() }));
vi.mock('../../service/watchState', () => ({ vi.mock('../../services/watchState', () => ({
watchState: { isLoggedIn: false } watchState: { isLoggedIn: false }
})); }));
+8 -8
View File
@@ -9,7 +9,7 @@ import en from '../../localization/en.json';
// --- Mocks --- // --- Mocks ---
vi.mock('../../service/config', () => ({ vi.mock('../../services/config', () => ({
default: { default: {
init: vi.fn(), init: vi.fn(),
getString: vi getString: vi
@@ -36,14 +36,14 @@ vi.mock('../../service/config', () => ({
} }
})); }));
vi.mock('../../service/websocket', () => ({ vi.mock('../../services/websocket', () => ({
wsState: { connected: false, messageCount: 0, bytesReceived: 0 }, wsState: { connected: false, messageCount: 0, bytesReceived: 0 },
initWebsocket: vi.fn(), initWebsocket: vi.fn(),
closeWebSocket: vi.fn(), closeWebSocket: vi.fn(),
reconnectWebSocket: vi.fn() reconnectWebSocket: vi.fn()
})); }));
vi.mock('../../service/webapi', () => ({ vi.mock('../../services/webapi', () => ({
default: { default: {
execute: vi.fn().mockResolvedValue({ execute: vi.fn().mockResolvedValue({
status: 200, status: 200,
@@ -62,13 +62,13 @@ vi.mock('worker-timers', () => ({
clearTimeout: vi.fn() clearTimeout: vi.fn()
})); }));
vi.mock('../../service/jsonStorage', () => ({ vi.mock('../../services/jsonStorage', () => ({
default: vi.fn() default: vi.fn()
})); }));
vi.mock('../../service/watchState', () => ({ vi.mock('../../services/watchState', () => ({
watchState: { isLoggedIn: false } watchState: { isLoggedIn: false }
})); }));
vi.mock('../../service/database', () => ({ vi.mock('../../services/database', () => ({
database: new Proxy( database: new Proxy(
{}, {},
{ {
@@ -79,7 +79,7 @@ vi.mock('../../service/database', () => ({
} }
) )
})); }));
vi.mock('../../plugin/router', () => ({ vi.mock('../../plugins/router', () => ({
router: { router: {
beforeEach: vi.fn(), beforeEach: vi.fn(),
push: vi.fn(), push: vi.fn(),
@@ -100,7 +100,7 @@ vi.mock('vue-router', async (importOriginal) => {
})) }))
}; };
}); });
vi.mock('../../plugin/interopApi', () => ({ vi.mock('../../plugins/interopApi', () => ({
initInteropApi: vi.fn() initInteropApi: vi.fn()
})); }));
@@ -597,7 +597,7 @@
} from '../../ui/dropdown-menu'; } from '../../ui/dropdown-menu';
import { Badge } from '../../ui/badge'; import { Badge } from '../../ui/badge';
import { avatarRequest } from '../../../api'; import { avatarRequest } from '../../../api';
import { database } from '../../../service/database'; import { database } from '../../../services/database';
import { formatJsonVars } from '../../../shared/utils/base/ui'; import { formatJsonVars } from '../../../shared/utils/base/ui';
import { handleImageUploadInput } from '../../../shared/utils/imageUpload'; import { handleImageUploadInput } from '../../../shared/utils/imageUpload';
import { runDeleteVRChatCacheFlow as deleteVRChatCache } from '../../../coordinators/gameCoordinator'; import { runDeleteVRChatCacheFlow as deleteVRChatCache } from '../../../coordinators/gameCoordinator';
@@ -15,7 +15,7 @@ vi.mock('vue-i18n', () => ({
}) })
})); }));
vi.mock('../../../../plugin/router', () => { vi.mock('../../../../plugins/router', () => {
const { ref } = require('vue'); const { ref } = require('vue');
return { return {
router: { router: {
@@ -40,8 +40,8 @@ vi.mock('vue-router', async (importOriginal) => {
})) }))
}; };
}); });
vi.mock('../../../../plugin/interopApi', () => ({ initInteropApi: vi.fn() })); vi.mock('../../../../plugins/interopApi', () => ({ initInteropApi: vi.fn() }));
vi.mock('../../../../service/database', () => ({ vi.mock('../../../../services/database', () => ({
database: new Proxy( database: new Proxy(
{}, {},
{ {
@@ -52,7 +52,7 @@ vi.mock('../../../../service/database', () => ({
} }
) )
})); }));
vi.mock('../../../../service/config', () => ({ vi.mock('../../../../services/config', () => ({
default: { default: {
init: vi.fn(), init: vi.fn(),
getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'), getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'),
@@ -70,11 +70,11 @@ vi.mock('../../../../service/config', () => ({
remove: vi.fn() remove: vi.fn()
} }
})); }));
vi.mock('../../../../service/jsonStorage', () => ({ default: vi.fn() })); vi.mock('../../../../services/jsonStorage', () => ({ default: vi.fn() }));
vi.mock('../../../../service/watchState', () => ({ vi.mock('../../../../services/watchState', () => ({
watchState: { isLoggedIn: false } watchState: { isLoggedIn: false }
})); }));
vi.mock('../../../../service/request', () => ({ vi.mock('../../../../services/request', () => ({
request: vi.fn().mockResolvedValue({ json: {} }), request: vi.fn().mockResolvedValue({ json: {} }),
processBulk: vi.fn(), processBulk: vi.fn(),
buildRequestInit: vi.fn(), buildRequestInit: vi.fn(),
@@ -19,7 +19,7 @@ vi.mock('vue-i18n', () => {
}; };
}); });
vi.mock('../../../../plugin/router', () => { vi.mock('../../../../plugins/router', () => {
const { ref } = require('vue'); const { ref } = require('vue');
return { return {
router: { router: {
@@ -44,8 +44,8 @@ vi.mock('vue-router', async (importOriginal) => {
})) }))
}; };
}); });
vi.mock('../../../../plugin/interopApi', () => ({ initInteropApi: vi.fn() })); vi.mock('../../../../plugins/interopApi', () => ({ initInteropApi: vi.fn() }));
vi.mock('../../../../service/database', () => ({ vi.mock('../../../../services/database', () => ({
database: new Proxy( database: new Proxy(
{}, {},
{ {
@@ -56,7 +56,7 @@ vi.mock('../../../../service/database', () => ({
} }
) )
})); }));
vi.mock('../../../../service/config', () => ({ vi.mock('../../../../services/config', () => ({
default: { default: {
init: vi.fn(), init: vi.fn(),
getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'), getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'),
@@ -74,11 +74,11 @@ vi.mock('../../../../service/config', () => ({
remove: vi.fn() remove: vi.fn()
} }
})); }));
vi.mock('../../../../service/jsonStorage', () => ({ default: vi.fn() })); vi.mock('../../../../services/jsonStorage', () => ({ default: vi.fn() }));
vi.mock('../../../../service/watchState', () => ({ vi.mock('../../../../services/watchState', () => ({
watchState: { isLoggedIn: false } watchState: { isLoggedIn: false }
})); }));
vi.mock('../../../../service/request', () => ({ vi.mock('../../../../services/request', () => ({
request: vi.fn().mockResolvedValue({ json: {} }), request: vi.fn().mockResolvedValue({ json: {} }),
processBulk: vi.fn(), processBulk: vi.fn(),
buildRequestInit: vi.fn(), buildRequestInit: vi.fn(),
@@ -10,7 +10,7 @@ vi.mock('../../../../api', () => ({
}, },
userRequest: {} userRequest: {}
})); }));
vi.mock('../../../../plugin/router', () => { vi.mock('../../../../plugins/router', () => {
const { ref } = require('vue'); const { ref } = require('vue');
return { return {
router: { router: {
@@ -35,8 +35,8 @@ vi.mock('vue-router', async (importOriginal) => {
})) }))
}; };
}); });
vi.mock('../../../../plugin/interopApi', () => ({ initInteropApi: vi.fn() })); vi.mock('../../../../plugins/interopApi', () => ({ initInteropApi: vi.fn() }));
vi.mock('../../../../service/database', () => ({ vi.mock('../../../../services/database', () => ({
database: new Proxy( database: new Proxy(
{}, {},
{ {
@@ -47,7 +47,7 @@ vi.mock('../../../../service/database', () => ({
} }
) )
})); }));
vi.mock('../../../../service/config', () => ({ vi.mock('../../../../services/config', () => ({
default: { default: {
init: vi.fn(), init: vi.fn(),
getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'), getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'),
@@ -65,11 +65,11 @@ vi.mock('../../../../service/config', () => ({
remove: vi.fn() remove: vi.fn()
} }
})); }));
vi.mock('../../../../service/jsonStorage', () => ({ default: vi.fn() })); vi.mock('../../../../services/jsonStorage', () => ({ default: vi.fn() }));
vi.mock('../../../../service/watchState', () => ({ vi.mock('../../../../services/watchState', () => ({
watchState: { isLoggedIn: false } watchState: { isLoggedIn: false }
})); }));
vi.mock('../../../../service/request', () => ({ vi.mock('../../../../services/request', () => ({
request: vi.fn().mockResolvedValue({ json: {} }), request: vi.fn().mockResolvedValue({ json: {} }),
processBulk: vi.fn(), processBulk: vi.fn(),
buildRequestInit: vi.fn(), buildRequestInit: vi.fn(),
@@ -13,7 +13,7 @@ vi.mock('vue-i18n', () => ({
install: vi.fn() install: vi.fn()
}) })
})); }));
vi.mock('../../../../plugin/router', () => { vi.mock('../../../../plugins/router', () => {
const { ref: vRef } = require('vue'); const { ref: vRef } = require('vue');
return { return {
router: { router: {
@@ -38,8 +38,8 @@ vi.mock('vue-router', async (importOriginal) => {
})) }))
}; };
}); });
vi.mock('../../../../plugin/interopApi', () => ({ initInteropApi: vi.fn() })); vi.mock('../../../../plugins/interopApi', () => ({ initInteropApi: vi.fn() }));
vi.mock('../../../../service/database', () => ({ vi.mock('../../../../services/database', () => ({
database: new Proxy( database: new Proxy(
{}, {},
{ {
@@ -50,7 +50,7 @@ vi.mock('../../../../service/database', () => ({
} }
) )
})); }));
vi.mock('../../../../service/config', () => ({ vi.mock('../../../../services/config', () => ({
default: { default: {
init: vi.fn(), init: vi.fn(),
getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'), getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'),
@@ -68,11 +68,11 @@ vi.mock('../../../../service/config', () => ({
remove: vi.fn() remove: vi.fn()
} }
})); }));
vi.mock('../../../../service/jsonStorage', () => ({ default: vi.fn() })); vi.mock('../../../../services/jsonStorage', () => ({ default: vi.fn() }));
vi.mock('../../../../service/watchState', () => ({ vi.mock('../../../../services/watchState', () => ({
watchState: { isLoggedIn: false } watchState: { isLoggedIn: false }
})); }));
vi.mock('../../../../service/request', () => ({ vi.mock('../../../../services/request', () => ({
request: vi.fn().mockResolvedValue({ json: {} }), request: vi.fn().mockResolvedValue({ json: {} }),
processBulk: vi.fn(), processBulk: vi.fn(),
buildRequestInit: vi.fn(), buildRequestInit: vi.fn(),
@@ -1,5 +1,5 @@
import { Checkbox } from '@/components/ui/checkbox'; import { Checkbox } from '@/components/ui/checkbox';
import { i18n } from '@/plugin'; import { i18n } from '@/plugins';
import { formatDateFilter } from '@/shared/utils'; import { formatDateFilter } from '@/shared/utils';
import { Button } from '@/components/ui/button'; import { Button } from '@/components/ui/button';
import { ArrowUpDown } from 'lucide-vue-next'; import { ArrowUpDown } from 'lucide-vue-next';
@@ -1,5 +1,5 @@
import { Checkbox } from '@/components/ui/checkbox'; import { Checkbox } from '@/components/ui/checkbox';
import { i18n } from '@/plugin'; import { i18n } from '@/plugins';
import { ArrowUpDown } from 'lucide-vue-next'; import { ArrowUpDown } from 'lucide-vue-next';
import { Button } from '@/components/ui/button'; import { Button } from '@/components/ui/button';
@@ -1,5 +1,5 @@
import { Checkbox } from '@/components/ui/checkbox'; import { Checkbox } from '@/components/ui/checkbox';
import { i18n } from '@/plugin'; import { i18n } from '@/plugins';
import { ArrowUpDown } from 'lucide-vue-next'; import { ArrowUpDown } from 'lucide-vue-next';
import { Button } from '@/components/ui/button'; import { Button } from '@/components/ui/button';
@@ -1,5 +1,5 @@
import { Checkbox } from '@/components/ui/checkbox'; import { Checkbox } from '@/components/ui/checkbox';
import { i18n } from '@/plugin'; import { i18n } from '@/plugins';
import { ArrowUpDown } from 'lucide-vue-next'; import { ArrowUpDown } from 'lucide-vue-next';
import { Button } from '@/components/ui/button'; import { Button } from '@/components/ui/button';
@@ -1,5 +1,5 @@
import Location from '@/components/Location.vue'; import Location from '@/components/Location.vue';
import { i18n } from '@/plugin'; import { i18n } from '@/plugins';
import { formatDateFilter } from '@/shared/utils'; import { formatDateFilter } from '@/shared/utils';
import { ArrowUpDown } from 'lucide-vue-next'; import { ArrowUpDown } from 'lucide-vue-next';
import { Button } from '@/components/ui/button'; import { Button } from '@/components/ui/button';
@@ -1,5 +1,5 @@
import { Checkbox } from '@/components/ui/checkbox'; import { Checkbox } from '@/components/ui/checkbox';
import { i18n } from '@/plugin'; import { i18n } from '@/plugins';
import { formatDateFilter } from '@/shared/utils'; import { formatDateFilter } from '@/shared/utils';
import { ArrowUpDown } from 'lucide-vue-next'; import { ArrowUpDown } from 'lucide-vue-next';
import { Button } from '@/components/ui/button'; import { Button } from '@/components/ui/button';
@@ -1,6 +1,6 @@
import CountdownTimer from '@/components/CountdownTimer.vue'; import CountdownTimer from '@/components/CountdownTimer.vue';
import { Button } from '@/components/ui/button'; import { Button } from '@/components/ui/button';
import { i18n } from '@/plugin'; import { i18n } from '@/plugins';
import { SquarePen } from 'lucide-vue-next'; import { SquarePen } from 'lucide-vue-next';
const { t } = i18n.global; const { t } = i18n.global;
+1 -1
View File
@@ -101,7 +101,7 @@
import { groupRequest, queryRequest } from '../../api'; import { groupRequest, queryRequest } from '../../api';
import { VirtualCombobox } from '../ui/virtual-combobox'; import { VirtualCombobox } from '../ui/virtual-combobox';
import configRepository from '../../service/config'; import configRepository from '../../services/config';
const { vipFriends, onlineFriends, activeFriends, offlineFriends } = storeToRefs(useFriendStore()); const { vipFriends, onlineFriends, activeFriends, offlineFriends } = storeToRefs(useFriendStore());
const { currentUserGroups, inviteGroupDialog } = storeToRefs(useGroupStore()); const { currentUserGroups, inviteGroupDialog } = storeToRefs(useGroupStore());
+1 -1
View File
@@ -165,7 +165,7 @@
import { instanceRequest, queryRequest } from '../../api'; import { instanceRequest, queryRequest } from '../../api';
import InviteDialog from './InviteDialog/InviteDialog.vue'; import InviteDialog from './InviteDialog/InviteDialog.vue';
import configRepository from '../../service/config'; import configRepository from '../../services/config';
const { t } = useI18n(); const { t } = useI18n();
+1 -1
View File
@@ -585,7 +585,7 @@
import { VirtualCombobox } from '../ui/virtual-combobox'; import { VirtualCombobox } from '../ui/virtual-combobox';
import InviteDialog from './InviteDialog/InviteDialog.vue'; import InviteDialog from './InviteDialog/InviteDialog.vue';
import configRepository from '../../service/config'; import configRepository from '../../services/config';
const props = defineProps({ const props = defineProps({
newInstanceDialogLocationTag: { newInstanceDialogLocationTag: {
@@ -41,7 +41,7 @@
import { DataTableLayout } from '../../ui/data-table'; import { DataTableLayout } from '../../ui/data-table';
import { InputGroupField } from '../../../components/ui/input-group'; import { InputGroupField } from '../../../components/ui/input-group';
import { createColumns } from './previousInstancesInfoColumns.jsx'; import { createColumns } from './previousInstancesInfoColumns.jsx';
import { database } from '../../../service/database'; import { database } from '../../../services/database';
import { useVrcxVueTable } from '../../../lib/table/useVrcxVueTable'; import { useVrcxVueTable } from '../../../lib/table/useVrcxVueTable';
import { lookupUser } from '../../../coordinators/userCoordinator'; import { lookupUser } from '../../../coordinators/userCoordinator';
@@ -56,7 +56,7 @@
} from '../../../shared/utils'; } from '../../../shared/utils';
import { DataTableLayout } from '../../ui/data-table'; import { DataTableLayout } from '../../ui/data-table';
import { createPreviousInstancesColumns } from './previousInstancesColumns.jsx'; import { createPreviousInstancesColumns } from './previousInstancesColumns.jsx';
import { database } from '../../../service/database'; import { database } from '../../../services/database';
import { useVrcxVueTable } from '../../../lib/table/useVrcxVueTable'; import { useVrcxVueTable } from '../../../lib/table/useVrcxVueTable';
const props = defineProps({ const props = defineProps({
@@ -4,7 +4,7 @@ import DisplayName from '../../DisplayName.vue';
import Location from '../../Location.vue'; import Location from '../../Location.vue';
import LocationWorld from '../../LocationWorld.vue'; import LocationWorld from '../../LocationWorld.vue';
import { Button } from '../../ui/button'; import { Button } from '../../ui/button';
import { i18n } from '../../../plugin'; import { i18n } from '../../../plugins';
import { formatDateFilter } from '../../../shared/utils'; import { formatDateFilter } from '../../../shared/utils';
const { t } = i18n.global; const { t } = i18n.global;
@@ -1,7 +1,7 @@
import { ArrowUpDown } from 'lucide-vue-next'; import { ArrowUpDown } from 'lucide-vue-next';
import { Button } from '../../ui/button'; import { Button } from '../../ui/button';
import { i18n } from '../../../plugin'; import { i18n } from '../../../plugins';
import { formatDateFilter } from '../../../shared/utils'; import { formatDateFilter } from '../../../shared/utils';
const { t } = i18n.global; const { t } = i18n.global;
@@ -67,8 +67,8 @@
compareByLastActiveRef, compareByLastActiveRef,
userImage userImage
} from '../../../shared/utils'; } from '../../../shared/utils';
import { database } from '../../../service/database'; import { database } from '../../../services/database';
import { processBulk } from '../../../service/request'; import { processBulk } from '../../../services/request';
import { useOptionKeySelect } from '../../../composables/useOptionKeySelect'; import { useOptionKeySelect } from '../../../composables/useOptionKeySelect';
import { useUserStore } from '../../../stores'; import { useUserStore } from '../../../stores';
import { userDialogMutualFriendSortingOptions } from '../../../shared/constants'; import { userDialogMutualFriendSortingOptions } from '../../../shared/constants';
@@ -19,7 +19,7 @@ vi.mock('vue-i18n', () => {
}; };
}); });
vi.mock('../../../../plugin/router', () => { vi.mock('../../../../plugins/router', () => {
const { ref } = require('vue'); const { ref } = require('vue');
return { return {
router: { router: {
@@ -44,8 +44,8 @@ vi.mock('vue-router', async (importOriginal) => {
})) }))
}; };
}); });
vi.mock('../../../../plugin/interopApi', () => ({ initInteropApi: vi.fn() })); vi.mock('../../../../plugins/interopApi', () => ({ initInteropApi: vi.fn() }));
vi.mock('../../../../service/database', () => ({ vi.mock('../../../../services/database', () => ({
database: new Proxy( database: new Proxy(
{}, {},
{ {
@@ -56,7 +56,7 @@ vi.mock('../../../../service/database', () => ({
} }
) )
})); }));
vi.mock('../../../../service/config', () => ({ vi.mock('../../../../services/config', () => ({
default: { default: {
init: vi.fn(), init: vi.fn(),
getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'), getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'),
@@ -74,8 +74,8 @@ vi.mock('../../../../service/config', () => ({
remove: vi.fn() remove: vi.fn()
} }
})); }));
vi.mock('../../../../service/jsonStorage', () => ({ default: vi.fn() })); vi.mock('../../../../services/jsonStorage', () => ({ default: vi.fn() }));
vi.mock('../../../../service/watchState', () => ({ vi.mock('../../../../services/watchState', () => ({
watchState: { isLoggedIn: false } watchState: { isLoggedIn: false }
})); }));
@@ -16,7 +16,7 @@ vi.mock('vue-i18n', () => ({
}) })
})); }));
vi.mock('../../../../plugin/router', () => { vi.mock('../../../../plugins/router', () => {
const { ref } = require('vue'); const { ref } = require('vue');
return { return {
router: { router: {
@@ -43,8 +43,8 @@ vi.mock('vue-router', async (importOriginal) => {
}; };
}); });
vi.mock('../../../../plugin/interopApi', () => ({ initInteropApi: vi.fn() })); vi.mock('../../../../plugins/interopApi', () => ({ initInteropApi: vi.fn() }));
vi.mock('../../../../service/database', () => ({ vi.mock('../../../../services/database', () => ({
database: new Proxy( database: new Proxy(
{}, {},
{ {
@@ -56,7 +56,7 @@ vi.mock('../../../../service/database', () => ({
) )
})); }));
vi.mock('../../../../service/config', () => ({ vi.mock('../../../../services/config', () => ({
default: { default: {
init: vi.fn(), init: vi.fn(),
getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'), getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'),
@@ -75,11 +75,11 @@ vi.mock('../../../../service/config', () => ({
} }
})); }));
vi.mock('../../../../service/jsonStorage', () => ({ default: vi.fn() })); vi.mock('../../../../services/jsonStorage', () => ({ default: vi.fn() }));
vi.mock('../../../../service/watchState', () => ({ vi.mock('../../../../services/watchState', () => ({
watchState: { isLoggedIn: false } watchState: { isLoggedIn: false }
})); }));
vi.mock('../../../../service/request', () => ({ vi.mock('../../../../services/request', () => ({
request: vi.fn().mockResolvedValue({ json: {} }), request: vi.fn().mockResolvedValue({ json: {} }),
processBulk: vi.fn(), processBulk: vi.fn(),
buildRequestInit: vi.fn(), buildRequestInit: vi.fn(),
@@ -15,7 +15,7 @@ vi.mock('vue-i18n', () => ({
}) })
})); }));
vi.mock('../../../../plugin/router', () => { vi.mock('../../../../plugins/router', () => {
const { ref } = require('vue'); const { ref } = require('vue');
return { return {
router: { router: {
@@ -40,8 +40,8 @@ vi.mock('vue-router', async (importOriginal) => {
})) }))
}; };
}); });
vi.mock('../../../../plugin/interopApi', () => ({ initInteropApi: vi.fn() })); vi.mock('../../../../plugins/interopApi', () => ({ initInteropApi: vi.fn() }));
vi.mock('../../../../service/database', () => ({ vi.mock('../../../../services/database', () => ({
database: new Proxy( database: new Proxy(
{}, {},
{ {
@@ -52,7 +52,7 @@ vi.mock('../../../../service/database', () => ({
} }
) )
})); }));
vi.mock('../../../../service/config', () => ({ vi.mock('../../../../services/config', () => ({
default: { default: {
init: vi.fn(), init: vi.fn(),
getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'), getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'),
@@ -70,11 +70,11 @@ vi.mock('../../../../service/config', () => ({
remove: vi.fn() remove: vi.fn()
} }
})); }));
vi.mock('../../../../service/jsonStorage', () => ({ default: vi.fn() })); vi.mock('../../../../services/jsonStorage', () => ({ default: vi.fn() }));
vi.mock('../../../../service/watchState', () => ({ vi.mock('../../../../services/watchState', () => ({
watchState: { isLoggedIn: false } watchState: { isLoggedIn: false }
})); }));
vi.mock('../../../../service/request', () => ({ vi.mock('../../../../services/request', () => ({
request: vi.fn().mockResolvedValue({ json: {} }), request: vi.fn().mockResolvedValue({ json: {} }),
processBulk: vi.fn(), processBulk: vi.fn(),
buildRequestInit: vi.fn(), buildRequestInit: vi.fn(),
@@ -19,7 +19,7 @@ vi.mock('vue-i18n', () => {
}; };
}); });
vi.mock('../../../../plugin/router', () => { vi.mock('../../../../plugins/router', () => {
const { ref } = require('vue'); const { ref } = require('vue');
return { return {
router: { router: {
@@ -44,8 +44,8 @@ vi.mock('vue-router', async (importOriginal) => {
})) }))
}; };
}); });
vi.mock('../../../../plugin/interopApi', () => ({ initInteropApi: vi.fn() })); vi.mock('../../../../plugins/interopApi', () => ({ initInteropApi: vi.fn() }));
vi.mock('../../../../service/database', () => ({ vi.mock('../../../../services/database', () => ({
database: new Proxy( database: new Proxy(
{}, {},
{ {
@@ -56,7 +56,7 @@ vi.mock('../../../../service/database', () => ({
} }
) )
})); }));
vi.mock('../../../../service/config', () => ({ vi.mock('../../../../services/config', () => ({
default: { default: {
init: vi.fn(), init: vi.fn(),
getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'), getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'),
@@ -74,11 +74,11 @@ vi.mock('../../../../service/config', () => ({
remove: vi.fn() remove: vi.fn()
} }
})); }));
vi.mock('../../../../service/jsonStorage', () => ({ default: vi.fn() })); vi.mock('../../../../services/jsonStorage', () => ({ default: vi.fn() }));
vi.mock('../../../../service/watchState', () => ({ vi.mock('../../../../services/watchState', () => ({
watchState: { isLoggedIn: false } watchState: { isLoggedIn: false }
})); }));
vi.mock('../../../../service/request', () => ({ vi.mock('../../../../services/request', () => ({
request: vi.fn().mockResolvedValue({ json: {} }), request: vi.fn().mockResolvedValue({ json: {} }),
processBulk: vi.fn(), processBulk: vi.fn(),
buildRequestInit: vi.fn(), buildRequestInit: vi.fn(),
@@ -33,7 +33,7 @@ vi.mock('../../../../shared/utils', () => ({
parseLocation: vi.fn(() => ({ worldId: 'wrld_test', tag: 'wrld_test~123' })) parseLocation: vi.fn(() => ({ worldId: 'wrld_test', tag: 'wrld_test~123' }))
})); }));
vi.mock('../../../../service/database', () => ({ vi.mock('../../../../services/database', () => ({
database: { database: {
addFriendLogHistory: vi.fn() addFriendLogHistory: vi.fn()
} }
@@ -48,7 +48,7 @@ const {
playerModerationRequest, playerModerationRequest,
miscRequest miscRequest
} = await import('../../../../api'); } = await import('../../../../api');
const { database } = await import('../../../../service/database'); const { database } = await import('../../../../services/database');
function createMockUserDialog() { function createMockUserDialog() {
return ref({ return ref({
@@ -1,6 +1,6 @@
import CountdownTimer from '@/components/CountdownTimer.vue'; import CountdownTimer from '@/components/CountdownTimer.vue';
import { Button } from '@/components/ui/button'; import { Button } from '@/components/ui/button';
import { i18n } from '@/plugin'; import { i18n } from '@/plugins';
import { SquarePen } from 'lucide-vue-next'; import { SquarePen } from 'lucide-vue-next';
const { t } = i18n.global; const { t } = i18n.global;
@@ -9,7 +9,7 @@ import {
queryRequest queryRequest
} from '../../../api'; } from '../../../api';
import { copyToClipboard, parseLocation } from '../../../shared/utils'; import { copyToClipboard, parseLocation } from '../../../shared/utils';
import { database } from '../../../service/database'; import { database } from '../../../services/database';
/** /**
* Composable for UserDialog command dispatch. * Composable for UserDialog command dispatch.
@@ -9,14 +9,14 @@ vi.mock('../../../../shared/utils', () => ({
timeToText: vi.fn((ms) => `${Math.floor(ms / 1000)}s`) timeToText: vi.fn((ms) => `${Math.floor(ms / 1000)}s`)
})); }));
vi.mock('../../../../service/database', () => ({ vi.mock('../../../../services/database', () => ({
database: { database: {
setWorldMemo: vi.fn(), setWorldMemo: vi.fn(),
deleteWorldMemo: vi.fn() deleteWorldMemo: vi.fn()
} }
})); }));
const { database } = await import('../../../../service/database'); const { database } = await import('../../../../services/database');
const { compareUnityVersion } = await import('../../../../shared/utils'); const { compareUnityVersion } = await import('../../../../shared/utils');
/** /**
@@ -5,7 +5,7 @@ import {
formatDateFilter, formatDateFilter,
timeToText timeToText
} from '../../../shared/utils'; } from '../../../shared/utils';
import { database } from '../../../service/database'; import { database } from '../../../services/database';
/** /**
* Composable for WorldDialogInfoTab computed properties and actions. * Composable for WorldDialogInfoTab computed properties and actions.
@@ -26,7 +26,7 @@ vi.mock('../../../views/Feed/Feed.vue', () => ({
default: { template: '<div />' } default: { template: '<div />' }
})); }));
vi.mock('../../../views/Feed/columns.jsx', () => ({ columns: [] })); vi.mock('../../../views/Feed/columns.jsx', () => ({ columns: [] }));
vi.mock('../../../plugin/router', () => ({ vi.mock('../../../plugins/router', () => ({
router: { router: {
beforeEach: vi.fn(), beforeEach: vi.fn(),
push: vi.fn(), push: vi.fn(),
@@ -47,8 +47,8 @@ vi.mock('vue-router', async (importOriginal) => {
})) }))
}; };
}); });
vi.mock('../../../plugin/interopApi', () => ({ initInteropApi: vi.fn() })); vi.mock('../../../plugins/interopApi', () => ({ initInteropApi: vi.fn() }));
vi.mock('../../../service/database', () => ({ vi.mock('../../../services/database', () => ({
database: new Proxy( database: new Proxy(
{}, {},
{ {
@@ -59,7 +59,7 @@ vi.mock('../../../service/database', () => ({
} }
) )
})); }));
vi.mock('../../../service/config', () => ({ vi.mock('../../../services/config', () => ({
default: { default: {
init: vi.fn(), init: vi.fn(),
getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'), getString: vi.fn().mockImplementation((_k, d) => d ?? '{}'),
@@ -77,8 +77,8 @@ vi.mock('../../../service/config', () => ({
remove: vi.fn() remove: vi.fn()
} }
})); }));
vi.mock('../../../service/jsonStorage', () => ({ default: vi.fn() })); vi.mock('../../../services/jsonStorage', () => ({ default: vi.fn() }));
vi.mock('../../../service/watchState', () => ({ vi.mock('../../../services/watchState', () => ({
watchState: { isLoggedIn: false } watchState: { isLoggedIn: false }
})); }));
+2 -2
View File
@@ -1,7 +1,7 @@
import { toast } from 'vue-sonner'; import { toast } from 'vue-sonner';
import { i18n } from '../plugin/i18n'; import { i18n } from '../plugins/i18n';
import { AppDebug } from '../service/appConfig'; import { AppDebug } from '../services/appConfig';
import { useAdvancedSettingsStore } from '../stores/settings/advanced'; import { useAdvancedSettingsStore } from '../stores/settings/advanced';
import { useAuthStore } from '../stores/auth'; import { useAuthStore } from '../stores/auth';
+5 -5
View File
@@ -1,8 +1,8 @@
import { i18n } from '../plugin/i18n'; import { i18n } from '../plugins/i18n';
import Noty from 'noty'; import Noty from 'noty';
import { closeWebSocket, initWebsocket } from '../service/websocket'; import { closeWebSocket, initWebsocket } from '../services/websocket';
import { escapeTag } from '../shared/utils'; import { escapeTag } from '../shared/utils';
import { queryClient } from '../queries'; import { queryClient } from '../queries';
import { useAuthStore } from '../stores/auth'; import { useAuthStore } from '../stores/auth';
@@ -10,10 +10,10 @@ import { useNotificationStore } from '../stores/notification';
import { useUpdateLoopStore } from '../stores/updateLoop'; import { useUpdateLoopStore } from '../stores/updateLoop';
import { useUserStore } from '../stores/user'; import { useUserStore } from '../stores/user';
import { applyCurrentUser } from './userCoordinator'; import { applyCurrentUser } from './userCoordinator';
import { watchState } from '../service/watchState'; import { watchState } from '../services/watchState';
import configRepository from '../service/config'; import configRepository from '../services/config';
import webApiService from '../service/webapi'; import webApiService from '../services/webapi';
/** /**
* Runs the shared logout side effects (including goodbye notification). * Runs the shared logout side effects (including goodbye notification).
+5 -5
View File
@@ -1,6 +1,6 @@
import { nextTick } from 'vue'; import { nextTick } from 'vue';
import { toast } from 'vue-sonner'; import { toast } from 'vue-sonner';
import { i18n } from '../plugin/i18n'; import { i18n } from '../plugins/i18n';
import { import {
createDefaultAvatarRef, createDefaultAvatarRef,
@@ -13,10 +13,10 @@ import {
storeAvatarImage storeAvatarImage
} from '../shared/utils'; } from '../shared/utils';
import { avatarRequest, miscRequest, queryRequest } from '../api'; import { avatarRequest, miscRequest, queryRequest } from '../api';
import { AppDebug } from '../service/appConfig'; import { AppDebug } from '../services/appConfig';
import { database } from '../service/database'; import { database } from '../services/database';
import { patchAvatarFromEvent } from '../queries'; import { patchAvatarFromEvent } from '../queries';
import { processBulk } from '../service/request'; import { processBulk } from '../services/request';
import { applyFavorite } from './favoriteCoordinator'; import { applyFavorite } from './favoriteCoordinator';
import { refreshUserDialogAvatars, showUserDialog } from './userCoordinator'; import { refreshUserDialogAvatars, showUserDialog } from './userCoordinator';
import { useAdvancedSettingsStore } from '../stores/settings/advanced'; import { useAdvancedSettingsStore } from '../stores/settings/advanced';
@@ -28,7 +28,7 @@ import { useUiStore } from '../stores/ui';
import { useUserStore } from '../stores/user'; import { useUserStore } from '../stores/user';
import { useVRCXUpdaterStore } from '../stores/vrcxUpdater'; import { useVRCXUpdaterStore } from '../stores/vrcxUpdater';
import webApiService from '../service/webapi'; import webApiService from '../services/webapi';
/** /**
* @param {object} json * @param {object} json
+4 -4
View File
@@ -10,10 +10,10 @@ import { useWorldStore } from '../stores/world';
import { applyWorld } from './worldCoordinator'; import { applyWorld } from './worldCoordinator';
import { runUpdateFriendFlow } from './friendPresenceCoordinator'; import { runUpdateFriendFlow } from './friendPresenceCoordinator';
import { avatarRequest, favoriteRequest, queryRequest } from '../api'; import { avatarRequest, favoriteRequest, queryRequest } from '../api';
import { database } from '../service/database'; import { database } from '../services/database';
import { i18n } from '../plugin/i18n'; import { i18n } from '../plugins/i18n';
import { processBulk } from '../service/request'; import { processBulk } from '../services/request';
import { watchState } from '../service/watchState'; import { watchState } from '../services/watchState';
import { import {
compareByName, compareByName,
createDefaultFavoriteCachedRef, createDefaultFavoriteCachedRef,
@@ -1,13 +1,13 @@
import { getGroupName, getWorldName, isRealInstance } from '../shared/utils'; import { getGroupName, getWorldName, isRealInstance } from '../shared/utils';
import { AppDebug } from '../service/appConfig'; import { AppDebug } from '../services/appConfig';
import { database } from '../service/database'; import { database } from '../services/database';
import { useFeedStore } from '../stores/feed'; import { useFeedStore } from '../stores/feed';
import { useFriendStore } from '../stores/friend'; import { useFriendStore } from '../stores/friend';
import { useNotificationStore } from '../stores/notification'; import { useNotificationStore } from '../stores/notification';
import { useSharedFeedStore } from '../stores/sharedFeed'; import { useSharedFeedStore } from '../stores/sharedFeed';
import { useUserStore } from '../stores/user'; import { useUserStore } from '../stores/user';
import { userRequest } from '../api'; import { userRequest } from '../api';
import { watchState } from '../service/watchState'; import { watchState } from '../services/watchState';
/** /**
* @param {object} ctx * @param {object} ctx
@@ -1,6 +1,6 @@
import { i18n } from '../plugin/i18n'; import { i18n } from '../plugins/i18n';
import { database } from '../service/database'; import { database } from '../services/database';
import { friendRequest, userRequest } from '../api'; import { friendRequest, userRequest } from '../api';
import { getNameColour } from '../shared/utils'; import { getNameColour } from '../shared/utils';
import { handleFavoriteDelete } from './favoriteCoordinator'; import { handleFavoriteDelete } from './favoriteCoordinator';
@@ -12,9 +12,9 @@ import { useNotificationStore } from '../stores/notification';
import { useSharedFeedStore } from '../stores/sharedFeed'; import { useSharedFeedStore } from '../stores/sharedFeed';
import { useUiStore } from '../stores/ui'; import { useUiStore } from '../stores/ui';
import { useUserStore } from '../stores/user'; import { useUserStore } from '../stores/user';
import { watchState } from '../service/watchState'; import { watchState } from '../services/watchState';
import configRepository from '../service/config'; import configRepository from '../services/config';
/** /**
* @param {object} args * @param {object} args
+4 -4
View File
@@ -1,16 +1,16 @@
import { toast } from 'vue-sonner'; import { toast } from 'vue-sonner';
import { AppDebug } from '../service/appConfig'; import { AppDebug } from '../services/appConfig';
import { migrateMemos } from '../shared/utils'; import { migrateMemos } from '../shared/utils';
import { reconnectWebSocket } from '../service/websocket'; import { reconnectWebSocket } from '../services/websocket';
import { useAuthStore } from '../stores/auth'; import { useAuthStore } from '../stores/auth';
import { useFriendStore } from '../stores/friend'; import { useFriendStore } from '../stores/friend';
import { useUpdateLoopStore } from '../stores/updateLoop'; import { useUpdateLoopStore } from '../stores/updateLoop';
import { useUserStore } from '../stores/user'; import { useUserStore } from '../stores/user';
import { getCurrentUser } from './userCoordinator'; import { getCurrentUser } from './userCoordinator';
import { watchState } from '../service/watchState'; import { watchState } from '../services/watchState';
import configRepository from '../service/config'; import configRepository from '../services/config';
/** /**
* Runs friend list refresh orchestration. * Runs friend list refresh orchestration.
+2 -2
View File
@@ -4,7 +4,7 @@ import {
deleteVRChatCache as _deleteVRChatCache, deleteVRChatCache as _deleteVRChatCache,
isRealInstance isRealInstance
} from '../shared/utils'; } from '../shared/utils';
import { database } from '../service/database'; import { database } from '../services/database';
import { useAdvancedSettingsStore } from '../stores/settings/advanced'; import { useAdvancedSettingsStore } from '../stores/settings/advanced';
import { useAvatarStore } from '../stores/avatar'; import { useAvatarStore } from '../stores/avatar';
import { addAvatarWearTime } from './avatarCoordinator'; import { addAvatarWearTime } from './avatarCoordinator';
@@ -21,7 +21,7 @@ import { useUserStore } from '../stores/user';
import { useVrStore } from '../stores/vr'; import { useVrStore } from '../stores/vr';
import { useWorldStore } from '../stores/world'; import { useWorldStore } from '../stores/world';
import configRepository from '../service/config'; import configRepository from '../services/config';
import * as workerTimers from 'worker-timers'; import * as workerTimers from 'worker-timers';
+6 -6
View File
@@ -11,13 +11,13 @@ import {
parsePrintFromUrl, parsePrintFromUrl,
replaceBioSymbols replaceBioSymbols
} from '../shared/utils'; } from '../shared/utils';
import { i18n } from '../plugin/i18n'; import { i18n } from '../plugins/i18n';
import { AppDebug } from '../service/appConfig'; import { AppDebug } from '../services/appConfig';
import { database } from '../service/database'; import { database } from '../services/database';
import { runLastLocationResetFlow, runUpdateCurrentUserLocationFlow } from './locationCoordinator'; import { runLastLocationResetFlow, runUpdateCurrentUserLocationFlow } from './locationCoordinator';
import { getGroupName } from '../shared/utils'; import { getGroupName } from '../shared/utils';
import { userRequest } from '../api'; import { userRequest } from '../api';
import { watchState } from '../service/watchState'; import { watchState } from '../services/watchState';
import { toast } from 'vue-sonner'; import { toast } from 'vue-sonner';
import { useAdvancedSettingsStore } from '../stores/settings/advanced'; import { useAdvancedSettingsStore } from '../stores/settings/advanced';
@@ -36,7 +36,7 @@ import { useUserStore } from '../stores/user';
import { useVrStore } from '../stores/vr'; import { useVrStore } from '../stores/vr';
import { useVrcxStore } from '../stores/vrcx'; import { useVrcxStore } from '../stores/vrcx';
import gameLogService from '../service/gameLog.js'; import gameLogService from '../services/gameLog.js';
import * as workerTimers from 'worker-timers'; import * as workerTimers from 'worker-timers';
@@ -579,4 +579,4 @@ export async function disableGameLogDialog() {
} }
} }
import configRepository from '../service/config'; import configRepository from '../services/config';
+4 -4
View File
@@ -1,6 +1,6 @@
import { nextTick } from 'vue'; import { nextTick } from 'vue';
import { toast } from 'vue-sonner'; import { toast } from 'vue-sonner';
import { i18n } from '../plugin/i18n'; import { i18n } from '../plugins/i18n';
import { import {
convertFileUrlToImageUrl, convertFileUrlToImageUrl,
@@ -9,7 +9,7 @@ import {
replaceBioSymbols replaceBioSymbols
} from '../shared/utils'; } from '../shared/utils';
import { groupRequest, instanceRequest, queryRequest } from '../api'; import { groupRequest, instanceRequest, queryRequest } from '../api';
import { database } from '../service/database'; import { database } from '../services/database';
import { groupDialogFilterOptions } from '../shared/constants/'; import { groupDialogFilterOptions } from '../shared/constants/';
import { patchGroupFromEvent } from '../queries'; import { patchGroupFromEvent } from '../queries';
import { useGameStore } from '../stores/game'; import { useGameStore } from '../stores/game';
@@ -19,9 +19,9 @@ import { useNotificationStore } from '../stores/notification';
import { useUiStore } from '../stores/ui'; import { useUiStore } from '../stores/ui';
import { useUserStore } from '../stores/user'; import { useUserStore } from '../stores/user';
import { useGroupStore } from '../stores/group'; import { useGroupStore } from '../stores/group';
import { watchState } from '../service/watchState'; import { watchState } from '../services/watchState';
import configRepository from '../service/config'; import configRepository from '../services/config';
import * as workerTimers from 'worker-timers'; import * as workerTimers from 'worker-timers';
+1 -1
View File
@@ -1,5 +1,5 @@
import { toast } from 'vue-sonner'; import { toast } from 'vue-sonner';
import { i18n } from '../plugin/i18n'; import { i18n } from '../plugins/i18n';
import { instanceRequest } from '../api'; import { instanceRequest } from '../api';
import { parseLocation } from '../shared/utils'; import { parseLocation } from '../shared/utils';
+1 -1
View File
@@ -4,7 +4,7 @@ import {
isRealInstance, isRealInstance,
parseLocation parseLocation
} from '../shared/utils'; } from '../shared/utils';
import { database } from '../service/database'; import { database } from '../services/database';
import { useAdvancedSettingsStore } from '../stores/settings/advanced'; import { useAdvancedSettingsStore } from '../stores/settings/advanced';
import { useGameLogStore } from '../stores/gameLog'; import { useGameLogStore } from '../stores/gameLog';
import { useGameStore } from '../stores/game'; import { useGameStore } from '../stores/game';
+5 -5
View File
@@ -1,6 +1,6 @@
import { reactive } from 'vue'; import { reactive } from 'vue';
import { toast } from 'vue-sonner'; import { toast } from 'vue-sonner';
import { i18n } from '../plugin/i18n'; import { i18n } from '../plugins/i18n';
import { import {
arraysMatch, arraysMatch,
@@ -22,11 +22,11 @@ import {
queryRequest, queryRequest,
userRequest userRequest
} from '../api'; } from '../api';
import { processBulk, request } from '../service/request'; import { processBulk, request } from '../services/request';
import { AppDebug } from '../service/appConfig'; import { AppDebug } from '../services/appConfig';
import { database } from '../service/database'; import { database } from '../services/database';
import { patchUserFromEvent } from '../queries'; import { patchUserFromEvent } from '../queries';
import { watchState } from '../service/watchState'; import { watchState } from '../services/watchState';
import { applyAvatar, showAvatarDialog } from './avatarCoordinator'; import { applyAvatar, showAvatarDialog } from './avatarCoordinator';
import { applyFavorite } from './favoriteCoordinator'; import { applyFavorite } from './favoriteCoordinator';
import { import {
+2 -2
View File
@@ -1,6 +1,6 @@
import { getGroupName, getWorldName, parseLocation } from '../shared/utils'; import { getGroupName, getWorldName, parseLocation } from '../shared/utils';
import { AppDebug } from '../service/appConfig'; import { AppDebug } from '../services/appConfig';
import { database } from '../service/database'; import { database } from '../services/database';
import { useAvatarStore } from '../stores/avatar'; import { useAvatarStore } from '../stores/avatar';
import { getAvatarName } from './avatarCoordinator'; import { getAvatarName } from './avatarCoordinator';
import { useFeedStore } from '../stores/feed'; import { useFeedStore } from '../stores/feed';
+1 -1
View File
@@ -7,7 +7,7 @@ import { useInstanceStore } from '../stores/instance';
import { useLocationStore } from '../stores/location'; import { useLocationStore } from '../stores/location';
import { useUserStore } from '../stores/user'; import { useUserStore } from '../stores/user';
import { useWorldStore } from '../stores/world'; import { useWorldStore } from '../stores/world';
import { failedGetRequests } from '../service/request'; import { failedGetRequests } from '../services/request';
/** /**
* Clears caches across multiple stores while preserving data that is * Clears caches across multiple stores while preserving data that is
+3 -3
View File
@@ -1,6 +1,6 @@
import { nextTick } from 'vue'; import { nextTick } from 'vue';
import { toast } from 'vue-sonner'; import { toast } from 'vue-sonner';
import { i18n } from '../plugin/i18n'; import { i18n } from '../plugins/i18n';
import { import {
checkVRChatCache, checkVRChatCache,
@@ -14,9 +14,9 @@ import {
sanitizeEntityJson sanitizeEntityJson
} from '../shared/utils'; } from '../shared/utils';
import { instanceRequest, queryRequest, worldRequest } from '../api'; import { instanceRequest, queryRequest, worldRequest } from '../api';
import { database } from '../service/database'; import { database } from '../services/database';
import { patchWorldFromEvent } from '../queries'; import { patchWorldFromEvent } from '../queries';
import { processBulk } from '../service/request'; import { processBulk } from '../services/request';
import { applyFavorite } from './favoriteCoordinator'; import { applyFavorite } from './favoriteCoordinator';
import { useFavoriteStore } from '../stores/favorite'; import { useFavoriteStore } from '../stores/favorite';
import { useInstanceStore } from '../stores/instance'; import { useInstanceStore } from '../stores/instance';
@@ -1,7 +1,7 @@
// @ts-nocheck // @ts-nocheck
import InteropApi from '../ipc-electron/interopApi.js'; import InteropApi from '../ipc-electron/interopApi.js';
import configRepository from '../service/config'; import configRepository from '../services/config.js';
import vrcxJsonStorage from '../service/jsonStorage'; import vrcxJsonStorage from '../services/jsonStorage.js';
export async function initInteropApi(isVrOverlay = false) { export async function initInteropApi(isVrOverlay = false) {
if (isVrOverlay) { if (isVrOverlay) {
@@ -1,6 +1,6 @@
import { createRouter, createWebHashHistory } from 'vue-router'; import { createRouter, createWebHashHistory } from 'vue-router';
import { watchState } from './../service/watchState'; import { watchState } from '../services/watchState';
import FavoritesAvatar from './../views/Favorites/FavoritesAvatar.vue'; import FavoritesAvatar from './../views/Favorites/FavoritesAvatar.vue';
import FavoritesFriend from './../views/Favorites/FavoritesFriend.vue'; import FavoritesFriend from './../views/Favorites/FavoritesFriend.vue';
@@ -1,7 +1,7 @@
import { router } from './router'; import { router } from './router';
import { startRendererMemoryThresholdReport } from './piniaActionTrail'; import { startRendererMemoryThresholdReport } from './piniaActionTrail';
import configRepository from '../service/config'; import configRepository from '../services/config';
export async function isSentryOptedIn() { export async function isSentryOptedIn() {
return NIGHTLY && configRepository.getBool('VRCX_SentryEnabled', false); return NIGHTLY && configRepository.getBool('VRCX_SentryEnabled', false);
+1 -1
View File
@@ -9,7 +9,7 @@ import {
} from '../shared/utils/base/ui'; } from '../shared/utils/base/ui';
import { i18n, loadLocalizedStrings } from './i18n'; import { i18n, loadLocalizedStrings } from './i18n';
import configRepository from '../service/config'; import configRepository from '../services/config';
export async function initUi() { export async function initUi() {
try { try {
@@ -1,5 +1,5 @@
// Mock router to avoid transitive i18n.global error from columns.jsx // Mock router to avoid transitive i18n.global error from columns.jsx
vi.mock('../../plugin/router.js', () => ({ vi.mock('../../plugins/router.js', () => ({
router: { beforeEach: vi.fn(), push: vi.fn() }, router: { beforeEach: vi.fn(), push: vi.fn() },
initRouter: vi.fn() initRouter: vi.fn()
})); }));
@@ -1,5 +1,5 @@
// Mock router to avoid transitive i18n.global error from columns.jsx // Mock router to avoid transitive i18n.global error from columns.jsx
vi.mock('../../plugin/router.js', () => ({ vi.mock('../../plugins/router.js', () => ({
router: { beforeEach: vi.fn(), push: vi.fn() }, router: { beforeEach: vi.fn(), push: vi.fn() },
initRouter: vi.fn() initRouter: vi.fn()
})); }));

Some files were not shown because too many files have changed in this diff Show More