mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-10-25 18:54:52 +00:00 
			
		
		
		
	🎨
This commit is contained in:
		
							parent
							
								
									ff85eff209
								
							
						
					
					
						commit
						388ef3de08
					
				
					 25 changed files with 923 additions and 1293 deletions
				
			
		|  | @ -1,296 +0,0 @@ | ||||||
| <!-- |  | ||||||
| SPDX-FileCopyrightText: syuilo and misskey-project |  | ||||||
| SPDX-License-Identifier: AGPL-3.0-only |  | ||||||
| --> |  | ||||||
| 
 |  | ||||||
| <template> |  | ||||||
| <div ref="el" class="fdidabkc" :style="{ background: bg }" @click="onClick"> |  | ||||||
| 	<template v-if="pageMetadata"> |  | ||||||
| 		<div class="titleContainer" @click="showTabsPopup"> |  | ||||||
| 			<i v-if="pageMetadata.icon" class="icon" :class="pageMetadata.icon"></i> |  | ||||||
| 
 |  | ||||||
| 			<div class="title"> |  | ||||||
| 				<div class="title">{{ pageMetadata.title }}</div> |  | ||||||
| 			</div> |  | ||||||
| 		</div> |  | ||||||
| 		<div class="tabs"> |  | ||||||
| 			<button v-for="tab in tabs" :ref="(el) => tabRefs[tab.key] = el" v-tooltip.noDelay="tab.title" class="tab _button" :class="{ active: tab.key != null && tab.key === props.tab }" @mousedown="(ev) => onTabMousedown(tab, ev)" @click="(ev) => onTabClick(tab, ev)"> |  | ||||||
| 				<i v-if="tab.icon" class="icon" :class="tab.icon"></i> |  | ||||||
| 				<span v-if="!tab.iconOnly" class="title">{{ tab.title }}</span> |  | ||||||
| 			</button> |  | ||||||
| 			<div ref="tabHighlightEl" class="highlight"></div> |  | ||||||
| 		</div> |  | ||||||
| 	</template> |  | ||||||
| 	<div class="buttons right"> |  | ||||||
| 		<template v-if="actions"> |  | ||||||
| 			<template v-for="action in actions"> |  | ||||||
| 				<MkButton v-if="action.asFullButton" class="fullButton" primary :disabled="action.disabled" @click.stop="action.handler"><i :class="action.icon" style="margin-right: 6px;"></i>{{ action.text }}</MkButton> |  | ||||||
| 				<button v-else v-tooltip.noDelay="action.text" class="_button button" :class="{ highlighted: action.highlighted }" :disabled="action.disabled" @click.stop="action.handler" @touchstart="preventDrag"><i :class="action.icon"></i></button> |  | ||||||
| 			</template> |  | ||||||
| 		</template> |  | ||||||
| 	</div> |  | ||||||
| </div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script lang="ts" setup> |  | ||||||
| import { computed, onMounted, onUnmounted, ref, useTemplateRef, watch, nextTick, inject } from 'vue'; |  | ||||||
| import tinycolor from 'tinycolor2'; |  | ||||||
| import { scrollToTop } from '@@/js/scroll.js'; |  | ||||||
| import { popupMenu } from '@/os.js'; |  | ||||||
| import MkButton from '@/components/MkButton.vue'; |  | ||||||
| import { globalEvents } from '@/events.js'; |  | ||||||
| import { DI } from '@/di.js'; |  | ||||||
| 
 |  | ||||||
| type Tab = { |  | ||||||
| 	key?: string | null; |  | ||||||
| 	title: string; |  | ||||||
| 	icon?: string; |  | ||||||
| 	iconOnly?: boolean; |  | ||||||
| 	onClick?: (ev: MouseEvent) => void; |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| const props = defineProps<{ |  | ||||||
| 	tabs?: Tab[]; |  | ||||||
| 	tab?: string; |  | ||||||
| 	actions?: { |  | ||||||
| 		text: string; |  | ||||||
| 		icon: string; |  | ||||||
| 		asFullButton?: boolean; |  | ||||||
| 		disabled?: boolean; |  | ||||||
| 		handler: (ev: MouseEvent) => void; |  | ||||||
| 	}[]; |  | ||||||
| 	thin?: boolean; |  | ||||||
| }>(); |  | ||||||
| 
 |  | ||||||
| const emit = defineEmits<{ |  | ||||||
| 	(ev: 'update:tab', key: string); |  | ||||||
| }>(); |  | ||||||
| 
 |  | ||||||
| const pageMetadata = inject(DI.pageMetadata, ref(null)); |  | ||||||
| 
 |  | ||||||
| const el = useTemplateRef('el'); |  | ||||||
| const tabHighlightEl = useTemplateRef('tabHighlightEl'); |  | ||||||
| const tabRefs = {}; |  | ||||||
| const bg = ref<string | null>(null); |  | ||||||
| const height = ref(0); |  | ||||||
| const hasTabs = computed(() => { |  | ||||||
| 	return props.tabs && props.tabs.length > 0; |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| const showTabsPopup = (ev: MouseEvent) => { |  | ||||||
| 	if (!hasTabs.value) return; |  | ||||||
| 	ev.preventDefault(); |  | ||||||
| 	ev.stopPropagation(); |  | ||||||
| 	const menu = props.tabs.map(tab => ({ |  | ||||||
| 		text: tab.title, |  | ||||||
| 		icon: tab.icon, |  | ||||||
| 		active: tab.key != null && tab.key === props.tab, |  | ||||||
| 		action: (ev) => { |  | ||||||
| 			onTabClick(tab, ev); |  | ||||||
| 		}, |  | ||||||
| 	})); |  | ||||||
| 	popupMenu(menu, ev.currentTarget ?? ev.target); |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| const preventDrag = (ev: TouchEvent) => { |  | ||||||
| 	ev.stopPropagation(); |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| const onClick = () => { |  | ||||||
| 	scrollToTop(el.value, { behavior: 'smooth' }); |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| function onTabMousedown(tab: Tab, ev: MouseEvent): void { |  | ||||||
| 	// ユーザビリティの観点からmousedown時にはonClickは呼ばない |  | ||||||
| 	if (tab.key) { |  | ||||||
| 		emit('update:tab', tab.key); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function onTabClick(tab: Tab, ev: MouseEvent): void { |  | ||||||
| 	if (tab.onClick) { |  | ||||||
| 		ev.preventDefault(); |  | ||||||
| 		ev.stopPropagation(); |  | ||||||
| 		tab.onClick(ev); |  | ||||||
| 	} |  | ||||||
| 	if (tab.key) { |  | ||||||
| 		emit('update:tab', tab.key); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const calcBg = () => { |  | ||||||
| 	const rawBg = pageMetadata.value.bg ?? 'var(--MI_THEME-bg)'; |  | ||||||
| 	const tinyBg = tinycolor(rawBg.startsWith('var(') ? getComputedStyle(window.document.documentElement).getPropertyValue(rawBg.slice(4, -1)) : rawBg); |  | ||||||
| 	tinyBg.setAlpha(0.85); |  | ||||||
| 	bg.value = tinyBg.toRgbString(); |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| onMounted(() => { |  | ||||||
| 	calcBg(); |  | ||||||
| 	globalEvents.on('themeChanging', calcBg); |  | ||||||
| 
 |  | ||||||
| 	watch(() => [props.tab, props.tabs], () => { |  | ||||||
| 		nextTick(() => { |  | ||||||
| 			const tabEl = tabRefs[props.tab]; |  | ||||||
| 			if (tabEl && tabHighlightEl.value) { |  | ||||||
| 				// offsetWidth や offsetLeft は少数を丸めてしまうため getBoundingClientRect を使う必要がある |  | ||||||
| 				// https://developer.mozilla.org/ja/docs/Web/API/HTMLElement/offsetWidth#%E5%80%A4 |  | ||||||
| 				const parentRect = tabEl.parentElement.getBoundingClientRect(); |  | ||||||
| 				const rect = tabEl.getBoundingClientRect(); |  | ||||||
| 				tabHighlightEl.value.style.width = rect.width + 'px'; |  | ||||||
| 				tabHighlightEl.value.style.left = (rect.left - parentRect.left) + 'px'; |  | ||||||
| 			} |  | ||||||
| 		}); |  | ||||||
| 	}, { |  | ||||||
| 		immediate: true, |  | ||||||
| 	}); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| onUnmounted(() => { |  | ||||||
| 	globalEvents.off('themeChanging', calcBg); |  | ||||||
| }); |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <style lang="scss" scoped> |  | ||||||
| .fdidabkc { |  | ||||||
| 	--height: 60px; |  | ||||||
| 	display: flex; |  | ||||||
| 	width: 100%; |  | ||||||
| 	-webkit-backdrop-filter: var(--MI-blur, blur(15px)); |  | ||||||
| 	backdrop-filter: var(--MI-blur, blur(15px)); |  | ||||||
| 
 |  | ||||||
| 	> .buttons { |  | ||||||
| 		--margin: 8px; |  | ||||||
| 		display: flex; |  | ||||||
|     align-items: center; |  | ||||||
| 		height: var(--height); |  | ||||||
| 		margin: 0 var(--margin); |  | ||||||
| 
 |  | ||||||
| 		&.right { |  | ||||||
| 			margin-left: auto; |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		&:empty { |  | ||||||
| 			width: var(--height); |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		> .button { |  | ||||||
| 			display: flex; |  | ||||||
| 			align-items: center; |  | ||||||
| 			justify-content: center; |  | ||||||
| 			height: calc(var(--height) - (var(--margin) * 2)); |  | ||||||
| 			width: calc(var(--height) - (var(--margin) * 2)); |  | ||||||
| 			box-sizing: border-box; |  | ||||||
| 			position: relative; |  | ||||||
| 			border-radius: 5px; |  | ||||||
| 
 |  | ||||||
| 			&:hover { |  | ||||||
| 				background: rgba(0, 0, 0, 0.05); |  | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 			&.highlighted { |  | ||||||
| 				color: var(--MI_THEME-accent); |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		> .fullButton { |  | ||||||
| 			& + .fullButton { |  | ||||||
| 				margin-left: 12px; |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	> .titleContainer { |  | ||||||
| 		display: flex; |  | ||||||
| 		align-items: center; |  | ||||||
| 		max-width: 400px; |  | ||||||
| 		overflow: auto; |  | ||||||
| 		white-space: nowrap; |  | ||||||
| 		text-align: left; |  | ||||||
| 		font-weight: bold; |  | ||||||
| 		flex-shrink: 0; |  | ||||||
| 		margin-left: 24px; |  | ||||||
| 
 |  | ||||||
| 		> .avatar { |  | ||||||
| 			$size: 32px; |  | ||||||
| 			display: inline-block; |  | ||||||
| 			width: $size; |  | ||||||
| 			height: $size; |  | ||||||
| 			vertical-align: bottom; |  | ||||||
| 			margin: 0 8px; |  | ||||||
| 			pointer-events: none; |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		> .icon { |  | ||||||
| 			margin-right: 8px; |  | ||||||
| 			width: 16px; |  | ||||||
| 			text-align: center; |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		> .title { |  | ||||||
| 			min-width: 0; |  | ||||||
| 			overflow: hidden; |  | ||||||
| 			text-overflow: ellipsis; |  | ||||||
| 			white-space: nowrap; |  | ||||||
| 			line-height: 1.1; |  | ||||||
| 
 |  | ||||||
| 			> .subtitle { |  | ||||||
| 				opacity: 0.6; |  | ||||||
| 				font-size: 0.8em; |  | ||||||
| 				font-weight: normal; |  | ||||||
| 				white-space: nowrap; |  | ||||||
| 				overflow: hidden; |  | ||||||
| 				text-overflow: ellipsis; |  | ||||||
| 
 |  | ||||||
| 				&.activeTab { |  | ||||||
| 					text-align: center; |  | ||||||
| 
 |  | ||||||
| 					> .chevron { |  | ||||||
| 						display: inline-block; |  | ||||||
| 						margin-left: 6px; |  | ||||||
| 					} |  | ||||||
| 				} |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	> .tabs { |  | ||||||
| 		position: relative; |  | ||||||
| 		margin-left: 16px; |  | ||||||
| 		font-size: 0.8em; |  | ||||||
| 		overflow: auto; |  | ||||||
| 		white-space: nowrap; |  | ||||||
| 
 |  | ||||||
| 		> .tab { |  | ||||||
| 			display: inline-block; |  | ||||||
| 			position: relative; |  | ||||||
| 			padding: 0 10px; |  | ||||||
| 			height: 100%; |  | ||||||
| 			font-weight: normal; |  | ||||||
| 			opacity: 0.7; |  | ||||||
| 
 |  | ||||||
| 			&:hover { |  | ||||||
| 				opacity: 1; |  | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 			&.active { |  | ||||||
| 				opacity: 1; |  | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 			> .icon + .title { |  | ||||||
| 				margin-left: 8px; |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		> .highlight { |  | ||||||
| 			position: absolute; |  | ||||||
| 			bottom: 0; |  | ||||||
| 			height: 3px; |  | ||||||
| 			background: var(--MI_THEME-accent); |  | ||||||
| 			border-radius: 999px; |  | ||||||
| 			transition: all 0.2s ease; |  | ||||||
| 			pointer-events: none; |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| </style> |  | ||||||
|  | @ -4,11 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <MkStickyContainer> | <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||||
| 	<template #header> |  | ||||||
| 		<XHeader :actions="headerActions" :tabs="headerTabs"/> |  | ||||||
| 	</template> |  | ||||||
| 
 |  | ||||||
| 	<MkSpacer :contentMax="900"> | 	<MkSpacer :contentMax="900"> | ||||||
| 		<div :class="$style.root" class="_gaps_m"> | 		<div :class="$style.root" class="_gaps_m"> | ||||||
| 			<div :class="$style.addButton"> | 			<div :class="$style.addButton"> | ||||||
|  | @ -41,14 +37,13 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</div> | 			</div> | ||||||
| 		</div> | 		</div> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| </MkStickyContainer> | </PageWithHeader> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup lang="ts"> | <script setup lang="ts"> | ||||||
| import { entities } from 'misskey-js'; | import { entities } from 'misskey-js'; | ||||||
| import { computed, defineAsyncComponent, onMounted, ref } from 'vue'; | import { computed, defineAsyncComponent, onMounted, ref } from 'vue'; | ||||||
| import XRecipient from './notification-recipient.item.vue'; | import XRecipient from './notification-recipient.item.vue'; | ||||||
| import XHeader from '@/pages/admin/_header_.vue'; |  | ||||||
| import { misskeyApi } from '@/utility/misskey-api.js'; | import { misskeyApi } from '@/utility/misskey-api.js'; | ||||||
| import MkInput from '@/components/MkInput.vue'; | import MkInput from '@/components/MkInput.vue'; | ||||||
| import MkSelect from '@/components/MkSelect.vue'; | import MkSelect from '@/components/MkSelect.vue'; | ||||||
|  |  | ||||||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <MkStickyContainer> | <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||||
| 	<template #header><XHeader :actions="headerActions" :tabs="headerTabs"/></template> |  | ||||||
| 	<MkSpacer :contentMax="900"> | 	<MkSpacer :contentMax="900"> | ||||||
| 		<div :class="$style.root" class="_gaps"> | 		<div :class="$style.root" class="_gaps"> | ||||||
| 			<div :class="$style.subMenus" class="_gaps"> | 			<div :class="$style.subMenus" class="_gaps"> | ||||||
|  | @ -55,12 +54,11 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</MkPagination> | 			</MkPagination> | ||||||
| 		</div> | 		</div> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| </MkStickyContainer> | </PageWithHeader> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { computed, useTemplateRef, ref } from 'vue'; | import { computed, useTemplateRef, ref } from 'vue'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import MkSelect from '@/components/MkSelect.vue'; | import MkSelect from '@/components/MkSelect.vue'; | ||||||
| import MkPagination from '@/components/MkPagination.vue'; | import MkPagination from '@/components/MkPagination.vue'; | ||||||
| import XAbuseReport from '@/components/MkAbuseReport.vue'; | import XAbuseReport from '@/components/MkAbuseReport.vue'; | ||||||
|  |  | ||||||
|  | @ -4,10 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <MkStickyContainer> | <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||||
| 	<template #header> |  | ||||||
| 		<XHeader :actions="headerActions" :tabs="headerTabs"/> |  | ||||||
| 	</template> |  | ||||||
| 	<MkSpacer :contentMax="900"> | 	<MkSpacer :contentMax="900"> | ||||||
| 		<MkSelect v-model="filterType" :class="$style.input" @update:modelValue="filterItems"> | 		<MkSelect v-model="filterType" :class="$style.input" @update:modelValue="filterItems"> | ||||||
| 			<template #label>{{ i18n.ts.state }}</template> | 			<template #label>{{ i18n.ts.state }}</template> | ||||||
|  | @ -81,13 +78,12 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</MkButton> | 			</MkButton> | ||||||
| 		</div> | 		</div> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| </MkStickyContainer> | </PageWithHeader> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { ref, computed } from 'vue'; | import { ref, computed } from 'vue'; | ||||||
| import * as Misskey from 'misskey-js'; | import * as Misskey from 'misskey-js'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import MkButton from '@/components/MkButton.vue'; | import MkButton from '@/components/MkButton.vue'; | ||||||
| import MkInput from '@/components/MkInput.vue'; | import MkInput from '@/components/MkInput.vue'; | ||||||
| import MkTextarea from '@/components/MkTextarea.vue'; | import MkTextarea from '@/components/MkTextarea.vue'; | ||||||
|  |  | ||||||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <MkStickyContainer> | <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||||
| 	<template #header><XHeader :actions="headerActions" :tabs="headerTabs"/></template> |  | ||||||
| 	<MkSpacer :contentMax="900"> | 	<MkSpacer :contentMax="900"> | ||||||
| 		<div class="_gaps"> | 		<div class="_gaps"> | ||||||
| 			<MkInfo>{{ i18n.ts._announcement.shouldNotBeUsedToPresentPermanentInfo }}</MkInfo> | 			<MkInfo>{{ i18n.ts._announcement.shouldNotBeUsedToPresentPermanentInfo }}</MkInfo> | ||||||
|  | @ -81,12 +80,11 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</template> | 			</template> | ||||||
| 		</div> | 		</div> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| </MkStickyContainer> | </PageWithHeader> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { ref, computed, watch } from 'vue'; | import { ref, computed, watch } from 'vue'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import MkButton from '@/components/MkButton.vue'; | import MkButton from '@/components/MkButton.vue'; | ||||||
| import MkInput from '@/components/MkInput.vue'; | import MkInput from '@/components/MkInput.vue'; | ||||||
| import MkSelect from '@/components/MkSelect.vue'; | import MkSelect from '@/components/MkSelect.vue'; | ||||||
|  |  | ||||||
|  | @ -4,9 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <div> | <PageWithHeader :tabs="headerTabs"> | ||||||
| 	<MkStickyContainer> |  | ||||||
| 		<template #header><XHeader :tabs="headerTabs"/></template> |  | ||||||
| 	<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32"> | 	<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32"> | ||||||
| 		<FormSuspense :p="init"> | 		<FormSuspense :p="init"> | ||||||
| 			<div class="_gaps_m"> | 			<div class="_gaps_m"> | ||||||
|  | @ -99,14 +97,13 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</MkSpacer> | 			</MkSpacer> | ||||||
| 		</div> | 		</div> | ||||||
| 	</template> | 	</template> | ||||||
| 	</MkStickyContainer> | </PageWithHeader> | ||||||
| </div> |  | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { ref, computed } from 'vue'; | import { ref, computed } from 'vue'; | ||||||
| import JSON5 from 'json5'; | import JSON5 from 'json5'; | ||||||
| import XHeader from './_header_.vue'; | import { host } from '@@/js/config.js'; | ||||||
| import MkInput from '@/components/MkInput.vue'; | import MkInput from '@/components/MkInput.vue'; | ||||||
| import MkTextarea from '@/components/MkTextarea.vue'; | import MkTextarea from '@/components/MkTextarea.vue'; | ||||||
| import FormSuspense from '@/components/form/suspense.vue'; | import FormSuspense from '@/components/form/suspense.vue'; | ||||||
|  | @ -117,7 +114,6 @@ import { i18n } from '@/i18n.js'; | ||||||
| import { definePage } from '@/page.js'; | import { definePage } from '@/page.js'; | ||||||
| import MkButton from '@/components/MkButton.vue'; | import MkButton from '@/components/MkButton.vue'; | ||||||
| import MkColorInput from '@/components/MkColorInput.vue'; | import MkColorInput from '@/components/MkColorInput.vue'; | ||||||
| import { host } from '@@/js/config.js'; |  | ||||||
| 
 | 
 | ||||||
| const iconUrl = ref<string | null>(null); | const iconUrl = ref<string | null>(null); | ||||||
| const app192IconUrl = ref<string | null>(null); | const app192IconUrl = ref<string | null>(null); | ||||||
|  |  | ||||||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <MkStickyContainer> | <PageWithHeader :tabs="headerTabs"> | ||||||
| 	<template #header><XHeader :tabs="headerTabs"/></template> |  | ||||||
| 	<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32"> | 	<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32"> | ||||||
| 		<FormSuspense :p="init"> | 		<FormSuspense :p="init"> | ||||||
| 			<div class="_gaps_m"> | 			<div class="_gaps_m"> | ||||||
|  | @ -60,12 +59,11 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</MkSpacer> | 			</MkSpacer> | ||||||
| 		</div> | 		</div> | ||||||
| 	</template> | 	</template> | ||||||
| </MkStickyContainer> | </PageWithHeader> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { ref, computed } from 'vue'; | import { ref, computed } from 'vue'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import MkSwitch from '@/components/MkSwitch.vue'; | import MkSwitch from '@/components/MkSwitch.vue'; | ||||||
| import MkInput from '@/components/MkInput.vue'; | import MkInput from '@/components/MkInput.vue'; | ||||||
| import FormInfo from '@/components/MkInfo.vue'; | import FormInfo from '@/components/MkInfo.vue'; | ||||||
|  |  | ||||||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <MkStickyContainer> | <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||||
| 	<template #header><XHeader :actions="headerActions" :tabs="headerTabs"/></template> |  | ||||||
| 	<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32"> | 	<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32"> | ||||||
| 		<FormSuspense :p="init"> | 		<FormSuspense :p="init"> | ||||||
| 			<div class="_gaps_m"> | 			<div class="_gaps_m"> | ||||||
|  | @ -38,12 +37,11 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</div> | 			</div> | ||||||
| 		</FormSuspense> | 		</FormSuspense> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| </MkStickyContainer> | </PageWithHeader> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { ref, computed } from 'vue'; | import { ref, computed } from 'vue'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import MkInput from '@/components/MkInput.vue'; | import MkInput from '@/components/MkInput.vue'; | ||||||
| import MkButton from '@/components/MkButton.vue'; | import MkButton from '@/components/MkButton.vue'; | ||||||
| import MkSwitch from '@/components/MkSwitch.vue'; | import MkSwitch from '@/components/MkSwitch.vue'; | ||||||
|  |  | ||||||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <MkStickyContainer> | <PageWithHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"> | ||||||
| 	<template #header><XHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs"/></template> |  | ||||||
| 	<MkSpacer :contentMax="800"> | 	<MkSpacer :contentMax="800"> | ||||||
| 		<XQueue v-if="tab === 'deliver'" domain="deliver"/> | 		<XQueue v-if="tab === 'deliver'" domain="deliver"/> | ||||||
| 		<XQueue v-else-if="tab === 'inbox'" domain="inbox"/> | 		<XQueue v-else-if="tab === 'inbox'" domain="inbox"/> | ||||||
|  | @ -15,13 +14,12 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			<MkButton danger @click="clear"><i class="ti ti-trash"></i> {{ i18n.ts.clearQueue }}</MkButton> | 			<MkButton danger @click="clear"><i class="ti ti-trash"></i> {{ i18n.ts.clearQueue }}</MkButton> | ||||||
| 		</div> | 		</div> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| </MkStickyContainer> | </PageWithHeader> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { ref, computed } from 'vue'; | import { ref, computed } from 'vue'; | ||||||
| import XQueue from './federation-job-queue.chart.vue'; | import XQueue from './federation-job-queue.chart.vue'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import type { Ref } from 'vue'; | import type { Ref } from 'vue'; | ||||||
| import * as os from '@/os.js'; | import * as os from '@/os.js'; | ||||||
| import { i18n } from '@/i18n.js'; | import { i18n } from '@/i18n.js'; | ||||||
|  |  | ||||||
|  | @ -4,9 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <div> | <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||||
| 	<MkStickyContainer> |  | ||||||
| 		<template #header><XHeader :actions="headerActions"/></template> |  | ||||||
| 	<MkSpacer :contentMax="900"> | 	<MkSpacer :contentMax="900"> | ||||||
| 		<div class="_gaps"> | 		<div class="_gaps"> | ||||||
| 			<div> | 			<div> | ||||||
|  | @ -53,14 +51,12 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</MkPagination> | 			</MkPagination> | ||||||
| 		</div> | 		</div> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| 	</MkStickyContainer> | </PageWithHeader> | ||||||
| </div> |  | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import * as Misskey from 'misskey-js'; | import * as Misskey from 'misskey-js'; | ||||||
| import { computed, ref } from 'vue'; | import { computed, ref } from 'vue'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import MkInput from '@/components/MkInput.vue'; | import MkInput from '@/components/MkInput.vue'; | ||||||
| import MkSelect from '@/components/MkSelect.vue'; | import MkSelect from '@/components/MkSelect.vue'; | ||||||
| import MkPagination from '@/components/MkPagination.vue'; | import MkPagination from '@/components/MkPagination.vue'; | ||||||
|  |  | ||||||
|  | @ -4,9 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <div> | <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||||
| 	<MkStickyContainer> |  | ||||||
| 		<template #header><XHeader :actions="headerActions"/></template> |  | ||||||
| 	<MkSpacer :contentMax="900"> | 	<MkSpacer :contentMax="900"> | ||||||
| 		<div class="_gaps"> | 		<div class="_gaps"> | ||||||
| 			<div class="inputs" style="display: flex; gap: var(--MI-margin); flex-wrap: wrap;"> | 			<div class="inputs" style="display: flex; gap: var(--MI-margin); flex-wrap: wrap;"> | ||||||
|  | @ -31,13 +29,11 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			<MkFileListForAdmin :pagination="pagination" :viewMode="viewMode"/> | 			<MkFileListForAdmin :pagination="pagination" :viewMode="viewMode"/> | ||||||
| 		</div> | 		</div> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| 	</MkStickyContainer> | </PageWithHeader> | ||||||
| </div> |  | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { computed, ref } from 'vue'; | import { computed, ref } from 'vue'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import MkInput from '@/components/MkInput.vue'; | import MkInput from '@/components/MkInput.vue'; | ||||||
| import MkSelect from '@/components/MkSelect.vue'; | import MkSelect from '@/components/MkSelect.vue'; | ||||||
| import MkFileListForAdmin from '@/components/MkFileListForAdmin.vue'; | import MkFileListForAdmin from '@/components/MkFileListForAdmin.vue'; | ||||||
|  |  | ||||||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <MkStickyContainer> | <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||||
| 	<template #header><XHeader :actions="headerActions" :tabs="headerTabs"/></template> |  | ||||||
| 	<MkSpacer :contentMax="800"> | 	<MkSpacer :contentMax="800"> | ||||||
| 		<div class="_gaps_m"> | 		<div class="_gaps_m"> | ||||||
| 			<MkFolder :expanded="false"> | 			<MkFolder :expanded="false"> | ||||||
|  | @ -51,12 +50,11 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</MkPagination> | 			</MkPagination> | ||||||
| 		</div> | 		</div> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| </MkStickyContainer> | </PageWithHeader> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { computed, ref, useTemplateRef } from 'vue'; | import { computed, ref, useTemplateRef } from 'vue'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import type { Paging } from '@/components/MkPagination.vue'; | import type { Paging } from '@/components/MkPagination.vue'; | ||||||
| import { i18n } from '@/i18n.js'; | import { i18n } from '@/i18n.js'; | ||||||
| import * as os from '@/os.js'; | import * as os from '@/os.js'; | ||||||
|  |  | ||||||
|  | @ -4,9 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <div> | <PageWithHeader :tabs="headerTabs"> | ||||||
| 	<MkStickyContainer> |  | ||||||
| 		<template #header><XHeader :tabs="headerTabs"/></template> |  | ||||||
| 	<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32"> | 	<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32"> | ||||||
| 		<FormSuspense :p="init"> | 		<FormSuspense :p="init"> | ||||||
| 			<div class="_gaps_m"> | 			<div class="_gaps_m"> | ||||||
|  | @ -122,13 +120,11 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</div> | 			</div> | ||||||
| 		</FormSuspense> | 		</FormSuspense> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| 	</MkStickyContainer> | </PageWithHeader> | ||||||
| </div> |  | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { ref, computed } from 'vue'; | import { ref, computed } from 'vue'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import MkSwitch from '@/components/MkSwitch.vue'; | import MkSwitch from '@/components/MkSwitch.vue'; | ||||||
| import MkInput from '@/components/MkInput.vue'; | import MkInput from '@/components/MkInput.vue'; | ||||||
| import MkTextarea from '@/components/MkTextarea.vue'; | import MkTextarea from '@/components/MkTextarea.vue'; | ||||||
|  |  | ||||||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <MkStickyContainer> | <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||||
| 	<template #header><XHeader :actions="headerActions" :tabs="headerTabs"/></template> |  | ||||||
| 	<MkSpacer :contentMax="900"> | 	<MkSpacer :contentMax="900"> | ||||||
| 		<div class="_gaps"> | 		<div class="_gaps"> | ||||||
| 			<div style="display: flex; gap: var(--MI-margin); flex-wrap: wrap;"> | 			<div style="display: flex; gap: var(--MI-margin); flex-wrap: wrap;"> | ||||||
|  | @ -35,13 +34,12 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			<MkButton primary rounded style="margin: 0 auto;" @click="fetchMore">{{ i18n.ts.loadMore }}</MkButton> | 			<MkButton primary rounded style="margin: 0 auto;" @click="fetchMore">{{ i18n.ts.loadMore }}</MkButton> | ||||||
| 		</div> | 		</div> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| </MkStickyContainer> | </PageWithHeader> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { computed, useTemplateRef, ref, watch } from 'vue'; | import { computed, useTemplateRef, ref, watch } from 'vue'; | ||||||
| import * as Misskey from 'misskey-js'; | import * as Misskey from 'misskey-js'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import XModLog from './modlog.ModLog.vue'; | import XModLog from './modlog.ModLog.vue'; | ||||||
| import MkSelect from '@/components/MkSelect.vue'; | import MkSelect from '@/components/MkSelect.vue'; | ||||||
| import MkInput from '@/components/MkInput.vue'; | import MkInput from '@/components/MkInput.vue'; | ||||||
|  |  | ||||||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <MkStickyContainer> | <PageWithHeader :tabs="headerTabs"> | ||||||
| 	<template #header><XHeader :tabs="headerTabs"/></template> |  | ||||||
| 	<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32"> | 	<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32"> | ||||||
| 		<FormSuspense :p="init"> | 		<FormSuspense :p="init"> | ||||||
| 			<div class="_gaps_m"> | 			<div class="_gaps_m"> | ||||||
|  | @ -79,12 +78,11 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</MkSpacer> | 			</MkSpacer> | ||||||
| 		</div> | 		</div> | ||||||
| 	</template> | 	</template> | ||||||
| </MkStickyContainer> | </PageWithHeader> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { ref, computed } from 'vue'; | import { ref, computed } from 'vue'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import MkSwitch from '@/components/MkSwitch.vue'; | import MkSwitch from '@/components/MkSwitch.vue'; | ||||||
| import MkInput from '@/components/MkInput.vue'; | import MkInput from '@/components/MkInput.vue'; | ||||||
| import FormSuspense from '@/components/form/suspense.vue'; | import FormSuspense from '@/components/form/suspense.vue'; | ||||||
|  |  | ||||||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <MkStickyContainer> | <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||||
| 	<template #header><XHeader :actions="headerActions" :tabs="headerTabs"/></template> |  | ||||||
| 	<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32"> | 	<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32"> | ||||||
| 		<div class="_gaps"> | 		<div class="_gaps"> | ||||||
| 			<div class="_panel" style="padding: 16px;"> | 			<div class="_panel" style="padding: 16px;"> | ||||||
|  | @ -104,12 +103,11 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</MkFolder> | 			</MkFolder> | ||||||
| 		</div> | 		</div> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| </MkStickyContainer> | </PageWithHeader> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { ref, computed } from 'vue'; | import { ref, computed } from 'vue'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import * as os from '@/os.js'; | import * as os from '@/os.js'; | ||||||
| import { misskeyApi } from '@/utility/misskey-api.js'; | import { misskeyApi } from '@/utility/misskey-api.js'; | ||||||
| import { fetchInstance } from '@/instance.js'; | import { fetchInstance } from '@/instance.js'; | ||||||
|  |  | ||||||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <MkStickyContainer> | <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||||
| 	<template #header><XHeader :actions="headerActions" :tabs="headerTabs"/></template> |  | ||||||
| 	<MkSpacer :contentMax="800"> | 	<MkSpacer :contentMax="800"> | ||||||
| 		<div class="_gaps"> | 		<div class="_gaps"> | ||||||
| 			<div v-for="relay in relays" :key="relay.inbox" class="relaycxt _panel" style="padding: 16px;"> | 			<div v-for="relay in relays" :key="relay.inbox" class="relaycxt _panel" style="padding: 16px;"> | ||||||
|  | @ -20,13 +19,12 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</div> | 			</div> | ||||||
| 		</div> | 		</div> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| </MkStickyContainer> | </PageWithHeader> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { ref, computed } from 'vue'; | import { ref, computed } from 'vue'; | ||||||
| import * as Misskey from 'misskey-js'; | import * as Misskey from 'misskey-js'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import MkButton from '@/components/MkButton.vue'; | import MkButton from '@/components/MkButton.vue'; | ||||||
| import * as os from '@/os.js'; | import * as os from '@/os.js'; | ||||||
| import { misskeyApi } from '@/utility/misskey-api.js'; | import { misskeyApi } from '@/utility/misskey-api.js'; | ||||||
|  |  | ||||||
|  | @ -4,9 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <div> | <PageWithHeader :tabs="headerTabs"> | ||||||
| 	<MkStickyContainer> |  | ||||||
| 		<template #header><XHeader :tabs="headerTabs"/></template> |  | ||||||
| 	<MkSpacer :contentMax="600" :marginMin="16" :marginMax="32"> | 	<MkSpacer :contentMax="600" :marginMin="16" :marginMax="32"> | ||||||
| 		<XEditor v-if="data" v-model="data"/> | 		<XEditor v-if="data" v-model="data"/> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
|  | @ -18,14 +16,13 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 		</div> | 		</div> | ||||||
| 	</template> | 	</template> | ||||||
| 	</MkStickyContainer> | 	</MkStickyContainer> | ||||||
| </div> | </PageWithHeader> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { computed, ref } from 'vue'; | import { computed, ref } from 'vue'; | ||||||
| import * as Misskey from 'misskey-js'; | import * as Misskey from 'misskey-js'; | ||||||
| import { v4 as uuid } from 'uuid'; | import { v4 as uuid } from 'uuid'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import XEditor from './roles.editor.vue'; | import XEditor from './roles.editor.vue'; | ||||||
| import * as os from '@/os.js'; | import * as os from '@/os.js'; | ||||||
| import { misskeyApi } from '@/utility/misskey-api.js'; | import { misskeyApi } from '@/utility/misskey-api.js'; | ||||||
|  |  | ||||||
|  | @ -4,9 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <div> | <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||||
| 	<MkStickyContainer> |  | ||||||
| 		<template #header><XHeader :actions="headerActions" :tabs="headerTabs"/></template> |  | ||||||
| 	<MkSpacer :contentMax="700"> | 	<MkSpacer :contentMax="700"> | ||||||
| 		<div class="_gaps"> | 		<div class="_gaps"> | ||||||
| 			<div class="_buttons"> | 			<div class="_buttons"> | ||||||
|  | @ -57,13 +55,11 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			<MkInfo v-else>{{ i18n.ts._role.isConditionalRole }}</MkInfo> | 			<MkInfo v-else>{{ i18n.ts._role.isConditionalRole }}</MkInfo> | ||||||
| 		</div> | 		</div> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| 	</MkStickyContainer> | </PageWithHeader> | ||||||
| </div> |  | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { computed, reactive, ref } from 'vue'; | import { computed, reactive, ref } from 'vue'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import XEditor from './roles.editor.vue'; | import XEditor from './roles.editor.vue'; | ||||||
| import MkFolder from '@/components/MkFolder.vue'; | import MkFolder from '@/components/MkFolder.vue'; | ||||||
| import * as os from '@/os.js'; | import * as os from '@/os.js'; | ||||||
|  |  | ||||||
|  | @ -4,9 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <div> | <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||||
| 	<MkStickyContainer> |  | ||||||
| 		<template #header><XHeader :actions="headerActions" :tabs="headerTabs"/></template> |  | ||||||
| 	<MkSpacer :contentMax="700"> | 	<MkSpacer :contentMax="700"> | ||||||
| 		<div class="_gaps"> | 		<div class="_gaps"> | ||||||
| 			<MkFolder> | 			<MkFolder> | ||||||
|  | @ -286,14 +284,12 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</div> | 			</div> | ||||||
| 		</div> | 		</div> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| 	</MkStickyContainer> | </PageWithHeader> | ||||||
| </div> |  | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { computed, reactive, ref } from 'vue'; | import { computed, reactive, ref } from 'vue'; | ||||||
| import { ROLE_POLICIES } from '@@/js/const.js'; | import { ROLE_POLICIES } from '@@/js/const.js'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import MkInput from '@/components/MkInput.vue'; | import MkInput from '@/components/MkInput.vue'; | ||||||
| import MkFolder from '@/components/MkFolder.vue'; | import MkFolder from '@/components/MkFolder.vue'; | ||||||
| import MkSwitch from '@/components/MkSwitch.vue'; | import MkSwitch from '@/components/MkSwitch.vue'; | ||||||
|  |  | ||||||
|  | @ -4,8 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <MkStickyContainer> | <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||||
| 	<template #header><XHeader :actions="headerActions" :tabs="headerTabs"/></template> |  | ||||||
| 	<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32"> | 	<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32"> | ||||||
| 		<div class="_gaps_m"> | 		<div class="_gaps_m"> | ||||||
| 			<XBotProtection/> | 			<XBotProtection/> | ||||||
|  | @ -117,13 +116,12 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</MkFolder> | 			</MkFolder> | ||||||
| 		</div> | 		</div> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| </MkStickyContainer> | </PageWithHeader> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { ref, computed } from 'vue'; | import { ref, computed } from 'vue'; | ||||||
| import XBotProtection from './bot-protection.vue'; | import XBotProtection from './bot-protection.vue'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import MkFolder from '@/components/MkFolder.vue'; | import MkFolder from '@/components/MkFolder.vue'; | ||||||
| import MkRadios from '@/components/MkRadios.vue'; | import MkRadios from '@/components/MkRadios.vue'; | ||||||
| import MkSwitch from '@/components/MkSwitch.vue'; | import MkSwitch from '@/components/MkSwitch.vue'; | ||||||
|  |  | ||||||
|  | @ -4,9 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <div> | <PageWithHeader :tabs="headerTabs"> | ||||||
| 	<MkStickyContainer> |  | ||||||
| 		<template #header><XHeader :tabs="headerTabs"/></template> |  | ||||||
| 	<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32"> | 	<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32"> | ||||||
| 		<div class="_gaps_m"> | 		<div class="_gaps_m"> | ||||||
| 			<div>{{ i18n.ts._serverRules.description }}</div> | 			<div>{{ i18n.ts._serverRules.description }}</div> | ||||||
|  | @ -37,12 +35,11 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 		</div> | 		</div> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| 	</MkStickyContainer> | 	</MkStickyContainer> | ||||||
| </div> | </PageWithHeader> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { defineAsyncComponent, ref, computed } from 'vue'; | import { defineAsyncComponent, ref, computed } from 'vue'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import * as os from '@/os.js'; | import * as os from '@/os.js'; | ||||||
| import { fetchInstance, instance } from '@/instance.js'; | import { fetchInstance, instance } from '@/instance.js'; | ||||||
| import { i18n } from '@/i18n.js'; | import { i18n } from '@/i18n.js'; | ||||||
|  |  | ||||||
|  | @ -4,9 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <div> | <PageWithHeader :tabs="headerTabs"> | ||||||
| 	<MkStickyContainer> |  | ||||||
| 		<template #header><XHeader :tabs="headerTabs"/></template> |  | ||||||
| 	<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32"> | 	<MkSpacer :contentMax="700" :marginMin="16" :marginMax="32"> | ||||||
| 		<div class="_gaps_m"> | 		<div class="_gaps_m"> | ||||||
| 			<MkFolder :defaultOpen="true"> | 			<MkFolder :defaultOpen="true"> | ||||||
|  | @ -253,13 +251,11 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</MkFolder> | 			</MkFolder> | ||||||
| 		</div> | 		</div> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| 	</MkStickyContainer> | </PageWithHeader> | ||||||
| </div> |  | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { ref, computed, reactive } from 'vue'; | import { ref, computed, reactive } from 'vue'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import MkSwitch from '@/components/MkSwitch.vue'; | import MkSwitch from '@/components/MkSwitch.vue'; | ||||||
| import MkInput from '@/components/MkInput.vue'; | import MkInput from '@/components/MkInput.vue'; | ||||||
| import MkTextarea from '@/components/MkTextarea.vue'; | import MkTextarea from '@/components/MkTextarea.vue'; | ||||||
|  |  | ||||||
|  | @ -4,11 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <MkStickyContainer> | <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||||
| 	<template #header> |  | ||||||
| 		<XHeader :actions="headerActions" :tabs="headerTabs"/> |  | ||||||
| 	</template> |  | ||||||
| 
 |  | ||||||
| 	<MkSpacer :contentMax="900"> | 	<MkSpacer :contentMax="900"> | ||||||
| 		<div class="_gaps_m"> | 		<div class="_gaps_m"> | ||||||
| 			<MkButton primary @click="onCreateWebhookClicked"> | 			<MkButton primary @click="onCreateWebhookClicked"> | ||||||
|  | @ -22,7 +18,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</FormSection> | 			</FormSection> | ||||||
| 		</div> | 		</div> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| </MkStickyContainer> | </PageWithHeader> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
|  | @ -32,7 +28,6 @@ import XItem from './system-webhook.item.vue'; | ||||||
| import FormSection from '@/components/form/section.vue'; | import FormSection from '@/components/form/section.vue'; | ||||||
| import { definePage } from '@/page.js'; | import { definePage } from '@/page.js'; | ||||||
| import { i18n } from '@/i18n.js'; | import { i18n } from '@/i18n.js'; | ||||||
| import XHeader from '@/pages/admin/_header_.vue'; |  | ||||||
| import MkButton from '@/components/MkButton.vue'; | import MkButton from '@/components/MkButton.vue'; | ||||||
| import { misskeyApi } from '@/utility/misskey-api.js'; | import { misskeyApi } from '@/utility/misskey-api.js'; | ||||||
| import { showSystemWebhookEditorDialog } from '@/components/MkSystemWebhookEditor.impl.js'; | import { showSystemWebhookEditorDialog } from '@/components/MkSystemWebhookEditor.impl.js'; | ||||||
|  |  | ||||||
|  | @ -4,9 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <div> | <PageWithHeader :actions="headerActions" :tabs="headerTabs"> | ||||||
| 	<MkStickyContainer> |  | ||||||
| 		<template #header><XHeader :actions="headerActions" :tabs="headerTabs"/></template> |  | ||||||
| 	<MkSpacer :contentMax="900"> | 	<MkSpacer :contentMax="900"> | ||||||
| 		<div class="_gaps"> | 		<div class="_gaps"> | ||||||
| 			<div :class="$style.inputs"> | 			<div :class="$style.inputs"> | ||||||
|  | @ -55,13 +53,11 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</MkPagination> | 			</MkPagination> | ||||||
| 		</div> | 		</div> | ||||||
| 	</MkSpacer> | 	</MkSpacer> | ||||||
| 	</MkStickyContainer> | </PageWithHeader> | ||||||
| </div> |  | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
| import { computed, useTemplateRef, ref, watchEffect } from 'vue'; | import { computed, useTemplateRef, ref, watchEffect } from 'vue'; | ||||||
| import XHeader from './_header_.vue'; |  | ||||||
| import { defaultMemoryStorage } from '@/memory-storage'; | import { defaultMemoryStorage } from '@/memory-storage'; | ||||||
| import MkButton from '@/components/MkButton.vue'; | import MkButton from '@/components/MkButton.vue'; | ||||||
| import MkInput from '@/components/MkInput.vue'; | import MkInput from '@/components/MkInput.vue'; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue