mirror of
https://gitlab.com/mbugroup/lti-web-client.git
synced 2026-05-24 15:25:46 +00:00
fix: get kandang options from project flock kandang instead of kandang master data
This commit is contained in:
@@ -15,7 +15,7 @@ import {
|
|||||||
InventoryAdjustmentFormSchema,
|
InventoryAdjustmentFormSchema,
|
||||||
InventoryAdjustmentFormValues,
|
InventoryAdjustmentFormValues,
|
||||||
} from '@/components/pages/inventory/adjustment/form/InventoryAdjustmentForm.schema';
|
} from '@/components/pages/inventory/adjustment/form/InventoryAdjustmentForm.schema';
|
||||||
import { KandangApi, LocationApi } from '@/services/api/master-data';
|
import { LocationApi } from '@/services/api/master-data';
|
||||||
import {
|
import {
|
||||||
ProjectFlockApi,
|
ProjectFlockApi,
|
||||||
ProjectFlockKandangApi,
|
ProjectFlockKandangApi,
|
||||||
@@ -32,8 +32,6 @@ import { useFormikErrorList } from '@/services/hooks/useFormikErrorList';
|
|||||||
import AlertErrorList from '@/components/helper/form/FormErrors';
|
import AlertErrorList from '@/components/helper/form/FormErrors';
|
||||||
import { Location } from '@/types/api/master-data/location';
|
import { Location } from '@/types/api/master-data/location';
|
||||||
import { ProjectFlock } from '@/types/api/production/project-flock';
|
import { ProjectFlock } from '@/types/api/production/project-flock';
|
||||||
import { ProjectFlockKandang } from '@/types/api/production/project-flock-kandang';
|
|
||||||
import { Kandang } from '@/types/api/master-data/kandang';
|
|
||||||
import { Product } from '@/types/api/master-data/product';
|
import { Product } from '@/types/api/master-data/product';
|
||||||
import { ProjectFlockKandangLookup } from '@/types/api/production/project-flock';
|
import { ProjectFlockKandangLookup } from '@/types/api/production/project-flock';
|
||||||
import { BaseApiResponse } from '@/types/api/api-general';
|
import { BaseApiResponse } from '@/types/api/api-general';
|
||||||
@@ -119,40 +117,19 @@ const InventoryAdjustmentForm = ({
|
|||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
const { rawData: approvedProjectFlockKandangsRawData } =
|
|
||||||
useSelect<ProjectFlockKandang>(
|
|
||||||
ProjectFlockKandangApi.basePath,
|
|
||||||
'id',
|
|
||||||
'id',
|
|
||||||
'search',
|
|
||||||
{
|
|
||||||
step_name: 'Disetujui',
|
|
||||||
limit: '100',
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
const approvedProjectFlockKandangs = useMemo(() => {
|
|
||||||
if (
|
|
||||||
approvedProjectFlockKandangsRawData &&
|
|
||||||
'data' in approvedProjectFlockKandangsRawData
|
|
||||||
) {
|
|
||||||
return approvedProjectFlockKandangsRawData.data as ProjectFlockKandang[];
|
|
||||||
}
|
|
||||||
return [];
|
|
||||||
}, [approvedProjectFlockKandangsRawData]);
|
|
||||||
|
|
||||||
const {
|
const {
|
||||||
setInputValue: setKandangInputValue,
|
options: projectFlockKandangOptions,
|
||||||
options: kandangOptionsFromApi,
|
loadMore: loadMoreProjectFlockKandangs,
|
||||||
isLoadingOptions: isLoadingKandangOptions,
|
setInputValue: setProjectFlockKandangInputValue,
|
||||||
loadMore: loadMoreKandangs,
|
isLoadingOptions: isLoadingProjectFlockKandangOptions,
|
||||||
} = useSelect<Kandang>(
|
} = useSelect(
|
||||||
selectedProjectFlock ? KandangApi.basePath : '',
|
selectedProjectFlock ? ProjectFlockKandangApi.basePath : '',
|
||||||
'id',
|
'kandang.id',
|
||||||
'name',
|
'kandang.name',
|
||||||
'search',
|
'search',
|
||||||
{
|
{
|
||||||
location_id: selectedProjectFlockLocationId,
|
step_name: 'Disetujui',
|
||||||
|
project_flock_id: String(selectedProjectFlock?.value),
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
@@ -222,26 +199,6 @@ const InventoryAdjustmentForm = ({
|
|||||||
return (product?.flags as string[]) || [];
|
return (product?.flags as string[]) || [];
|
||||||
}, [selectedProduct, productOptions]);
|
}, [selectedProduct, productOptions]);
|
||||||
|
|
||||||
const kandangOptions = useMemo(() => {
|
|
||||||
let options: OptionType[] = [];
|
|
||||||
|
|
||||||
if (selectedProjectFlock) {
|
|
||||||
const approvedKandangIds = approvedProjectFlockKandangs
|
|
||||||
.filter((pfk) => pfk.project_flock_id === selectedProjectFlock.value)
|
|
||||||
.map((pfk) => pfk.kandang_id);
|
|
||||||
|
|
||||||
options = kandangOptionsFromApi.filter((kandang) =>
|
|
||||||
approvedKandangIds.includes(kandang.value as number)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
return options;
|
|
||||||
}, [
|
|
||||||
selectedProjectFlock,
|
|
||||||
kandangOptionsFromApi,
|
|
||||||
approvedProjectFlockKandangs,
|
|
||||||
]);
|
|
||||||
|
|
||||||
const formikInitialValues = useMemo<Partial<InventoryAdjustmentFormValues>>(
|
const formikInitialValues = useMemo<Partial<InventoryAdjustmentFormValues>>(
|
||||||
() => ({
|
() => ({
|
||||||
location: null,
|
location: null,
|
||||||
@@ -693,10 +650,10 @@ const InventoryAdjustmentForm = ({
|
|||||||
label='Kandang'
|
label='Kandang'
|
||||||
value={selectedKandang}
|
value={selectedKandang}
|
||||||
onChange={kandangChangeHandler}
|
onChange={kandangChangeHandler}
|
||||||
onInputChange={setKandangInputValue}
|
onInputChange={setProjectFlockKandangInputValue}
|
||||||
options={kandangOptions}
|
options={projectFlockKandangOptions}
|
||||||
onMenuScrollToBottom={loadMoreKandangs}
|
onMenuScrollToBottom={loadMoreProjectFlockKandangs}
|
||||||
isLoading={isLoadingKandangOptions}
|
isLoading={isLoadingProjectFlockKandangOptions}
|
||||||
isError={
|
isError={
|
||||||
formik.touched.kandang_id && Boolean(formik.errors.kandang_id)
|
formik.touched.kandang_id && Boolean(formik.errors.kandang_id)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user