mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-10-25 02:34:51 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			66 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <!--
 | |
| SPDX-FileCopyrightText: syuilo and misskey-project
 | |
| SPDX-License-Identifier: AGPL-3.0-only
 | |
| -->
 | |
| 
 | |
| <template>
 | |
| <PageWithHeader v-model:tab="tab" :actions="headerActions" :tabs="headerTabs">
 | |
| 	<MkHorizontalSwipe v-model:tab="tab" :tabs="headerTabs">
 | |
| 		<div v-if="tab === 'featured'">
 | |
| 			<XFeatured/>
 | |
| 		</div>
 | |
| 		<div v-else-if="tab === 'users'">
 | |
| 			<XUsers/>
 | |
| 		</div>
 | |
| 		<div v-else-if="tab === 'roles'">
 | |
| 			<XRoles/>
 | |
| 		</div>
 | |
| 	</MkHorizontalSwipe>
 | |
| </PageWithHeader>
 | |
| </template>
 | |
| 
 | |
| <script lang="ts" setup>
 | |
| import { computed, watch, ref, useTemplateRef } from 'vue';
 | |
| import XFeatured from './explore.featured.vue';
 | |
| import XUsers from './explore.users.vue';
 | |
| import XRoles from './explore.roles.vue';
 | |
| import MkFoldableSection from '@/components/MkFoldableSection.vue';
 | |
| import MkHorizontalSwipe from '@/components/MkHorizontalSwipe.vue';
 | |
| import { definePage } from '@/page.js';
 | |
| import { i18n } from '@/i18n.js';
 | |
| 
 | |
| const props = withDefaults(defineProps<{
 | |
| 	tag?: string;
 | |
| 	initialTab?: string;
 | |
| }>(), {
 | |
| 	initialTab: 'featured',
 | |
| });
 | |
| 
 | |
| const tab = ref(props.initialTab);
 | |
| const tagsEl = useTemplateRef('tagsEl');
 | |
| 
 | |
| watch(() => props.tag, () => {
 | |
| 	if (tagsEl.value) tagsEl.value.toggleContent(props.tag == null);
 | |
| });
 | |
| 
 | |
| const headerActions = computed(() => []);
 | |
| 
 | |
| const headerTabs = computed(() => [{
 | |
| 	key: 'featured',
 | |
| 	icon: 'ti ti-bolt',
 | |
| 	title: i18n.ts.featured,
 | |
| }, {
 | |
| 	key: 'users',
 | |
| 	icon: 'ti ti-users',
 | |
| 	title: i18n.ts.users,
 | |
| }, {
 | |
| 	key: 'roles',
 | |
| 	icon: 'ti ti-badges',
 | |
| 	title: i18n.ts.roles,
 | |
| }]);
 | |
| 
 | |
| definePage(() => ({
 | |
| 	title: i18n.ts.explore,
 | |
| 	icon: 'ti ti-hash',
 | |
| }));
 | |
| </script>
 |