import { useApi } from '@gear-js/react-hooks'; import { Button } from '@gear-js/ui'; import { useContractApiWithFile, useLoading, useProgramActions } from '@/hooks'; import { Subheader } from '@/shared/ui/subheader'; import { GasMethod } from '@/shared/config'; import { Values } from '@/hooks/useProgramActions/types'; import { ProgramForm, SailsProgramForm } from '@/widgets/programForm'; import { useWasmFile } from '@/features/code'; import { ProgramFileInput } from '@/features/program'; import { UploadMetadata } from '@/features/uploadMetadata'; import { BackButton, Box } from '@/shared/ui'; import PlusSVG from '@/shared/assets/images/actions/plus.svg?react'; import styles from './UploadProgram.module.scss'; const UploadProgram = () => { const { api, isApiReady } = useApi(); const wasmFile = useWasmFile(); const { metadata, sails, isLoading, ...contractApi } = useContractApiWithFile(wasmFile.buffer); const uploadProgram = useProgramActions(); const [isSubmitting, enableSubmitting, disableSubmitting] = useLoading(); const handleWasmFileChange = (value: File | undefined) => { contractApi.reset(); wasmFile.handleChange(value); }; const handleSubmit = (values: Values) => { if (!isApiReady) throw new Error('API is not initialized'); if (!wasmFile.buffer) throw new Error('File is not found'); enableSubmitting(); const { gasLimit, value, payload: initPayload, payloadType, keepAlive } = values; const program = { code: wasmFile.buffer, value, gasLimit, initPayload, keepAlive }; const result = api.program.upload(program, metadata.value, payloadType); const onSuccess = () => { wasmFile.reset(); contractApi.reset(); disableSubmitting(); }; uploadProgram(result, { metadata, sails }, values, onSuccess, disableSubmitting); }; return (
{wasmFile.value && } {!wasmFile.value && ( )} {wasmFile.buffer && (
{sails.value ? ( ) : ( )}
)}
{wasmFile.buffer && (
)}
); }; export { UploadProgram };