Merge remote-tracking branch 'origin/staging' into origin/production

This commit is contained in:
Linksehat Staging Server
2024-02-01 09:52:37 +07:00
7 changed files with 86 additions and 9 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

@@ -167,7 +167,8 @@ class ReportLogController extends Controller
'Duration GL',
'Duration FGL',
'Status GL',
'Status Final GL'
'Status Final GL',
'Import By Excel'
];
// Sheet 1
$writer->getCurrentSheet()->setName('Data');
@@ -209,6 +210,15 @@ class ReportLogController extends Controller
$durationGl = 0;
}
$approveByFgl = '-';
if ($row['import_system']) {
$approveByFgl = 'Import By Excel';
} else if ($row['final_log'] == 1 && $row['status_final_log'] == 'requested'){
$approveByFgl = '-';
} else {
$approveByFgl = Helper::userName($row['approved_final_log_by']);
}
$rowData = [
$row['code'], // code
@@ -218,7 +228,7 @@ class ReportLogController extends Controller
$row['approved_by'] ? Helper::userName($row['approved_by']) : '-', // created by
$created_final_at ? $created_final_at : "-", // fgl create time
$row['approved_final_log_at'] ? $row['approved_final_log_at'] : "", // fgl submit time
$row['final_log'] == 1 ? Helper::userName($row['approved_final_log_by']) : '-', // fgl create by
$approveByFgl, // fgl create by
$serviceName, // service
$provider ? $provider->name : '-', // provider
count($documentQty), // dokument qty
@@ -226,6 +236,7 @@ class ReportLogController extends Controller
$row['final_log'] == 1 ? $durationFinalGl : '-', // duration fgl
$row['status'] ?? '-', // status gl
$row['status_final_log'] ?? '-', // status fgl
$row['import_system'] == 1 ? 'True' : 'False', // status fgl
];
$row = WriterEntityFactory::createRowFromArray($rowData);
$writer->addRow($row);

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

@@ -40,13 +40,16 @@ class ReportLogResource extends JsonResource
$created_final_at = null;
}
if ($this->approved_at){
$durationGl = Helper::differenceTime($formattedDateTime, $this->approved_at);
$durationGl = Helper::differenceTime($formattedDateTime, $this->submission_date);
$approveByFgl = '-';
if ($this->import_system) {
$approveByFgl = 'Import By Excel';
} else if ($this->final_log == 1 && $this->status_final_log == 'requested'){
$approveByFgl = '-';
} else {
$durationGl = 0;
$approveByFgl = Helper::userName($this->approved_final_log_by);
}
$data = [
'id' => $this->id,
'code' => $this->code,
@@ -55,7 +58,7 @@ class ReportLogResource extends JsonResource
'submission_date' => $this->approved_at ? $this->approved_at : null,
'approved_by' => Helper::userName($this->approved_by),
'approved_final_log_at' => $this->approved_final_log_at,
'approved_final_log_by' => $this->final_log == 1 ? Helper::userName($this->approved_final_log_by) : '-',
'approved_final_log_by' => $approveByFgl,
'service_name' => $this->service ? $this->service->name : '',
'provider' => $provider ? $provider->name : '-',
'document_qty' => count($documentQty),

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" />