1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-09-28 17:55:15 +02:00
unleash.unleash/frontend/src/component/segments/SegmentDelete/SegmentDelete.tsx

50 lines
1.4 KiB
TypeScript

import React from 'react';
import { ConditionallyRender } from 'component/common/ConditionallyRender/ConditionallyRender';
import { useStrategiesBySegment } from 'hooks/api/getters/useStrategiesBySegment/useStrategiesBySegment';
import { ISegment } from 'interfaces/segment';
import { SegmentDeleteConfirm } from './SegmentDeleteConfirm/SegmentDeleteConfirm';
import { SegmentDeleteUsedSegment } from './SegmentDeleteUsedSegment/SegmentDeleteUsedSegment';
interface ISegmentDeleteProps {
segment: ISegment;
open: boolean;
onClose: () => void;
onRemove: () => void;
}
export const SegmentDelete = ({
segment,
open,
onClose,
onRemove,
}: ISegmentDeleteProps) => {
const { strategies, loading } = useStrategiesBySegment(segment.id);
const canDeleteSegment = strategies?.length === 0;
if (loading) {
return null;
}
return (
<ConditionallyRender
condition={canDeleteSegment}
show={
<SegmentDeleteConfirm
segment={segment}
open={open}
onClose={onClose}
onRemove={onRemove}
/>
}
elseShow={
<SegmentDeleteUsedSegment
segment={segment}
open={open}
onClose={onClose}
strategies={strategies}
/>
}
/>
);
};