Portal/rsconcept/frontend/src/features/oss/dialogs/DlgChangeInputSchema.tsx

90 lines
2.9 KiB
TypeScript
Raw Normal View History

2024-07-28 21:29:46 +03:00
'use client';
2025-02-10 13:27:55 +03:00
import { zodResolver } from '@hookform/resolvers/zod';
2024-07-28 21:29:46 +03:00
import clsx from 'clsx';
2025-02-10 13:27:55 +03:00
import { Controller, useForm } from 'react-hook-form';
2024-07-28 21:29:46 +03:00
import { MiniButton } from '@/components/Control';
2024-07-28 21:29:46 +03:00
import { IconReset } from '@/components/Icons';
import { Label } from '@/components/Input';
import { ModalForm } from '@/components/Modal';
import { useLibrary } from '@/features/library/backend/useLibrary';
2025-02-10 13:27:55 +03:00
import { ILibraryItem, LibraryItemType } from '@/features/library/models/library';
import PickSchema from '@/features/rsform/components/PickSchema';
import { useDialogsStore } from '@/stores/dialogs';
2024-07-28 21:29:46 +03:00
import { IInputUpdateDTO, IOperationPosition, schemaInputUpdate } from '../backend/api';
2025-02-10 13:27:55 +03:00
import { useInputUpdate } from '../backend/useInputUpdate';
import { IOperation, IOperationSchema } from '../models/oss';
import { sortItemsForOSS } from '../models/ossAPI';
export interface DlgChangeInputSchemaProps {
2024-07-28 21:29:46 +03:00
oss: IOperationSchema;
target: IOperation;
2025-02-10 13:27:55 +03:00
positions: IOperationPosition[];
2024-07-28 21:29:46 +03:00
}
function DlgChangeInputSchema() {
2025-02-10 13:27:55 +03:00
const { oss, target, positions } = useDialogsStore(state => state.props as DlgChangeInputSchemaProps);
const { inputUpdate } = useInputUpdate();
const { setValue, handleSubmit, control } = useForm<IInputUpdateDTO>({
resolver: zodResolver(schemaInputUpdate),
2025-02-10 13:27:55 +03:00
defaultValues: {
target: target.id,
positions: positions,
input: target.result
}
});
2025-01-23 19:41:31 +03:00
const { items } = useLibrary();
const sortedItems = sortItemsForOSS(oss, items);
2024-07-28 21:29:46 +03:00
function baseFilter(item: ILibraryItem) {
2025-02-10 13:27:55 +03:00
return !oss.schemas.includes(item.id) || item.id === target.result;
}
2024-07-28 21:29:46 +03:00
2025-02-10 13:27:55 +03:00
function onSubmit(data: IInputUpdateDTO) {
inputUpdate({ itemID: oss.id, data: data });
2025-02-06 14:09:20 +03:00
}
2024-07-28 21:29:46 +03:00
return (
2025-02-06 20:27:56 +03:00
<ModalForm
2024-07-28 21:29:46 +03:00
overflowVisible
header='Выбор концептуальной схемы'
submitText='Подтвердить выбор'
2025-02-10 13:27:55 +03:00
onSubmit={event => void handleSubmit(onSubmit)(event)}
2024-07-28 21:29:46 +03:00
className={clsx('w-[35rem]', 'pb-3 px-6 cc-column')}
>
<div className='flex justify-between gap-3 items-center'>
<div className='flex gap-3'>
<Label text='Загружаемая концептуальная схема' />
<MiniButton
title='Сбросить выбор схемы'
noHover
noPadding
icon={<IconReset size='1.25rem' className='icon-primary' />}
2025-02-10 13:27:55 +03:00
onClick={() => setValue('input', null)}
2024-07-28 21:29:46 +03:00
/>
</div>
</div>
2025-02-10 13:27:55 +03:00
<Controller
name='input'
control={control}
render={({ field }) => (
<PickSchema
items={sortedItems}
itemType={LibraryItemType.RSFORM}
value={field.value}
onChange={field.onChange}
rows={14}
baseFilter={baseFilter}
/>
)}
2024-07-28 21:29:46 +03:00
/>
2025-02-06 20:27:56 +03:00
</ModalForm>
2024-07-28 21:29:46 +03:00
);
}
export default DlgChangeInputSchema;