decide.nolog.cz/app/components/language-select.js

50 lines
1.2 KiB
JavaScript
Raw Normal View History

import classic from 'ember-classic-decorator';
import { classNames, tagName } from '@ember-decorators/component';
import { computed } from '@ember/object';
2018-12-29 01:27:37 +01:00
import { inject as service } from '@ember/service';
import { readOnly } from '@ember/object/computed';
import Component from '@ember/component';
2016-06-20 19:28:10 +02:00
import localesMeta from 'croodle/locales/meta';
2015-11-20 02:18:19 +01:00
@classic
@tagName('select')
@classNames('language-select')
export default class LanguageSelect extends Component {
@service
intl;
@service
moment;
@service
powerCalendar;
2015-11-20 02:18:19 +01:00
@readOnly('intl.primaryLocale')
current;
@computed('intl.locales')
get locales() {
let currentLocale = this.intl.primaryLocale;
2015-12-07 22:21:38 +01:00
return Object.keys(localesMeta).map(function(locale) {
2015-12-07 22:21:38 +01:00
return {
id: locale,
selected: locale === currentLocale,
2016-06-20 19:28:10 +02:00
text: localesMeta[locale]
2015-12-07 22:21:38 +01:00
};
2015-11-20 02:18:19 +01:00
});
}
2015-11-20 02:18:19 +01:00
change() {
let locale = this.element.options[this.element.selectedIndex].value;
2018-12-29 20:35:04 +01:00
this.intl.set('locale', locale.includes('-') ? [locale, locale.split('-')[0]] : [locale]);
2018-12-29 20:35:04 +01:00
this.moment.changeLocale(locale);
this.powerCalendar.set('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
}
}