2023-05-18 12:24:31 +02:00
|
|
|
import React, { useState } from 'react';
|
|
|
|
import { Alert, Box, styled, Typography } from '@mui/material';
|
2023-05-18 08:07:56 +02:00
|
|
|
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';
|
2023-05-18 11:21:10 +02:00
|
|
|
import { useChangeRequestsEnabled } from 'hooks/useChangeRequestsEnabled';
|
|
|
|
import { useChangeRequestApi } from 'hooks/api/actions/useChangeRequestApi/useChangeRequestApi';
|
|
|
|
import { usePendingChangeRequests } from 'hooks/api/getters/usePendingChangeRequests/usePendingChangeRequests';
|
2023-05-18 12:24:31 +02:00
|
|
|
import { ConditionallyRender } from 'component/common/ConditionallyRender/ConditionallyRender';
|
2023-05-18 08:07:56 +02:00
|
|
|
|
|
|
|
interface IExportDialogProps {
|
|
|
|
showExportDialog: boolean;
|
2023-05-18 12:24:31 +02:00
|
|
|
data: Pick<FeatureSchema, 'name' | 'environments'>[];
|
2023-05-18 08:07:56 +02:00
|
|
|
onClose: () => void;
|
|
|
|
onConfirm?: () => void;
|
|
|
|
environments: string[];
|
|
|
|
projectId: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
const StyledSelect = styled(GeneralSelect)(({ theme }) => ({
|
2023-05-18 12:24:31 +02:00
|
|
|
minWidth: '450px',
|
2023-05-18 08:07:56 +02:00
|
|
|
marginTop: theme.spacing(2),
|
2023-05-18 12:24:31 +02:00
|
|
|
marginBottom: theme.spacing(1.5),
|
|
|
|
}));
|
|
|
|
|
|
|
|
const SpacedAlert = styled(Alert)(({ theme }) => ({
|
|
|
|
marginBottom: theme.spacing(1.5),
|
2023-05-18 08:07:56 +02:00
|
|
|
}));
|
|
|
|
|
|
|
|
export const BulkEnableDialog = ({
|
|
|
|
showExportDialog,
|
|
|
|
data,
|
|
|
|
onClose,
|
|
|
|
onConfirm,
|
|
|
|
environments,
|
|
|
|
projectId,
|
|
|
|
}: IExportDialogProps) => {
|
|
|
|
const [selected, setSelected] = useState(environments[0]);
|
|
|
|
const { bulkToggleFeaturesEnvironmentOn } = useFeatureApi();
|
2023-05-18 11:21:10 +02:00
|
|
|
const { addChange } = useChangeRequestApi();
|
|
|
|
const { refetch: refetchProject } = useProject(projectId);
|
|
|
|
const { setToastApiError, setToastData } = useToast();
|
|
|
|
const { isChangeRequestConfigured } = useChangeRequestsEnabled(projectId);
|
|
|
|
const { refetch: refetchChangeRequests } =
|
|
|
|
usePendingChangeRequests(projectId);
|
2023-05-18 12:24:31 +02:00
|
|
|
const alreadyEnabledCount = data.filter(
|
|
|
|
feature =>
|
|
|
|
feature.environments?.find(
|
|
|
|
environment => selected === environment.name
|
|
|
|
)?.enabled === true
|
|
|
|
).length;
|
2023-05-18 08:07:56 +02:00
|
|
|
|
|
|
|
const getOptions = () =>
|
|
|
|
environments.map(env => ({
|
|
|
|
key: env,
|
|
|
|
label: env,
|
|
|
|
}));
|
|
|
|
|
|
|
|
const onClick = async () => {
|
|
|
|
try {
|
2023-05-18 11:21:10 +02:00
|
|
|
if (isChangeRequestConfigured(selected)) {
|
|
|
|
await addChange(
|
|
|
|
projectId,
|
|
|
|
selected,
|
|
|
|
data.map(feature => ({
|
|
|
|
action: 'updateEnabled',
|
|
|
|
feature: feature.name,
|
|
|
|
payload: { enabled: true },
|
|
|
|
}))
|
|
|
|
);
|
|
|
|
refetchChangeRequests();
|
|
|
|
setToastData({
|
|
|
|
text: 'Your enable feature toggles changes have been added to change request',
|
|
|
|
type: 'success',
|
|
|
|
title: 'Changes added to a draft',
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
await bulkToggleFeaturesEnvironmentOn(
|
|
|
|
projectId,
|
|
|
|
data.map(feature => feature.name),
|
|
|
|
selected
|
|
|
|
);
|
|
|
|
refetchProject();
|
|
|
|
setToastData({
|
|
|
|
text: 'Your feature toggles have been enabled',
|
|
|
|
type: 'success',
|
|
|
|
title: 'Features enabled',
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2023-05-18 08:07:56 +02:00
|
|
|
onClose();
|
|
|
|
onConfirm?.();
|
|
|
|
} catch (e: unknown) {
|
|
|
|
setToastApiError(formatUnknownError(e));
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2023-05-18 11:21:10 +02:00
|
|
|
const buttonText = isChangeRequestConfigured(selected)
|
|
|
|
? 'Add to change request'
|
2023-05-18 14:51:49 +02:00
|
|
|
: 'Enable toggles';
|
2023-05-18 11:21:10 +02:00
|
|
|
|
2023-05-18 08:07:56 +02:00
|
|
|
return (
|
|
|
|
<Dialogue
|
|
|
|
open={showExportDialog}
|
|
|
|
title="Enable feature toggles"
|
|
|
|
onClose={onClose}
|
|
|
|
onClick={onClick}
|
2023-05-18 11:21:10 +02:00
|
|
|
primaryButtonText={buttonText}
|
2023-05-18 08:07:56 +02:00
|
|
|
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)}
|
|
|
|
/>
|
2023-05-18 12:24:31 +02:00
|
|
|
<ConditionallyRender
|
|
|
|
condition={isChangeRequestConfigured(selected)}
|
|
|
|
show={
|
|
|
|
<SpacedAlert severity="warning">
|
|
|
|
Change requests are enabled for this environment.
|
|
|
|
</SpacedAlert>
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
<ConditionallyRender
|
|
|
|
condition={alreadyEnabledCount > 0}
|
|
|
|
show={
|
|
|
|
<SpacedAlert severity="info">
|
|
|
|
{alreadyEnabledCount} feature{' '}
|
|
|
|
{alreadyEnabledCount > 1
|
|
|
|
? 'toggles are '
|
|
|
|
: 'toggle is '}
|
|
|
|
already enabled.
|
|
|
|
</SpacedAlert>
|
|
|
|
}
|
|
|
|
/>
|
2023-05-18 08:07:56 +02:00
|
|
|
</Box>
|
|
|
|
</Dialogue>
|
|
|
|
);
|
|
|
|
};
|