add services for edit and delete out guilds

This commit is contained in:
2026-01-20 12:38:07 +03:30
parent e03e4bd0cc
commit 4e0c45e595
5 changed files with 289 additions and 84 deletions

View File

@@ -76,9 +76,12 @@ export const SlaughterSellCarcassOutProvinceAddBuyer = ({
city: Yup.string()
.required("این فیلد اجباری است!")
.typeError("لطفا فیلد را به درستی وارد کنید!"),
nationalId: Yup.string()
.required("این فیلد اجباری است!")
.matches(/^\d{10,11}$/, "شناسه باید 10 یا 11 رقم و فقط عدد باشد"),
nationalId:
defaultPersonType === "legal" && isEdit
? Yup.string().nullable()
: Yup.string()
.required("این فیلد اجباری است!")
.matches(/^\d{10,11}$/, "شناسه باید 10 یا 11 رقم و فقط عدد باشد"),
}),
validateOnMount: true,
});
@@ -90,21 +93,27 @@ export const SlaughterSellCarcassOutProvinceAddBuyer = ({
},
validationSchema: Yup.object({
personType: Yup.string().oneOf(["real", "legal"]).required(),
nationalCode: Yup.string()
.required("این فیلد اجباری است!")
.when("personType", {
is: "real",
then: (schema) =>
schema
.length(10, "کد ملی باید 10 رقم باشد")
.matches(/^\d{10}$/, "کد ملی باید فقط شامل اعداد باشد"),
otherwise: (schema) =>
schema
.length(11, "شناسه ملی حقوقی باید 11 رقم باشد")
.matches(/^\d{11}$/, "شناسه ملی حقوقی باید فقط شامل اعداد باشد"),
}),
nationalCode:
isEdit && defaultPersonType === "real"
? Yup.string().nullable()
: Yup.string()
.required("این فیلد اجباری است!")
.when("personType", {
is: "real",
then: (schema) =>
schema
.length(10, "کد ملی باید 10 رقم باشد")
.matches(/^\d{10}$/, "کد ملی باید فقط شامل اعداد باشد"),
otherwise: (schema) =>
schema
.length(11, "شناسه ملی حقوقی باید 11 رقم باشد")
.matches(
/^\d{11}$/,
"شناسه ملی حقوقی باید فقط شامل اعداد باشد"
),
}),
}),
validateOnMount: true,
validateOnMount: isEdit ? false : true,
});
useEffect(() => {
@@ -404,74 +413,86 @@ export const SlaughterSellCarcassOutProvinceAddBuyer = ({
direction="column"
gap={2}
>
<Grid container xs={12}>
<LabelField label="نوع شخص">
<RadioGroup
row
name="personType"
value={formik2.values.personType}
onChange={(e) => {
const value = e.target.value;
formik2.setFieldValue("personType", value);
// reset previous results when toggling type
setUserData(null);
setNotFound(false);
setLockedFields({});
formik.resetForm({
values: {
mobile: "",
firstName: "",
lastName: "",
unitName: "",
province: "",
city: "",
nationalId: "",
},
});
}}
>
<FormControlLabel value="real" control={<Radio />} label="حقیقی" />
<FormControlLabel value="legal" control={<Radio />} label="حقوقی" />
</RadioGroup>
</LabelField>
<Typography mt={2}>
{"استعلام "}
{formik2.values.personType === "legal" ? "شناسه ملی حقوقی" : "کد ملی"}
</Typography>
<Grid mt={SPACING.SMALL} display="flex" width={1}>
<TextField
fullWidth
id="nationalCode"
name="nationalCode"
label={
formik2.values.personType === "legal"
? "شناسه ملی حقوقی"
: "کد ملی"
}
variant="outlined"
value={formik2.values.nationalCode}
error={Boolean(
formik2.touched.nationalCode && formik2.errors.nationalCode
)}
onChange={formik2.handleChange}
onBlur={formik2.handleBlur}
helperText={
formik2.touched.nationalCode && formik2.errors.nationalCode
}
inputProps={{
maxLength: formik2.values.personType === "legal" ? 11 : 10,
}}
/>
<IconButton
disabled={!formik2.isValid || inquiryInProgress}
aria-label="search"
color="primary"
onClick={handleNationalInquiry}
>
<SearchIcon />
</IconButton>
{!isEdit && (
<Grid container xs={12}>
<LabelField label="نوع شخص">
<RadioGroup
row
name="personType"
value={formik2.values.personType}
onChange={(e) => {
const value = e.target.value;
formik2.setFieldValue("personType", value);
// reset previous results when toggling type
setUserData(null);
setNotFound(false);
setLockedFields({});
formik.resetForm({
values: {
mobile: "",
firstName: "",
lastName: "",
unitName: "",
province: "",
city: "",
nationalId: "",
},
});
}}
>
<FormControlLabel
value="real"
control={<Radio />}
label="حقیقی"
/>
<FormControlLabel
value="legal"
control={<Radio />}
label="حقوقی"
/>
</RadioGroup>
</LabelField>
<Typography mt={2}>
{"استعلام "}
{formik2.values.personType === "legal"
? "شناسه ملی حقوقی"
: "کد ملی"}
</Typography>
<Grid mt={SPACING.SMALL} display="flex" width={1}>
<TextField
fullWidth
id="nationalCode"
name="nationalCode"
label={
formik2.values.personType === "legal"
? "شناسه ملی حقوقی"
: "کد ملی"
}
variant="outlined"
value={formik2.values.nationalCode}
error={Boolean(
formik2.touched.nationalCode && formik2.errors.nationalCode
)}
onChange={formik2.handleChange}
onBlur={formik2.handleBlur}
helperText={
formik2.touched.nationalCode && formik2.errors.nationalCode
}
inputProps={{
maxLength: formik2.values.personType === "legal" ? 11 : 10,
}}
/>
<IconButton
disabled={!formik2.isValid || inquiryInProgress}
aria-label="search"
color="primary"
onClick={handleNationalInquiry}
>
<SearchIcon />
</IconButton>
</Grid>
</Grid>
</Grid>
)}
{userData || notFound || isEdit ? (
<Grid