2022-10-31 13:46:54 +01:00
|
|
|
import { useCallback, VFC } from 'react';
|
2022-10-26 13:57:59 +02:00
|
|
|
import { Box } from '@mui/material';
|
|
|
|
import { SuggestedFeatureToggleChange } from '../SuggestedChangeOverview/SuggestedFeatureToggleChange/SuggestedFeatureToggleChange';
|
|
|
|
import { objectId } from 'utils/objectId';
|
|
|
|
import { ConditionallyRender } from 'component/common/ConditionallyRender/ConditionallyRender';
|
|
|
|
import { ToggleStatusChange } from '../SuggestedChangeOverview/SuggestedFeatureToggleChange/ToggleStatusChange';
|
2022-10-28 09:43:49 +02:00
|
|
|
// import {
|
|
|
|
// StrategyAddedChange,
|
|
|
|
// StrategyDeletedChange,
|
|
|
|
// StrategyEditedChange,
|
|
|
|
// } from '../SuggestedChangeOverview/SuggestedFeatureToggleChange/StrategyChange';
|
|
|
|
// import {
|
|
|
|
// formatStrategyName,
|
|
|
|
// GetFeatureStrategyIcon,
|
|
|
|
// } from 'utils/strategyNames';
|
|
|
|
import type { ISuggestChangesResponse } from 'hooks/api/getters/useSuggestedChangesDraft/useSuggestedChangesDraft';
|
2022-10-31 13:46:54 +01:00
|
|
|
import { useSuggestChangeApi } from 'hooks/api/actions/useSuggestChangeApi/useSuggestChangeApi';
|
|
|
|
import { formatUnknownError } from 'utils/formatUnknownError';
|
|
|
|
import useToast from 'hooks/useToast';
|
2022-10-26 13:57:59 +02:00
|
|
|
|
2022-10-31 13:46:54 +01:00
|
|
|
interface ISuggestedChangeset {
|
2022-10-28 09:43:49 +02:00
|
|
|
suggestedChange: ISuggestChangesResponse;
|
2022-10-31 13:46:54 +01:00
|
|
|
onRefetch?: () => void;
|
|
|
|
onNavigate?: () => void;
|
|
|
|
}
|
|
|
|
|
|
|
|
export const SuggestedChangeset: VFC<ISuggestedChangeset> = ({
|
|
|
|
suggestedChange,
|
|
|
|
onRefetch,
|
|
|
|
onNavigate,
|
|
|
|
}) => {
|
|
|
|
const { discardSuggestions } = useSuggestChangeApi();
|
|
|
|
const { setToastData, setToastApiError } = useToast();
|
|
|
|
const onDiscard = (id: number) => async () => {
|
|
|
|
try {
|
|
|
|
await discardSuggestions(
|
|
|
|
suggestedChange.project,
|
|
|
|
suggestedChange.id,
|
|
|
|
id
|
|
|
|
);
|
|
|
|
setToastData({
|
|
|
|
title: 'Change discarded from suggestion draft.',
|
|
|
|
type: 'success',
|
|
|
|
});
|
|
|
|
onRefetch?.();
|
|
|
|
} catch (error: unknown) {
|
|
|
|
setToastApiError(formatUnknownError(error));
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2022-10-26 13:57:59 +02:00
|
|
|
return (
|
|
|
|
<Box>
|
|
|
|
Changes
|
2022-10-28 09:43:49 +02:00
|
|
|
{suggestedChange.features?.map(featureToggleChange => (
|
2022-10-26 13:57:59 +02:00
|
|
|
<SuggestedFeatureToggleChange
|
2022-10-28 09:43:49 +02:00
|
|
|
key={featureToggleChange.name}
|
2022-10-31 13:46:54 +01:00
|
|
|
featureName={featureToggleChange.name}
|
|
|
|
projectId={suggestedChange.project}
|
|
|
|
onNavigate={onNavigate}
|
2022-10-26 13:57:59 +02:00
|
|
|
>
|
2022-10-28 09:43:49 +02:00
|
|
|
{featureToggleChange.changes.map(change => (
|
2022-10-26 13:57:59 +02:00
|
|
|
<Box key={objectId(change)}>
|
|
|
|
<ConditionallyRender
|
|
|
|
condition={change.action === 'updateEnabled'}
|
|
|
|
show={
|
|
|
|
<ToggleStatusChange
|
2022-10-28 09:43:49 +02:00
|
|
|
enabled={change?.payload?.enabled}
|
2022-10-31 13:46:54 +01:00
|
|
|
onDiscard={onDiscard(change.id)}
|
2022-10-26 13:57:59 +02:00
|
|
|
/>
|
|
|
|
}
|
|
|
|
/>
|
2022-10-28 09:43:49 +02:00
|
|
|
{/* <ConditionallyRender
|
2022-10-26 13:57:59 +02:00
|
|
|
condition={change.action === 'addStrategy'}
|
|
|
|
show={
|
|
|
|
<StrategyAddedChange>
|
|
|
|
<GetFeatureStrategyIcon
|
|
|
|
strategyName={change.payload.name}
|
|
|
|
/>
|
|
|
|
{formatStrategyName(
|
|
|
|
change.payload.name
|
|
|
|
)}
|
|
|
|
</StrategyAddedChange>
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
<ConditionallyRender
|
|
|
|
condition={change.action === 'deleteStrategy'}
|
|
|
|
show={<StrategyDeletedChange />}
|
|
|
|
/>
|
|
|
|
<ConditionallyRender
|
|
|
|
condition={change.action === 'updateStrategy'}
|
|
|
|
show={<StrategyEditedChange />}
|
2022-10-28 09:43:49 +02:00
|
|
|
/> */}
|
2022-10-26 13:57:59 +02:00
|
|
|
</Box>
|
|
|
|
))}
|
|
|
|
</SuggestedFeatureToggleChange>
|
|
|
|
))}
|
|
|
|
</Box>
|
|
|
|
);
|
|
|
|
};
|