From 0b9a7cc8428b17aec2c9fa0dfc63a519ba6b264b Mon Sep 17 00:00:00 2001 From: Oleg Kalyanov Date: Thu, 11 Jan 2024 13:26:01 +0000 Subject: [PATCH] Fix localization issues (#31) --- .nvmrc | 2 +- demo/index.ts | 5 +++-- src/l10n.ts | 20 ++++++++++++++------ src/polygon.ts | 6 +++--- src/snapPoint.ts | 4 ++-- src/utils.ts | 8 ++++---- 6 files changed, 27 insertions(+), 18 deletions(-) diff --git a/.nvmrc b/.nvmrc index 6f7f377..958b5a3 100644 --- a/.nvmrc +++ b/.nvmrc @@ -1 +1 @@ -v16 +v14 diff --git a/demo/index.ts b/demo/index.ts index 49a7cac..0685308 100644 --- a/demo/index.ts +++ b/demo/index.ts @@ -45,8 +45,9 @@ const languageControl = new mapgl.Control( map, ` `, { diff --git a/src/l10n.ts b/src/l10n.ts index 1ebd7e2..1081b26 100644 --- a/src/l10n.ts +++ b/src/l10n.ts @@ -1,8 +1,6 @@ -/** - * @hidden - * @internal - */ -export const dictionary = { +const DEFAULT_LOCALE = 'en'; + +const DICTIONARY = { start: { en: 'Start', ru: 'Старт', @@ -19,4 +17,14 @@ export const dictionary = { en: 'km', ru: 'км', }, -}; +} as const; + +type L10nKey = keyof typeof DICTIONARY; + +/** + * @hidden + * @internal + */ +export function getTranslation(key: L10nKey, locale: string = DEFAULT_LOCALE) { + return DICTIONARY[key][locale] ?? DICTIONARY[key][DEFAULT_LOCALE]; +} diff --git a/src/polygon.ts b/src/polygon.ts index e7f6eeb..a4e28c2 100644 --- a/src/polygon.ts +++ b/src/polygon.ts @@ -4,7 +4,7 @@ import { area } from './geo/area'; import { centroid } from './geo/centroid'; import { GeoPoint } from './types'; import { style } from './style'; -import { dictionary } from './l10n'; +import { getTranslation } from './l10n'; /** * @internal @@ -80,10 +80,10 @@ export class Polygon { function getLabelText(area: number, lang: string) { lang = lang.toLowerCase(); if (area < 1e5) { - return `${area.toFixed(1)} ${dictionary.meter[lang]}²`; + return `${area.toFixed(1)} ${getTranslation('meter', lang)}²`; } - return `${(area / 1e6).toFixed(1)} ${dictionary.kilometer[lang]}²`; + return `${(area / 1e6).toFixed(1)} ${getTranslation('kilometer', lang)}²`; } function createLabel(map: mapgl.Map, coordinates: GeoPoint, area: number): mapgl.Label { diff --git a/src/snapPoint.ts b/src/snapPoint.ts index 9d0c330..377a0ec 100644 --- a/src/snapPoint.ts +++ b/src/snapPoint.ts @@ -1,7 +1,7 @@ import { GeoPoint, SnapInfo } from './types'; import { createHtmlMarker, getJointDistanceText, getLabelHtml, getSnapLabelHtml } from './utils'; import { style } from './style'; -import { dictionary } from './l10n'; +import { getTranslation } from './l10n'; /** * @hidden @@ -74,7 +74,7 @@ function createLabel(map: mapgl.Map, coordinates: GeoPoint, distance: number) { function getLabelText(map: mapgl.Map, distance: number) { const lang = map.getLanguage().toLowerCase(); const distanceText = getJointDistanceText(distance, false, lang); - const addJointText = dictionary.addPoint[lang] || dictionary.addPoint.en; + const addJointText = getTranslation('addPoint', lang); return getSnapLabelHtml(distanceText, addJointText); } diff --git a/src/utils.ts b/src/utils.ts index b014b6f..b33a6bc 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -1,6 +1,6 @@ import { GeoPoint, ScreenPoint, SnapInfo } from './types'; import { Joint } from './joint'; -import { dictionary } from './l10n'; +import { getTranslation } from './l10n'; import { style } from './style'; import { JOINT_REMOVE_BUTTON_SVG } from './constants'; import css from './index.module.css'; @@ -20,16 +20,16 @@ export function getJointDistanceText( lang = lang.toLowerCase(); if (first) { - return dictionary.start[lang] || dictionary.start.en; + return getTranslation('start', lang); } if (distance < 1000) { - return `${distance} ${dictionary.meter[lang] || dictionary.meter.en}`; + return `${distance} ${getTranslation('meter', lang)}`; } const kmDist = (distance / 1000).toFixed(1); - return `${kmDist} ${dictionary.kilometer[lang] || dictionary.kilometer.en}`; + return `${kmDist} ${getTranslation('kilometer', lang)}`; } /**