summaryrefslogtreecommitdiffstats
path: root/web/react/stores/localization_store.jsx
diff options
context:
space:
mode:
authorChristopher Speller <crspeller@gmail.com>2016-03-14 00:56:37 -0400
committerChristopher Speller <crspeller@gmail.com>2016-03-14 00:56:37 -0400
commit975159b52ac6bf0ee6b2d5b73d2391b2e0c6e165 (patch)
treea0852f9faf6de9962b5478ed3f1bbaccd71062c0 /web/react/stores/localization_store.jsx
parent160e1a8bea6d8280ef3b41a4a9f80674b75f3eb0 (diff)
parentd7cdcf082fab6c0cb7c2fe4bed821bd1a8000e69 (diff)
downloadchat-975159b52ac6bf0ee6b2d5b73d2391b2e0c6e165.tar.gz
chat-975159b52ac6bf0ee6b2d5b73d2391b2e0c6e165.tar.bz2
chat-975159b52ac6bf0ee6b2d5b73d2391b2e0c6e165.zip
Merge pull request #2331 from mattermost/plt-1680
PLT-1680 Converting client to react-router. Stage 1
Diffstat (limited to 'web/react/stores/localization_store.jsx')
-rw-r--r--web/react/stores/localization_store.jsx60
1 files changed, 60 insertions, 0 deletions
diff --git a/web/react/stores/localization_store.jsx b/web/react/stores/localization_store.jsx
new file mode 100644
index 000000000..0e3a63724
--- /dev/null
+++ b/web/react/stores/localization_store.jsx
@@ -0,0 +1,60 @@
+// Copyright (c) 2015 Mattermost, Inc. All Rights Reserved.
+// See License.txt for license information.
+
+import AppDispatcher from '../dispatcher/app_dispatcher.jsx';
+import EventEmitter from 'events';
+import Constants from '../utils/constants.jsx';
+const ActionTypes = Constants.ActionTypes;
+
+const CHANGE_EVENT = 'change';
+
+class LocalizationStoreClass extends EventEmitter {
+ constructor() {
+ super();
+
+ this.currentLocale = 'en';
+ this.currentTranslations = null;
+ }
+
+ emitChange() {
+ this.emit(CHANGE_EVENT);
+ }
+
+ addChangeListener(callback) {
+ this.on(CHANGE_EVENT, callback);
+ }
+
+ removeChangeListener(callback) {
+ this.removeListener(CHANGE_EVENT, callback);
+ }
+
+ setCurrentLocale(locale, translations) {
+ this.currentLocale = locale;
+ this.currentTranslations = translations;
+ }
+
+ getLocale() {
+ return this.currentLocale;
+ }
+
+ getTranslations() {
+ return this.currentTranslations;
+ }
+}
+
+var LocalizationStore = new LocalizationStoreClass();
+LocalizationStore.setMaxListeners(0);
+
+LocalizationStore.dispatchToken = AppDispatcher.register((payload) => {
+ var action = payload.action;
+
+ switch (action.type) {
+ case ActionTypes.RECEIVED_LOCALE:
+ LocalizationStore.setCurrentLocale(action.locale, action.translations);
+ LocalizationStore.emitChange();
+ break;
+ default:
+ }
+});
+
+export default LocalizationStore;