2023-10-15 19:11:08 +02:00
|
|
|
import Component from '@glimmer/component';
|
2018-12-29 01:27:37 +01:00
|
|
|
import { inject as service } from '@ember/service';
|
2016-06-20 19:28:10 +02:00
|
|
|
import localesMeta from 'croodle/locales/meta';
|
2023-10-15 19:11:08 +02:00
|
|
|
import { action } from '@ember/object';
|
2023-10-29 19:16:33 +01:00
|
|
|
import type IntlService from 'ember-intl/services/intl';
|
|
|
|
import type PowerCalendarService from 'ember-power-calendar/services/power-calendar';
|
2015-11-20 02:18:19 +01:00
|
|
|
|
2020-01-18 10:13:50 +01:00
|
|
|
export default class LanguageSelect extends Component {
|
2023-10-29 19:16:33 +01:00
|
|
|
@service declare intl: IntlService;
|
|
|
|
@service declare powerCalendar: PowerCalendarService;
|
2015-11-20 02:18:19 +01:00
|
|
|
|
2023-09-21 12:30:14 +02:00
|
|
|
get currentLocale() {
|
|
|
|
return this.intl.primaryLocale;
|
|
|
|
}
|
2020-01-18 10:13:50 +01:00
|
|
|
|
2023-10-29 19:16:33 +01:00
|
|
|
locales = localesMeta;
|
2015-11-20 02:18:19 +01:00
|
|
|
|
2023-10-15 19:11:08 +02:00
|
|
|
@action
|
2023-10-29 19:16:33 +01:00
|
|
|
handleChange(event: Event) {
|
|
|
|
const selectElement = event.target as HTMLSelectElement;
|
|
|
|
const locale = selectElement.value as keyof typeof this.locales;
|
2018-12-29 20:35:04 +01:00
|
|
|
|
2023-10-15 20:37:03 +02:00
|
|
|
this.intl.locale = locale.includes('-')
|
2023-10-29 19:16:33 +01:00
|
|
|
? [locale, locale.split('-')[0] as string]
|
2023-10-15 20:37:03 +02:00
|
|
|
: [locale];
|
2023-10-15 19:11:08 +02:00
|
|
|
this.powerCalendar.locale = locale;
|
2018-12-29 20:35:04 +01:00
|
|
|
|
|
|
|
if (window.localStorage) {
|
|
|
|
window.localStorage.setItem('locale', locale);
|
|
|
|
}
|
2015-11-20 02:18:19 +01:00
|
|
|
}
|
2020-01-18 10:13:50 +01:00
|
|
|
}
|
2023-11-04 14:54:30 +01:00
|
|
|
|
|
|
|
declare module '@glint/environment-ember-loose/registry' {
|
|
|
|
export default interface Registry {
|
|
|
|
LanguageSelect: typeof LanguageSelect;
|
|
|
|
}
|
|
|
|
}
|