import React, { useState, useEffect } from 'react'; import * as Yup from 'yup'; import { yupResolver } from '@hookform/resolvers/yup'; import { Controller, useForm } from 'react-hook-form'; import HookFormSelect from '@/core/components/elements/Select/HookFormSelect'; import odooApi from '~/libs/odooApi'; import stateApi from '@/lib/address/api/stateApi.js'; import cityApi from '@/lib/address/api/cityApi'; const informasiPerusahaan = ({}) => { const { register, handleSubmit, formState: { errors }, control, reset, watch, setValue, values, } = useForm({ resolver: yupResolver(validationSchema), defaultValues, }); const [industries, setIndustries] = useState([]); const [selectedCategory, setSelectedCategory] = useState(''); const [states, setState] = useState([]); const [cities, setCities] = useState([]); useEffect(() => { const loadState = async () => { let dataState = await stateApi(); dataState = dataState.map((state) => ({ value: state.id, label: state.name, })); setState(dataState); }; loadState(); }, []); const watchState = watch('state'); useEffect(() => { setValue('city', ''); if (watchState) { const loadCities = async () => { let dataCities = await cityApi({ stateId: watchState }); dataCities = dataCities.map((city) => ({ value: city.id, label: city.name, })); setCities(dataCities); }; loadCities(); } }, [watchState, setValue]); useEffect(() => { const loadIndustries = async () => { const dataIndustries = await odooApi('GET', '/api/v1/partner/industry'); setIndustries( dataIndustries?.map((o) => ({ value: o.id, label: o.name, category: o.category, })) ); }; loadIndustries(); }, []); useEffect(() => { const selectedIndustryType = industries.find( (industry) => industry.value === watch('industry_id') ); if (selectedIndustryType) { // updateForm('industry_id', `${selectedIndustryType?.value}`); setSelectedCategory(selectedIndustryType.category); } }, [watch('industry_id'), industries]); const onSubmitHandler = async (values) => { console.log('values', values); }; return ( <>

Informasi Perusahaan

isi detail perusahaan sesuai dengan nama yang terdaftar{' '}
Format: PT. INDOTEKNIK DOTCOM GEMILANG
{errors.name?.message}
isi detail perusahaan sesuai dengan nama yang terdaftar
( )} /> {selectedCategory && ( Kategori : {selectedCategory} )}
{errors.industry_id?.message}
alamat sesuai dengan alamat kantor pusat
{errors.street?.message}
( )} />
{errors.state?.message}
( )} />
{errors.city?.message}
{errors.zip?.message}
isi no telfon perusahaan yang sesuai
{errors.mobile?.message}
Isi detail data bank perusahaan anda
Format: BCA, Mandiri, CIMB, BNI dll
{errors.bankName?.message}
Format: John Doe
{errors.accountName?.message}
Format: 01234567896
{errors.accountNumber?.message}
isi no telfon perusahaan yang sesuai
); }; const validationSchema = Yup.object().shape({ // email: Yup.string() // .email('Format harus seperti contoh@email.com') // .required('Harus di-isi'), name: Yup.string().required('Harus di-isi'), industry_id: Yup.string().required('Harus di-pilih'), street: Yup.string().required('Harus di-isi'), zip: Yup.string().required('Harus di-isi'), state: Yup.string().required('Harus di-pilih'), city: Yup.string().required('Harus di-pilih'), mobile: Yup.string().required('Harus di-isi'), bankName: Yup.string().required('Harus di-isi'), accountName: Yup.string().required('Harus di-isi'), accountNumber: Yup.string().required('Harus di-isi'), }); const defaultValues = { // email: '', name: '', industry_id: '', street: '', state: '', city: '', zip: '', mobile: '', bankName: '', accountName: '', accountNumber: '', }; export default informasiPerusahaan;