diff --git a/src/components/header/Header.vue b/src/components/header/Header.vue index 2816e69b..0962cb11 100644 --- a/src/components/header/Header.vue +++ b/src/components/header/Header.vue @@ -58,7 +58,7 @@ :class="'is-' + calendarMode + '-mode'" @click="$emit('change-mode', calendarMode)" > - {{ getLanguage(languageKeys[calendarMode], time.CALENDAR_LOCALE) }} + {{ getTranslationForMode(calendarMode) }} @@ -79,7 +79,7 @@ import { type configInterface } from '../../typings/config.interface'; import Time from '../../helpers/Time'; import { type periodInterface } from '../../typings/interfaces/period.interface'; import getLanguage from '../../language'; -import { type modeType } from '../../typings/types'; +import {ModeTranslationMapping, type modeType} from '../../typings/types'; export default defineComponent({ name: 'AppHeader', @@ -157,10 +157,7 @@ export default defineComponent({ }, modeName() { - return this.getLanguage( - this.languageKeys[this.mode], - this.time?.CALENDAR_LOCALE - ); + return this.getTranslationForMode(this.mode) }, onlyDayModeIsEnabled() { @@ -191,6 +188,12 @@ export default defineComponent({ goToPeriod(direction: 'previous' | 'next') { (this.$refs.periodSelect as typeof DatePicker).goToPeriod(direction); }, + + getTranslationForMode(mode: modeType) { + const modeTranslationKey = ModeTranslationMapping[mode as keyof typeof ModeTranslationMapping] + + return this.getLanguage(this.languageKeys[modeTranslationKey], this.time?.CALENDAR_LOCALE) + } } }); diff --git a/src/typings/types.ts b/src/typings/types.ts index 6569a4b5..07205d7c 100644 --- a/src/typings/types.ts +++ b/src/typings/types.ts @@ -21,3 +21,11 @@ export type DayInfo = { thisDayIndex: number, dateTimeString: string } + +// Since the agenda doesn't need its own translations, we map it to the month mode +export enum ModeTranslationMapping { + month = "month", + agenda = "month", + week = "week", + day = "day", +}