summaryrefslogtreecommitdiff
path: root/packages/frontend/src/instance.ts
diff options
context:
space:
mode:
authorHazelnoot <acomputerdog@gmail.com>2025-05-30 12:35:26 -0400
committerHazelnoot <acomputerdog@gmail.com>2025-05-30 13:04:38 -0400
commit5818a89ba035339360dedb4698d7bc3313ade5c4 (patch)
tree03a897cc49b177f4d4781ffe2722e1576fb2493e /packages/frontend/src/instance.ts
parentchange default value of canUseTranslator to false (diff)
downloadsharkey-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.ts8
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());