Readlebee/app/appListeners.js

29 lines
957 B
JavaScript

export const appListeners = (app, state, emitter) => {
emitter.on('DOMContentLoaded', () => {
emitter.emit('DOMTitleChange', app.siteConfig.siteName);
// Emitter listeners
emitter.on('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('set-language', newLanguage => {
app.setSettingsItem('lang', newLanguage);
state.language = newLanguage;
state.i18n.fetchLocaleUI().then(() => {
emitter.emit('render');
});
});
state.i18n.fetchLocaleUI().then(() => {
app.checkIfLoggedIn(state).then(isLoggedIn => {
emitter.emit('render'); // This should hopefully only run once after the DOM is loaded. It prevents routing issues where 'render' hasn't been defined yet
});
})
});
}