mirror of
https://github.com/Unleash/unleash.git
synced 2025-10-27 11:02:16 +01:00
Should help cleaning up some of these: 
81 lines
2.3 KiB
TypeScript
81 lines
2.3 KiB
TypeScript
import {
|
|
IChangeRequestDeleteSegment,
|
|
IChangeRequestUpdateSegment,
|
|
} from 'component/changeRequest/changeRequest.types';
|
|
import { FC } from 'react';
|
|
import EventDiff from 'component/events/EventDiff/EventDiff';
|
|
import omit from 'lodash.omit';
|
|
import { TooltipLink } from 'component/common/TooltipLink/TooltipLink';
|
|
import { styled } from '@mui/material';
|
|
import { textTruncated } from 'themes/themeStyles';
|
|
import { ISegment } from 'interfaces/segment';
|
|
import { NameWithChangeInfo } from './NameWithChangeInfo/NameWithChangeInfo';
|
|
|
|
const StyledCodeSection = styled('div')(({ theme }) => ({
|
|
overflowX: 'auto',
|
|
'& code': {
|
|
wordWrap: 'break-word',
|
|
whiteSpace: 'pre-wrap',
|
|
fontFamily: 'monospace',
|
|
lineHeight: 1.5,
|
|
fontSize: theme.fontSizes.smallBody,
|
|
},
|
|
}));
|
|
|
|
export const SegmentDiff: FC<{
|
|
change: IChangeRequestUpdateSegment | IChangeRequestDeleteSegment;
|
|
currentSegment?: ISegment;
|
|
}> = ({ change, currentSegment }) => {
|
|
const changeRequestSegment =
|
|
change.action === 'deleteSegment' ? undefined : change.payload;
|
|
|
|
return (
|
|
<StyledCodeSection>
|
|
<EventDiff
|
|
entry={{
|
|
preData: omit(currentSegment, ['createdAt', 'createdBy']),
|
|
data: changeRequestSegment,
|
|
}}
|
|
/>
|
|
</StyledCodeSection>
|
|
);
|
|
};
|
|
interface IStrategyTooltipLinkProps {
|
|
change: IChangeRequestUpdateSegment | IChangeRequestDeleteSegment;
|
|
}
|
|
|
|
const StyledContainer: FC = styled('div')(({ theme }) => ({
|
|
display: 'grid',
|
|
gridAutoFlow: 'column',
|
|
gridTemplateColumns: 'auto 1fr',
|
|
gap: theme.spacing(1),
|
|
alignItems: 'center',
|
|
}));
|
|
|
|
const Truncated = styled('div')(() => ({
|
|
...textTruncated,
|
|
maxWidth: 500,
|
|
}));
|
|
|
|
export const SegmentTooltipLink: FC<IStrategyTooltipLinkProps> = ({
|
|
change,
|
|
children,
|
|
}) => (
|
|
<StyledContainer>
|
|
<Truncated>
|
|
<TooltipLink
|
|
tooltip={children}
|
|
tooltipProps={{
|
|
maxWidth: 500,
|
|
maxHeight: 600,
|
|
}}
|
|
>
|
|
<NameWithChangeInfo
|
|
previousName={change.name}
|
|
newName={change.payload.name}
|
|
/>
|
|
</TooltipLink>
|
|
</Truncated>
|
|
</StyledContainer>
|
|
);
|