1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- import { SET_CONFIG } from '../base/config/actionTypes';
- import MiddlewareRegistry from '../base/redux/MiddlewareRegistry';
-
- import { SET_DYNAMIC_BRANDING_DATA } from './actionTypes';
- import { fetchCustomBrandingData } from './actions.native';
-
- import './middleware.any';
-
- MiddlewareRegistry.register(store => next => action => {
- switch (action.type) {
- case SET_CONFIG: {
- const result = next(action);
-
- store.dispatch(fetchCustomBrandingData());
-
- return result;
- }
-
- case SET_DYNAMIC_BRANDING_DATA: {
- const {
- avatarBackgrounds = [],
- backgroundColor,
- backgroundImageUrl,
- brandedIcons,
- didPageUrl,
- downloadAppsUrl,
- inviteDomain,
- labels,
- liveStreamingDialogUrls,
- salesforceUrl,
- sharedVideoAllowedURLDomains,
- supportUrl,
- userDocumentationUrl
- } = action.value;
-
- action.value = {
- avatarBackgrounds,
- backgroundColor,
- backgroundImageUrl,
- brandedIcons,
- didPageUrl,
- downloadAppsUrl,
- inviteDomain,
- labels,
- liveStreamingDialogUrls,
- salesforceUrl,
- sharedVideoAllowedURLDomains,
- supportUrl,
- userDocumentationUrl
- };
-
- // The backend may send an empty string, make sure we skip that.
- if (Array.isArray(avatarBackgrounds)) {
- // TODO: implement support for gradients.
- action.value.avatarBackgrounds = avatarBackgrounds.filter(
- (color: string) => !color.includes('linear-gradient')
- );
- }
-
- break;
- }
- }
-
- return next(action);
- });
|