mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-06 00:07:44 +01:00
96 lines
3.7 KiB
TypeScript
96 lines
3.7 KiB
TypeScript
import React, { VFC } from 'react';
|
|
import { Box, Typography } from '@mui/material';
|
|
import type { IChangeRequest } from '../changeRequest.types';
|
|
import { FeatureToggleChanges } from './Changes/FeatureToggleChanges';
|
|
import { FeatureChange } from './Changes/Change/FeatureChange';
|
|
import { ChangeActions } from './Changes/Change/ChangeActions';
|
|
import { ConditionallyRender } from 'component/common/ConditionallyRender/ConditionallyRender';
|
|
import { SegmentChange } from './Changes/Change/SegmentChange';
|
|
|
|
interface IChangeRequestProps {
|
|
changeRequest: IChangeRequest;
|
|
onRefetch?: () => void;
|
|
onNavigate?: () => void;
|
|
}
|
|
|
|
export const ChangeRequest: VFC<IChangeRequestProps> = ({
|
|
changeRequest,
|
|
onRefetch,
|
|
onNavigate,
|
|
}) => {
|
|
return (
|
|
<Box>
|
|
<ConditionallyRender
|
|
condition={changeRequest.segments.length > 0}
|
|
show={
|
|
<Typography variant="body2" color="text.secondary">
|
|
You request changes for these segments:
|
|
</Typography>
|
|
}
|
|
/>
|
|
|
|
{changeRequest.segments?.map(segment => (
|
|
<SegmentChange
|
|
key={segment.payload.id}
|
|
segmentChange={segment}
|
|
onNavigate={onNavigate}
|
|
/>
|
|
))}
|
|
<ConditionallyRender
|
|
condition={changeRequest.features.length > 0}
|
|
show={
|
|
<Typography variant="body2" color="text.secondary">
|
|
You request changes for these feature toggles:
|
|
</Typography>
|
|
}
|
|
/>
|
|
{changeRequest.features?.map(feature => (
|
|
<FeatureToggleChanges
|
|
key={feature.name}
|
|
featureName={feature.name}
|
|
projectId={changeRequest.project}
|
|
onNavigate={onNavigate}
|
|
conflict={feature.conflict}
|
|
>
|
|
{feature.changes.map((change, index) => (
|
|
<FeatureChange
|
|
key={index}
|
|
discard={
|
|
<ChangeActions
|
|
changeRequest={changeRequest}
|
|
feature={feature.name}
|
|
change={change}
|
|
onRefetch={onRefetch}
|
|
/>
|
|
}
|
|
index={index}
|
|
changeRequest={changeRequest}
|
|
change={change}
|
|
feature={feature}
|
|
/>
|
|
))}
|
|
{feature.defaultChange ? (
|
|
<FeatureChange
|
|
discard={
|
|
<Typography
|
|
variant="body2"
|
|
color="text.secondary"
|
|
>
|
|
{feature.defaultChange.action ===
|
|
'addStrategy'
|
|
? 'Default strategy will be added'
|
|
: 'Feature status will change'}
|
|
</Typography>
|
|
}
|
|
index={feature.changes.length}
|
|
changeRequest={changeRequest}
|
|
change={feature.defaultChange}
|
|
feature={feature}
|
|
/>
|
|
) : null}
|
|
</FeatureToggleChanges>
|
|
))}
|
|
</Box>
|
|
);
|
|
};
|