From 7af0464a11bcc5a38e5d6f0584dab3dac8e6fcda Mon Sep 17 00:00:00 2001 From: Arthur DANJOU Date: Fri, 5 Sep 2025 14:08:13 +0200 Subject: [PATCH] feat: simplify localization handling and add resume component with translations --- app/components/chat/CommandPalette.vue | 7 +- app/components/chat/MessageContainer.vue | 5 +- app/components/chat/MessageFromArthur.vue | 8 +- app/components/tool/Activity.vue | 5 +- app/components/tool/Projects.vue | 5 +- app/components/tool/Resume.vue | 36 ++++ app/components/tool/Stats.vue | 5 +- app/components/tool/Writings.vue | 5 +- app/pages/projects/index.vue | 2 +- app/pages/writings/index.vue | 2 +- locales/en.json | 4 + locales/es.json | 226 +++++++++++++++++++++- locales/fr.json | 6 +- 13 files changed, 286 insertions(+), 30 deletions(-) create mode 100644 app/components/tool/Resume.vue diff --git a/app/components/chat/CommandPalette.vue b/app/components/chat/CommandPalette.vue index 0344c62..35f67c4 100644 --- a/app/components/chat/CommandPalette.vue +++ b/app/components/chat/CommandPalette.vue @@ -15,7 +15,7 @@ const searchTerm = ref('') const openMessageModal = ref(false) const openClearModal = ref(false) -const { t, locale, locales } = useI18n() +const { t, locale } = useI18n() const { messages, submitMessage } = useChat() const { clearMessages, messages: storeMessages } = useChatStore() @@ -32,7 +32,6 @@ function onSelect(item: CommandPaletteItem) { submitMessage(item.type, item.prompt, item.fetchStates ?? []) } -const currentLocale = computed(() => locales.value.filter(l => l.code === locale.value)[0]) const { changeLocale } = useLanguage() const { dark, toggleDark } = useTheme() @@ -41,7 +40,7 @@ defineShortcuts({ enter: () => openMessageModal.value = !openMessageModal.value, meta_k: () => openMessageModal.value = !openMessageModal.value, meta_d: () => openClearModal.value = !openClearModal.value, - l: () => changeLocale(currentLocale.value!.code === 'en' ? 'fr' : currentLocale.value!.code === 'fr' ? 'es' : 'en'), + l: () => changeLocale(locale.value === 'en' ? 'fr' : locale.value === 'fr' ? 'es' : 'en'), t: () => toggleDark({ clientX: window.innerWidth / 2, clientY: window.innerHeight }), }) @@ -279,7 +278,7 @@ function isRoute(name: string): boolean { aria-label="Change language" class="cursor-pointer" size="xl" - @click.prevent="changeLocale(currentLocale!.code === 'en' ? 'fr' : currentLocale!.code === 'fr' ? 'es' : 'en')" + @click.prevent="changeLocale(locale === 'en' ? 'fr' : locale === 'fr' ? 'es' : 'en')" /> diff --git a/app/components/chat/MessageContainer.vue b/app/components/chat/MessageContainer.vue index 63b9ccc..aa901eb 100644 --- a/app/components/chat/MessageContainer.vue +++ b/app/components/chat/MessageContainer.vue @@ -8,9 +8,8 @@ const props = defineProps<{ const isArthur = computed(() => props.message.sender === ChatSender.ARTHUR) -const { t, locale, locales } = useI18n() -const currentLocale = computed(() => locales.value.find(l => l.code === locale.value)) -const formatDate = computed(() => useDateFormat(props.message.createdAt, 'D MMMM YYYY, HH:mm', { locales: currentLocale.value?.code ?? 'en' }).value) +const { t, locale } = useI18n() +const formatDate = computed(() => useDateFormat(props.message.createdAt, 'D MMMM YYYY, HH:mm', { locales: locale.value ?? 'en' }).value)