All files / src/contexts/Config Config.tsx

21.42% Statements 3/14
0% Branches 0/4
0% Functions 0/2
23.07% Lines 3/13

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39              1x   1x   1x                                                      
import { createContext, FunctionComponent, useContext } from "react";
import { useQuery, UseQueryResult } from "react-query";
import { useLocation } from "react-router-dom";
import { fetchConfig, Config } from "../../api/config";
 
export type ConfigQuery = UseQueryResult<Config>;
 
const ConfigContext = createContext<ConfigQuery | undefined>(undefined);
 
export const useConfig = () => useContext(ConfigContext)!;
 
export const ConfigProvider: FunctionComponent = ({ children }) => {
  const { search } = useLocation();
  const { data, ...config }: ConfigQuery = useQuery("config", fetchConfig);
 
  const configData = { ...data };
 
  // allow overriding feature flags using query params the query param name is
  // `ff-<flagName>`, for example,
  // `https://constructs.dev?ff-generalAvailability`.
  const params = new URLSearchParams(search);
  configData.featureFlags = configData.featureFlags ?? {};
 
  for (const key of params.keys()) {
    if (key.startsWith("ff-")) {
      const flagName = key.slice(3);
      (configData.featureFlags as Record<string, boolean>)[flagName] = true;
    }
  }
 
  return (
    <ConfigContext.Provider
      value={{ ...config, data: configData } as ConfigQuery}
    >
      {children}
    </ConfigContext.Provider>
  );
};