hippofish/packages/client/src/scripts/page-metadata.ts

51 lines
1.1 KiB
TypeScript
Raw Normal View History

import type { entities } from "firefish-js";
2023-09-02 01:27:33 +02:00
import type { ComputedRef, Ref } from "vue";
import { inject, isRef, onActivated, onMounted, provide, ref } from "vue";
2023-01-13 05:40:33 +01:00
export const setPageMetadata = Symbol("setPageMetadata");
export const pageMetadataProvider = Symbol("pageMetadataProvider");
2023-09-02 01:27:33 +02:00
export interface PageMetadata {
title: string;
subtitle?: string;
icon?: string | null;
2024-04-04 10:53:02 +02:00
avatar?: entities.UserDetailed | null;
userName?: entities.User | null;
bg?: string;
2023-09-02 01:27:33 +02:00
}
2023-01-13 05:40:33 +01:00
export function definePageMetadata(
metadata:
| PageMetadata
| null
| Ref<PageMetadata | null>
| ComputedRef<PageMetadata | null>,
): void {
const _metadata = isRef(metadata) ? metadata : ref(metadata);
provide(pageMetadataProvider, _metadata);
const set = inject(setPageMetadata) as any;
if (set) {
set(_metadata);
onMounted(() => {
set(_metadata);
});
onActivated(() => {
set(_metadata);
});
}
}
2023-01-13 05:40:33 +01:00
export function provideMetadataReceiver(
callback: (info: ComputedRef<PageMetadata>) => void,
): void {
provide(setPageMetadata, callback);
}
export function injectPageMetadata(): PageMetadata | undefined {
return inject(pageMetadataProvider);
}