Auto locale
This commit is contained in:
18
src/routes/+layout.server.ts
Normal file
18
src/routes/+layout.server.ts
Normal file
@@ -0,0 +1,18 @@
|
||||
import type {LayoutServerLoad} from './$types';
|
||||
import {defaultLocale, locales} from "$lib/translations";
|
||||
|
||||
export const prerender = true;
|
||||
|
||||
export const load: LayoutServerLoad = async ({ request }) => {
|
||||
const supportedLocales = locales.get().map((l) => l.toLowerCase());
|
||||
|
||||
let locale = `${`${request.headers.get('accept-language')}`.match(/[a-zA-Z]+?(?=[-_,;])/)}`.toLowerCase();
|
||||
|
||||
if (!supportedLocales.includes(locale)) {
|
||||
locale = defaultLocale;
|
||||
}
|
||||
|
||||
return {
|
||||
i18n: { locale },
|
||||
};
|
||||
}
|
||||
@@ -1,13 +1,11 @@
|
||||
import type {LayoutLoad} from './$types';
|
||||
import {loadTranslations} from "$lib/translations";
|
||||
import {loadTranslations} from '$lib/translations';
|
||||
import type {LayoutLoad} from "./$types";
|
||||
|
||||
export const prerender = true;
|
||||
|
||||
export const load: LayoutLoad = async ({ url }) => {
|
||||
export const load: LayoutLoad = async ({ url, data }) => {
|
||||
const { pathname } = url;
|
||||
const { locale } = data.i18n
|
||||
|
||||
const initLocale = 'ru';
|
||||
await loadTranslations(locale, pathname);
|
||||
|
||||
await loadTranslations(initLocale, pathname);
|
||||
return {};
|
||||
}
|
||||
};
|
||||
|
||||
@@ -10,11 +10,11 @@
|
||||
</h2>
|
||||
|
||||
<div class="grid md:grid-cols-[1fr_auto] gap-6">
|
||||
<div>
|
||||
<div class="max-w-2xl">
|
||||
{@html $t('about.text')}
|
||||
</div>
|
||||
|
||||
<div class="grid gap-x-2 grid-cols-[auto_1fr] items-center text-slate-400">
|
||||
<div class="grid gap-x-2 grid-cols-[auto_1fr] h-fit items-center text-slate-400">
|
||||
<div class="flex gap-2 items-center">
|
||||
<MaterialSymbolsWork></MaterialSymbolsWork>
|
||||
{$t('about.career')}
|
||||
|
||||
Reference in New Issue
Block a user