1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-06 00:07:44 +01:00
unleash.unleash/frontend/src/component/feature/FeatureToggleList/BulkEnableDialog.tsx

86 lines
2.5 KiB
TypeScript
Raw Normal View History

2023-05-18 08:07:56 +02:00
import { useState } from 'react';
import { Box, styled, Typography } from '@mui/material';
import { Dialogue } from 'component/common/Dialogue/Dialogue';
import GeneralSelect from 'component/common/GeneralSelect/GeneralSelect';
import useToast from 'hooks/useToast';
import type { FeatureSchema } from 'openapi';
import { formatUnknownError } from 'utils/formatUnknownError';
import useFeatureApi from 'hooks/api/actions/useFeatureApi/useFeatureApi';
import useProject from 'hooks/api/getters/useProject/useProject';
interface IExportDialogProps {
showExportDialog: boolean;
data: Pick<FeatureSchema, 'name'>[];
onClose: () => void;
onConfirm?: () => void;
environments: string[];
projectId: string;
}
const StyledSelect = styled(GeneralSelect)(({ theme }) => ({
minWidth: '250px',
marginTop: theme.spacing(2),
}));
export const BulkEnableDialog = ({
showExportDialog,
data,
onClose,
onConfirm,
environments,
projectId,
}: IExportDialogProps) => {
const [selected, setSelected] = useState(environments[0]);
const { bulkToggleFeaturesEnvironmentOn } = useFeatureApi();
const { refetch } = useProject(projectId);
const { setToastApiError } = useToast();
const getOptions = () =>
environments.map(env => ({
key: env,
label: env,
}));
const onClick = async () => {
try {
await bulkToggleFeaturesEnvironmentOn(
projectId,
data.map(feature => feature.name),
selected
);
refetch();
onClose();
onConfirm?.();
} catch (e: unknown) {
setToastApiError(formatUnknownError(e));
}
};
return (
<Dialogue
open={showExportDialog}
title="Enable feature toggles"
onClose={onClose}
onClick={onClick}
primaryButtonText="Enable toggles"
secondaryButtonText="Cancel"
>
<Box>
You have selected <b>{data.length}</b> feature toggles to
enable.
<br />
<br />
<Typography>
Select which environment to enable the features for:
</Typography>
<StyledSelect
options={getOptions()}
value={selected}
onChange={(option: string) => setSelected(option)}
/>
</Box>
</Dialogue>
);
};