2023-07-27 08:31:52 +03:00
|
|
|
<!--
|
|
|
|
SPDX-FileCopyrightText: syuilo and other misskey contributors
|
|
|
|
SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
-->
|
|
|
|
|
2020-11-17 15:52:07 +02:00
|
|
|
<template>
|
2024-01-30 12:53:53 +02:00
|
|
|
<MkModal ref="modal" v-slot="{ type, maxHeight }" :preferType="preferedModalType" :anchor="anchor" :transparentBg="true" :src="src" @click="modal?.close()" @closed="emit('closed')">
|
2022-02-23 16:40:31 +02:00
|
|
|
<div class="szkkfdyq _popup _shadow" :class="{ asDrawer: type === 'drawer' }" :style="{ maxHeight: maxHeight ? maxHeight + 'px' : '' }">
|
2020-11-17 15:52:07 +02:00
|
|
|
<div class="main">
|
2023-11-01 06:34:05 +02:00
|
|
|
<template v-for="item in items" :key="item.text">
|
2023-01-14 13:31:48 +02:00
|
|
|
<button v-if="item.action" v-click-anime class="_button item" @click="$event => { item.action($event); close(); }">
|
2021-04-20 17:22:59 +03:00
|
|
|
<i class="icon" :class="item.icon"></i>
|
2020-11-17 15:52:07 +02:00
|
|
|
<div class="text">{{ item.text }}</div>
|
2023-11-01 06:34:05 +02:00
|
|
|
<span v-if="item.indicate && item.indicateValue" class="_indicateCounter indicatorWithValue">{{ item.indicateValue }}</span>
|
|
|
|
<span v-else-if="item.indicate" class="indicator"><i class="_indicatorCircle"></i></span>
|
2020-11-17 15:52:07 +02:00
|
|
|
</button>
|
2023-01-14 13:31:48 +02:00
|
|
|
<MkA v-else v-click-anime :to="item.to" class="item" @click.passive="close()">
|
2021-04-20 17:22:59 +03:00
|
|
|
<i class="icon" :class="item.icon"></i>
|
2020-11-17 15:52:07 +02:00
|
|
|
<div class="text">{{ item.text }}</div>
|
2023-11-01 06:34:05 +02:00
|
|
|
<span v-if="item.indicate && item.indicateValue" class="_indicateCounter indicatorWithValue">{{ item.indicateValue }}</span>
|
|
|
|
<span v-else-if="item.indicate" class="indicator"><i class="_indicatorCircle"></i></span>
|
2020-11-17 15:52:07 +02:00
|
|
|
</MkA>
|
|
|
|
</template>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</MkModal>
|
|
|
|
</template>
|
|
|
|
|
2022-02-23 16:40:31 +02:00
|
|
|
<script lang="ts" setup>
|
2023-12-07 07:42:09 +02:00
|
|
|
import { shallowRef } from 'vue';
|
2022-09-06 12:21:49 +03:00
|
|
|
import MkModal from '@/components/MkModal.vue';
|
2023-11-01 06:34:05 +02:00
|
|
|
import { navbarItemDef } from '@/navbar.js';
|
2023-09-19 10:37:43 +03:00
|
|
|
import { defaultStore } from '@/store.js';
|
|
|
|
import { deviceKind } from '@/scripts/device-kind.js';
|
2020-11-17 15:52:07 +02:00
|
|
|
|
2022-02-23 16:40:31 +02:00
|
|
|
const props = withDefaults(defineProps<{
|
|
|
|
src?: HTMLElement;
|
2022-03-27 10:28:25 +03:00
|
|
|
anchor?: { x: string; y: string; };
|
2022-02-23 16:40:31 +02:00
|
|
|
}>(), {
|
2022-03-27 10:28:25 +03:00
|
|
|
anchor: () => ({ x: 'right', y: 'center' }),
|
2020-11-17 15:52:07 +02:00
|
|
|
});
|
2022-02-23 16:40:31 +02:00
|
|
|
|
|
|
|
const emit = defineEmits<{
|
|
|
|
(ev: 'closed'): void;
|
|
|
|
}>();
|
|
|
|
|
|
|
|
const preferedModalType = (deviceKind === 'desktop' && props.src != null) ? 'popup' :
|
|
|
|
deviceKind === 'smartphone' ? 'drawer' :
|
|
|
|
'dialog';
|
|
|
|
|
2023-12-07 07:42:09 +02:00
|
|
|
const modal = shallowRef<InstanceType<typeof MkModal>>();
|
2022-02-23 16:40:31 +02:00
|
|
|
|
|
|
|
const menu = defaultStore.state.menu;
|
|
|
|
|
2022-07-14 11:42:12 +03:00
|
|
|
const items = Object.keys(navbarItemDef).filter(k => !menu.includes(k)).map(k => navbarItemDef[k]).filter(def => def.show == null ? true : def.show).map(def => ({
|
2022-02-23 16:40:31 +02:00
|
|
|
type: def.to ? 'link' : 'button',
|
2023-01-05 06:59:48 +02:00
|
|
|
text: def.title,
|
2022-02-23 16:40:31 +02:00
|
|
|
icon: def.icon,
|
|
|
|
to: def.to,
|
|
|
|
action: def.action,
|
|
|
|
indicate: def.indicated,
|
2023-11-01 06:34:05 +02:00
|
|
|
indicateValue: def.indicateValue,
|
2022-02-23 16:40:31 +02:00
|
|
|
}));
|
|
|
|
|
|
|
|
function close() {
|
2024-01-30 12:53:53 +02:00
|
|
|
modal.value?.close();
|
2022-02-23 16:40:31 +02:00
|
|
|
}
|
2020-11-17 15:52:07 +02:00
|
|
|
</script>
|
|
|
|
|
2022-12-27 11:29:39 +02:00
|
|
|
<style lang="scss" scoped>
|
2020-11-17 15:52:07 +02:00
|
|
|
.szkkfdyq {
|
|
|
|
max-height: 100%;
|
2022-02-23 16:40:31 +02:00
|
|
|
width: min(460px, 100vw);
|
2023-01-14 14:04:30 +02:00
|
|
|
margin: auto;
|
2022-02-23 16:40:31 +02:00
|
|
|
padding: 24px;
|
2020-11-17 15:52:07 +02:00
|
|
|
box-sizing: border-box;
|
|
|
|
overflow: auto;
|
2022-02-23 16:40:31 +02:00
|
|
|
overscroll-behavior: contain;
|
|
|
|
text-align: left;
|
2020-11-17 15:52:07 +02:00
|
|
|
border-radius: 16px;
|
|
|
|
|
2022-02-23 16:40:31 +02:00
|
|
|
&.asDrawer {
|
|
|
|
width: 100%;
|
2023-01-10 06:50:34 +02:00
|
|
|
padding: 16px 16px max(env(safe-area-inset-bottom, 0px), 16px) 16px;
|
2022-02-23 16:40:31 +02:00
|
|
|
border-radius: 24px;
|
|
|
|
border-bottom-right-radius: 0;
|
|
|
|
border-bottom-left-radius: 0;
|
|
|
|
text-align: center;
|
2020-11-17 15:52:07 +02:00
|
|
|
}
|
2022-02-23 16:40:31 +02:00
|
|
|
|
2023-01-14 13:31:48 +02:00
|
|
|
> .main {
|
2022-02-23 16:40:31 +02:00
|
|
|
display: grid;
|
|
|
|
grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
|
|
|
|
|
2023-01-14 13:31:48 +02:00
|
|
|
> .item {
|
2020-11-17 15:52:07 +02:00
|
|
|
position: relative;
|
2022-02-23 16:40:31 +02:00
|
|
|
display: flex;
|
2020-11-17 15:52:07 +02:00
|
|
|
flex-direction: column;
|
|
|
|
align-items: center;
|
|
|
|
justify-content: center;
|
2021-04-25 06:31:11 +03:00
|
|
|
vertical-align: bottom;
|
2022-02-23 16:40:31 +02:00
|
|
|
height: 100px;
|
|
|
|
border-radius: 10px;
|
2023-12-02 05:05:03 +02:00
|
|
|
padding: 10px;
|
|
|
|
box-sizing: border-box;
|
2020-11-17 15:52:07 +02:00
|
|
|
|
|
|
|
&:hover {
|
2022-02-23 16:40:31 +02:00
|
|
|
color: var(--accent);
|
|
|
|
background: var(--accentedBg);
|
2020-11-17 15:52:07 +02:00
|
|
|
text-decoration: none;
|
|
|
|
}
|
|
|
|
|
|
|
|
> .icon {
|
2022-02-23 16:40:31 +02:00
|
|
|
font-size: 24px;
|
|
|
|
height: 24px;
|
2020-11-17 15:52:07 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
> .text {
|
2022-02-23 16:40:31 +02:00
|
|
|
margin-top: 12px;
|
|
|
|
font-size: 0.8em;
|
2020-11-17 15:52:07 +02:00
|
|
|
line-height: 1.5em;
|
2024-02-06 12:24:52 +02:00
|
|
|
text-align: center;
|
2020-11-17 15:52:07 +02:00
|
|
|
}
|
|
|
|
|
2023-11-01 06:34:05 +02:00
|
|
|
> .indicatorWithValue {
|
|
|
|
position: absolute;
|
|
|
|
top: 32px;
|
|
|
|
left: 16px;
|
|
|
|
|
|
|
|
@media (max-width: 500px) {
|
|
|
|
top: 16px;
|
|
|
|
left: 8px;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-20 17:22:59 +03:00
|
|
|
> .indicator {
|
2020-11-17 15:52:07 +02:00
|
|
|
position: absolute;
|
|
|
|
top: 32px;
|
|
|
|
left: 32px;
|
|
|
|
color: var(--indicator);
|
|
|
|
font-size: 8px;
|
2024-01-21 13:26:52 +02:00
|
|
|
animation: global-blink 1s infinite;
|
2020-11-17 15:52:07 +02:00
|
|
|
|
|
|
|
@media (max-width: 500px) {
|
|
|
|
top: 16px;
|
|
|
|
left: 16px;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</style>
|