fix type errors of MkPageHeader

This commit is contained in:
Lhcfl 2024-04-04 16:53:02 +08:00
parent 3902b82470
commit 995d679afd
3 changed files with 28 additions and 16 deletions

View file

@ -19,7 +19,8 @@
"rules": {
"style": {
"useImportType": "warn",
"useShorthandFunctionType": "warn"
"useShorthandFunctionType": "warn",
"useTemplate": "warn"
}
}
}

View file

@ -3,8 +3,8 @@
v-if="show"
ref="el"
class="fdidabkb"
:class="{ thin: thin_, tabs: tabs?.length > 0 }"
:style="{ background: bg }"
:class="{ thin: thin_, tabs: isTabs(tabs)}"
:style="{ background: bg || undefined }"
@click="onClick"
>
<div class="left">
@ -70,14 +70,14 @@
</div>
<template v-if="metadata">
<nav
v-if="hasTabs"
v-if="isTabs(tabs)"
ref="tabsEl"
class="tabs"
:class="{ collapse: hasTabs && tabs.length > 3 }"
:class="{ collapse: tabs.length > 3 }"
>
<button
v-for="tab in tabs"
:ref="(el) => (tabRefs[tab.key] = el)"
:ref="(el) => (tab.key && (tabRefs[tab.key] = el))"
v-tooltip.noDelay="tab.title"
v-vibrate="5"
class="tab _button"
@ -157,6 +157,7 @@ const props = defineProps<{
actions?: {
text: string;
icon: string;
highlighted?: boolean;
handler: (ev: MouseEvent) => void;
}[];
thin?: boolean;
@ -171,7 +172,7 @@ const displayBackButton =
inject("shouldBackButton", true);
const emit = defineEmits<{
(ev: "update:tab", key: string);
"update:tab": [key: string];
}>();
const metadata = injectPageMetadata();
@ -183,9 +184,14 @@ const el = ref<HTMLElement | null>(null);
const tabRefs = {};
const tabHighlightEl = ref<HTMLElement | null>(null);
const tabsEl = ref<HTMLElement | null>(null);
const bg = ref(null);
const bg = ref<string | null | number>(null);
const narrow = ref(false);
const hasTabs = computed(() => props.tabs && props.tabs.length > 0);
function isTabs(t: Tab[] | undefined): t is Tab[] {
return t != null && t.length > 0;
}
const hasActions = computed(() => props.actions && props.actions.length > 0);
const show = computed(() => {
return !hideTitle || hasTabs.value || hasActions.value;
@ -201,7 +207,7 @@ const openAccountMenu = (ev: MouseEvent) => {
};
const showTabsPopup = (ev: MouseEvent) => {
if (!hasTabs.value) return;
if (!isTabs(props.tabs)) return;
if (!narrow.value) return;
ev.preventDefault();
ev.stopPropagation();
@ -213,7 +219,7 @@ const showTabsPopup = (ev: MouseEvent) => {
onTabClick(tab, ev);
},
}));
popupMenu(menu, ev.currentTarget ?? ev.target);
popupMenu(menu, (ev.currentTarget ?? ev.target) as HTMLElement);
};
const preventDrag = (ev: TouchEvent) => {
@ -224,8 +230,10 @@ const onClick = () => {
if (props.to) {
location.href = props.to;
} else {
if (el.value) {
scrollToTop(el.value, { behavior: "smooth" });
}
}
};
function onTabMousedown(tab: Tab, ev: MouseEvent): void {
@ -257,6 +265,8 @@ onMounted(() => {
() => [props.tab, props.tabs],
() => {
nextTick(() => {
if (props.tab == null) return;
if (!isTabs(props.tabs)) return;
const tabEl = tabRefs[props.tab];
if (tabEl && tabHighlightEl.value) {
// offsetWidth offsetLeft getBoundingClientRect 使
@ -266,7 +276,8 @@ onMounted(() => {
tabEl.style = `--width: ${tabSizeX}px`;
}
setTimeout(() => {
tabHighlightEl.value.style.width = tabSizeX + "px";
if (tabHighlightEl.value == null) return;
tabHighlightEl.value.style.width = `${tabSizeX}px`;
tabHighlightEl.value.style.transform = `translateX(${tabEl.offsetLeft}px)`;
window.requestAnimationFrame(() => {
tabsEl.value?.scrollTo({
@ -283,10 +294,10 @@ onMounted(() => {
},
);
if (el.value && el.value.parentElement) {
if (el.value?.parentElement) {
narrow.value = el.value.parentElement.offsetWidth < 500;
ro = new ResizeObserver((entries, observer) => {
if (el.value.parentElement && document.body.contains(el.value)) {
ro = new ResizeObserver((_entries, _observer) => {
if (el.value?.parentElement && document.body.contains(el.value)) {
narrow.value = el.value.parentElement.offsetWidth < 500;
}
});

View file

@ -9,7 +9,7 @@ export interface PageMetadata {
title: string;
subtitle?: string;
icon?: string | null;
avatar?: entities.User | null;
avatar?: entities.UserDetailed | null;
userName?: entities.User | null;
bg?: string;
}