mirror of
https://github.com/umami-software/umami.git
synced 2026-02-19 20:15:41 +01:00
- Rewrite messages.ts to plain string key maps (remove MessageDescriptor) - Rewrite useMessages hook to expose t from useTranslations() directly - Rename formatMessage → t across 193 consumer files - Replace custom FormattedMessage component with next-intl t.rich() - Update 52 language files to use rich text tags (<b>, <a>) - Remove all direct imports from @/components/messages in favor of useMessages() Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
22 lines
897 B
TypeScript
22 lines
897 B
TypeScript
import { Text } from '@umami/react-zen';
|
|
import { IconLabel } from '@/components/common/IconLabel';
|
|
import { LinkButton } from '@/components/common/LinkButton';
|
|
import { PageHeader } from '@/components/common/PageHeader';
|
|
import { useBoard, useMessages, useNavigation, useWebsiteQuery } from '@/components/hooks';
|
|
import { Edit } from '@/components/icons';
|
|
|
|
export function BoardViewHeader() {
|
|
const { board } = useBoard();
|
|
const { renderUrl } = useNavigation();
|
|
const { t, labels } = useMessages();
|
|
const { data: website } = useWebsiteQuery(board?.parameters?.websiteId);
|
|
|
|
return (
|
|
<PageHeader title={board?.name} description={board?.description}>
|
|
{website?.name && <Text>{website.name}</Text>}
|
|
<LinkButton href={renderUrl(`/boards/${board?.id}/edit`, false)}>
|
|
<IconLabel icon={<Edit />}>{t(labels.edit)}</IconLabel>
|
|
</LinkButton>
|
|
</PageHeader>
|
|
);
|
|
}
|