2025-09-23 22:36:40 +07:00
|
|
|
import './styles.scss';
|
|
|
|
|
|
2025-10-04 23:09:18 +07:00
|
|
|
import { Button, Popover } from 'antd';
|
2025-09-23 22:36:40 +07:00
|
|
|
import { ChevronDown, ChevronUp } from 'lucide-react';
|
|
|
|
|
import { useState } from 'react';
|
|
|
|
|
|
|
|
|
|
import { useCreateAlertState } from '../context';
|
|
|
|
|
import EvaluationWindowPopover from './EvaluationWindowPopover';
|
|
|
|
|
import { getEvaluationWindowTypeText, getTimeframeText } from './utils';
|
|
|
|
|
|
|
|
|
|
function EvaluationSettings(): JSX.Element {
|
2025-10-04 23:09:18 +07:00
|
|
|
const { evaluationWindow, setEvaluationWindow } = useCreateAlertState();
|
2025-09-23 22:36:40 +07:00
|
|
|
const [
|
|
|
|
|
isEvaluationWindowPopoverOpen,
|
|
|
|
|
setIsEvaluationWindowPopoverOpen,
|
|
|
|
|
] = useState(false);
|
|
|
|
|
|
|
|
|
|
const popoverContent = (
|
|
|
|
|
<Popover
|
|
|
|
|
open={isEvaluationWindowPopoverOpen}
|
|
|
|
|
onOpenChange={(visibility: boolean): void => {
|
|
|
|
|
setIsEvaluationWindowPopoverOpen(visibility);
|
|
|
|
|
}}
|
|
|
|
|
content={
|
|
|
|
|
<EvaluationWindowPopover
|
|
|
|
|
evaluationWindow={evaluationWindow}
|
|
|
|
|
setEvaluationWindow={setEvaluationWindow}
|
|
|
|
|
/>
|
|
|
|
|
}
|
|
|
|
|
trigger="click"
|
|
|
|
|
showArrow={false}
|
|
|
|
|
>
|
|
|
|
|
<Button>
|
|
|
|
|
<div className="evaluate-alert-conditions-button-left">
|
|
|
|
|
{getTimeframeText(evaluationWindow)}
|
|
|
|
|
</div>
|
|
|
|
|
<div className="evaluate-alert-conditions-button-right">
|
|
|
|
|
<div className="evaluate-alert-conditions-button-right-text">
|
|
|
|
|
{getEvaluationWindowTypeText(evaluationWindow.windowType)}
|
|
|
|
|
</div>
|
|
|
|
|
{isEvaluationWindowPopoverOpen ? (
|
|
|
|
|
<ChevronUp size={16} />
|
|
|
|
|
) : (
|
|
|
|
|
<ChevronDown size={16} />
|
|
|
|
|
)}
|
|
|
|
|
</div>
|
|
|
|
|
</Button>
|
|
|
|
|
</Popover>
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
return (
|
2025-10-04 23:09:18 +07:00
|
|
|
<div
|
|
|
|
|
className="condensed-evaluation-settings-container"
|
|
|
|
|
data-testid="condensed-evaluation-settings-container"
|
|
|
|
|
>
|
|
|
|
|
{popoverContent}
|
2025-09-23 22:36:40 +07:00
|
|
|
</div>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export default EvaluationSettings;
|