datahub/datahub-web-react/src/AppConfigProvider.tsx

47 lines
1.6 KiB
TypeScript
Raw Normal View History

import React, { useEffect } from 'react';
import './App.less';
import { THIRD_PARTY_LOGGING_KEY } from './app/analytics/analytics';
import { checkAuthStatus } from './app/auth/checkAuthStatus';
import { AppConfigContext, DEFAULT_APP_CONFIG } from './appConfigContext';
import { useAppConfigQuery } from './graphql/app.generated';
2022-09-01 17:06:30 -07:00
function changeFavicon(src) {
let link = document.querySelector("link[rel~='icon']") as any;
if (!link) {
link = document.createElement('link');
link.rel = 'icon';
document.getElementsByTagName('head')[0].appendChild(link);
}
link.href = src;
}
const AppConfigProvider = ({ children }: { children: React.ReactNode }) => {
const { data: appConfigData, refetch } = useAppConfigQuery();
const refreshAppConfig = () => {
refetch();
};
useEffect(() => {
if (appConfigData && appConfigData.appConfig) {
if (appConfigData.appConfig.telemetryConfig.enableThirdPartyLogging) {
localStorage.setItem(THIRD_PARTY_LOGGING_KEY, 'true');
checkAuthStatus(); // identify in analyitcs once we receive config response
} else {
localStorage.setItem(THIRD_PARTY_LOGGING_KEY, 'false');
}
2022-09-01 17:06:30 -07:00
changeFavicon(appConfigData.appConfig.visualConfig.faviconUrl);
}
}, [appConfigData]);
return (
<AppConfigContext.Provider
value={{ config: appConfigData?.appConfig || DEFAULT_APP_CONFIG, refreshContext: refreshAppConfig }}
>
{children}
</AppConfigContext.Provider>
);
};
export default AppConfigProvider;