2019-09-13 11:59:45 +00:00
|
|
|
import { ReduxAction } from "../constants/ReduxActionConstants";
|
2019-09-09 09:08:54 +00:00
|
|
|
import {
|
|
|
|
|
SENTRY_PROD_CONFIG,
|
|
|
|
|
SENTRY_STAGE_CONFIG,
|
|
|
|
|
HOTJAR_PROD_HJID,
|
|
|
|
|
HOTJAR_PROD_HJSV,
|
|
|
|
|
} from "../constants/ThirdPartyConstants";
|
|
|
|
|
import * as Sentry from "@sentry/browser";
|
|
|
|
|
import AnalyticsUtil from "./AnalyticsUtil";
|
|
|
|
|
import netlifyIdentity from "netlify-identity-widget";
|
2019-09-13 11:59:45 +00:00
|
|
|
import FontFaceObserver from "fontfaceobserver";
|
2019-09-18 10:19:50 +00:00
|
|
|
import PropertyControlRegistry from "./PropertyControlRegistry";
|
|
|
|
|
import WidgetBuilderRegistry from "./WidgetRegistry";
|
2019-09-18 14:10:57 +00:00
|
|
|
import { Property } from "../api/ActionAPI";
|
|
|
|
|
import _ from "lodash";
|
2019-08-30 10:33:49 +00:00
|
|
|
|
|
|
|
|
export const createReducer = (
|
|
|
|
|
initialState: any,
|
2019-09-09 09:08:54 +00:00
|
|
|
handlers: { [type: string]: Function },
|
2019-08-30 10:33:49 +00:00
|
|
|
) => {
|
|
|
|
|
return function reducer(state = initialState, action: ReduxAction<any>) {
|
|
|
|
|
if (handlers.hasOwnProperty(action.type)) {
|
2019-09-09 09:08:54 +00:00
|
|
|
return handlers[action.type](state, action);
|
2019-08-30 10:33:49 +00:00
|
|
|
} else {
|
2019-09-09 09:08:54 +00:00
|
|
|
return state;
|
2019-08-30 10:33:49 +00:00
|
|
|
}
|
2019-09-09 09:08:54 +00:00
|
|
|
};
|
|
|
|
|
};
|
2019-08-30 10:33:49 +00:00
|
|
|
|
|
|
|
|
export const appInitializer = () => {
|
2019-09-18 10:19:50 +00:00
|
|
|
WidgetBuilderRegistry.registerWidgetBuilders();
|
|
|
|
|
PropertyControlRegistry.registerPropertyControlBuilders();
|
2019-09-02 15:36:24 +00:00
|
|
|
netlifyIdentity.init();
|
2019-08-30 10:33:49 +00:00
|
|
|
switch (process.env.REACT_APP_ENVIRONMENT) {
|
|
|
|
|
case "PRODUCTION":
|
2019-09-09 09:08:54 +00:00
|
|
|
Sentry.init(SENTRY_PROD_CONFIG);
|
2019-08-30 11:23:42 +00:00
|
|
|
AnalyticsUtil.initializeHotjar(HOTJAR_PROD_HJID, HOTJAR_PROD_HJSV);
|
|
|
|
|
AnalyticsUtil.initializeSegment();
|
2019-08-30 10:33:49 +00:00
|
|
|
break;
|
|
|
|
|
case "STAGING":
|
2019-09-09 09:08:54 +00:00
|
|
|
Sentry.init(SENTRY_STAGE_CONFIG);
|
|
|
|
|
break;
|
2019-08-30 10:33:49 +00:00
|
|
|
case "LOCAL":
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
2019-09-06 11:40:00 +00:00
|
|
|
const textFont = new FontFaceObserver("DM Sans");
|
2019-09-09 09:08:54 +00:00
|
|
|
textFont
|
|
|
|
|
.load()
|
|
|
|
|
.then(() => {
|
|
|
|
|
document.body.className += "fontLoaded";
|
|
|
|
|
})
|
|
|
|
|
.catch(err => {
|
|
|
|
|
console.log(err);
|
|
|
|
|
});
|
|
|
|
|
};
|
2019-09-18 14:10:57 +00:00
|
|
|
|
|
|
|
|
export const mapToPropList = (map: Record<string, string>): Property[] => {
|
|
|
|
|
return _.map(map, (value, key) => {
|
|
|
|
|
return { key: key, value: value };
|
|
|
|
|
});
|
|
|
|
|
};
|