'use client'; import { zodResolver } from '@hookform/resolvers/zod'; import clsx from 'clsx'; import { Controller, useForm, useWatch } from 'react-hook-form'; import { Checkbox, TextArea, TextInput } from '@/components/Input'; import { ModalForm } from '@/components/Modal'; import { IVersionCreateDTO, schemaVersionCreate } from '@/features/library/backend/api'; import { useVersionCreate } from '@/features/library/backend/useVersionCreate'; import { IVersionInfo, LibraryItemID, VersionID } from '@/features/library/models/library'; import { nextVersion } from '@/features/library/models/libraryAPI'; import { useDialogsStore } from '@/stores/dialogs'; import { errorMsg } from '@/utils/labels'; import { ConstituentaID } from '../models/rsform'; export interface DlgCreateVersionProps { itemID: LibraryItemID; versions: IVersionInfo[]; onCreate: (newVersion: VersionID) => void; selected: ConstituentaID[]; totalCount: number; } function DlgCreateVersion() { const { itemID, // versions, selected, totalCount, onCreate } = useDialogsStore(state => state.props as DlgCreateVersionProps); const { versionCreate } = useVersionCreate(); const { register, handleSubmit, control } = useForm({ resolver: zodResolver(schemaVersionCreate), defaultValues: { version: versions.length > 0 ? nextVersion(versions[0].version) : '1.0.0', description: '', items: undefined } }); const version = useWatch({ control, name: 'version' }); const canSubmit = !versions.find(ver => ver.version === version); function onSubmit(data: IVersionCreateDTO) { return versionCreate({ itemID, data }).then(onCreate); } return ( void handleSubmit(onSubmit)(event)} >