2023-12-13 14:32:57 +03:00
|
|
|
|
'use client';
|
|
|
|
|
|
2023-12-18 19:42:27 +03:00
|
|
|
|
import clsx from 'clsx';
|
2023-12-07 01:21:27 +03:00
|
|
|
|
import { useMemo, useState } from 'react';
|
|
|
|
|
|
2023-12-13 14:32:57 +03:00
|
|
|
|
import Checkbox from '@/components/Common/Checkbox';
|
|
|
|
|
import Modal, { ModalProps } from '@/components/Common/Modal';
|
|
|
|
|
import { IRSForm } from '@/models/rsform';
|
2023-12-18 19:42:27 +03:00
|
|
|
|
import { classnames, prefixes } from '@/utils/constants';
|
2023-12-13 14:32:57 +03:00
|
|
|
|
|
2023-12-07 01:21:27 +03:00
|
|
|
|
import ConstituentsList from './ConstituentsList';
|
|
|
|
|
|
|
|
|
|
interface DlgDeleteCstProps
|
|
|
|
|
extends Pick<ModalProps, 'hideWindow'> {
|
|
|
|
|
selected: number[]
|
|
|
|
|
onDelete: (items: number[]) => void
|
|
|
|
|
schema: IRSForm
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function DlgDeleteCst({ hideWindow, selected, schema, onDelete }: DlgDeleteCstProps) {
|
|
|
|
|
const [expandOut, setExpandOut] = useState(false);
|
|
|
|
|
const expansion: number[] = useMemo(() => schema.graph.expandOutputs(selected), [selected, schema.graph]);
|
|
|
|
|
|
|
|
|
|
function handleSubmit() {
|
|
|
|
|
hideWindow();
|
|
|
|
|
if (expandOut) {
|
|
|
|
|
onDelete(selected.concat(expansion));
|
|
|
|
|
} else {
|
|
|
|
|
onDelete(selected);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<Modal canSubmit
|
2023-12-18 19:42:27 +03:00
|
|
|
|
header='Удаление конституент'
|
2023-12-07 01:21:27 +03:00
|
|
|
|
submitText={expandOut ? 'Удалить с зависимыми' : 'Удалить'}
|
|
|
|
|
hideWindow={hideWindow}
|
|
|
|
|
onSubmit={handleSubmit}
|
2023-12-18 19:42:27 +03:00
|
|
|
|
className={clsx(
|
|
|
|
|
'max-w-[60vw] min-w-[30rem]',
|
|
|
|
|
'px-6',
|
|
|
|
|
classnames.flex_col
|
|
|
|
|
)}
|
2023-12-07 01:21:27 +03:00
|
|
|
|
>
|
|
|
|
|
<ConstituentsList
|
|
|
|
|
title='Выбраны к удалению'
|
|
|
|
|
list={selected}
|
|
|
|
|
items={schema.items}
|
|
|
|
|
prefix={prefixes.cst_delete_list}
|
|
|
|
|
/>
|
|
|
|
|
<ConstituentsList
|
|
|
|
|
title='Зависимые конституенты'
|
|
|
|
|
list={expansion}
|
|
|
|
|
items={schema.items}
|
|
|
|
|
prefix={prefixes.cst_dependant_list}
|
|
|
|
|
/>
|
|
|
|
|
<Checkbox
|
|
|
|
|
label='Удалить зависимые конституенты'
|
|
|
|
|
value={expandOut}
|
|
|
|
|
setValue={value => setExpandOut(value)}
|
|
|
|
|
/>
|
|
|
|
|
</Modal>);
|
|
|
|
|
}
|
|
|
|
|
|
2023-12-13 14:32:57 +03:00
|
|
|
|
export default DlgDeleteCst;
|