'use client'; import { Controller, useForm, useWatch } from 'react-hook-form'; import { zodResolver } from '@hookform/resolvers/zod'; import clsx from 'clsx'; import { Checkbox, TextArea, TextInput } from '@/components/Input'; import { ModalForm } from '@/components/Modal'; import { useDialogsStore } from '@/stores/dialogs'; import { errorMsg } from '@/utils/labels'; import { IVersionCreateDTO, IVersionInfo, schemaVersionCreate } from '../backend/types'; import { useVersionCreate } from '../backend/useVersionCreate'; import { nextVersion } from '../models/libraryAPI'; export interface DlgCreateVersionProps { itemID: number; versions: IVersionInfo[]; onCreate: (newVersion: number) => void; selected: number[]; totalCount: number; } export 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[versions.length - 1].version) : '1.0.0', description: '', items: [] } }); 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)} >