@redneckz/wildless-cms-uni-blocks 0.14.821 → 0.14.822
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundle/bundle.umd.js +54 -15
- package/bundle/bundle.umd.min.js +1 -1
- package/bundle/retail/validator/getLimitedBirthdayValidation.d.ts +2 -0
- package/bundle/retail/validator/validators.d.ts +6 -1
- package/dist/components/ApplicationLeadForm/ApplicationLeadForm.js +9 -2
- package/dist/components/ApplicationLeadForm/ApplicationLeadForm.js.map +1 -1
- package/dist/components/CreditCardForm/CreditCardFormStep.js +7 -1
- package/dist/components/CreditCardForm/CreditCardFormStep.js.map +1 -1
- package/dist/components/CreditForm/CreditFormStep.js +7 -1
- package/dist/components/CreditForm/CreditFormStep.js.map +1 -1
- package/dist/components/DebitForm/DebitFormStep.js +7 -1
- package/dist/components/DebitForm/DebitFormStep.js.map +1 -1
- package/dist/retail/validator/getLimitedBirthdayValidation.d.ts +2 -0
- package/dist/retail/validator/getLimitedBirthdayValidation.js +21 -0
- package/dist/retail/validator/getLimitedBirthdayValidation.js.map +1 -0
- package/dist/retail/validator/validatorObj.js +0 -1
- package/dist/retail/validator/validatorObj.js.map +1 -1
- package/dist/retail/validator/validators.d.ts +6 -1
- package/dist/retail/validator/validators.js +10 -8
- package/dist/retail/validator/validators.js.map +1 -1
- package/lib/components/ApplicationLeadForm/ApplicationLeadForm.js +9 -2
- package/lib/components/ApplicationLeadForm/ApplicationLeadForm.js.map +1 -1
- package/lib/components/CreditCardForm/CreditCardFormStep.js +7 -1
- package/lib/components/CreditCardForm/CreditCardFormStep.js.map +1 -1
- package/lib/components/CreditForm/CreditFormStep.js +7 -1
- package/lib/components/CreditForm/CreditFormStep.js.map +1 -1
- package/lib/components/DebitForm/DebitFormStep.js +7 -1
- package/lib/components/DebitForm/DebitFormStep.js.map +1 -1
- package/lib/retail/validator/getLimitedBirthdayValidation.d.ts +2 -0
- package/lib/retail/validator/getLimitedBirthdayValidation.js +18 -0
- package/lib/retail/validator/getLimitedBirthdayValidation.js.map +1 -0
- package/lib/retail/validator/validatorObj.js +1 -2
- package/lib/retail/validator/validatorObj.js.map +1 -1
- package/lib/retail/validator/validators.d.ts +6 -1
- package/lib/retail/validator/validators.js +10 -8
- package/lib/retail/validator/validators.js.map +1 -1
- package/mobile/bundle/bundle.umd.js +48 -14
- package/mobile/bundle/bundle.umd.min.js +1 -1
- package/mobile/bundle/retail/validator/getLimitedBirthdayValidation.d.ts +2 -0
- package/mobile/bundle/retail/validator/validators.d.ts +6 -1
- package/mobile/dist/components/ApplicationLeadForm/ApplicationLeadForm.js +9 -2
- package/mobile/dist/components/ApplicationLeadForm/ApplicationLeadForm.js.map +1 -1
- package/mobile/dist/components/CreditCardForm/CreditCardFormStep.js +7 -1
- package/mobile/dist/components/CreditCardForm/CreditCardFormStep.js.map +1 -1
- package/mobile/dist/components/CreditForm/CreditFormStep.js +7 -1
- package/mobile/dist/components/CreditForm/CreditFormStep.js.map +1 -1
- package/mobile/dist/components/DebitForm/DebitFormStep.js +7 -1
- package/mobile/dist/components/DebitForm/DebitFormStep.js.map +1 -1
- package/mobile/dist/retail/validator/getLimitedBirthdayValidation.d.ts +2 -0
- package/mobile/dist/retail/validator/getLimitedBirthdayValidation.js +21 -0
- package/mobile/dist/retail/validator/getLimitedBirthdayValidation.js.map +1 -0
- package/mobile/dist/retail/validator/validatorObj.js +0 -1
- package/mobile/dist/retail/validator/validatorObj.js.map +1 -1
- package/mobile/dist/retail/validator/validators.d.ts +6 -1
- package/mobile/dist/retail/validator/validators.js +10 -8
- package/mobile/dist/retail/validator/validators.js.map +1 -1
- package/mobile/lib/components/ApplicationLeadForm/ApplicationLeadForm.js +9 -2
- package/mobile/lib/components/ApplicationLeadForm/ApplicationLeadForm.js.map +1 -1
- package/mobile/lib/components/CreditCardForm/CreditCardFormStep.js +7 -1
- package/mobile/lib/components/CreditCardForm/CreditCardFormStep.js.map +1 -1
- package/mobile/lib/components/CreditForm/CreditFormStep.js +7 -1
- package/mobile/lib/components/CreditForm/CreditFormStep.js.map +1 -1
- package/mobile/lib/components/DebitForm/DebitFormStep.js +7 -1
- package/mobile/lib/components/DebitForm/DebitFormStep.js.map +1 -1
- package/mobile/lib/retail/validator/getLimitedBirthdayValidation.d.ts +2 -0
- package/mobile/lib/retail/validator/getLimitedBirthdayValidation.js +18 -0
- package/mobile/lib/retail/validator/getLimitedBirthdayValidation.js.map +1 -0
- package/mobile/lib/retail/validator/validatorObj.js +1 -2
- package/mobile/lib/retail/validator/validatorObj.js.map +1 -1
- package/mobile/lib/retail/validator/validators.d.ts +6 -1
- package/mobile/lib/retail/validator/validators.js +10 -8
- package/mobile/lib/retail/validator/validators.js.map +1 -1
- package/mobile/src/components/ApplicationLeadForm/ApplicationLeadForm.tsx +17 -6
- package/mobile/src/components/CreditCardForm/CreditCardFormStep.tsx +9 -1
- package/mobile/src/components/CreditForm/CreditFormStep.tsx +10 -1
- package/mobile/src/components/DebitForm/DebitFormStep.tsx +9 -1
- package/mobile/src/retail/validator/getLimitedBirthdayValidation.ts +21 -0
- package/mobile/src/retail/validator/validatorObj.ts +0 -2
- package/mobile/src/retail/validator/validators.ts +24 -13
- package/package.json +1 -1
- package/src/components/ApplicationLeadForm/ApplicationLeadForm.tsx +17 -6
- package/src/components/CreditCardForm/CreditCardFormStep.tsx +9 -1
- package/src/components/CreditForm/CreditFormStep.tsx +10 -1
- package/src/components/DebitForm/DebitFormStep.tsx +9 -1
- package/src/retail/validator/getLimitedBirthdayValidation.ts +21 -0
- package/src/retail/validator/validatorObj.ts +0 -2
- package/src/retail/validator/validators.ts +24 -13
|
@@ -2,25 +2,27 @@ import { isCyrillic } from '../../utils/isCyrilic.js';
|
|
|
2
2
|
import { validator } from '../../validation/validator.js';
|
|
3
3
|
const ERROR_MESSAGE = 'Некорректно заполненное поле';
|
|
4
4
|
const ADDRESS_ERROR_MESSAGE = 'Укажите регион, город/населенный пункт, улицу, дом';
|
|
5
|
-
const MIN_AGE = 23;
|
|
6
|
-
const MAX_AGE = 75;
|
|
7
|
-
const AGE_ERROR_MESSAGE = 'Допустимый возраст заёмщика - от 23 до 75 лет';
|
|
8
5
|
const addressDaDataValidate = (address) => Boolean(address.region && (address.city || address.locality) && address.house);
|
|
9
6
|
export const addressDaDataValidator = () => validator(addressDaDataValidate)(ADDRESS_ERROR_MESSAGE);
|
|
10
7
|
export const addressOrganizationValidator = () => validator((address) => Boolean(address.fiasCode && (address.city || address.locality) && address.house))(ADDRESS_ERROR_MESSAGE);
|
|
11
8
|
export const codeWordValidator = (errorMsg) => validator((_) => typeof _ === 'string' && _.length >= 3 && _.length <= 21 && isCyrillic(_))(errorMsg ?? ERROR_MESSAGE);
|
|
12
9
|
export const jobNumberValidator = (errorMsg) => validator((_) => typeof _ === 'string' && /^[0-9]{1,2}$/g.test(_))(errorMsg ?? ERROR_MESSAGE);
|
|
13
10
|
export const lengthStringValidator = (inputLength, errorMsg) => validator((_) => typeof _ === 'string' && _.length >= 1 && _.length <= inputLength)(errorMsg ?? ERROR_MESSAGE);
|
|
14
|
-
const limitedBirthdayValidate = (date) => {
|
|
11
|
+
const limitedBirthdayValidate = ({ minAge, maxAge }) => (date) => {
|
|
15
12
|
const today = new Date();
|
|
16
|
-
const minDate = new Date(today.getFullYear() -
|
|
17
|
-
const maxDate =
|
|
18
|
-
|
|
13
|
+
const minDate = new Date(today.getFullYear() - minAge, today.getMonth(), today.getDate());
|
|
14
|
+
const maxDate = maxAge
|
|
15
|
+
? new Date(today.getFullYear() - maxAge, today.getMonth(), today.getDate())
|
|
16
|
+
: null;
|
|
17
|
+
if (!date || date > minDate) {
|
|
18
|
+
return false;
|
|
19
|
+
}
|
|
20
|
+
if (maxDate && date < maxDate) {
|
|
19
21
|
return false;
|
|
20
22
|
}
|
|
21
23
|
return true;
|
|
22
24
|
};
|
|
23
|
-
export const limitedBirthdayValidator = () => validator(limitedBirthdayValidate)(
|
|
25
|
+
export const limitedBirthdayValidator = (params) => validator(limitedBirthdayValidate(params))(params.errorMessage);
|
|
24
26
|
export const numberValidator = (errorMsg) => validator((_) => typeof _ === 'string' && _.length === 6)(errorMsg);
|
|
25
27
|
export const serieValidator = (errorMsg) => validator((_) => typeof _ === 'string' && _.length === 4)(errorMsg);
|
|
26
28
|
const snilsValidate = (snils) => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"validators.js","sourceRoot":"","sources":["../../../src/retail/validator/validators.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;AAGvD,MAAM,aAAa,GAAG,8BAA8B,CAAC;AAErD,MAAM,qBAAqB,GAAG,oDAAoD,CAAC;
|
|
1
|
+
{"version":3,"file":"validators.js","sourceRoot":"","sources":["../../../src/retail/validator/validators.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;AAGvD,MAAM,aAAa,GAAG,8BAA8B,CAAC;AAErD,MAAM,qBAAqB,GAAG,oDAAoD,CAAC;AAQnF,MAAM,qBAAqB,GAAG,CAAC,OAAgB,EAAE,EAAE,CACjD,OAAO,CAAC,OAAO,CAAC,MAAM,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,QAAQ,CAAC,IAAI,OAAO,CAAC,KAAK,CAAC,CAAC;AAEjF,MAAM,CAAC,MAAM,sBAAsB,GAAG,GAAG,EAAE,CAAC,SAAS,CAAC,qBAAqB,CAAC,CAAC,qBAAqB,CAAC,CAAC;AAEpG,MAAM,CAAC,MAAM,4BAA4B,GAAG,GAAG,EAAE,CAC/C,SAAS,CAAC,CAAC,OAAgB,EAAE,EAAE,CAC7B,OAAO,CAAC,OAAO,CAAC,QAAQ,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,QAAQ,CAAC,IAAI,OAAO,CAAC,KAAK,CAAC,CACjF,CAAC,qBAAqB,CAAC,CAAC;AAE3B,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,QAAiB,EAAE,EAAE,CACrD,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,QAAQ,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,IAAI,EAAE,IAAI,UAAU,CAAC,CAAC,CAAC,CAAC,CACzF,QAAQ,IAAI,aAAa,CAC1B,CAAC;AAEJ,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,QAAiB,EAAE,EAAE,CACtD,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,QAAQ,IAAI,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,IAAI,aAAa,CAAC,CAAC;AAEhG,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,WAAmB,EAAE,QAAiB,EAAE,EAAE,CAC9E,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,QAAQ,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,IAAI,WAAW,CAAC,CACjF,QAAQ,IAAI,aAAa,CAC1B,CAAC;AAEJ,MAAM,uBAAuB,GAC3B,CAAC,EAAE,MAAM,EAAE,MAAM,EAAmC,EAAE,EAAE,CACxD,CAAC,IAAW,EAAE,EAAE;IACd,MAAM,KAAK,GAAG,IAAI,IAAI,EAAE,CAAC;IAEzB,MAAM,OAAO,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,GAAG,MAAM,EAAE,KAAK,CAAC,QAAQ,EAAE,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;IAC1F,MAAM,OAAO,GAAG,MAAM;QACpB,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,GAAG,MAAM,EAAE,KAAK,CAAC,QAAQ,EAAE,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC;QAC3E,CAAC,CAAC,IAAI,CAAC;IAET,IAAI,CAAC,IAAI,IAAI,IAAI,GAAG,OAAO,EAAE;QAC3B,OAAO,KAAK,CAAC;KACd;IAED,IAAI,OAAO,IAAI,IAAI,GAAG,OAAO,EAAE;QAC7B,OAAO,KAAK,CAAC;KACd;IAED,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAEJ,MAAM,CAAC,MAAM,wBAAwB,GAAG,CAAC,MAAuC,EAAE,EAAE,CAClF,SAAS,CAAC,uBAAuB,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;AAElE,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,QAAgB,EAAE,EAAE,CAClD,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,QAAQ,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;AAEtE,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,QAAgB,EAAE,EAAE,CACjD,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,QAAQ,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;AAEtE,MAAM,aAAa,GAAG,CAAC,KAAa,EAAE,EAAE;IACtC,MAAM,GAAG,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;IAClD,IAAI,GAAG,CAAC,MAAM,KAAK,EAAE,EAAE;QACrB,IAAI,QAAQ,GAAG,CAAC,CAAC;QACjB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;YAC1B,QAAQ,IAAI,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;SAC/C;QACD,IAAI,QAAQ,GAAG,GAAG,EAAE;YAClB,QAAQ,GAAG,QAAQ,GAAG,GAAG,CAAC;SAC3B;QACD,IAAI,QAAQ,KAAK,GAAG,IAAI,QAAQ,KAAK,GAAG,EAAE;YACxC,QAAQ,GAAG,CAAC,CAAC;SACd;QAED,OAAO,QAAQ,KAAK,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;KAC5C;IAED,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,QAAgB,EAAE,EAAE,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,QAAQ,CAAC,CAAC"}
|
|
@@ -2,7 +2,9 @@ import { JSX } from '@redneckz/uni-jsx';
|
|
|
2
2
|
import { useEffect, useMemo } from '@redneckz/uni-jsx/lib/hooks';
|
|
3
3
|
import { useBool } from '@redneckz/uni-jsx/lib/hooks/useBool';
|
|
4
4
|
import { useForm } from '../../hooks/useForm/useForm';
|
|
5
|
+
import { type SectionsRetailProps } from '../../retail/model/InputSectionsType';
|
|
5
6
|
import { type FieldRetailDef } from '../../retail/model/RetailFormContent';
|
|
7
|
+
import { getLimitedBirthdayValidation } from '../../retail/validator/getLimitedBirthdayValidation';
|
|
6
8
|
import { validatorObj } from '../../retail/validator/validatorObj';
|
|
7
9
|
import { ApplicationFormLayout } from '../../ui-kit/ApplicationFormLayout/ApplicationFormLayout';
|
|
8
10
|
import { useDialog } from '../../ui-kit/DialogManager/useDialog';
|
|
@@ -15,7 +17,7 @@ import { Text } from '../../ui-kit/Text/Text';
|
|
|
15
17
|
import { type UniBlockProps } from '../../UniBlock/UniBlockProps';
|
|
16
18
|
import { style } from '../../utils/style';
|
|
17
19
|
import { getApplicationFormData } from './applicationFormData';
|
|
18
|
-
import { type ApplicationLeadFormContent } from './ApplicationLeadFormContent';
|
|
20
|
+
import { type ApplicationLeadFormContent, type ProductType } from './ApplicationLeadFormContent';
|
|
19
21
|
import { renderInputs } from './renderInputs';
|
|
20
22
|
import { renderSubmitButton } from './renderSubmitButton';
|
|
21
23
|
import { useApplicationLeadApi } from './useApplicationLeadApi';
|
|
@@ -36,12 +38,13 @@ export const ApplicationLeadForm = JSX<ApplicationLeadFormProps>(
|
|
|
36
38
|
}) => {
|
|
37
39
|
const [esiaError, { setTrue: setEsiaError }] = useBool(false);
|
|
38
40
|
const applicationFormData = useMemo(() => getApplicationFormData(productType), [productType]);
|
|
39
|
-
const inputs = useMemo(
|
|
40
|
-
() => (applicationFormData?.flatMap((_) => _?.inputs) || []) as FieldRetailDef[],
|
|
41
|
-
[applicationFormData],
|
|
42
|
-
);
|
|
41
|
+
const inputs = useMemo(() => getInputs(applicationFormData), [applicationFormData]);
|
|
43
42
|
|
|
44
|
-
const
|
|
43
|
+
const extendedValidatorObj = useMemo(() => getExtendedValidatorObj(productType), [productType]);
|
|
44
|
+
const formValidator = useMemo(
|
|
45
|
+
() => getFormValidator(inputs, extendedValidatorObj),
|
|
46
|
+
[inputs, extendedValidatorObj],
|
|
47
|
+
);
|
|
45
48
|
|
|
46
49
|
const [initialFormState, { isLoading }] = useInitApplicationLead({
|
|
47
50
|
inputs,
|
|
@@ -98,3 +101,11 @@ export const ApplicationLeadForm = JSX<ApplicationLeadFormProps>(
|
|
|
98
101
|
);
|
|
99
102
|
},
|
|
100
103
|
);
|
|
104
|
+
|
|
105
|
+
const getInputs = (applicationFormData?: SectionsRetailProps[]) =>
|
|
106
|
+
(applicationFormData?.flatMap((_) => _?.inputs) || []) as FieldRetailDef[];
|
|
107
|
+
|
|
108
|
+
const getExtendedValidatorObj = (productType: ProductType) => ({
|
|
109
|
+
...validatorObj,
|
|
110
|
+
limitedBirthday: getLimitedBirthdayValidation(productType),
|
|
111
|
+
});
|
|
@@ -5,6 +5,7 @@ import { type SectionsRetailProps } from '../../retail/model/InputSectionsType';
|
|
|
5
5
|
import { type LeadFormState } from '../../retail/model/LeadFormState';
|
|
6
6
|
import { calculateInputs } from '../../retail/utils/calculateInputs';
|
|
7
7
|
import { renderStep } from '../../retail/utils/renderStep';
|
|
8
|
+
import { getLimitedBirthdayValidation } from '../../retail/validator/getLimitedBirthdayValidation';
|
|
8
9
|
import { validatorObj } from '../../retail/validator/validatorObj';
|
|
9
10
|
import { getFormValidator } from '../../ui-kit/FormField/getObjectValidator';
|
|
10
11
|
import { StepsNavigationButtons } from './StepsNavigationButtons';
|
|
@@ -18,6 +19,13 @@ export interface CreditCardFormStepProps {
|
|
|
18
19
|
onFinish?: () => void;
|
|
19
20
|
}
|
|
20
21
|
|
|
22
|
+
const PRODUCT_TYPE = 'creditCard';
|
|
23
|
+
|
|
24
|
+
const extendedValidatorObj = {
|
|
25
|
+
...validatorObj,
|
|
26
|
+
limitedBirthday: getLimitedBirthdayValidation(PRODUCT_TYPE),
|
|
27
|
+
};
|
|
28
|
+
|
|
21
29
|
export const CreditCardFormStep = JSX<CreditCardFormStepProps>(
|
|
22
30
|
({ step, sections, onPrevStep, onNextStep, onFinish }) => {
|
|
23
31
|
const inputs = useMemo(
|
|
@@ -30,7 +38,7 @@ export const CreditCardFormStep = JSX<CreditCardFormStepProps>(
|
|
|
30
38
|
// TODO Слишком сложно
|
|
31
39
|
getFormValidator(
|
|
32
40
|
calculateInputs((_) => formState[_])(inputs, step),
|
|
33
|
-
|
|
41
|
+
extendedValidatorObj,
|
|
34
42
|
)(formState),
|
|
35
43
|
[inputs],
|
|
36
44
|
);
|
|
@@ -6,6 +6,7 @@ import { type SectionsRetailProps } from '../../retail/model/InputSectionsType';
|
|
|
6
6
|
import { type LeadFormState } from '../../retail/model/LeadFormState';
|
|
7
7
|
import { calculateInputs } from '../../retail/utils/calculateInputs';
|
|
8
8
|
import { renderStep } from '../../retail/utils/renderStep';
|
|
9
|
+
import { getLimitedBirthdayValidation } from '../../retail/validator/getLimitedBirthdayValidation';
|
|
9
10
|
import { validatorObj } from '../../retail/validator/validatorObj';
|
|
10
11
|
import { getFormValidator } from '../../ui-kit/FormField/getObjectValidator';
|
|
11
12
|
import { type ProgramsSourceProps } from './ProgramsSourceProps';
|
|
@@ -21,6 +22,13 @@ export interface CreditFormStepProps {
|
|
|
21
22
|
onFinish?: () => void;
|
|
22
23
|
}
|
|
23
24
|
|
|
25
|
+
const PRODUCT_TYPE = 'credit';
|
|
26
|
+
|
|
27
|
+
const extendedValidatorObj = {
|
|
28
|
+
...validatorObj,
|
|
29
|
+
limitedBirthday: getLimitedBirthdayValidation(PRODUCT_TYPE),
|
|
30
|
+
};
|
|
31
|
+
|
|
24
32
|
export const CreditFormStep = JSX<CreditFormStepProps>(
|
|
25
33
|
({ step, sections, programsSource, onPrevStep, onNextStep, onFinish }) => {
|
|
26
34
|
const { programId } = useRetailFormStore();
|
|
@@ -30,12 +38,13 @@ export const CreditFormStep = JSX<CreditFormStepProps>(
|
|
|
30
38
|
() => sections?.flatMap((_: SectionsRetailProps) => _?.inputs ?? []),
|
|
31
39
|
[sections],
|
|
32
40
|
);
|
|
41
|
+
|
|
33
42
|
const formValidator = useCallback(
|
|
34
43
|
(formState: LeadFormState) =>
|
|
35
44
|
// TODO Слишком сложно
|
|
36
45
|
getFormValidator(
|
|
37
46
|
calculateInputs((_) => formState[_])(inputs, step),
|
|
38
|
-
|
|
47
|
+
extendedValidatorObj,
|
|
39
48
|
)(formState),
|
|
40
49
|
[inputs],
|
|
41
50
|
);
|
|
@@ -5,6 +5,7 @@ import { type SectionsRetailProps } from '../../retail/model/InputSectionsType';
|
|
|
5
5
|
import type { LeadFormState } from '../../retail/model/LeadFormState';
|
|
6
6
|
import { calculateInputs } from '../../retail/utils/calculateInputs';
|
|
7
7
|
import { renderStep } from '../../retail/utils/renderStep';
|
|
8
|
+
import { getLimitedBirthdayValidation } from '../../retail/validator/getLimitedBirthdayValidation';
|
|
8
9
|
import { validatorObj } from '../../retail/validator/validatorObj';
|
|
9
10
|
import { getFormValidator } from '../../ui-kit/FormField/getObjectValidator';
|
|
10
11
|
import { StepsNavigationButtons } from './StepsNavigationButtons';
|
|
@@ -18,6 +19,13 @@ export interface DebitFormStepProps {
|
|
|
18
19
|
onFinish?: () => void;
|
|
19
20
|
}
|
|
20
21
|
|
|
22
|
+
const PRODUCT_TYPE = 'debitCard';
|
|
23
|
+
|
|
24
|
+
const extendedValidatorObj = {
|
|
25
|
+
...validatorObj,
|
|
26
|
+
limitedBirthday: getLimitedBirthdayValidation(PRODUCT_TYPE),
|
|
27
|
+
};
|
|
28
|
+
|
|
21
29
|
export const DebitFormStep = JSX<DebitFormStepProps>(
|
|
22
30
|
({ step, sections, onPrevStep, onNextStep, onFinish }) => {
|
|
23
31
|
const inputs = useMemo(
|
|
@@ -30,7 +38,7 @@ export const DebitFormStep = JSX<DebitFormStepProps>(
|
|
|
30
38
|
// TODO Слишком сложно
|
|
31
39
|
getFormValidator(
|
|
32
40
|
calculateInputs((_) => formState[_])(inputs, step),
|
|
33
|
-
|
|
41
|
+
extendedValidatorObj,
|
|
34
42
|
)(formState),
|
|
35
43
|
[inputs],
|
|
36
44
|
);
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { type ProductType } from '../../components/ApplicationLeadForm/ApplicationLeadFormContent';
|
|
2
|
+
import { limitedBirthdayValidator, type LimitedBirthdayValidationParams } from './validators';
|
|
3
|
+
|
|
4
|
+
const limitedBirthdayValidationData: Record<ProductType, LimitedBirthdayValidationParams> = {
|
|
5
|
+
credit: {
|
|
6
|
+
minAge: 23,
|
|
7
|
+
maxAge: 75,
|
|
8
|
+
errorMessage: 'Допустимый возраст заёмщика - от 23 до 75 лет',
|
|
9
|
+
},
|
|
10
|
+
creditCard: {
|
|
11
|
+
minAge: 21,
|
|
12
|
+
errorMessage: 'Допустимый возраст заёмщика - от 21 года',
|
|
13
|
+
},
|
|
14
|
+
debitCard: {
|
|
15
|
+
minAge: 18,
|
|
16
|
+
errorMessage: 'Допустимый возраст - от 18 лет',
|
|
17
|
+
},
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
export const getLimitedBirthdayValidation = (productType: ProductType) =>
|
|
21
|
+
limitedBirthdayValidator(limitedBirthdayValidationData[productType]);
|
|
@@ -11,7 +11,6 @@ import {
|
|
|
11
11
|
codeWordValidator,
|
|
12
12
|
jobNumberValidator,
|
|
13
13
|
lengthStringValidator,
|
|
14
|
-
limitedBirthdayValidator,
|
|
15
14
|
numberValidator,
|
|
16
15
|
serieValidator,
|
|
17
16
|
snilsValidator,
|
|
@@ -53,7 +52,6 @@ const validatorRetailObj: Record<string, Validator> = {
|
|
|
53
52
|
addressRetail: defaultSelectValidator('Выберите адрес банка'),
|
|
54
53
|
addressMatch: defaultValidator(),
|
|
55
54
|
sex: defaultValidator('Укажите свой пол'),
|
|
56
|
-
limitedBirthday: limitedBirthdayValidator(),
|
|
57
55
|
birthPlace: defaultValidator('Укажите место рождения'),
|
|
58
56
|
education: defaultSelectValidator('Выберите ваше образование'),
|
|
59
57
|
housing: defaultSelectValidator('Выберите тип жилья'),
|
|
@@ -6,9 +6,11 @@ const ERROR_MESSAGE = 'Некорректно заполненное поле';
|
|
|
6
6
|
|
|
7
7
|
const ADDRESS_ERROR_MESSAGE = 'Укажите регион, город/населенный пункт, улицу, дом';
|
|
8
8
|
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
9
|
+
export interface LimitedBirthdayValidationParams {
|
|
10
|
+
minAge: number;
|
|
11
|
+
maxAge?: number;
|
|
12
|
+
errorMessage: string;
|
|
13
|
+
}
|
|
12
14
|
|
|
13
15
|
const addressDaDataValidate = (address: Address) =>
|
|
14
16
|
Boolean(address.region && (address.city || address.locality) && address.house);
|
|
@@ -33,20 +35,29 @@ export const lengthStringValidator = (inputLength: number, errorMsg?: string) =>
|
|
|
33
35
|
errorMsg ?? ERROR_MESSAGE,
|
|
34
36
|
);
|
|
35
37
|
|
|
36
|
-
const limitedBirthdayValidate =
|
|
37
|
-
|
|
38
|
+
const limitedBirthdayValidate =
|
|
39
|
+
({ minAge, maxAge }: LimitedBirthdayValidationParams) =>
|
|
40
|
+
(date?: Date) => {
|
|
41
|
+
const today = new Date();
|
|
38
42
|
|
|
39
|
-
|
|
40
|
-
|
|
43
|
+
const minDate = new Date(today.getFullYear() - minAge, today.getMonth(), today.getDate());
|
|
44
|
+
const maxDate = maxAge
|
|
45
|
+
? new Date(today.getFullYear() - maxAge, today.getMonth(), today.getDate())
|
|
46
|
+
: null;
|
|
41
47
|
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
48
|
+
if (!date || date > minDate) {
|
|
49
|
+
return false;
|
|
50
|
+
}
|
|
45
51
|
|
|
46
|
-
|
|
47
|
-
|
|
52
|
+
if (maxDate && date < maxDate) {
|
|
53
|
+
return false;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
return true;
|
|
57
|
+
};
|
|
48
58
|
|
|
49
|
-
export const limitedBirthdayValidator = () =>
|
|
59
|
+
export const limitedBirthdayValidator = (params: LimitedBirthdayValidationParams) =>
|
|
60
|
+
validator(limitedBirthdayValidate(params))(params.errorMessage);
|
|
50
61
|
|
|
51
62
|
export const numberValidator = (errorMsg: string) =>
|
|
52
63
|
validator((_) => typeof _ === 'string' && _.length === 6)(errorMsg);
|
package/package.json
CHANGED
|
@@ -2,7 +2,9 @@ import { JSX } from '@redneckz/uni-jsx';
|
|
|
2
2
|
import { useEffect, useMemo } from '@redneckz/uni-jsx/lib/hooks';
|
|
3
3
|
import { useBool } from '@redneckz/uni-jsx/lib/hooks/useBool';
|
|
4
4
|
import { useForm } from '../../hooks/useForm/useForm';
|
|
5
|
+
import { type SectionsRetailProps } from '../../retail/model/InputSectionsType';
|
|
5
6
|
import { type FieldRetailDef } from '../../retail/model/RetailFormContent';
|
|
7
|
+
import { getLimitedBirthdayValidation } from '../../retail/validator/getLimitedBirthdayValidation';
|
|
6
8
|
import { validatorObj } from '../../retail/validator/validatorObj';
|
|
7
9
|
import { ApplicationFormLayout } from '../../ui-kit/ApplicationFormLayout/ApplicationFormLayout';
|
|
8
10
|
import { useDialog } from '../../ui-kit/DialogManager/useDialog';
|
|
@@ -15,7 +17,7 @@ import { Text } from '../../ui-kit/Text/Text';
|
|
|
15
17
|
import { type UniBlockProps } from '../../UniBlock/UniBlockProps';
|
|
16
18
|
import { style } from '../../utils/style';
|
|
17
19
|
import { getApplicationFormData } from './applicationFormData';
|
|
18
|
-
import { type ApplicationLeadFormContent } from './ApplicationLeadFormContent';
|
|
20
|
+
import { type ApplicationLeadFormContent, type ProductType } from './ApplicationLeadFormContent';
|
|
19
21
|
import { renderInputs } from './renderInputs';
|
|
20
22
|
import { renderSubmitButton } from './renderSubmitButton';
|
|
21
23
|
import { useApplicationLeadApi } from './useApplicationLeadApi';
|
|
@@ -36,12 +38,13 @@ export const ApplicationLeadForm = JSX<ApplicationLeadFormProps>(
|
|
|
36
38
|
}) => {
|
|
37
39
|
const [esiaError, { setTrue: setEsiaError }] = useBool(false);
|
|
38
40
|
const applicationFormData = useMemo(() => getApplicationFormData(productType), [productType]);
|
|
39
|
-
const inputs = useMemo(
|
|
40
|
-
() => (applicationFormData?.flatMap((_) => _?.inputs) || []) as FieldRetailDef[],
|
|
41
|
-
[applicationFormData],
|
|
42
|
-
);
|
|
41
|
+
const inputs = useMemo(() => getInputs(applicationFormData), [applicationFormData]);
|
|
43
42
|
|
|
44
|
-
const
|
|
43
|
+
const extendedValidatorObj = useMemo(() => getExtendedValidatorObj(productType), [productType]);
|
|
44
|
+
const formValidator = useMemo(
|
|
45
|
+
() => getFormValidator(inputs, extendedValidatorObj),
|
|
46
|
+
[inputs, extendedValidatorObj],
|
|
47
|
+
);
|
|
45
48
|
|
|
46
49
|
const [initialFormState, { isLoading }] = useInitApplicationLead({
|
|
47
50
|
inputs,
|
|
@@ -98,3 +101,11 @@ export const ApplicationLeadForm = JSX<ApplicationLeadFormProps>(
|
|
|
98
101
|
);
|
|
99
102
|
},
|
|
100
103
|
);
|
|
104
|
+
|
|
105
|
+
const getInputs = (applicationFormData?: SectionsRetailProps[]) =>
|
|
106
|
+
(applicationFormData?.flatMap((_) => _?.inputs) || []) as FieldRetailDef[];
|
|
107
|
+
|
|
108
|
+
const getExtendedValidatorObj = (productType: ProductType) => ({
|
|
109
|
+
...validatorObj,
|
|
110
|
+
limitedBirthday: getLimitedBirthdayValidation(productType),
|
|
111
|
+
});
|
|
@@ -5,6 +5,7 @@ import { type SectionsRetailProps } from '../../retail/model/InputSectionsType';
|
|
|
5
5
|
import { type LeadFormState } from '../../retail/model/LeadFormState';
|
|
6
6
|
import { calculateInputs } from '../../retail/utils/calculateInputs';
|
|
7
7
|
import { renderStep } from '../../retail/utils/renderStep';
|
|
8
|
+
import { getLimitedBirthdayValidation } from '../../retail/validator/getLimitedBirthdayValidation';
|
|
8
9
|
import { validatorObj } from '../../retail/validator/validatorObj';
|
|
9
10
|
import { getFormValidator } from '../../ui-kit/FormField/getObjectValidator';
|
|
10
11
|
import { StepsNavigationButtons } from './StepsNavigationButtons';
|
|
@@ -18,6 +19,13 @@ export interface CreditCardFormStepProps {
|
|
|
18
19
|
onFinish?: () => void;
|
|
19
20
|
}
|
|
20
21
|
|
|
22
|
+
const PRODUCT_TYPE = 'creditCard';
|
|
23
|
+
|
|
24
|
+
const extendedValidatorObj = {
|
|
25
|
+
...validatorObj,
|
|
26
|
+
limitedBirthday: getLimitedBirthdayValidation(PRODUCT_TYPE),
|
|
27
|
+
};
|
|
28
|
+
|
|
21
29
|
export const CreditCardFormStep = JSX<CreditCardFormStepProps>(
|
|
22
30
|
({ step, sections, onPrevStep, onNextStep, onFinish }) => {
|
|
23
31
|
const inputs = useMemo(
|
|
@@ -30,7 +38,7 @@ export const CreditCardFormStep = JSX<CreditCardFormStepProps>(
|
|
|
30
38
|
// TODO Слишком сложно
|
|
31
39
|
getFormValidator(
|
|
32
40
|
calculateInputs((_) => formState[_])(inputs, step),
|
|
33
|
-
|
|
41
|
+
extendedValidatorObj,
|
|
34
42
|
)(formState),
|
|
35
43
|
[inputs],
|
|
36
44
|
);
|
|
@@ -6,6 +6,7 @@ import { type SectionsRetailProps } from '../../retail/model/InputSectionsType';
|
|
|
6
6
|
import { type LeadFormState } from '../../retail/model/LeadFormState';
|
|
7
7
|
import { calculateInputs } from '../../retail/utils/calculateInputs';
|
|
8
8
|
import { renderStep } from '../../retail/utils/renderStep';
|
|
9
|
+
import { getLimitedBirthdayValidation } from '../../retail/validator/getLimitedBirthdayValidation';
|
|
9
10
|
import { validatorObj } from '../../retail/validator/validatorObj';
|
|
10
11
|
import { getFormValidator } from '../../ui-kit/FormField/getObjectValidator';
|
|
11
12
|
import { type ProgramsSourceProps } from './ProgramsSourceProps';
|
|
@@ -21,6 +22,13 @@ export interface CreditFormStepProps {
|
|
|
21
22
|
onFinish?: () => void;
|
|
22
23
|
}
|
|
23
24
|
|
|
25
|
+
const PRODUCT_TYPE = 'credit';
|
|
26
|
+
|
|
27
|
+
const extendedValidatorObj = {
|
|
28
|
+
...validatorObj,
|
|
29
|
+
limitedBirthday: getLimitedBirthdayValidation(PRODUCT_TYPE),
|
|
30
|
+
};
|
|
31
|
+
|
|
24
32
|
export const CreditFormStep = JSX<CreditFormStepProps>(
|
|
25
33
|
({ step, sections, programsSource, onPrevStep, onNextStep, onFinish }) => {
|
|
26
34
|
const { programId } = useRetailFormStore();
|
|
@@ -30,12 +38,13 @@ export const CreditFormStep = JSX<CreditFormStepProps>(
|
|
|
30
38
|
() => sections?.flatMap((_: SectionsRetailProps) => _?.inputs ?? []),
|
|
31
39
|
[sections],
|
|
32
40
|
);
|
|
41
|
+
|
|
33
42
|
const formValidator = useCallback(
|
|
34
43
|
(formState: LeadFormState) =>
|
|
35
44
|
// TODO Слишком сложно
|
|
36
45
|
getFormValidator(
|
|
37
46
|
calculateInputs((_) => formState[_])(inputs, step),
|
|
38
|
-
|
|
47
|
+
extendedValidatorObj,
|
|
39
48
|
)(formState),
|
|
40
49
|
[inputs],
|
|
41
50
|
);
|
|
@@ -5,6 +5,7 @@ import { type SectionsRetailProps } from '../../retail/model/InputSectionsType';
|
|
|
5
5
|
import type { LeadFormState } from '../../retail/model/LeadFormState';
|
|
6
6
|
import { calculateInputs } from '../../retail/utils/calculateInputs';
|
|
7
7
|
import { renderStep } from '../../retail/utils/renderStep';
|
|
8
|
+
import { getLimitedBirthdayValidation } from '../../retail/validator/getLimitedBirthdayValidation';
|
|
8
9
|
import { validatorObj } from '../../retail/validator/validatorObj';
|
|
9
10
|
import { getFormValidator } from '../../ui-kit/FormField/getObjectValidator';
|
|
10
11
|
import { StepsNavigationButtons } from './StepsNavigationButtons';
|
|
@@ -18,6 +19,13 @@ export interface DebitFormStepProps {
|
|
|
18
19
|
onFinish?: () => void;
|
|
19
20
|
}
|
|
20
21
|
|
|
22
|
+
const PRODUCT_TYPE = 'debitCard';
|
|
23
|
+
|
|
24
|
+
const extendedValidatorObj = {
|
|
25
|
+
...validatorObj,
|
|
26
|
+
limitedBirthday: getLimitedBirthdayValidation(PRODUCT_TYPE),
|
|
27
|
+
};
|
|
28
|
+
|
|
21
29
|
export const DebitFormStep = JSX<DebitFormStepProps>(
|
|
22
30
|
({ step, sections, onPrevStep, onNextStep, onFinish }) => {
|
|
23
31
|
const inputs = useMemo(
|
|
@@ -30,7 +38,7 @@ export const DebitFormStep = JSX<DebitFormStepProps>(
|
|
|
30
38
|
// TODO Слишком сложно
|
|
31
39
|
getFormValidator(
|
|
32
40
|
calculateInputs((_) => formState[_])(inputs, step),
|
|
33
|
-
|
|
41
|
+
extendedValidatorObj,
|
|
34
42
|
)(formState),
|
|
35
43
|
[inputs],
|
|
36
44
|
);
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { type ProductType } from '../../components/ApplicationLeadForm/ApplicationLeadFormContent';
|
|
2
|
+
import { limitedBirthdayValidator, type LimitedBirthdayValidationParams } from './validators';
|
|
3
|
+
|
|
4
|
+
const limitedBirthdayValidationData: Record<ProductType, LimitedBirthdayValidationParams> = {
|
|
5
|
+
credit: {
|
|
6
|
+
minAge: 23,
|
|
7
|
+
maxAge: 75,
|
|
8
|
+
errorMessage: 'Допустимый возраст заёмщика - от 23 до 75 лет',
|
|
9
|
+
},
|
|
10
|
+
creditCard: {
|
|
11
|
+
minAge: 21,
|
|
12
|
+
errorMessage: 'Допустимый возраст заёмщика - от 21 года',
|
|
13
|
+
},
|
|
14
|
+
debitCard: {
|
|
15
|
+
minAge: 18,
|
|
16
|
+
errorMessage: 'Допустимый возраст - от 18 лет',
|
|
17
|
+
},
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
export const getLimitedBirthdayValidation = (productType: ProductType) =>
|
|
21
|
+
limitedBirthdayValidator(limitedBirthdayValidationData[productType]);
|
|
@@ -11,7 +11,6 @@ import {
|
|
|
11
11
|
codeWordValidator,
|
|
12
12
|
jobNumberValidator,
|
|
13
13
|
lengthStringValidator,
|
|
14
|
-
limitedBirthdayValidator,
|
|
15
14
|
numberValidator,
|
|
16
15
|
serieValidator,
|
|
17
16
|
snilsValidator,
|
|
@@ -53,7 +52,6 @@ const validatorRetailObj: Record<string, Validator> = {
|
|
|
53
52
|
addressRetail: defaultSelectValidator('Выберите адрес банка'),
|
|
54
53
|
addressMatch: defaultValidator(),
|
|
55
54
|
sex: defaultValidator('Укажите свой пол'),
|
|
56
|
-
limitedBirthday: limitedBirthdayValidator(),
|
|
57
55
|
birthPlace: defaultValidator('Укажите место рождения'),
|
|
58
56
|
education: defaultSelectValidator('Выберите ваше образование'),
|
|
59
57
|
housing: defaultSelectValidator('Выберите тип жилья'),
|
|
@@ -6,9 +6,11 @@ const ERROR_MESSAGE = 'Некорректно заполненное поле';
|
|
|
6
6
|
|
|
7
7
|
const ADDRESS_ERROR_MESSAGE = 'Укажите регион, город/населенный пункт, улицу, дом';
|
|
8
8
|
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
9
|
+
export interface LimitedBirthdayValidationParams {
|
|
10
|
+
minAge: number;
|
|
11
|
+
maxAge?: number;
|
|
12
|
+
errorMessage: string;
|
|
13
|
+
}
|
|
12
14
|
|
|
13
15
|
const addressDaDataValidate = (address: Address) =>
|
|
14
16
|
Boolean(address.region && (address.city || address.locality) && address.house);
|
|
@@ -33,20 +35,29 @@ export const lengthStringValidator = (inputLength: number, errorMsg?: string) =>
|
|
|
33
35
|
errorMsg ?? ERROR_MESSAGE,
|
|
34
36
|
);
|
|
35
37
|
|
|
36
|
-
const limitedBirthdayValidate =
|
|
37
|
-
|
|
38
|
+
const limitedBirthdayValidate =
|
|
39
|
+
({ minAge, maxAge }: LimitedBirthdayValidationParams) =>
|
|
40
|
+
(date?: Date) => {
|
|
41
|
+
const today = new Date();
|
|
38
42
|
|
|
39
|
-
|
|
40
|
-
|
|
43
|
+
const minDate = new Date(today.getFullYear() - minAge, today.getMonth(), today.getDate());
|
|
44
|
+
const maxDate = maxAge
|
|
45
|
+
? new Date(today.getFullYear() - maxAge, today.getMonth(), today.getDate())
|
|
46
|
+
: null;
|
|
41
47
|
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
48
|
+
if (!date || date > minDate) {
|
|
49
|
+
return false;
|
|
50
|
+
}
|
|
45
51
|
|
|
46
|
-
|
|
47
|
-
|
|
52
|
+
if (maxDate && date < maxDate) {
|
|
53
|
+
return false;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
return true;
|
|
57
|
+
};
|
|
48
58
|
|
|
49
|
-
export const limitedBirthdayValidator = () =>
|
|
59
|
+
export const limitedBirthdayValidator = (params: LimitedBirthdayValidationParams) =>
|
|
60
|
+
validator(limitedBirthdayValidate(params))(params.errorMessage);
|
|
50
61
|
|
|
51
62
|
export const numberValidator = (errorMsg: string) =>
|
|
52
63
|
validator((_) => typeof _ === 'string' && _.length === 6)(errorMsg);
|