Skip to content

Commit

Permalink
fix: 🐛 fix crash when moment locale and language code differ
Browse files Browse the repository at this point in the history
  • Loading branch information
kajetan-kazimierczak committed Nov 17, 2021
1 parent d158295 commit 623bf48
Show file tree
Hide file tree
Showing 3 changed files with 28 additions and 8 deletions.
2 changes: 1 addition & 1 deletion apps/skolplattformen-sthlm/components/week.component.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,7 @@ export const Day = ({ weekDay, lunch, lessons }: DayProps) => {
}

export const Week = ({ child }: WeekProps) => {
moment.locale(LanguageService.getLanguageCode())
moment.locale(LanguageService.getLocale())
const days = moment.weekdaysShort().slice(1, 6)
const currentDayIndex = Math.min(moment().isoWeekday() - 1, 5)
const [selectedIndex, setSelectedIndex] = useState(currentDayIndex)
Expand Down
15 changes: 8 additions & 7 deletions apps/skolplattformen-sthlm/services/languageService.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,13 +16,15 @@ import 'moment/locale/ru'
import 'moment/locale/sv'
import 'moment/locale/zh-cn'
import { I18nManager } from 'react-native'
import { languages } from '../utils/translation'

const changeListeners: Record<string, any> = {}

let allString: Record<string, any> = {}

let Strings: Record<string, any> = {}
let languageCode: string
let momentLocale: string

const rtlList: { [key: string]: boolean } = {
en: false,
Expand All @@ -40,17 +42,15 @@ export const isRTL = (langCode: string) => {
return rtlList[langCode]
}

const getCorrespondingMomentLocale = (langCode?: string): string => {
if (langCode === 'la') return 'sv'
if (langCode === 'so') return 'sv'
if (langCode === 'nb_NO') return 'nb'
if (langCode === 'zh_Hant' || langCode === 'zh_Hans') return 'zh-cn'
return langCode!
const getCorrespondingMomentLocale = (languageCode?: string): string => {
const lang = languages.find(({ langCode }) => langCode === languageCode)
return lang?.locale || 'sv'
}

export const LanguageService = {
get: () => Strings,
getLanguageCode: () => languageCode,
getLocale: () => momentLocale,
setAllData: ({ data }: { data: Record<string, any> }) => {
allString = data
},
Expand All @@ -61,11 +61,12 @@ export const LanguageService = {
i18n.locale = langCode
I18nManager.forceRTL(isRTL(langCode))
}
moment.locale(getCorrespondingMomentLocale(langCode))
moment.locale(momentLocale)
},
setLanguageCode: ({ langCode }: { langCode?: string }) => {
if (langCode && allString[langCode]) {
languageCode = langCode
momentLocale = getCorrespondingMomentLocale(langCode)
Strings = merge(allString.sv, allString[langCode])
} else {
const dataKeys = Object.keys(allString)
Expand Down
19 changes: 19 additions & 0 deletions apps/skolplattformen-sthlm/utils/translation.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ interface Language {
langCode: string
languageName: string
languageLocalName: string
locale: string
active: boolean
}

Expand All @@ -12,110 +13,128 @@ export const languages: Language[] = [
langCode: 'sv',
languageName: 'Swedish',
languageLocalName: 'Svenska',
locale: 'sv',
active: true,
},
{
langCode: 'ar',
languageName: 'Arabic',
languageLocalName: 'اَلْعَرَبِيَّةُ',
locale: 'ar',
active: true,
},
{
langCode: 'zh_Hant',
languageName: 'Chinese (traditional)',
languageLocalName: '中國傳統的',
locale: 'zh-cn',
active: true,
},
{
langCode: 'zh_Hans',
languageName: 'Chinese (simplified)',
languageLocalName: '简体中文',
locale: 'zh-cn',
active: true,
},
{
langCode: 'nl',
languageName: 'Dutch',
languageLocalName: 'Nederlands',
locale: 'nl',
active: true,
},
{
langCode: 'en',
languageName: 'English',
languageLocalName: 'English',
locale: 'en',
active: true,
},

{
langCode: 'de',
languageName: 'German',
languageLocalName: 'Deutsch',
locale: 'de',
active: true,
},

{
langCode: 'fi',
languageName: 'Finnish',
languageLocalName: 'Suomi',
locale: 'fi',
active: true,
},
{
langCode: 'fr',
languageName: 'French',
languageLocalName: 'Français',
locale: 'fr',
active: true,
},
{
langCode: 'it',
languageName: 'Italian',
languageLocalName: 'Italiano',
locale: 'it',
active: true,
},
{
langCode: 'ja',
languageName: 'Japanese',
languageLocalName: '日本語',
locale: 'ja',
active: true,
},
{
langCode: 'la',
languageName: 'Latin',
languageLocalName: 'Latina',
locale: 'sv',
active: true,
},
{
langCode: 'nb_NO',
languageName: 'Norwegian Bokmål',
languageLocalName: 'Norsk bokmål',
locale: 'nb',
active: true,
},
{
langCode: 'pl',
languageName: 'Polish',
languageLocalName: 'Polski',
locale: 'pl',
active: true,
},
{
langCode: 'pt',
languageName: 'Portuguese',
languageLocalName: 'Português',
locale: 'pt',
active: true,
},
{
langCode: 'ru',
languageName: 'Russian',
languageLocalName: 'русский',
locale: 'ru',
active: false,
},
{
langCode: 'so',
languageName: 'Somali',
languageLocalName: 'af-Soomaali',
locale: 'sv',
active: true,
},
{
langCode: 'es',
languageName: 'Spanish',
languageLocalName: 'Español',
locale: 'es',
active: true,
},
]
Expand Down

0 comments on commit 623bf48

Please sign in to comment.