refactor(frontend): boot分割したり副作用減らしたりとか

#10838
This commit is contained in:
syuilo
2023-05-15 19:08:46 +09:00
parent a7ee4aabcb
commit 23f106a0c1
26 changed files with 628 additions and 573 deletions

View File

@@ -40,7 +40,7 @@ import { popups, pendingApiRequestsCount } from '@/os';
import { uploads } from '@/scripts/upload';
import * as sound from '@/scripts/sound';
import { $i } from '@/account';
import { stream } from '@/stream';
import { useStream } from '@/stream';
import { i18n } from '@/i18n';
import { defaultStore } from '@/store';
@@ -55,7 +55,7 @@ function onNotification(notification) {
if ($i.mutingNotificationTypes.includes(notification.type)) return;
if (document.visibilityState === 'visible') {
stream.send('readNotification');
useStream().send('readNotification');
notifications.unshift(notification);
window.setTimeout(() => {
@@ -71,7 +71,7 @@ function onNotification(notification) {
}
if ($i) {
const connection = stream.useChannel('main', null, 'UI');
const connection = useStream().useChannel('main', null, 'UI');
connection.on('notification', onNotification);
//#region Listen message from SW

View File

@@ -10,7 +10,7 @@
<script lang="ts" setup>
import { onUnmounted } from 'vue';
import { stream } from '@/stream';
import { useStream } from '@/stream';
import { i18n } from '@/i18n';
import MkButton from '@/components/MkButton.vue';
import * as os from '@/os';
@@ -32,10 +32,10 @@ function reload() {
location.reload();
}
stream.on('_disconnected_', onDisconnected);
useStream().on('_disconnected_', onDisconnected);
onUnmounted(() => {
stream.off('_disconnected_', onDisconnected);
useStream().off('_disconnected_', onDisconnected);
});
</script>

View File

@@ -0,0 +1,34 @@
<template>
<div class="mk-app" style="container-type: inline-size;">
<RouterView/>
<XCommon/>
</div>
</template>
<script lang="ts" setup>
import { provide, ComputedRef } from 'vue';
import XCommon from './_common_/common.vue';
import { mainRouter } from '@/router';
import { PageMetadata, provideMetadataReceiver } from '@/scripts/page-metadata';
import { instanceName } from '@/config';
let pageMetadata = $ref<null | ComputedRef<PageMetadata>>();
provide('router', mainRouter);
provideMetadataReceiver((info) => {
pageMetadata = info;
if (pageMetadata.value) {
document.title = `${pageMetadata.value.title} | ${instanceName}`;
}
});
document.documentElement.style.overflowY = 'scroll';
</script>
<style lang="scss" scoped>
.mk-app {
min-height: 100dvh;
box-sizing: border-box;
}
</style>