Readlebee/app/appListeners.js

29 lines
1023 B
JavaScript
Raw Normal View History

export const appListeners = (app, state, emitter) => {
emitter.on(state.events.DOMCONTENTLOADED, () => {
emitter.emit(state.events.DOMTITLECHANGE, app.siteConfig.siteName);
2020-09-16 22:00:45 +02:00
// Emitter listeners
emitter.on(state.events.RENDER, callback => {
// This is a dirty hack to get the callback to call *after* re-rendering.
if (callback && typeof callback === "function") {
setTimeout(() => {
callback();
}, 50);
}
});
emitter.on(state.events.SET_LANGUAGE, newLanguage => {
app.setSettingsItem('lang', newLanguage);
state.language = newLanguage;
state.i18n.fetchLocaleUI().then(() => {
emitter.emit(state.events.RENDER);
});
});
2019-09-26 20:56:28 +02:00
state.i18n.fetchLocaleUI().then(() => {
app.checkIfLoggedIn(state).then(isLoggedIn => {
emitter.emit(state.events.RENDER); // This should hopefully only run once after the DOM is loaded. It prevents routing issues where 'render' hasn't been defined yet
});
})
});
}