1
0
forked from mirror/misskey

Update boot.ts

This commit is contained in:
syuilo 2024-08-22 17:32:24 +09:00
parent 2398a8013d
commit c42d184208

View File

@ -8,37 +8,16 @@ import 'vite/modulepreload-polyfill';
import '@/style.scss'; import '@/style.scss';
import { createApp, defineAsyncComponent } from 'vue'; import { createApp, defineAsyncComponent } from 'vue';
import type { CommonBootOptions } from '@/boot/common.js';
import { common } from '@/boot/common.js';
import { setIframeId, postMessageToParentWindow } from '@/scripts/post-message.js'; import { setIframeId, postMessageToParentWindow } from '@/scripts/post-message.js';
import { parseEmbedParams } from '@/scripts/embed-page.js'; import { parseEmbedParams } from '@/scripts/embed-page.js';
import { defaultStore } from '@/store.js';
import { useRouter } from '@/router/supplier.js';
import { createEmbedRouter } from '@/router.js'; import { createEmbedRouter } from '@/router.js';
const bootOptions: Partial<CommonBootOptions> = {
routerFactory: createEmbedRouter,
};
const params = new URLSearchParams(location.search); const params = new URLSearchParams(location.search);
const embedParams = parseEmbedParams(params); const embedParams = parseEmbedParams(params);
// カラーモードのオーバーライド
if (embedParams.colorMode != null) {
bootOptions.forceColorMode = embedParams.colorMode;
}
// サイズの制限 // サイズの制限
document.documentElement.style.maxWidth = '500px'; document.documentElement.style.maxWidth = '500px';
// サーバー起動の場合はもとから付与されているけど一応
document.documentElement.classList.add('embed');
// 外部タブでのstoreの変更の影響を受けないように
defaultStore.setConfig({
disableMessageChannel: true,
});
// iframeIdの設定 // iframeIdの設定
function setIframeIdHandler(event: MessageEvent) { function setIframeIdHandler(event: MessageEvent) {
if (event.data?.type === 'misskey:embedParent:registerIframeId' && event.data.payload?.iframeId != null) { if (event.data?.type === 'misskey:embedParent:registerIframeId' && event.data.payload?.iframeId != null) {
@ -49,30 +28,11 @@ function setIframeIdHandler(event: MessageEvent) {
window.addEventListener('message', setIframeIdHandler); window.addEventListener('message', setIframeIdHandler);
// 起動 const app = createApp(
common(() => createApp(
defineAsyncComponent(() => import('@/ui.vue')), defineAsyncComponent(() => import('@/ui.vue')),
), bootOptions).then(async ({ app }) => { );
//#region Embed Provide
app.provide('EMBED_PAGE', true);
app.provide('embedParams', embedParams);
//#endregion
//#region defaultStoreを書き換え //#region Embed Provide
await defaultStore.ready; app.provide('embedParams', embedParams);
//#endregion
defaultStore.set('sound_notUseSound', true);
//#endregion
//#region Embed Link Behavior
//強制的に新しいタブで開く
const router = useRouter();
router.navHook = (path, flag): boolean => {
window.open(path, '_blank', 'noopener');
return true;
};
//#endregion
// 起動完了を通知(このあとクライアント側から misskey:embedParent:registerIframeId が送信される)
postMessageToParentWindow('misskey:embed:ready');
});