summaryrefslogtreecommitdiff
path: root/src/lib/auth/components/CompanyProfile.jsx
blob: ff6739538eb54e63b8f1fa81e62936c14aa7329c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
import odooApi from '@/core/api/odooApi'
import HookFormSelect from '@/core/components/elements/Select/HookFormSelect'
import useAuth from '@/core/hooks/useAuth'
import addressApi from '@/lib/address/api/addressApi'
import { ChevronDownIcon, ChevronUpIcon } from '@heroicons/react/24/outline'
import { useEffect, useState } from 'react'
import { Controller, useForm } from 'react-hook-form'
import { toast } from 'react-hot-toast'

const CompanyProfile = () => {
  const auth = useAuth()
  const [isOpen, setIsOpen] = useState(false)
  const toggle = () => setIsOpen(!isOpen)
  const { register, setValue, control, handleSubmit } = useForm({
    defaultValues: {
      industry: '',
      companyType: '',
      name: '',
      taxName: '',
      npwp: ''
    }
  })

  const [industries, setIndustries] = useState([])
  useEffect(() => {
    const loadIndustries = async () => {
      const dataIndustries = await odooApi('GET', '/api/v1/partner/industry')
      setIndustries(dataIndustries?.map((o) => ({ value: o.id, label: o.name })))
    }
    loadIndustries()
  }, [])

  const [companyTypes, setCompanyTypes] = useState([])
  useEffect(() => {
    const loadCompanyTypes = async () => {
      const dataCompanyTypes = await odooApi('GET', '/api/v1/partner/company_type')
      setCompanyTypes(dataCompanyTypes?.map((o) => ({ value: o.id, label: o.name })))
    }
    loadCompanyTypes()
  }, [])

  useEffect(() => {
    const loadProfile = async () => {
      const dataProfile = await addressApi({ id: auth.parentId })
      setValue('name', dataProfile.name)
      setValue('industry', dataProfile.industryId)
      setValue('companyType', dataProfile.companyTypeId)
      setValue('taxName', dataProfile.taxName)
      setValue('npwp', dataProfile.npwp)
    }
    if (auth) loadProfile()
  }, [auth, setValue])

  const onSubmitHandler = async (values) => {
    const data = {
      ...values,
      company_type_id: values.companyType,
      industry_id: values.industry,
      tax_name: values.taxName
    }
    const isUpdated = await odooApi('PUT', `/api/v1/partner/${auth.parentId}`, data)
    if (isUpdated?.id) {
      toast.success('Berhasil mengubah profil', { duration: 1500 })
      return
    }
    toast.error('Terjadi kesalahan internal')
  }

  return (
    <>
      <button type='button' onClick={toggle} className='p-4 flex items-center text-left w-full'>
        <div>
          <div className='font-semibold mb-2'>Informasi Usaha</div>
          <div className='text-gray_r-11'>
            Dibawah ini adalah data usaha yang anda masukkan, periksa kembali data usaha anda.
          </div>
        </div>
        <div className='ml-auto p-2 bg-gray_r-3 rounded'>
          {!isOpen && <ChevronDownIcon className='w-6' />}
          {isOpen && <ChevronUpIcon className='w-6' />}
        </div>
      </button>

      {isOpen && (
        <form className='p-4 border-t border-gray_r-6' onSubmit={handleSubmit(onSubmitHandler)}>
          <div className='grid grid-cols-1 sm:grid-cols-2 gap-4'>
            <div>
              <label className='block mb-3'>Klasifikasi Jenis Usaha</label>
              <Controller
                name='industry'
                control={control}
                render={(props) => <HookFormSelect {...props} options={industries} />}
              />
            </div>
            <div className='flex flex-wrap'>
              <div className='w-full mb-3'>Nama Usaha</div>
              <div className='w-3/12 pr-1'>
                <Controller
                  name='companyType'
                  control={control}
                  render={(props) => <HookFormSelect {...props} options={companyTypes} />}
                />
              </div>
              <div className='w-9/12 pl-1'>
                <input
                  {...register('name')}
                  type='text'
                  className='form-input'
                  placeholder='Cth: Indoteknik Dotcom Gemilang'
                />
              </div>
            </div>
            <div>
              <label>Nama Wajib Pajak</label>
              <input {...register('taxName')} type='text' className='form-input mt-3' />
            </div>
            <div>
              <label>Nomor NPWP</label>
              <input {...register('npwp')} type='text' className='form-input mt-3' />
            </div>
          </div>
          <button type='submit' className='btn-yellow w-full mt-6'>
            Simpan
          </button>
        </form>
      )}
    </>
  )
}

export default CompanyProfile