@redneckz/wildless-cms-uni-blocks 0.14.820 → 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 +237 -236
- package/bundle/bundle.umd.min.js +1 -1
- package/bundle/components/ApplicationLeadForm/ApplicationLeadForm.d.ts +0 -5
- package/bundle/components/ApplicationLeadForm/applicationFormData.d.ts +1 -0
- package/bundle/components/ApplicationLeadForm/getInitialFormState.d.ts +1 -1
- package/bundle/components/ApplicationLeadForm/parseEsiaProfile.d.ts +2 -2
- package/bundle/components/ApplicationLeadForm/useApplicationLeadApi.d.ts +2 -1
- package/bundle/components/ApplicationLeadForm/useInitApplicationLead.d.ts +4 -4
- package/bundle/retail/api/checkCode.d.ts +0 -1
- package/{dist/retail/api/esiaRequestProfile.d.ts → bundle/retail/api/updateProfileEsia.d.ts} +4 -11
- package/bundle/retail/api/updateUserTask.d.ts +0 -1
- package/bundle/retail/api/uploadFile.d.ts +1 -1
- package/bundle/retail/components/EsiaLoginDialog/EsiaLoginDialog.d.ts +4 -0
- package/bundle/retail/components/EsiaLoginDialog/useEsiaLoginDialog.d.ts +1 -0
- package/bundle/retail/model/NameFieldDef.d.ts +1 -1
- package/bundle/retail/validator/getLimitedBirthdayValidation.d.ts +2 -0
- package/bundle/retail/validator/validators.d.ts +6 -1
- package/bundle/ui-kit/FormField/shouldRenderField.d.ts +1 -1
- package/dist/components/ApplicationLeadForm/ApplicationLeadForm.d.ts +0 -5
- package/dist/components/ApplicationLeadForm/ApplicationLeadForm.js +17 -28
- package/dist/components/ApplicationLeadForm/ApplicationLeadForm.js.map +1 -1
- package/dist/components/ApplicationLeadForm/applicationFormData.d.ts +1 -0
- package/dist/components/ApplicationLeadForm/applicationFormData.js +31 -6
- package/dist/components/ApplicationLeadForm/applicationFormData.js.map +1 -1
- package/dist/components/ApplicationLeadForm/getInitialFormState.d.ts +1 -1
- package/dist/components/ApplicationLeadForm/getInitialFormState.js +2 -8
- package/dist/components/ApplicationLeadForm/getInitialFormState.js.map +1 -1
- package/dist/components/ApplicationLeadForm/parseEsiaProfile.d.ts +2 -2
- package/dist/components/ApplicationLeadForm/parseEsiaProfile.js +50 -80
- package/dist/components/ApplicationLeadForm/parseEsiaProfile.js.map +1 -1
- package/dist/components/ApplicationLeadForm/useApplicationLeadApi.d.ts +2 -1
- package/dist/components/ApplicationLeadForm/useApplicationLeadApi.js +10 -7
- package/dist/components/ApplicationLeadForm/useApplicationLeadApi.js.map +1 -1
- package/dist/components/ApplicationLeadForm/useInitApplicationLead.d.ts +4 -4
- package/dist/components/ApplicationLeadForm/useInitApplicationLead.js +24 -16
- package/dist/components/ApplicationLeadForm/useInitApplicationLead.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/api/checkCode.d.ts +0 -1
- package/dist/retail/api/checkCode.js +2 -3
- package/dist/retail/api/checkCode.js.map +1 -1
- package/{bundle/retail/api/esiaRequestProfile.d.ts → dist/retail/api/updateProfileEsia.d.ts} +4 -11
- package/dist/retail/api/updateProfileEsia.js +6 -0
- package/dist/retail/api/updateProfileEsia.js.map +1 -0
- package/dist/retail/api/updateUserTask.d.ts +0 -1
- package/dist/retail/api/updateUserTask.js.map +1 -1
- package/dist/retail/api/uploadFile.d.ts +1 -1
- package/dist/retail/api/uploadFile.js +3 -2
- package/dist/retail/api/uploadFile.js.map +1 -1
- package/dist/retail/components/DraftDialog/parseDraftTask.js +1 -2
- package/dist/retail/components/DraftDialog/parseDraftTask.js.map +1 -1
- package/dist/retail/components/EsiaLoginDialog/EsiaLoginDialog.d.ts +4 -0
- package/dist/retail/components/EsiaLoginDialog/EsiaLoginDialog.js +34 -0
- package/dist/retail/components/EsiaLoginDialog/EsiaLoginDialog.js.map +1 -0
- package/dist/retail/components/EsiaLoginDialog/useEsiaLoginDialog.d.ts +1 -0
- package/dist/retail/components/EsiaLoginDialog/useEsiaLoginDialog.js +15 -0
- package/dist/retail/components/EsiaLoginDialog/useEsiaLoginDialog.js.map +1 -0
- package/dist/retail/components/Fields/BeginDateField.js +1 -2
- package/dist/retail/components/Fields/BeginDateField.js.map +1 -1
- package/dist/retail/components/Fields/ConfirmationIncomeField.js +1 -4
- package/dist/retail/components/Fields/ConfirmationIncomeField.js.map +1 -1
- package/dist/retail/components/Fields/DaDataInnField.js +1 -2
- package/dist/retail/components/Fields/DaDataInnField.js.map +1 -1
- package/dist/retail/components/Fields/Experience5YearsField.js +1 -2
- package/dist/retail/components/Fields/Experience5YearsField.js.map +1 -1
- package/dist/retail/components/Fields/GeneralSeniorityField.js +1 -2
- package/dist/retail/components/Fields/GeneralSeniorityField.js.map +1 -1
- package/dist/retail/components/Fields/JobsNumberField.js +1 -2
- package/dist/retail/components/Fields/JobsNumberField.js.map +1 -1
- package/dist/retail/components/Fields/LastJobExperienceField.js +1 -2
- package/dist/retail/components/Fields/LastJobExperienceField.js.map +1 -1
- package/dist/retail/components/Fields/OrganizationNameField.js +1 -2
- package/dist/retail/components/Fields/OrganizationNameField.js.map +1 -1
- package/dist/retail/components/Fields/WagesField.js +1 -2
- package/dist/retail/components/Fields/WagesField.js.map +1 -1
- package/dist/retail/content.js +5 -11
- package/dist/retail/content.js.map +1 -1
- package/dist/retail/model/NameFieldDef.d.ts +1 -1
- package/dist/retail/utils/mainFormStateMap.js +0 -1
- package/dist/retail/utils/mainFormStateMap.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/dist/ui-kit/FormField/Fields/PhoneField.js +1 -2
- package/dist/ui-kit/FormField/Fields/PhoneField.js.map +1 -1
- package/dist/ui-kit/FormField/shouldRenderField.d.ts +1 -1
- package/dist/ui-kit/FormField/shouldRenderField.js +1 -1
- package/dist/ui-kit/FormField/shouldRenderField.js.map +1 -1
- package/lib/common.css +1 -1
- package/lib/components/ApplicationLeadForm/ApplicationLeadForm.d.ts +0 -5
- package/lib/components/ApplicationLeadForm/ApplicationLeadForm.js +17 -28
- package/lib/components/ApplicationLeadForm/ApplicationLeadForm.js.map +1 -1
- package/lib/components/ApplicationLeadForm/applicationFormData.d.ts +1 -0
- package/lib/components/ApplicationLeadForm/applicationFormData.js +30 -5
- package/lib/components/ApplicationLeadForm/applicationFormData.js.map +1 -1
- package/lib/components/ApplicationLeadForm/getInitialFormState.d.ts +1 -1
- package/lib/components/ApplicationLeadForm/getInitialFormState.js +2 -8
- package/lib/components/ApplicationLeadForm/getInitialFormState.js.map +1 -1
- package/lib/components/ApplicationLeadForm/parseEsiaProfile.d.ts +2 -2
- package/lib/components/ApplicationLeadForm/parseEsiaProfile.js +50 -80
- package/lib/components/ApplicationLeadForm/parseEsiaProfile.js.map +1 -1
- package/lib/components/ApplicationLeadForm/useApplicationLeadApi.d.ts +2 -1
- package/lib/components/ApplicationLeadForm/useApplicationLeadApi.js +10 -7
- package/lib/components/ApplicationLeadForm/useApplicationLeadApi.js.map +1 -1
- package/lib/components/ApplicationLeadForm/useInitApplicationLead.d.ts +4 -4
- package/lib/components/ApplicationLeadForm/useInitApplicationLead.js +24 -16
- package/lib/components/ApplicationLeadForm/useInitApplicationLead.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/api/checkCode.d.ts +0 -1
- package/lib/retail/api/checkCode.js +1 -1
- package/lib/retail/api/checkCode.js.map +1 -1
- package/lib/retail/api/{esiaRequestProfile.d.ts → updateProfileEsia.d.ts} +4 -11
- package/lib/retail/api/updateProfileEsia.js +3 -0
- package/lib/retail/api/updateProfileEsia.js.map +1 -0
- package/lib/retail/api/updateUserTask.d.ts +0 -1
- package/lib/retail/api/updateUserTask.js.map +1 -1
- package/lib/retail/api/uploadFile.d.ts +1 -1
- package/lib/retail/api/uploadFile.js +3 -2
- package/lib/retail/api/uploadFile.js.map +1 -1
- package/lib/retail/components/DraftDialog/parseDraftTask.js +1 -2
- package/lib/retail/components/DraftDialog/parseDraftTask.js.map +1 -1
- package/lib/retail/components/EsiaLoginDialog/EsiaLoginDialog.d.ts +4 -0
- package/lib/retail/components/EsiaLoginDialog/EsiaLoginDialog.fixture.d.ts +5 -0
- package/lib/retail/components/EsiaLoginDialog/EsiaLoginDialog.js +32 -0
- package/lib/retail/components/EsiaLoginDialog/EsiaLoginDialog.js.map +1 -0
- package/lib/retail/components/EsiaLoginDialog/useEsiaLoginDialog.d.ts +1 -0
- package/lib/retail/components/EsiaLoginDialog/useEsiaLoginDialog.js +12 -0
- package/lib/retail/components/EsiaLoginDialog/useEsiaLoginDialog.js.map +1 -0
- package/lib/retail/components/Fields/BeginDateField.js +1 -2
- package/lib/retail/components/Fields/BeginDateField.js.map +1 -1
- package/lib/retail/components/Fields/ConfirmationIncomeField.js +2 -5
- package/lib/retail/components/Fields/ConfirmationIncomeField.js.map +1 -1
- package/lib/retail/components/Fields/DaDataInnField.js +1 -2
- package/lib/retail/components/Fields/DaDataInnField.js.map +1 -1
- package/lib/retail/components/Fields/Experience5YearsField.js +1 -2
- package/lib/retail/components/Fields/Experience5YearsField.js.map +1 -1
- package/lib/retail/components/Fields/GeneralSeniorityField.js +1 -2
- package/lib/retail/components/Fields/GeneralSeniorityField.js.map +1 -1
- package/lib/retail/components/Fields/JobsNumberField.js +1 -2
- package/lib/retail/components/Fields/JobsNumberField.js.map +1 -1
- package/lib/retail/components/Fields/LastJobExperienceField.js +1 -2
- package/lib/retail/components/Fields/LastJobExperienceField.js.map +1 -1
- package/lib/retail/components/Fields/OrganizationNameField.js +1 -2
- package/lib/retail/components/Fields/OrganizationNameField.js.map +1 -1
- package/lib/retail/components/Fields/WagesField.js +1 -2
- package/lib/retail/components/Fields/WagesField.js.map +1 -1
- package/lib/retail/content.js +5 -11
- package/lib/retail/content.js.map +1 -1
- package/lib/retail/model/NameFieldDef.d.ts +1 -1
- package/lib/retail/utils/mainFormStateMap.js +0 -1
- package/lib/retail/utils/mainFormStateMap.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/lib/ui-kit/FormField/Fields/PhoneField.js +1 -2
- package/lib/ui-kit/FormField/Fields/PhoneField.js.map +1 -1
- package/lib/ui-kit/FormField/shouldRenderField.d.ts +1 -1
- package/lib/ui-kit/FormField/shouldRenderField.js +1 -1
- package/lib/ui-kit/FormField/shouldRenderField.js.map +1 -1
- package/mobile/bundle/bundle.umd.js +231 -235
- package/mobile/bundle/bundle.umd.min.js +1 -1
- package/mobile/bundle/components/ApplicationLeadForm/ApplicationLeadForm.d.ts +0 -5
- package/mobile/bundle/components/ApplicationLeadForm/applicationFormData.d.ts +1 -0
- package/mobile/bundle/components/ApplicationLeadForm/getInitialFormState.d.ts +1 -1
- package/mobile/bundle/components/ApplicationLeadForm/parseEsiaProfile.d.ts +2 -2
- package/mobile/bundle/components/ApplicationLeadForm/useApplicationLeadApi.d.ts +2 -1
- package/mobile/bundle/components/ApplicationLeadForm/useInitApplicationLead.d.ts +4 -4
- package/mobile/bundle/retail/api/checkCode.d.ts +0 -1
- package/mobile/bundle/retail/api/{esiaRequestProfile.d.ts → updateProfileEsia.d.ts} +4 -11
- package/mobile/bundle/retail/api/updateUserTask.d.ts +0 -1
- package/mobile/bundle/retail/api/uploadFile.d.ts +1 -1
- package/mobile/bundle/retail/components/EsiaLoginDialog/EsiaLoginDialog.d.ts +4 -0
- package/mobile/bundle/retail/components/EsiaLoginDialog/useEsiaLoginDialog.d.ts +1 -0
- package/mobile/bundle/retail/model/NameFieldDef.d.ts +1 -1
- package/mobile/bundle/retail/validator/getLimitedBirthdayValidation.d.ts +2 -0
- package/mobile/bundle/retail/validator/validators.d.ts +6 -1
- package/mobile/bundle/ui-kit/FormField/shouldRenderField.d.ts +1 -1
- package/mobile/dist/components/ApplicationLeadForm/ApplicationLeadForm.d.ts +0 -5
- package/mobile/dist/components/ApplicationLeadForm/ApplicationLeadForm.js +17 -28
- package/mobile/dist/components/ApplicationLeadForm/ApplicationLeadForm.js.map +1 -1
- package/mobile/dist/components/ApplicationLeadForm/applicationFormData.d.ts +1 -0
- package/mobile/dist/components/ApplicationLeadForm/applicationFormData.js +31 -6
- package/mobile/dist/components/ApplicationLeadForm/applicationFormData.js.map +1 -1
- package/mobile/dist/components/ApplicationLeadForm/getInitialFormState.d.ts +1 -1
- package/mobile/dist/components/ApplicationLeadForm/getInitialFormState.js +2 -8
- package/mobile/dist/components/ApplicationLeadForm/getInitialFormState.js.map +1 -1
- package/mobile/dist/components/ApplicationLeadForm/parseEsiaProfile.d.ts +2 -2
- package/mobile/dist/components/ApplicationLeadForm/parseEsiaProfile.js +50 -80
- package/mobile/dist/components/ApplicationLeadForm/parseEsiaProfile.js.map +1 -1
- package/mobile/dist/components/ApplicationLeadForm/useApplicationLeadApi.d.ts +2 -1
- package/mobile/dist/components/ApplicationLeadForm/useApplicationLeadApi.js +10 -7
- package/mobile/dist/components/ApplicationLeadForm/useApplicationLeadApi.js.map +1 -1
- package/mobile/dist/components/ApplicationLeadForm/useInitApplicationLead.d.ts +4 -4
- package/mobile/dist/components/ApplicationLeadForm/useInitApplicationLead.js +24 -16
- package/mobile/dist/components/ApplicationLeadForm/useInitApplicationLead.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/api/checkCode.d.ts +0 -1
- package/mobile/dist/retail/api/checkCode.js +2 -3
- package/mobile/dist/retail/api/checkCode.js.map +1 -1
- package/mobile/dist/retail/api/updateProfileEsia.d.ts +77 -0
- package/mobile/dist/retail/api/updateProfileEsia.js +6 -0
- package/mobile/dist/retail/api/updateProfileEsia.js.map +1 -0
- package/mobile/dist/retail/api/updateUserTask.d.ts +0 -1
- package/mobile/dist/retail/api/updateUserTask.js.map +1 -1
- package/mobile/dist/retail/api/uploadFile.d.ts +1 -1
- package/mobile/dist/retail/api/uploadFile.js +3 -2
- package/mobile/dist/retail/api/uploadFile.js.map +1 -1
- package/mobile/dist/retail/components/DraftDialog/parseDraftTask.js +1 -2
- package/mobile/dist/retail/components/DraftDialog/parseDraftTask.js.map +1 -1
- package/mobile/dist/retail/components/EsiaLoginDialog/EsiaLoginDialog.d.ts +4 -0
- package/mobile/dist/retail/components/EsiaLoginDialog/EsiaLoginDialog.js +34 -0
- package/mobile/dist/retail/components/EsiaLoginDialog/EsiaLoginDialog.js.map +1 -0
- package/mobile/dist/retail/components/EsiaLoginDialog/useEsiaLoginDialog.d.ts +1 -0
- package/mobile/dist/retail/components/EsiaLoginDialog/useEsiaLoginDialog.js +15 -0
- package/mobile/dist/retail/components/EsiaLoginDialog/useEsiaLoginDialog.js.map +1 -0
- package/mobile/dist/retail/components/Fields/BeginDateField.js +1 -2
- package/mobile/dist/retail/components/Fields/BeginDateField.js.map +1 -1
- package/mobile/dist/retail/components/Fields/ConfirmationIncomeField.js +1 -4
- package/mobile/dist/retail/components/Fields/ConfirmationIncomeField.js.map +1 -1
- package/mobile/dist/retail/components/Fields/DaDataInnField.js +1 -2
- package/mobile/dist/retail/components/Fields/DaDataInnField.js.map +1 -1
- package/mobile/dist/retail/components/Fields/Experience5YearsField.js +1 -2
- package/mobile/dist/retail/components/Fields/Experience5YearsField.js.map +1 -1
- package/mobile/dist/retail/components/Fields/GeneralSeniorityField.js +1 -2
- package/mobile/dist/retail/components/Fields/GeneralSeniorityField.js.map +1 -1
- package/mobile/dist/retail/components/Fields/JobsNumberField.js +1 -2
- package/mobile/dist/retail/components/Fields/JobsNumberField.js.map +1 -1
- package/mobile/dist/retail/components/Fields/LastJobExperienceField.js +1 -2
- package/mobile/dist/retail/components/Fields/LastJobExperienceField.js.map +1 -1
- package/mobile/dist/retail/components/Fields/OrganizationNameField.js +1 -2
- package/mobile/dist/retail/components/Fields/OrganizationNameField.js.map +1 -1
- package/mobile/dist/retail/components/Fields/WagesField.js +1 -2
- package/mobile/dist/retail/components/Fields/WagesField.js.map +1 -1
- package/mobile/dist/retail/content.js +5 -11
- package/mobile/dist/retail/content.js.map +1 -1
- package/mobile/dist/retail/model/NameFieldDef.d.ts +1 -1
- package/mobile/dist/retail/utils/mainFormStateMap.js +0 -1
- package/mobile/dist/retail/utils/mainFormStateMap.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/dist/ui-kit/FormField/Fields/PhoneField.js +1 -2
- package/mobile/dist/ui-kit/FormField/Fields/PhoneField.js.map +1 -1
- package/mobile/dist/ui-kit/FormField/shouldRenderField.d.ts +1 -1
- package/mobile/dist/ui-kit/FormField/shouldRenderField.js +1 -1
- package/mobile/dist/ui-kit/FormField/shouldRenderField.js.map +1 -1
- package/mobile/lib/common.css +1 -1
- package/mobile/lib/components/ApplicationLeadForm/ApplicationLeadForm.d.ts +0 -5
- package/mobile/lib/components/ApplicationLeadForm/ApplicationLeadForm.js +17 -28
- package/mobile/lib/components/ApplicationLeadForm/ApplicationLeadForm.js.map +1 -1
- package/mobile/lib/components/ApplicationLeadForm/applicationFormData.d.ts +1 -0
- package/mobile/lib/components/ApplicationLeadForm/applicationFormData.js +30 -5
- package/mobile/lib/components/ApplicationLeadForm/applicationFormData.js.map +1 -1
- package/mobile/lib/components/ApplicationLeadForm/getInitialFormState.d.ts +1 -1
- package/mobile/lib/components/ApplicationLeadForm/getInitialFormState.js +2 -8
- package/mobile/lib/components/ApplicationLeadForm/getInitialFormState.js.map +1 -1
- package/mobile/lib/components/ApplicationLeadForm/parseEsiaProfile.d.ts +2 -2
- package/mobile/lib/components/ApplicationLeadForm/parseEsiaProfile.js +50 -80
- package/mobile/lib/components/ApplicationLeadForm/parseEsiaProfile.js.map +1 -1
- package/mobile/lib/components/ApplicationLeadForm/useApplicationLeadApi.d.ts +2 -1
- package/mobile/lib/components/ApplicationLeadForm/useApplicationLeadApi.js +10 -7
- package/mobile/lib/components/ApplicationLeadForm/useApplicationLeadApi.js.map +1 -1
- package/mobile/lib/components/ApplicationLeadForm/useInitApplicationLead.d.ts +4 -4
- package/mobile/lib/components/ApplicationLeadForm/useInitApplicationLead.js +24 -16
- package/mobile/lib/components/ApplicationLeadForm/useInitApplicationLead.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/api/checkCode.d.ts +0 -1
- package/mobile/lib/retail/api/checkCode.js +1 -1
- package/mobile/lib/retail/api/checkCode.js.map +1 -1
- package/mobile/lib/retail/api/updateProfileEsia.d.ts +77 -0
- package/mobile/lib/retail/api/updateProfileEsia.js +3 -0
- package/mobile/lib/retail/api/updateProfileEsia.js.map +1 -0
- package/mobile/lib/retail/api/updateUserTask.d.ts +0 -1
- package/mobile/lib/retail/api/updateUserTask.js.map +1 -1
- package/mobile/lib/retail/api/uploadFile.d.ts +1 -1
- package/mobile/lib/retail/api/uploadFile.js +3 -2
- package/mobile/lib/retail/api/uploadFile.js.map +1 -1
- package/mobile/lib/retail/components/DraftDialog/parseDraftTask.js +1 -2
- package/mobile/lib/retail/components/DraftDialog/parseDraftTask.js.map +1 -1
- package/mobile/lib/retail/components/EsiaLoginDialog/EsiaLoginDialog.d.ts +4 -0
- package/mobile/lib/retail/components/EsiaLoginDialog/EsiaLoginDialog.js +32 -0
- package/mobile/lib/retail/components/EsiaLoginDialog/EsiaLoginDialog.js.map +1 -0
- package/mobile/lib/retail/components/EsiaLoginDialog/useEsiaLoginDialog.d.ts +1 -0
- package/mobile/lib/retail/components/EsiaLoginDialog/useEsiaLoginDialog.js +12 -0
- package/mobile/lib/retail/components/EsiaLoginDialog/useEsiaLoginDialog.js.map +1 -0
- package/mobile/lib/retail/components/Fields/BeginDateField.js +1 -2
- package/mobile/lib/retail/components/Fields/BeginDateField.js.map +1 -1
- package/mobile/lib/retail/components/Fields/ConfirmationIncomeField.js +2 -5
- package/mobile/lib/retail/components/Fields/ConfirmationIncomeField.js.map +1 -1
- package/mobile/lib/retail/components/Fields/DaDataInnField.js +1 -2
- package/mobile/lib/retail/components/Fields/DaDataInnField.js.map +1 -1
- package/mobile/lib/retail/components/Fields/Experience5YearsField.js +1 -2
- package/mobile/lib/retail/components/Fields/Experience5YearsField.js.map +1 -1
- package/mobile/lib/retail/components/Fields/GeneralSeniorityField.js +1 -2
- package/mobile/lib/retail/components/Fields/GeneralSeniorityField.js.map +1 -1
- package/mobile/lib/retail/components/Fields/JobsNumberField.js +1 -2
- package/mobile/lib/retail/components/Fields/JobsNumberField.js.map +1 -1
- package/mobile/lib/retail/components/Fields/LastJobExperienceField.js +1 -2
- package/mobile/lib/retail/components/Fields/LastJobExperienceField.js.map +1 -1
- package/mobile/lib/retail/components/Fields/OrganizationNameField.js +1 -2
- package/mobile/lib/retail/components/Fields/OrganizationNameField.js.map +1 -1
- package/mobile/lib/retail/components/Fields/WagesField.js +1 -2
- package/mobile/lib/retail/components/Fields/WagesField.js.map +1 -1
- package/mobile/lib/retail/content.js +5 -11
- package/mobile/lib/retail/content.js.map +1 -1
- package/mobile/lib/retail/model/NameFieldDef.d.ts +1 -1
- package/mobile/lib/retail/utils/mainFormStateMap.js +0 -1
- package/mobile/lib/retail/utils/mainFormStateMap.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/lib/ui-kit/FormField/Fields/PhoneField.js +1 -2
- package/mobile/lib/ui-kit/FormField/Fields/PhoneField.js.map +1 -1
- package/mobile/lib/ui-kit/FormField/shouldRenderField.d.ts +1 -1
- package/mobile/lib/ui-kit/FormField/shouldRenderField.js +1 -1
- package/mobile/lib/ui-kit/FormField/shouldRenderField.js.map +1 -1
- package/mobile/src/components/ApplicationLeadForm/ApplicationLeadForm.tsx +27 -37
- package/mobile/src/components/ApplicationLeadForm/applicationFormData.tsx +31 -5
- package/mobile/src/components/ApplicationLeadForm/getInitialFormState.tsx +1 -8
- package/mobile/src/components/ApplicationLeadForm/parseEsiaProfile.ts +66 -91
- package/mobile/src/components/ApplicationLeadForm/useApplicationLeadApi.tsx +65 -57
- package/mobile/src/components/ApplicationLeadForm/useInitApplicationLead.ts +48 -32
- 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/api/checkCode.ts +1 -1
- package/mobile/src/retail/api/{esiaRequestProfile.ts → updateProfileEsia.ts} +5 -16
- package/mobile/src/retail/api/updateUserTask.ts +0 -1
- package/mobile/src/retail/api/uploadFile.ts +3 -2
- package/mobile/src/retail/components/DraftDialog/parseDraftTask.ts +0 -2
- package/mobile/src/retail/components/EsiaLoginDialog/EsiaLoginDialog.tsx +65 -0
- package/mobile/src/retail/components/EsiaLoginDialog/useEsiaLoginDialog.tsx +13 -0
- package/mobile/src/retail/components/Fields/BeginDateField.tsx +0 -2
- package/mobile/src/retail/components/Fields/ConfirmationIncomeField.tsx +7 -18
- package/mobile/src/retail/components/Fields/DaDataInnField.tsx +0 -2
- package/mobile/src/retail/components/Fields/Experience5YearsField.tsx +0 -2
- package/mobile/src/retail/components/Fields/GeneralSeniorityField.tsx +0 -2
- package/mobile/src/retail/components/Fields/JobsNumberField.tsx +0 -2
- package/mobile/src/retail/components/Fields/LastJobExperienceField.tsx +0 -2
- package/mobile/src/retail/components/Fields/OrganizationNameField.tsx +0 -2
- package/mobile/src/retail/components/Fields/WagesField.tsx +0 -2
- package/mobile/src/retail/content.tsx +5 -11
- package/mobile/src/retail/model/NameFieldDef.ts +0 -1
- package/mobile/src/retail/utils/mainFormStateMap.ts +0 -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/mobile/src/ui-kit/FormField/Fields/PhoneField.tsx +1 -9
- package/mobile/src/ui-kit/FormField/shouldRenderField.tsx +1 -2
- package/package.json +1 -1
- package/src/components/ApplicationLeadForm/ApplicationLeadForm.tsx +27 -37
- package/src/components/ApplicationLeadForm/applicationFormData.tsx +31 -5
- package/src/components/ApplicationLeadForm/getInitialFormState.tsx +1 -8
- package/src/components/ApplicationLeadForm/parseEsiaProfile.ts +66 -91
- package/src/components/ApplicationLeadForm/useApplicationLeadApi.tsx +65 -57
- package/src/components/ApplicationLeadForm/useInitApplicationLead.ts +48 -32
- 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/api/checkCode.ts +1 -1
- package/src/retail/api/{esiaRequestProfile.ts → updateProfileEsia.ts} +5 -16
- package/src/retail/api/updateUserTask.ts +0 -1
- package/src/retail/api/uploadFile.ts +3 -2
- package/src/retail/components/DraftDialog/parseDraftTask.ts +0 -2
- package/src/retail/components/EsiaLoginDialog/EsiaLoginDialog.fixture.tsx +7 -0
- package/src/retail/components/EsiaLoginDialog/EsiaLoginDialog.tsx +65 -0
- package/src/retail/components/EsiaLoginDialog/useEsiaLoginDialog.tsx +13 -0
- package/src/retail/components/Fields/BeginDateField.tsx +0 -2
- package/src/retail/components/Fields/ConfirmationIncomeField.tsx +7 -18
- package/src/retail/components/Fields/DaDataInnField.tsx +0 -2
- package/src/retail/components/Fields/Experience5YearsField.tsx +0 -2
- package/src/retail/components/Fields/GeneralSeniorityField.tsx +0 -2
- package/src/retail/components/Fields/JobsNumberField.tsx +0 -2
- package/src/retail/components/Fields/LastJobExperienceField.tsx +0 -2
- package/src/retail/components/Fields/OrganizationNameField.tsx +0 -2
- package/src/retail/components/Fields/WagesField.tsx +0 -2
- package/src/retail/content.tsx +5 -11
- package/src/retail/model/NameFieldDef.ts +0 -1
- package/src/retail/utils/mainFormStateMap.ts +0 -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
- package/src/ui-kit/FormField/Fields/PhoneField.tsx +1 -9
- package/src/ui-kit/FormField/shouldRenderField.tsx +1 -2
- package/bundle/components/ApplicationLeadForm/EsiaLoginBanner.d.ts +0 -4
- package/dist/components/ApplicationLeadForm/EsiaLoginBanner.d.ts +0 -4
- package/dist/components/ApplicationLeadForm/EsiaLoginBanner.js +0 -22
- package/dist/components/ApplicationLeadForm/EsiaLoginBanner.js.map +0 -1
- package/dist/retail/api/esiaRequestProfile.js +0 -10
- package/dist/retail/api/esiaRequestProfile.js.map +0 -1
- package/lib/components/ApplicationLeadForm/EsiaLoginBanner.d.ts +0 -4
- package/lib/components/ApplicationLeadForm/EsiaLoginBanner.js +0 -20
- package/lib/components/ApplicationLeadForm/EsiaLoginBanner.js.map +0 -1
- package/lib/retail/api/esiaRequestProfile.js +0 -7
- package/lib/retail/api/esiaRequestProfile.js.map +0 -1
- package/mobile/bundle/components/ApplicationLeadForm/EsiaLoginBanner.d.ts +0 -4
- package/mobile/dist/components/ApplicationLeadForm/EsiaLoginBanner.d.ts +0 -4
- package/mobile/dist/components/ApplicationLeadForm/EsiaLoginBanner.js +0 -22
- package/mobile/dist/components/ApplicationLeadForm/EsiaLoginBanner.js.map +0 -1
- package/mobile/dist/retail/api/esiaRequestProfile.d.ts +0 -84
- package/mobile/dist/retail/api/esiaRequestProfile.js +0 -10
- package/mobile/dist/retail/api/esiaRequestProfile.js.map +0 -1
- package/mobile/lib/components/ApplicationLeadForm/EsiaLoginBanner.d.ts +0 -4
- package/mobile/lib/components/ApplicationLeadForm/EsiaLoginBanner.js +0 -20
- package/mobile/lib/components/ApplicationLeadForm/EsiaLoginBanner.js.map +0 -1
- package/mobile/lib/retail/api/esiaRequestProfile.d.ts +0 -84
- package/mobile/lib/retail/api/esiaRequestProfile.js +0 -7
- package/mobile/lib/retail/api/esiaRequestProfile.js.map +0 -1
- package/mobile/src/components/ApplicationLeadForm/EsiaLoginBanner.tsx +0 -51
- package/src/components/ApplicationLeadForm/EsiaLoginBanner.tsx +0 -51
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
import { useCallback, useEffect, useMemo } from '@redneckz/uni-jsx/lib/hooks';
|
|
2
|
+
import { useBool } from '@redneckz/uni-jsx/lib/hooks/useBool';
|
|
3
|
+
import { locationNavigator } from '../../external/locationNavigator';
|
|
2
4
|
import { useSetter } from '../../hooks/useSetter';
|
|
3
|
-
import {
|
|
5
|
+
import { updateProfileEsia } from '../../retail/api/updateProfileEsia';
|
|
4
6
|
import { type LeadFormState } from '../../retail/model/LeadFormState';
|
|
5
7
|
import { type FieldRetailDef } from '../../retail/model/RetailFormContent';
|
|
6
|
-
import {
|
|
8
|
+
import { safeJsonParse } from '../../utils/safeJsonParse';
|
|
7
9
|
import { type ProductType } from './ApplicationLeadFormContent';
|
|
8
10
|
import { getInitialFormState } from './getInitialFormState';
|
|
9
11
|
import { parseEsiaProfile } from './parseEsiaProfile';
|
|
@@ -13,62 +15,76 @@ type InitApplicationLeadProps = {
|
|
|
13
15
|
inputs: FieldRetailDef[];
|
|
14
16
|
nextStepLink: string;
|
|
15
17
|
productType: ProductType;
|
|
16
|
-
|
|
17
|
-
esiaAuthSuccess: boolean;
|
|
18
|
+
setEsiaError: () => void;
|
|
18
19
|
};
|
|
19
20
|
|
|
20
21
|
export const useInitApplicationLead = ({
|
|
21
22
|
inputs,
|
|
23
|
+
nextStepLink,
|
|
22
24
|
productType,
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
25
|
+
setEsiaError,
|
|
26
|
+
}: InitApplicationLeadProps): [LeadFormState, { isLoading: boolean }] => {
|
|
27
|
+
const navigator = locationNavigator();
|
|
28
|
+
const [isLoading, { setTrue: startLoading, setFalse: endLoading }] = useBool(false);
|
|
29
|
+
|
|
26
30
|
const leadFormStore = useLeadFormStore();
|
|
27
31
|
const saveForm = useSetter(leadFormStore, 'leadForm');
|
|
28
32
|
|
|
29
33
|
const initialFormState = useMemo(
|
|
30
|
-
() => getInitialFormState(inputs, leadFormStore.leadForm
|
|
34
|
+
() => getInitialFormState(inputs, leadFormStore.leadForm),
|
|
31
35
|
[inputs, leadFormStore.leadForm],
|
|
32
36
|
);
|
|
33
37
|
|
|
34
|
-
const
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
38
|
+
const updateEsiaProfile = useCallback(
|
|
39
|
+
async (profileId: string, code: string, state: string) => {
|
|
40
|
+
startLoading();
|
|
41
|
+
try {
|
|
42
|
+
const data = await updateProfileEsia({
|
|
43
|
+
profileId,
|
|
44
|
+
code,
|
|
45
|
+
state,
|
|
46
|
+
redirectUri: globalThis.location?.href,
|
|
47
|
+
});
|
|
48
|
+
|
|
49
|
+
if (data && leadFormStore?.taskId) {
|
|
50
|
+
const parsedData = await parseEsiaProfile(
|
|
51
|
+
data,
|
|
52
|
+
leadFormStore.taskId.toString(),
|
|
53
|
+
productType === 'debitCard',
|
|
54
|
+
);
|
|
43
55
|
|
|
44
|
-
|
|
45
|
-
|
|
56
|
+
saveForm((_) => ({
|
|
57
|
+
..._,
|
|
58
|
+
...parsedData,
|
|
59
|
+
}));
|
|
60
|
+
}
|
|
46
61
|
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
62
|
+
navigator.assign(nextStepLink);
|
|
63
|
+
} catch {
|
|
64
|
+
setEsiaError();
|
|
65
|
+
} finally {
|
|
66
|
+
endLoading();
|
|
52
67
|
}
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
}, []);
|
|
68
|
+
},
|
|
69
|
+
[nextStepLink],
|
|
70
|
+
);
|
|
57
71
|
|
|
58
72
|
useEffect(() => {
|
|
59
73
|
leadFormStore.productType = productType;
|
|
60
|
-
|
|
74
|
+
const profileId: string = <string>(
|
|
75
|
+
safeJsonParse(globalThis.localStorage?.getItem('profileId') ?? '')
|
|
76
|
+
);
|
|
61
77
|
const params = new URLSearchParams(decodeURIComponent(globalThis.location?.search));
|
|
62
78
|
const code = params.get('code');
|
|
63
79
|
const state = params.get('state');
|
|
64
80
|
|
|
65
|
-
if (code && state) {
|
|
66
|
-
|
|
81
|
+
if (profileId && code && state) {
|
|
82
|
+
updateEsiaProfile(profileId, code, state);
|
|
67
83
|
} else {
|
|
68
84
|
sessionStorage.removeItem('accessToken');
|
|
69
85
|
sessionStorage.removeItem('refreshToken');
|
|
70
86
|
}
|
|
71
87
|
}, []);
|
|
72
88
|
|
|
73
|
-
return initialFormState;
|
|
89
|
+
return [initialFormState, { isLoading }];
|
|
74
90
|
};
|
|
@@ -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
|
);
|
|
@@ -16,7 +16,7 @@ export type CheckCodeResponse = {
|
|
|
16
16
|
export const checkCode = async (body: CheckCodeBody) =>
|
|
17
17
|
fetchRetailJSON<CheckCodeResponse>('/sms/checkCode', 'POST', body).then(saveToken);
|
|
18
18
|
|
|
19
|
-
|
|
19
|
+
const saveToken = (data: CheckCodeResponse | null) => {
|
|
20
20
|
if (data) {
|
|
21
21
|
globalThis.sessionStorage.setItem('accessToken', data.access_token);
|
|
22
22
|
globalThis.sessionStorage.setItem('refreshToken', data.refresh_token);
|
|
@@ -1,14 +1,13 @@
|
|
|
1
|
-
import { saveToken, type CheckCodeResponse } from './checkCode';
|
|
2
1
|
import { fetchRetailJSON } from './doRequest';
|
|
3
2
|
|
|
4
|
-
export type
|
|
3
|
+
export type UpdateProfileEsiaBody = {
|
|
5
4
|
code: string;
|
|
6
|
-
|
|
5
|
+
profileId: string;
|
|
7
6
|
state: string;
|
|
8
7
|
redirectUri: string;
|
|
9
8
|
};
|
|
10
9
|
|
|
11
|
-
export type
|
|
10
|
+
export type UpdateProfileEsiaResponse = {
|
|
12
11
|
profile: {
|
|
13
12
|
id: number;
|
|
14
13
|
esiaId: string;
|
|
@@ -76,18 +75,8 @@ export type EsiaRequestProfileResponse = CheckCodeResponse & {
|
|
|
76
75
|
workLengthLastJob: number;
|
|
77
76
|
pdfFileWorkbook: string;
|
|
78
77
|
pdfFilePayout: string;
|
|
79
|
-
pdfFileSigPayout: string;
|
|
80
|
-
pdfFileSigWorkbook: string;
|
|
81
|
-
xmlFilePayout: string;
|
|
82
|
-
xmlFileSigPayout: string;
|
|
83
|
-
xmlFileSigWorkbook: string;
|
|
84
|
-
xmlFileWorkbook: string;
|
|
85
78
|
};
|
|
86
79
|
};
|
|
87
80
|
|
|
88
|
-
export const
|
|
89
|
-
fetchRetailJSON<
|
|
90
|
-
saveToken(res);
|
|
91
|
-
|
|
92
|
-
return res;
|
|
93
|
-
});
|
|
81
|
+
export const updateProfileEsia = (body: UpdateProfileEsiaBody) =>
|
|
82
|
+
fetchRetailJSON<UpdateProfileEsiaResponse>('/esia/updateProfileEsia', 'POST', body);
|
|
@@ -5,12 +5,13 @@ export type DocumentCategory = 'CONFIRMING_EMPLOYMENT_DOC' | 'CONFIRMING_INCOME_
|
|
|
5
5
|
|
|
6
6
|
export const uploadFile = async (
|
|
7
7
|
file: Blob,
|
|
8
|
+
taskId: string,
|
|
8
9
|
documentCategory: DocumentCategory,
|
|
9
|
-
isPDF = false,
|
|
10
10
|
): Promise<File> => {
|
|
11
11
|
const fd = new FormData();
|
|
12
|
+
fd.append('taskId', taskId);
|
|
12
13
|
fd.append('documentCategory', documentCategory);
|
|
13
|
-
fd.append('file', file,
|
|
14
|
+
fd.append('file', file, 'file.pdf');
|
|
14
15
|
|
|
15
16
|
const res = await globalThis
|
|
16
17
|
?.fetch?.(`/light-api-cash/v1/file`, {
|
|
@@ -68,7 +68,6 @@ export const parseDraftTask = (task: Task): LeadFormState => {
|
|
|
68
68
|
payrollCardRshbFlg: isInsurance,
|
|
69
69
|
consentInsuranceFlg: isSalaryClient,
|
|
70
70
|
incomeCertificateCd,
|
|
71
|
-
profile,
|
|
72
71
|
} = participant;
|
|
73
72
|
|
|
74
73
|
return {
|
|
@@ -122,7 +121,6 @@ export const parseDraftTask = (task: Task): LeadFormState => {
|
|
|
122
121
|
monthsValue,
|
|
123
122
|
isAnnuity: paymentTypeCd?.key === 'ANNUITY',
|
|
124
123
|
},
|
|
125
|
-
esiaAccountTypeCd: profile?.esiaAccountTypeCd,
|
|
126
124
|
...getParticipantIncomes(participantIncomes),
|
|
127
125
|
...getParticipantAddresses(participantAddresses),
|
|
128
126
|
...getParticipantContacts(participantContacts),
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { JSX } from '@redneckz/uni-jsx';
|
|
2
|
+
import { useCallback } from '@redneckz/uni-jsx/lib/hooks';
|
|
3
|
+
import { locationNavigator } from '../../../external/locationNavigator';
|
|
4
|
+
import { Button } from '../../../ui-kit/Button/Button';
|
|
5
|
+
import { Dialog } from '../../../ui-kit/DialogManager/Dialog';
|
|
6
|
+
import { Img } from '../../../ui-kit/Img/Img';
|
|
7
|
+
import { getLink } from '../../api/getLink';
|
|
8
|
+
import { useRetailFormStore } from '../../hooks/useRetailFormStore';
|
|
9
|
+
|
|
10
|
+
export interface EsiaLoginDialogProps {
|
|
11
|
+
onClose?: () => void;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export const EsiaLoginDialog = JSX<EsiaLoginDialogProps>(({ onClose }) => {
|
|
15
|
+
const navigator = locationNavigator();
|
|
16
|
+
const retailFormStore = useRetailFormStore();
|
|
17
|
+
|
|
18
|
+
const handleAuth = useCallback(async () => {
|
|
19
|
+
const resp = await getLink({
|
|
20
|
+
redirectUri: globalThis.location.origin + globalThis.location.pathname,
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
if (resp?.link) {
|
|
24
|
+
navigator.assign(resp.link);
|
|
25
|
+
globalThis.location.href = resp.link;
|
|
26
|
+
}
|
|
27
|
+
}, []);
|
|
28
|
+
|
|
29
|
+
const handleClose = useCallback(() => {
|
|
30
|
+
if (retailFormStore.leadForm) {
|
|
31
|
+
const leadForm = { ...retailFormStore.leadForm };
|
|
32
|
+
delete leadForm.esiaAccountTypeCd;
|
|
33
|
+
retailFormStore.leadForm = leadForm;
|
|
34
|
+
}
|
|
35
|
+
onClose?.();
|
|
36
|
+
}, []);
|
|
37
|
+
|
|
38
|
+
return (
|
|
39
|
+
<Dialog className="my-6xl max-w-lg w-full min-h-fit mx-auto rounded-lg" onClose={handleClose}>
|
|
40
|
+
<div className="flex flex-col gap-lg items-center rounded-md">
|
|
41
|
+
<div className="flex items-center justify-around w-full px-m">
|
|
42
|
+
<ul className="list-disc">
|
|
43
|
+
<li>Вероятность одобрения выше</li>
|
|
44
|
+
<li>Без справок о доходах и трудоустройстве</li>
|
|
45
|
+
<li>С защитой Ваших данных</li>
|
|
46
|
+
</ul>
|
|
47
|
+
<Img image={{ icon: 'GosUslugiIcon', iconVersion: 'normal' }} height="70" />
|
|
48
|
+
</div>
|
|
49
|
+
<div className="@container flex flex-wrap gap-lg w-full">
|
|
50
|
+
<Button type="button" onClick={handleAuth} className="w-full md:w-auto">
|
|
51
|
+
Заполнить через Госуслуги
|
|
52
|
+
</Button>
|
|
53
|
+
<Button
|
|
54
|
+
type="button"
|
|
55
|
+
version="secondary"
|
|
56
|
+
onClick={handleClose}
|
|
57
|
+
className="w-full md:w-auto"
|
|
58
|
+
>
|
|
59
|
+
Пропустить
|
|
60
|
+
</Button>
|
|
61
|
+
</div>
|
|
62
|
+
</div>
|
|
63
|
+
</Dialog>
|
|
64
|
+
);
|
|
65
|
+
});
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { useCallback } from '@redneckz/uni-jsx/lib/hooks';
|
|
2
|
+
import { locationNavigator } from '../../../external/locationNavigator';
|
|
3
|
+
import { useDialog } from '../../../ui-kit/DialogManager/useDialog';
|
|
4
|
+
import { EsiaLoginDialog } from './EsiaLoginDialog';
|
|
5
|
+
|
|
6
|
+
export const useEsiaLoginDialog = (nextStepLink: string) => {
|
|
7
|
+
const { open } = useDialog(EsiaLoginDialog);
|
|
8
|
+
const navigator = locationNavigator();
|
|
9
|
+
|
|
10
|
+
return useCallback(() => {
|
|
11
|
+
open({ onClose: () => navigator.assign(nextStepLink) });
|
|
12
|
+
}, [open, nextStepLink]);
|
|
13
|
+
};
|
|
@@ -1,13 +1,11 @@
|
|
|
1
1
|
import { JSX } from '@redneckz/uni-jsx';
|
|
2
2
|
import { DatePickerControl } from '../../../ui-kit/DatePicker/DatePickerControl';
|
|
3
3
|
import { type CustomFieldProps } from '../../../ui-kit/FormField/CustomFieldProps';
|
|
4
|
-
import { isEsiaAuthorize } from '../../utils/isEsiaAuthorize';
|
|
5
4
|
|
|
6
5
|
export const BeginDateField = JSX<CustomFieldProps>(({ field, input }) => (
|
|
7
6
|
<DatePickerControl
|
|
8
7
|
label="Дата начала работы на текущем месте"
|
|
9
8
|
{...field(input?.name ?? '')}
|
|
10
9
|
{...input}
|
|
11
|
-
disabled={input?.filledByEsia && isEsiaAuthorize(field, input?.name ?? '')}
|
|
12
10
|
/>
|
|
13
11
|
));
|
|
@@ -1,29 +1,18 @@
|
|
|
1
1
|
import { JSX } from '@redneckz/uni-jsx';
|
|
2
2
|
import { type CustomFieldProps } from '../../../ui-kit/FormField/CustomFieldProps';
|
|
3
|
-
import { InfoCard } from '../../../ui-kit/InfoCard/InfoCard';
|
|
4
3
|
import { useLeadFormData } from '../../hooks/useLeadFormData';
|
|
5
|
-
import { isEsiaAuthorize } from '../../utils/isEsiaAuthorize';
|
|
6
4
|
import { SelectField } from './SelectField';
|
|
7
5
|
|
|
8
6
|
export const ConfirmationIncomeField = JSX<CustomFieldProps>(({ field, input }) => {
|
|
9
7
|
const { data: confirmationIncome } = useLeadFormData('INCOME_CERT_UNITED');
|
|
10
|
-
const filledByEsia = input?.filledByEsia && isEsiaAuthorize(field, input?.name ?? '');
|
|
11
8
|
|
|
12
9
|
return (
|
|
13
|
-
<
|
|
14
|
-
{
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
field={field}
|
|
21
|
-
source={confirmationIncome}
|
|
22
|
-
label="Способ подтверждения дохода"
|
|
23
|
-
fieldName="confirmationIncome"
|
|
24
|
-
input={input}
|
|
25
|
-
disabled={filledByEsia}
|
|
26
|
-
/>
|
|
27
|
-
</div>
|
|
10
|
+
<SelectField
|
|
11
|
+
field={field}
|
|
12
|
+
source={confirmationIncome}
|
|
13
|
+
label="Способ подтверждения дохода"
|
|
14
|
+
fieldName="confirmationIncome"
|
|
15
|
+
input={input}
|
|
16
|
+
/>
|
|
28
17
|
);
|
|
29
18
|
});
|
|
@@ -4,7 +4,6 @@ import { type CustomFieldProps } from '../../../ui-kit/FormField/CustomFieldProp
|
|
|
4
4
|
import { type DaDataSuggestion } from '../../api/dadataHints/dadataHintsType';
|
|
5
5
|
import { getOrganizationFromInn } from '../../api/getOrganizationFromInn';
|
|
6
6
|
import { useRetailFormStore } from '../../hooks/useRetailFormStore';
|
|
7
|
-
import { isEsiaAuthorize } from '../../utils/isEsiaAuthorize';
|
|
8
7
|
import { updateOrganizationFields } from '../../utils/updateOrganizationFields';
|
|
9
8
|
import { DaDataInputControl } from '../DaDataInputControl/DaDataInputControl';
|
|
10
9
|
|
|
@@ -42,7 +41,6 @@ export const DaDataInnField = JSX<CustomFieldProps>(({ field, input }) => {
|
|
|
42
41
|
{...input}
|
|
43
42
|
{...field(input?.name ?? '')}
|
|
44
43
|
onDaDataChange={onDaDataChange}
|
|
45
|
-
disabled={input?.filledByEsia && isEsiaAuthorize(field, input?.name ?? '')}
|
|
46
44
|
/>
|
|
47
45
|
);
|
|
48
46
|
});
|
|
@@ -2,7 +2,6 @@ import { JSX } from '@redneckz/uni-jsx';
|
|
|
2
2
|
import { useCallback } from '@redneckz/uni-jsx/lib/hooks';
|
|
3
3
|
import { type CustomFieldProps } from '../../../ui-kit/FormField/CustomFieldProps';
|
|
4
4
|
import { clamp } from '../../../utils/clamp';
|
|
5
|
-
import { isEsiaAuthorize } from '../../utils/isEsiaAuthorize';
|
|
6
5
|
import { DaDataInputControl } from '../DaDataInputControl/DaDataInputControl';
|
|
7
6
|
|
|
8
7
|
const MAX_YEARS = 5;
|
|
@@ -23,7 +22,6 @@ export const Experience5YearsField = JSX<CustomFieldProps>(({ field, input }) =>
|
|
|
23
22
|
{...field(input?.name ?? '')}
|
|
24
23
|
{...input}
|
|
25
24
|
onChange={onChange}
|
|
26
|
-
disabled={input?.filledByEsia && isEsiaAuthorize(field, input?.name ?? '')}
|
|
27
25
|
/>
|
|
28
26
|
);
|
|
29
27
|
});
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { JSX } from '@redneckz/uni-jsx';
|
|
2
2
|
import { type CustomFieldProps } from '../../../ui-kit/FormField/CustomFieldProps';
|
|
3
|
-
import { isEsiaAuthorize } from '../../utils/isEsiaAuthorize';
|
|
4
3
|
import { DaDataInputControl } from '../DaDataInputControl/DaDataInputControl';
|
|
5
4
|
|
|
6
5
|
export const GeneralSeniorityField = JSX<CustomFieldProps>(({ field, input }) => (
|
|
@@ -11,6 +10,5 @@ export const GeneralSeniorityField = JSX<CustomFieldProps>(({ field, input }) =>
|
|
|
11
10
|
placeholder="Количество лет"
|
|
12
11
|
{...field(input?.name ?? '')}
|
|
13
12
|
{...input}
|
|
14
|
-
disabled={input?.filledByEsia && isEsiaAuthorize(field, input?.name ?? '')}
|
|
15
13
|
/>
|
|
16
14
|
));
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { JSX } from '@redneckz/uni-jsx';
|
|
2
2
|
import { type CustomFieldProps } from '../../../ui-kit/FormField/CustomFieldProps';
|
|
3
|
-
import { isEsiaAuthorize } from '../../utils/isEsiaAuthorize';
|
|
4
3
|
import { DaDataInputControl } from '../DaDataInputControl/DaDataInputControl';
|
|
5
4
|
|
|
6
5
|
export const JobsNumberField = JSX<CustomFieldProps>(({ field, input }) => (
|
|
@@ -11,6 +10,5 @@ export const JobsNumberField = JSX<CustomFieldProps>(({ field, input }) => (
|
|
|
11
10
|
maxLength={2}
|
|
12
11
|
{...field(input?.name ?? '')}
|
|
13
12
|
{...input}
|
|
14
|
-
disabled={input?.filledByEsia && isEsiaAuthorize(field, input?.name ?? '')}
|
|
15
13
|
/>
|
|
16
14
|
));
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { JSX } from '@redneckz/uni-jsx';
|
|
2
2
|
import { type CustomFieldProps } from '../../../ui-kit/FormField/CustomFieldProps';
|
|
3
|
-
import { isEsiaAuthorize } from '../../utils/isEsiaAuthorize';
|
|
4
3
|
import { DaDataInputControl } from '../DaDataInputControl/DaDataInputControl';
|
|
5
4
|
|
|
6
5
|
export const LastJobExperienceField = JSX<CustomFieldProps>(({ field, input }) => (
|
|
@@ -11,6 +10,5 @@ export const LastJobExperienceField = JSX<CustomFieldProps>(({ field, input }) =
|
|
|
11
10
|
maxLength={2}
|
|
12
11
|
{...field(input?.name ?? '')}
|
|
13
12
|
{...input}
|
|
14
|
-
disabled={input?.filledByEsia && isEsiaAuthorize(field, input?.name ?? '')}
|
|
15
13
|
/>
|
|
16
14
|
));
|
|
@@ -3,7 +3,6 @@ import { useCallback } from '@redneckz/uni-jsx/lib/hooks';
|
|
|
3
3
|
import { type CustomFieldProps } from '../../../ui-kit/FormField/CustomFieldProps';
|
|
4
4
|
import { type DaDataSuggestion } from '../../api/dadataHints/dadataHintsType';
|
|
5
5
|
import { useRetailFormStore } from '../../hooks/useRetailFormStore';
|
|
6
|
-
import { isEsiaAuthorize } from '../../utils/isEsiaAuthorize';
|
|
7
6
|
import { updateOrganizationFields } from '../../utils/updateOrganizationFields';
|
|
8
7
|
import { DaDataInputControl } from '../DaDataInputControl/DaDataInputControl';
|
|
9
8
|
|
|
@@ -20,7 +19,6 @@ export const OrganizationNameField = JSX<CustomFieldProps>(({ field, input }) =>
|
|
|
20
19
|
label="Наименование организации"
|
|
21
20
|
{...input}
|
|
22
21
|
{...field(input?.name ?? '')}
|
|
23
|
-
disabled={input?.filledByEsia && isEsiaAuthorize(field, input?.name ?? '')}
|
|
24
22
|
onDaDataChange={onDaDataChange}
|
|
25
23
|
/>
|
|
26
24
|
);
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { JSX } from '@redneckz/uni-jsx';
|
|
2
2
|
import { type CustomFieldProps } from '../../../ui-kit/FormField/CustomFieldProps';
|
|
3
|
-
import { isEsiaAuthorize } from '../../utils/isEsiaAuthorize';
|
|
4
3
|
import { DaDataInputControl } from '../DaDataInputControl/DaDataInputControl';
|
|
5
4
|
|
|
6
5
|
export const WagesField = JSX<CustomFieldProps>(({ field, input }) => (
|
|
@@ -10,6 +9,5 @@ export const WagesField = JSX<CustomFieldProps>(({ field, input }) => (
|
|
|
10
9
|
isInteger={true}
|
|
11
10
|
{...field(input?.name ?? '')}
|
|
12
11
|
{...input}
|
|
13
|
-
disabled={input?.filledByEsia && isEsiaAuthorize(field, input?.name ?? '')}
|
|
14
12
|
/>
|
|
15
13
|
));
|
package/src/retail/content.tsx
CHANGED
|
@@ -139,7 +139,7 @@ const EMPLOYMENT_CONTENT: CreditCardSectionsProps[] = [
|
|
|
139
139
|
label: 'Телефон работодателя',
|
|
140
140
|
required: true,
|
|
141
141
|
},
|
|
142
|
-
{ name: 'beginDate', required: true
|
|
142
|
+
{ name: 'beginDate', required: true },
|
|
143
143
|
],
|
|
144
144
|
},
|
|
145
145
|
{
|
|
@@ -180,16 +180,6 @@ const FAMILY_STATUS_AND_INCOME_CONTENT: CreditCardSectionsProps[] = [
|
|
|
180
180
|
{
|
|
181
181
|
title: 'Совокупный доход',
|
|
182
182
|
},
|
|
183
|
-
{
|
|
184
|
-
columns: 1,
|
|
185
|
-
inputs: [
|
|
186
|
-
{
|
|
187
|
-
name: 'confirmationIncome',
|
|
188
|
-
required: true,
|
|
189
|
-
filledByEsia: true,
|
|
190
|
-
},
|
|
191
|
-
],
|
|
192
|
-
},
|
|
193
183
|
{
|
|
194
184
|
inputs: [
|
|
195
185
|
{
|
|
@@ -198,6 +188,10 @@ const FAMILY_STATUS_AND_INCOME_CONTENT: CreditCardSectionsProps[] = [
|
|
|
198
188
|
},
|
|
199
189
|
],
|
|
200
190
|
},
|
|
191
|
+
{
|
|
192
|
+
columns: 1,
|
|
193
|
+
inputs: [{ name: 'confirmationIncome', required: true }],
|
|
194
|
+
},
|
|
201
195
|
{
|
|
202
196
|
columns: 1,
|
|
203
197
|
inputs: [{ name: 'wages', required: true, filledByEsia: true }],
|
|
@@ -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('Выберите тип жилья'),
|