Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(presenter): make i18n locale extractable from url #335

Merged
Merged
Show file tree
Hide file tree
Changes from 22 commits
Commits
Show all changes
44 commits
Select commit Hold shift + click to select a range
f66d696
Make i18n for page titles.
Elweyn Mar 14, 2024
e33dd42
Locale in i18n.global.locale.value is 'de' or 'en' for testing set fi…
Elweyn Mar 16, 2024
a4e9ccf
Locale in i18n.global.locale.value is 'de' or 'en' for testing set fi…
Elweyn Mar 16, 2024
c2044a1
We don't want to use 'de-DE' and use 'de' instead.
Elweyn Mar 16, 2024
f547fe8
Set i18n.global.locale.value to the value extracted out of the url.
Elweyn Mar 16, 2024
a89eb31
Change export function to export const title.
Elweyn Mar 16, 2024
e5ab2d7
Create localeStore.
Elweyn Mar 18, 2024
85a6817
Remove changes on +title.ts
Elweyn Mar 18, 2024
c371959
Merge branch 'master' into 208-feature-implement-page-title-translati…
Elweyn Mar 18, 2024
db89d5e
Add locale to pageContext.
Elweyn Mar 19, 2024
d40547e
Change html lang to store value.
Elweyn Mar 19, 2024
94c6915
Use localeStore as value of languageselector.
Elweyn Mar 19, 2024
d3172be
Transfere locale to frontend.
Elweyn Mar 22, 2024
d34b5e8
Change pageContext.url to pageContext.urlLogical.
Elweyn Mar 22, 2024
861eb45
Remove LocaleStore.
Elweyn Mar 22, 2024
5de2157
Set locale to pageContext and add default i18n value.
Elweyn Mar 22, 2024
2251b90
Set default locale to the locale given in pageContext.
Elweyn Mar 22, 2024
15ac759
Remove LocaleStorage.
Elweyn Mar 22, 2024
dc7cdc3
Add locale to the pageContext
Elweyn Mar 22, 2024
9a099de
Add non default locale to the prerenderContext.pageContexts.
Elweyn Mar 22, 2024
7e0bdfb
Merge branch 'master' into 208-feature-implement-page-title-translati…
Elweyn Mar 22, 2024
a87ea62
Correct linting.
Elweyn Mar 22, 2024
d43176e
Define LocaleCode and give the type to array of locales.
Elweyn Mar 23, 2024
88cadea
Make extractLocale more dynamic to locales changes.
Elweyn Mar 23, 2024
70d50b0
Use the defined locales and localeDefault.
Elweyn Mar 23, 2024
5fc33b3
Make locales check more dynamic.
Elweyn Mar 23, 2024
04f8c1c
Make PageContext.locale use the defined LocaleCode type.
Elweyn Mar 23, 2024
022c869
Make locales check more dynamic.
Elweyn Mar 23, 2024
d3bc59a
Move localizedLocale to locales folder.
Elweyn Mar 23, 2024
4bdcfa1
Add default locale to the mock pageContext.
Elweyn Mar 25, 2024
79faef1
Test if changing language switch the i18n value.
Elweyn Mar 25, 2024
244901e
Merge branch 'master' into 208-feature-implement-page-title-translati…
Elweyn Mar 25, 2024
114aeec
Merge branch 'master' into 208-feature-implement-page-title-translati…
Elweyn Mar 25, 2024
1cbc7bd
Update presenter/src/components/language/LanguageSelector.vue
Elweyn Mar 26, 2024
4f88924
Update presenter/renderer/app.ts
Elweyn Mar 26, 2024
0a101c7
Update presenter/locales/extractLocale.ts
Elweyn Mar 26, 2024
d61220e
Update presenter/renderer/+onBeforeRoute.ts
Elweyn Mar 26, 2024
fe90407
Remove changes to LanguageSelector since the locale is set somewhere …
Elweyn Mar 26, 2024
82c9452
Fix linting error.
Elweyn Mar 26, 2024
d6a1980
Change test description.
Elweyn Mar 26, 2024
67eebde
Remove check on defaultLocale in prerenderStart
Elweyn Mar 26, 2024
805d515
Move /locales to /src/locales.
Elweyn Mar 26, 2024
91f5b0b
Move src/locales/*.ts to src/locales/index.ts and change import.
Elweyn Mar 26, 2024
a80a6ed
Remove text in LanguageSelector.
Elweyn Mar 26, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
18 changes: 18 additions & 0 deletions presenter/locales/extractLocale.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
import { locales, localeDefault } from './locales'

export function extractLocale(url: string) {
const urlPaths = url.split('/')
let locale: 'en' | 'de'
let urlWithoutLocale
// We remove the URL locale, for example `/de/about` => `/about`
const firstPath = urlPaths[1]
if (locales.filter((locale) => locale !== localeDefault).includes(firstPath)) {
locale = 'en'
urlWithoutLocale = '/' + urlPaths.slice(2).join('/')
} else {
locale = localeDefault
urlWithoutLocale = url
}

return { locale, urlWithoutLocale }
}
2 changes: 2 additions & 0 deletions presenter/locales/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
export { extractLocale } from './extractLocale'
export { locales, localeDefault } from './locales'
2 changes: 2 additions & 0 deletions presenter/locales/locales.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
export const locales = ['de', 'en']
export const localeDefault = 'de'
2 changes: 1 addition & 1 deletion presenter/renderer/+config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
export default {
clientRouting: true,
prefetchStaticAssets: 'viewport',
passToClient: ['pageProps', /* 'urlPathname', */ 'routeParams'],
passToClient: ['pageProps', /* 'urlPathname', */ 'routeParams', 'locale'],
meta: {
title: {
// Make the value of `title` available on both the server- and client-side
Expand Down
20 changes: 20 additions & 0 deletions presenter/renderer/+onBeforeRoute.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
import { PageContext } from 'vike/types'

import { extractLocale } from '#root/locales/extractLocale'

export function onBeforeRoute(pageContext: PageContext) {
if (pageContext.urlPathname.endsWith('.js')) {
Elweyn marked this conversation as resolved.
Show resolved Hide resolved
return { pageContext: { urlLogical: pageContext.urlPathname } }
}
Elweyn marked this conversation as resolved.
Show resolved Hide resolved

const { urlWithoutLocale, locale } = extractLocale(pageContext.urlPathname)

return {
pageContext: {
// Make `locale` available as `pageContext.locale`
locale,
// Vike's router will use pageContext.urlLogical instead of pageContext.urlOriginal
urlLogical: urlWithoutLocale,
},
}
}
35 changes: 35 additions & 0 deletions presenter/renderer/+onPrerenderStart.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
import { PageContextServer } from 'vike/types'

export { onPrerenderStart }

const locales = ['en', 'de']
const localeDefault = 'de'

function onPrerenderStart(prerenderContext: { pageContexts: PageContextServer[] }): {
prerenderContext: {
pageContexts: PageContextServer[]
}
} {
const storePageContexts: PageContextServer[] = []
prerenderContext.pageContexts.forEach((pageContext) => {
// Duplicate pageContext for each locale
locales.forEach((locale) => {
// Localize URL
let { urlOriginal } = pageContext
if (locale !== localeDefault) {
urlOriginal = `/${locale}${urlOriginal}`
}
storePageContexts.push({
...pageContext,
urlOriginal,
// Set pageContext.locale
locale,
})
})
})
return {
prerenderContext: {
pageContexts: storePageContexts,
},
}
}
6 changes: 6 additions & 0 deletions presenter/renderer/app.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ function createApp(pageContext: PageContext, isClient = true) {
data: () => ({
Page: markRaw(pageContext.Page),
pageProps: markRaw(pageContext.pageProps || {}),
locale: markRaw(pageContext.locale || {}),
isClient,
}),
created() {
Expand Down Expand Up @@ -64,13 +65,18 @@ function createApp(pageContext: PageContext, isClient = true) {
Object.assign(pageContextReactive, pageContext)
rootComponent.Page = markRaw(pageContext.Page)
rootComponent.pageProps = markRaw(pageContext.pageProps || {})
rootComponent.locale = markRaw(pageContext.locale || {})
},
})

const pageContextReactive = reactive(pageContext)

setPageContext(app, pageContextReactive)

if (pageContext.locale === 'de' || pageContext.locale === 'en') {
i18n.global.locale.value = pageContext.locale
}

return { app, i18n }
}

Expand Down
20 changes: 19 additions & 1 deletion presenter/src/components/language/LanguageSelector.vue
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
<template>
<v-select
v-model="$i18n.locale"
v-model="selectedLocale"
density="compact"
name="language"
:items="languages"
Expand All @@ -12,6 +12,7 @@
bg-color="transparent"
hide-details="auto"
flat
@update:model-value="updateLocale"
>
<template #selection="{ item }">
<span>{{ item.raw.locale.toUpperCase() }}</span>
Expand All @@ -29,11 +30,28 @@
<script lang="ts" setup>
import { ref } from 'vue'

import { usePageContext } from '#context/usePageContext'
import i18n from '#plugins/i18n'

// TODO better place? maybe locales folder?
const languages = ref([
{ locale: 'de', title: 'Deutsch' },
{ locale: 'en', title: 'English' },
])

const pageContext = usePageContext()

if (pageContext.locale === 'de' || pageContext.locale === 'en') {
i18n.global.locale.value = pageContext.locale
}

const selectedLocale = ref(i18n.global.locale.value)

function updateLocale() {
if (selectedLocale.value === 'de' || selectedLocale.value === 'en') {
i18n.global.locale.value = selectedLocale.value
}
}
</script>

<style lang="scss">
Expand Down
1 change: 1 addition & 0 deletions presenter/types/PageContext.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ declare global {
}
Page: Page
pageProps?: PageProps
locale?: string
}
}
}
Loading