diff options
| author | Hazelnoot <acomputerdog@gmail.com> | 2025-05-30 12:35:26 -0400 |
|---|---|---|
| committer | Hazelnoot <acomputerdog@gmail.com> | 2025-05-30 13:04:38 -0400 |
| commit | 5818a89ba035339360dedb4698d7bc3313ade5c4 (patch) | |
| tree | 03a897cc49b177f4d4781ffe2722e1576fb2493e /packages/frontend/src/instance.ts | |
| parent | change default value of canUseTranslator to false (diff) | |
| download | sharkey-5818a89ba035339360dedb4698d7bc3313ade5c4.tar.gz sharkey-5818a89ba035339360dedb4698d7bc3313ade5c4.tar.bz2 sharkey-5818a89ba035339360dedb4698d7bc3313ade5c4.zip | |
fix circular reference between i.ts, instance.ts, and misskeyApi.ts
Diffstat (limited to 'packages/frontend/src/instance.ts')
| -rw-r--r-- | packages/frontend/src/instance.ts | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/packages/frontend/src/instance.ts b/packages/frontend/src/instance.ts index e75e3dfd34..956fc9e120 100644 --- a/packages/frontend/src/instance.ts +++ b/packages/frontend/src/instance.ts @@ -3,11 +3,12 @@ * SPDX-License-Identifier: AGPL-3.0-only */ -import { computed, reactive } from 'vue'; +import { computed, nextTick, reactive } from 'vue'; import * as Misskey from 'misskey-js'; import { misskeyApi } from '@/utility/misskey-api.js'; import { miLocalStorage } from '@/local-storage.js'; import { DEFAULT_INFO_IMAGE_URL, DEFAULT_NOT_FOUND_IMAGE_URL, DEFAULT_SERVER_ERROR_IMAGE_URL } from '@@/js/const.js'; +import { $i } from '@/i'; // TODO: 他のタブと永続化されたstateを同期 @@ -38,6 +39,8 @@ export const notFoundImageUrl = computed(() => instance.notFoundImageUrl ?? DEFA export const isEnabledUrlPreview = computed(() => instance.enableUrlPreview ?? true); +export const policies = computed<Misskey.entities.RolePolicies>(() => $i?.policies ?? instance.policies); + export async function fetchInstance(force = false): Promise<Misskey.entities.MetaDetailed> { if (!force) { const cachedAt = miLocalStorage.getItem('instanceCachedAt') ? parseInt(miLocalStorage.getItem('instanceCachedAt')!) : 0; @@ -60,3 +63,6 @@ export async function fetchInstance(force = false): Promise<Misskey.entities.Met return instance; } + +// instance export can be empty sometimes, which causes problems. +nextTick(() => fetchInstance()); |