import { FC } from 'react'; import { SvgIcon, useTheme } from '@mui/material'; import LocationOnIcon from '@mui/icons-material/LocationOn'; import PeopleIcon from '@mui/icons-material/People'; import LanguageIcon from '@mui/icons-material/Language'; import PowerSettingsNewIcon from '@mui/icons-material/PowerSettingsNew'; import CodeIcon from '@mui/icons-material/Code'; import { ReactComponent as RolloutIcon } from 'assets/icons/rollout.svg'; export const formatStrategyName = (strategyName: string): string => { return formattedStrategyNames[strategyName] ?? strategyName; }; const RolloutSvgIcon: FC = props => ( } inheritViewBox /> ); export const getFeatureStrategyIcon = (strategyName: string) => { switch (strategyName) { case 'default': return PowerSettingsNewIcon; case 'remoteAddress': return LanguageIcon; case 'flexibleRollout': return RolloutSvgIcon; case 'userWithId': return PeopleIcon; case 'applicationHostname': return LocationOnIcon; default: return CodeIcon; } }; export const GetFeatureStrategyIcon: FC<{ strategyName: string }> = ({ strategyName, }) => { const theme = useTheme(); const Icon = getFeatureStrategyIcon(strategyName); return ; }; export const formattedStrategyNames: Record = { applicationHostname: 'Hosts', default: 'Standard', flexibleRollout: 'Gradual rollout', gradualRolloutRandom: 'Randomized', gradualRolloutSessionId: 'Sessions', gradualRolloutUserId: 'Users', remoteAddress: 'IPs', userWithId: 'UserIDs', };