Update tambah field rekanan di hospital

This commit is contained in:
2024-02-01 09:07:54 +07:00
parent 0e9694101f
commit 135c0987ab
5 changed files with 65 additions and 2 deletions

View File

@@ -53,6 +53,7 @@ class OrganizationController extends Controller
'type' => 'hospital',
'status' => $request->active == 1 ? 'active' : 'inactive',
'description' => $request->description,
'corporate_id_partner' => $request->corporate_id_partner
];
$create_organization = Organization::create($organization);

View File

@@ -31,6 +31,7 @@ class OrganizationResource extends JsonResource
'district_id' => $this->currentAddress->district_id ?? null,
'village_id' => $this->currentAddress->village_id ?? null,
'postal_code' => $this->currentAddress->postal_code ?? null,
'corporate_id_partner' => $this->corporate_id_partner ?? null,
'active' => $this->status == 'active' ? 1 : 0,
];

View File

@@ -18,6 +18,7 @@ class Organization extends Model
'description',
'part_of',
'main_address_id',
'corporate_id_partner',
];
// public $with = [

View File

@@ -21,6 +21,7 @@ export type Organizations = {
merchant_key: string;
image_url: string;
region_groups: string;
corporate_id_partner: string;
};
export type Provinces = {

View File

@@ -127,13 +127,12 @@ export default function OrganizationsForm({ isEdit, currentOrganizations }: Prop
village_id: currentOrganizations?.village_id || '',
postal_code: currentOrganizations?.postal_code || '',
description: currentOrganizations?.description || '',
corporate_id_partner: currentOrganizations?.corporate_id_partner || [],
}),
// eslint-disable-next-line react-hooks/exhaustive-deps
[currentOrganizations]
);
console.log('defaultValues', defaultValues);
function StatusLabel({ value }: { value: boolean }) {
return (
<Chip
@@ -217,6 +216,8 @@ export default function OrganizationsForm({ isEdit, currentOrganizations }: Prop
formData.append('postal_code', data.postal_code);
formData.append('description', data.description);
formData.append('corporate_id_partner', data.corporate_id_partner);
if (!isEdit) {
console.log('formData', formData);
const response = await axios.post('/organizations', formData);
@@ -256,6 +257,15 @@ export default function OrganizationsForm({ isEdit, currentOrganizations }: Prop
const [district, setDistrict] = useState<any>([]);
const [village, setVillage] = useState<any>([]);
const [corporate_id_partner, setCorporateIdPartner] = useState<any>([]);
const [selectedCorporatID, setSelectedCorporateID] = useState<any>([]);
const handleSelectChange = (event, selectedOptions:any) => {
const selectedValues = selectedOptions.map(option => option.value);
setSelectedCorporateID(selectedValues);
setValue('corporate_id_partner', selectedCorporatID)
};
useEffect(() => {
axios.get('/province').then((res) => {
setProvince(res.data.data.map((item: any) => ({ value: item.id, label: item.name })));
@@ -304,6 +314,27 @@ export default function OrganizationsForm({ isEdit, currentOrganizations }: Prop
}
}, [values.province_id, values.city_id, values.district_id, values.village_id]);
useEffect(() => {
axios.get('/corporates').then((res) => {
setCorporateIdPartner(res.data.data.map((item: any) => ({ value: item.id, label: item.name })));
});
const loadCorporateIdPartner = async () => {
if (values.corporate_id_partner == currentOrganizations?.corporate_id_partner){
const res = await axios.get('/corporates');
setCorporateIdPartner(res.data.data.map((item: any) => ({ value: item.id, label: item.name })));
}
}
if (values.corporate_id_partner) {
loadCorporateIdPartner();
}
console.log(corporate_id_partner, 'test');
}, [values.corporate_id_partner])
const findValueProvince = province.find(
(item: any) => item.value === currentOrganizations?.province_id
);
@@ -315,6 +346,10 @@ export default function OrganizationsForm({ isEdit, currentOrganizations }: Prop
(item: any) => item.value === currentOrganizations?.village_id
);
const findValueCorporate = selectedCorporatID.find(
(item: any) => item.value === currentOrganizations?.corporate_id_partner
);
return (
<FormProvider methods={methods} onSubmit={handleSubmit(onSubmit)}>
<Stack spacing={3}>
@@ -450,6 +485,8 @@ export default function OrganizationsForm({ isEdit, currentOrganizations }: Prop
)}
/>
</Grid>
<Grid item xs={12} md={4}>
<LabelStyle>Kode Pos</LabelStyle>
<RHFTextField name="postal_code" placeholder="Tuliskan Kode Pos" />
@@ -462,6 +499,28 @@ export default function OrganizationsForm({ isEdit, currentOrganizations }: Prop
<LabelStyle>Longitude</LabelStyle>
<RHFTextField name="lng" placeholder="Tuliskan Longitude" />
</Grid>
<Grid item xs={12}>
<LabelStyle>Rekanan</LabelStyle>
<Controller
name="corporate_id_partner"
control={control}
render={({ field: { onChange, value } }) => (
<Autocomplete
id="combo-box-demo"
options={corporate_id_partner}
getOptionLabel={(option) => option.label}
value={corporate_id_partner.filter(option => selectedCorporatID.includes(option.value))}
onChange={handleSelectChange}
multiple // Enable multiple selections
renderInput={(params) => (
<TextField {...params} label="Corporate" variant="outlined" fullWidth />
)}
/>
)}
/>
</Grid>
<Grid item xs={12}>
<LabelStyle>Deskripsi</LabelStyle>
<RHFEditor name="description" placeholder="Tuliskan Deskripsi" />