diff --git a/js/sources/user_source.js b/js/sources/user_source.js index 05165391..5940169b 100644 --- a/js/sources/user_source.js +++ b/js/sources/user_source.js @@ -18,7 +18,7 @@ const UserSource = { success: UserActions.successFetchCurrentUser, error: UserActions.currentUserFailed, shouldFetch(state) { - return state.invalidateCache || state.currentUser && !state.currentUser.email; + return state.userMeta.invalidateCache || state.currentUser && !state.currentUser.email; } }, diff --git a/js/sources/whitelabel_source.js b/js/sources/whitelabel_source.js new file mode 100644 index 00000000..eda0ba19 --- /dev/null +++ b/js/sources/whitelabel_source.js @@ -0,0 +1,25 @@ +'use strict'; + +import requests from '../utils/requests'; +import WhitelabelActions from '../actions/whitelabel_actions'; + +import { getSubdomain } from '../utils/general_utils'; + + +const WhitelabelSource = { + lookupWhitelabel: { + remote() { + return requests.get('whitelabel_settings', {'subdomain': getSubdomain()}); + }, + local(state) { + return Object.keys(state.whitelabel).length > 0 ? state : {}; + }, + success: WhitelabelActions.successFetchWhitelabel, + error: WhitelabelActions.whitelabelFailed, + shouldFetch(state) { + return state.whitelabelMeta.invalidateCache || Object.keys(state.whitelabel).length === 0; + } + } +}; + +export default WhitelabelSource; \ No newline at end of file