mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-10-25 02:34:51 +00:00 
			
		
		
		
	refactor(frontend): use PageWithHeader instead of MkStickyContainer+MkPageHeader combination
This commit is contained in:
		
							parent
							
								
									733a391d86
								
							
						
					
					
						commit
						ce858a676b
					
				
					 70 changed files with 199 additions and 237 deletions
				
			
		
							
								
								
									
										32
									
								
								packages/frontend/src/components/global/PageWithHeader.vue
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								packages/frontend/src/components/global/PageWithHeader.vue
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,32 @@ | |||
| <!-- | ||||
| SPDX-FileCopyrightText: syuilo and misskey-project | ||||
| SPDX-License-Identifier: AGPL-3.0-only | ||||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer class="_pageScrollable"> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :actions="actions" :tabs="tabs"/></template> | ||||
| 	<slot></slot> | ||||
| </MkStickyContainer> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
| import type { PageHeaderItem } from '@/types/page-header.js'; | ||||
| import type { Tab } from './MkPageHeader.tabs.vue'; | ||||
| 
 | ||||
| const props = withDefaults(defineProps<{ | ||||
| 	tabs?: Tab[]; | ||||
| 	actions?: PageHeaderItem[] | null; | ||||
| 	thin?: boolean; | ||||
| 	hideTitle?: boolean; | ||||
| 	displayMyAvatar?: boolean; | ||||
| }>(), { | ||||
| 	tabs: () => ([] as Tab[]), | ||||
| }); | ||||
| 
 | ||||
| const tab = defineModel<string>('tab'); | ||||
| </script> | ||||
| 
 | ||||
| <style lang="scss" module> | ||||
| 
 | ||||
| </style> | ||||
|  | @ -25,6 +25,8 @@ import MkPageHeader from './global/MkPageHeader.vue'; | |||
| import MkSpacer from './global/MkSpacer.vue'; | ||||
| import MkStickyContainer from './global/MkStickyContainer.vue'; | ||||
| import MkLazy from './global/MkLazy.vue'; | ||||
| import PageWithHeader from './global/PageWithHeader.vue'; | ||||
| import PageWithAnimBg from './global/PageWithAnimBg.vue'; | ||||
| import SearchMarker from './global/SearchMarker.vue'; | ||||
| import SearchLabel from './global/SearchLabel.vue'; | ||||
| import SearchKeyword from './global/SearchKeyword.vue'; | ||||
|  | @ -60,6 +62,8 @@ export const components = { | |||
| 	MkSpacer: MkSpacer, | ||||
| 	MkStickyContainer: MkStickyContainer, | ||||
| 	MkLazy: MkLazy, | ||||
| 	PageWithHeader: PageWithHeader, | ||||
| 	PageWithAnimBg: PageWithAnimBg, | ||||
| 	SearchMarker: SearchMarker, | ||||
| 	SearchLabel: SearchLabel, | ||||
| 	SearchKeyword: SearchKeyword, | ||||
|  | @ -89,6 +93,8 @@ declare module '@vue/runtime-core' { | |||
| 		MkSpacer: typeof MkSpacer; | ||||
| 		MkStickyContainer: typeof MkStickyContainer; | ||||
| 		MkLazy: typeof MkLazy; | ||||
| 		PageWithHeader: typeof PageWithHeader; | ||||
| 		PageWithAnimBg: typeof PageWithAnimBg; | ||||
| 		SearchMarker: typeof SearchMarker; | ||||
| 		SearchLabel: typeof SearchLabel; | ||||
| 		SearchKeyword: typeof SearchKeyword; | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<div style="overflow: clip;"> | ||||
| 		<MkSpacer :contentMax="600" :marginMin="20"> | ||||
| 			<div class="_gaps_m znqjceqz"> | ||||
|  | @ -130,7 +129,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</MkSpacer> | ||||
| 	</div> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkHorizontalSwipe v-model:tab="tab" :tabs="headerTabs"> | ||||
| 		<MkSpacer v-if="tab === 'overview'" :contentMax="600" :marginMin="20"> | ||||
| 			<XOverview/> | ||||
|  | @ -20,7 +19,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			<MkInstanceStats/> | ||||
| 		</MkSpacer> | ||||
| 	</MkHorizontalSwipe> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,12 +4,11 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader/></template> | ||||
| <PageWithHeader> | ||||
| 	<MkSpacer :contentMax="1200"> | ||||
| 		<MkAchievements :user="$i"/> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer v-if="file" :contentMax="600" :marginMin="16" :marginMax="32"> | ||||
| 		<div v-if="tab === 'overview'" class="cxqhhsmd _gaps_m"> | ||||
| 			<a class="thumbnail" :href="file.url" target="_blank"> | ||||
|  | @ -67,7 +66,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</MkObjectView> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="600" :marginMin="16" :marginMax="32"> | ||||
| 		<FormSuspense :p="init"> | ||||
| 			<div v-if="tab === 'overview'" class="_gaps_m"> | ||||
|  | @ -208,7 +207,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</FormSuspense> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="800" :marginMin="16" :marginMax="32"> | ||||
| 		<FormSuspense v-slot="{ result: database }" :p="databasePromiseFactory"> | ||||
| 			<MkKeyValue v-for="table in database" :key="table[0]" oneline style="margin: 1em 0;"> | ||||
|  | @ -14,7 +13,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</MkKeyValue> | ||||
| 		</FormSuspense> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,15 +4,13 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader/></template> | ||||
| 
 | ||||
| <PageWithHeader> | ||||
| 	<MkSpacer :contentMax="500"> | ||||
| 		<div class="_gaps"> | ||||
| 			<MkAd v-for="ad in instance.ads" :key="ad.id" :specify="ad"/> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="800"> | ||||
| 		<Transition | ||||
| 			:enterActiveClass="prefer.s.animation ? $style.fadeEnterActive : ''" | ||||
|  | @ -44,7 +43,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			<MkLoading v-else/> | ||||
| 		</Transition> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="800"> | ||||
| 		<MkHorizontalSwipe v-model:tab="tab" :tabs="headerTabs"> | ||||
| 			<div class="_gaps"> | ||||
|  | @ -43,7 +42,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</MkHorizontalSwipe> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="800"> | ||||
| 		<div ref="rootEl"> | ||||
| 			<div v-if="queue > 0" :class="$style.new"><button class="_buttonPrimary" :class="$style.newButton" @click="top()">{{ i18n.ts.newNoteRecived }}</button></div> | ||||
|  | @ -20,7 +19,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="700"> | ||||
| 		<div class="_gaps_m"> | ||||
| 			<div class="_gaps_m"> | ||||
|  | @ -30,7 +29,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="500"> | ||||
| 		<div v-if="state == 'fetch-session-error'"> | ||||
| 			<p>{{ i18n.ts.somethingHappened }}</p> | ||||
|  | @ -38,7 +37,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			<MkSignin @login="onLogin"/> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="900"> | ||||
| 		<div class="_gaps"> | ||||
| 			<div :class="$style.decorations"> | ||||
|  | @ -22,7 +21,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="700"> | ||||
| 		<div v-if="channelId == null || channel != null" class="_gaps_m"> | ||||
| 			<MkInput v-model="name"> | ||||
|  | @ -65,7 +64,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="700" :class="$style.main"> | ||||
| 		<MkHorizontalSwipe v-model:tab="tab" :tabs="headerTabs"> | ||||
| 			<div v-if="channel && tab === 'overview'" class="_gaps"> | ||||
|  | @ -69,7 +68,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</MkSpacer> | ||||
| 		</div> | ||||
| 	</template> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="1200"> | ||||
| 		<MkHorizontalSwipe v-model:tab="tab" :tabs="headerTabs"> | ||||
| 			<div v-if="tab === 'search'" :class="$style.searchRoot"> | ||||
|  | @ -56,7 +55,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</MkHorizontalSwipe> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,12 +4,11 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader/></template> | ||||
| <PageWithHeader> | ||||
| 	<MkSpacer :contentMax="800"> | ||||
| 		<MkClickerGame/> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions"/></template> | ||||
| <PageWithHeader :actions="headerActions"> | ||||
| 	<MkSpacer :contentMax="800"> | ||||
| 		<div v-if="clip" class="_gaps"> | ||||
| 			<div class="_panel"> | ||||
|  | @ -27,7 +26,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			<MkNotes :pagination="pagination" :detail="true"/> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader/></template> | ||||
| <PageWithHeader> | ||||
| 	<MkSpacer :contentMax="600" :marginMin="20"> | ||||
| 		<div class="_gaps_m"> | ||||
| 			<MkKeyValue :copy="instance.maintainerName"> | ||||
|  | @ -31,7 +30,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</MkKeyValue> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="900"> | ||||
| 		<div class="ogwlenmc"> | ||||
| 			<div v-if="tab === 'local'" class="local"> | ||||
|  | @ -68,7 +67,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkHorizontalSwipe v-model:tab="tab" :tabs="headerTabs"> | ||||
| 		<div v-if="tab === 'featured'"> | ||||
| 			<XFeatured/> | ||||
|  | @ -17,7 +16,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			<XRoles/> | ||||
| 		</div> | ||||
| 	</MkHorizontalSwipe> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader/></template> | ||||
| <PageWithHeader> | ||||
| 	<MkSpacer :contentMax="800"> | ||||
| 		<MkPagination :pagination="pagination"> | ||||
| 			<template #empty> | ||||
|  | @ -22,7 +21,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</template> | ||||
| 		</MkPagination> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="700"> | ||||
| 		<div class="_gaps"> | ||||
| 			<MkInput v-model="title"> | ||||
|  | @ -37,7 +36,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</MkSpacer> | ||||
| 		</div> | ||||
| 	</template> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="700"> | ||||
| 		<MkHorizontalSwipe v-model:tab="tab" :tabs="headerTabs"> | ||||
| 			<div v-if="tab === 'featured'"> | ||||
|  | @ -36,7 +35,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</MkHorizontalSwipe> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="700"> | ||||
| 		<Transition :name="prefer.s.animation ? 'fade' : ''" mode="out-in"> | ||||
| 			<div v-if="flash" :key="flash.id"> | ||||
|  | @ -58,7 +57,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			<MkLoading v-else/> | ||||
| 		</Transition> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="800"> | ||||
| 		<MkHorizontalSwipe v-model:tab="tab" :tabs="headerTabs"> | ||||
| 			<MkPagination ref="paginationComponent" :pagination="pagination"> | ||||
|  | @ -38,7 +37,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</MkPagination> | ||||
| 		</MkHorizontalSwipe> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="800" :marginMin="16" :marginMax="32"> | ||||
| 		<FormSuspense :p="init" class="_gaps"> | ||||
| 			<MkInput v-model="title"> | ||||
|  | @ -34,7 +33,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</FormSuspense> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="1400"> | ||||
| 		<MkHorizontalSwipe v-model:tab="tab" :tabs="headerTabs"> | ||||
| 			<div v-if="tab === 'explore'"> | ||||
|  | @ -43,7 +42,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</MkHorizontalSwipe> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="1000" :marginMin="16" :marginMax="32"> | ||||
| 		<div class="_root"> | ||||
| 			<Transition :name="prefer.s.animation ? 'fade' : ''" mode="out-in"> | ||||
|  | @ -59,7 +58,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</Transition> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader/></template> | ||||
| <PageWithHeader> | ||||
| 	<MkSpacer :contentMax="800"> | ||||
| 		<div class="_gaps"> | ||||
| 			<div class="_panel" :class="$style.link"> | ||||
|  | @ -20,7 +19,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,7 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkPageWithAnimBg> | ||||
| <PageWithAnimBg> | ||||
| 	<MkSpacer :contentMax="550" :marginMax="50"> | ||||
| 		<MkLoading v-if="uiPhase === 'fetching'"/> | ||||
| 		<MkExtensionInstaller v-else-if="uiPhase === 'confirm' && data" :extension="data" @confirm="install()" @cancel="close_()"> | ||||
|  | @ -37,7 +37,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkPageWithAnimBg> | ||||
| </PageWithAnimBg> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  | @ -57,7 +57,6 @@ import { parseThemeCode, installTheme } from '@/theme.js'; | |||
| import { unisonReload } from '@/utility/unison-reload.js'; | ||||
| import { i18n } from '@/i18n.js'; | ||||
| import { definePage } from '@/page.js'; | ||||
| import MkPageWithAnimBg from '@/components/MkPageWithAnimBg.vue'; | ||||
| 
 | ||||
| const uiPhase = ref<'fetching' | 'confirm' | 'error'>('fetching'); | ||||
| const errorKV = ref<{ | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer v-if="instance" :contentMax="600" :marginMin="16" :marginMax="32"> | ||||
| 		<MkHorizontalSwipe v-model:tab="tab" :tabs="headerTabs"> | ||||
| 			<div v-if="tab === 'overview'" class="_gaps_m"> | ||||
|  | @ -129,7 +128,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</MkHorizontalSwipe> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader/></template> | ||||
| <PageWithHeader> | ||||
| 	<MkSpacer v-if="!instance.disableRegistration || !($i && ($i.isAdmin || $i.policies.canInvite))" :contentMax="1200"> | ||||
| 		<div :class="$style.root"> | ||||
| 			<img :class="$style.img" :src="serverErrorImageUrl" draggable="false"/> | ||||
|  | @ -30,7 +29,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</MkPagination> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer v-if="error != null" :contentMax="1200"> | ||||
| 		<div :class="$style.root"> | ||||
| 			<img :class="$style.img" :src="serverErrorImageUrl" draggable="false"/> | ||||
|  | @ -30,7 +29,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 		<MkButton v-if="!list.isLiked" v-tooltip="i18n.ts.like" inline :class="$style.button" asLike @click="like()"><i class="ti ti-heart"></i><span v-if="1 > 0" class="count">{{ list.likedCount }}</span></MkButton> | ||||
| 		<MkButton inline @click="create()"><i class="ti ti-download" :class="$style.import"></i>{{ i18n.ts.import }}</MkButton> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="800"> | ||||
| 		<div v-if="state === 'done'" class="_buttonsCenter"> | ||||
| 			<MkButton @click="close">{{ i18n.ts.close }}</MkButton> | ||||
|  | @ -15,7 +14,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			<MkLoading/> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,7 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkPageWithAnimBg> | ||||
| <PageWithAnimBg> | ||||
| 	<div :class="$style.formContainer"> | ||||
| 		<div :class="$style.form"> | ||||
| 			<MkAuthConfirm | ||||
|  | @ -24,13 +24,12 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</MkAuthConfirm> | ||||
| 		</div> | ||||
| 	</div> | ||||
| </MkPageWithAnimBg> | ||||
| </PageWithAnimBg> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
| import { computed, useTemplateRef } from 'vue'; | ||||
| import * as Misskey from 'misskey-js'; | ||||
| import MkPageWithAnimBg from '@/components/MkPageWithAnimBg.vue'; | ||||
| import MkAuthConfirm from '@/components/MkAuthConfirm.vue'; | ||||
| import { i18n } from '@/i18n.js'; | ||||
| import { misskeyApi } from '@/utility/misskey-api.js'; | ||||
|  |  | |||
|  | @ -4,11 +4,9 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| 
 | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkAntennaEditor @created="onAntennaCreated"/> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,11 +4,9 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| 
 | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkAntennaEditor v-if="antenna" :antenna="antenna" @updated="onAntennaUpdated"/> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="700"> | ||||
| 		<div> | ||||
| 			<div v-if="antennas.length === 0" class="empty"> | ||||
|  | @ -24,7 +23,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="700"> | ||||
| 		<MkHorizontalSwipe v-model:tab="tab" :tabs="headerTabs"> | ||||
| 			<div v-if="tab === 'my'" class="_gaps"> | ||||
|  | @ -20,7 +19,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</MkHorizontalSwipe> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="700"> | ||||
| 		<div class="_gaps"> | ||||
| 			<div v-if="items.length === 0" class="empty"> | ||||
|  | @ -25,7 +24,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="700" :class="$style.main"> | ||||
| 		<div v-if="list" class="_gaps"> | ||||
| 			<MkFolder> | ||||
|  | @ -49,7 +48,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</MkFolder> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="800"> | ||||
| 		<div> | ||||
| 			<Transition :name="prefer.s.animation ? 'fade' : ''" mode="out-in"> | ||||
|  | @ -44,7 +43,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</Transition> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="800"> | ||||
| 		<MkHorizontalSwipe v-model:tab="tab" :tabs="headerTabs"> | ||||
| 			<div v-if="tab === 'all'"> | ||||
|  | @ -19,7 +18,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</MkHorizontalSwipe> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,7 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkPageWithAnimBg> | ||||
| <PageWithAnimBg> | ||||
| 	<div :class="$style.formContainer"> | ||||
| 		<div :class="$style.form"> | ||||
| 			<MkAuthConfirm | ||||
|  | @ -18,12 +18,11 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			/> | ||||
| 		</div> | ||||
| 	</div> | ||||
| </MkPageWithAnimBg> | ||||
| </PageWithAnimBg> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
| import * as Misskey from 'misskey-js'; | ||||
| import MkPageWithAnimBg from '@/components/MkPageWithAnimBg.vue'; | ||||
| import { definePage } from '@/page.js'; | ||||
| import MkAuthConfirm from '@/components/MkAuthConfirm.vue'; | ||||
| 
 | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="700"> | ||||
| 		<div class="jqqmcavi"> | ||||
| 			<MkButton v-if="pageId" class="button" inline link :to="`/@${ author.username }/pages/${ currentName }`"><i class="ti ti-external-link"></i> {{ i18n.ts._pages.viewPage }}</MkButton> | ||||
|  | @ -57,19 +56,19 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
| import { computed, provide, watch, ref } from 'vue'; | ||||
| import * as Misskey from 'misskey-js'; | ||||
| import { v4 as uuid } from 'uuid'; | ||||
| import { url } from '@@/js/config.js'; | ||||
| import XBlocks from './page-editor.blocks.vue'; | ||||
| import MkButton from '@/components/MkButton.vue'; | ||||
| import MkSelect from '@/components/MkSelect.vue'; | ||||
| import MkSwitch from '@/components/MkSwitch.vue'; | ||||
| import MkInput from '@/components/MkInput.vue'; | ||||
| import { url } from '@@/js/config.js'; | ||||
| import * as os from '@/os.js'; | ||||
| import { misskeyApi } from '@/utility/misskey-api.js'; | ||||
| import { selectFile } from '@/utility/select-file.js'; | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="800"> | ||||
| 		<Transition | ||||
| 			:enterActiveClass="prefer.s.animation ? $style.fadeEnterActive : ''" | ||||
|  | @ -94,7 +93,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			<MkLoading v-else/> | ||||
| 		</Transition> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="700"> | ||||
| 		<MkHorizontalSwipe v-model:tab="tab" :tabs="headerTabs"> | ||||
| 			<div v-if="tab === 'featured'"> | ||||
|  | @ -34,7 +33,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</MkHorizontalSwipe> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="600" :marginMin="16"> | ||||
| 		<div class="_gaps_m"> | ||||
| 			<FormSplit> | ||||
|  | @ -29,7 +28,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</FormSection> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="600" :marginMin="16"> | ||||
| 		<div class="_gaps_m"> | ||||
| 			<FormInfo warn>{{ i18n.ts.editTheseSettingsMayBreakAccount }}</FormInfo> | ||||
|  | @ -41,7 +40,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</template> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="600" :marginMin="16"> | ||||
| 		<MkButton primary @click="createKey">{{ i18n.ts._registry.createKey }}</MkButton> | ||||
| 
 | ||||
|  | @ -18,7 +17,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</FormSection> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer v-if="token" :contentMax="700" :marginMin="16" :marginMax="32"> | ||||
| 		<div class="_gaps_m"> | ||||
| 			<MkInput v-model="password" type="password"> | ||||
|  | @ -16,7 +15,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			<MkButton primary @click="save">{{ i18n.ts.save }}</MkButton> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader v-model:tab="tab" :tabs="headerTabs"> | ||||
| 	<MkSpacer v-if="error != null" :contentMax="1200"> | ||||
| 		<div :class="$style.root"> | ||||
| 			<img :class="$style.img" :src="serverErrorImageUrl" draggable="false"/> | ||||
|  | @ -32,7 +31,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			<div>{{ i18n.ts.nothing }}</div> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,9 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader/></template> | ||||
| 
 | ||||
| <PageWithHeader> | ||||
| 	<MkSpacer :contentMax="800"> | ||||
| 		<div :class="$style.root"> | ||||
| 			<div class="_gaps_s"> | ||||
|  | @ -53,13 +51,15 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
| import { onDeactivated, onUnmounted, ref, watch, computed } from 'vue'; | ||||
| import type { Ref } from 'vue'; | ||||
| import { Interpreter, Parser, utils } from '@syuilo/aiscript'; | ||||
| import type { Ref } from 'vue'; | ||||
| import type { AsUiComponent } from '@/aiscript/ui.js'; | ||||
| import type { AsUiRoot } from '@/aiscript/ui.js'; | ||||
| import MkContainer from '@/components/MkContainer.vue'; | ||||
| import MkButton from '@/components/MkButton.vue'; | ||||
| import MkTextarea from '@/components/MkTextarea.vue'; | ||||
|  | @ -70,13 +70,10 @@ import { $i } from '@/i.js'; | |||
| import { i18n } from '@/i18n.js'; | ||||
| import { definePage } from '@/page.js'; | ||||
| import { registerAsUiLib } from '@/aiscript/ui.js'; | ||||
| import type { AsUiComponent } from '@/aiscript/ui.js'; | ||||
| import MkAsUi from '@/components/MkAsUi.vue'; | ||||
| import { miLocalStorage } from '@/local-storage.js'; | ||||
| import { claimAchievement } from '@/utility/achievements.js'; | ||||
| 
 | ||||
| import type { AsUiRoot } from '@/aiscript/ui.js'; | ||||
| 
 | ||||
| const parser = new Parser(); | ||||
| let aiscript: Interpreter; | ||||
| const code = ref(''); | ||||
|  | @ -103,7 +100,7 @@ function stringifyUiProps(uiProps) { | |||
| 	return JSON.stringify( | ||||
| 		{ ...uiProps, type: undefined, id: undefined }, | ||||
| 		(k, v) => typeof v === 'function' ? '<function>' : v, | ||||
| 		2 | ||||
| 		2, | ||||
| 	); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -4,9 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| 
 | ||||
| <PageWithHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkHorizontalSwipe v-model:tab="tab" :tabs="headerTabs"> | ||||
| 		<MkSpacer v-if="tab === 'note'" :contentMax="800"> | ||||
| 			<div v-if="notesSearchAvailable || ignoreNotesSearchAvailable"> | ||||
|  | @ -21,7 +19,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			<XUser v-bind="props"/> | ||||
| 		</MkSpacer> | ||||
| 	</MkHorizontalSwipe> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer class="_pageScrollable"> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :tabs="headerTabs" :actions="headerActions"> | ||||
| 	<MkSpacer :contentMax="900" :marginMin="20" :marginMax="32"> | ||||
| 		<div ref="el" class="vvcocwet" :class="{ wide: !narrow }"> | ||||
| 			<div class="body"> | ||||
|  | @ -27,7 +26,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </mkstickycontainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script setup lang="ts"> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="800"> | ||||
| 		<MkPostForm | ||||
| 			v-if="state === 'writing'" | ||||
|  | @ -26,7 +25,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			<MkButton @click="goToMisskey">{{ i18n.ts.goToMisskey }}</MkButton> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,7 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkPageWithAnimBg> | ||||
| <PageWithAnimBg> | ||||
| 	<div :class="$style.formContainer"> | ||||
| 		<form :class="$style.form" class="_panel" @submit.prevent="submit()"> | ||||
| 			<div :class="$style.banner"> | ||||
|  | @ -20,13 +20,12 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</form> | ||||
| 	</div> | ||||
| </MkPageWithAnimBg> | ||||
| </PageWithAnimBg> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
| import { ref } from 'vue'; | ||||
| import MkButton from '@/components/MkButton.vue'; | ||||
| import MkPageWithAnimBg from '@/components/MkPageWithAnimBg.vue'; | ||||
| import { i18n } from '@/i18n.js'; | ||||
| import * as os from '@/os.js'; | ||||
| import { misskeyApi } from '@/utility/misskey-api.js'; | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="800"> | ||||
| 		<MkNotes ref="notes" class="" :pagination="pagination"/> | ||||
| 	</MkSpacer> | ||||
|  | @ -16,7 +15,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</MkSpacer> | ||||
| 		</div> | ||||
| 	</template> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  | @ -63,7 +62,7 @@ const headerActions = computed(() => [{ | |||
| 				genEmbedCode('tags', props.tag); | ||||
| 			}, | ||||
| 		}], ev.currentTarget ?? ev.target); | ||||
| 	} | ||||
| 	}, | ||||
| }]); | ||||
| 
 | ||||
| const headerTabs = computed(() => []); | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="800" :marginMin="16" :marginMax="32"> | ||||
| 		<div class="cwepdizn _gaps_m"> | ||||
| 			<MkFolder :defaultOpen="true"> | ||||
|  | @ -69,7 +68,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</MkFolder> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer class="_pageScrollable"> | ||||
| 	<template #header><MkPageHeader v-model:tab="src" :actions="headerActions" :tabs="$i ? headerTabs : headerTabsWhenNotLogin" :displayMyAvatar="true"/></template> | ||||
| <PageWithHeader v-model:tab="src" :actions="headerActions" :tabs="$i ? headerTabs : headerTabsWhenNotLogin" :displayMyAvatar="true"> | ||||
| 	<MkSpacer :contentMax="800"> | ||||
| 		<MkHorizontalSwipe v-model:tab="src" :tabs="$i ? headerTabs : headerTabsWhenNotLogin"> | ||||
| 			<div ref="rootEl"> | ||||
|  | @ -31,7 +30,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</MkHorizontalSwipe> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="800"> | ||||
| 		<div ref="rootEl"> | ||||
| 			<div v-if="queue > 0" :class="$style.new"><button class="_buttonPrimary" :class="$style.newButton" @click="top()">{{ i18n.ts.newNoteRecived }}</button></div> | ||||
|  | @ -20,7 +19,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,15 +4,13 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader/></template> | ||||
| 
 | ||||
| <PageWithHeader> | ||||
| 	<MkSpacer :contentMax="1200"> | ||||
| 		<div class="_gaps_s"> | ||||
| 			<MkUserList :pagination="tagUsers"/> | ||||
| 		</div> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="1000"> | ||||
| 		<Transition name="fade" mode="out-in"> | ||||
| 			<div v-if="user"> | ||||
|  | @ -15,7 +14,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			<MkLoading v-else/> | ||||
| 		</Transition> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer> | ||||
| 	<template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||
| 	<MkSpacer :contentMax="1000"> | ||||
| 		<Transition name="fade" mode="out-in"> | ||||
| 			<div v-if="user"> | ||||
|  | @ -15,7 +14,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			<MkLoading v-else/> | ||||
| 		</Transition> | ||||
| 	</MkSpacer> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,9 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkStickyContainer class="_pageScrollable"> | ||||
| 	<template #header><MkPageHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template> | ||||
| 	<div> | ||||
| <PageWithHeader v-model:tab="tab" :tabs="headerTabs" :actions="headerActions"> | ||||
| 	<div v-if="user"> | ||||
| 		<MkHorizontalSwipe v-model:tab="tab" :tabs="headerTabs"> | ||||
| 			<XHome v-if="tab === 'home'" :user="user" @unfoldFiles="() => { tab = 'files'; }"/> | ||||
|  | @ -27,8 +25,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 	</div> | ||||
| 	<MkError v-else-if="error" @retry="fetchUser()"/> | ||||
| 	<MkLoading v-else/> | ||||
| 	</div> | ||||
| </MkStickyContainer> | ||||
| </PageWithHeader> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  |  | |||
|  | @ -4,7 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| --> | ||||
| 
 | ||||
| <template> | ||||
| <MkPageWithAnimBg> | ||||
| <PageWithAnimBg> | ||||
| 	<div :class="$style.formContainer"> | ||||
| 		<form :class="$style.form" class="_panel" @submit.prevent="submit()"> | ||||
| 			<div :class="$style.title"> | ||||
|  | @ -34,7 +34,7 @@ SPDX-License-Identifier: AGPL-3.0-only | |||
| 			</div> | ||||
| 		</form> | ||||
| 	</div> | ||||
| </MkPageWithAnimBg> | ||||
| </PageWithAnimBg> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts" setup> | ||||
|  | @ -45,7 +45,6 @@ import MkInput from '@/components/MkInput.vue'; | |||
| import * as os from '@/os.js'; | ||||
| import { misskeyApi } from '@/utility/misskey-api.js'; | ||||
| import { i18n } from '@/i18n.js'; | ||||
| import MkPageWithAnimBg from '@/components/MkPageWithAnimBg.vue'; | ||||
| import { login } from '@/accounts.js'; | ||||
| 
 | ||||
| const username = ref(''); | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue