mirror of
https://gitlab.com/mbugroup/lti-web-client.git
synced 2026-05-24 23:35:45 +00:00
Merge branch 'codex/uniformity-week-calculation' into 'development'
codex/fix: uniformity week calculation See merge request mbugroup/lti-web-client!402
This commit is contained in:
@@ -3,7 +3,6 @@ import { Uniformity } from '@/types/api/production/uniformity';
|
|||||||
|
|
||||||
type UniformityFormSchemaType = {
|
type UniformityFormSchemaType = {
|
||||||
date: string;
|
date: string;
|
||||||
week: number;
|
|
||||||
location?: {
|
location?: {
|
||||||
value: number;
|
value: number;
|
||||||
label: string;
|
label: string;
|
||||||
@@ -45,10 +44,6 @@ const FileSchema = Yup.mixed<File>()
|
|||||||
export const UniformityFormSchema: Yup.ObjectSchema<UniformityFormSchemaType> =
|
export const UniformityFormSchema: Yup.ObjectSchema<UniformityFormSchemaType> =
|
||||||
Yup.object({
|
Yup.object({
|
||||||
date: Yup.string().required('Tanggal wajib diisi!'),
|
date: Yup.string().required('Tanggal wajib diisi!'),
|
||||||
week: Yup.number()
|
|
||||||
.min(1, 'Minggu ke wajib diisi!')
|
|
||||||
.required('Minggu ke wajib diisi!')
|
|
||||||
.typeError('Minggu ke wajib diisi!'),
|
|
||||||
location: Yup.object({
|
location: Yup.object({
|
||||||
value: Yup.number().min(1).required(),
|
value: Yup.number().min(1).required(),
|
||||||
label: Yup.string().required(),
|
label: Yup.string().required(),
|
||||||
@@ -81,7 +76,6 @@ export type UniformityFormValues = Yup.InferType<typeof UniformityFormSchema>;
|
|||||||
|
|
||||||
export type UniformityFormData = {
|
export type UniformityFormData = {
|
||||||
date: string;
|
date: string;
|
||||||
week: number;
|
|
||||||
project_flock_kandang_id: number;
|
project_flock_kandang_id: number;
|
||||||
document: File | null;
|
document: File | null;
|
||||||
document_name: string;
|
document_name: string;
|
||||||
@@ -91,8 +85,7 @@ export const getUniformityFormInitialValues = (
|
|||||||
initialValues?: Partial<Uniformity>
|
initialValues?: Partial<Uniformity>
|
||||||
): UniformityFormValues => {
|
): UniformityFormValues => {
|
||||||
return {
|
return {
|
||||||
date: initialValues?.week ? '' : '',
|
date: '',
|
||||||
week: initialValues?.week ?? 0,
|
|
||||||
location: null,
|
location: null,
|
||||||
location_id: 0,
|
location_id: 0,
|
||||||
project_flock: null,
|
project_flock: null,
|
||||||
|
|||||||
@@ -27,7 +27,6 @@ import { LocationApi } from '@/services/api/master-data';
|
|||||||
import {
|
import {
|
||||||
ProjectFlockApi,
|
ProjectFlockApi,
|
||||||
ProjectFlockKandangApi,
|
ProjectFlockKandangApi,
|
||||||
RecordingApi,
|
|
||||||
} from '@/services/api/production';
|
} from '@/services/api/production';
|
||||||
import { UniformityApi } from '@/services/api/uniformity';
|
import { UniformityApi } from '@/services/api/uniformity';
|
||||||
import { isResponseError, isResponseSuccess } from '@/lib/api-helper';
|
import { isResponseError, isResponseSuccess } from '@/lib/api-helper';
|
||||||
@@ -40,7 +39,6 @@ import {
|
|||||||
ProjectFlockKandangLookup,
|
ProjectFlockKandangLookup,
|
||||||
ProjectFlock,
|
ProjectFlock,
|
||||||
} from '@/types/api/production/project-flock';
|
} from '@/types/api/production/project-flock';
|
||||||
import { Recording } from '@/types/api/production/recording';
|
|
||||||
import { Kandang } from '@/types/api/master-data/kandang';
|
import { Kandang } from '@/types/api/master-data/kandang';
|
||||||
import UniformityPreviewForm from '@/components/pages/production/uniformity/form/UniformityPreviewForm';
|
import UniformityPreviewForm from '@/components/pages/production/uniformity/form/UniformityPreviewForm';
|
||||||
import UniformityResultForm from '@/components/pages/production/uniformity/form/UniformityResultForm';
|
import UniformityResultForm from '@/components/pages/production/uniformity/form/UniformityResultForm';
|
||||||
@@ -204,23 +202,6 @@ const UniformityForm = ({
|
|||||||
? projectFlockKandangLookupData.data
|
? projectFlockKandangLookupData.data
|
||||||
: undefined;
|
: undefined;
|
||||||
|
|
||||||
// ===== RECORDINGS DATA (FOR WEEK CALCULATION) =====
|
|
||||||
const recordingsUrl = useMemo(() => {
|
|
||||||
if (!projectFlockKandangLookup?.project_flock_kandang_id) return null;
|
|
||||||
const params = new URLSearchParams({
|
|
||||||
page: '1',
|
|
||||||
limit: '100',
|
|
||||||
project_flock_kandang_id:
|
|
||||||
projectFlockKandangLookup.project_flock_kandang_id.toString(),
|
|
||||||
});
|
|
||||||
return `${RecordingApi.basePath}?${params.toString()}`;
|
|
||||||
}, [projectFlockKandangLookup?.project_flock_kandang_id]);
|
|
||||||
|
|
||||||
const { data: recordingsData } = useSWR(
|
|
||||||
recordingsUrl,
|
|
||||||
recordingsUrl ? RecordingApi.getAllFetcher : null
|
|
||||||
);
|
|
||||||
|
|
||||||
// ===== FORM CONFIGURATION =====
|
// ===== FORM CONFIGURATION =====
|
||||||
const formikInitialValues = useMemo<UniformityFormValues>(
|
const formikInitialValues = useMemo<UniformityFormValues>(
|
||||||
() => getUniformityFormInitialValues(initialValues),
|
() => getUniformityFormInitialValues(initialValues),
|
||||||
@@ -246,7 +227,6 @@ const UniformityForm = ({
|
|||||||
|
|
||||||
setUniformityFormData({
|
setUniformityFormData({
|
||||||
date: values.date,
|
date: values.date,
|
||||||
week: values.week,
|
|
||||||
project_flock_kandang_id: projectFlockKandangId,
|
project_flock_kandang_id: projectFlockKandangId,
|
||||||
document: values.document as File,
|
document: values.document as File,
|
||||||
document_name: (values.document as File).name,
|
document_name: (values.document as File).name,
|
||||||
@@ -475,59 +455,6 @@ const UniformityForm = ({
|
|||||||
generateUniformityTemplate(population, projectFlockKandangLookup);
|
generateUniformityTemplate(population, projectFlockKandangLookup);
|
||||||
}, [projectFlockKandangLookup]);
|
}, [projectFlockKandangLookup]);
|
||||||
|
|
||||||
// ===== SIDE EFFECTS =====
|
|
||||||
useEffect(() => {
|
|
||||||
if (
|
|
||||||
projectFlockKandangLookup?.chick_in_date &&
|
|
||||||
projectFlockKandangLookup?.project_flock_kandang_id
|
|
||||||
) {
|
|
||||||
const chickInDate = new Date(projectFlockKandangLookup.chick_in_date);
|
|
||||||
chickInDate.setHours(0, 0, 0, 0);
|
|
||||||
|
|
||||||
let initialWeek = 18;
|
|
||||||
|
|
||||||
if (
|
|
||||||
isResponseSuccess(recordingsData) &&
|
|
||||||
recordingsData.data &&
|
|
||||||
recordingsData.data.length > 0
|
|
||||||
) {
|
|
||||||
const sortedRecordings = [...recordingsData.data].sort(
|
|
||||||
(a: Recording, b: Recording) =>
|
|
||||||
new Date(a.record_datetime).getTime() -
|
|
||||||
new Date(b.record_datetime).getTime()
|
|
||||||
);
|
|
||||||
|
|
||||||
const earliestRecording = sortedRecordings[0];
|
|
||||||
if (earliestRecording?.project_flock?.production_standart?.week) {
|
|
||||||
initialWeek =
|
|
||||||
earliestRecording.project_flock.production_standart.week;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (formik.values.date) {
|
|
||||||
const selectedDate = new Date(formik.values.date);
|
|
||||||
selectedDate.setHours(0, 0, 0, 0);
|
|
||||||
|
|
||||||
const daysDiff = Math.floor(
|
|
||||||
(selectedDate.getTime() - chickInDate.getTime()) /
|
|
||||||
(1000 * 60 * 60 * 24)
|
|
||||||
);
|
|
||||||
|
|
||||||
const weeksDiff = Math.floor(daysDiff / 7);
|
|
||||||
|
|
||||||
setFieldValue('week', initialWeek + weeksDiff);
|
|
||||||
} else {
|
|
||||||
setFieldValue('week', initialWeek);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, [
|
|
||||||
projectFlockKandangLookup?.chick_in_date,
|
|
||||||
projectFlockKandangLookup?.project_flock_kandang_id,
|
|
||||||
recordingsData,
|
|
||||||
formik.values.date,
|
|
||||||
setFieldValue,
|
|
||||||
]);
|
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
const unsub = subscribeValidate(() => {
|
const unsub = subscribeValidate(() => {
|
||||||
setIsValid(true);
|
setIsValid(true);
|
||||||
|
|||||||
@@ -63,7 +63,6 @@ const UniformityResultForm = () => {
|
|||||||
try {
|
try {
|
||||||
const payload = {
|
const payload = {
|
||||||
date: uniformityFormData.date,
|
date: uniformityFormData.date,
|
||||||
week: uniformityFormData.week,
|
|
||||||
project_flock_kandang_id: uniformityFormData.project_flock_kandang_id,
|
project_flock_kandang_id: uniformityFormData.project_flock_kandang_id,
|
||||||
document: uniformityFormData.document,
|
document: uniformityFormData.document,
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -56,7 +56,6 @@ export class UniformityApiService extends BaseApiService<
|
|||||||
): Promise<BaseApiResponse<UniformityDetail> | undefined> {
|
): Promise<BaseApiResponse<UniformityDetail> | undefined> {
|
||||||
const formData = new FormData();
|
const formData = new FormData();
|
||||||
formData.append('date', payload.date);
|
formData.append('date', payload.date);
|
||||||
formData.append('week', payload.week.toString());
|
|
||||||
formData.append(
|
formData.append(
|
||||||
'project_flock_kandang_id',
|
'project_flock_kandang_id',
|
||||||
payload.project_flock_kandang_id.toString()
|
payload.project_flock_kandang_id.toString()
|
||||||
|
|||||||
-1
@@ -146,7 +146,6 @@ export type CreateUniformityPayload = {
|
|||||||
date: string;
|
date: string;
|
||||||
project_flock_kandang_id: number;
|
project_flock_kandang_id: number;
|
||||||
document: File;
|
document: File;
|
||||||
week: number;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
export type VerifyUniformityPayload = {
|
export type VerifyUniformityPayload = {
|
||||||
|
|||||||
Reference in New Issue
Block a user