\r\n
\r\n
\r\n
{props.t(\"Logout\")}\r\n \r\n \r\n \r\n \r\n )\r\n}\r\n\r\nProfileMenu.propTypes = {\r\n success: PropTypes.any,\r\n t: PropTypes.any\r\n}\r\n\r\nconst mapStatetoProps = state => {\r\n const { error, success } = state.Profile\r\n return { error, success }\r\n}\r\n\r\nexport default withRouter(\r\n connect(mapStatetoProps, {})(withTranslation()(ProfileMenu))\r\n)\r\n","export default __webpack_public_path__ + \"static/media/megamenu-img.8b069df4.png\";","export default __webpack_public_path__ + \"static/media/logo.9901a8a0.svg\";","export default __webpack_public_path__ + \"static/media/logo-light.f0fb0325.svg\";","import PropTypes from 'prop-types';\r\nimport React, { useState } from \"react\";\r\n\r\nimport { connect } from \"react-redux\";\r\nimport { Row, Col } from \"reactstrap\";\r\nimport { Link } from \"react-router-dom\";\r\n\r\n// Reactstrap\r\nimport { Dropdown, DropdownToggle, DropdownMenu } from \"reactstrap\";\r\n\r\n// Import menuDropdown\r\nimport LanguageDropdown from \"../CommonForBoth/TopbarDropdown/LanguageDropdown\";\r\nimport NotificationDropdown from \"../CommonForBoth/TopbarDropdown/NotificationDropdown\";\r\nimport ProfileMenu from \"../CommonForBoth/TopbarDropdown/ProfileMenu\";\r\nimport megamenuImg from \"../../assets/images/megamenu-img.png\";\r\n\r\n// import images\r\nimport github from \"../../assets/images/brands/github.png\";\r\nimport bitbucket from \"../../assets/images/brands/bitbucket.png\";\r\nimport dribbble from \"../../assets/images/brands/dribbble.png\";\r\nimport dropbox from \"../../assets/images/brands/dropbox.png\";\r\nimport mail_chimp from \"../../assets/images/brands/mail_chimp.png\";\r\nimport slack from \"../../assets/images/brands/slack.png\";\r\n\r\nimport logo from \"../../assets/images/logo.svg\";\r\nimport logoLightSvg from \"../../assets/images/logo-light.svg\";\r\nimport banner from \"../../assets/images/banner/banner.jpg\";\r\n\r\n//i18n\r\nimport { withTranslation } from \"react-i18next\";\r\n\r\n// Redux Store\r\nimport {\r\n showRightSidebarAction,\r\n toggleLeftmenu,\r\n changeSidebarType,\r\n} from \"../../store/actions\";\r\n\r\n\r\nconst Header = () => {\r\n const [search, setsearch] = useState(false);\r\n const [megaMenu, setmegaMenu] = useState(false);\r\n const [socialDrp, setsocialDrp] = useState(false);\r\n\r\n function toggleFullscreen() {\r\n if (\r\n !document.fullscreenElement &&\r\n /* alternative standard method */ !document.mozFullScreenElement &&\r\n !document.webkitFullscreenElement\r\n ) {\r\n // current working methods\r\n if (document.documentElement.requestFullscreen) {\r\n document.documentElement.requestFullscreen();\r\n } else if (document.documentElement.mozRequestFullScreen) {\r\n document.documentElement.mozRequestFullScreen();\r\n } else if (document.documentElement.webkitRequestFullscreen) {\r\n document.documentElement.webkitRequestFullscreen(\r\n Element.ALLOW_KEYBOARD_INPUT\r\n );\r\n }\r\n } else {\r\n if (document.cancelFullScreen) {\r\n document.cancelFullScreen();\r\n } else if (document.mozCancelFullScreen) {\r\n document.mozCancelFullScreen();\r\n } else if (document.webkitCancelFullScreen) {\r\n document.webkitCancelFullScreen();\r\n }\r\n }\r\n }\r\n\r\n function tToggle() {\r\n debugger;\r\n var body = document.body;\r\n if (window.screen.width <= 998) {\r\n body.classList.toggle(\"sidebar-enable\");\r\n } else {\r\n body.classList.toggle(\"vertical-collpsed\");\r\n body.classList.toggle(\"sidebar-enable\");\r\n }\r\n }\r\n\r\n return (\r\n
\r\n \r\n \r\n
\r\n
\r\n \r\n \r\n

\r\n
\r\n \r\n \r\n \r\n \r\n
\r\n \r\n
\r\n
\r\n
\r\n \r\n \r\n );\r\n};\r\n\r\nHeader.propTypes = {\r\n changeSidebarType: PropTypes.func,\r\n leftMenu: PropTypes.any,\r\n leftSideBarType: PropTypes.any,\r\n showRightSidebar: PropTypes.any,\r\n showRightSidebarAction: PropTypes.func,\r\n t: PropTypes.any,\r\n toggleLeftmenu: PropTypes.func\r\n};\r\n\r\nconst mapStatetoProps = state => {\r\n const {\r\n layoutType,\r\n showRightSidebar,\r\n leftMenu,\r\n leftSideBarType,\r\n } = state.Layout;\r\n return { layoutType, showRightSidebar, leftMenu, leftSideBarType };\r\n};\r\n\r\nexport default connect(mapStatetoProps, {\r\n showRightSidebarAction,\r\n toggleLeftmenu,\r\n changeSidebarType,\r\n})(withTranslation()(Header));\r\n","import React from \"react\"\r\nimport { Container, Row, Col } from \"reactstrap\"\r\n\r\nconst Footer = () => {\r\n return (\r\n
\r\n \r\n \r\n )\r\n}\r\n\r\nexport default Footer\r\n","import React, { Component } from 'react'\r\nimport authHeader from \"helpers/authHeader\";\r\nimport { Input } from \"reactstrap\"\r\nimport axios from 'axios';\r\nimport { deletePOIUrl } from \"../../helpers/fakebackend_helper\";\r\n\r\nfunction TableRows({ rowsData, deletePoiRows, handleChange, handleCheckChange, handleUploadChange }) {\r\n $(\".maxFuture\").flatpickr({\r\n dateFormat: \"d-M-Y\",\r\n minDate: \"today\",\r\n disableMobile: \"true\"\r\n });\r\n\r\n function DeletePOI(poiid) {\r\n debugger;\r\n const deleteStatusModel = {\r\n RegistrationId: localStorage.getItem('registrationId'),\r\n Id: poiid\r\n }\r\n if (rowsData.length > 1) {\r\n axios.post(deletePOIUrl(), deleteStatusModel, { headers: authHeader() })\r\n .then(res => {\r\n\r\n })\r\n }\r\n }\r\n\r\n return (\r\n rowsData.map((data, index) => {\r\n const { poiid, SelectedProofofIdentity, EnterNumber, POIPOA, Expiry, Upload, poifilepath, poifilepathurl, Delete } = data;\r\n\r\n return (\r\n
\r\n \r\n \r\n | \r\n \r\n {\r\n if (e.key === 'Enter') e.preventDefault()\r\n }}\r\n onChange={(evnt) => (handleChange(index, evnt))}\r\n maxLength=\"20\"\r\n autoComplete=\"off\"\r\n />\r\n | \r\n \r\n \r\n | \r\n \r\n (handleChange(index, evnt))}\r\n disabled={SelectedProofofIdentity == \"UID\" || SelectedProofofIdentity == \"Voter ID\"}\r\n />\r\n | \r\n \r\n (handleUploadChange(index, evnt))}\r\n onKeyPress={e => {\r\n if (e.key === 'Enter') e.preventDefault()\r\n }}\r\n >\r\n \r\n \r\n \r\n \r\n | \r\n \r\n \r\n | \r\n
\r\n )\r\n })\r\n )\r\n}\r\n\r\nexport default TableRows","import React, { useState, useEffect } from \"react\"\r\nimport axios from 'axios';\r\nimport authHeader from \"helpers/authHeader\";\r\nimport fileDownload from 'js-file-download'\r\nimport MetaTags from \"react-meta-tags\"\r\nimport Header from \"../../components/VerticalLayout/Header\";\r\nimport Footer from \"../../components/VerticalLayout/Footer\";\r\n\r\nimport {\r\n Card,\r\n CardTitle,\r\n CardBody,\r\n Table,\r\n Col,\r\n Container,\r\n Form,\r\n FormGroup,\r\n Input,\r\n InputGroup,\r\n Label,\r\n NavItem,\r\n NavLink,\r\n Row,\r\n Button,\r\n TabContent,\r\n TabPane,\r\n FormFeedback,\r\n\r\n} from \"reactstrap\"\r\n\r\nimport banner from \"../../assets/images/banner/banner.jpg\";\r\n\r\n\r\n// Formik validation\r\nimport * as Yup from \"yup\";\r\nimport { ErrorMessage, useFormik } from \"formik\";\r\nimport { useHistory } from \"react-router-dom\";\r\nimport classnames from \"classnames\";\r\n/*import $ from 'jquery';*/\r\nimport Flatpickr from \"react-flatpickr\";\r\nimport toastr from \"toastr\";\r\nimport \"toastr/build/toastr.min.css\";\r\nimport { branchUrl, registrationUrl, registrationPOIUrl, familyDetilsUrl, relatedPersonDetilsUrl, form60Url, additionalDetailsUrl, technoProductsUrl, nominationDetailsUrl, submitAccountUrl } from \"../../helpers/fakebackend_helper\";\r\n\r\n//redux\r\nimport { useSelector, useDispatch } from \"react-redux\";\r\n\r\n//Get State s\r\nimport { getState } from \"../../store/actions\";\r\n\r\n//Get Occupation\r\nimport { getOccupation } from \"../../store/actions\";\r\n\r\n//GetAll RelatedPersonType\r\nimport { getRelatedPersonType } from \"../../store/actions\";\r\n\r\n//GetAll Education\r\nimport { getEducation } from \"../../store/actions\";\r\n\r\n//GetAll OccupationDetails\r\nimport { getOccupationDetails } from \"../../store/actions\";\r\n\r\n//GetAll AssetDetails\r\nimport { getAssetDetails } from \"../../store/actions\";\r\n\r\n//GetAll OtherBankAccounts\r\nimport { getOtherBankAccounts } from \"../../store/actions\";\r\n\r\n//GetAll AccountType\r\nimport { getAccountType } from \"../../store/actions\";\r\n\r\n//GetAll EntityType\r\nimport { getEntityType } from \"../../store/actions\";\r\n\r\n//GetAll Location\r\nimport { getLocation } from \"../../store/actions\";\r\n\r\n// GetByLocationId Branch\r\nimport { getBranch } from \"../../store/actions\";\r\n\r\n//GetAll Poi\r\nimport { getPoi } from \"../../store/actions\";\r\n\r\nimport TableRows from './TableRows';\r\n\r\nconst Registration = () => {\r\n\r\n //function getBase64(file) {\r\n // return new Promise((resolve, reject) => {\r\n // debugger;\r\n // const reader = new FileReader();\r\n // reader.readAsDataURL(file);\r\n // reader.onload = () => resolve(reader.result);\r\n // reader.onerror = error => reject(error);\r\n // });\r\n //}\r\n\r\n //function getBase64(file) {\r\n // return new Promise((resolve, reject) => {\r\n // debugger;\r\n // const reader = new FileReader();\r\n // reader.readAsDataURL(file);\r\n // reader.onload = () => resolve(reader.result);\r\n // reader.onerror = error => reject(error);\r\n // });\r\n //}\r\n\r\n var getBase64 = async (file) => {\r\n debugger;\r\n return await new Promise((resolve, reject) => {\r\n debugger;\r\n const reader = new FileReader();\r\n reader.readAsDataURL(file);\r\n reader.onload = () => resolve(reader.result);\r\n reader.onerror = error => reject(error);\r\n });\r\n }\r\n\r\n //=============Define State====================\r\n const history = useHistory();\r\n\r\n const [branch, setBranch] = useState([]);\r\n const [showEasing, setshowEasing] = useState(\"swing\");\r\n const [hideEasing, sethideEasing] = useState(\"linear\");\r\n const [showMethod, setshowMethod] = useState(\"fadeIn\");\r\n const [hideMethod, sethideMethod] = useState(\"fadeOut\");\r\n const [showDuration, setshowDuration] = useState(300);\r\n const [hideDuration, sethideDuration] = useState(1000);\r\n const [timeOut, settimeOut] = useState(2000);\r\n const [extendedTimeOut, setextendedTimeOut] = useState(1000);\r\n\r\n function SuccessMessage(message) {\r\n toastr.options = {\r\n positionClass: \"toast-top-center\",\r\n timeOut: timeOut,\r\n extendedTimeOut: extendedTimeOut,\r\n closeButton: true,\r\n debug: false,\r\n progressBar: false,\r\n preventDuplicates: false,\r\n newestOnTop: false,\r\n showEasing: showEasing,\r\n hideEasing: hideEasing,\r\n showMethod: showMethod,\r\n hideMethod: hideMethod,\r\n showDuration: showDuration,\r\n hideDuration: hideDuration\r\n };\r\n\r\n toastr.success(message, \"Information\");\r\n }\r\n\r\n function ErrorMessage(message) {\r\n toastr.options = {\r\n positionClass: \"toast-top-center\",\r\n timeOut: timeOut,\r\n extendedTimeOut: extendedTimeOut,\r\n closeButton: true,\r\n debug: false,\r\n progressBar: false,\r\n preventDuplicates: false,\r\n newestOnTop: false,\r\n showEasing: showEasing,\r\n hideEasing: hideEasing,\r\n showMethod: showMethod,\r\n hideMethod: hideMethod,\r\n showDuration: showDuration,\r\n hideDuration: hideDuration\r\n };\r\n\r\n toastr.error(message, \"Error\");\r\n }\r\n\r\n\r\n const dispatch = useDispatch();\r\n const { stateData } = useSelector(state => ({\r\n stateData: state.Registration.stateData,\r\n }));\r\n\r\n //GetAll Occupation\r\n const { occupationData } = useSelector(state => ({\r\n occupationData: state.Registration.occupationData,\r\n }));\r\n\r\n //GetAll RelatedPersonType\r\n const { relatedPersonTypeData } = useSelector(state => ({\r\n relatedPersonTypeData: state.Registration.relatedPersonTypeData,\r\n }));\r\n\r\n //GetAll Education\r\n const { educationData } = useSelector(state => ({\r\n educationData: state.Registration.educationData,\r\n }));\r\n\r\n //GetAll OccupationDetails\r\n const { occupationDetailsData } = useSelector(state => ({\r\n occupationDetailsData: state.Registration.occupationDetailsData,\r\n }));\r\n\r\n //GetAll AssetDetails\r\n const { assetDetailsData } = useSelector(state => ({\r\n assetDetailsData: state.Registration.assetDetailsData,\r\n }));\r\n\r\n //GetAll OtherBankAccounts\r\n const { otherBankAccountsData } = useSelector(state => ({\r\n otherBankAccountsData: state.Registration.otherBankAccountsData,\r\n }));\r\n\r\n //GetAll AccountType\r\n const { accountTypeData } = useSelector(state => ({\r\n accountTypeData: state.Registration.accountTypeData,\r\n }));\r\n\r\n //GetAll EntityType\r\n const { entityTypeData } = useSelector(state => ({\r\n entityTypeData: state.Registration.entityTypeData,\r\n }));\r\n\r\n //GetAll Location\r\n const { locationData } = useSelector(state => ({\r\n locationData: state.Registration.locationData,\r\n }));\r\n\r\n // GetByLocationId Branch\r\n const { branchData } = useSelector(state => ({\r\n branchData: state.Registration.branchData,\r\n }));\r\n\r\n //GetAll Poi\r\n const { poiData } = useSelector(state => ({\r\n poiData: state.Registration.poiData,\r\n }));\r\n\r\n function onChangeLocation(value) {\r\n debugger;\r\n\r\n const LocationId = value.target.value;\r\n\r\n const branchModel = {\r\n LocationId: LocationId\r\n };\r\n\r\n axios.post(branchUrl(), branchModel, { headers: authHeader() }).then((response) => {\r\n setBranch(response.data)\r\n }, (error) => {\r\n console.log(error.response);\r\n });\r\n }\r\n\r\n function chkNumeric(e) {\r\n let input = e.target.value;\r\n\r\n if (input == \"\") {\r\n validation.handleChange(e);\r\n }\r\n else if (typeof input !== \"undefined\") {\r\n var pattern = new RegExp(/^[0-9\\b]+$/);\r\n if (pattern.test(input)) {\r\n validation.handleChange(e);\r\n }\r\n }\r\n }\r\n\r\n const [rowsData, setRowsData] = useState([]);\r\n const [rowsData1, setRowsData1] = useState([]);\r\n\r\n const addPoiRows = (id) => {\r\n debugger;\r\n if ($(`#ddlPOI${id} option:selected`).val() == \"\" && $(`#ddlPOIPOA${id} option:selected`).val() == \"\") {\r\n ErrorMessage(\"Please select Proof of Identity!\");\r\n $(`#ddlPOI${id}`).focus();\r\n $(`#ddlPOIPOA${id}`).focus();\r\n return;\r\n }\r\n\r\n const rowsInput = {\r\n SelectedProofofIdentity: $(\"#ddlPOI1 option:selected\").text(),\r\n EnterNumber: '',\r\n POIPOA : $(\"#ddlPOIPOA1 option:selected\").text(),\r\n //POI: false,\r\n //POI: $(\"#ddlPOIPOA1 option:selected\").text(),\r\n //POA: false,\r\n Expiry: '',\r\n Upload: '',\r\n Delete: ''\r\n }\r\n setRowsData([...rowsData, rowsInput])\r\n }\r\n\r\n const deletePoiRows = (index) => {\r\n const rows = [...rowsData];\r\n rows.splice(index, 1);\r\n setRowsData(rows);\r\n }\r\n\r\n const handleChange = (index, evnt) => {\r\n debugger;\r\n const { name, value } = evnt.target;\r\n const rowsInput = [...rowsData];\r\n rowsInput[index][name] = value;\r\n setRowsData(rowsInput);\r\n }\r\n\r\n const handleCheckChange = (index, evnt, POIPOA) => {\r\n debugger;\r\n //const { name, value } = evnt.target;\r\n const { name, checked } = evnt.target;\r\n const rowsInput = [...rowsData];\r\n if (name == \"POI\") {\r\n if ({ POIPOA } == \"POI\" || { POIPOA } == \"Both\") {\r\n rowsInput[index][name] = checked;\r\n }\r\n //else\r\n // rowsInput[index][name] = false;\r\n }\r\n \r\n \r\n //rowsInput[index][name] = checked;\r\n setRowsData(rowsInput);\r\n }\r\n\r\n const handleUploadChange = (index, evnt) => {\r\n debugger;\r\n const { name, value } = evnt.target;\r\n const rowsInput = [...rowsData];\r\n rowsInput[index][name] = evnt.target.files[0];\r\n setRowsData(rowsInput);\r\n }\r\n\r\n //Upload files\r\n const [selectedFile, setSelectedFile] = React.useState(\"\");\r\n const [file, setuploadFile] = useState([]);\r\n\r\n function handleUpload(event) {\r\n debugger;\r\n\r\n //getBase64(event.target.files[0]).then(\r\n // data => {\r\n // setSelectedFile(data);\r\n // }\r\n //);\r\n\r\n setSelectedFile(event.target.files[0]);\r\n }\r\n\r\n var authCustomerObject = JSON.parse(localStorage.getItem('authCustomer'));\r\n\r\n var objCustomerMainholder = { personalchoose: '', firstname: '', middlename: '', lastname: '', phoneno: authCustomerObject.mobileNo, email: authCustomerObject.email, gender: '', occupation: '', dob: '', maritalstatus: '2', nationality: '1', communicationaddress: '', communicationstate: '', communicationcity: '', communicationpincode: '', permanentaddress: '', permanentstate: '', permanentcity: '', permanentpincode: '', poi: '', pan: '', panfile: '' };\r\n var objCustomer = { personalchoose: '', firstname: '', middlename: '', lastname: '', phoneno: '', email: '', gender: '', occupation: '', dob: '', maritalstatus: '2', nationality: '1', communicationaddress: '', communicationstate: '', communicationcity: '', communicationpincode: '', permanentaddress: '', permanentstate: '', permanentcity: '', permanentpincode: '', poi: '', pan: '', panfile: '' };\r\n\r\n const [rows1, setrows1] = useState([{ id: 1 }]);\r\n\r\n const registrationHoldersList = [];\r\n const registrationHoldersPOIList = [];\r\n\r\n var registrationHoldersPOI = {\r\n POI: '',\r\n POINo: '',\r\n POIPOA:'',\r\n IsPOI: '',\r\n IsPOA: '',\r\n ExpiryDate: '',\r\n Base64POI: ''\r\n }\r\n\r\n var registrationHolders = {\r\n Title: '',\r\n FirstName: '',\r\n MiddleName: '',\r\n LastName: '',\r\n DOB: '',\r\n Gender: '',\r\n Nationality: '',\r\n Occupation: '',\r\n Mobile: '',\r\n Email: '',\r\n MartialStatus: '',\r\n LocalAddress1: '',\r\n LocalAddress2: '',\r\n LocalAddress3: '',\r\n LocalCity: '',\r\n LocalPin: '',\r\n LocalState: '',\r\n PermanentAddress1: '',\r\n PermanentAddress2: '',\r\n PermanentAddress3: '',\r\n PermanentCity: '',\r\n PermanentPin: '',\r\n PermanentState: '',\r\n PAN: '',\r\n Base64PAN: '',\r\n registrationHoldersPOI: registrationHoldersPOIList\r\n }\r\n\r\n const personalDetails = {\r\n AccountTypeId: '',\r\n EntityTypeId: '',\r\n LocationId: '',\r\n BranchId: '',\r\n registrationHolders: registrationHoldersList\r\n }\r\n\r\n const familyDetails = {\r\n RegistrationId: '',\r\n FatherTitle: '',\r\n FatherFirstName: '',\r\n FatherMiddleName: '',\r\n FatherLastName: '',\r\n MotherTitle: '',\r\n MotherFirstName: '',\r\n MotherMiddleName: '',\r\n MotherLastName: '',\r\n MaidenTitle: '',\r\n MaidenFirstName: '',\r\n MaidenMiddleName: '',\r\n MaidenLastName: ''\r\n }\r\n\r\n const relatedPerson = {\r\n RegistrationId: '',\r\n RelatedPersonTitle: '',\r\n RelatedPeronFirstName: '',\r\n RelatedPeronMiddleName: '',\r\n RelatedPeronLastName: '',\r\n RelatedPersonCustomerRelation: '',\r\n RelatedPersonType: '',\r\n RelatedPersonPANNo: '',\r\n RelatedPersonAadhaarNo: '',\r\n RelatedPersonCourtOrderNo: ''\r\n }\r\n\r\n const form60 = {\r\n RegistrationId: '',\r\n DeclarantDocuments: '',\r\n DeclarantTransactionParticulars: '',\r\n DeclarantAmountofTransaction: '',\r\n DeclarantAssessedTax: '',\r\n DetailsOfIncomeTax: '',\r\n ReasonForNoPan: ''\r\n }\r\n\r\n const additionalDetails = {\r\n RegistrationId: '',\r\n FundsExpectedOrigin: '',\r\n FundsUtilisationExpected: '',\r\n OtherBankAccounts: '',\r\n Turnover: '',\r\n AverageIncome: '',\r\n AverageBalance: '',\r\n Education: '',\r\n Religion: '',\r\n OccupationDetails: '',\r\n LineOfBusiness: '',\r\n BusinessName: '',\r\n BusinessStartDate: '',\r\n BusinessAddress1: '',\r\n BusinessAddress2: '',\r\n BusinessAddress3: '',\r\n BusinessTelNo: '',\r\n BusinessMobileNo: '',\r\n BusinessAnnualIncome: '',\r\n BusinessIncomeSource: '',\r\n BusinessWealthSource: '',\r\n BusinessEstimatedValue: '',\r\n BusinessAssetDetails: '',\r\n BornNonIndia: '',\r\n TaxResidenceNonIndia: '',\r\n BusinessVehicleType: '',\r\n BusinessCarPurchaseYear: '',\r\n BusinessCarMaker: '',\r\n InterestedIn: ''\r\n }\r\n\r\n const technoProducts = {\r\n RegistrationId: '',\r\n DebitCard: '',\r\n SMSBanking: '',\r\n MobileBanking: '',\r\n StatementOnEmail: '',\r\n AadhaarCardSeeding: '',\r\n InterntBanking: ''\r\n }\r\n\r\n const nominationDetails = {\r\n RegistrationId: '',\r\n NatureofDeposit: '',\r\n DistinguishingNo: '',\r\n AdditionalDetails: '',\r\n NomineeFirstName: '',\r\n NomineeMiddleName: '',\r\n NomineeLastName: '',\r\n NomineeAddress1: '',\r\n NomineeAddress2: '',\r\n NomineeAddress3: '',\r\n Relationship: '',\r\n Age: '',\r\n MinorDOB: '',\r\n AccountOperations: ''\r\n }\r\n\r\n useEffect(() => {\r\n dispatch(getState());\r\n dispatch(getOccupation());\r\n dispatch(getRelatedPersonType());\r\n dispatch(getEducation());\r\n dispatch(getOccupationDetails());\r\n dispatch(getAssetDetails());\r\n dispatch(getOtherBankAccounts());\r\n dispatch(getAccountType());\r\n dispatch(getEntityType());\r\n dispatch(getLocation());\r\n dispatch(getBranch());\r\n dispatch(getPoi());\r\n }, [dispatch]);\r\n\r\n\r\n function disablePAN(id) {\r\n if ($(`#chkPAN${id}`).prop('checked') == true) {\r\n $(`#txtPancard${id}`).attr('disabled', 'disabled');\r\n $(`#Upload${id}`).attr('disabled', 'disabled');\r\n $(`#txtPancard${id}`).val('');\r\n }\r\n else {\r\n $(`#txtPancard${id}`).removeAttr('disabled');\r\n $(`#Upload${id}`).removeAttr('disabled');\r\n }\r\n }\r\n\r\n function DownloadRegistrationPDF(fileName) {\r\n debugger;\r\n //Live application url\r\n //var url = \"JSBOnlineAccountAPI/RegistrationPrintPDF/\" + fileName;\r\n\r\n //Development url\r\n var url = \"RegistrationPrintPDF/\" + fileName;\r\n\r\n axios.get(url, {\r\n responseType: \"blob\"\r\n }).then((response) => {\r\n fileDownload(response.data, fileName);\r\n history.push(\"/success\");\r\n }\r\n )\r\n };\r\n\r\n function CreateAccount(tabId) {\r\n debugger;\r\n\r\n if (tabId == 1) {\r\n\r\n //toggleTabVertical(tabId + 1);\r\n //return;\r\n\r\n if (($('#txtPancard1').val().trim() == \"\") && ($(\"#chkPAN1\").prop('checked') == false)) {\r\n $('#txtPancard1').focus();\r\n ErrorMessage(\"Please enter PAN No. or check Form60!\");\r\n return;\r\n }\r\n\r\n if ($(\"#chkPAN1\").prop('checked') == false) {\r\n $('#navForm60').css('background-color', 'lightgrey');\r\n }\r\n else {\r\n $('#navForm60').css('background-color', '');\r\n }\r\n\r\n var dob = new Date($('#txtdob1').val());\r\n var today = new Date();\r\n var age = Math.floor((today - dob) / (365.25 * 24 * 60 * 60 * 1000));\r\n\r\n if (age > 18) {\r\n $('#navRelatedPerson').css('background-color', 'lightgrey');\r\n }\r\n else {\r\n $('#navRelatedPerson').css('background-color', '');\r\n }\r\n\r\n\r\n var IsValid = false;\r\n\r\n if (rowsData.length == 0) {\r\n ErrorMessage(\"Please add atleast one POI document!\");\r\n return IsValid = false;\r\n }\r\n else {\r\n rowsData.map(poiCustomerData => {\r\n if (poiCustomerData.EnterNumber.trim().length == 0) {\r\n ErrorMessage(\"Please enter Document Number for \" + poiCustomerData.SelectedProofofIdentity + \"!\");\r\n return IsValid = false;\r\n }\r\n else if (poiCustomerData.POI == false && poiCustomerData.POA == false) {\r\n ErrorMessage(\"Please select either POI or POA for \" + poiCustomerData.SelectedProofofIdentity + \"!\");\r\n return IsValid = false;\r\n }\r\n else if (poiCustomerData.Upload.length == 0) {\r\n ErrorMessage(\"Please uplaod document for \" + poiCustomerData.SelectedProofofIdentity + \"!\");\r\n return IsValid = false;\r\n }\r\n else {\r\n return IsValid = true;\r\n }\r\n })\r\n }\r\n\r\n var registrationId = '';\r\n registrationId = localStorage.getItem(\"RegistrationId\");\r\n\r\n if (registrationId != null) {\r\n toggleTabVertical(tabId + 1)\r\n }\r\n else {\r\n if (IsValid) {\r\n\r\n personalDetails.AccountTypeId = $('#ddlaccounttype').val();\r\n personalDetails.EntityTypeId = $('#ddlentitytype').val();\r\n personalDetails.LocationId = $('#ddllocation').val();\r\n personalDetails.BranchId = $('#ddlbranch').val();\r\n\r\n const modifiedRowsNew = [...formRows];\r\n\r\n for (var id = 1; id <= modifiedRowsNew.length; id++) {\r\n registrationHolders = {},\r\n\r\n registrationHolders.Title = $('#ddlpersonalchoose' + id).val(),\r\n registrationHolders.FirstName = $('#txtFirstName' + id).val().trim(),\r\n registrationHolders.MiddleName = $('#txtMiddleName' + id).val().trim(),\r\n registrationHolders.LastName = $('#txtLastName' + id).val().trim(),\r\n registrationHolders.DOB = $('#txtdob' + id).val(),\r\n registrationHolders.Gender = $('#ddlgender' + id).val(),\r\n registrationHolders.Nationality = $('#ddlnationality' + id).val(),\r\n registrationHolders.Occupation = $('#ddloccupation' + id).val().trim(),\r\n registrationHolders.Mobile = $('#txtPhoneno' + id).val().trim(),\r\n registrationHolders.Email = $('#txtEmailID' + id).val().trim(),\r\n registrationHolders.MartialStatus = $('#ddlmaratialstatus' + id).val(),\r\n registrationHolders.LocalAddress1 = $('#txtCommunicationAddress1' + id).val().trim(),\r\n registrationHolders.LocalAddress2 = $('#txtCommunicationAddress2' + id).val().trim(),\r\n registrationHolders.LocalAddress3 = $('#txtCommunicationAddress3' + id).val().trim(),\r\n registrationHolders.LocalCity = $('#txtCommunicationCity' + id).val().trim(),\r\n registrationHolders.LocalPin = $('#txtCommunicationPincode' + id).val().trim(),\r\n registrationHolders.LocalState = $('#ddlCommunicationState' + id).val(),\r\n registrationHolders.PermanentAddress1 = $('#txtPermanentAddress1' + id).val().trim(),\r\n registrationHolders.PermanentAddress2 = $('#txtPermanentAddress2' + id).val().trim(),\r\n registrationHolders.PermanentAddress3 = $('#txtPermanentAddress3' + id).val().trim(),\r\n registrationHolders.PermanentCity = $('#txtPermanentCity' + id).val().trim(),\r\n registrationHolders.PermanentPin = $('#txtPermanentPincode' + id).val().trim(),\r\n registrationHolders.PermanentState = $('#ddlPermanentState' + id).val(),\r\n registrationHolders.PAN = $('#txtPancard' + id).val(),\r\n\r\n rowsData.map(poiCustomerData => {\r\n getBase64(poiCustomerData.Upload).then(data => {\r\n registrationHoldersPOI = {},\r\n registrationHoldersPOI.Base64POI = data,\r\n registrationHoldersPOI.POI = poiCustomerData.SelectedProofofIdentity,\r\n\r\n registrationHoldersPOI.POINo = poiCustomerData.EnterNumber,\r\n registrationHoldersPOI.IsPOI = poiCustomerData.POI == true ? (poiCustomerData.POIPOA == \"POI\" ? \"true\" : \"false\") : (poiCustomerData.POIPOA == \"POA & POI\" ? \"true\" : \"false\"),\r\n registrationHoldersPOI.IsPOA = poiCustomerData.POA == true ? (poiCustomerData.POIPOA == \"POA\" ? \"true\" : \"false\") : (poiCustomerData.POIPOA == \"POA & POI\" ? \"true\" : \"false\"),\r\n //registrationHoldersPOI.IsPOI = poiCustomerData.POI == true ? \"true\" : \"false\",\r\n //registrationHoldersPOI.IsPOA = poiCustomerData.POA == true ? \"true\" : \"false\",\r\n registrationHoldersPOI.ExpiryDate = poiCustomerData.Expiry,\r\n\r\n registrationHoldersPOIList.push(registrationHoldersPOI)\r\n })\r\n })\r\n\r\n registrationHolders.registrationHoldersPOI = registrationHoldersPOIList\r\n registrationHoldersList.push(registrationHolders)\r\n }\r\n\r\n\r\n getBase64(selectedFile).then(\r\n data => {\r\n registrationHolders.Base64PAN = data\r\n\r\n axios.post(registrationUrl(), personalDetails, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n debugger;\r\n localStorage.setItem(\"RegistrationId\", res.data.registrationId)\r\n localStorage.setItem(\"ReferenceNo\", res.data.referenceNo)\r\n toggleTabVertical(tabId + 1)\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n }\r\n })\r\n }\r\n );\r\n }\r\n }\r\n }\r\n else if (tabId == 2) {\r\n\r\n //toggleTabVertical(tabId + 1);\r\n //return;\r\n\r\n familyDetails.RegistrationId = localStorage.getItem('RegistrationId');\r\n familyDetails.FatherTitle = $('#ddlfatherchoose :selected').text();\r\n familyDetails.FatherFirstName = $('#txtFatherFirstName').val().trim();\r\n familyDetails.FatherMiddleName = $('#txtFatherMiddleName').val().trim();\r\n familyDetails.FatherLastName = $('#txtFatherLastName').val().trim();\r\n familyDetails.MotherTitle = $('#ddlmotherchoose :selected').text();\r\n familyDetails.MotherFirstName = $('#txtMotherFirstName').val().trim();\r\n familyDetails.MotherMiddleName = $('#txtMotherMiddleName').val().trim();\r\n familyDetails.MotherLastName = $('#txtMotherLastName').val().trim();\r\n familyDetails.MaidenTitle = $('#ddlmaidenchoose :selected').text();\r\n familyDetails.MaidenFirstName = $('#txtMaidenFirstName').val().trim();\r\n familyDetails.MaidenMiddleName = $('#txtMaidenMiddleName').val().trim();\r\n familyDetails.MaidenLastName = $('#txtMaidenLastName').val().trim();\r\n\r\n axios.post(familyDetilsUrl(), familyDetails, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n //toggleTabVertical(tabId + 1)\r\n\r\n var dob = new Date($('#txtdob1').val());\r\n var today = new Date();\r\n var age = Math.floor((today - dob) / (365.25 * 24 * 60 * 60 * 1000));\r\n\r\n if (age > 18 && $(\"#chkPAN1\").prop('checked') == false) {\r\n toggleTabVertical(tabId + 3);\r\n }\r\n else if (age > 18 && $(\"#chkPAN1\").prop('checked') == true) {\r\n toggleTabVertical(tabId + 2);\r\n }\r\n else if (age < 18) {\r\n toggleTabVertical(tabId + 1);\r\n }\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n }\r\n })\r\n }\r\n else if (tabId == 3) {\r\n\r\n //toggleTabVertical(tabId + 1);\r\n //return;\r\n\r\n var RelatedPersonType = \"\";\r\n if ($(\"#chkguardian\").prop('checked') == true) {\r\n RelatedPersonType = RelatedPersonType + \"Guardian of Minor\" + \", \";\r\n }\r\n else {\r\n RelatedPersonType.replace(\"Guardian of Minor\" + \", \");\r\n }\r\n\r\n if ($(\"#chkassignee\").prop('checked') == true) {\r\n RelatedPersonType = RelatedPersonType + \"Assignee\" + \", \";\r\n }\r\n else {\r\n RelatedPersonType.replace(\"Assignee\" + \", \");\r\n }\r\n\r\n if ($(\"#chkauthorized\").prop('checked') == true) {\r\n RelatedPersonType = RelatedPersonType + \"Authorized representative\" + \", \";\r\n }\r\n else {\r\n RelatedPersonType.replace(\"Authorized representative\" + \", \");\r\n }\r\n\r\n relatedPerson.RegistrationId = localStorage.getItem('RegistrationId');\r\n relatedPerson.RelatedPersonTitle = $('#ddlrelatedpersonchoose :selected').text();\r\n relatedPerson.RelatedPeronFirstName = $('#txtrelatedpersonfirstname').val().trim();\r\n relatedPerson.RelatedPeronMiddleName = $('#txtrelatedpersonmiddlename').val().trim();\r\n relatedPerson.RelatedPeronLastName = $('#txtrelatedpersonlastname').val().trim();\r\n relatedPerson.RelatedPersonCustomerRelation = $('#txtcustomerrelation').val().trim();\r\n relatedPerson.RelatedPersonType = RelatedPersonType;\r\n relatedPerson.RelatedPersonPANNo = $('#txtRelatedPan').val().trim();\r\n relatedPerson.RelatedPersonAadhaarNo = $('#txtRelatedAadhaar').val().trim();\r\n relatedPerson.RelatedPersonCourtOrderNo = $('#txtRelatedCourtOrderNo').val().trim();\r\n\r\n axios.post(relatedPersonDetilsUrl(), relatedPerson, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n if ($(\"#chkPAN1\").prop('checked') == true) {\r\n toggleTabVertical(tabId + 1);\r\n }\r\n else if ($(\"#chkPAN1\").prop('checked') == false) {\r\n toggleTabVertical(tabId + 2);\r\n }\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n }\r\n })\r\n }\r\n else if (tabId == 4) {\r\n\r\n //toggleTabVertical(tabId + 1);\r\n //return;\r\n\r\n var DeclarantAssessedTax = false;\r\n\r\n if ($(\"#rbaccessedtaxyes\").prop(\"checked\")) {\r\n DeclarantAssessedTax = true;\r\n }\r\n else if ($(\"#rbaccessedtaxno\").prop(\"checked\")) {\r\n DeclarantAssessedTax = false;\r\n }\r\n\r\n form60.RegistrationId = localStorage.getItem('RegistrationId');\r\n form60.DeclarantDocuments = \"\";\r\n form60.DeclarantTransactionParticulars = $('#txttransactionparticulars').val().trim();\r\n form60.DeclarantAmountofTransaction = $('#txttransactionsamount').val().trim();\r\n form60.DeclarantAssessedTax = DeclarantAssessedTax;\r\n form60.DetailsOfIncomeTax = $('#txtdetailsofincometax').val().trim();\r\n form60.ReasonForNoPan = $('#txtreasonfornopan').val().trim();\r\n\r\n axios.post(form60Url(), form60, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n toggleTabVertical(tabId + 1)\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n }\r\n })\r\n }\r\n else if (tabId == 5) {\r\n\r\n //toggleTabVertical(tabId + 1);\r\n //return;\r\n\r\n debugger;\r\n\r\n if ($('#ddloccupationdetails :selected').text() == \"Businessman\") {\r\n\r\n if ($('#txtlineofnusiness').val().trim() == \"\") {\r\n $('#txtlineofnusiness').focus();\r\n ErrorMessage(\"Line of Business is required!\");\r\n return;\r\n }\r\n else if ($('#txtbusinessname').val().trim() == \"\") {\r\n $('#txtbusinessname').focus();\r\n ErrorMessage(\"Business Name is required!\");\r\n return;\r\n }\r\n else if ($('#txtstartbusinessdate').val().trim() == \"\") {\r\n $('#txtstartbusinessdate').focus();\r\n ErrorMessage(\"Date of starting business is required!\");\r\n return;\r\n }\r\n else if ($('#txtbussinessaddress1').val().trim() == \"\") {\r\n $('#txtbussinessaddress1').focus();\r\n ErrorMessage(\"Address1 required!\");\r\n return;\r\n }\r\n else if ($('#txtbussinessaddress2').val().trim() == \"\") {\r\n $('#txtbussinessaddress2').focus();\r\n ErrorMessage(\"Address2 required!\");\r\n return;\r\n }\r\n else if ($('#txtbussinessaddress3').val().trim() == \"\") {\r\n $('#txtbussinessaddress3').focus();\r\n ErrorMessage(\"Address3 required!\");\r\n return;\r\n }\r\n }\r\n\r\n if ($(\"#rbtwowheeler\").prop(\"checked\")) {\r\n if ($('#txttwowheelermonth').val().trim() == \"\") {\r\n $('#txttwowheelermonth').focus();\r\n ErrorMessage(\"Two Wheeler month is required!\");\r\n return;\r\n }\r\n else if ($('#txttwowheeleryear').val().trim() == \"\") {\r\n $('#txttwowheeleryear').focus();\r\n ErrorMessage(\"Two Wheeler year is required!\");\r\n return;\r\n }\r\n else if (parseInt($('#txttwowheelermonth').val().trim()) > 12) {\r\n $('#txttwowheelermonth').focus();\r\n ErrorMessage(\"Two Wheeler month should be valid!\");\r\n return;\r\n }\r\n\r\n if (parseInt($('#txttwowheeleryear').val().trim()) > 2050) {\r\n $('#txttwowheeleryear').focus();\r\n ErrorMessage(\"Two Wheeler year should be valid!\");\r\n return;\r\n }\r\n }\r\n else if ($(\"#rbcar\").prop(\"checked\")) {\r\n if ($('#txtcarmonth').val().trim() == \"\") {\r\n $('#txtcarmonth').focus();\r\n ErrorMessage(\"Car month is required!\");\r\n return;\r\n }\r\n else if ($('#txtcaryear').val().trim() == \"\") {\r\n $('#txtcaryear').focus();\r\n ErrorMessage(\"Car year is required!\");\r\n return;\r\n }\r\n else if (parseInt($('#txtcarmonth').val().trim()) > 12) {\r\n $('#txtcarmonth').focus();\r\n ErrorMessage(\"Car month should be valid!\");\r\n return;\r\n }\r\n\r\n if (parseInt($('#txtcaryear').val().trim()) > 2050) {\r\n $('#txtcaryear').focus();\r\n ErrorMessage(\"Car year should be valid!\");\r\n return;\r\n }\r\n }\r\n\r\n else if ($(\"#rbother\").prop(\"checked\")) {\r\n if ($('#txtothermonth').val().trim() == \"\") {\r\n $('#txtothermonth').focus();\r\n ErrorMessage(\"Other month is required!\");\r\n return;\r\n }\r\n else if ($('#txtotheryear').val().trim() == \"\") {\r\n $('#txtotheryear').focus();\r\n ErrorMessage(\"Other year is required!\");\r\n return;\r\n }\r\n else if (parseInt($('#txtothermonth').val().trim()) > 12) {\r\n $('#txtothermonth').focus();\r\n ErrorMessage(\"Other month should be valid!\");\r\n return;\r\n }\r\n\r\n if (parseInt($('#txtotheryear').val().trim()) > 2050) {\r\n $('#txtotheryear').focus();\r\n ErrorMessage(\"Other year should be valid!\");\r\n return;\r\n }\r\n }\r\n\r\n var BornNonIndia = '';\r\n var TaxResidenceNonIndia = '';\r\n var VehicleType = '';\r\n var CarPurchaseYear = '';\r\n var InterestedIn = '';\r\n\r\n if ($(\"#rbbornyes\").prop(\"checked\")) {\r\n BornNonIndia = \"true\";\r\n }\r\n else if ($(\"#rbbornno\").prop(\"checked\")) {\r\n BornNonIndia = \"false\";\r\n }\r\n\r\n if ($(\"#rbtaxresidenceyes\").prop(\"checked\")) {\r\n TaxResidenceNonIndia = \"true\";\r\n }\r\n else if ($(\"#rbtaxresidenceno\").prop(\"checked\")) {\r\n TaxResidenceNonIndia = \"false\";\r\n }\r\n\r\n if ($(\"#rbtwowheeler\").prop(\"checked\")) {\r\n VehicleType = 'Two Wheeler';\r\n CarPurchaseYear = $('#txttwowheelermonth').val() + '-' + $('#txttwowheeleryear').val();\r\n }\r\n else if ($(\"#rbcar\").prop(\"checked\")) {\r\n VehicleType = 'Car';\r\n CarPurchaseYear = $('#txtcarmonth').val() + '-' + $('#txtcaryear').val();\r\n }\r\n else if ($(\"#rbother\").prop(\"checked\")) {\r\n VehicleType = 'Other';\r\n CarPurchaseYear = $('#txtothermonth').val() + '-' + $('#txtotheryear').val();\r\n }\r\n\r\n if ($(\"#chkmutualfunds\").prop(\"checked\")) {\r\n InterestedIn = InterestedIn + \"Mutual Funds\" + \", \";\r\n }\r\n if ($(\"#chkhealthinsurance\").prop(\"checked\")) {\r\n InterestedIn = InterestedIn + \"Health Insurance\" + \", \";\r\n }\r\n if ($(\"#chkgeneralinsurance\").prop(\"checked\")) {\r\n InterestedIn = InterestedIn + \"General Insurance\" + \", \";\r\n }\r\n if ($(\"#chkdemat\").prop(\"checked\")) {\r\n InterestedIn = InterestedIn + \"Demat\" + \", \";\r\n }\r\n if ($(\"#chkpmsby\").prop(\"checked\")) {\r\n InterestedIn = InterestedIn + \"Pradhan Mantri Suraksha Bima Yojana (PMSBY)\" + \", \";\r\n }\r\n if ($(\"#chkpmjjby\").prop(\"checked\")) {\r\n InterestedIn = InterestedIn + \"Pradhan Mantri Jeevan Jyoti Bima Yojana (PMJJBY)\" + \", \";\r\n }\r\n\r\n additionalDetails.RegistrationId = localStorage.getItem('RegistrationId');\r\n additionalDetails.FundsExpectedOrigin = $('#ddlfundsforcredit :selected').text();\r\n additionalDetails.FundsUtilisationExpected = $('#ddlfundsbydebit :selected').text();\r\n additionalDetails.OtherBankAccounts = $('#ddlotherbanksaccounts :selected').text();\r\n additionalDetails.Turnover = $('#txtturnover').val().trim();\r\n additionalDetails.AverageIncome = $('#txtaverageincome').val().trim();\r\n additionalDetails.AverageBalance = $('#txtexpectedincome').val().trim();\r\n additionalDetails.Education = $('#ddleducation :selected').text();\r\n additionalDetails.Religion = $('#ddlreligion :selected').text();\r\n additionalDetails.OccupationDetails = $('#ddloccupationdetails :selected').text();\r\n additionalDetails.LineOfBusiness = $('#txtlineofnusiness').val().trim();\r\n additionalDetails.BusinessName = $('#txtbusinessname').val().trim();\r\n additionalDetails.BusinessStartDate = $('#txtstartbusinessdate').val();\r\n additionalDetails.BusinessAddress1 = $('#txtbussinessaddress1').val().trim();\r\n additionalDetails.BusinessAddress2 = $('#txtbussinessaddress2').val().trim();\r\n additionalDetails.BusinessAddress3 = $('#txtbussinessaddress3').val().trim();\r\n additionalDetails.BusinessTelNo = $('#txtofficecontact').val().trim();\r\n additionalDetails.BusinessMobileNo = $('#txtofficemobileno').val().trim();\r\n additionalDetails.BusinessAnnualIncome = $('#ddlannualincome :selected').text();\r\n additionalDetails.BusinessIncomeSource = $('#txtsourceofincome').val().trim();\r\n additionalDetails.BusinessWealthSource = $('#txtsourceofwealth').val().trim();\r\n additionalDetails.BusinessEstimatedValue = $('#ddlestimatedvalue :selected').text();\r\n additionalDetails.BusinessAssetDetails = $('#ddlassetdetails :selected').text();\r\n additionalDetails.BornNonIndia = BornNonIndia;\r\n additionalDetails.TaxResidenceNonIndia = TaxResidenceNonIndia;\r\n additionalDetails.BusinessVehicleType = VehicleType;\r\n additionalDetails.BusinessCarPurchaseYear = CarPurchaseYear;\r\n additionalDetails.BusinessCarMaker = $('#txtcarmaker').val().trim();\r\n additionalDetails.InterestedIn = InterestedIn;\r\n\r\n axios.post(additionalDetailsUrl(), additionalDetails, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n toggleTabVertical(tabId + 1)\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n }\r\n })\r\n\r\n }\r\n else if (tabId == 6) {\r\n\r\n //toggleTabVertical(tabId + 1);\r\n //return;\r\n\r\n var DebitCard, SMSBanking, MobileBanking, StatementOnEmail, AadhaarCardSeeding, InterntBanking = \"false\";\r\n\r\n if ($(\"#switchdebitcard\").prop(\"checked\"))\r\n DebitCard = \"true\"\r\n else\r\n DebitCard = \"false\"\r\n\r\n if ($(\"#switchsmsbanking\").prop(\"checked\"))\r\n SMSBanking = \"true\"\r\n else\r\n SMSBanking = \"false\"\r\n\r\n if ($(\"#switchmobilebanking\").prop(\"checked\"))\r\n MobileBanking = \"true\"\r\n else\r\n MobileBanking = \"false\"\r\n\r\n if ($(\"#switchemail\").prop(\"checked\"))\r\n StatementOnEmail = \"true\"\r\n else\r\n StatementOnEmail = \"false\"\r\n\r\n if ($(\"#switchaadhaarcard\").prop(\"checked\"))\r\n AadhaarCardSeeding = \"true\"\r\n else\r\n AadhaarCardSeeding = \"false\"\r\n\r\n if ($(\"#switchinternetbanking\").prop(\"checked\"))\r\n InterntBanking = \"true\"\r\n else\r\n InterntBanking = \"false\"\r\n\r\n technoProducts.RegistrationId = localStorage.getItem('RegistrationId');\r\n technoProducts.DebitCard = DebitCard;\r\n technoProducts.SMSBanking = SMSBanking;\r\n technoProducts.MobileBanking = MobileBanking;\r\n technoProducts.StatementOnEmail = StatementOnEmail;\r\n technoProducts.AadhaarCardSeeding = AadhaarCardSeeding;\r\n technoProducts.InterntBanking = InterntBanking;\r\n\r\n axios.post(technoProductsUrl(), technoProducts, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n toggleTabVertical(tabId + 1)\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n }\r\n })\r\n }\r\n else if (tabId == 7) {\r\n\r\n //toggleTabVertical(tabId + 1);\r\n //return;\r\n\r\n var AccountOperations = \"\";\r\n if ($(\"#rbself\").prop(\"checked\")) {\r\n AccountOperations = \"Self\";\r\n }\r\n else if ($(\"#rbeither\").prop(\"checked\")) {\r\n AccountOperations = \"Either or surviver\";\r\n }\r\n else if ($(\"#rbformer\").prop(\"checked\")) {\r\n AccountOperations = \"Former or surviver\";\r\n }\r\n else if ($(\"#rbanyone\").prop(\"checked\")) {\r\n AccountOperations = \"Anyone or surviver\";\r\n }\r\n else if ($(\"#rbjointly\").prop(\"checked\")) {\r\n AccountOperations = \"Jointly by all\";\r\n }\r\n\r\n nominationDetails.RegistrationId = localStorage.getItem('RegistrationId');\r\n nominationDetails.NatureofDeposit = $('#txtnatureofdeposit').val().trim();\r\n nominationDetails.DistinguishingNo = $('#txtdistinguishingnumber').val().trim();\r\n nominationDetails.AdditionalDetails = $('#txtadditionaldetails').val().trim();\r\n nominationDetails.NomineeFirstName = $('#txtnomineefirstname').val().trim();\r\n nominationDetails.NomineeMiddleName = $('#txtnomineemiddlename').val().trim();\r\n nominationDetails.NomineeLastName = $('#txtnomineelastname').val().trim();\r\n nominationDetails.NomineeAddress1 = $('#txtnomineeaddress1').val().trim();\r\n nominationDetails.NomineeAddress2 = $('#txtnomineeaddress2').val().trim();\r\n nominationDetails.NomineeAddress3 = $('#txtnomineeaddress3').val().trim();\r\n nominationDetails.Relationship = $('#txtnomineerelationship').val().trim();\r\n nominationDetails.Age = $('#txtnomineeage').val().trim();\r\n nominationDetails.MinorDOB = $('#txtnomineeminordob').val();\r\n nominationDetails.AccountOperations = AccountOperations;\r\n\r\n axios.post(nominationDetailsUrl(), nominationDetails, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n toggleTabVertical(tabId + 1)\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n }\r\n })\r\n }\r\n else if (tabId == 8) {\r\n\r\n const createAccountModel = {\r\n RegistrationId: localStorage.getItem('RegistrationId')\r\n }\r\n\r\n try {\r\n axios.post(submitAccountUrl(), createAccountModel, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n var fileName = localStorage.getItem(\"ReferenceNo\") + \".pdf\";\r\n DownloadRegistrationPDF(fileName);\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n }\r\n }).catch(err => {\r\n console.log(err);\r\n });\r\n }\r\n catch (error) {\r\n console.log(error);\r\n }\r\n }\r\n }\r\n\r\n const [formRows, setFormRows] = useState([{ id: 1 }]);\r\n\r\n const onAddFormRow = () => {\r\n\r\n var validUsersCount = validation.values.users.length\r\n\r\n const modifiedRows = [...formRows];\r\n\r\n //if (modifiedRows.length + 1 <= validUsersCount) {\r\n // modifiedRows.push({ id: modifiedRows.length + 1 });\r\n // setFormRows(modifiedRows);\r\n //}\r\n modifiedRows.push({ id: modifiedRows.length + 1 });\r\n\r\n\r\n setFormRows(modifiedRows);\r\n //validation.values.users.push(objCustomer);\r\n //console.log(validation.values.users)\r\n\r\n console.log(formRows)\r\n };\r\n\r\n const [activeTab, setactiveTab] = useState(1)\r\n const [activeTabVartical, setoggleTabVertical] = useState(1)\r\n\r\n const [passedSteps, setPassedSteps] = useState([1])\r\n const [passedStepsVertical, setPassedStepsVertical] = useState([1])\r\n\r\n function toggleTab(tab) {\r\n if (activeTab !== tab) {\r\n var modifiedSteps = [...passedSteps, tab]\r\n if (tab >= 1 && tab <= 4) {\r\n setactiveTab(tab)\r\n setPassedSteps(modifiedSteps)\r\n }\r\n }\r\n }\r\n\r\n function toggleTabVertical(tab) {\r\n if (activeTabVartical !== tab) {\r\n var modifiedSteps = [...passedStepsVertical, tab]\r\n\r\n if (tab >= 1 && tab <= 8) {\r\n setoggleTabVertical(tab)\r\n setPassedStepsVertical(modifiedSteps)\r\n }\r\n }\r\n }\r\n\r\n function FillAddress(id) {\r\n debugger;\r\n\r\n if ($(\"#chkSameAs\" + id).prop(\"checked\")) {\r\n let comAddress1 = $('#txtCommunicationAddress1' + id).val();\r\n let comAddress2 = $('#txtCommunicationAddress2' + id).val();\r\n let comAddress3 = $('#txtCommunicationAddress3' + id).val();\r\n let comCity = $('#txtCommunicationCity' + id).val();\r\n let comPin = $('#txtCommunicationPincode' + id).val();\r\n let comState = $('#ddlCommunicationState' + id).val();\r\n\r\n $('#txtPermanentAddress1' + id).val(comAddress1);\r\n $('#txtPermanentAddress2' + id).val(comAddress2);\r\n $('#txtPermanentAddress3' + id).val(comAddress3);\r\n $('#txtPermanentCity' + id).val(comCity);\r\n $('#txtPermanentPincode' + id).val(comPin);\r\n $('#ddlPermanentState' + id).val(comState);\r\n\r\n validation.values.users[id - 1].permanentaddress = comAddress1;\r\n validation.values.users[id - 1].permanentstate = comState;\r\n validation.values.users[id - 1].permanentcity = comCity;\r\n validation.values.users[id - 1].permanentpincode = comPin;\r\n }\r\n else {\r\n $('#txtPermanentAddress1' + id).val('');\r\n $('#txtPermanentAddress2' + id).val('');\r\n $('#txtPermanentAddress3' + id).val('');\r\n $('#txtPermanentCity' + id).val('');\r\n $('#txtPermanentPincode' + id).val('');\r\n $('#ddlPermanentState' + id).val('');\r\n }\r\n }\r\n\r\n // Form validation\r\n const validation = useFormik({\r\n\r\n enableReinitialize: true,\r\n\r\n initialValues: {\r\n accounttype: '1',\r\n entitytype: '1',\r\n location: '',\r\n branch: '',\r\n fatherchoose: '',\r\n fatherlastname: '',\r\n fatherfirstname: '',\r\n motherchoose: '',\r\n motherlastname: '',\r\n motherfirstname: '',\r\n maidenchoose: '',\r\n maidenlastname: '',\r\n maidenfirstname: '',\r\n\r\n users: [objCustomerMainholder, objCustomer],\r\n\r\n pancard: '',\r\n mobileno: '',\r\n adharcard: '',\r\n mobilenumber: '',\r\n relatedpersonchoose: '',\r\n relatedpersonlastname: '',\r\n relatedpersonfirstname: '',\r\n relatedpersonrelation: '',\r\n relatedpersonpan: '',\r\n relatedpersonaadhar: '',\r\n\r\n transactionparticulars: '',\r\n transactionsamount: '',\r\n detailsofincometax: '',\r\n reasonfornopan: '',\r\n\r\n nomineenatureofdeposit: '',\r\n nomineedistinguishingnumber: '',\r\n nomineelastname: '',\r\n nomineefirstname: '',\r\n nomineeaddress1: '',\r\n nomineerelation: '',\r\n\r\n annualactivity: '',\r\n averageincome: '',\r\n expectedincome: '',\r\n officecontact: '',\r\n officemobileno: '',\r\n twowheelermonth: '',\r\n twowheeleryear: '',\r\n carmonth: '',\r\n caryear: '',\r\n anyothermonth: '',\r\n anyotheryear: ''\r\n },\r\n validationSchema: Yup.object({\r\n accounttype: Yup.string().required(\"Account Type required\"),\r\n entitytype: Yup.string().required(\"Entity Type required\"),\r\n location: Yup.string().required(\"Location required\"),\r\n branch: Yup.string().required(\"Branch required\"),\r\n fatherchoose: Yup.string().required(\"Father Title required\"),\r\n fatherlastname: Yup.string().required(\"Father Last Name required\"),\r\n fatherfirstname: Yup.string().required(\"Father First name required\"),\r\n motherchoose: Yup.string().required(\"Mother Title required\"),\r\n motherlastname: Yup.string().required(\"Mother Last name required\"),\r\n motherfirstname: Yup.string().required(\"Mother First name required\"),\r\n maidenchoose: Yup.string().required(\"Maiden Title required\"),\r\n maidenlastname: Yup.string().required(\"Maiden Last name required\"),\r\n maidenfirstname: Yup.string().required(\"Maiden First name required\"),\r\n\r\n users: Yup.array().of(\r\n Yup.object().shape({\r\n personalchoose: Yup.string().required(\"Title required\"),\r\n firstname: Yup.string().required(\"First Name required\"),\r\n middlename: Yup.string().required(\"Middle Name required\"),\r\n lastname: Yup.string().required(\"Last Name required\"),\r\n phoneno: Yup.string().required(\"Phone No. required\"),\r\n gender: Yup.string().required(\"Gender required\"),\r\n dob: Yup.string().required(\"Date of Birth required\"),\r\n maritalstatus: Yup.string().required(\"Maratial Status required\"),\r\n nationality: Yup.string().required(\"Nationality required\"),\r\n occupation: Yup.string().required(\"Occupation required\"),\r\n communicationaddress: Yup.string().required(\"Address 1 required\"),\r\n communicationstate: Yup.string().required(\"State required\"),\r\n communicationcity: Yup.string().required(\"City required\"),\r\n communicationpincode: Yup.number().required(\"Pincode required\"),\r\n permanentaddress: Yup.string().required(\"Address 1 required\"),\r\n permanentstate: Yup.string().required(\"State required\"),\r\n permanentcity: Yup.string().required(\"City required\"),\r\n permanentpincode: Yup.number().required(\"Pincode required\"),\r\n poi: Yup.string().required(\"POI required\"),\r\n poipoa: Yup.string().required(\"POI/POA required\"),\r\n pan: Yup.string().required(\"PAN No. required\"),\r\n panfile: Yup.string().required(\"PAN document required\"),\r\n })\r\n ),\r\n\r\n pancard: Yup.string().required(\"Please Enter A Valid PAN No\"),\r\n mobileno: Yup.number().required(\"10 Digit Mobile Number\"),\r\n adharcard: Yup.number().required(\"Please enter your ADHAR No\"),\r\n mobilenumber: Yup.number().required(\" Enter His Full Name\"),\r\n\r\n relatedpersonchoose: Yup.string().required(\"Title required\"),\r\n relatedpersonlastname: Yup.string().required(\"Last Name required\"),\r\n relatedpersonfirstname: Yup.string().required(\"First Name required\"),\r\n relatedpersonrelation: Yup.string().required(\"Customer Relation required\"),\r\n relatedpersonpan: Yup.string().required(\"PAN required\"),\r\n relatedpersonaadhar: Yup.string().required(\"Aadhaar required\"),\r\n\r\n transactionparticulars: Yup.string().required(\"Transaction Particulars required\"),\r\n transactionsamount: Yup.string().required(\"Amount of Transactions required\"),\r\n detailsofincometax: Yup.string().required(\"Details of income required\"),\r\n reasonfornopan: Yup.string().required(\"Reason for not having PAN required\"),\r\n\r\n nomineenatureofdeposit: Yup.string().required(\"Nature of deposit required\"),\r\n nomineedistinguishingnumber: Yup.string().required(\"Distinguishing number required\"),\r\n nomineelastname: Yup.string().required(\"Last Name required\"),\r\n nomineefirstname: Yup.string().required(\"First Name required\"),\r\n nomineeaddress1: Yup.string().required(\"Address1 required\"),\r\n nomineerelation: Yup.string().required(\"Relation required\"),\r\n }),\r\n\r\n onSubmit: (values) => {\r\n //console.log(\"values\", values);\r\n }\r\n });\r\n\r\n function CheckIsValidUser(controlValues) {\r\n\r\n //console.log(controlValues)\r\n //console.log(controlValues[0])\r\n var isCheckIfUndefined;\r\n\r\n var x = Object.keys(controlValues[0])\r\n const modifiedRows = [...formRows];\r\n\r\n\r\n controlValues.map((customer, i) => {\r\n isCheckIfUndefined = x.map(p => {\r\n if (customer[p] === \"\" || customer[p] === undefined)\r\n return true\r\n else\r\n return false\r\n })\r\n })\r\n\r\n var checkResponse = isCheckIfUndefined.includes(true)\r\n // console.log(checkResponse)\r\n return checkResponse\r\n\r\n }\r\n\r\n function CheckIsValid(controlValues) {\r\n debugger;\r\n //console.log(controlValues)\r\n //console.log(controlValues[0])\r\n var x = Object.keys(controlValues[0])\r\n var isCheckIfUndefined = x.map(p => {\r\n if (controlValues[0][p] === \"\" || controlValues[0][p] === undefined) {\r\n if (p == \"pan\" && controlValues[0][p] == \"\" && $(`#chkPAN1`).prop('checked') || p == \"panfile\" && controlValues[0][p] == \"\" && $(`#chkPAN1`).prop('checked')) {\r\n return false\r\n }\r\n else if (p == \"email\") {\r\n return false;\r\n }\r\n return true\r\n }\r\n else\r\n return false\r\n })\r\n\r\n var checkResponse = isCheckIfUndefined.includes(true)\r\n return checkResponse\r\n }\r\n\r\n $(\".d-block\").flatpickr({\r\n dateFormat: \"d-M-Y\",\r\n altFormat: \"F j, Y\",\r\n maxDate: \"today\",\r\n disableMobile: \"true\"\r\n });\r\n\r\n $(\".maxFuture\").flatpickr({\r\n dateFormat: \"d-M-Y\",\r\n disableMobile: \"true\"\r\n });\r\n\r\n const tabHeading = {\r\n color: \"#9a084f\",\r\n fontWeight: \"bold\"\r\n }\r\n\r\n const label = {\r\n color: \"black\"\r\n }\r\n\r\n const formBackground = {\r\n borderRadius: 8,\r\n flex: 1,\r\n //backgroundColor: \"rgb(247 242 242)\",\r\n padding: \"15px\"\r\n }\r\n\r\n const cardBackground = {\r\n borderRadius: 8,\r\n flex: 1,\r\n //backgroundColor: \"rgb(247 242 242)\",\r\n }\r\n\r\n const formButton = {\r\n marginLeft: \"20px\",\r\n backgroundColor: \"#9a084f\",\r\n fontSize: \"small\",\r\n borderRadius: \"0.50rem\"\r\n }\r\n\r\n const formButtonFirstPage = {\r\n marginLeft: \"90px\",\r\n backgroundColor: \"#9a084f\",\r\n fontSize: \"larger\",\r\n borderRadius: \"0.50rem\"\r\n }\r\n\r\n const formMandatory = {\r\n color: \"red\",\r\n fontWeight: \"bold\"\r\n }\r\n\r\n return (\r\n
\r\n\r\n \r\n
\r\n JSB-Registration\r\n \r\n
\r\n \r\n \r\n \r\n \r\n {/*
*/}\r\n {/* */}\r\n {/* */}\r\n {/*

*/}\r\n {/*
*/}\r\n {/* */}\r\n {/* */}\r\n {/* */}\r\n {/* */}\r\n {/*
*/}\r\n {/* */}\r\n {/*
*/}\r\n
\r\n \r\n
\r\n \r\n \r\n \r\n \r\n \r\n
\r\n
\r\n \r\n {\r\n toggleTabVertical(1)\r\n }}\r\n disabled={!(passedStepsVertical || []).includes(1)}\r\n >\r\n 1 Personal Details\r\n \r\n \r\n \r\n {\r\n toggleTabVertical(2)\r\n }}\r\n disabled={!(passedStepsVertical || []).includes(2)}\r\n >\r\n 2{\" \"}\r\n Family Details\r\n \r\n \r\n \r\n {\r\n toggleTabVertical(3)\r\n }}\r\n disabled={!(passedStepsVertical || []).includes(3)}\r\n >\r\n 3 Realated person\r\n \r\n \r\n \r\n {\r\n toggleTabVertical(4)\r\n }}\r\n disabled={!(passedStepsVertical || []).includes(4)}\r\n >\r\n 4 Form no 60/61\r\n \r\n \r\n \r\n {\r\n toggleTabVertical(5)\r\n }}\r\n disabled={!(passedStepsVertical || []).includes(5)}\r\n >\r\n 5 Additional\r\n Details\r\n \r\n \r\n \r\n {\r\n toggleTabVertical(6)\r\n }}\r\n disabled={!(passedStepsVertical || []).includes(6)}\r\n >\r\n 6 Techno products\r\n \r\n \r\n \r\n {\r\n toggleTabVertical(7)\r\n }}\r\n disabled={!(passedStepsVertical || []).includes(7)}\r\n >\r\n 7 Nomination\r\n \r\n \r\n \r\n {\r\n toggleTabVertical(8)\r\n }}\r\n disabled={!(passedStepsVertical || []).includes(8)}\r\n >\r\n 8 Applicant\r\n Declaration\r\n \r\n \r\n
\r\n
\r\n\r\n
\r\n
\r\n \r\n \r\n\r\n \r\n
\r\n\r\n {/**/}\r\n \r\n \r\n
\r\n \r\n )\r\n}\r\n\r\nexport default Registration\r\n","import MetaTags from \"react-meta-tags\";\r\nimport React, { useState, useEffect } from \"react\"\r\nimport { Row, Col, CardBody, Card, Container } from \"reactstrap\";\r\nimport banner from \"../../assets/images/banner/banner.jpg\";\r\nimport { useHistory } from \"react-router-dom\";\r\n\r\nconst success = () => {\r\n const history = useHistory();\r\n const [referenceNo, setReferenceNo] = useState('');\r\n\r\n function GoToLogin() {\r\n history.push(\"/login\");\r\n }\r\n\r\n const cardBackground = {\r\n borderRadius: 15,\r\n flex: 1,\r\n marginTop: \"20px\",\r\n boxShadow: \"#504f4f6b 5px 5px 20px\",\r\n marginLeft: \"150px\",\r\n marginRight: \"150px\"\r\n }\r\n\r\n useEffect(() => {\r\n setReferenceNo(localStorage.getItem(\"ReferenceNo\"));\r\n localStorage.clear();\r\n }, []);\r\n\r\n return (\r\n
\r\n \r\n JSB-Success\r\n \r\n \r\n
\r\n \r\n \r\n \r\n \r\n
\r\n
\r\n

\r\n
\r\n
\r\n
\r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n \r\n \r\n \r\n\r\n \r\n
\r\n \r\n
\r\n \r\n );\r\n};\r\n\r\nexport default success\r\n\r\n\r\n","import React from \"react\"\r\nimport PropTypes from 'prop-types';\r\nimport { Circles } from \"react-loader-spinner\";\r\n\r\nfunction FormLoader({ loading }) {\r\n return (\r\n loading ?\r\n //
\r\n // \r\n //
\r\n
\r\n \r\n :\r\n /*
*/\r\n
\r\n \r\n
\r\n )\r\n};\r\n\r\nFormLoader.propTypes = {\r\n loading: PropTypes.bool\r\n}\r\n\r\nexport default FormLoader\r\n","import React, { useState, useEffect } from \"react\"\r\nimport axios from 'axios';\r\nimport authHeader from \"helpers/authHeader\";\r\nimport MetaTags from \"react-meta-tags\"\r\nimport Flatpickr from \"react-flatpickr\";\r\nimport {\r\n Card,\r\n CardBody,\r\n Table,\r\n Col,\r\n Container,\r\n Form,\r\n FormGroup,\r\n Input,\r\n InputGroup,\r\n Label,\r\n NavItem,\r\n NavLink,\r\n Row,\r\n Button,\r\n TabContent,\r\n TabPane,\r\n FormFeedback,\r\n\r\n} from \"reactstrap\"\r\n\r\n// Formik validation\r\nimport * as Yup from \"yup\";\r\nimport { ErrorMessage, useFormik } from \"formik\";\r\nimport { useHistory } from \"react-router-dom\";\r\nimport classnames from \"classnames\";\r\nimport toastr from \"toastr\";\r\nimport \"toastr/build/toastr.min.css\";\r\nimport { getAPIUrl, updatePersonalDetailsUrl, familyDetilsUrl, relatedPersonDetilsUrl, form60Url, updateAccountHoldersStatusUrl, getFirstAccountHolderDetailsUrl, additionalDetailsUrl, getCustomerAdditionalDetailsUrl } from \"../../helpers/fakebackend_helper\";\r\n\r\n//redux\r\nimport { useSelector, useDispatch } from \"react-redux\";\r\n\r\n//Get States\r\nimport { getState } from \"../../store/actions\";\r\n\r\n//Get Occupation\r\nimport { getOccupation } from \"../../store/actions\";\r\n\r\n//GetAll RelatedPersonType\r\nimport { getRelatedPersonType } from \"../../store/actions\";\r\n\r\n//GetAll Poi\r\nimport { getPoi } from \"../../store/actions\";\r\n\r\n//GetAll Education\r\nimport { getEducation } from \"../../store/actions\";\r\n\r\n//GetAll OccupationDetails\r\nimport { getOccupationDetails } from \"../../store/actions\";\r\n\r\n//GetAll AssetDetails\r\nimport { getAssetDetails } from \"../../store/actions\";\r\n\r\n//GetAll OtherBankAccounts\r\nimport { getOtherBankAccounts } from \"../../store/actions\";\r\n\r\n\r\nimport TableRows from './TableRows';\r\nimport PropTypes from 'prop-types';\r\n\r\nconst FirstHolder = () => {\r\n\r\n var getBase64 = async (file) => {\r\n return await new Promise((resolve, reject) => {\r\n const reader = new FileReader();\r\n reader.readAsDataURL(file);\r\n reader.onload = () => resolve(reader.result);\r\n reader.onerror = error => reject(error);\r\n });\r\n }\r\n\r\n //=============Define State====================\r\n const history = useHistory();\r\n\r\n const [branch, setBranch] = useState([]);\r\n const [showEasing, setshowEasing] = useState(\"swing\");\r\n const [hideEasing, sethideEasing] = useState(\"linear\");\r\n const [showMethod, setshowMethod] = useState(\"fadeIn\");\r\n const [hideMethod, sethideMethod] = useState(\"fadeOut\");\r\n const [showDuration, setshowDuration] = useState(300);\r\n const [hideDuration, sethideDuration] = useState(1000);\r\n const [timeOut, settimeOut] = useState(2000);\r\n const [extendedTimeOut, setextendedTimeOut] = useState(1000);\r\n\r\n const [firstHoldersData, setFirstHoldersData] = useState([]);\r\n const [emailError, setEmailError] = useState('');\r\n const [panError, setPanError] = useState('');\r\n const [aadharError, setAadharError] = useState('');\r\n const [isPreloader, setPreloader] = useState(false);\r\n const [date, setDate] = useState(new Date());\r\n \r\n function emailValidation(value) {\r\n debugger;\r\n const email = value.target.value;\r\n const regex = /^(([^<>()[\\]\\.,;:\\s@\\\"]+(\\.[^<>()[\\]\\.,;:\\s@\\\"]+)*)|(\\\".+\\\"))@(([^<>()[\\]\\.,;:\\s@\\\"]+\\.)+[^<>()[\\]\\.,;:\\s@\\\"]{2,})$/i;\r\n if (!email || regex.test(email)\r\n === false) {\r\n setEmailError('Enter valid Email!')\r\n return false;\r\n }\r\n else {\r\n setEmailError('')\r\n return true;\r\n }\r\n }\r\n\r\n function panValidation(pan) {\r\n const regex = /^([A-Z]){5}([0-9]){4}([A-Z]){1}?$/;\r\n if (!pan || regex.test(pan) === false) {\r\n return false;\r\n }\r\n else {\r\n return true;\r\n }\r\n }\r\n\r\n //function aadharValidation(uid) {\r\n // if (uid.length != 12) {\r\n // return false;\r\n // }\r\n\r\n // var Verhoeff = {\r\n // \"d\": [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],\r\n // [1, 2, 3, 4, 0, 6, 7, 8, 9, 5],\r\n // [2, 3, 4, 0, 1, 7, 8, 9, 5, 6],\r\n // [3, 4, 0, 1, 2, 8, 9, 5, 6, 7],\r\n // [4, 0, 1, 2, 3, 9, 5, 6, 7, 8],\r\n // [5, 9, 8, 7, 6, 0, 4, 3, 2, 1],\r\n // [6, 5, 9, 8, 7, 1, 0, 4, 3, 2],\r\n // [7, 6, 5, 9, 8, 2, 1, 0, 4, 3],\r\n // [8, 7, 6, 5, 9, 3, 2, 1, 0, 4],\r\n // [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]],\r\n // \"p\": [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],\r\n // [1, 5, 7, 6, 2, 8, 3, 0, 9, 4],\r\n // [5, 8, 0, 3, 7, 9, 6, 1, 4, 2],\r\n // [8, 9, 1, 6, 0, 4, 3, 5, 2, 7],\r\n // [9, 4, 5, 3, 1, 2, 6, 8, 7, 0],\r\n // [4, 2, 8, 6, 5, 7, 3, 9, 0, 1],\r\n // [2, 7, 9, 3, 8, 0, 6, 4, 1, 5],\r\n // [7, 0, 4, 6, 9, 1, 3, 2, 5, 8]],\r\n // \"j\": [0, 4, 3, 2, 1, 5, 6, 7, 8, 9],\r\n // \"check\": function (str) {\r\n // var c = 0;\r\n // str.replace(/\\D+/g, \"\").split(\"\").reverse().join(\"\").replace(/[\\d]/g, function (u, i) {\r\n // c = Verhoeff.d[c][Verhoeff.p[i % 8][parseInt(u, 10)]];\r\n // });\r\n // return c;\r\n\r\n // },\r\n // \"get\": function (str) {\r\n\r\n // var c = 0;\r\n // str.replace(/\\D+/g, \"\").split(\"\").reverse().join(\"\").replace(/[\\d]/g, function (u, i) {\r\n // c = Verhoeff.d[c][Verhoeff.p[(i + 1) % 8][parseInt(u, 10)]];\r\n // });\r\n // return Verhoeff.j[c];\r\n // }\r\n // };\r\n\r\n // String.prototype.verhoeffCheck = (function () {\r\n // var d = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],\r\n // [1, 2, 3, 4, 0, 6, 7, 8, 9, 5],\r\n // [2, 3, 4, 0, 1, 7, 8, 9, 5, 6],\r\n // [3, 4, 0, 1, 2, 8, 9, 5, 6, 7],\r\n // [4, 0, 1, 2, 3, 9, 5, 6, 7, 8],\r\n // [5, 9, 8, 7, 6, 0, 4, 3, 2, 1],\r\n // [6, 5, 9, 8, 7, 1, 0, 4, 3, 2],\r\n // [7, 6, 5, 9, 8, 2, 1, 0, 4, 3],\r\n // [8, 7, 6, 5, 9, 3, 2, 1, 0, 4],\r\n // [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]];\r\n // var p = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],\r\n // [1, 5, 7, 6, 2, 8, 3, 0, 9, 4],\r\n // [5, 8, 0, 3, 7, 9, 6, 1, 4, 2],\r\n // [8, 9, 1, 6, 0, 4, 3, 5, 2, 7],\r\n // [9, 4, 5, 3, 1, 2, 6, 8, 7, 0],\r\n // [4, 2, 8, 6, 5, 7, 3, 9, 0, 1],\r\n // [2, 7, 9, 3, 8, 0, 6, 4, 1, 5],\r\n // [7, 0, 4, 6, 9, 1, 3, 2, 5, 8]];\r\n\r\n // return function () {\r\n // var c = 0;\r\n // this.replace(/\\D+/g, \"\").split(\"\").reverse().join(\"\").replace(/[\\d]/g, function (u, i) {\r\n // c = d[c][p[i % 8][parseInt(u, 10)]];\r\n // });\r\n // return (c === 0);\r\n // };\r\n // })();\r\n\r\n // if (Verhoeff['check'](uid) === 0) {\r\n // return true;\r\n // } else {\r\n // return false;\r\n // }\r\n //}\r\n\r\n function aadharValidation(uid) {\r\n debugger;\r\n var regex = new RegExp(\"^[2-9]{1}[0-9]{3}[0-9]{4}[0-9]{4}$\");\r\n if (!uid || regex.test(uid) === false) {\r\n return false;\r\n }\r\n else {\r\n if (uid.length != 12) {\r\n return false;\r\n }\r\n\r\n var Verhoeff = {\r\n \"d\": [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],\r\n [1, 2, 3, 4, 0, 6, 7, 8, 9, 5],\r\n [2, 3, 4, 0, 1, 7, 8, 9, 5, 6],\r\n [3, 4, 0, 1, 2, 8, 9, 5, 6, 7],\r\n [4, 0, 1, 2, 3, 9, 5, 6, 7, 8],\r\n [5, 9, 8, 7, 6, 0, 4, 3, 2, 1],\r\n [6, 5, 9, 8, 7, 1, 0, 4, 3, 2],\r\n [7, 6, 5, 9, 8, 2, 1, 0, 4, 3],\r\n [8, 7, 6, 5, 9, 3, 2, 1, 0, 4],\r\n [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]],\r\n \"p\": [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],\r\n [1, 5, 7, 6, 2, 8, 3, 0, 9, 4],\r\n [5, 8, 0, 3, 7, 9, 6, 1, 4, 2],\r\n [8, 9, 1, 6, 0, 4, 3, 5, 2, 7],\r\n [9, 4, 5, 3, 1, 2, 6, 8, 7, 0],\r\n [4, 2, 8, 6, 5, 7, 3, 9, 0, 1],\r\n [2, 7, 9, 3, 8, 0, 6, 4, 1, 5],\r\n [7, 0, 4, 6, 9, 1, 3, 2, 5, 8]],\r\n \"j\": [0, 4, 3, 2, 1, 5, 6, 7, 8, 9],\r\n \"check\": function (str) {\r\n var c = 0;\r\n str.replace(/\\D+/g, \"\").split(\"\").reverse().join(\"\").replace(/[\\d]/g, function (u, i) {\r\n c = Verhoeff.d[c][Verhoeff.p[i % 8][parseInt(u, 10)]];\r\n });\r\n return c;\r\n\r\n },\r\n \"get\": function (str) {\r\n\r\n var c = 0;\r\n str.replace(/\\D+/g, \"\").split(\"\").reverse().join(\"\").replace(/[\\d]/g, function (u, i) {\r\n c = Verhoeff.d[c][Verhoeff.p[(i + 1) % 8][parseInt(u, 10)]];\r\n });\r\n return Verhoeff.j[c];\r\n }\r\n };\r\n\r\n String.prototype.verhoeffCheck = (function () {\r\n var d = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],\r\n [1, 2, 3, 4, 0, 6, 7, 8, 9, 5],\r\n [2, 3, 4, 0, 1, 7, 8, 9, 5, 6],\r\n [3, 4, 0, 1, 2, 8, 9, 5, 6, 7],\r\n [4, 0, 1, 2, 3, 9, 5, 6, 7, 8],\r\n [5, 9, 8, 7, 6, 0, 4, 3, 2, 1],\r\n [6, 5, 9, 8, 7, 1, 0, 4, 3, 2],\r\n [7, 6, 5, 9, 8, 2, 1, 0, 4, 3],\r\n [8, 7, 6, 5, 9, 3, 2, 1, 0, 4],\r\n [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]];\r\n var p = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],\r\n [1, 5, 7, 6, 2, 8, 3, 0, 9, 4],\r\n [5, 8, 0, 3, 7, 9, 6, 1, 4, 2],\r\n [8, 9, 1, 6, 0, 4, 3, 5, 2, 7],\r\n [9, 4, 5, 3, 1, 2, 6, 8, 7, 0],\r\n [4, 2, 8, 6, 5, 7, 3, 9, 0, 1],\r\n [2, 7, 9, 3, 8, 0, 6, 4, 1, 5],\r\n [7, 0, 4, 6, 9, 1, 3, 2, 5, 8]];\r\n\r\n return function () {\r\n var c = 0;\r\n this.replace(/\\D+/g, \"\").split(\"\").reverse().join(\"\").replace(/[\\d]/g, function (u, i) {\r\n c = d[c][p[i % 8][parseInt(u, 10)]];\r\n });\r\n return (c === 0);\r\n };\r\n })();\r\n\r\n if (Verhoeff['check'](uid) === 0) {\r\n return true;\r\n } else {\r\n return false;\r\n }\r\n }\r\n }\r\n\r\n function passportValidation(passport) {\r\n debugger;\r\n var regex = new RegExp(\"^[A-PR-WY][1-9]\\\\d\\\\s?\\\\d{4}[1-9]$\");\r\n if (!passport || regex.test(passport) === false) {\r\n return false;\r\n }\r\n else {\r\n return true;\r\n }\r\n }\r\n function licenseValidation(license) {\r\n debugger;\r\n var regex = new RegExp(\"^(([A-Z]{2}[0-9]{2})( )|([A-Z]{2}-[0-9]{2}))((19|20)[0-9][0-9])[0-9]{7}$\");\r\n if (!license || regex.test(license) === false) {\r\n return false;\r\n }\r\n else {\r\n return true;\r\n }\r\n }\r\n function voterIDValidation(voterId) {\r\n debugger;\r\n var regex = /^([A-Z]){3}([0-9]){7}?$/g;\r\n if (!voterId || regex.test(voterId) === false) {\r\n return false;\r\n }\r\n else {\r\n return true;\r\n }\r\n }\r\n\r\n function getCustomerAge() {\r\n debugger;\r\n var dob = new Date(validation.values.dob);\r\n var today = new Date();\r\n var age = Math.floor((today - dob) / (365.25 * 24 * 60 * 60 * 1000));\r\n return age;\r\n }\r\n\r\n function SuccessMessage(message) {\r\n toastr.options = {\r\n positionClass: \"toast-top-center\",\r\n timeOut: timeOut,\r\n extendedTimeOut: extendedTimeOut,\r\n closeButton: true,\r\n debug: false,\r\n progressBar: false,\r\n preventDuplicates: false,\r\n newestOnTop: false,\r\n showEasing: showEasing,\r\n hideEasing: hideEasing,\r\n showMethod: showMethod,\r\n hideMethod: hideMethod,\r\n showDuration: showDuration,\r\n hideDuration: hideDuration\r\n };\r\n\r\n toastr.success(message, \"Information\");\r\n }\r\n\r\n function ErrorMessage(message) {\r\n toastr.options = {\r\n positionClass: \"toast-top-center\",\r\n timeOut: timeOut,\r\n extendedTimeOut: extendedTimeOut,\r\n closeButton: true,\r\n debug: false,\r\n progressBar: false,\r\n preventDuplicates: false,\r\n newestOnTop: false,\r\n showEasing: showEasing,\r\n hideEasing: hideEasing,\r\n showMethod: showMethod,\r\n hideMethod: hideMethod,\r\n showDuration: showDuration,\r\n hideDuration: hideDuration\r\n };\r\n\r\n toastr.error(message, \"Error\");\r\n }\r\n\r\n //GetAll OtherBankAccounts\r\n const { otherBankAccountsData } = useSelector(state => ({\r\n otherBankAccountsData: state.Registration.otherBankAccountsData,\r\n }));\r\n\r\n //GetAll Education\r\n const { educationData } = useSelector(state => ({\r\n educationData: state.Registration.educationData,\r\n }));\r\n\r\n //GetAll OccupationDetails\r\n const { occupationDetailsData } = useSelector(state => ({\r\n occupationDetailsData: state.Registration.occupationDetailsData,\r\n }));\r\n\r\n //GetAll AssetDetails\r\n const { assetDetailsData } = useSelector(state => ({\r\n assetDetailsData: state.Registration.assetDetailsData,\r\n }));\r\n\r\n\r\n const dispatch = useDispatch();\r\n const { stateData } = useSelector(state => ({\r\n stateData: state.Registration.stateData,\r\n }));\r\n\r\n //GetAll Occupation\r\n const { occupationData } = useSelector(state => ({\r\n occupationData: state.Registration.occupationData,\r\n }));\r\n\r\n //GetAll Poi\r\n const { poiData } = useSelector(state => ({\r\n poiData: state.Registration.poiData,\r\n }));\r\n\r\n function chkNumeric(e) {\r\n let input = e.target.value;\r\n\r\n if (input == \"\") {\r\n validation.handleChange(e);\r\n }\r\n else if (typeof input !== \"undefined\") {\r\n var pattern = new RegExp(/^[0-9\\b]+$/);\r\n if (pattern.test(input)) {\r\n validation.handleChange(e);\r\n }\r\n }\r\n }\r\n\r\n const [rowsData, setRowsData] = useState([]);\r\n\r\n const addPoiRows = () => {\r\n debugger;\r\n if ($(\"#ddlPOI option:selected\").val() == \"\") {\r\n ErrorMessage(\"Please select Proof of Identity!\");\r\n $(\"#ddlPOI\").focus();\r\n return;\r\n }\r\n else if ($(\"#ddlPOIPOA option:selected\").val() == \"\") {\r\n ErrorMessage(\"Please select POI/POA!\");\r\n $(\"#ddlPOIPOA\").focus();\r\n return;\r\n }\r\n\r\n if (rowsData.some(person => person.SelectedProofofIdentity === $(\"#ddlPOI option:selected\").text())) {\r\n ErrorMessage($(\"#ddlPOI option:selected\").text() + \" is already exists!\");\r\n return;\r\n }\r\n\r\n const rowsInput = {\r\n poiid: '',\r\n SelectedProofofIdentity: $(\"#ddlPOI option:selected\").text(),\r\n EnterNumber: '',\r\n POIPOA: $(\"#ddlPOIPOA option:selected\").text(),\r\n Expiry: '',\r\n Upload: '',\r\n poifilepath: '',\r\n poifilepathurl: '',\r\n Delete: ''\r\n }\r\n setRowsData([...rowsData, rowsInput])\r\n }\r\n\r\n const deletePoiRows = (index) => {\r\n debugger;\r\n if (rowsData.length > 1) {\r\n const rows = [...rowsData];\r\n rows.splice(index, 1);\r\n setRowsData(rows);\r\n }\r\n else if (rowsData.length == 1) {\r\n ErrorMessage(\"Atleast one POI/POA document is Compulsory!\");\r\n }\r\n }\r\n\r\n const handleChange = (index, evnt) => {\r\n\r\n const { name, value } = evnt.target;\r\n const rowsInput = [...rowsData];\r\n rowsInput[index][name] = value;\r\n setRowsData(rowsInput);\r\n }\r\n\r\n const handleCheckChange = (index, evnt) => {\r\n\r\n const { name, checked } = evnt.target;\r\n const rowsInput = [...rowsData];\r\n rowsInput[index][name] = checked;\r\n setRowsData(rowsInput);\r\n }\r\n\r\n const handleUploadChange = (index, evnt) => {\r\n\r\n const { name, value } = evnt.target;\r\n const rowsInput = [...rowsData];\r\n rowsInput[index][name] = evnt.target.files[0];\r\n setRowsData(rowsInput);\r\n }\r\n\r\n //Upload files\r\n const [selectedPhotoFile, setSelectedPhotoFile] = React.useState(\"\");\r\n const [selectedFile, setSelectedFile] = React.useState(\"\");\r\n\r\n function handlePhotoUpload(event) {\r\n setSelectedPhotoFile(event.target.files[0]);\r\n }\r\n\r\n function handleUpload(event) {\r\n setSelectedFile(event.target.files[0]);\r\n }\r\n\r\n const registrationHoldersPOIList = [];\r\n\r\n var registrationHoldersPOI = {\r\n POI: '',\r\n POINo: '',\r\n IsPOI: '',\r\n IsPOA: '',\r\n ExpiryDate: '',\r\n Base64POI: ''\r\n }\r\n\r\n var objRegistrationHolders = {\r\n Title: '',\r\n FirstName: '',\r\n MiddleName: '',\r\n LastName: '',\r\n DOB: '',\r\n Gender: '',\r\n Nationality: '',\r\n Occupation: '',\r\n Mobile: '',\r\n Email: '',\r\n MartialStatus: '',\r\n LocalAddress1: '',\r\n LocalAddress2: '',\r\n LocalAddress3: '',\r\n LocalCity: '',\r\n LocalPin: '',\r\n LocalState: '',\r\n PermanentAddress1: '',\r\n PermanentAddress2: '',\r\n PermanentAddress3: '',\r\n PermanentCity: '',\r\n PermanentPin: '',\r\n PermanentState: '',\r\n PAN: '',\r\n Base64PAN: '',\r\n registrationHoldersPOI: registrationHoldersPOIList\r\n }\r\n\r\n const personalDetails = {\r\n RegistrationId: localStorage.getItem(\"registrationId\"),\r\n objRegistrationHolders: objRegistrationHolders\r\n }\r\n\r\n const familyDetails = {\r\n RegistrationId: '',\r\n FatherTitle: '',\r\n FatherFirstName: '',\r\n FatherMiddleName: '',\r\n FatherLastName: '',\r\n MotherTitle: '',\r\n MotherFirstName: '',\r\n MotherMiddleName: '',\r\n MotherLastName: '',\r\n MaidenTitle: '',\r\n MaidenFirstName: '',\r\n MaidenMiddleName: '',\r\n MaidenLastName: ''\r\n }\r\n\r\n const relatedPerson = {\r\n RegistrationId: '',\r\n RelatedPersonTitle: '',\r\n RelatedPeronFirstName: '',\r\n RelatedPeronMiddleName: '',\r\n RelatedPeronLastName: '',\r\n RelatedPersonCustomerRelation: '',\r\n RelatedPersonType: '',\r\n RelatedPersonPANNo: '',\r\n RelatedPersonAadhaarNo: '',\r\n RelatedPersonCourtOrderNo: ''\r\n }\r\n\r\n const form60 = {\r\n RegistrationId: '',\r\n DeclarantDocuments: '',\r\n DeclarantTransactionParticulars: '',\r\n DeclarantAmountofTransaction: '',\r\n DeclarantAssessedTax: '',\r\n DetailsOfIncomeTax: '',\r\n ReasonForNoPan: ''\r\n }\r\n\r\n const additionalDetails = {\r\n RegistrationId: '',\r\n FundsExpectedOrigin: '',\r\n FundsUtilisationExpected: '',\r\n OtherBankAccounts: '',\r\n Turnover: '',\r\n AverageIncome: '',\r\n AverageBalance: '',\r\n Education: '',\r\n Religion: '',\r\n OccupationDetails: '',\r\n LineOfBusiness: '',\r\n BusinessName: '',\r\n BusinessStartDate: '',\r\n BusinessAddress1: '',\r\n BusinessAddress2: '',\r\n BusinessAddress3: '',\r\n BusinessTelNo: '',\r\n BusinessMobileNo: '',\r\n BusinessAnnualIncome: '',\r\n BusinessIncomeSource: '',\r\n BusinessWealthSource: '',\r\n BusinessEstimatedValue: '',\r\n BusinessAssetDetails: '',\r\n BornNonIndia: '',\r\n TaxResidenceNonIndia: '',\r\n BusinessVehicleType: '',\r\n BusinessCarPurchaseYear: '',\r\n BusinessCarMaker: '',\r\n InterestedIn: ''\r\n }\r\n\r\n const registrationHoldersId = localStorage.getItem('registrationHoldersId');\r\n\r\n useEffect(() => {\r\n debugger;\r\n if (isPreloader === true) {\r\n document.getElementById(\"preloader\").style.display = \"block\";\r\n document.getElementById(\"status\").style.display = \"block\";\r\n } else {\r\n document.getElementById(\"preloader\").style.display = \"none\";\r\n document.getElementById(\"status\").style.display = \"none\";\r\n }\r\n }, [isPreloader]);\r\n\r\n useEffect(() => {\r\n dispatch(getState());\r\n dispatch(getOccupation());\r\n dispatch(getRelatedPersonType());\r\n dispatch(getPoi());\r\n dispatch(getEducation());\r\n dispatch(getOccupationDetails());\r\n dispatch(getAssetDetails());\r\n dispatch(getOtherBankAccounts());\r\n GetFirstAccountHolderDetails();\r\n }, [dispatch]);\r\n\r\n function BindAdditionalDetails(additionalDetails) {\r\n debugger;\r\n if (additionalDetails != null) {\r\n additionalDetails.fundsExpectedOrigin == null ? $('#ddlfundsforcredit option:selected').val(1) : additionalDetails.fundsExpectedOrigin == '' ? $('#ddlfundsforcredit option:selected').val(1) : $('#ddlfundsforcredit option:selected').text(additionalDetails.fundsExpectedOrigin);\r\n additionalDetails.fundsUtilisationExpected == null ? $('#ddlfundsbydebit option:selected').val(1) : additionalDetails.fundsUtilisationExpected == '' ? $('#ddlfundsbydebit option:selected').val(1) : $('#ddlfundsbydebit option:selected').text(additionalDetails.fundsUtilisationExpected);\r\n additionalDetails.otherBankAccounts == null ? $('#ddlotherbanksaccounts option:selected').val(1) : additionalDetails.otherBankAccounts == '' ? $('#ddlotherbanksaccounts option:selected').val(1) : $('#ddlotherbanksaccounts option:selected').text(additionalDetails.otherBankAccounts);\r\n $('#txtturnover').val(additionalDetails.turnover);\r\n $('#txtaverageincome').val(additionalDetails.averageIncome);\r\n $('#txtexpectedincome').val(additionalDetails.averageBalance);\r\n additionalDetails.education == null ? $('#ddleducation option:selected').val(1) : additionalDetails.education == '' ? $('#ddleducation option:selected').val(1) : $('#ddleducation option:selected').text(additionalDetails.education);\r\n additionalDetails.religion == null ? $('#ddlreligion option:selected').val(1) : additionalDetails.religion == '' ? $('#ddlreligion option:selected').val(1) : $('#ddlreligion option:selected').text(additionalDetails.religion);\r\n additionalDetails.occupationDetails == null ? $('#ddloccupationdetails option:selected').val(1) : additionalDetails.occupationDetails == '' ? $('#ddloccupationdetails option:selected').val(1) : $('#ddloccupationdetails option:selected').text(additionalDetails.occupationDetails);\r\n $('#txtlineofnusiness').val(additionalDetails.lineOfBusiness);\r\n $('#txtbusinessname').val(additionalDetails.businessName);\r\n $('#txtstartbusinessdate').val(additionalDetails.businessStartDate);\r\n $('#txtbussinessaddress1').val(additionalDetails.businessAddress1);\r\n $('#txtbussinessaddress2').val(additionalDetails.businessAddress2);\r\n $('#txtbussinessaddress3').val(additionalDetails.businessAddress3);\r\n $('#txtofficecontact').val(additionalDetails.businessTelNo);\r\n $('#txtofficemobileno').val(additionalDetails.businessMobileNo);\r\n additionalDetails.businessAnnualIncome == null ? $('#ddlannualincome option:selected').val(1) : additionalDetails.businessAnnualIncome == '' ? $('#ddlannualincome option:selected').val(1) : $('#ddlannualincome option:selected').text(additionalDetails.businessAnnualIncome);\r\n $('#txtsourceofincome').val(additionalDetails.businessIncomeSource);\r\n $('#txtsourceofwealth').val(additionalDetails.businessWealthSource);\r\n additionalDetails.businessEstimatedValue == null ? $('#ddlestimatedvalue option:selected').val(1) : additionalDetails.businessEstimatedValue == '' ? $('#ddlestimatedvalue option:selected').val(1) : $('#ddlestimatedvalue option:selected').text(additionalDetails.businessEstimatedValue);\r\n additionalDetails.caste == null ? $('#caste option:selected').val(1) : additionalDetails.caste == '' ? $('#caste option:selected').val(1) : $('#caste option:selected').text(additionalDetails.caste);\r\n\r\n if (additionalDetails.businessAssetDetails != null) {\r\n if (additionalDetails.businessAssetDetails.length > 0) {\r\n if (additionalDetails.businessAssetDetails.includes('Commercial Property')) {\r\n $('#chkcommercialproperty').prop('checked', true);\r\n }\r\n else {\r\n $('#chkcommercialproperty').prop('checked', false);\r\n }\r\n\r\n if (additionalDetails.businessAssetDetails.includes('House')) {\r\n $('#chkhouse').prop('checked', true);\r\n }\r\n else {\r\n $('#chkhouse').prop('checked', false);\r\n }\r\n\r\n if (additionalDetails.businessAssetDetails.includes('Plot')) {\r\n $('#chkplot').prop('checked', true);\r\n }\r\n else {\r\n $('#chkplot').prop('checked', false);\r\n }\r\n\r\n if (additionalDetails.businessAssetDetails.includes('Others')) {\r\n $('#chkothers').prop('checked', true);\r\n }\r\n else {\r\n $('#chkothers').prop('checked', false);\r\n }\r\n }\r\n }\r\n\r\n if (additionalDetails.taxResidenceNonIndia != null) {\r\n if (additionalDetails.taxResidenceNonIndia == true) {\r\n $('#rbtaxresidenceyes').prop('checked', true);\r\n $('#rbtaxresidenceno').prop('checked', false);\r\n }\r\n else if (additionalDetails.taxResidenceNonIndia == false) {\r\n $('#rbtaxresidenceyes').prop('checked', false);\r\n $('#rbtaxresidenceno').prop('checked', true);\r\n }\r\n }\r\n\r\n if (additionalDetails.bornNonIndia != null) {\r\n if (additionalDetails.bornNonIndia == true) {\r\n $('#rbbornyes').prop('checked', true);\r\n $('#rbbornno').prop('checked', false);\r\n }\r\n else if (additionalDetails.bornNonIndia == false) {\r\n $('#rbbornyes').prop('checked', false);\r\n $('#rbbornno').prop('checked', true);\r\n }\r\n }\r\n\r\n if (additionalDetails.businessVehicleTwoWheeler != null) {\r\n if (additionalDetails.businessVehicleTwoWheeler.length > 0) {\r\n if (additionalDetails.businessVehicleTwoWheeler.includes('Two Wheeler')) {\r\n $('#chktwowheeler').prop('checked', true);\r\n $('#twowheeleryear').val(additionalDetails.businessTwoWheelerPurchaseYear);\r\n }\r\n else {\r\n $('#chktwowheeler').prop('checked', false);\r\n }\r\n }\r\n }\r\n\r\n if (additionalDetails.businessVehicleCar != null) {\r\n if (additionalDetails.businessVehicleCar.length > 0) {\r\n if (additionalDetails.businessVehicleCar.includes('Car')) {\r\n $('#chkcar').prop('checked', true);\r\n $('#txtcaryear').val(additionalDetails.businessCarPurchaseYear);\r\n }\r\n else {\r\n $('#chkcar').prop('checked', false);\r\n }\r\n }\r\n }\r\n\r\n if (additionalDetails.businessVehicleOther != null) {\r\n if (additionalDetails.businessVehicleOther.length > 0) {\r\n if (additionalDetails.businessVehicleOther.includes('Other')) {\r\n $('#chkother').prop('checked', true);\r\n $('#txtotheryear').val(additionalDetails.businessOtherPurchaseYear);\r\n }\r\n else {\r\n $('#chkother').prop('checked', false);\r\n }\r\n }\r\n }\r\n\r\n if (additionalDetails.interestedIn != null) {\r\n if (additionalDetails.interestedIn.length > 0) {\r\n if (additionalDetails.interestedIn.includes('Mutual Funds')) {\r\n $('#chkmutualfunds').prop('checked', true);\r\n }\r\n else {\r\n $('#chkmutualfunds').prop('checked', false);\r\n }\r\n\r\n if (additionalDetails.interestedIn.includes('Health Insurance')) {\r\n $('#chkhealthinsurance').prop('checked', true);\r\n }\r\n else {\r\n $('#chkhealthinsurance').prop('checked', false);\r\n }\r\n\r\n if (additionalDetails.interestedIn.includes('General Insurance')) {\r\n $('#chkgeneralinsurance').prop('checked', true);\r\n }\r\n else {\r\n $('#chkgeneralinsurance').prop('checked', false);\r\n }\r\n\r\n if (additionalDetails.interestedIn.includes('Demat')) {\r\n $('#chkdemat').prop('checked', true);\r\n }\r\n else {\r\n $('#chkdemat').prop('checked', false);\r\n }\r\n\r\n if (additionalDetails.interestedIn.includes('Pradhan Mantri Suraksha Bima Yojana (PMSBY)')) {\r\n $('#chkpmsby').prop('checked', true);\r\n }\r\n else {\r\n $('#chkpmsby').prop('checked', false);\r\n }\r\n\r\n if (additionalDetails.interestedIn.includes('Pradhan Mantri Jeevan Jyoti Bima Yojana (PMJJBY)')) {\r\n $('#chkpmjjby').prop('checked', true);\r\n }\r\n else {\r\n $('#chkpmjjby').prop('checked', false);\r\n }\r\n }\r\n }\r\n\r\n $('#txtcarmaker').val(additionalDetails.businessCarMaker);\r\n }\r\n }\r\n\r\n function GetFirstAccountHolderDetails() {\r\n debugger;\r\n const customerDetailModel = {\r\n RegistrationId: localStorage.getItem(\"registrationId\"),\r\n RegistrationHolderId: registrationHoldersId\r\n };\r\n\r\n setPreloader(true);\r\n\r\n axios.post(getFirstAccountHolderDetailsUrl(), customerDetailModel, { headers: authHeader() })\r\n .then(response => {\r\n debugger;\r\n if (response.data.length != 0 && response.data[0].relatedPersonType != null) {\r\n if (response.data[0].relatedPersonType.indexOf(\"Guardian of Minor\") != -1) {\r\n $('#rbguardian').prop('checked', true);\r\n $('#rbassignee').prop('checked', false);\r\n $('#rbauthorized').prop('checked', false);\r\n }\r\n if (response.data[0].relatedPersonType.indexOf(\"Assignee\") != -1) {\r\n $('#rbassignee').prop('checked', true);\r\n $('#rbguardian').prop('checked', false);\r\n $('#rbauthorized').prop('checked', false);\r\n }\r\n if (response.data[0].relatedPersonType.indexOf(\"Authorized representative\") != -1) {\r\n $('#rbauthorized').prop('checked', true);\r\n $('#rbguardian').prop('checked', false);\r\n $('#rbassignee').prop('checked', false);\r\n }\r\n }\r\n\r\n if (response.data.length != 0 && response.data[0].declarantAssessedTax != null) {\r\n if (response.data[0].declarantAssessedTax == true) {\r\n $('#rbaccessedtaxyes').prop('checked', true);\r\n $('#rbaccessedtaxno').prop('checked', false);\r\n }\r\n else if (response.data[0].declarantAssessedTax == false) {\r\n $('#rbaccessedtaxyes').prop('checked', false);\r\n $('#rbaccessedtaxno').prop('checked', true);\r\n }\r\n }\r\n\r\n if (response.data.length != 0 && response.data[0].isPAN != null) {\r\n if (response.data[0].isPAN == false) {\r\n $('#chkPAN').prop('checked', true);\r\n $(\"#txtPancard\").attr('disabled', 'disabled');\r\n $(\"#Upload\").attr('disabled', 'disabled');\r\n $(\"#txtPancard\").val('');\r\n }\r\n else if (response.data[0].isPAN == true) {\r\n $('#chkPAN').prop('checked', false);\r\n $(\"#txtPancard\").removeAttr('disabled');\r\n $(\"#Upload\").removeAttr('disabled');\r\n }\r\n }\r\n\r\n if (response.data.length == 0) {\r\n setFirstHoldersData(response.data);\r\n BindPOIPOA(response.data);\r\n setPreloader(false);\r\n return;\r\n }\r\n else if (response.data.length > 0) {\r\n if (response.data[0].photoFilePath != \"\") {\r\n $(\"#lnkPhotoDownload\").css(\"visibility\", \"visible\");\r\n $(\"#lnkPhotoDownload\").prop(\"href\", getAPIUrl() + \"/Photo/\" + response.data[0].photoFilePath);\r\n }\r\n\r\n if (response.data[0].panFilePath != \"\") {\r\n $(\"#lnkPANDownload\").css(\"visibility\", \"visible\");\r\n $(\"#lnkPANDownload\").prop(\"href\", getAPIUrl() + \"/POIFiles/\" + response.data[0].panFilePath);\r\n }\r\n\r\n BindAdditionalDetails(response.data[0]);\r\n setFirstHoldersData(response.data[0]);\r\n BindPOIPOA(response.data);\r\n setPreloader(false);\r\n }\r\n\r\n setPreloader(false);\r\n }, (error) => {\r\n console.log(error.response);\r\n setPreloader(false);\r\n })\r\n }\r\n\r\n function disablePAN() {\r\n if ($(\"#chkPAN\").prop('checked') == true) {\r\n $(\"#txtPancard\").attr('disabled', 'disabled');\r\n $(\"#Upload\").attr('disabled', 'disabled');\r\n $(\"#txtPancard\").val('');\r\n }\r\n else {\r\n $(\"#txtPancard\").removeAttr('disabled');\r\n $(\"#Upload\").removeAttr('disabled');\r\n }\r\n }\r\n\r\n function firstHolderSave(personalDetails, tabId) {\r\n debugger;\r\n if (selectedPhotoFile != '' && selectedFile != '') {\r\n\r\n setPreloader(true);\r\n getBase64(selectedPhotoFile).then(\r\n photodata => {\r\n objRegistrationHolders.Base64Photo = photodata;\r\n\r\n getBase64(selectedFile).then(\r\n poidata => {\r\n objRegistrationHolders.Base64PAN = poidata\r\n\r\n axios.post(updatePersonalDetailsUrl(), personalDetails, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n toggleTabVertical(tabId + 1);\r\n setPreloader(false);\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n setPreloader(false);\r\n }\r\n })\r\n }\r\n );\r\n }\r\n );\r\n }\r\n else if (selectedPhotoFile != '' && selectedFile == '') {\r\n\r\n setPreloader(true);\r\n objRegistrationHolders.Base64PAN = '';\r\n\r\n getBase64(selectedPhotoFile).then(\r\n photodata => {\r\n objRegistrationHolders.Base64Photo = photodata;\r\n\r\n axios.post(updatePersonalDetailsUrl(), personalDetails, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n toggleTabVertical(tabId + 1);\r\n setPreloader(false);\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n setPreloader(false);\r\n }\r\n })\r\n }\r\n );\r\n }\r\n else if (selectedPhotoFile == '' && selectedFile != '') {\r\n\r\n setPreloader(true);\r\n objRegistrationHolders.Base64Photo = '';\r\n\r\n getBase64(selectedFile).then(\r\n poidata => {\r\n objRegistrationHolders.Base64PAN = poidata;\r\n\r\n axios.post(updatePersonalDetailsUrl(), personalDetails, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n toggleTabVertical(tabId + 1);\r\n setPreloader(false);\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n setPreloader(false);\r\n }\r\n })\r\n }\r\n );\r\n }\r\n else if (selectedPhotoFile == '' && selectedFile == '') {\r\n\r\n setPreloader(true);\r\n objRegistrationHolders.Base64Photo = '';\r\n objRegistrationHolders.Base64PAN = '';\r\n\r\n axios.post(updatePersonalDetailsUrl(), personalDetails, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n toggleTabVertical(tabId + 1);\r\n setPreloader(false);\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n setPreloader(false);\r\n }\r\n })\r\n }\r\n }\r\n\r\n function CreateAccount(tabId) {\r\n debugger;\r\n var today = new Date();\r\n\r\n if (tabId == 1) {\r\n\r\n //toggleTabVertical(tabId + 1);\r\n //return;\r\n\r\n if ($('#txtPhoneno').val().length > 0) {\r\n if ($('#txtPhoneno').val().length != 10) {\r\n $('#txtPhoneno').focus();\r\n ErrorMessage(\"Please enter 10 digit Mobile number!\");\r\n return;\r\n }\r\n }\r\n\r\n if (($('#txtPancard').val().trim() == \"\") && ($(\"#chkPAN\").prop('checked') == false)) {\r\n $('#txtPancard').focus();\r\n ErrorMessage(\"Please enter PAN No. or check Form60!\");\r\n return;\r\n }\r\n\r\n if ($(\"#chkPAN\").prop('checked') == false) {\r\n $('#navForm60').css('background-color', 'lightgrey');\r\n }\r\n else {\r\n $('#navForm60').css('background-color', '');\r\n }\r\n\r\n if ($(\"#chkPAN\").prop('checked') == false) {\r\n if (!panValidation($('#txtPancard').val().trim())) {\r\n ErrorMessage('Please enter valid PAN Number!');\r\n $('#txtPancard').focus();\r\n return;\r\n }\r\n }\r\n\r\n var age = getCustomerAge();\r\n if (age > 18) {\r\n $('#navRelatedPerson').css('background-color', 'lightgrey');\r\n }\r\n else {\r\n $('#navRelatedPerson').css('background-color', '');\r\n }\r\n\r\n var IsValid = false;\r\n\r\n if (rowsData.length == 0) {\r\n ErrorMessage(\"Please add atleast one POI/POA document!\");\r\n return IsValid = false;\r\n }\r\n else {\r\n rowsData.map(poiCustomerData => {\r\n debugger;\r\n if (poiCustomerData.EnterNumber.trim().length == 0) {\r\n ErrorMessage(\"Please enter Document Number for \" + poiCustomerData.SelectedProofofIdentity + \"!\");\r\n return IsValid = false;\r\n }\r\n else if (poiCustomerData.Upload.length == 0 && poiCustomerData.poifilepath.length == 0) {\r\n ErrorMessage(\"Please uplaod document for \" + poiCustomerData.SelectedProofofIdentity + \"!\");\r\n return IsValid = false;\r\n }\r\n else {\r\n return IsValid = true;\r\n }\r\n })\r\n }\r\n\r\n\r\n rowsData.map(poiCustomerData => {\r\n if (poiCustomerData.EnterNumber.trim().length > 0) {\r\n if (poiCustomerData.SelectedProofofIdentity == \"Passport\" && (!passportValidation(poiCustomerData.EnterNumber))) {\r\n ErrorMessage('Please enter valid Passport Number!');\r\n return IsValid = false;\r\n }\r\n else if (poiCustomerData.SelectedProofofIdentity == \"UID\" && (!aadharValidation(poiCustomerData.EnterNumber))) {\r\n ErrorMessage('Please enter valid Aadhaar Number!');\r\n return IsValid = false;\r\n }\r\n else if (poiCustomerData.SelectedProofofIdentity == \"License\" && (!licenseValidation(poiCustomerData.EnterNumber))) {\r\n ErrorMessage('Please enter valid License Number!');\r\n return IsValid = false;\r\n }\r\n //else if (poiCustomerData.SelectedProofofIdentity == \"Voter ID\" && (!voterIDValidation(poiCustomerData.EnterNumber))) {\r\n // ErrorMessage('Please enter valid Voter ID Number!');\r\n // return IsValid = false;\r\n //}\r\n }\r\n })\r\n\r\n if (rowsData.find(p => p.POIPOA == \"POA & POI\") == undefined) {\r\n if (rowsData.find(p => p.POIPOA == \"POI\") == undefined) {\r\n ErrorMessage(\"Please add POI document!\");\r\n return IsValid = false;\r\n }\r\n else if (rowsData.find(p => p.POIPOA == \"POA\") == undefined) {\r\n ErrorMessage(\"Please add POA document!\");\r\n return IsValid = false;\r\n }\r\n }\r\n\r\n var age = getCustomerAge();\r\n var isPAN = \"true\";\r\n if ($(\"#chkPAN\").prop('checked') == true) {\r\n isPAN = \"false\";\r\n }\r\n\r\n if (IsValid) {\r\n objRegistrationHolders = {};\r\n\r\n objRegistrationHolders.Id = registrationHoldersId;\r\n objRegistrationHolders.Title = $('#ddlpersonalchoose').val();\r\n objRegistrationHolders.FirstName = $('#txtFirstName').val().trim();\r\n objRegistrationHolders.MiddleName = $('#txtMiddleName').val().trim();\r\n objRegistrationHolders.LastName = $('#txtLastName').val().trim();\r\n objRegistrationHolders.DOB = $('#txtdob').val();\r\n objRegistrationHolders.Gender = $('#ddlgender').val();\r\n objRegistrationHolders.Nationality = $('#ddlnationality').val();\r\n objRegistrationHolders.Occupation = $('#ddloccupation').val().trim();\r\n objRegistrationHolders.Mobile = $('#txtPhoneno').val().trim();\r\n objRegistrationHolders.Email = $('#txtEmailID').val().trim();\r\n objRegistrationHolders.MartialStatus = $('#ddlmaratialstatus').val();\r\n objRegistrationHolders.LocalAddress1 = $('#txtCommunicationAddress1').val().trim();\r\n objRegistrationHolders.LocalAddress2 = $('#txtCommunicationAddress2').val().trim();\r\n objRegistrationHolders.LocalAddress3 = $('#txtCommunicationAddress3').val().trim();\r\n objRegistrationHolders.LocalCity = $('#txtCommunicationCity').val().trim();\r\n objRegistrationHolders.LocalPin = $('#txtCommunicationPincode').val().trim();\r\n objRegistrationHolders.LocalState = $('#ddlCommunicationState').val();\r\n objRegistrationHolders.PermanentAddress1 = $('#txtPermanentAddress1').val().trim();\r\n objRegistrationHolders.PermanentAddress2 = $('#txtPermanentAddress2').val().trim();\r\n objRegistrationHolders.PermanentAddress3 = $('#txtPermanentAddress3').val().trim();\r\n objRegistrationHolders.PermanentCity = $('#txtPermanentCity').val().trim();\r\n objRegistrationHolders.PermanentPin = $('#txtPermanentPincode').val().trim();\r\n objRegistrationHolders.PermanentState = $('#ddlPermanentState').val();\r\n objRegistrationHolders.PAN = $('#txtPancard').val();\r\n objRegistrationHolders.IsMinor = age < 18 ? \"true\" : \"false\";\r\n objRegistrationHolders.isPAN = isPAN;\r\n objRegistrationHolders.CustomerId = $('#txtCustomerID').val().trim();\r\n objRegistrationHolders.CKYCNo = $('#txtCKYCNumber').val().trim();\r\n\r\n rowsData.map(poiCustomerData => {\r\n if (poiCustomerData.Upload != \"\") {\r\n getBase64(poiCustomerData.Upload).then(data => {\r\n registrationHoldersPOI = {};\r\n registrationHoldersPOI.POIId = poiCustomerData.poiid;\r\n registrationHoldersPOI.Base64POI = data;\r\n registrationHoldersPOI.POI = poiCustomerData.SelectedProofofIdentity;\r\n registrationHoldersPOI.POINo = poiCustomerData.EnterNumber;\r\n registrationHoldersPOI.POIPOA = poiCustomerData.POIPOA;\r\n registrationHoldersPOI.ExpiryDate = poiCustomerData.Expiry;\r\n registrationHoldersPOIList.push(registrationHoldersPOI);\r\n\r\n if (registrationHoldersPOIList.length == rowsData.length) {\r\n objRegistrationHolders.registrationHoldersPOI = registrationHoldersPOIList;\r\n personalDetails.objRegistrationHolders = objRegistrationHolders;\r\n\r\n firstHolderSave(personalDetails, tabId);\r\n }\r\n })\r\n }\r\n else {\r\n registrationHoldersPOI = {};\r\n registrationHoldersPOI.POIId = poiCustomerData.poiid;\r\n registrationHoldersPOI.Base64POI = \"\";\r\n registrationHoldersPOI.POI = poiCustomerData.SelectedProofofIdentity;\r\n registrationHoldersPOI.POINo = poiCustomerData.EnterNumber;\r\n registrationHoldersPOI.POIPOA = poiCustomerData.POIPOA;\r\n registrationHoldersPOI.ExpiryDate = poiCustomerData.Expiry;\r\n registrationHoldersPOIList.push(registrationHoldersPOI);\r\n\r\n if (registrationHoldersPOIList.length == rowsData.length) {\r\n objRegistrationHolders.registrationHoldersPOI = registrationHoldersPOIList;\r\n personalDetails.objRegistrationHolders = objRegistrationHolders;\r\n\r\n firstHolderSave(personalDetails, tabId);\r\n }\r\n }\r\n })\r\n }\r\n }\r\n else if (tabId == 2) {\r\n\r\n //toggleTabVertical(tabId + 1);\r\n //return;\r\n\r\n familyDetails.RegistrationId = localStorage.getItem('registrationId');\r\n familyDetails.FatherTitle = $('#ddlfatherchoose :selected').text();\r\n familyDetails.FatherFirstName = $('#txtFatherFirstName').val().trim();\r\n familyDetails.FatherMiddleName = $('#txtFatherMiddleName').val().trim();\r\n familyDetails.FatherLastName = $('#txtFatherLastName').val().trim();\r\n familyDetails.MotherTitle = $('#ddlmotherchoose :selected').text();\r\n familyDetails.MotherFirstName = $('#txtMotherFirstName').val().trim();\r\n familyDetails.MotherMiddleName = $('#txtMotherMiddleName').val().trim();\r\n familyDetails.MotherLastName = $('#txtMotherLastName').val().trim();\r\n familyDetails.MaidenTitle = $('#ddlmaidenchoose :selected').text();\r\n familyDetails.MaidenFirstName = $('#txtMaidenFirstName').val().trim();\r\n familyDetails.MaidenMiddleName = $('#txtMaidenMiddleName').val().trim();\r\n familyDetails.MaidenLastName = $('#txtMaidenLastName').val().trim();\r\n\r\n setPreloader(true);\r\n axios.post(familyDetilsUrl(), familyDetails, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n var age = getCustomerAge();\r\n\r\n if (age > 18) {\r\n if ($(\"#chkPAN\").prop('checked') == false) {\r\n toggleTabVertical(tabId + 3);\r\n setPreloader(false);\r\n }\r\n else {\r\n toggleTabVertical(tabId + 2);\r\n setPreloader(false);\r\n }\r\n }\r\n else {\r\n toggleTabVertical(tabId + 1);\r\n setPreloader(false);\r\n }\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n setPreloader(false);\r\n }\r\n })\r\n }\r\n else if (tabId == 3) {\r\n\r\n //toggleTabVertical(tabId + 1);\r\n //return;\r\n\r\n if (!panValidation($('#txtRelatedPan').val().trim())) {\r\n ErrorMessage('Please enter valid PAN Number!');\r\n $('#txtPancard').focus();\r\n return;\r\n }\r\n if ($('#txtRelatedAadhaar').val().trim().length > 0) {\r\n if (!aadharValidation($('#txtRelatedAadhaar').val().trim())) {\r\n ErrorMessage('Please enter valid Aadhaar Number!');\r\n return;\r\n }\r\n }\r\n //if (!aadharValidation($('#txtRelatedAadhaar').val().trim())) {\r\n // ErrorMessage('Please enter valid Aadhaar Number!');\r\n // return;\r\n //}\r\n\r\n var RelatedPersonType = \"\";\r\n if ($(\"#rbguardian\").prop('checked') == true) {\r\n RelatedPersonType = \"Guardian of Minor\";\r\n }\r\n else if ($(\"#rbassignee\").prop('checked') == true) {\r\n RelatedPersonType = \"Assignee\";\r\n }\r\n else if ($(\"#rbauthorized\").prop('checked') == true) {\r\n RelatedPersonType = \"Authorized representative\";\r\n }\r\n\r\n relatedPerson.RegistrationId = localStorage.getItem('registrationId');\r\n relatedPerson.RelatedPersonTitle = $('#ddlrelatedpersonchoose :selected').text();\r\n relatedPerson.RelatedPeronFirstName = $('#txtrelatedpersonfirstname').val().trim();\r\n relatedPerson.RelatedPeronMiddleName = $('#txtrelatedpersonmiddlename').val().trim();\r\n relatedPerson.RelatedPeronLastName = $('#txtrelatedpersonlastname').val().trim();\r\n relatedPerson.RelatedPersonCustomerRelation = $('#txtcustomerrelation').val().trim();\r\n relatedPerson.RelatedPersonType = RelatedPersonType;\r\n relatedPerson.RelatedPersonPANNo = $('#txtRelatedPan').val().trim();\r\n relatedPerson.RelatedPersonAadhaarNo = $('#txtRelatedAadhaar').val().trim();\r\n relatedPerson.RelatedPersonCourtOrderNo = $('#txtRelatedCourtOrderNo').val().trim();\r\n\r\n setPreloader(true);\r\n axios.post(relatedPersonDetilsUrl(), relatedPerson, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n if ($(\"#chkPAN\").prop('checked') == true) {\r\n toggleTabVertical(tabId + 1);\r\n setPreloader(false);\r\n }\r\n else if ($(\"#chkPAN\").prop('checked') == false) {\r\n toggleTabVertical(tabId + 2);\r\n setPreloader(false);\r\n }\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n setPreloader(false);\r\n }\r\n })\r\n }\r\n else if (tabId == 4) {\r\n\r\n //toggleTabVertical(tabId + 1);\r\n //return;\r\n\r\n var DeclarantAssessedTax = false;\r\n\r\n if ($(\"#rbaccessedtaxyes\").prop(\"checked\")) {\r\n DeclarantAssessedTax = true;\r\n }\r\n else if ($(\"#rbaccessedtaxno\").prop(\"checked\")) {\r\n DeclarantAssessedTax = false;\r\n }\r\n\r\n form60.RegistrationId = localStorage.getItem('registrationId');\r\n form60.RegistrationHolderId = registrationHoldersId;\r\n form60.DeclarantDocuments = \"\";\r\n form60.DeclarantTransactionParticulars = $('#txttransactionparticulars').val().trim();\r\n form60.DeclarantAmountofTransaction = $('#txttransactionsamount').val().trim();\r\n form60.DeclarantAssessedTax = DeclarantAssessedTax;\r\n form60.DetailsOfIncomeTax = $('#txtdetailsofincometax').val().trim();\r\n form60.ReasonForNoPan = $('#txtreasonfornopan').val().trim();\r\n\r\n setPreloader(true);\r\n axios.post(form60Url(), form60, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n toggleTabVertical(tabId + 1);\r\n setPreloader(false);\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n setPreloader(false);\r\n }\r\n })\r\n }\r\n else if (tabId == 5) {\r\n if ($('#ddloccupationdetails :selected').text() == \"Businessman\") {\r\n\r\n if ($('#txtlineofnusiness').val().trim() == \"\") {\r\n $('#txtlineofnusiness').focus();\r\n ErrorMessage(\"Line of Business is required!\");\r\n return;\r\n }\r\n else if ($('#txtbusinessname').val().trim() == \"\") {\r\n $('#txtbusinessname').focus();\r\n ErrorMessage(\"Business Name is required!\");\r\n return;\r\n }\r\n else if ($('#txtstartbusinessdate').val().trim() == \"\") {\r\n $('#txtstartbusinessdate').focus();\r\n ErrorMessage(\"Date of starting business is required!\");\r\n return;\r\n }\r\n else if ($('#txtbussinessaddress1').val().trim() == \"\") {\r\n $('#txtbussinessaddress1').focus();\r\n ErrorMessage(\"Address1 required!\");\r\n return;\r\n }\r\n else if ($('#txtbussinessaddress2').val().trim() == \"\") {\r\n $('#txtbussinessaddress2').focus();\r\n ErrorMessage(\"Address2 required!\");\r\n return;\r\n }\r\n }\r\n\r\n if ($('#txtofficemobileno').val().length > 0) {\r\n if ($('#txtofficemobileno').val().length != 10) {\r\n $('#txtofficemobileno').focus();\r\n ErrorMessage(\"Please enter 10 digit Mobile number!\");\r\n return;\r\n }\r\n }\r\n\r\n if ($(\"#chktwowheeler\").prop(\"checked\")) {\r\n debugger;\r\n if ($('#txttwowheeleryear').val().trim() == \"\") {\r\n $('#txttwowheeleryear').focus();\r\n ErrorMessage(\"Two Wheeler year is required!\");\r\n return;\r\n }\r\n if (parseInt($('#txttwowheeleryear').val().trim()) > today.getFullYear()) {\r\n $('#txttwowheeleryear').focus();\r\n ErrorMessage(\"Two Wheeler year should be valid!\");\r\n return;\r\n }\r\n }\r\n if ($(\"#chkcar\").prop(\"checked\")) {\r\n if ($('#txtcaryear').val().trim() == \"\") {\r\n $('#txtcaryear').focus();\r\n ErrorMessage(\"Car year is required!\");\r\n return;\r\n }\r\n\r\n if (parseInt($('#txtcaryear').val().trim()) > today.getFullYear()) {\r\n $('#txtcaryear').focus();\r\n ErrorMessage(\"Car year should be valid!\");\r\n return;\r\n }\r\n }\r\n if ($(\"#chkother\").prop(\"checked\")) {\r\n if ($('#txtotheryear').val().trim() == \"\") {\r\n $('#txtotheryear').focus();\r\n ErrorMessage(\"Other year is required!\");\r\n return;\r\n }\r\n\r\n if (parseInt($('#txtotheryear').val().trim()) > today.getFullYear()) {\r\n $('#txtotheryear').focus();\r\n ErrorMessage(\"Other year should be valid!\");\r\n return;\r\n }\r\n }\r\n\r\n var BornNonIndia = '';\r\n var TaxResidenceNonIndia = '';\r\n var BusinessVehicleTwoWheeler = '';\r\n var BusinessVehicleCar = '';\r\n var BusinessVehicleOther = '';\r\n var BusinessTwoWheelerPurchaseYear = '';\r\n var BusinessCarPurchaseYear = '';\r\n var BusinessOtherPurchaseYear = '';\r\n var InterestedIn = '';\r\n var BusinessAssetDetails = '';\r\n\r\n if ($(\"#rbbornyes\").prop(\"checked\")) {\r\n BornNonIndia = \"true\";\r\n }\r\n else if ($(\"#rbbornno\").prop(\"checked\")) {\r\n BornNonIndia = \"false\";\r\n }\r\n\r\n if ($(\"#rbtaxresidenceyes\").prop(\"checked\")) {\r\n TaxResidenceNonIndia = \"true\";\r\n }\r\n else if ($(\"#rbtaxresidenceno\").prop(\"checked\")) {\r\n TaxResidenceNonIndia = \"false\";\r\n }\r\n\r\n if ($(\"#chktwowheeler\").prop(\"checked\")) {\r\n BusinessVehicleTwoWheeler = 'Two Wheeler';\r\n BusinessTwoWheelerPurchaseYear = $('#txttwowheeleryear').val();\r\n }\r\n if ($(\"#chkcar\").prop(\"checked\")) {\r\n BusinessVehicleCar = 'Car';\r\n BusinessCarPurchaseYear = $('#txtcaryear').val();\r\n }\r\n if ($(\"#chkother\").prop(\"checked\")) {\r\n BusinessVehicleOther = 'Other';\r\n BusinessOtherPurchaseYear = $('#txtotheryear').val();\r\n }\r\n\r\n if ($(\"#chkcommercialproperty\").prop(\"checked\")) {\r\n BusinessAssetDetails = BusinessAssetDetails + \"Commercial Property\" + \", \";\r\n }\r\n if ($(\"#chkhouse\").prop(\"checked\")) {\r\n BusinessAssetDetails = BusinessAssetDetails + \"House\" + \", \";\r\n }\r\n if ($(\"#chkplot\").prop(\"checked\")) {\r\n BusinessAssetDetails = BusinessAssetDetails + \"Plot\" + \", \";\r\n }\r\n if ($(\"#chkothers\").prop(\"checked\")) {\r\n BusinessAssetDetails = BusinessAssetDetails + \"Others\" + \", \";\r\n }\r\n\r\n if ($(\"#chktwowheeler\").prop(\"checked\")) {\r\n BusinessVehicleTwoWheeler = \"Two Wheeler\";\r\n }\r\n if ($(\"#chkcar\").prop(\"checked\")) {\r\n BusinessVehicleCar = \"Car\";\r\n }\r\n if ($(\"#chkother\").prop(\"checked\")) {\r\n BusinessVehicleOther = \"Other\";\r\n }\r\n\r\n if ($(\"#chkmutualfunds\").prop(\"checked\")) {\r\n InterestedIn = InterestedIn + \"Mutual Funds\" + \", \";\r\n }\r\n if ($(\"#chkhealthinsurance\").prop(\"checked\")) {\r\n InterestedIn = InterestedIn + \"Health Insurance\" + \", \";\r\n }\r\n if ($(\"#chkgeneralinsurance\").prop(\"checked\")) {\r\n InterestedIn = InterestedIn + \"General Insurance\" + \", \";\r\n }\r\n if ($(\"#chkdemat\").prop(\"checked\")) {\r\n InterestedIn = InterestedIn + \"Demat\" + \", \";\r\n }\r\n if ($(\"#chkpmsby\").prop(\"checked\")) {\r\n InterestedIn = InterestedIn + \"Pradhan Mantri Suraksha Bima Yojana (PMSBY)\" + \", \";\r\n }\r\n if ($(\"#chkpmjjby\").prop(\"checked\")) {\r\n InterestedIn = InterestedIn + \"Pradhan Mantri Jeevan Jyoti Bima Yojana (PMJJBY)\" + \", \";\r\n }\r\n\r\n additionalDetails.RegistrationId = localStorage.getItem('registrationId');\r\n additionalDetails.RegistrationHolderId = registrationHoldersId;\r\n additionalDetails.FundsExpectedOrigin = $('#ddlfundsforcredit :selected').text();\r\n additionalDetails.FundsUtilisationExpected = $('#ddlfundsbydebit :selected').text();\r\n additionalDetails.OtherBankAccounts = $('#ddlotherbanksaccounts :selected').text();\r\n additionalDetails.Turnover = $('#txtturnover').val().trim();\r\n additionalDetails.AverageIncome = $('#txtaverageincome').val().trim();\r\n additionalDetails.AverageBalance = $('#txtexpectedincome').val().trim();\r\n additionalDetails.Education = $('#ddleducation :selected').text();\r\n additionalDetails.Religion = $('#ddlreligion :selected').text();\r\n additionalDetails.OccupationDetails = $('#ddloccupationdetails :selected').text();\r\n additionalDetails.LineOfBusiness = $('#txtlineofnusiness').val().trim();\r\n additionalDetails.BusinessName = $('#txtbusinessname').val().trim();\r\n additionalDetails.BusinessStartDate = $('#txtstartbusinessdate').val();\r\n additionalDetails.BusinessAddress1 = $('#txtbussinessaddress1').val().trim();\r\n additionalDetails.BusinessAddress2 = $('#txtbussinessaddress2').val().trim();\r\n additionalDetails.BusinessAddress3 = $('#txtbussinessaddress3').val().trim();\r\n additionalDetails.BusinessTelNo = $('#txtofficecontact').val().trim();\r\n additionalDetails.BusinessMobileNo = $('#txtofficemobileno').val().trim();\r\n additionalDetails.BusinessAnnualIncome = $('#ddlannualincome :selected').text();\r\n additionalDetails.BusinessIncomeSource = $('#txtsourceofincome').val().trim();\r\n additionalDetails.BusinessWealthSource = $('#txtsourceofwealth').val().trim();\r\n additionalDetails.BusinessEstimatedValue = $('#ddlestimatedvalue :selected').text();\r\n additionalDetails.BusinessAssetDetails = BusinessAssetDetails;\r\n additionalDetails.BornNonIndia = BornNonIndia;\r\n additionalDetails.TaxResidenceNonIndia = TaxResidenceNonIndia;\r\n additionalDetails.BusinessVehicleTwoWheeler = BusinessVehicleTwoWheeler;\r\n additionalDetails.BusinessVehicleCar = BusinessVehicleCar;\r\n additionalDetails.BusinessVehicleOther = BusinessVehicleOther;\r\n additionalDetails.BusinessTwoWheelerPurchaseYear = BusinessTwoWheelerPurchaseYear;\r\n additionalDetails.BusinessCarPurchaseYear = BusinessCarPurchaseYear;\r\n additionalDetails.BusinessOtherPurchaseYear = BusinessOtherPurchaseYear;\r\n additionalDetails.BusinessCarMaker = $('#txtcarmaker').val().trim();\r\n additionalDetails.InterestedIn = InterestedIn;\r\n additionalDetails.caste = $('#caste :selected').text();\r\n\r\n setPreloader(true);\r\n axios.post(additionalDetailsUrl(), additionalDetails, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n toggleTabVertical(tabId + 1);\r\n setPreloader(false);\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n setPreloader(false);\r\n }\r\n })\r\n }\r\n else if (tabId == 6) {\r\n\r\n if ($(\"#chkTerms\").prop('checked') == true) {\r\n const updateStatus = {\r\n RegistrationId: localStorage.getItem('registrationId'),\r\n RegistrationHolderId: registrationHoldersId\r\n };\r\n\r\n setPreloader(true);\r\n axios.post(updateAccountHoldersStatusUrl(), updateStatus, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n history.push(\"/CreateNewAccount\");\r\n setPreloader(false);\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n setPreloader(false);\r\n }\r\n })\r\n }\r\n else {\r\n ErrorMessage(\"Please select Terms & conditions\");\r\n $(\"#chkTerms\").focus();\r\n }\r\n }\r\n }\r\n\r\n const [activeTabVartical, setoggleTabVertical] = useState(1)\r\n const [passedStepsVertical, setPassedStepsVertical] = useState([1])\r\n const [communicationState, setCommunicationState] = useState(null)\r\n\r\n function SetCommunicationState(communicationState) {\r\n setCommunicationState(communicationState);\r\n }\r\n\r\n function toggleTabVertical(tab) {\r\n if (activeTabVartical !== tab) {\r\n var modifiedSteps = [...passedStepsVertical, tab]\r\n\r\n if (tab >= 1 && tab <= 6) {\r\n setoggleTabVertical(tab)\r\n setPassedStepsVertical(modifiedSteps)\r\n }\r\n }\r\n }\r\n\r\n function FillAddress() {\r\n\r\n if ($(\"#chkSameAs\").prop(\"checked\")) {\r\n let comAddress1 = $('#txtCommunicationAddress1').val();\r\n let comAddress2 = $('#txtCommunicationAddress2').val();\r\n let comAddress3 = $('#txtCommunicationAddress3').val();\r\n let comCity = $('#txtCommunicationCity').val();\r\n let comPin = $('#txtCommunicationPincode').val();\r\n let comState = $('#ddlCommunicationState').val();\r\n\r\n $('#txtPermanentAddress1').val(comAddress1);\r\n $('#txtPermanentAddress2').val(comAddress2);\r\n $('#txtPermanentAddress3').val(comAddress3);\r\n $('#txtPermanentCity').val(comCity);\r\n $('#txtPermanentPincode').val(comPin);\r\n $('#ddlPermanentState').val(comState);\r\n\r\n validation.values.permanentaddress = comAddress1;\r\n validation.values.permanentaddress2 = comAddress2;\r\n validation.values.permanentaddress3 = comAddress3;\r\n validation.values.permanentstate = comState;\r\n validation.values.permanentcity = comCity;\r\n validation.values.permanentpincode = comPin;\r\n }\r\n else {\r\n $('#txtPermanentAddress1').val('');\r\n $('#txtPermanentAddress2').val('');\r\n $('#txtPermanentAddress3').val('');\r\n $('#txtPermanentCity').val('');\r\n $('#txtPermanentPincode').val('');\r\n $('#ddlPermanentState').val('');\r\n }\r\n }\r\n\r\n var authCustomerObject = JSON.parse(localStorage.getItem('authCustomer'));\r\n\r\n\r\n // Form validation\r\n const validation = useFormik({\r\n\r\n enableReinitialize: true,\r\n\r\n initialValues: {\r\n\r\n personalchoose: firstHoldersData.title == null ? '' : firstHoldersData.title,\r\n firstname: firstHoldersData.firstName == null ? '' : firstHoldersData.firstName,\r\n middlename: firstHoldersData.middleName == null ? '' : firstHoldersData.middleName,\r\n lastname: firstHoldersData.lastName == null ? '' : firstHoldersData.lastName,\r\n //phoneno: firstHoldersData.mobile == null ? '' : firstHoldersData.mobile,\r\n phoneno: firstHoldersData.mobile == null ? authCustomerObject.mobileNo : firstHoldersData.mobile,\r\n //email: firstHoldersData.email == null ? '' : firstHoldersData.email,\r\n email: firstHoldersData.email == null ? authCustomerObject.email == null ? '' : authCustomerObject.email : firstHoldersData.email,\r\n gender: firstHoldersData.gender == null ? '' : firstHoldersData.gender,\r\n occupation: firstHoldersData.occupation == null ? '' : firstHoldersData.occupation,\r\n dob: firstHoldersData.dob == null ? '' : firstHoldersData.dob,\r\n maritalstatus: firstHoldersData.length == 0 ? '2' : firstHoldersData.dob == null ? '2' : firstHoldersData.maritalStatus,\r\n nationality: firstHoldersData.length == 0 ? '1' : firstHoldersData.dob == null ? '1' : firstHoldersData.nationality,\r\n communicationaddress: firstHoldersData.localAddress1 == null ? '' : firstHoldersData.localAddress1,\r\n communicationaddress2: firstHoldersData.localAddress2 == null ? '' : firstHoldersData.localAddress2,\r\n communicationaddress3: firstHoldersData.localAddress3 == null ? '' : firstHoldersData.localAddress3,\r\n communicationstate: firstHoldersData.localState == null ? '' : firstHoldersData.localState,\r\n communicationcity: firstHoldersData.localCity == null ? '' : firstHoldersData.localCity,\r\n communicationpincode: firstHoldersData.localPin == null ? '' : firstHoldersData.localPin,\r\n permanentaddress: firstHoldersData.permanentAddress1 == null ? '' : firstHoldersData.permanentAddress1,\r\n permanentaddress2: firstHoldersData.permanentAddress2 == null ? '' : firstHoldersData.permanentAddress2,\r\n permanentaddress3: firstHoldersData.permanentAddress3 == null ? '' : firstHoldersData.permanentAddress3,\r\n permanentstate: firstHoldersData.permanentState == null ? '' : firstHoldersData.permanentState,\r\n permanentcity: firstHoldersData.permanentCity == null ? '' : firstHoldersData.permanentCity,\r\n permanentpincode: firstHoldersData.permanentPin == null ? '' : firstHoldersData.permanentPin,\r\n poi: '',\r\n poipoa: '',\r\n pan: firstHoldersData.pan == null ? '' : firstHoldersData.pan,\r\n panfile: '',\r\n poifilePath: firstHoldersData.poiFilePath == null ? '' : firstHoldersData.poiFilePath,\r\n customerid: firstHoldersData.customerId == null ? '' : firstHoldersData.customerId,\r\n ckycno: firstHoldersData.ckycNo == null ? '' : firstHoldersData.ckycNo,\r\n photofile: '',\r\n photofilepath: firstHoldersData.photoFilePath == null ? '' : firstHoldersData.photoFilePath,\r\n\r\n fatherchoose: firstHoldersData.fatherTitle == null ? '' : firstHoldersData.fatherTitle,\r\n fatherlastname: firstHoldersData.fatherLastName == null ? '' : firstHoldersData.fatherLastName,\r\n fatherfirstname: firstHoldersData.fatherFirstName == null ? '' : firstHoldersData.fatherFirstName,\r\n fathermiddlename: firstHoldersData.fatherMiddleName == null ? '' : firstHoldersData.fatherMiddleName,\r\n motherchoose: firstHoldersData.motherTitle == null ? '' : firstHoldersData.motherTitle,\r\n motherlastname: firstHoldersData.motherLastName == null ? '' : firstHoldersData.motherLastName,\r\n motherfirstname: firstHoldersData.motherFirstName == null ? '' : firstHoldersData.motherFirstName,\r\n mothermiddlename: firstHoldersData.motherMiddleName == null ? '' : firstHoldersData.motherMiddleName,\r\n maidenchoose: firstHoldersData.maidenTitle == null ? '' : firstHoldersData.maidenTitle,\r\n maidenlastname: firstHoldersData.maidenLastName == null ? '' : firstHoldersData.maidenLastName,\r\n maidenfirstname: firstHoldersData.maidenFirstName == null ? '' : firstHoldersData.maidenFirstName,\r\n maidenmiddlename: firstHoldersData.maidenMiddleName == null ? '' : firstHoldersData.maidenMiddleName,\r\n\r\n relatedpersonchoose: firstHoldersData.relatedPersonTitle == null ? '' : firstHoldersData.relatedPersonTitle,\r\n relatedpersonlastname: firstHoldersData.relatedPeronLastName == null ? '' : firstHoldersData.relatedPeronLastName,\r\n relatedpersonfirstname: firstHoldersData.relatedPeronFirstName == null ? '' : firstHoldersData.relatedPeronFirstName,\r\n relatedpersonmiddlename: firstHoldersData.relatedPeronMiddleName == null ? '' : firstHoldersData.relatedPeronMiddleName,\r\n relatedpersonrelation: firstHoldersData.relatedPersonCustomerRelation == null ? '' : firstHoldersData.relatedPersonCustomerRelation,\r\n relatedpersonpan: firstHoldersData.relatedPersonPANNo == null ? '' : firstHoldersData.relatedPersonPANNo,\r\n relatedpersonaadhar: firstHoldersData.relatedPersonAadhaarNo == null ? '' : firstHoldersData.relatedPersonAadhaarNo,\r\n relatedcourt: firstHoldersData.relatedPersonCourtOrderNo == null ? '' : firstHoldersData.relatedPersonCourtOrderNo,\r\n\r\n transactionparticulars: firstHoldersData.declarantTransactionParticulars == null ? '' : firstHoldersData.declarantTransactionParticulars,\r\n transactionsamount: firstHoldersData.declarantAmountofTransaction == null ? '' : firstHoldersData.declarantAmountofTransaction,\r\n detailsofincometax: firstHoldersData.detailsOfIncomeTax == null ? '' : firstHoldersData.detailsOfIncomeTax,\r\n reasonfornopan: firstHoldersData.reasonForNoPan == null ? '' : firstHoldersData.reasonForNoPan,\r\n\r\n annualactivity: firstHoldersData.turnover == null ? '' : firstHoldersData.turnover,\r\n averageincome: firstHoldersData.averageIncome == null ? '' : firstHoldersData.averageIncome,\r\n expectedincome: firstHoldersData.averageBalance == null ? '' : firstHoldersData.averageBalance,\r\n officecontact: firstHoldersData.businessTelNo == null ? '' : firstHoldersData.businessTelNo,\r\n officemobileno: firstHoldersData.businessMobileNo == null ? '' : firstHoldersData.businessMobileNo,\r\n twowheeleryear: firstHoldersData.businessVehicleTwoWheeler == \"Two Wheeler\" ? firstHoldersData.businessTwoWheelerPurchaseYear == null ? '' : firstHoldersData.businessTwoWheelerPurchaseYear : '',\r\n caryear: firstHoldersData.businessVehicleCar == \"Car\" ? firstHoldersData.businessCarPurchaseYear == null ? '' : firstHoldersData.businessCarPurchaseYear : '',\r\n anyotheryear: firstHoldersData.businessVehicleOther == \"Other\" ? firstHoldersData.businessOtherPurchaseYear == null ? '' : firstHoldersData.businessOtherPurchaseYear : '',\r\n annualincome: firstHoldersData.annualincome == null ? '' : firstHoldersData.annualincome,\r\n },\r\n validationSchema: Yup.object({\r\n\r\n personalchoose: Yup.string().required(\"Title required\"),\r\n firstname: Yup.string().required(\"First Name required\").matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n middlename: Yup.string().required(\"Middle Name required\").matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n lastname: Yup.string().required(\"Last Name required\").matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n phoneno: Yup.string().required(\"Phone No. required\"),\r\n gender: Yup.string().required(\"Gender required\"),\r\n dob: Yup.string().required(\"Date of Birth required\"),\r\n maritalstatus: Yup.string().required(\"Maratial Status required\"),\r\n nationality: Yup.string().required(\"Nationality required\"),\r\n occupation: Yup.string().required(\"Occupation required\"),\r\n communicationaddress: Yup.string().required(\"Address 1 required\"),\r\n communicationstate: Yup.string().required(\"State required\"),\r\n communicationcity: Yup.string().required(\"City required\").matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n communicationpincode: Yup.number().required(\"Pincode required\"),\r\n permanentaddress: Yup.string().required(\"Address 1 required\"),\r\n permanentstate: Yup.string().required(\"State required\"),\r\n permanentcity: Yup.string().required(\"City required\").matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n permanentpincode: Yup.number().required(\"Pincode required\"),\r\n poi: Yup.string().required(\"POI required\"),\r\n poipoa: Yup.string().required(\"POI/POA required\"),\r\n pan: Yup.string().required(\"PAN No. required\"),\r\n panfile: Yup.string().required(\"PAN document required\"),\r\n photofile: Yup.string().required(\"Photo required\"),\r\n\r\n fatherchoose: Yup.string().required(\"Father Title required\"),\r\n fatherlastname: Yup.string().required(\"Father Last Name required\").matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n fatherfirstname: Yup.string().required(\"Father First name required\").matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n fathermiddlename: Yup.string().matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n motherchoose: Yup.string().required(\"Mother Title required\"),\r\n motherlastname: Yup.string().required(\"Mother Last Name required\").matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n motherfirstname: Yup.string().required(\"Mother First Name required\").matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n mothermiddlename: Yup.string().matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n maidenchoose: Yup.string().required(\"Maiden Title required\"),\r\n maidenlastname: Yup.string().required(\"Maiden Last Name required\").matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n maidenfirstname: Yup.string().required(\"Maiden First Name required\").matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n maidenmiddlename: Yup.string().matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n relatedpersonchoose: Yup.string().required(\"Title required\"),\r\n relatedpersonlastname: Yup.string().required(\"Last Name required\").matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n relatedpersonfirstname: Yup.string().required(\"First Name required\").matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n relatedpersonmiddlename: Yup.string().matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n relatedpersonrelation: Yup.string().required(\"Customer Relation required\").matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n relatedpersonpan: Yup.string().required(\"PAN required\"),\r\n relatedpersonaadhar: Yup.string().required(\"Aadhaar required\"),\r\n\r\n transactionparticulars: Yup.string().required(\"Transaction Particulars required\"),\r\n transactionsamount: Yup.string().required(\"Amount of Transactions required\"),\r\n detailsofincometax: Yup.string().required(\"Details of income required\"),\r\n reasonfornopan: Yup.string().required(\"Reason for not having PAN required\"),\r\n\r\n annualactivity: Yup.string().required(\"Annual activity/ A/c turnover required\"),\r\n averageincome: Yup.string().required(\"Average income required\"),\r\n expectedincome: Yup.string().required(\"Expected average balance required\"),\r\n annualincome: Yup.string().required(\"Annual income required\"),\r\n officemobileno: Yup.string().required(\"Mobile number required\"),\r\n }),\r\n\r\n onSubmit: (values) => {\r\n //console.log(\"values\", values);\r\n }\r\n });\r\n\r\n function BindPOIPOA(data) {\r\n debugger;\r\n var listPOI = [];\r\n\r\n if (data.length > 0) {\r\n if (data[0].poi != null) {\r\n data.map(p => {\r\n var rowsInput = {\r\n poiid: p.poiId.toString(),\r\n SelectedProofofIdentity: p.poi,\r\n EnterNumber: p.poiNo,\r\n POIPOA: p.poipoa,\r\n Expiry: p.expiryDate == null ? '' : p.expiryDate,\r\n Upload: '',\r\n poifilepath: p.poiFilePath,\r\n poifilepathurl: getAPIUrl() + \"/POIFiles/\" + p.poiFilePath,\r\n Delete: ''\r\n }\r\n listPOI.push(rowsInput);\r\n })\r\n\r\n setRowsData(listPOI);\r\n }\r\n }\r\n }\r\n\r\n function CheckIsValid(controlValues) {\r\n debugger;\r\n var x = Object.keys(controlValues[0])\r\n var isCheckIfUndefined = x.map(p => {\r\n if (controlValues[0][p] === \"\" || controlValues[0][p] === undefined) {\r\n if ((p == \"pan\" && controlValues[0][p] == \"\" && $(\"#chkPAN\").prop('checked')) || (p == \"panfile\" && controlValues[0][p] == \"\" && $(\"#chkPAN\").prop('checked'))) {\r\n return false;\r\n }\r\n else if (p == \"panfile\" && validation.values.poifilePath != '' && !$(\"#chkPAN\").prop('checked')) {\r\n return false;\r\n }\r\n else if (p == \"photofile\" && validation.values.photofilepath != '') {\r\n return false;\r\n }\r\n else if (p == \"panfile\" && validation.values.poifilePath == '' && !$(\"#chkPAN\").prop('checked')) {\r\n return true;\r\n }\r\n else if (p == \"photofile\" && validation.values.photofilepath == '') {\r\n return true;\r\n }\r\n else if (p == \"email\") {\r\n return false;\r\n }\r\n return true;\r\n }\r\n else\r\n return false;\r\n })\r\n\r\n var checkResponse = isCheckIfUndefined.includes(true)\r\n return checkResponse\r\n }\r\n\r\n // Function to format the date as \"dd-mmm-yyyy\"\r\n function formatDate(date) {\r\n debugger;\r\n const options = { day: '2-digit', month: 'short', year: 'numeric' };\r\n return date.toLocaleDateString('en-US', options);\r\n }\r\n\r\n $(\".d-block\").flatpickr({\r\n dateFormat: \"d-M-Y\",\r\n altFormat: \"F j, Y\",\r\n maxDate: \"today\",\r\n disableMobile: \"true\"\r\n });\r\n //$(\".d-block\").flatpickr({\r\n // dateFormat: \"d-m-Y\",\r\n // altFormat: \"F j, Y\",\r\n // maxDate: \"today\",\r\n // disableMobile: \"true\"\r\n //});\r\n\r\n $(\".maxFuture\").flatpickr({\r\n dateFormat: \"d-M-Y\",\r\n disableMobile: \"true\"\r\n });\r\n\r\n const tabHeading = {\r\n color: \"#9a084f\",\r\n fontWeight: \"bold\"\r\n }\r\n\r\n const label = {\r\n color: \"black\"\r\n }\r\n\r\n const formBackground = {\r\n borderRadius: 8,\r\n flex: 1,\r\n //backgroundColor: \"rgb(247 242 242)\",\r\n padding: \"15px\"\r\n }\r\n\r\n const cardBackground = {\r\n borderRadius: 15,\r\n flex: 1,\r\n marginTop: \"20px\",\r\n boxShadow: \"#504f4f6b 5px 5px 20px\",\r\n height: \"95%\",\r\n width: \"100%\"\r\n }\r\n\r\n const formButton = {\r\n marginLeft: \"20px\",\r\n backgroundColor: \"#9a084f\",\r\n fontSize: \"small\",\r\n borderRadius: \"0.50rem\"\r\n }\r\n\r\n const formButtonFirstPage = {\r\n marginLeft: \"15px\",\r\n backgroundColor: \"#9a084f\",\r\n fontSize: \"small\",\r\n borderRadius: \"0.50rem\"\r\n }\r\n\r\n const formMandatory = {\r\n color: \"red\",\r\n fontWeight: \"bold\"\r\n }\r\n \r\n return (\r\n \r\n
\r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n\r\n \r\n JSB-First Holder\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n
\r\n
\r\n \r\n {\r\n toggleTabVertical(1)\r\n }}\r\n disabled={!(passedStepsVertical || []).includes(1)}\r\n >\r\n 1 Personal Details\r\n \r\n \r\n \r\n {\r\n toggleTabVertical(2)\r\n }}\r\n disabled={!(passedStepsVertical || []).includes(2)}\r\n >\r\n 2{\" \"}\r\n Family Details\r\n \r\n \r\n \r\n {\r\n toggleTabVertical(3)\r\n }}\r\n disabled={!(passedStepsVertical || []).includes(3)}\r\n >\r\n 3 Related person\r\n \r\n \r\n \r\n {\r\n toggleTabVertical(4)\r\n }}\r\n disabled={!(passedStepsVertical || []).includes(4)}\r\n >\r\n 4 Form no 60/61\r\n \r\n \r\n \r\n {\r\n toggleTabVertical(5)\r\n }}\r\n disabled={!(passedStepsVertical || []).includes(5)}\r\n >\r\n 5 Additional Details\r\n \r\n \r\n \r\n {\r\n toggleTabVertical(6)\r\n }}\r\n disabled={!(passedStepsVertical || []).includes(6)}\r\n >\r\n 6Declaration\r\n \r\n \r\n
\r\n
\r\n\r\n
\r\n
\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n
\r\n \r\n \r\n\r\n \r\n \r\n \r\n
\r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n
\r\n \r\n \r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n \r\n \r\n )\r\n}\r\n\r\nexport default FirstHolder\r\n","import MetaTags from \"react-meta-tags\";\r\nimport React, { useState, useEffect } from \"react\"\r\nimport { Row, Col, CardBody, Card, Container } from \"reactstrap\";\r\n/*import ImageViewer from \"react-simple-image-viewer\";*/\r\nimport PropTypes from 'prop-types';\r\n\r\n\r\nconst ShowPhoto = () => {\r\n\r\n const images = [\r\n \"http://placeimg.com/1200/800/nature\",\r\n \"http://placeimg.com/800/1200/nature\",\r\n \"http://placeimg.com/1920/1080/nature\",\r\n \"http://placeimg.com/1500/500/nature\"\r\n ];\r\n\r\n return (\r\n <>>\r\n );\r\n};\r\n\r\nShowPhoto.propTypes = {\r\n srcPath: PropTypes.string\r\n}\r\n\r\nexport default ShowPhoto\r\n\r\n\r\n","import React, { useState, useEffect } from \"react\"\r\nimport axios from 'axios';\r\nimport authHeader from \"helpers/authHeader\";\r\nimport MetaTags from \"react-meta-tags\"\r\nimport Flatpickr from \"react-flatpickr\";\r\nimport Select from 'react-select'\r\nimport {\r\n Card,\r\n CardBody,\r\n Table,\r\n Col,\r\n Container,\r\n Form,\r\n FormGroup,\r\n Input,\r\n InputGroup,\r\n Label,\r\n NavItem,\r\n NavLink,\r\n Row,\r\n Button,\r\n TabContent,\r\n TabPane,\r\n FormFeedback,\r\n\r\n} from \"reactstrap\"\r\n\r\n// Formik validation\r\nimport * as Yup from \"yup\";\r\nimport { ErrorMessage, useFormik } from \"formik\";\r\nimport { useHistory } from \"react-router-dom\";\r\nimport classnames from \"classnames\";\r\nimport toastr from \"toastr\";\r\nimport \"toastr/build/toastr.min.css\";\r\nimport { getAPIUrl, updatePersonalDetailsUrl, form60Url, getOtherHolderDetails, updateAccountHoldersStatusUrl, additionalDetailsUrl, getCustomerAdditionalDetailsUrl } from \"../../helpers/fakebackend_helper\";\r\nimport ShowPhoto from \"../../pages/JSBForms/ShowPhoto\"\r\n\r\n//redux\r\nimport { useSelector, useDispatch } from \"react-redux\";\r\n\r\n//Get States\r\nimport { getState } from \"../../store/actions\";\r\n\r\n//Get Occupation\r\nimport { getOccupation } from \"../../store/actions\";\r\n\r\n//GetAll Poi\r\nimport { getPoi } from \"../../store/actions\";\r\n\r\n//GetAll Education\r\nimport { getEducation } from \"../../store/actions\";\r\n\r\n//GetAll OccupationDetails\r\nimport { getOccupationDetails } from \"../../store/actions\";\r\n\r\n//GetAll AssetDetails\r\nimport { getAssetDetails } from \"../../store/actions\";\r\n\r\n//GetAll OtherBankAccounts\r\nimport { getOtherBankAccounts } from \"../../store/actions\";\r\n\r\nimport TableRows from './TableRows';\r\nimport banner from \"../../assets/images/banner/banner.jpg\";\r\n\r\nconst OtherHolder = () => {\r\n\r\n var getBase64 = async (file) => {\r\n return await new Promise((resolve, reject) => {\r\n debugger;\r\n const reader = new FileReader();\r\n reader.readAsDataURL(file);\r\n reader.onload = () => resolve(reader.result);\r\n reader.onerror = error => reject(error);\r\n });\r\n }\r\n\r\n //=============Define State====================\r\n const history = useHistory();\r\n\r\n const [branch, setBranch] = useState([]);\r\n const [showEasing, setshowEasing] = useState(\"swing\");\r\n const [hideEasing, sethideEasing] = useState(\"linear\");\r\n const [showMethod, setshowMethod] = useState(\"fadeIn\");\r\n const [hideMethod, sethideMethod] = useState(\"fadeOut\");\r\n const [showDuration, setshowDuration] = useState(300);\r\n const [hideDuration, sethideDuration] = useState(1000);\r\n const [timeOut, settimeOut] = useState(2000);\r\n const [extendedTimeOut, setextendedTimeOut] = useState(1000);\r\n\r\n function SuccessMessage(message) {\r\n toastr.options = {\r\n positionClass: \"toast-top-center\",\r\n timeOut: timeOut,\r\n extendedTimeOut: extendedTimeOut,\r\n closeButton: true,\r\n debug: false,\r\n progressBar: false,\r\n preventDuplicates: false,\r\n newestOnTop: false,\r\n showEasing: showEasing,\r\n hideEasing: hideEasing,\r\n showMethod: showMethod,\r\n hideMethod: hideMethod,\r\n showDuration: showDuration,\r\n hideDuration: hideDuration\r\n };\r\n\r\n toastr.success(message, \"Information\");\r\n }\r\n\r\n function ErrorMessage(message) {\r\n toastr.options = {\r\n positionClass: \"toast-top-center\",\r\n timeOut: timeOut,\r\n extendedTimeOut: extendedTimeOut,\r\n closeButton: true,\r\n debug: false,\r\n progressBar: false,\r\n preventDuplicates: false,\r\n newestOnTop: false,\r\n showEasing: showEasing,\r\n hideEasing: hideEasing,\r\n showMethod: showMethod,\r\n hideMethod: hideMethod,\r\n showDuration: showDuration,\r\n hideDuration: hideDuration\r\n };\r\n\r\n toastr.error(message, \"Error\");\r\n }\r\n\r\n //GetAll OtherBankAccounts\r\n const { otherBankAccountsData } = useSelector(state => ({\r\n otherBankAccountsData: state.Registration.otherBankAccountsData,\r\n }));\r\n\r\n //GetAll Education\r\n const { educationData } = useSelector(state => ({\r\n educationData: state.Registration.educationData,\r\n }));\r\n\r\n //GetAll OccupationDetails\r\n const { occupationDetailsData } = useSelector(state => ({\r\n occupationDetailsData: state.Registration.occupationDetailsData,\r\n }));\r\n\r\n //GetAll AssetDetails\r\n const { assetDetailsData } = useSelector(state => ({\r\n assetDetailsData: state.Registration.assetDetailsData,\r\n }));\r\n\r\n const dispatch = useDispatch();\r\n const { stateData } = useSelector(state => ({\r\n stateData: state.Registration.stateData,\r\n }));\r\n\r\n //GetAll Occupation\r\n const { occupationData } = useSelector(state => ({\r\n occupationData: state.Registration.occupationData,\r\n }));\r\n\r\n //GetAll Poi\r\n const { poiData } = useSelector(state => ({\r\n poiData: state.Registration.poiData,\r\n }));\r\n\r\n function chkNumeric(e) {\r\n let input = e.target.value;\r\n\r\n if (input == \"\") {\r\n validation.handleChange(e);\r\n }\r\n else if (typeof input !== \"undefined\") {\r\n var pattern = new RegExp(/^[0-9\\b]+$/);\r\n if (pattern.test(input)) {\r\n validation.handleChange(e);\r\n }\r\n }\r\n }\r\n\r\n const [rowsData, setRowsData] = useState([]);\r\n\r\n const addPoiRows = () => {\r\n debugger;\r\n if ($(\"#ddlPOI option:selected\").val() == \"\") {\r\n ErrorMessage(\"Please select Proof of Identity!\");\r\n $(\"#ddlPOI\").focus();\r\n return;\r\n }\r\n else if ($(\"#ddlPOIPOA option:selected\").val() == \"\") {\r\n ErrorMessage(\"Please select POI/POA!\");\r\n $(\"#ddlPOIPOA\").focus();\r\n return;\r\n }\r\n\r\n if (rowsData.some(person => person.SelectedProofofIdentity === $(\"#ddlPOI option:selected\").text())) {\r\n ErrorMessage($(\"#ddlPOI option:selected\").text() + \" is already exists!\");\r\n return;\r\n }\r\n\r\n const rowsInput = {\r\n poiid: '',\r\n SelectedProofofIdentity: $(\"#ddlPOI option:selected\").text(),\r\n EnterNumber: '',\r\n POIPOA: $(\"#ddlPOIPOA option:selected\").text(),\r\n Expiry: '',\r\n Upload: '',\r\n poifilepath: '',\r\n poifilepathurl: '',\r\n Delete: ''\r\n }\r\n setRowsData([...rowsData, rowsInput])\r\n }\r\n\r\n const deletePoiRows = (index) => {\r\n debugger;\r\n if (rowsData.length > 1) {\r\n const rows = [...rowsData];\r\n rows.splice(index, 1);\r\n setRowsData(rows);\r\n }\r\n else if (rowsData.length == 1) {\r\n ErrorMessage(\"Atleast one POI/POA document is Compulsory!\");\r\n }\r\n }\r\n\r\n const handleChange = (index, evnt) => {\r\n debugger;\r\n const { name, value } = evnt.target;\r\n const rowsInput = [...rowsData];\r\n rowsInput[index][name] = value;\r\n setRowsData(rowsInput);\r\n }\r\n\r\n const handleCheckChange = (index, evnt) => {\r\n debugger;\r\n const { name, checked } = evnt.target;\r\n const rowsInput = [...rowsData];\r\n rowsInput[index][name] = checked;\r\n setRowsData(rowsInput);\r\n }\r\n\r\n const handleUploadChange = (index, evnt) => {\r\n debugger;\r\n const { name, value } = evnt.target;\r\n const rowsInput = [...rowsData];\r\n rowsInput[index][name] = evnt.target.files[0];\r\n setRowsData(rowsInput);\r\n }\r\n\r\n //Upload files\r\n const [selectedPhotoFile, setSelectedPhotoFile] = React.useState(\"\");\r\n const [selectedFile, setSelectedFile] = React.useState(\"\");\r\n const [holdersData, setHoldersData] = useState([]);\r\n\r\n const [emailError, setEmailError] = useState('');\r\n const [panError, setPanError] = useState('');\r\n const [isPreloader, setPreloader] = useState(false);\r\n\r\n function emailValidation(value) {\r\n debugger;\r\n const email = value.target.value;\r\n const regex = /^(([^<>()[\\]\\.,;:\\s@\\\"]+(\\.[^<>()[\\]\\.,;:\\s@\\\"]+)*)|(\\\".+\\\"))@(([^<>()[\\]\\.,;:\\s@\\\"]+\\.)+[^<>()[\\]\\.,;:\\s@\\\"]{2,})$/i;\r\n if (!email || regex.test(email)\r\n === false) {\r\n setEmailError('Enter valid Email!')\r\n return false;\r\n }\r\n else {\r\n setEmailError('')\r\n return true;\r\n }\r\n }\r\n\r\n function panValidation(pan) {\r\n const regex = /^([A-Z]){5}([0-9]){4}([A-Z]){1}?$/;\r\n if (!pan || regex.test(pan) === false) {\r\n setPanError('Enter valid PAN number!')\r\n }\r\n else {\r\n setPanError('')\r\n return true;\r\n }\r\n }\r\n\r\n function passportValidation(passport) {\r\n debugger;\r\n var regex = new RegExp(\"^[A-PR-WY][1-9]\\\\d\\\\s?\\\\d{4}[1-9]$\");\r\n if (!passport || regex.test(passport) === false) {\r\n return false;\r\n }\r\n else {\r\n return true;\r\n }\r\n }\r\n function licenseValidation(license) {\r\n debugger;\r\n var regex = new RegExp(\"^(([A-Z]{2}[0-9]{2})( )|([A-Z]{2}-[0-9]{2}))((19|20)[0-9][0-9])[0-9]{7}$\");\r\n if (!license || regex.test(license) === false) {\r\n return false;\r\n }\r\n else {\r\n return true;\r\n }\r\n }\r\n function voterIDValidation(voterId) {\r\n debugger;\r\n var regex = /^([A-Z]){3}([0-9]){7}?$/g;\r\n if (!voterId || regex.test(voterId) === false) {\r\n return false;\r\n }\r\n else {\r\n return true;\r\n }\r\n }\r\n\r\n //function aadharValidation(uid) {\r\n // if (uid.length != 12) {\r\n // return false;\r\n // }\r\n\r\n // var Verhoeff = {\r\n // \"d\": [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],\r\n // [1, 2, 3, 4, 0, 6, 7, 8, 9, 5],\r\n // [2, 3, 4, 0, 1, 7, 8, 9, 5, 6],\r\n // [3, 4, 0, 1, 2, 8, 9, 5, 6, 7],\r\n // [4, 0, 1, 2, 3, 9, 5, 6, 7, 8],\r\n // [5, 9, 8, 7, 6, 0, 4, 3, 2, 1],\r\n // [6, 5, 9, 8, 7, 1, 0, 4, 3, 2],\r\n // [7, 6, 5, 9, 8, 2, 1, 0, 4, 3],\r\n // [8, 7, 6, 5, 9, 3, 2, 1, 0, 4],\r\n // [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]],\r\n // \"p\": [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],\r\n // [1, 5, 7, 6, 2, 8, 3, 0, 9, 4],\r\n // [5, 8, 0, 3, 7, 9, 6, 1, 4, 2],\r\n // [8, 9, 1, 6, 0, 4, 3, 5, 2, 7],\r\n // [9, 4, 5, 3, 1, 2, 6, 8, 7, 0],\r\n // [4, 2, 8, 6, 5, 7, 3, 9, 0, 1],\r\n // [2, 7, 9, 3, 8, 0, 6, 4, 1, 5],\r\n // [7, 0, 4, 6, 9, 1, 3, 2, 5, 8]],\r\n // \"j\": [0, 4, 3, 2, 1, 5, 6, 7, 8, 9],\r\n // \"check\": function (str) {\r\n // var c = 0;\r\n // str.replace(/\\D+/g, \"\").split(\"\").reverse().join(\"\").replace(/[\\d]/g, function (u, i) {\r\n // c = Verhoeff.d[c][Verhoeff.p[i % 8][parseInt(u, 10)]];\r\n // });\r\n // return c;\r\n\r\n // },\r\n // \"get\": function (str) {\r\n\r\n // var c = 0;\r\n // str.replace(/\\D+/g, \"\").split(\"\").reverse().join(\"\").replace(/[\\d]/g, function (u, i) {\r\n // c = Verhoeff.d[c][Verhoeff.p[(i + 1) % 8][parseInt(u, 10)]];\r\n // });\r\n // return Verhoeff.j[c];\r\n // }\r\n // };\r\n\r\n // String.prototype.verhoeffCheck = (function () {\r\n // var d = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],\r\n // [1, 2, 3, 4, 0, 6, 7, 8, 9, 5],\r\n // [2, 3, 4, 0, 1, 7, 8, 9, 5, 6],\r\n // [3, 4, 0, 1, 2, 8, 9, 5, 6, 7],\r\n // [4, 0, 1, 2, 3, 9, 5, 6, 7, 8],\r\n // [5, 9, 8, 7, 6, 0, 4, 3, 2, 1],\r\n // [6, 5, 9, 8, 7, 1, 0, 4, 3, 2],\r\n // [7, 6, 5, 9, 8, 2, 1, 0, 4, 3],\r\n // [8, 7, 6, 5, 9, 3, 2, 1, 0, 4],\r\n // [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]];\r\n // var p = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],\r\n // [1, 5, 7, 6, 2, 8, 3, 0, 9, 4],\r\n // [5, 8, 0, 3, 7, 9, 6, 1, 4, 2],\r\n // [8, 9, 1, 6, 0, 4, 3, 5, 2, 7],\r\n // [9, 4, 5, 3, 1, 2, 6, 8, 7, 0],\r\n // [4, 2, 8, 6, 5, 7, 3, 9, 0, 1],\r\n // [2, 7, 9, 3, 8, 0, 6, 4, 1, 5],\r\n // [7, 0, 4, 6, 9, 1, 3, 2, 5, 8]];\r\n\r\n // return function () {\r\n // var c = 0;\r\n // this.replace(/\\D+/g, \"\").split(\"\").reverse().join(\"\").replace(/[\\d]/g, function (u, i) {\r\n // c = d[c][p[i % 8][parseInt(u, 10)]];\r\n // });\r\n // return (c === 0);\r\n // };\r\n // })();\r\n\r\n // if (Verhoeff['check'](uid) === 0) {\r\n // return true;\r\n // } else {\r\n // return false;\r\n // }\r\n //}\r\n\r\n function aadharValidation(uid) {\r\n debugger;\r\n var regex = new RegExp(\"^[2-9]{1}[0-9]{3}[0-9]{4}[0-9]{4}$\");\r\n if (!uid || regex.test(uid) === false) {\r\n return false;\r\n }\r\n else {\r\n if (uid.length != 12) {\r\n return false;\r\n }\r\n\r\n var Verhoeff = {\r\n \"d\": [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],\r\n [1, 2, 3, 4, 0, 6, 7, 8, 9, 5],\r\n [2, 3, 4, 0, 1, 7, 8, 9, 5, 6],\r\n [3, 4, 0, 1, 2, 8, 9, 5, 6, 7],\r\n [4, 0, 1, 2, 3, 9, 5, 6, 7, 8],\r\n [5, 9, 8, 7, 6, 0, 4, 3, 2, 1],\r\n [6, 5, 9, 8, 7, 1, 0, 4, 3, 2],\r\n [7, 6, 5, 9, 8, 2, 1, 0, 4, 3],\r\n [8, 7, 6, 5, 9, 3, 2, 1, 0, 4],\r\n [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]],\r\n \"p\": [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],\r\n [1, 5, 7, 6, 2, 8, 3, 0, 9, 4],\r\n [5, 8, 0, 3, 7, 9, 6, 1, 4, 2],\r\n [8, 9, 1, 6, 0, 4, 3, 5, 2, 7],\r\n [9, 4, 5, 3, 1, 2, 6, 8, 7, 0],\r\n [4, 2, 8, 6, 5, 7, 3, 9, 0, 1],\r\n [2, 7, 9, 3, 8, 0, 6, 4, 1, 5],\r\n [7, 0, 4, 6, 9, 1, 3, 2, 5, 8]],\r\n \"j\": [0, 4, 3, 2, 1, 5, 6, 7, 8, 9],\r\n \"check\": function (str) {\r\n var c = 0;\r\n str.replace(/\\D+/g, \"\").split(\"\").reverse().join(\"\").replace(/[\\d]/g, function (u, i) {\r\n c = Verhoeff.d[c][Verhoeff.p[i % 8][parseInt(u, 10)]];\r\n });\r\n return c;\r\n\r\n },\r\n \"get\": function (str) {\r\n\r\n var c = 0;\r\n str.replace(/\\D+/g, \"\").split(\"\").reverse().join(\"\").replace(/[\\d]/g, function (u, i) {\r\n c = Verhoeff.d[c][Verhoeff.p[(i + 1) % 8][parseInt(u, 10)]];\r\n });\r\n return Verhoeff.j[c];\r\n }\r\n };\r\n\r\n String.prototype.verhoeffCheck = (function () {\r\n var d = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],\r\n [1, 2, 3, 4, 0, 6, 7, 8, 9, 5],\r\n [2, 3, 4, 0, 1, 7, 8, 9, 5, 6],\r\n [3, 4, 0, 1, 2, 8, 9, 5, 6, 7],\r\n [4, 0, 1, 2, 3, 9, 5, 6, 7, 8],\r\n [5, 9, 8, 7, 6, 0, 4, 3, 2, 1],\r\n [6, 5, 9, 8, 7, 1, 0, 4, 3, 2],\r\n [7, 6, 5, 9, 8, 2, 1, 0, 4, 3],\r\n [8, 7, 6, 5, 9, 3, 2, 1, 0, 4],\r\n [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]];\r\n var p = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],\r\n [1, 5, 7, 6, 2, 8, 3, 0, 9, 4],\r\n [5, 8, 0, 3, 7, 9, 6, 1, 4, 2],\r\n [8, 9, 1, 6, 0, 4, 3, 5, 2, 7],\r\n [9, 4, 5, 3, 1, 2, 6, 8, 7, 0],\r\n [4, 2, 8, 6, 5, 7, 3, 9, 0, 1],\r\n [2, 7, 9, 3, 8, 0, 6, 4, 1, 5],\r\n [7, 0, 4, 6, 9, 1, 3, 2, 5, 8]];\r\n\r\n return function () {\r\n var c = 0;\r\n this.replace(/\\D+/g, \"\").split(\"\").reverse().join(\"\").replace(/[\\d]/g, function (u, i) {\r\n c = d[c][p[i % 8][parseInt(u, 10)]];\r\n });\r\n return (c === 0);\r\n };\r\n })();\r\n\r\n if (Verhoeff['check'](uid) === 0) {\r\n return true;\r\n } else {\r\n return false;\r\n }\r\n }\r\n }\r\n\r\n function getCustomerAge() {\r\n var dob = new Date(validation.values.dob);\r\n var today = new Date();\r\n var age = Math.floor((today - dob) / (365.25 * 24 * 60 * 60 * 1000));\r\n return age;\r\n }\r\n\r\n function handlePhotoUpload(event) {\r\n setSelectedPhotoFile(event.target.files[0]);\r\n }\r\n function handleUpload(event) {\r\n setSelectedFile(event.target.files[0]);\r\n }\r\n\r\n var authCustomerObject = JSON.parse(localStorage.getItem('authCustomer'));\r\n\r\n const registrationHoldersPOIList = [];\r\n\r\n var registrationHoldersPOI = {\r\n POI: '',\r\n POINo: '',\r\n IsPOI: '',\r\n IsPOA: '',\r\n ExpiryDate: '',\r\n Base64POI: ''\r\n }\r\n\r\n var objRegistrationHolders = {\r\n Title: '',\r\n FirstName: '',\r\n MiddleName: '',\r\n LastName: '',\r\n DOB: '',\r\n Gender: '',\r\n Nationality: '',\r\n Occupation: '',\r\n Mobile: '',\r\n Email: '',\r\n MartialStatus: '',\r\n LocalAddress1: '',\r\n LocalAddress2: '',\r\n LocalAddress3: '',\r\n LocalCity: '',\r\n LocalPin: '',\r\n LocalState: '',\r\n PermanentAddress1: '',\r\n PermanentAddress2: '',\r\n PermanentAddress3: '',\r\n PermanentCity: '',\r\n PermanentPin: '',\r\n PermanentState: '',\r\n PAN: '',\r\n Base64PAN: '',\r\n registrationHoldersPOI: registrationHoldersPOIList\r\n }\r\n\r\n const personalDetails = {\r\n RegistrationId: localStorage.getItem(\"registrationId\"),\r\n objRegistrationHolders: objRegistrationHolders\r\n }\r\n\r\n const form60 = {\r\n RegistrationId: '',\r\n DeclarantDocuments: '',\r\n DeclarantTransactionParticulars: '',\r\n DeclarantAmountofTransaction: '',\r\n DeclarantAssessedTax: '',\r\n DetailsOfIncomeTax: '',\r\n ReasonForNoPan: ''\r\n }\r\n\r\n const additionalDetails = {\r\n RegistrationId: '',\r\n FundsExpectedOrigin: '',\r\n FundsUtilisationExpected: '',\r\n OtherBankAccounts: '',\r\n Turnover: '',\r\n AverageIncome: '',\r\n AverageBalance: '',\r\n Education: '',\r\n Religion: '',\r\n OccupationDetails: '',\r\n LineOfBusiness: '',\r\n BusinessName: '',\r\n BusinessStartDate: '',\r\n BusinessAddress1: '',\r\n BusinessAddress2: '',\r\n BusinessAddress3: '',\r\n BusinessTelNo: '',\r\n BusinessMobileNo: '',\r\n BusinessAnnualIncome: '',\r\n BusinessIncomeSource: '',\r\n BusinessWealthSource: '',\r\n BusinessEstimatedValue: '',\r\n BusinessAssetDetails: '',\r\n BornNonIndia: '',\r\n TaxResidenceNonIndia: '',\r\n BusinessVehicleType: '',\r\n BusinessCarPurchaseYear: '',\r\n BusinessCarMaker: '',\r\n InterestedIn: ''\r\n }\r\n\r\n const registrationHoldersId = localStorage.getItem('registrationHoldersId');\r\n\r\n function GetOtherHolderDetails() {\r\n debugger;\r\n const createAccountHolderModel = {\r\n RegistrationId: localStorage.getItem('registrationId'),\r\n RegistrationHolderId: registrationHoldersId\r\n };\r\n\r\n setPreloader(true);\r\n\r\n axios.post(getOtherHolderDetails(), createAccountHolderModel, { headers: authHeader() }).then((response) => {\r\n if (response.data.length != 0 && response.data[0].declarantAssessedTax != null) {\r\n if (response.data[0].declarantAssessedTax == true) {\r\n $('#rbaccessedtaxyes').prop('checked', true);\r\n $('#rbaccessedtaxno').prop('checked', false);\r\n }\r\n else if (response.data[0].declarantAssessedTax == false) {\r\n $('#rbaccessedtaxyes').prop('checked', false);\r\n $('#rbaccessedtaxno').prop('checked', true);\r\n }\r\n }\r\n\r\n if (response.data.length != 0 && response.data[0].isPAN != null) {\r\n if (response.data[0].isPAN == false) {\r\n $('#chkPAN').prop('checked', true);\r\n $(\"#txtPancard\").attr('disabled', 'disabled');\r\n $(\"#Upload\").attr('disabled', 'disabled');\r\n $(\"#txtPancard\").val('');\r\n }\r\n else if (response.data[0].isPAN == true) {\r\n $('#chkPAN').prop('checked', false);\r\n $(\"#txtPancard\").removeAttr('disabled');\r\n $(\"#Upload\").removeAttr('disabled');\r\n }\r\n }\r\n\r\n if (response.data.length == 0) {\r\n setHoldersData(response.data);\r\n BindPOIPOA(response.data);\r\n setPreloader(false);\r\n return;\r\n }\r\n else if (response.data.length > 0) {\r\n if (response.data[0].photoFilePath != \"\") {\r\n $(\"#lnkPhotoDownload\").css(\"visibility\", \"visible\");\r\n $(\"#lnkPhotoDownload\").prop(\"href\", getAPIUrl() + \"/Photo/\" + response.data[0].photoFilePath);\r\n }\r\n if (response.data[0].panFilePath != \"\") {\r\n $(\"#lnkPANDownload\").css(\"visibility\", \"visible\");\r\n $(\"#lnkPANDownload\").prop(\"href\", getAPIUrl() + \"/POIFiles/\" + response.data[0].panFilePath);\r\n }\r\n\r\n BindAdditionalDetails(response.data[0]);\r\n setHoldersData(response.data[0]);\r\n BindPOIPOA(response.data);\r\n setPreloader(false);\r\n }\r\n\r\n setPreloader(false);\r\n }, (error) => {\r\n ErrorMessage(error.response);\r\n setPreloader(false);\r\n });\r\n }\r\n\r\n useEffect(() => {\r\n debugger;\r\n if (isPreloader === true) {\r\n document.getElementById(\"preloader\").style.display = \"block\";\r\n document.getElementById(\"status\").style.display = \"block\";\r\n } else {\r\n document.getElementById(\"preloader\").style.display = \"none\";\r\n document.getElementById(\"status\").style.display = \"none\";\r\n }\r\n }, [isPreloader]);\r\n\r\n useEffect(() => {\r\n dispatch(getState());\r\n dispatch(getOccupation());\r\n dispatch(getPoi());\r\n dispatch(getEducation());\r\n dispatch(getOccupationDetails());\r\n dispatch(getAssetDetails());\r\n dispatch(getOtherBankAccounts());\r\n GetOtherHolderDetails();\r\n }, [dispatch]);\r\n\r\n function BindAdditionalDetails(additionalDetails) {\r\n debugger;\r\n if (additionalDetails != null) {\r\n additionalDetails.fundsExpectedOrigin == null ? $('#ddlfundsforcredit option:selected').val(1) : additionalDetails.fundsExpectedOrigin == '' ? $('#ddlfundsforcredit option:selected').val(1) : $('#ddlfundsforcredit option:selected').text(additionalDetails.fundsExpectedOrigin);\r\n additionalDetails.fundsUtilisationExpected == null ? $('#ddlfundsbydebit option:selected').val(1) : additionalDetails.fundsUtilisationExpected == '' ? $('#ddlfundsbydebit option:selected').val(1) : $('#ddlfundsbydebit option:selected').text(additionalDetails.fundsUtilisationExpected);\r\n additionalDetails.otherBankAccounts == null ? $('#ddlotherbanksaccounts option:selected').val(1) : additionalDetails.otherBankAccounts == '' ? $('#ddlotherbanksaccounts option:selected').val(1) : $('#ddlotherbanksaccounts option:selected').text(additionalDetails.otherBankAccounts);\r\n $('#txtturnover').val(additionalDetails.turnover);\r\n $('#txtaverageincome').val(additionalDetails.averageIncome);\r\n $('#txtexpectedincome').val(additionalDetails.averageBalance);\r\n additionalDetails.education == null ? $('#ddleducation option:selected').val(1) : additionalDetails.education == '' ? $('#ddleducation option:selected').val(1) : $('#ddleducation option:selected').text(additionalDetails.education);\r\n additionalDetails.religion == null ? $('#ddlreligion option:selected').val(1) : additionalDetails.religion == '' ? $('#ddlreligion option:selected').val(1) : $('#ddlreligion option:selected').text(additionalDetails.religion);\r\n additionalDetails.occupationDetails == null ? $('#ddloccupationdetails option:selected').val(1) : additionalDetails.occupationDetails == '' ? $('#ddloccupationdetails option:selected').val(1) : $('#ddloccupationdetails option:selected').text(additionalDetails.occupationDetails);\r\n $('#txtlineofnusiness').val(additionalDetails.lineOfBusiness);\r\n $('#txtbusinessname').val(additionalDetails.businessName);\r\n $('#txtstartbusinessdate').val(additionalDetails.businessStartDate);\r\n $('#txtbussinessaddress1').val(additionalDetails.businessAddress1);\r\n $('#txtbussinessaddress2').val(additionalDetails.businessAddress2);\r\n $('#txtbussinessaddress3').val(additionalDetails.businessAddress3);\r\n $('#txtofficecontact').val(additionalDetails.businessTelNo);\r\n $('#txtofficemobileno').val(additionalDetails.businessMobileNo);\r\n additionalDetails.businessAnnualIncome == null ? $('#ddlannualincome option:selected').val(1) : additionalDetails.businessAnnualIncome == '' ? $('#ddlannualincome option:selected').val(1) : $('#ddlannualincome option:selected').text(additionalDetails.businessAnnualIncome);\r\n $('#txtsourceofincome').val(additionalDetails.businessIncomeSource);\r\n $('#txtsourceofwealth').val(additionalDetails.businessWealthSource);\r\n additionalDetails.businessEstimatedValue == null ? $('#ddlestimatedvalue option:selected').val(1) : additionalDetails.businessEstimatedValue == '' ? $('#ddlestimatedvalue option:selected').val(1) : $('#ddlestimatedvalue option:selected').text(additionalDetails.businessEstimatedValue);\r\n additionalDetails.caste == null ? $('#caste option:selected').val(1) : additionalDetails.caste == '' ? $('#caste option:selected').val(1) : $('#caste option:selected').text(additionalDetails.caste);\r\n\r\n if (additionalDetails.businessAssetDetails != null) {\r\n if (additionalDetails.businessAssetDetails.length > 0) {\r\n if (additionalDetails.businessAssetDetails.includes('Commercial Property')) {\r\n $('#chkcommercialproperty').prop('checked', true);\r\n }\r\n else {\r\n $('#chkcommercialproperty').prop('checked', false);\r\n }\r\n\r\n if (additionalDetails.businessAssetDetails.includes('House')) {\r\n $('#chkhouse').prop('checked', true);\r\n }\r\n else {\r\n $('#chkhouse').prop('checked', false);\r\n }\r\n\r\n if (additionalDetails.businessAssetDetails.includes('Plot')) {\r\n $('#chkplot').prop('checked', true);\r\n }\r\n else {\r\n $('#chkplot').prop('checked', false);\r\n }\r\n\r\n if (additionalDetails.businessAssetDetails.includes('Others')) {\r\n $('#chkothers').prop('checked', true);\r\n }\r\n else {\r\n $('#chkothers').prop('checked', false);\r\n }\r\n }\r\n }\r\n\r\n if (additionalDetails.taxResidenceNonIndia != null) {\r\n if (additionalDetails.taxResidenceNonIndia == true) {\r\n $('#rbtaxresidenceyes').prop('checked', true);\r\n $('#rbtaxresidenceno').prop('checked', false);\r\n }\r\n else if (additionalDetails.taxResidenceNonIndia == false) {\r\n $('#rbtaxresidenceyes').prop('checked', false);\r\n $('#rbtaxresidenceno').prop('checked', true);\r\n }\r\n }\r\n\r\n if (additionalDetails.bornNonIndia != null) {\r\n if (additionalDetails.bornNonIndia == true) {\r\n $('#rbbornyes').prop('checked', true);\r\n $('#rbbornno').prop('checked', false);\r\n }\r\n else if (additionalDetails.bornNonIndia == false) {\r\n $('#rbbornyes').prop('checked', false);\r\n $('#rbbornno').prop('checked', true);\r\n }\r\n }\r\n\r\n if (additionalDetails.businessVehicleTwoWheeler != null) {\r\n if (additionalDetails.businessVehicleTwoWheeler.length > 0) {\r\n if (additionalDetails.businessVehicleTwoWheeler.includes('Two Wheeler')) {\r\n $('#chktwowheeler').prop('checked', true);\r\n $('#twowheeleryear').val(additionalDetails.businessTwoWheelerPurchaseYear);\r\n }\r\n else {\r\n $('#chktwowheeler').prop('checked', false);\r\n }\r\n }\r\n }\r\n\r\n if (additionalDetails.businessVehicleCar != null) {\r\n if (additionalDetails.businessVehicleCar.length > 0) {\r\n if (additionalDetails.businessVehicleCar.includes('Car')) {\r\n $('#chkcar').prop('checked', true);\r\n $('#txtcaryear').val(additionalDetails.businessCarPurchaseYear);\r\n }\r\n else {\r\n $('#chkcar').prop('checked', false);\r\n }\r\n }\r\n }\r\n\r\n if (additionalDetails.businessVehicleOther != null) {\r\n if (additionalDetails.businessVehicleOther.length > 0) {\r\n if (additionalDetails.businessVehicleOther.includes('Other')) {\r\n $('#chkother').prop('checked', true);\r\n $('#txtotheryear').val(additionalDetails.businessOtherPurchaseYear);\r\n }\r\n else {\r\n $('#chkother').prop('checked', false);\r\n }\r\n }\r\n }\r\n\r\n if (additionalDetails.interestedIn != null) {\r\n if (additionalDetails.interestedIn.length > 0) {\r\n if (additionalDetails.interestedIn.includes('Mutual Funds')) {\r\n $('#chkmutualfunds').prop('checked', true);\r\n }\r\n else {\r\n $('#chkmutualfunds').prop('checked', false);\r\n }\r\n\r\n if (additionalDetails.interestedIn.includes('Health Insurance')) {\r\n $('#chkhealthinsurance').prop('checked', true);\r\n }\r\n else {\r\n $('#chkhealthinsurance').prop('checked', false);\r\n }\r\n\r\n if (additionalDetails.interestedIn.includes('General Insurance')) {\r\n $('#chkgeneralinsurance').prop('checked', true);\r\n }\r\n else {\r\n $('#chkgeneralinsurance').prop('checked', false);\r\n }\r\n\r\n if (additionalDetails.interestedIn.includes('Demat')) {\r\n $('#chkdemat').prop('checked', true);\r\n }\r\n else {\r\n $('#chkdemat').prop('checked', false);\r\n }\r\n\r\n if (additionalDetails.interestedIn.includes('Pradhan Mantri Suraksha Bima Yojana (PMSBY)')) {\r\n $('#chkpmsby').prop('checked', true);\r\n }\r\n else {\r\n $('#chkpmsby').prop('checked', false);\r\n }\r\n\r\n if (additionalDetails.interestedIn.includes('Pradhan Mantri Jeevan Jyoti Bima Yojana (PMJJBY)')) {\r\n $('#chkpmjjby').prop('checked', true);\r\n }\r\n else {\r\n $('#chkpmjjby').prop('checked', false);\r\n }\r\n }\r\n }\r\n\r\n $('#txtcarmaker').val(additionalDetails.businessCarMaker);\r\n }\r\n }\r\n\r\n function disablePAN() {\r\n if ($(\"#chkPAN\").prop('checked') == true) {\r\n $(\"#txtPancard\").attr('disabled', 'disabled');\r\n $(\"#Upload\").attr('disabled', 'disabled');\r\n $(\"#txtPancard\").val('');\r\n }\r\n else {\r\n $(\"#txtPancard\").removeAttr('disabled');\r\n $(\"#Upload\").removeAttr('disabled');\r\n }\r\n }\r\n\r\n function otherHolderSave(personalDetails, tabId) {\r\n if (selectedPhotoFile != '' && selectedFile != '') {\r\n\r\n setPreloader(true);\r\n getBase64(selectedPhotoFile).then(\r\n photodata => {\r\n objRegistrationHolders.Base64Photo = photodata;\r\n\r\n getBase64(selectedFile).then(\r\n poidata => {\r\n objRegistrationHolders.Base64PAN = poidata\r\n\r\n axios.post(updatePersonalDetailsUrl(), personalDetails, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n if ($(\"#chkPAN\").prop('checked') == true) {\r\n toggleTabVertical(tabId + 1);\r\n setPreloader(false);\r\n }\r\n else if ($(\"#chkPAN\").prop('checked') == false) {\r\n toggleTabVertical(tabId + 2);\r\n setPreloader(false);\r\n }\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n setPreloader(false);\r\n }\r\n })\r\n }\r\n );\r\n }\r\n );\r\n }\r\n else if (selectedPhotoFile != '' && selectedFile == '') {\r\n\r\n setPreloader(true);\r\n objRegistrationHolders.Base64PAN = '';\r\n\r\n getBase64(selectedPhotoFile).then(\r\n photodata => {\r\n objRegistrationHolders.Base64Photo = photodata;\r\n\r\n axios.post(updatePersonalDetailsUrl(), personalDetails, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n if ($(\"#chkPAN\").prop('checked') == true) {\r\n toggleTabVertical(tabId + 1);\r\n setPreloader(false);\r\n }\r\n else if ($(\"#chkPAN\").prop('checked') == false) {\r\n toggleTabVertical(tabId + 2);\r\n setPreloader(false);\r\n }\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n setPreloader(false);\r\n }\r\n })\r\n }\r\n );\r\n }\r\n else if (selectedPhotoFile == '' && selectedFile != '') {\r\n\r\n setPreloader(true);\r\n objRegistrationHolders.Base64Photo = '';\r\n\r\n getBase64(selectedFile).then(\r\n poidata => {\r\n objRegistrationHolders.Base64PAN = poidata;\r\n\r\n axios.post(updatePersonalDetailsUrl(), personalDetails, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n if ($(\"#chkPAN\").prop('checked') == true) {\r\n toggleTabVertical(tabId + 1);\r\n setPreloader(false);\r\n }\r\n else if ($(\"#chkPAN\").prop('checked') == false) {\r\n toggleTabVertical(tabId + 2);\r\n setPreloader(false);\r\n }\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n setPreloader(false);\r\n }\r\n })\r\n }\r\n );\r\n }\r\n else if (selectedPhotoFile == '' && selectedFile == '') {\r\n\r\n setPreloader(true);\r\n objRegistrationHolders.Base64Photo = '';\r\n objRegistrationHolders.Base64PAN = '';\r\n\r\n axios.post(updatePersonalDetailsUrl(), personalDetails, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n if ($(\"#chkPAN\").prop('checked') == true) {\r\n toggleTabVertical(tabId + 1);\r\n setPreloader(false);\r\n }\r\n else if ($(\"#chkPAN\").prop('checked') == false) {\r\n toggleTabVertical(tabId + 2);\r\n setPreloader(false);\r\n }\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n setPreloader(false);\r\n }\r\n })\r\n }\r\n }\r\n\r\n function CreateAccount(tabId) {\r\n debugger;\r\n\r\n var today = new Date();\r\n\r\n if (tabId == 1) {\r\n\r\n //toggleTabVertical(tabId + 1);\r\n //return;\r\n\r\n if ($('#txtPhoneno').val().length > 0) {\r\n if ($('#txtPhoneno').val().length != 10) {\r\n $('#txtPhoneno').focus();\r\n ErrorMessage(\"Please enter 10 digit Mobile number!\");\r\n return;\r\n }\r\n }\r\n\r\n if (($('#txtPancard').val().trim() == \"\") && ($(\"#chkPAN\").prop('checked') == false)) {\r\n $('#txtPancard').focus();\r\n ErrorMessage(\"Please enter PAN No. or check Form60!\");\r\n return;\r\n }\r\n\r\n if ($(\"#chkPAN\").prop('checked') == false) {\r\n $('#navForm60').css('background-color', 'lightgrey');\r\n }\r\n else {\r\n $('#navForm60').css('background-color', '');\r\n }\r\n\r\n debugger;\r\n if ($(\"#chkPAN\").prop('checked') == false) {\r\n if (!panValidation($('#txtPancard').val().trim())) {\r\n ErrorMessage('Please enter valid PAN Number!');\r\n $('#txtPancard').focus();\r\n return;\r\n }\r\n }\r\n\r\n var IsValid = false;\r\n\r\n if (rowsData.length == 0) {\r\n ErrorMessage(\"Please add atleast one POI/POA document!\");\r\n return IsValid = false;\r\n }\r\n else {\r\n rowsData.map(poiCustomerData => {\r\n debugger;\r\n if (poiCustomerData.EnterNumber.trim().length == 0) {\r\n ErrorMessage(\"Please enter Document Number for \" + poiCustomerData.SelectedProofofIdentity + \"!\");\r\n return IsValid = false;\r\n }\r\n else if (poiCustomerData.Upload.length == 0 && poiCustomerData.poifilepath.length == 0) {\r\n ErrorMessage(\"Please uplaod document for \" + poiCustomerData.SelectedProofofIdentity + \"!\");\r\n return IsValid = false;\r\n }\r\n else {\r\n return IsValid = true;\r\n }\r\n })\r\n }\r\n\r\n rowsData.map(poiCustomerData => {\r\n if (poiCustomerData.EnterNumber.trim().length > 0) {\r\n if (poiCustomerData.SelectedProofofIdentity == \"Passport\" && (!passportValidation(poiCustomerData.EnterNumber))) {\r\n ErrorMessage('Please enter valid Passport Number!');\r\n return IsValid = false;\r\n }\r\n else if (poiCustomerData.SelectedProofofIdentity == \"UID\" && (!aadharValidation(poiCustomerData.EnterNumber))) {\r\n ErrorMessage('Please enter valid Aadhaar Number!');\r\n return IsValid = false;\r\n }\r\n else if (poiCustomerData.SelectedProofofIdentity == \"License\" && (!licenseValidation(poiCustomerData.EnterNumber))) {\r\n ErrorMessage('Please enter valid License Number!');\r\n return IsValid = false;\r\n }\r\n //else if (poiCustomerData.SelectedProofofIdentity == \"Voter ID\" && (!voterIDValidation(poiCustomerData.EnterNumber))) {\r\n // ErrorMessage('Please enter valid Voter ID Number!');\r\n // return IsValid = false;\r\n //}\r\n }\r\n })\r\n\r\n if (rowsData.find(p => p.POIPOA == \"POA & POI\") == undefined) {\r\n if (rowsData.find(p => p.POIPOA == \"POI\") == undefined) {\r\n ErrorMessage(\"Please add POI document!\");\r\n return IsValid = false;\r\n }\r\n else if (rowsData.find(p => p.POIPOA == \"POA\") == undefined) {\r\n ErrorMessage(\"Please add POA document!\");\r\n return IsValid = false;\r\n }\r\n }\r\n\r\n var age = getCustomerAge();\r\n var isPAN = \"true\";\r\n if ($(\"#chkPAN\").prop('checked') == true) {\r\n isPAN = \"false\";\r\n }\r\n\r\n if (IsValid) {\r\n\r\n objRegistrationHolders = {};\r\n\r\n objRegistrationHolders.Id = registrationHoldersId;\r\n objRegistrationHolders.Title = $('#ddlpersonalchoose').val();\r\n objRegistrationHolders.FirstName = $('#txtFirstName').val().trim();\r\n objRegistrationHolders.MiddleName = $('#txtMiddleName').val().trim();\r\n objRegistrationHolders.LastName = $('#txtLastName').val().trim();\r\n objRegistrationHolders.DOB = $('#txtdob').val();\r\n objRegistrationHolders.Gender = $('#ddlgender').val();\r\n objRegistrationHolders.Nationality = $('#ddlnationality').val();\r\n objRegistrationHolders.Occupation = $('#ddloccupation').val().trim();\r\n objRegistrationHolders.Mobile = $('#txtPhoneno').val().trim();\r\n objRegistrationHolders.Email = $('#txtEmailID').val().trim();\r\n objRegistrationHolders.MartialStatus = $('#ddlmaratialstatus').val();\r\n objRegistrationHolders.LocalAddress1 = $('#txtCommunicationAddress1').val().trim();\r\n objRegistrationHolders.LocalAddress2 = $('#txtCommunicationAddress2').val().trim();\r\n objRegistrationHolders.LocalAddress3 = $('#txtCommunicationAddress3').val().trim();\r\n objRegistrationHolders.LocalCity = $('#txtCommunicationCity').val().trim();\r\n objRegistrationHolders.LocalPin = $('#txtCommunicationPincode').val().trim();\r\n objRegistrationHolders.LocalState = $('#ddlCommunicationState').val();\r\n objRegistrationHolders.PermanentAddress1 = $('#txtPermanentAddress1').val().trim();\r\n objRegistrationHolders.PermanentAddress2 = $('#txtPermanentAddress2').val().trim();\r\n objRegistrationHolders.PermanentAddress3 = $('#txtPermanentAddress3').val().trim();\r\n objRegistrationHolders.PermanentCity = $('#txtPermanentCity').val().trim();\r\n objRegistrationHolders.PermanentPin = $('#txtPermanentPincode').val().trim();\r\n objRegistrationHolders.PermanentState = $('#ddlPermanentState').val();\r\n objRegistrationHolders.PAN = $('#txtPancard').val();\r\n objRegistrationHolders.IsMinor = age < 18 ? \"true\" : \"false\";\r\n objRegistrationHolders.isPAN = isPAN;\r\n objRegistrationHolders.CustomerId = $('#txtCustomerID').val().trim();\r\n objRegistrationHolders.CKYCNo = $('#txtCKYCNumber').val().trim();\r\n\r\n rowsData.map(poiCustomerData => {\r\n if (poiCustomerData.Upload != \"\") {\r\n getBase64(poiCustomerData.Upload).then(data => {\r\n registrationHoldersPOI = {};\r\n registrationHoldersPOI.POIId = poiCustomerData.poiid;\r\n registrationHoldersPOI.Base64POI = data;\r\n registrationHoldersPOI.POI = poiCustomerData.SelectedProofofIdentity;\r\n registrationHoldersPOI.POINo = poiCustomerData.EnterNumber;\r\n registrationHoldersPOI.POIPOA = poiCustomerData.POIPOA;\r\n registrationHoldersPOI.ExpiryDate = poiCustomerData.Expiry;\r\n registrationHoldersPOIList.push(registrationHoldersPOI);\r\n\r\n if (registrationHoldersPOIList.length == rowsData.length) {\r\n objRegistrationHolders.registrationHoldersPOI = registrationHoldersPOIList;\r\n personalDetails.objRegistrationHolders = objRegistrationHolders;\r\n\r\n otherHolderSave(personalDetails, tabId);\r\n }\r\n })\r\n }\r\n else {\r\n registrationHoldersPOI = {};\r\n registrationHoldersPOI.POIId = poiCustomerData.poiid;\r\n registrationHoldersPOI.Base64POI = \"\";\r\n registrationHoldersPOI.POI = poiCustomerData.SelectedProofofIdentity;\r\n registrationHoldersPOI.POINo = poiCustomerData.EnterNumber;\r\n registrationHoldersPOI.POIPOA = poiCustomerData.POIPOA;\r\n registrationHoldersPOI.ExpiryDate = poiCustomerData.Expiry;\r\n registrationHoldersPOIList.push(registrationHoldersPOI);\r\n\r\n if (registrationHoldersPOIList.length == rowsData.length) {\r\n objRegistrationHolders.registrationHoldersPOI = registrationHoldersPOIList;\r\n personalDetails.objRegistrationHolders = objRegistrationHolders;\r\n\r\n otherHolderSave(personalDetails, tabId);\r\n }\r\n }\r\n })\r\n }\r\n }\r\n else if (tabId == 2) {\r\n\r\n //toggleTabVertical(tabId + 1);\r\n //return;\r\n\r\n var DeclarantAssessedTax = false;\r\n\r\n if ($(\"#rbaccessedtaxyes\").prop(\"checked\")) {\r\n DeclarantAssessedTax = true;\r\n }\r\n else if ($(\"#rbaccessedtaxno\").prop(\"checked\")) {\r\n DeclarantAssessedTax = false;\r\n }\r\n\r\n form60.RegistrationId = localStorage.getItem('registrationId');\r\n form60.RegistrationHolderId = registrationHoldersId;\r\n form60.DeclarantDocuments = \"\";\r\n form60.DeclarantTransactionParticulars = $('#txttransactionparticulars').val().trim();\r\n form60.DeclarantAmountofTransaction = $('#txttransactionsamount').val().trim();\r\n form60.DeclarantAssessedTax = DeclarantAssessedTax;\r\n form60.DetailsOfIncomeTax = $('#txtdetailsofincometax').val().trim();\r\n form60.ReasonForNoPan = $('#txtreasonfornopan').val().trim();\r\n\r\n setPreloader(true);\r\n axios.post(form60Url(), form60, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n toggleTabVertical(tabId + 1);\r\n setPreloader(false);\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n setPreloader(false);\r\n }\r\n })\r\n }\r\n else if (tabId == 3) {\r\n if ($('#ddloccupationdetails :selected').text() == \"Businessman\") {\r\n\r\n if ($('#txtlineofnusiness').val().trim() == \"\") {\r\n $('#txtlineofnusiness').focus();\r\n ErrorMessage(\"Line of Business is required!\");\r\n return;\r\n }\r\n else if ($('#txtbusinessname').val().trim() == \"\") {\r\n $('#txtbusinessname').focus();\r\n ErrorMessage(\"Business Name is required!\");\r\n return;\r\n }\r\n else if ($('#txtstartbusinessdate').val().trim() == \"\") {\r\n $('#txtstartbusinessdate').focus();\r\n ErrorMessage(\"Date of starting business is required!\");\r\n return;\r\n }\r\n else if ($('#txtbussinessaddress1').val().trim() == \"\") {\r\n $('#txtbussinessaddress1').focus();\r\n ErrorMessage(\"Address1 required!\");\r\n return;\r\n }\r\n else if ($('#txtbussinessaddress2').val().trim() == \"\") {\r\n $('#txtbussinessaddress2').focus();\r\n ErrorMessage(\"Address2 required!\");\r\n return;\r\n }\r\n }\r\n\r\n if ($(\"#chktwowheeler\").prop(\"checked\")) {\r\n if ($('#txttwowheeleryear').val().trim() == \"\") {\r\n $('#txttwowheeleryear').focus();\r\n ErrorMessage(\"Two Wheeler year is required!\");\r\n return;\r\n }\r\n if (parseInt($('#txttwowheeleryear').val().trim()) > today.getFullYear()) {\r\n $('#txttwowheeleryear').focus();\r\n ErrorMessage(\"Two Wheeler year should be valid!\");\r\n return;\r\n }\r\n }\r\n if ($(\"#chkcar\").prop(\"checked\")) {\r\n if ($('#txtcaryear').val().trim() == \"\") {\r\n $('#txtcaryear').focus();\r\n ErrorMessage(\"Car year is required!\");\r\n return;\r\n }\r\n\r\n if (parseInt($('#txtcaryear').val().trim()) > today.getFullYear()) {\r\n $('#txtcaryear').focus();\r\n ErrorMessage(\"Car year should be valid!\");\r\n return;\r\n }\r\n }\r\n if ($(\"#chkother\").prop(\"checked\")) {\r\n if ($('#txtotheryear').val().trim() == \"\") {\r\n $('#txtotheryear').focus();\r\n ErrorMessage(\"Other year is required!\");\r\n return;\r\n }\r\n\r\n if (parseInt($('#txtotheryear').val().trim()) > today.getFullYear()) {\r\n $('#txtotheryear').focus();\r\n ErrorMessage(\"Other year should be valid!\");\r\n return;\r\n }\r\n }\r\n\r\n var BornNonIndia = '';\r\n var TaxResidenceNonIndia = '';\r\n var BusinessVehicleTwoWheeler = '';\r\n var BusinessVehicleCar = '';\r\n var BusinessVehicleOther = '';\r\n var BusinessTwoWheelerPurchaseYear = '';\r\n var BusinessCarPurchaseYear = '';\r\n var BusinessOtherPurchaseYear = '';\r\n var InterestedIn = '';\r\n var BusinessAssetDetails = '';\r\n\r\n if ($(\"#rbbornyes\").prop(\"checked\")) {\r\n BornNonIndia = \"true\";\r\n }\r\n else if ($(\"#rbbornno\").prop(\"checked\")) {\r\n BornNonIndia = \"false\";\r\n }\r\n\r\n if ($(\"#rbtaxresidenceyes\").prop(\"checked\")) {\r\n TaxResidenceNonIndia = \"true\";\r\n }\r\n else if ($(\"#rbtaxresidenceno\").prop(\"checked\")) {\r\n TaxResidenceNonIndia = \"false\";\r\n }\r\n\r\n if ($(\"#chktwowheeler\").prop(\"checked\")) {\r\n BusinessVehicleTwoWheeler = 'Two Wheeler';\r\n BusinessTwoWheelerPurchaseYear = $('#txttwowheeleryear').val();\r\n }\r\n if ($(\"#chkcar\").prop(\"checked\")) {\r\n BusinessVehicleCar = 'Car';\r\n BusinessCarPurchaseYear = $('#txtcaryear').val();\r\n }\r\n if ($(\"#chkother\").prop(\"checked\")) {\r\n BusinessVehicleOther = 'Other';\r\n BusinessOtherPurchaseYear = $('#txtotheryear').val();\r\n }\r\n\r\n if ($(\"#chkcommercialproperty\").prop(\"checked\")) {\r\n BusinessAssetDetails = BusinessAssetDetails + \"Commercial Property\" + \", \";\r\n }\r\n if ($(\"#chkhouse\").prop(\"checked\")) {\r\n BusinessAssetDetails = BusinessAssetDetails + \"House\" + \", \";\r\n }\r\n if ($(\"#chkplot\").prop(\"checked\")) {\r\n BusinessAssetDetails = BusinessAssetDetails + \"Plot\" + \", \";\r\n }\r\n if ($(\"#chkothers\").prop(\"checked\")) {\r\n BusinessAssetDetails = BusinessAssetDetails + \"Others\" + \", \";\r\n }\r\n\r\n if ($(\"#chktwowheeler\").prop(\"checked\")) {\r\n BusinessVehicleTwoWheeler = \"Two Wheeler\";\r\n }\r\n if ($(\"#chkcar\").prop(\"checked\")) {\r\n BusinessVehicleCar = \"Car\";\r\n }\r\n if ($(\"#chkother\").prop(\"checked\")) {\r\n BusinessVehicleOther = \"Other\";\r\n }\r\n\r\n if ($(\"#chkmutualfunds\").prop(\"checked\")) {\r\n InterestedIn = InterestedIn + \"Mutual Funds\" + \", \";\r\n }\r\n if ($(\"#chkhealthinsurance\").prop(\"checked\")) {\r\n InterestedIn = InterestedIn + \"Health Insurance\" + \", \";\r\n }\r\n if ($(\"#chkgeneralinsurance\").prop(\"checked\")) {\r\n InterestedIn = InterestedIn + \"General Insurance\" + \", \";\r\n }\r\n if ($(\"#chkdemat\").prop(\"checked\")) {\r\n InterestedIn = InterestedIn + \"Demat\" + \", \";\r\n }\r\n if ($(\"#chkpmsby\").prop(\"checked\")) {\r\n InterestedIn = InterestedIn + \"Pradhan Mantri Suraksha Bima Yojana (PMSBY)\" + \", \";\r\n }\r\n if ($(\"#chkpmjjby\").prop(\"checked\")) {\r\n InterestedIn = InterestedIn + \"Pradhan Mantri Jeevan Jyoti Bima Yojana (PMJJBY)\" + \", \";\r\n }\r\n\r\n additionalDetails.RegistrationId = localStorage.getItem('registrationId');\r\n additionalDetails.RegistrationHolderId = registrationHoldersId;\r\n additionalDetails.FundsExpectedOrigin = $('#ddlfundsforcredit :selected').text();\r\n additionalDetails.FundsUtilisationExpected = $('#ddlfundsbydebit :selected').text();\r\n additionalDetails.OtherBankAccounts = $('#ddlotherbanksaccounts :selected').text();\r\n additionalDetails.Turnover = $('#txtturnover').val().trim();\r\n additionalDetails.AverageIncome = $('#txtaverageincome').val().trim();\r\n additionalDetails.AverageBalance = $('#txtexpectedincome').val().trim();\r\n additionalDetails.Education = $('#ddleducation :selected').text();\r\n additionalDetails.Religion = $('#ddlreligion :selected').text();\r\n additionalDetails.OccupationDetails = $('#ddloccupationdetails :selected').text();\r\n additionalDetails.LineOfBusiness = $('#txtlineofnusiness').val().trim();\r\n additionalDetails.BusinessName = $('#txtbusinessname').val().trim();\r\n additionalDetails.BusinessStartDate = $('#txtstartbusinessdate').val();\r\n additionalDetails.BusinessAddress1 = $('#txtbussinessaddress1').val().trim();\r\n additionalDetails.BusinessAddress2 = $('#txtbussinessaddress2').val().trim();\r\n additionalDetails.BusinessAddress3 = $('#txtbussinessaddress3').val().trim();\r\n additionalDetails.BusinessTelNo = $('#txtofficecontact').val().trim();\r\n additionalDetails.BusinessMobileNo = $('#txtofficemobileno').val().trim();\r\n additionalDetails.BusinessAnnualIncome = $('#ddlannualincome :selected').text();\r\n additionalDetails.BusinessIncomeSource = $('#txtsourceofincome').val().trim();\r\n additionalDetails.BusinessWealthSource = $('#txtsourceofwealth').val().trim();\r\n additionalDetails.BusinessEstimatedValue = $('#ddlestimatedvalue :selected').text();\r\n additionalDetails.BusinessAssetDetails = BusinessAssetDetails;\r\n additionalDetails.BornNonIndia = BornNonIndia;\r\n additionalDetails.TaxResidenceNonIndia = TaxResidenceNonIndia;\r\n additionalDetails.BusinessVehicleTwoWheeler = BusinessVehicleTwoWheeler;\r\n additionalDetails.BusinessVehicleCar = BusinessVehicleCar;\r\n additionalDetails.BusinessVehicleOther = BusinessVehicleOther;\r\n additionalDetails.BusinessTwoWheelerPurchaseYear = BusinessTwoWheelerPurchaseYear;\r\n additionalDetails.BusinessCarPurchaseYear = BusinessCarPurchaseYear;\r\n additionalDetails.BusinessOtherPurchaseYear = BusinessOtherPurchaseYear;\r\n additionalDetails.BusinessCarMaker = $('#txtcarmaker').val().trim();\r\n additionalDetails.InterestedIn = InterestedIn;\r\n additionalDetails.caste = $('#caste :selected').text();\r\n\r\n setPreloader(true);\r\n axios.post(additionalDetailsUrl(), additionalDetails, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n toggleTabVertical(tabId + 1);\r\n setPreloader(false);\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n setPreloader(false);\r\n }\r\n })\r\n }\r\n else if (tabId == 4) {\r\n if ($(\"#chkTerms\").prop('checked') == true) {\r\n\r\n const updateStatus = {\r\n RegistrationId: localStorage.getItem('registrationId'),\r\n RegistrationHolderId: registrationHoldersId\r\n };\r\n\r\n setPreloader(true);\r\n axios.post(updateAccountHoldersStatusUrl(), updateStatus, { headers: authHeader() })\r\n .then(res => {\r\n if (res.data.responseCode == \"OK\") {\r\n history.push(\"/CreateNewAccount\");\r\n setPreloader(false);\r\n }\r\n else {\r\n ErrorMessage(res.data.responseMessage);\r\n setPreloader(false);\r\n }\r\n })\r\n }\r\n else {\r\n ErrorMessage(\"Please select Terms & conditions\");\r\n $(\"#chkTerms\").focus();\r\n }\r\n }\r\n }\r\n\r\n const [activeTabVartical, setoggleTabVertical] = useState(1)\r\n const [passedStepsVertical, setPassedStepsVertical] = useState([1])\r\n\r\n function toggleTabVertical(tab) {\r\n if (activeTabVartical !== tab) {\r\n var modifiedSteps = [...passedStepsVertical, tab]\r\n\r\n if (tab >= 1 && tab <= 4) {\r\n setoggleTabVertical(tab)\r\n setPassedStepsVertical(modifiedSteps)\r\n }\r\n }\r\n }\r\n\r\n function FillAddress() {\r\n debugger;\r\n\r\n if ($(\"#chkSameAs\").prop(\"checked\")) {\r\n let comAddress1 = $('#txtCommunicationAddress1').val();\r\n let comAddress2 = $('#txtCommunicationAddress2').val();\r\n let comAddress3 = $('#txtCommunicationAddress3').val();\r\n let comCity = $('#txtCommunicationCity').val();\r\n let comPin = $('#txtCommunicationPincode').val();\r\n let comState = $('#ddlCommunicationState').val();\r\n\r\n $('#txtPermanentAddress1').val(comAddress1);\r\n $('#txtPermanentAddress2').val(comAddress2);\r\n $('#txtPermanentAddress3').val(comAddress3);\r\n $('#txtPermanentCity').val(comCity);\r\n $('#txtPermanentPincode').val(comPin);\r\n $('#ddlPermanentState').val(comState);\r\n\r\n validation.values.permanentaddress = comAddress1;\r\n validation.values.permanentaddress2 = comAddress2;\r\n validation.values.permanentaddress3 = comAddress3;\r\n validation.values.permanentstate = comState;\r\n validation.values.permanentcity = comCity;\r\n validation.values.permanentpincode = comPin;\r\n }\r\n else {\r\n $('#txtPermanentAddress1').val('');\r\n $('#txtPermanentAddress2').val('');\r\n $('#txtPermanentAddress3').val('');\r\n $('#txtPermanentCity').val('');\r\n $('#txtPermanentPincode').val('');\r\n $('#ddlPermanentState').val('');\r\n }\r\n }\r\n\r\n // Form validation\r\n const validation = useFormik({\r\n\r\n enableReinitialize: true,\r\n\r\n initialValues: {\r\n\r\n personalchoose: holdersData.title == null ? '' : holdersData.title,\r\n firstname: holdersData.firstName == null ? '' : holdersData.firstName,\r\n middlename: holdersData.middleName == null ? '' : holdersData.middleName,\r\n lastname: holdersData.lastName == null ? '' : holdersData.lastName,\r\n phoneno: holdersData.mobile == null ? '' : holdersData.mobile,\r\n email: holdersData.email == null ? '' : holdersData.email,\r\n gender: holdersData.gender == null ? '' : holdersData.gender,\r\n occupation: holdersData.occupation == null ? '' : holdersData.occupation,\r\n dob: holdersData.dob == null ? '' : holdersData.dob,\r\n maritalstatus: holdersData.length == 0 ? '2' : holdersData.dob == null ? '2' : holdersData.maritalStatus,\r\n nationality: holdersData.length == 0 ? '1' : holdersData.dob == null ? '1' : holdersData.nationality,\r\n communicationaddress: holdersData.localAddress1 == null ? '' : holdersData.localAddress1,\r\n communicationaddress2: holdersData.localAddress2 == null ? '' : holdersData.localAddress2,\r\n communicationaddress3: holdersData.localAddress3 == null ? '' : holdersData.localAddress3,\r\n communicationstate: holdersData.localState == null ? '' : holdersData.localState,\r\n communicationcity: holdersData.localCity == null ? '' : holdersData.localCity,\r\n communicationpincode: holdersData.localPin == null ? '' : holdersData.localPin,\r\n permanentaddress: holdersData.permanentAddress1 == null ? '' : holdersData.permanentAddress1,\r\n permanentaddress2: holdersData.permanentAddress2 == null ? '' : holdersData.permanentAddress2,\r\n permanentaddress3: holdersData.permanentAddress3 == null ? '' : holdersData.permanentAddress3,\r\n permanentstate: holdersData.permanentState == null ? '' : holdersData.permanentState,\r\n permanentcity: holdersData.permanentCity == null ? '' : holdersData.permanentCity,\r\n permanentpincode: holdersData.permanentPin == null ? '' : holdersData.permanentPin,\r\n poi: '',\r\n poipoa: '',\r\n pan: holdersData.pan == null ? '' : holdersData.pan,\r\n panfile: '',\r\n poifilePath: holdersData.poiFilePath == null ? '' : holdersData.poiFilePath,\r\n customerid: holdersData.customerId == null ? '' : holdersData.customerId,\r\n ckycno: holdersData.ckycNo == null ? '' : holdersData.ckycNo,\r\n photofile: '',\r\n photofilepath: holdersData.photoFilePath == null ? '' : holdersData.photoFilePath,\r\n\r\n fatherchoose: holdersData.fatherTitle == null ? '' : holdersData.fatherTitle,\r\n fatherlastname: holdersData.fatherLastName == null ? '' : holdersData.fatherLastName,\r\n fatherfirstname: holdersData.fatherFirstName == null ? '' : holdersData.fatherFirstName,\r\n fathermiddlelame: holdersData.fatherMiddleName == null ? '' : holdersData.fatherMiddleName,\r\n motherchoose: holdersData.motherTitle == null ? '' : holdersData.motherTitle,\r\n motherlastname: holdersData.motherLastName == null ? '' : holdersData.motherLastName,\r\n motherfirstname: holdersData.motherFirstName == null ? '' : holdersData.motherFirstName,\r\n mothermiddlename: holdersData.motherMiddleName == null ? '' : holdersData.motherMiddleName,\r\n maidenchoose: holdersData.maidenTitle == null ? '' : holdersData.maidenTitle,\r\n maidenlastname: holdersData.maidenLastName == null ? '' : holdersData.maidenLastName,\r\n maidenfirstname: holdersData.maidenFirstName == null ? '' : holdersData.maidenFirstName,\r\n maidenmiddlename: holdersData.maidenMiddleName == null ? '' : holdersData.maidenMiddleName,\r\n\r\n relatedpersonchoose: holdersData.relatedPersonTitle == null ? '' : holdersData.relatedPersonTitle,\r\n relatedpersonlastname: holdersData.relatedPeronLastName == null ? '' : holdersData.relatedPeronLastName,\r\n relatedpersonfirstname: holdersData.relatedPeronFirstName == null ? '' : holdersData.relatedPeronFirstName,\r\n relatedpersonmiddlename: holdersData.relatedPeronMiddleName == null ? '' : holdersData.relatedPeronMiddleName,\r\n relatedpersonrelation: holdersData.relatedPersonCustomerRelation == null ? '' : holdersData.relatedPersonCustomerRelation,\r\n relatedpersonpan: holdersData.relatedPersonPANNo == null ? '' : holdersData.relatedPersonPANNo,\r\n relatedpersonaadhar: holdersData.relatedPersonAadhaarNo == null ? '' : holdersData.relatedPersonAadhaarNo,\r\n relatedcourt: holdersData.relatedPersonCourtOrderNo == null ? '' : holdersData.relatedPersonCourtOrderNo,\r\n\r\n transactionparticulars: holdersData.declarantTransactionParticulars == null ? '' : holdersData.declarantTransactionParticulars,\r\n transactionsamount: holdersData.declarantAmountofTransaction == null ? '' : holdersData.declarantAmountofTransaction,\r\n detailsofincometax: holdersData.detailsOfIncomeTax == null ? '' : holdersData.detailsOfIncomeTax,\r\n reasonfornopan: holdersData.reasonForNoPan == null ? '' : holdersData.reasonForNoPan,\r\n\r\n annualactivity: holdersData.turnover == null ? '' : holdersData.turnover,\r\n averageincome: holdersData.averageIncome == null ? '' : holdersData.averageIncome,\r\n expectedincome: holdersData.averageBalance == null ? '' : holdersData.averageBalance,\r\n officecontact: holdersData.businessTelNo == null ? '' : holdersData.businessTelNo,\r\n officemobileno: holdersData.businessMobileNo == null ? '' : holdersData.businessMobileNo,\r\n twowheeleryear: holdersData.businessVehicleTwoWheeler == \"Two Wheeler\" ? holdersData.businessTwoWheelerPurchaseYear == null ? '' : holdersData.businessTwoWheelerPurchaseYear : '',\r\n caryear: holdersData.businessVehicleCar == \"Car\" ? holdersData.businessCarPurchaseYear == null ? '' : holdersData.businessCarPurchaseYear : '',\r\n anyotheryear: holdersData.businessVehicleOther == \"Other\" ? holdersData.businessOtherPurchaseYear == null ? '' : holdersData.businessOtherPurchaseYear : '',\r\n annualincome: holdersData.annualincome == null ? '' : holdersData.annualincome,\r\n },\r\n validationSchema: Yup.object({\r\n\r\n personalchoose: Yup.string().required(\"Title required\"),\r\n firstname: Yup.string().required(\"First Name required\").matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n middlename: Yup.string().required(\"Middle Name required\").matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n lastname: Yup.string().required(\"Last Name required\").matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n phoneno: Yup.string().required(\"Phone No. required\"),\r\n gender: Yup.string().required(\"Gender required\"),\r\n dob: Yup.string().required(\"Date of Birth required\"),\r\n maritalstatus: Yup.string().required(\"Maratial Status required\"),\r\n nationality: Yup.string().required(\"Nationality required\"),\r\n occupation: Yup.string().required(\"Occupation required\"),\r\n communicationaddress: Yup.string().required(\"Address 1 required\"),\r\n communicationstate: Yup.string().required(\"State required\"),\r\n communicationcity: Yup.string().required(\"City required\").matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n communicationpincode: Yup.number().required(\"Pincode required\"),\r\n permanentaddress: Yup.string().required(\"Address 1 required\"),\r\n permanentstate: Yup.string().required(\"State required\"),\r\n permanentcity: Yup.string().required(\"City required\").matches(/^[A-Za-z ]+$/, \"Enter character only!\"),\r\n permanentpincode: Yup.number().required(\"Pincode required\"),\r\n poi: Yup.string().required(\"POI required\"),\r\n poipoa: Yup.string().required(\"POI/POA required\"),\r\n pan: Yup.string().required(\"PAN No. required\"),\r\n panfile: Yup.string().required(\"PAN document required\"),\r\n photofile: Yup.string().required(\"Photo required\"),\r\n\r\n transactionparticulars: Yup.string().required(\"Transaction Particulars required\"),\r\n transactionsamount: Yup.string().required(\"Amount of Transactions required\"),\r\n detailsofincometax: Yup.string().required(\"Details of income required\"),\r\n reasonfornopan: Yup.string().required(\"Reason for not having PAN required\"),\r\n\r\n annualactivity: Yup.string().required(\"Annual activity/ A/c turnover required\"),\r\n averageincome: Yup.string().required(\"Average income required\"),\r\n expectedincome: Yup.string().required(\"Expected average balance required\"),\r\n annualincome: Yup.string().required(\"Annual income required\"),\r\n officemobileno: Yup.string().required(\"Mobile number required\"),\r\n }),\r\n\r\n onSubmit: (values) => {\r\n //console.log(\"values\", values);\r\n }\r\n });\r\n\r\n\r\n function BindPOIPOA(data) {\r\n debugger;\r\n var listPOI = [];\r\n\r\n if (data.length > 0) {\r\n if (data[0].poi != null) {\r\n data.map(p => {\r\n var rowsInput = {\r\n poiid: p.poiId.toString(),\r\n SelectedProofofIdentity: p.poi,\r\n EnterNumber: p.poiNo,\r\n POIPOA: p.poipoa,\r\n Expiry: p.expiryDate == null ? '' : p.expiryDate,\r\n Upload: '',\r\n poifilepath: p.poiFilePath,\r\n poifilepathurl: getAPIUrl() + \"/POIFiles/\" + p.poiFilePath,\r\n Delete: ''\r\n }\r\n listPOI.push(rowsInput);\r\n })\r\n\r\n setRowsData(listPOI);\r\n }\r\n }\r\n }\r\n\r\n function CheckIsValid(controlValues) {\r\n debugger;\r\n var x = Object.keys(controlValues[0])\r\n var isCheckIfUndefined = x.map(p => {\r\n if (controlValues[0][p] === \"\" || controlValues[0][p] === undefined) {\r\n if ((p == \"pan\" && controlValues[0][p] == \"\" && $(\"#chkPAN\").prop('checked')) || (p == \"panfile\" && controlValues[0][p] == \"\" && $(\"#chkPAN\").prop('checked'))) {\r\n return false;\r\n }\r\n else if (p == \"panfile\" && validation.values.poifilePath != '' && !$(\"#chkPAN\").prop('checked')) {\r\n return false;\r\n }\r\n else if (p == \"photofile\" && validation.values.photofilepath != '') {\r\n return false;\r\n }\r\n else if (p == \"panfile\" && validation.values.poifilePath == '' && !$(\"#chkPAN\").prop('checked')) {\r\n return true;\r\n }\r\n else if (p == \"photofile\" && validation.values.photofilepath == '') {\r\n return true;\r\n }\r\n else if (p == \"email\") {\r\n return false;\r\n }\r\n return true;\r\n }\r\n else\r\n return false;\r\n })\r\n\r\n var checkResponse = isCheckIfUndefined.includes(true)\r\n return checkResponse\r\n }\r\n\r\n //$(\".d-block\").flatpickr({\r\n // dateFormat: \"d-M-Y\",\r\n // maxDate: \"today\"\r\n //});\r\n $(\".d-block\").flatpickr({\r\n dateFormat: \"d-M-Y\",\r\n altFormat: \"F j, Y\",\r\n maxDate: \"today\",\r\n disableMobile: \"true\"\r\n });\r\n\r\n $(\".maxFuture\").flatpickr({\r\n dateFormat: \"d-M-Y\",\r\n disableMobile: \"true\"\r\n });\r\n\r\n const tabHeading = {\r\n color: \"#9a084f\",\r\n fontWeight: \"bold\"\r\n }\r\n\r\n const label = {\r\n color: \"black\"\r\n }\r\n\r\n const formBackground = {\r\n borderRadius: 8,\r\n flex: 1,\r\n //backgroundColor: \"rgb(247 242 242)\",\r\n padding: \"15px\"\r\n }\r\n\r\n const cardBackground = {\r\n borderRadius: 8,\r\n flex: 1,\r\n //backgroundColor: \"rgb(247 242 242)\",\r\n }\r\n\r\n const formButton = {\r\n marginLeft: \"20px\",\r\n backgroundColor: \"#9a084f\",\r\n fontSize: \"small\",\r\n borderRadius: \"0.50rem\"\r\n }\r\n\r\n const formButtonFirstPage = {\r\n marginLeft: \"15px\",\r\n backgroundColor: \"#9a084f\",\r\n fontSize: \"small\",\r\n borderRadius: \"0.50rem\"\r\n }\r\n\r\n const formMandatory = {\r\n color: \"red\",\r\n fontWeight: \"bold\"\r\n }\r\n\r\n return (\r\n
\r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n\r\n \r\n JSB-Other Holder\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n
\r\n
\r\n \r\n {\r\n toggleTabVertical(1)\r\n }}\r\n disabled={!(passedStepsVertical || []).includes(1)}\r\n >\r\n 1 Personal Details\r\n \r\n \r\n \r\n {\r\n toggleTabVertical(2)\r\n }}\r\n disabled={!(passedStepsVertical || []).includes(2)}\r\n >\r\n 2{\" \"}\r\n Form no 60/61\r\n \r\n \r\n \r\n {\r\n toggleTabVertical(3)\r\n }}\r\n disabled={!(passedStepsVertical || []).includes(3)}\r\n >\r\n 3 Additional Details\r\n \r\n \r\n \r\n {\r\n toggleTabVertical(4)\r\n }}\r\n disabled={!(passedStepsVertical || []).includes(4)}\r\n >\r\n 4Declaration\r\n \r\n \r\n
\r\n
\r\n\r\n
\r\n
\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n
\r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n
\r\n \r\n \r\n
\r\n
\r\n \r\n \r\n\r\n \r\n
\r\n \r\n \r\n )\r\n}\r\n\r\nexport default OtherHolder\r\n","import PropTypes from \"prop-types\";\r\nimport MetaTags from \"react-meta-tags\";\r\nimport React, { useState, useEffect } from \"react\"\r\nimport { Row, Col, CardBody, Card, Alert, Container, Form, Input, FormFeedback, Label, FormGroup, Modal } from \"reactstrap\";\r\nimport axios from 'axios';\r\nimport { v4 as uuid } from 'uuid';\r\nimport { useSelector, useDispatch } from \"react-redux\";\r\nimport { useHistory, withRouter, Link } from \"react-router-dom\";\r\nimport toastr from \"toastr\";\r\nimport \"toastr/build/toastr.min.css\";\r\nimport * as Yup from \"yup\";\r\nimport { useFormik } from \"formik\";\r\nimport banner from \"../../assets/images/banner/banner.jpg\";\r\nimport authHeader from \"helpers/authHeader\";\r\nimport FormLoader from \"../JSBForms/FormLoader\";\r\nimport { checkBranchLogin } from \"../../helpers/fakebackend_helper\";\r\n\r\nconst BranchLogin = (props) => {\r\n const dispatch = useDispatch();\r\n const history = useHistory();\r\n const [isLoading, setLoading] = useState(false);\r\n\r\n const validation = useFormik({\r\n // enableReinitialize : use this flag when initial values needs to be changed\r\n enableReinitialize: true,\r\n\r\n initialValues: {\r\n username: '',\r\n password: '',\r\n showPassword: false,\r\n },\r\n validationSchema: Yup.object({\r\n username: Yup.string().required(\"User Name required\"),\r\n password: Yup.string().required(\"Password required\"),\r\n }),\r\n onSubmit: (values) => {\r\n //dispatch(BranchLoginUser(values, props.history));\r\n }\r\n\r\n });\r\n\r\n const [showEasing, setshowEasing] = useState(\"swing\");\r\n const [hideEasing, sethideEasing] = useState(\"linear\");\r\n const [showMethod, setshowMethod] = useState(\"fadeIn\");\r\n const [hideMethod, sethideMethod] = useState(\"fadeOut\");\r\n const [showDuration, setshowDuration] = useState(300);\r\n const [hideDuration, sethideDuration] = useState(1000);\r\n const [timeOut, settimeOut] = useState(2000);\r\n const [extendedTimeOut, setextendedTimeOut] = useState(1000);\r\n\r\n function SuccessMessage(message) {\r\n toastr.options = {\r\n positionClass: \"toast-top-center\",\r\n timeOut: timeOut,\r\n extendedTimeOut: extendedTimeOut,\r\n closeButton: true,\r\n debug: false,\r\n progressBar: false,\r\n preventDuplicates: false,\r\n newestOnTop: false,\r\n showEasing: showEasing,\r\n hideEasing: hideEasing,\r\n showMethod: showMethod,\r\n hideMethod: hideMethod,\r\n showDuration: showDuration,\r\n hideDuration: hideDuration\r\n };\r\n\r\n toastr.success(message, \"Information\");\r\n }\r\n\r\n function ErrorMessage(message) {\r\n toastr.options = {\r\n positionClass: \"toast-top-center\",\r\n timeOut: timeOut,\r\n extendedTimeOut: extendedTimeOut,\r\n closeButton: true,\r\n debug: false,\r\n progressBar: false,\r\n preventDuplicates: false,\r\n newestOnTop: false,\r\n showEasing: showEasing,\r\n hideEasing: hideEasing,\r\n showMethod: showMethod,\r\n hideMethod: hideMethod,\r\n showDuration: showDuration,\r\n hideDuration: hideDuration\r\n };\r\n\r\n toastr.error(message, \"Error\");\r\n }\r\n\r\n const textboxRounded = {\r\n color: \"black\",\r\n //fontSize: \"larger\"\r\n };\r\n\r\n const modalpopup = {\r\n border: \"2px solid black\", textAlign: \"center\", fontSize: \"large\", color: \"black\"\r\n };\r\n\r\n const cardBackground = {\r\n borderRadius: 15,\r\n flex: 1,\r\n marginTop: \"20px\",\r\n boxShadow: \"#504f4f6b 5px 5px 20px\",\r\n width: \"99%\",\r\n backgroundColor: \"rgb(247 242 242)\"\r\n }\r\n\r\n const [modal_backdrop, setmodal_backdrop] = useState(false);\r\n const [guid, setguid] = useState(\"\");\r\n const [isPreloader, setPreloader] = useState(false);\r\n\r\n function tog_backdrop() {\r\n setmodal_backdrop(!modal_backdrop);\r\n removeBodyCss();\r\n };\r\n\r\n function removeBodyCss() {\r\n document.body.classList.add(\"no_padding\")\r\n };\r\n\r\n useEffect(() => {\r\n if (isPreloader === true) {\r\n document.getElementById(\"preloader\").style.display = \"block\";\r\n document.getElementById(\"status\").style.display = \"block\";\r\n } else {\r\n document.getElementById(\"preloader\").style.display = \"none\";\r\n document.getElementById(\"status\").style.display = \"none\";\r\n }\r\n }, [isPreloader]);\r\n\r\n function CheckBranchLogin(UserName, Password) {\r\n debugger;\r\n const checkUser = {\r\n username: UserName,\r\n password: Password\r\n };\r\n\r\n setPreloader(true);\r\n axios.post(checkBranchLogin(), checkUser, { headers: authHeader() })\r\n .then(response => {\r\n if (response.data != null) {\r\n if (response.data.responseCode == \"OK\") {\r\n localStorage.setItem('branchToken', JSON.stringify(response.data.token));\r\n localStorage.setItem('userName', JSON.stringify(response.data.emp.username));\r\n localStorage.setItem('branchCode', JSON.stringify(response.data.emp.lbrcode));\r\n localStorage.setItem('branchName', JSON.stringify(response.data.emp.lbrname).replace(\"\\\"\", \"\").replace(\"\\\"\", \"\"));\r\n history.push('/CustomerList');\r\n }\r\n else {\r\n ErrorMessage(response.data.responseMessage);\r\n }\r\n }\r\n\r\n setPreloader(false);\r\n }, (error) => {\r\n console.log(error.response);\r\n setPreloader(false);\r\n })\r\n }\r\n\r\n return (\r\n
\r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n\r\n \r\n JSB-Branch Login\r\n \r\n \r\n \r\n \r\n \r\n
\r\n \r\n
\r\n \r\n \r\n \r\n \r\n
\r\n \r\n
\r\n \r\n
\r\n
\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n
\r\n \r\n
\r\n \r\n );\r\n};\r\n\r\nexport default BranchLogin\r\n\r\nBranchLogin.propTypes = {\r\n history: PropTypes.object,\r\n};\r\n\r\n\r\n","export default function branchAuthHeader() {\r\n const branchToken = JSON.parse(localStorage.getItem('branchToken'));\r\n\r\n if (branchToken) {\r\n return { Authorization: 'Bearer ' + branchToken };\r\n } else {\r\n return {};\r\n }\r\n}","import React from \"react\"\r\nimport { Redirect } from \"react-router-dom\"\r\n\r\n// JSB Forms\r\nimport login from \"../pages/JSBForms/login\"\r\nimport Status from \"../pages/JSBForms/Status\"\r\nimport CreateNewAccount from \"../pages/JSBForms/CreateNewAccount\"\r\n\r\nimport Registration from \"../pages/JSBForms/Registration\"\r\nimport Success from \"../pages/JSBForms/success\"\r\nimport FormLoader from \"../pages/JSBForms/FormLoader\"\r\nimport FirstHolder from \"../pages/JSBForms/FirstHolder\"\r\nimport OtherHolder from \"../pages/JSBForms/OtherHolder\"\r\nimport ShowPhoto from \"../pages/JSBForms/ShowPhoto\"\r\nimport BranchLogin from \"../pages/JSBForms/BranchLogin\"\r\nimport CustomerList from \"../pages/JSBForms/CustomerList\"\r\n\r\n\r\nconst authProtectedRoutes = [\r\n { path: \"/Registration\", component: Registration },\r\n { path: \"/Status\", component: Status },\r\n { path: \"/CreateNewAccount\", component: CreateNewAccount },\r\n { path: \"/FirstHolder\", component: FirstHolder },\r\n { path: \"/OtherHolder\", component: OtherHolder },\r\n \r\n\r\n { path: \"/\", exact: true, component: () =>
},\r\n]\r\n\r\nconst publicRoutes = [\r\n { path: \"/login\", component: login },\r\n { path: \"/BranchLogin\", component: BranchLogin },\r\n { path: \"/success\", component: Success },\r\n { path: \"/FormLoader\", component: FormLoader },\r\n { path: \"/CustomerList\", component: CustomerList },\r\n { path: \"/ShowPhoto\", component: ShowPhoto }\r\n]\r\n\r\nexport { authProtectedRoutes, publicRoutes }\r\n","import React, { useState, useEffect } from \"react\"\r\nimport axios from 'axios';\r\nimport branchAuthHeader from \"helpers/branchAuthHeader\";\r\n\r\nimport MetaTags from \"react-meta-tags\"\r\nimport {\r\n Card,\r\n CardBody,\r\n Table,\r\n Col,\r\n Container,\r\n Form,\r\n Label,\r\n NavItem,\r\n NavLink,\r\n Row,\r\n TabContent,\r\n TabPane,\r\n} from \"reactstrap\"\r\n\r\n// Formik validation\r\nimport * as Yup from \"yup\";\r\nimport { ErrorMessage, useFormik } from \"formik\";\r\nimport { useHistory } from \"react-router-dom\";\r\nimport classnames from \"classnames\";\r\nimport toastr from \"toastr\";\r\nimport \"toastr/build/toastr.min.css\";\r\n//Import BranchLogin Details\r\nimport { getAPIUrl, getAllBranchLoginCustomerList } from \"../../helpers/fakebackend_helper\"\r\n//redux\r\nimport { useSelector, useDispatch } from \"react-redux\";\r\nimport PropTypes from 'prop-types';\r\n//Pagination\r\nimport BootstrapTable from \"react-bootstrap-table-next\"\r\nimport paginationFactory, {\r\n PaginationListStandalone,\r\n PaginationProvider,\r\n} from \"react-bootstrap-table2-paginator\"\r\nimport ToolkitProvider, { Search } from \"react-bootstrap-table2-toolkit\"\r\n\r\nconst CustomerList = (props) => {\r\n\r\n\r\n const formButtonFirstPage = {\r\n marginLeft: \"15px\",\r\n backgroundColor: \"#9a084f\",\r\n fontSize: \"small\",\r\n borderRadius: \"0.50rem\"\r\n }\r\n\r\n const formMandatory = {\r\n color: \"red\",\r\n fontWeight: \"bold\"\r\n }\r\n const tabHeading = {\r\n color: \"#9a084f\",\r\n fontWeight: \"bold\"\r\n }\r\n\r\n const formBackground = {\r\n borderRadius: 8,\r\n flex: 1,\r\n //backgroundColor: \"rgb(247 242 242)\",\r\n padding: \"15px\"\r\n }\r\n const cardBackground = {\r\n borderRadius: 15,\r\n flex: 1,\r\n marginTop: \"20px\",\r\n boxShadow: \"#504f4f6b 5px 5px 20px\",\r\n height: \"90%\"\r\n }\r\n\r\n //=============Define State====================\r\n const history = useHistory();\r\n\r\n const [customerAccList, setCustomerAccList] = useState([]);\r\n const [showEasing, setshowEasing] = useState(\"swing\");\r\n const [hideEasing, sethideEasing] = useState(\"linear\");\r\n const [showMethod, setshowMethod] = useState(\"fadeIn\");\r\n const [hideMethod, sethideMethod] = useState(\"fadeOut\");\r\n const [showDuration, setshowDuration] = useState(300);\r\n const [hideDuration, sethideDuration] = useState(1000);\r\n const [timeOut, settimeOut] = useState(2000);\r\n const [extendedTimeOut, setextendedTimeOut] = useState(1000);\r\n\r\n //pagination customization\r\n const [modal, setModal] = useState(false)\r\n\r\n const { SearchBar } = Search\r\n const toggle = () => {\r\n setModal(!modal)\r\n }\r\n const defaultSorted = [\r\n {\r\n dataField: \"referenceNo\",\r\n order: \"desc\",\r\n },\r\n ]\r\n const CustomerPartialColumns = toggleModal => [\r\n {\r\n dataField: \"lastUpdated\",\r\n text: \"Last updated\",\r\n sort: true,\r\n style: { textAlign: \"center\", border: \"1px solid lightgrey\" },\r\n },\r\n {\r\n dataField: \"referenceNo\",\r\n text: \"Reference No.\",\r\n sort: true,\r\n style: { textAlign: \"center\", border: \"1px solid lightgrey\" },\r\n },\r\n {\r\n dataField: \"mobileNo\",\r\n text: \"Mobile Number\",\r\n sort: true,\r\n style: { textAlign: \"center\", border: \"1px solid lightgrey\" },\r\n },\r\n {\r\n dataField: \"customerName\",\r\n text: \"Customer Name\",\r\n sort: true,\r\n style: { textAlign: \"center\", border: \"1px solid lightgrey\" },\r\n },\r\n {\r\n dataField: \"accountTypeName\",\r\n text: \"Account Type\",\r\n sort: true,\r\n style: { textAlign: \"center\", border: \"1px solid lightgrey\" },\r\n },\r\n {\r\n dataField: \"entityTypeName\",\r\n text: \"Entity Type\",\r\n sort: true,\r\n style: { textAlign: \"center\", border: \"1px solid lightgrey\" },\r\n },\r\n {\r\n dataField: \"holdersCount\",\r\n text: \"Number of Holder\",\r\n sort: true,\r\n style: { textAlign: \"center\", border: \"1px solid lightgrey\" },\r\n },\r\n ]\r\n var CustomersPartial = customerAccList.filter(obj => {\r\n return obj.status === \"Partially Filled\"\r\n })\r\n\r\n const pageOptionsParial = {\r\n sizePerPage: 10,\r\n totalSize: CustomersPartial.length,\r\n custom: true,\r\n }\r\n\r\n const CustomerCompletedColumns = toggleModal => [\r\n {\r\n dataField: \"lastUpdated\",\r\n text: \"Last updated\",\r\n sort: true,\r\n style: { textAlign: \"center\", border: \"1px solid lightgrey\" },\r\n },\r\n {\r\n dataField: \"referenceNo\",\r\n text: \"Reference No.\",\r\n sort: true,\r\n style: { textAlign: \"center\", border: \"1px solid lightgrey\" },\r\n },\r\n {\r\n dataField: \"mobileNo\",\r\n text: \"Mobile Number\",\r\n sort: true,\r\n style: { textAlign: \"center\", border: \"1px solid lightgrey\" },\r\n },\r\n {\r\n dataField: \"customerName\",\r\n text: \"Customer Name\",\r\n sort: true,\r\n style: { textAlign: \"center\", border: \"1px solid lightgrey\" },\r\n },\r\n {\r\n dataField: \"accountTypeName\",\r\n text: \"Account Type\",\r\n sort: true,\r\n style: { textAlign: \"center\", border: \"1px solid lightgrey\" },\r\n },\r\n {\r\n dataField: \"entityTypeName\",\r\n text: \"Entity Type\",\r\n sort: true,\r\n style: { textAlign: \"center\", border: \"1px solid lightgrey\" },\r\n },\r\n {\r\n dataField: \"holdersCount\",\r\n text: \"Number of Holder\",\r\n sort: true,\r\n style: { textAlign: \"center\", border: \"1px solid lightgrey\" },\r\n },\r\n {\r\n dataField: \"referenceNo\",\r\n text: \"View/Download\",\r\n sort: true,\r\n style: { textAlign: \"center\", border: \"1px solid lightgrey\" },\r\n formatter: (cellContent, row) => {\r\n return (\r\n
\r\n \r\n \r\n
\r\n\r\n )\r\n }\r\n },\r\n ]\r\n\r\n var CustomersCompleted = customerAccList.filter(obj => {\r\n return obj.status === \"Completed\"\r\n })\r\n\r\n const pageOptionsCompleted = {\r\n sizePerPage: 10,\r\n totalSize: CustomersCompleted.length,\r\n custom: true,\r\n }\r\n function SuccessMessage(message) {\r\n toastr.options = {\r\n positionClass: \"toast-top-center\",\r\n timeOut: timeOut,\r\n extendedTimeOut: extendedTimeOut,\r\n closeButton: true,\r\n debug: false,\r\n progressBar: false,\r\n preventDuplicates: false,\r\n newestOnTop: false,\r\n showEasing: showEasing,\r\n hideEasing: hideEasing,\r\n showMethod: showMethod,\r\n hideMethod: hideMethod,\r\n showDuration: showDuration,\r\n hideDuration: hideDuration\r\n };\r\n\r\n toastr.success(message, \"Information\");\r\n }\r\n\r\n function ErrorMessage(message) {\r\n toastr.options = {\r\n positionClass: \"toast-top-center\",\r\n timeOut: timeOut,\r\n extendedTimeOut: extendedTimeOut,\r\n closeButton: true,\r\n debug: false,\r\n progressBar: false,\r\n preventDuplicates: false,\r\n newestOnTop: false,\r\n showEasing: showEasing,\r\n hideEasing: hideEasing,\r\n showMethod: showMethod,\r\n hideMethod: hideMethod,\r\n showDuration: showDuration,\r\n hideDuration: hideDuration\r\n };\r\n\r\n toastr.error(message, \"Error\");\r\n }\r\n\r\n\r\n const dispatch = useDispatch();\r\n const formButton = {\r\n marginLeft: \"20px\",\r\n backgroundColor: \"#9a084f\",\r\n fontSize: \"small\",\r\n borderRadius: \"0.50rem\"\r\n }\r\n\r\n function tog_backdrop() {\r\n setmodal_backdrop(!modal_backdrop);\r\n removeBodyCss();\r\n }\r\n\r\n function DownloadRegistrationPDF(fileName, id) {\r\n debugger;\r\n //Development url\r\n var url = getAPIUrl() + \"/RegistrationPrintPDF/\" + id + \".pdf\";\r\n\r\n axios({\r\n url: url, //your url\r\n method: 'GET',\r\n responseType: 'blob', // important\r\n headers: branchAuthHeader()\r\n }).then((response) => {\r\n const url = window.URL.createObjectURL(new Blob([response.data]));\r\n const link = document.createElement('a');\r\n link.href = url;\r\n link.setAttribute('download', fileName + \".pdf\"); //or any other extension\r\n document.body.appendChild(link);\r\n link.click();\r\n });\r\n\r\n //var a = $(\"
\");\r\n //a.attr(\"download\", fileName);\r\n //a.attr(\"href\", url);\r\n //$(\"body\").append(a);\r\n //a[0].click();\r\n //$(\"body\").remove(a);\r\n };\r\n\r\n function ViewRegistrationPDF(id) {\r\n debugger;\r\n var url = getAPIUrl() + \"/RegistrationPrintPDF/\" + id + \".pdf\";\r\n\r\n axios({\r\n url: url, //your url\r\n method: 'GET',\r\n responseType: 'blob', // important\r\n headers: branchAuthHeader()\r\n }).then((response) => {\r\n const url = window.URL.createObjectURL(new Blob([response.data]));\r\n\r\n const file = new Blob([response.data], {\r\n type: \"application/pdf\",\r\n });\r\n\r\n const fileURL = URL.createObjectURL(file);\r\n window.open(fileURL);\r\n });\r\n\r\n //var a2 = $(\"
\");\r\n //a2.attr(\"target\", \"_blank\");\r\n //a2.attr(\"href\", url);\r\n //$(\"body\").append(a2);\r\n //a2[0].click();\r\n //$(\"body\").remove(a2);\r\n };\r\n\r\n function ViewRegistrationPDF(fileName) {\r\n debugger;\r\n var url = getAPIUrl() + \"/RegistrationPrintPDF/\" + fileName + \".pdf\";\r\n\r\n var a = $(\"
\");\r\n a.attr(\"target\", \"_blank\");\r\n a.attr(\"href\", url);\r\n $(\"body\").append(a);\r\n a[0].click();\r\n $(\"body\").remove(a);\r\n };\r\n\r\n var authUserName = JSON.parse(localStorage.getItem('userName'));\r\n var authPassword = JSON.parse(localStorage.getItem('password'));\r\n\r\n const [username, setusername] = useState(authUserName);\r\n const [isPreloader, setPreloader] = useState(false);\r\n\r\n\r\n function GetBranchloginDetails(BranchCode) {\r\n debugger;\r\n\r\n const getAllBranchLoginCustomerListModel = {\r\n BranchCode: BranchCode\r\n }\r\n if (getAllBranchLoginCustomerListModel != null) {\r\n setPreloader(true);\r\n\r\n axios.post(getAllBranchLoginCustomerList(), getAllBranchLoginCustomerListModel, { headers: branchAuthHeader() }).then((response) => {\r\n setCustomerAccList(response.data);\r\n setPreloader(false);\r\n }, (error) => {\r\n console.log(error.response);\r\n setPreloader(false);\r\n });\r\n }\r\n }\r\n\r\n useEffect(() => {\r\n if (isPreloader === true) {\r\n document.getElementById(\"preloader\").style.display = \"block\";\r\n document.getElementById(\"status\").style.display = \"block\";\r\n } else {\r\n document.getElementById(\"preloader\").style.display = \"none\";\r\n document.getElementById(\"status\").style.display = \"none\";\r\n }\r\n }, [isPreloader]);\r\n\r\n useEffect(() => {\r\n var branchcode = localStorage.getItem('branchCode');\r\n GetBranchloginDetails(branchcode);\r\n }, []);\r\n\r\n\r\n const [activeTabVartical, setoggleTabVertical] = useState(1)\r\n const [passedStepsVertical, setPassedStepsVertical] = useState([1])\r\n\r\n function toggleTabVertical(tab) {\r\n if (activeTabVartical !== tab) {\r\n var modifiedSteps = [...passedStepsVertical, tab]\r\n\r\n if (tab >= 1 && tab <= 2) {\r\n setoggleTabVertical(tab)\r\n setPassedStepsVertical(modifiedSteps)\r\n }\r\n }\r\n }\r\n\r\n const [menu, setMenu] = useState(false)\r\n\r\n\r\n return (\r\n
\r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n\r\n \r\n JSB-Customer Details\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n {localStorage.getItem('branchName')}
\r\n \r\n
\r\n \r\n
\r\n
\r\n \r\n {\r\n toggleTabVertical(1)\r\n }}\r\n >\r\n 1 Completed forms\r\n \r\n \r\n \r\n {\r\n toggleTabVertical(2)\r\n }}\r\n >\r\n 2{\" \"}\r\n Partially Filled Forms\r\n \r\n \r\n
\r\n
\r\n\r\n
\r\n
\r\n
\r\n \r\n \r\n
\r\n {({ paginationProps, paginationTableProps }) => (\r\n \r\n {toolkitProps => (\r\n \r\n )}\r\n \r\n )}\r\n \r\n
\r\n \r\n\r\n \r\n \r\n
\r\n {({ paginationProps, paginationTableProps }) => (\r\n \r\n {toolkitProps => (\r\n \r\n )}\r\n \r\n )}\r\n \r\n
\r\n \r\n\r\n \r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n \r\n \r\n )\r\n}\r\n\r\nexport default CustomerList\r\n\r\nCustomerList.propTypes = {\r\n history: PropTypes.object,\r\n};","import React from \"react\"\r\nimport PropTypes from \"prop-types\"\r\nimport { Route, Redirect } from \"react-router-dom\"\r\n\r\nconst Authmiddleware = ({\r\n component: Component,\r\n layout: Layout,\r\n isAuthProtected,\r\n ...rest\r\n}) => (\r\n
{\r\n if ((isAuthProtected && !localStorage.getItem(\"authCustomer\"))) {\r\n return (\r\n \r\n )\r\n }\r\n\r\n return (\r\n \r\n \r\n \r\n )\r\n }}\r\n />\r\n)\r\n\r\nAuthmiddleware.propTypes = {\r\n isAuthProtected: PropTypes.bool,\r\n component: PropTypes.any,\r\n location: PropTypes.object,\r\n layout: PropTypes.any, \r\n}\r\n\r\nexport default Authmiddleware;\r\n","import PropTypes from \"prop-types\";\r\nimport React, { useEffect } from \"react\";\r\n\r\nimport { withRouter } from \"react-router-dom\";\r\nimport {\r\n changeLayout,\r\n changeSidebarTheme,\r\n changeSidebarThemeImage,\r\n changeSidebarType,\r\n changeTopbarTheme,\r\n changeLayoutWidth,\r\n showRightSidebarAction\r\n} from \"../../store/actions\";\r\n\r\n// Layout Related Components\r\nimport Header from \"./Header\";\r\n/*import Sidebar from \"./Sidebar\";*/\r\nimport Footer from \"./Footer\";\r\n/*import RightSidebar from \"../CommonForBoth/RightSidebar\";*/\r\n\r\n//redux\r\nimport { useSelector, useDispatch } from \"react-redux\";\r\n\r\nconst Layout = props => {\r\n const dispatch = useDispatch();\r\n\r\n const {\r\n isPreloader,\r\n leftSideBarThemeImage,\r\n layoutWidth,\r\n leftSideBarType,\r\n topbarTheme,\r\n showRightSidebar,\r\n leftSideBarTheme,\r\n } = useSelector(state => ({\r\n isPreloader: state.Layout.isPreloader,\r\n leftSideBarThemeImage: state.Layout.leftSideBarThemeImage,\r\n leftSideBarType: state.Layout.leftSideBarType,\r\n layoutWidth: state.Layout.layoutWidth,\r\n topbarTheme: state.Layout.topbarTheme,\r\n showRightSidebar: state.Layout.showRightSidebar,\r\n leftSideBarTheme: state.Layout.leftSideBarTheme,\r\n }));\r\n\r\n const isMobile = /iPhone|iPad|iPod|Android/i.test(navigator.userAgent);\r\n\r\n const toggleMenuCallback = () => {\r\n if (leftSideBarType === \"default\") {\r\n dispatch(changeSidebarType(\"condensed\", isMobile));\r\n } else if (leftSideBarType === \"condensed\") {\r\n dispatch(changeSidebarType(\"default\", isMobile));\r\n }\r\n };\r\n\r\n //hides right sidebar on body click\r\n // const hideRightbar = (event) => {\r\n // var rightbar = document.getElementById(\"right-bar\");\r\n // //if clicked in inside right bar, then do nothing\r\n // if (rightbar && rightbar.contains(event.target)) {\r\n // return;\r\n // } else {\r\n // //if clicked in outside of rightbar then fire action for hide rightbar\r\n // dispatch(showRightSidebarAction(false));\r\n // }\r\n // };\r\n\r\n /*\r\n layout settings\r\n */\r\n\r\n useEffect(() => {\r\n //init body click event fot toggle rightbar\r\n //document.body.addEventListener(\"click\", hideRightbar, true);\r\n\r\n if (isPreloader === true) {\r\n document.getElementById(\"preloader\").style.display = \"block\";\r\n document.getElementById(\"status\").style.display = \"block\";\r\n\r\n setTimeout(function () {\r\n document.getElementById(\"preloader\").style.display = \"none\";\r\n document.getElementById(\"status\").style.display = \"none\";\r\n }, 2500);\r\n } else {\r\n document.getElementById(\"preloader\").style.display = \"none\";\r\n document.getElementById(\"status\").style.display = \"none\";\r\n }\r\n }, [isPreloader]);\r\n\r\n useEffect(() => {\r\n window.scrollTo(0, 0);\r\n }, []);\r\n\r\n useEffect(() => {\r\n dispatch(changeLayout(\"vertical\"));\r\n }, [dispatch]);\r\n\r\n useEffect(() => {\r\n if (leftSideBarTheme) {\r\n dispatch(changeSidebarTheme(leftSideBarTheme));\r\n }\r\n }, [leftSideBarTheme, dispatch]);\r\n\r\n useEffect(() => {\r\n if (leftSideBarThemeImage) {\r\n dispatch(changeSidebarThemeImage(leftSideBarThemeImage));\r\n }\r\n }, [leftSideBarThemeImage, dispatch]);\r\n\r\n useEffect(() => {\r\n if (layoutWidth) {\r\n dispatch(changeLayoutWidth(layoutWidth));\r\n }\r\n }, [layoutWidth, dispatch]);\r\n\r\n useEffect(() => {\r\n if (leftSideBarType) {\r\n dispatch(changeSidebarType(leftSideBarType));\r\n }\r\n }, [leftSideBarType, dispatch]);\r\n\r\n useEffect(() => {\r\n if (topbarTheme) {\r\n dispatch(changeTopbarTheme(topbarTheme));\r\n }\r\n }, [topbarTheme, dispatch]);\r\n var body = document.body;\r\n body.classList.toggle(\"vertical-collpsed\");\r\n\r\n\r\n return (\r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n\r\n \r\n
\r\n
{props.children}
\r\n
\r\n
\r\n \r\n );\r\n};\r\n\r\nLayout.propTypes = {\r\n changeLayoutWidth: PropTypes.func,\r\n changeSidebarTheme: PropTypes.func,\r\n changeSidebarThemeImage: PropTypes.func,\r\n changeSidebarType: PropTypes.func,\r\n changeTopbarTheme: PropTypes.func,\r\n children: PropTypes.object,\r\n isPreloader: PropTypes.any,\r\n layoutWidth: PropTypes.any,\r\n leftSideBarTheme: PropTypes.any,\r\n leftSideBarThemeImage: PropTypes.any,\r\n leftSideBarType: PropTypes.any,\r\n location: PropTypes.object,\r\n showRightSidebar: PropTypes.any,\r\n topbarTheme: PropTypes.any,\r\n};\r\n\r\nexport default withRouter(Layout);\r\n","import PropTypes from \"prop-types\";\r\nimport React, { useState, useEffect } from \"react\";\r\nimport { Row, Col, Collapse } from \"reactstrap\";\r\nimport { Link, withRouter } from \"react-router-dom\";\r\nimport classname from \"classnames\";\r\n\r\n//i18n\r\nimport { withTranslation } from \"react-i18next\";\r\n\r\nimport { connect } from \"react-redux\";\r\n\r\nconst Navbar = props => {\r\n\r\n const [dashboard, setdashboard] = useState(false);\r\n const [ui, setui] = useState(false);\r\n const [app, setapp] = useState(false);\r\n const [email, setemail] = useState(false);\r\n const [ecommerce, setecommerce] = useState(false);\r\n const [crypto, setcrypto] = useState(false);\r\n const [project, setproject] = useState(false);\r\n const [task, settask] = useState(false);\r\n const [contact, setcontact] = useState(false);\r\n const [blog, setBlog] = useState(false);\r\n const [component, setcomponent] = useState(false);\r\n const [form, setform] = useState(false);\r\n const [table, settable] = useState(false);\r\n const [chart, setchart] = useState(false);\r\n const [icon, seticon] = useState(false);\r\n const [map, setmap] = useState(false);\r\n const [extra, setextra] = useState(false);\r\n const [invoice, setinvoice] = useState(false);\r\n const [auth, setauth] = useState(false);\r\n const [utility, setutility] = useState(false);\r\n\r\n useEffect(() => {\r\n var matchingMenuItem = null;\r\n var ul = document.getElementById(\"navigation\");\r\n var items = ul.getElementsByTagName(\"a\");\r\n for (var i = 0; i < items.length; ++i) {\r\n if (props.location.pathname === items[i].pathname) {\r\n matchingMenuItem = items[i];\r\n break;\r\n }\r\n }\r\n if (matchingMenuItem) {\r\n activateParentDropdown(matchingMenuItem);\r\n }\r\n });\r\n\r\n function activateParentDropdown(item) {\r\n item.classList.add(\"active\");\r\n const parent = item.parentElement;\r\n if (parent) {\r\n parent.classList.add(\"active\"); // li\r\n const parent2 = parent.parentElement;\r\n parent2.classList.add(\"active\"); // li\r\n const parent3 = parent2.parentElement;\r\n if (parent3) {\r\n parent3.classList.add(\"active\"); // li\r\n const parent4 = parent3.parentElement;\r\n if (parent4) {\r\n parent4.classList.add(\"active\"); // li\r\n const parent5 = parent4.parentElement;\r\n if (parent5) {\r\n parent5.classList.add(\"active\"); // li\r\n const parent6 = parent5.parentElement;\r\n if (parent6) {\r\n parent6.classList.add(\"active\"); // li\r\n }\r\n }\r\n }\r\n }\r\n }\r\n return false;\r\n }\r\n\r\n return (\r\n \r\n \r\n
\r\n \r\n
\r\n
\r\n \r\n );\r\n};\r\n\r\nNavbar.propTypes = {\r\n leftMenu: PropTypes.any,\r\n location: PropTypes.any,\r\n menuOpen: PropTypes.any,\r\n t: PropTypes.any,\r\n};\r\n\r\nconst mapStatetoProps = state => {\r\n const { leftMenu } = state.Layout;\r\n return { leftMenu };\r\n};\r\n\r\nexport default withRouter(\r\n connect(mapStatetoProps, {})(withTranslation()(Navbar))\r\n);\r\n","import React, { useState } from \"react\";\r\nimport PropTypes from 'prop-types';\r\n\r\nimport { connect } from \"react-redux\";\r\n\r\nimport { Link } from \"react-router-dom\";\r\n\r\n// Redux Store\r\nimport { showRightSidebarAction, toggleLeftmenu } from \"../../store/actions\";\r\n// reactstrap\r\nimport { Row, Col, Dropdown, DropdownToggle, DropdownMenu } from \"reactstrap\";\r\n\r\n// Import menuDropdown\r\nimport LanguageDropdown from \"../CommonForBoth/TopbarDropdown/LanguageDropdown\";\r\nimport NotificationDropdown from \"../CommonForBoth/TopbarDropdown/NotificationDropdown\";\r\nimport ProfileMenu from \"../CommonForBoth/TopbarDropdown/ProfileMenu\";\r\n\r\nimport megamenuImg from \"../../assets/images/megamenu-img.png\";\r\nimport logo from \"../../assets/images/logo.svg\";\r\nimport logoLight from \"../../assets/images/logo-light.png\";\r\nimport logoLightSvg from \"../../assets/images/logo-light.svg\";\r\nimport logoDark from \"../../assets/images/logo-dark.png\";\r\n\r\n// import images\r\nimport github from \"../../assets/images/brands/github.png\";\r\nimport bitbucket from \"../../assets/images/brands/bitbucket.png\";\r\nimport dribbble from \"../../assets/images/brands/dribbble.png\";\r\nimport dropbox from \"../../assets/images/brands/dropbox.png\";\r\nimport mail_chimp from \"../../assets/images/brands/mail_chimp.png\";\r\nimport slack from \"../../assets/images/brands/slack.png\";\r\n\r\n//i18n\r\nimport { withTranslation } from \"react-i18next\";\r\n\r\nconst Header = props => {\r\n const [menu, setMenu] = useState(false);\r\n const [isSearch, setSearch] = useState(false);\r\n const [socialDrp, setsocialDrp] = useState(false);\r\n\r\n function toggleFullscreen() {\r\n if (\r\n !document.fullscreenElement &&\r\n /* alternative standard method */ !document.mozFullScreenElement &&\r\n !document.webkitFullscreenElement\r\n ) {\r\n // current working methods\r\n if (document.documentElement.requestFullscreen) {\r\n document.documentElement.requestFullscreen();\r\n } else if (document.documentElement.mozRequestFullScreen) {\r\n document.documentElement.mozRequestFullScreen();\r\n } else if (document.documentElement.webkitRequestFullscreen) {\r\n document.documentElement.webkitRequestFullscreen(\r\n Element.ALLOW_KEYBOARD_INPUT\r\n );\r\n }\r\n } else {\r\n if (document.cancelFullScreen) {\r\n document.cancelFullScreen();\r\n } else if (document.mozCancelFullScreen) {\r\n document.mozCancelFullScreen();\r\n } else if (document.webkitCancelFullScreen) {\r\n document.webkitCancelFullScreen();\r\n }\r\n }\r\n }\r\n return (\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n \r\n
\r\n
\r\n \r\n \r\n\r\n
\r\n
\r\n
\r\n \r\n
\r\n
\r\n \r\n \r\n
\r\n\r\n
\r\n\r\n
\r\n\r\n
setMenu(!menu)}\r\n >\r\n \r\n {props.t(\"Mega Menu\")} \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n {props.t(\"UI Components\")}\r\n
\r\n \r\n - \r\n {props.t(\"Lightbox\")}\r\n
\r\n - \r\n {props.t(\"Range Slider\")}\r\n
\r\n - \r\n {props.t(\"Sweet Alert\")}\r\n
\r\n - \r\n {props.t(\"Rating\")}\r\n
\r\n - \r\n {props.t(\"Forms\")}\r\n
\r\n - \r\n {props.t(\"Tables\")}\r\n
\r\n - \r\n {props.t(\"Charts\")}\r\n
\r\n
\r\n \r\n\r\n \r\n \r\n {props.t(\"Applications\")}\r\n
\r\n \r\n - \r\n {props.t(\"Ecommerce\")}\r\n
\r\n - \r\n {props.t(\"Calendar\")}\r\n
\r\n - \r\n {props.t(\"Email\")}\r\n
\r\n - \r\n {props.t(\"Projects\")}\r\n
\r\n - \r\n {props.t(\"Tasks\")}\r\n
\r\n - \r\n {props.t(\"Contacts\")}\r\n
\r\n
\r\n \r\n\r\n \r\n \r\n {props.t(\"Extra Pages\")}\r\n
\r\n \r\n - \r\n {props.t(\"Light Sidebar\")}\r\n
\r\n - \r\n {props.t(\"Compact Sidebar\")}\r\n
\r\n - \r\n {props.t(\"Horizontal layout\")}\r\n
\r\n - \r\n {props.t(\"Maintenance\")}\r\n
\r\n - \r\n {props.t(\"Coming Soon\")}\r\n
\r\n - \r\n {props.t(\"Timeline\")}\r\n
\r\n - \r\n {props.t(\"FAQs\")}\r\n
\r\n
\r\n \r\n
\r\n \r\n \r\n \r\n \r\n \r\n {props.t(\"UI Components\")}\r\n
\r\n \r\n - \r\n {props.t(\"Lightbox\")}\r\n
\r\n - \r\n {props.t(\"Range Slider\")}\r\n
\r\n - \r\n {props.t(\"Sweet Alert\")}\r\n
\r\n - \r\n {props.t(\"Rating\")}\r\n
\r\n - \r\n {props.t(\"Forms\")}\r\n
\r\n - \r\n {props.t(\"Tables\")}\r\n
\r\n - \r\n {props.t(\"Charts\")}\r\n
\r\n
\r\n \r\n\r\n \r\n \r\n

\r\n
\r\n \r\n
\r\n \r\n
\r\n \r\n \r\n
\r\n\r\n
\r\n
\r\n\r\n
\r\n\r\n
{\r\n setsocialDrp(!socialDrp);\r\n }}\r\n >\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n\r\n
\r\n \r\n
\r\n\r\n
\r\n\r\n
\r\n\r\n
\r\n \r\n
\r\n
\r\n
\r\n \r\n \r\n );\r\n};\r\n\r\nHeader.propTypes = {\r\n leftMenu: PropTypes.any,\r\n showRightSidebar: PropTypes.any,\r\n showRightSidebarAction: PropTypes.func,\r\n t: PropTypes.any,\r\n toggleLeftmenu: PropTypes.func\r\n};\r\n\r\nconst mapStatetoProps = state => {\r\n const { layoutType, showRightSidebar, leftMenu } = state.Layout;\r\n return { layoutType, showRightSidebar, leftMenu };\r\n};\r\n\r\nexport default connect(mapStatetoProps, {\r\n showRightSidebarAction,\r\n toggleLeftmenu,\r\n})(withTranslation()(Header));\r\n","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","import React from \"react\"\r\nimport { Container, Row, Col } from \"reactstrap\"\r\n\r\nconst Footer = () => {\r\n return (\r\n \r\n \r\n \r\n )\r\n}\r\n\r\nexport default Footer\r\n","export default __webpack_public_path__ + \"static/media/img1.5d30e3f4.jpg\";","export default __webpack_public_path__ + \"static/media/img2.f153f12d.jpg\";","export default __webpack_public_path__ + \"static/media/img3.38bebc7d.jpg\";","export default __webpack_public_path__ + \"static/media/img4.508ca487.jpg\";","export default __webpack_public_path__ + \"static/media/layout-1.d6de7ba6.jpg\";","export default __webpack_public_path__ + \"static/media/layout-2.39f5fc81.jpg\";","export default __webpack_public_path__ + \"static/media/layout-3.ab7913ef.jpg\";","const layoutTypes = {\r\n HORIZONTAL: \"horizontal\",\r\n VERTICAL: \"vertical\",\r\n}\r\n\r\nconst layoutWidthTypes = {\r\n FLUID: \"fluid\",\r\n BOXED: \"boxed\",\r\n SCROLLABLE: \"scrollable\",\r\n}\r\n\r\nconst topBarThemeTypes = {\r\n LIGHT: \"light\",\r\n DARK: \"dark\",\r\n COLORED: \"colored\",\r\n}\r\n\r\nconst leftBarThemeImageTypes = {\r\n NONE: \"none\",\r\n IMG1: \"img1\",\r\n IMG2: \"img2\",\r\n IMG3: \"img3\",\r\n IMG4: \"img4\",\r\n}\r\n\r\nconst leftSidebarTypes = {\r\n DEFAULT: \"default\",\r\n COMPACT: \"compact\",\r\n ICON: \"icon\",\r\n}\r\n\r\nconst leftSideBarThemeTypes = {\r\n LIGHT: \"light\",\r\n COLORED: \"colored\",\r\n DARK: \"dark\",\r\n WINTER: \"winter\",\r\n LADYLIP: \"ladylip\",\r\n PLUMPLATE: \"plumplate\",\r\n STRONGBLISS: \"strongbliss\",\r\n GREATWHALE: \"greatwhale\",\r\n}\r\n\r\nexport {\r\n layoutTypes,\r\n layoutWidthTypes,\r\n topBarThemeTypes,\r\n leftBarThemeImageTypes,\r\n leftSidebarTypes,\r\n leftSideBarThemeTypes,\r\n}\r\n","import React from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { Row, Col, FormGroup } from \"reactstrap\";\r\n\r\nimport { connect } from \"react-redux\";\r\nimport {\r\n changeLayout,\r\n changeLayoutWidth,\r\n changeSidebarTheme,\r\n changeSidebarThemeImage,\r\n changeSidebarType,\r\n changePreloader,\r\n changeTopbarTheme,\r\n showRightSidebarAction,\r\n} from \"../../store/actions\";\r\n\r\n//SimpleBar\r\nimport SimpleBar from \"simplebar-react\";\r\n\r\nimport { Link } from \"react-router-dom\";\r\n\r\nimport \"../../components/CommonForBoth/rightbar.scss\";\r\n\r\n//Import images\r\nimport bgimg1 from \"../../assets/images/sidebar/img1.jpg\";\r\nimport bgimg2 from \"../../assets/images/sidebar/img2.jpg\";\r\nimport bgimg3 from \"../../assets/images/sidebar/img3.jpg\";\r\nimport bgimg4 from \"../../assets/images/sidebar/img4.jpg\";\r\nimport layout1 from \"../../assets/images/layouts/layout-1.jpg\";\r\nimport layout2 from \"../../assets/images/layouts/layout-2.jpg\";\r\nimport layout3 from \"../../assets/images/layouts/layout-3.jpg\";\r\n\r\n//constants\r\nimport {\r\n layoutTypes,\r\n layoutWidthTypes,\r\n topBarThemeTypes,\r\n leftBarThemeImageTypes,\r\n leftSidebarTypes,\r\n leftSideBarThemeTypes,\r\n} from \"../../constants/layout\";\r\n\r\nconst RightSidebar = props => {\r\n const onCloseRightBar = () => {\r\n const { onClose } = props;\r\n if (onClose) {\r\n onClose();\r\n }\r\n };\r\n return (\r\n \r\n \r\n
\r\n \r\n
\r\n {\r\n e.preventDefault()\r\n props.showRightSidebarAction(false)\r\n }}\r\n className=\"right-bar-toggle float-end\"\r\n >\r\n \r\n \r\n
Settings
\r\n \r\n\r\n
\r\n\r\n
\r\n
\r\n Layouts\r\n {\r\n if (e.target.checked) {\r\n props.changeLayout(e.target.value);\r\n }\r\n }}\r\n />\r\n \r\n {\r\n if (e.target.checked) {\r\n props.changeLayout(e.target.value);\r\n }\r\n }}\r\n />\r\n \r\n
\r\n\r\n
\r\n\r\n
\r\n \r\n Layout Width\r\n \r\n {\r\n if (e.target.checked) {\r\n props.changeLayoutWidth(e.target.value);\r\n }\r\n }}\r\n />\r\n \r\n {\r\n if (e.target.checked) {\r\n props.changeLayoutWidth(e.target.value);\r\n }\r\n }}\r\n />\r\n \r\n {\r\n if (e.target.checked) {\r\n props.changeLayoutWidth(e.target.value);\r\n }\r\n }}\r\n />\r\n \r\n
\r\n
\r\n\r\n
\r\n \r\n Topbar Theme\r\n \r\n {\r\n if (e.target.checked) {\r\n props.changeTopbarTheme(e.target.value);\r\n }\r\n }}\r\n />\r\n \r\n {\r\n if (e.target.checked) {\r\n props.changeTopbarTheme(e.target.value);\r\n }\r\n }}\r\n />\r\n \r\n {props.layoutType === \"vertical\" ? null : (\r\n <>\r\n {\r\n if (e.target.checked) {\r\n props.changeTopbarTheme(e.target.value);\r\n }\r\n }}\r\n />\r\n {\" \"}\r\n >\r\n )}\r\n
\r\n\r\n {props.layoutType === \"vertical\" ? (\r\n
\r\n
\r\n \r\n \r\n Left Sidebar Type{\" \"}\r\n \r\n {\r\n if (e.target.checked) {\r\n props.changeSidebarType(e.target.value);\r\n }\r\n }}\r\n />\r\n \r\n {\r\n if (e.target.checked) {\r\n props.changeSidebarType(e.target.value);\r\n }\r\n }}\r\n />\r\n \r\n {\r\n if (e.target.checked) {\r\n props.changeSidebarType(e.target.value);\r\n }\r\n }}\r\n />\r\n \r\n
\r\n\r\n
\r\n\r\n \r\n \r\n Left Sidebar Color Options\r\n \r\n \r\n \r\n {\r\n if (e.target.checked) {\r\n props.changeSidebarTheme(e.target.value);\r\n }\r\n }}\r\n />\r\n \r\n\r\n {\r\n if (e.target.checked) {\r\n props.changeSidebarTheme(e.target.value);\r\n }\r\n }}\r\n />\r\n \r\n\r\n {\r\n if (e.target.checked) {\r\n props.changeSidebarTheme(e.target.value);\r\n }\r\n }}\r\n />\r\n \r\n \r\n
\r\n \r\n \r\n\r\n {\r\n if (e.target.checked) {\r\n props.changeSidebarTheme(e.target.value);\r\n }\r\n }}\r\n />\r\n \r\n\r\n {\r\n if (e.target.checked) {\r\n props.changeSidebarTheme(e.target.value);\r\n }\r\n }}\r\n />\r\n \r\n\r\n {\r\n if (e.target.checked) {\r\n props.changeSidebarTheme(e.target.value);\r\n }\r\n }}\r\n />\r\n \r\n\r\n {\r\n if (e.target.checked) {\r\n props.changeSidebarTheme(e.target.value);\r\n }\r\n }}\r\n />\r\n \r\n {\r\n if (e.target.checked) {\r\n props.changeSidebarTheme(e.target.value);\r\n }\r\n }}\r\n />\r\n \r\n \r\n
\r\n
\r\n \r\n
\r\n Left Sidebar Bg Image\r\n \r\n
\r\n {\r\n if (e.target.checked) {\r\n props.changeSidebarThemeImage(e.target.value);\r\n }\r\n }}\r\n />\r\n\r\n
\r\n {\" \"}\r\n\r\n {\r\n if (e.target.checked) {\r\n props.changeSidebarThemeImage(e.target.value);\r\n }\r\n }}\r\n />\r\n\r\n
\r\n {\" \"}\r\n\r\n {\r\n if (e.target.checked) {\r\n props.changeSidebarThemeImage(e.target.value);\r\n }\r\n }}\r\n />\r\n\r\n
\r\n {\" \"}\r\n {\r\n if (e.target.checked) {\r\n props.changeSidebarThemeImage(e.target.value);\r\n }\r\n }}\r\n />\r\n
\r\n {\" \"}\r\n\r\n {\r\n if (e.target.checked) {\r\n props.changeSidebarThemeImage(e.target.value);\r\n }\r\n }}\r\n />\r\n
\r\n {\" \"}\r\n
\r\n
\r\n
\r\n \r\n ) : null}\r\n\r\n
\r\n \r\n Preloader\r\n \r\n\r\n \r\n {\r\n props.changePreloader(!props.isPreloader);\r\n }}\r\n />\r\n\r\n \r\n
\r\n \r\n\r\n
Choose Layouts
\r\n\r\n
\r\n
\r\n

\r\n \r\n
\r\n\r\n
\r\n
\r\n

\r\n \r\n
\r\n\r\n
\r\n
\r\n

\r\n \r\n
\r\n\r\n
\r\n
Purchase Now\r\n \r\n
\r\n
\r\n \r\n
\r\n \r\n \r\n );\r\n};\r\n\r\nRightSidebar.propTypes = {\r\n changeLayout: PropTypes.func,\r\n changeLayoutWidth: PropTypes.func,\r\n changePreloader: PropTypes.func,\r\n changeSidebarTheme: PropTypes.func,\r\n changeSidebarThemeImage: PropTypes.func,\r\n changeSidebarType: PropTypes.func,\r\n changeTopbarTheme: PropTypes.func,\r\n isPreloader: PropTypes.any,\r\n layoutType: PropTypes.any,\r\n layoutWidth: PropTypes.any,\r\n leftSideBarTheme: PropTypes.any,\r\n leftSideBarThemeImage: PropTypes.any,\r\n leftSideBarType: PropTypes.any,\r\n showRightSidebarAction: PropTypes.func,\r\n topbarTheme: PropTypes.any,\r\n onClose: PropTypes.func,\r\n};\r\n\r\nconst mapStateToProps = state => {\r\n return { ...state.Layout };\r\n};\r\n\r\nexport default connect(mapStateToProps, {\r\n changeLayout,\r\n changeSidebarTheme,\r\n changeSidebarThemeImage,\r\n changeSidebarType,\r\n changeLayoutWidth,\r\n changeTopbarTheme,\r\n changePreloader,\r\n showRightSidebarAction,\r\n})(RightSidebar);\r\n","import React, { useEffect, useState } from 'react';\r\nimport { withRouter } from \"react-router-dom\"\r\nimport PropTypes from \"prop-types\"\r\n\r\n//actions\r\nimport {\r\n changeLayout,\r\n changeTopbarTheme,\r\n changeLayoutWidth,\r\n showRightSidebarAction\r\n} from \"../../store/actions\"\r\n\r\n//redux\r\nimport { useSelector, useDispatch } from \"react-redux\"\r\n\r\n//components\r\nimport Navbar from \"./Navbar\"\r\nimport Header from \"./Header\"\r\nimport Footer from \"./Footer\"\r\nimport RightSidebar from \"../CommonForBoth/RightSidebar\"\r\nconst Layout = (props) => {\r\n\r\n const dispatch = useDispatch()\r\n\r\n const {\r\n topbarTheme, layoutWidth, isPreloader, showRightSidebar\r\n } = useSelector(state => ({\r\n topbarTheme: state.Layout.topbarTheme,\r\n layoutWidth: state.Layout.layoutWidth,\r\n isPreloader: state.Layout.isPreloader,\r\n showRightSidebar: state.Layout.showRightSidebar,\r\n }))\r\n\r\n /*\r\n document title\r\n */\r\n useEffect(() => {\r\n const title = props.location.pathname\r\n let currentage = title.charAt(1).toUpperCase() + title.slice(2)\r\n\r\n document.title =\r\n currentage + \" | JSB Online Account\"\r\n }, [props.location.pathname]);\r\n\r\n useEffect(() => {\r\n window.scrollTo(0, 0)\r\n }, []);\r\n\r\n\r\n //hides right sidebar on body click\r\n const hideRightbar = (event) => {\r\n var rightbar = document.getElementById(\"right-bar\");\r\n //if clicked in inside right bar, then do nothing\r\n if (rightbar && rightbar.contains(event.target)) {\r\n return;\r\n } else {\r\n //if clicked in outside of rightbar then fire action for hide rightbar\r\n dispatch(showRightSidebarAction(false));\r\n }\r\n };\r\n\r\n /*\r\n layout settings\r\n */\r\n useEffect(() => {\r\n dispatch(changeLayout(\"horizontal\"));\r\n }, [dispatch]);\r\n\r\n useEffect(() => {\r\n //init body click event fot toggle rightbar\r\n document.body.addEventListener(\"click\", hideRightbar, true);\r\n\r\n if (isPreloader === true) {\r\n document.getElementById(\"preloader\").style.display = \"block\"\r\n document.getElementById(\"status\").style.display = \"block\"\r\n\r\n setTimeout(function () {\r\n document.getElementById(\"preloader\").style.display = \"none\"\r\n document.getElementById(\"status\").style.display = \"none\"\r\n }, 2500)\r\n } else {\r\n document.getElementById(\"preloader\").style.display = \"none\"\r\n document.getElementById(\"status\").style.display = \"none\"\r\n }\r\n }, [isPreloader])\r\n\r\n useEffect(() => {\r\n if (topbarTheme) {\r\n dispatch(changeTopbarTheme(topbarTheme));\r\n }\r\n }, [dispatch, topbarTheme]);\r\n\r\n useEffect(() => {\r\n if (layoutWidth) {\r\n dispatch(changeLayoutWidth(layoutWidth));\r\n }\r\n }, [dispatch, layoutWidth]);\r\n\r\n const [isMenuOpened, setIsMenuOpened] = useState(false);\r\n const openMenu = () => {\r\n setIsMenuOpened(!isMenuOpened);\r\n }\r\n\r\n return (\r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n\r\n \r\n
\r\n
\r\n
{props.children}
\r\n
\r\n
\r\n\r\n {showRightSidebar ? : null}\r\n \r\n );\r\n}\r\n\r\nLayout.propTypes = {\r\n changeLayout: PropTypes.func,/* */\r\n changeLayoutWidth: PropTypes.func,\r\n changeTopbarTheme: PropTypes.func,\r\n children: PropTypes.object,\r\n isPreloader: PropTypes.any,\r\n layoutWidth: PropTypes.any,\r\n location: PropTypes.object,\r\n showRightSidebar: PropTypes.any,\r\n topbarTheme: PropTypes.any\r\n}\r\n\r\nexport default withRouter(Layout);","import React from \"react\"\r\nimport { Row, Col } from \"reactstrap\";\r\nimport banner from \"../../assets/images/banner/banner.jpg\";\r\nimport { useHistory } from \"react-router-dom\";\r\nimport logoutImg from \"jsbimages/logout_icon.png\"\r\n\r\nconst Header = () => {\r\n const history = useHistory();\r\n\r\n return (\r\n \r\n \r\n \r\n \r\n
\r\n \r\n
\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n
\r\n
\r\n \r\n
\r\n \r\n );\r\n};\r\n\r\nexport default Header\r\n\r\n\r\n","import React, { useState } from \"react\"\r\nimport {\r\n Card,\r\n CardBody,\r\n Table,\r\n Col,\r\n Container,\r\n Form,\r\n FormGroup,\r\n Input,\r\n InputGroup,\r\n Label,\r\n NavItem,\r\n NavLink,\r\n Row,\r\n Button,\r\n TabContent,\r\n TabPane,\r\n FormFeedback,\r\n Dropdown,\r\n DropdownToggle,\r\n DropdownMenu,\r\n DropdownItem,\r\n\r\n} from \"reactstrap\"\r\nimport banner from \"../../assets/images/banner/banner.jpg\";\r\nimport { useHistory } from \"react-router-dom\";\r\n\r\nconst BranchHeader = () => {\r\n var authUserName = JSON.parse(localStorage.getItem('userName'));\r\n\r\n const [menu, setMenu] = useState(false);\r\n const [username, setusername] = useState(authUserName);\r\n const history = useHistory();\r\n\r\n return (\r\n \r\n \r\n \r\n
\r\n \r\n \r\n

\r\n
\r\n \r\n \r\n \r\n \r\n
\r\n \r\n \r\n setMenu(!menu)}\r\n style={{ color: \"white\", fontSize: \"large\" }}\r\n >\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n \r\n );\r\n};\r\n\r\nexport default BranchHeader\r\n\r\n\r\n","import React from \"react\"\r\nimport { Row, Col, Container } from \"reactstrap\";\r\nimport { useHistory } from \"react-router-dom\";\r\n\r\nconst Footer = () => {\r\n\r\n return (\r\n \r\n \r\n \r\n );\r\n};\r\n\r\nexport default Footer\r\n\r\n\r\n","import React, { useEffect } from \"react\";\r\nimport PropTypes from 'prop-types'\r\nimport { withRouter } from \"react-router-dom\"\r\nimport Header from \"../../src/pages/JSBForms/Header\"\r\nimport BranchHeader from \"../../src/pages/JSBForms/BranchHeader\"\r\nimport Footer from \"../../src/pages/JSBForms/Footer\"\r\n\r\nconst NonAuthLayout = (props) => {\r\n var pageUrl = props.match.url;\r\n\r\n oncontextmenu = function () { return false; };\r\n\r\n useEffect(() => {\r\n window.scrollTo(0, 0);\r\n }, []);\r\n\r\n return (\r\n \r\n\r\n {pageUrl.toLowerCase() == \"/customerlist\" ? : (pageUrl.toLowerCase() == \"/login\" || pageUrl.toLowerCase() == \"/success\" || pageUrl.toLowerCase() == \"/branchlogin\") ? <>> : }\r\n {props.children}\r\n {pageUrl.toLowerCase() == \"/login\" || pageUrl.toLowerCase() == \"/success\" || pageUrl.toLowerCase() == \"/branchlogin\" ? <>> : }\r\n \r\n );\r\n}\r\n\r\nNonAuthLayout.propTypes = {\r\n children: PropTypes.any,\r\n location: PropTypes.object,\r\n match: PropTypes.string,\r\n url: PropTypes.string\r\n}\r\n\r\nexport default withRouter(NonAuthLayout)\r\n","import PropTypes from 'prop-types'\r\nimport React from \"react\"\r\n\r\nimport { Switch, BrowserRouter as Router } from \"react-router-dom\"\r\nimport { connect } from \"react-redux\"\r\n\r\n// Import Routes all\r\nimport { authProtectedRoutes, publicRoutes } from \"./routes\"\r\n\r\n// Import all middleware\r\nimport Authmiddleware from \"./routes/route\"\r\n\r\n// layouts Format\r\nimport VerticalLayout from \"./components/VerticalLayout/\"\r\nimport HorizontalLayout from \"./components/HorizontalLayout/\"\r\nimport NonAuthLayout from \"./components/NonAuthLayout\"\r\n\r\n// Import scss\r\nimport \"./assets/scss/theme.scss\"\r\n\r\nimport '../node_modules/flatpickr/dist/flatpickr.min.css';\r\n\r\n\r\nconst App = props => {\r\n function getLayout() {\r\n let layoutCls = HorizontalLayout\r\n switch (props.layout.layoutType) {\r\n case \"horizontal\":\r\n layoutCls = HorizontalLayout\r\n break\r\n default:\r\n layoutCls = VerticalLayout\r\n break\r\n }\r\n return layoutCls\r\n }\r\n\r\n const Layout = getLayout()\r\n return (\r\n \r\n \r\n \r\n {publicRoutes.map((route, idx) => (\r\n \r\n ))}\r\n\r\n {authProtectedRoutes.map((route, idx) => (\r\n \r\n ))}\r\n \r\n \r\n \r\n )\r\n}\r\n\r\nApp.propTypes = {\r\n layout: PropTypes.any\r\n}\r\n\r\nconst mapStateToProps = state => {\r\n return {\r\n layout: state.Layout,\r\n }\r\n}\r\n\r\nexport default connect(mapStateToProps, null)(App)\r\n","// This optional code is used to register a service worker.\r\n// register() is not called by default.\r\n\r\n// This lets the app load faster on subsequent visits in production, and gives\r\n// it offline capabilities. However, it also means that developers (and users)\r\n// will only see deployed updates on subsequent visits to a page, after all the\r\n// existing tabs open on the page have been closed, since previously cached\r\n// resources are updated in the background.\r\n\r\n// To learn more about the benefits of this model and instructions on how to\r\n// opt-in, read https://bit.ly/CRA-PWA\r\n\r\nconst isLocalhost = Boolean(\r\n window.location.hostname === \"localhost\" ||\r\n // [::1] is the IPv6 localhost address.\r\n window.location.hostname === \"[::1]\" ||\r\n // 127.0.0.0/8 are considered localhost for IPv4.\r\n window.location.hostname.match(\r\n /^127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/\r\n )\r\n)\r\n\r\nexport function register(config) {\r\n if (process.env.NODE_ENV === \"production\" && \"serviceWorker\" in navigator) {\r\n // The URL constructor is available in all browsers that support SW.\r\n const publicUrl = new URL(process.env.PUBLIC_URL, window.location.href)\r\n if (publicUrl.origin !== window.location.origin) {\r\n // Our service worker won't work if PUBLIC_URL is on a different origin\r\n // from what our page is served on. This might happen if a CDN is used to\r\n // serve assets; see https://github.com/facebook/create-react-app/issues/2374\r\n return\r\n }\r\n\r\n window.addEventListener(\"load\", () => {\r\n const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`\r\n\r\n if (isLocalhost) {\r\n // This is running on localhost. Let's check if a service worker still exists or not.\r\n checkValidServiceWorker(swUrl, config)\r\n\r\n // Add some additional logging to localhost, pointing developers to the\r\n // service worker/PWA documentation.\r\n navigator.serviceWorker.ready.then(() => {\r\n console.log(\r\n \"This web app is being served cache-first by a service \" +\r\n \"worker. To learn more, visit https://bit.ly/CRA-PWA\"\r\n )\r\n })\r\n } else {\r\n // Is not localhost. Just register service worker\r\n registerValidSW(swUrl, config)\r\n }\r\n })\r\n }\r\n}\r\n\r\nfunction registerValidSW(swUrl, config) {\r\n navigator.serviceWorker\r\n .register(swUrl)\r\n .then(registration => {\r\n registration.onupdatefound = () => {\r\n const installingWorker = registration.installing\r\n if (installingWorker == null) {\r\n return\r\n }\r\n installingWorker.onstatechange = () => {\r\n if (installingWorker.state === \"installed\") {\r\n if (navigator.serviceWorker.controller) {\r\n // At this point, the updated precached content has been fetched,\r\n // but the previous service worker will still serve the older\r\n // content until all client tabs are closed.\r\n console.log(\r\n \"New content is available and will be used when all \" +\r\n \"tabs for this page are closed. See https://bit.ly/CRA-PWA.\"\r\n )\r\n\r\n // Execute callback\r\n if (config && config.onUpdate) {\r\n config.onUpdate(registration)\r\n }\r\n } else {\r\n // At this point, everything has been precached.\r\n // It's the perfect time to display a\r\n // \"Content is cached for offline use.\" message.\r\n console.log(\"Content is cached for offline use.\")\r\n\r\n // Execute callback\r\n if (config && config.onSuccess) {\r\n config.onSuccess(registration)\r\n }\r\n }\r\n }\r\n }\r\n }\r\n })\r\n .catch(error => {\r\n console.error(\"Error during service worker registration:\", error)\r\n })\r\n}\r\n\r\nfunction checkValidServiceWorker(swUrl, config) {\r\n // Check if the service worker can be found. If it can't reload the page.\r\n fetch(swUrl, {\r\n headers: { \"Service-Worker\": \"script\" },\r\n })\r\n .then(response => {\r\n // Ensure service worker exists, and that we really are getting a JS file.\r\n const contentType = response.headers.get(\"content-type\")\r\n if (\r\n response.status === 404 ||\r\n (contentType != null && contentType.indexOf(\"javascript\") === -1)\r\n ) {\r\n // No service worker found. Probably a different app. Reload the page.\r\n navigator.serviceWorker.ready.then(registration => {\r\n registration.unregister().then(() => {\r\n window.location.reload()\r\n })\r\n })\r\n } else {\r\n // Service worker found. Proceed as normal.\r\n registerValidSW(swUrl, config)\r\n }\r\n })\r\n .catch(() => {\r\n console.log(\r\n \"No internet connection found. App is running in offline mode.\"\r\n )\r\n })\r\n}\r\n\r\nexport function unregister() {\r\n if (\"serviceWorker\" in navigator) {\r\n navigator.serviceWorker.ready\r\n .then(registration => {\r\n registration.unregister()\r\n })\r\n .catch(error => {\r\n console.error(error.message)\r\n })\r\n }\r\n}\r\n","// @flow\r\nimport {\r\n CHANGE_LAYOUT,\r\n CHANGE_LAYOUT_WIDTH,\r\n CHANGE_SIDEBAR_THEME,\r\n CHANGE_SIDEBAR_TYPE,\r\n CHANGE_TOPBAR_THEME,\r\n SHOW_RIGHT_SIDEBAR,\r\n CHANGE_SIDEBAR_THEME_IMAGE,\r\n CHANGE_PRELOADER,\r\n TOGGLE_LEFTMENU,\r\n SHOW_SIDEBAR,\r\n} from \"./actionTypes\"\r\n\r\n//constants\r\nimport {\r\n layoutTypes,\r\n layoutWidthTypes,\r\n topBarThemeTypes,\r\n leftBarThemeImageTypes,\r\n leftSidebarTypes,\r\n leftSideBarThemeTypes,\r\n} from \"../../constants/layout\";\r\n\r\nconst INIT_STATE = {\r\n layoutType: layoutTypes.VERTICAL,\r\n layoutWidth: layoutWidthTypes.FLUID,\r\n leftSideBarTheme: leftSideBarThemeTypes.DARK,\r\n leftSideBarThemeImage: leftBarThemeImageTypes.NONE,\r\n leftSideBarType: leftSidebarTypes.DEFAULT,\r\n topbarTheme: topBarThemeTypes.LIGHT,\r\n isPreloader: false,\r\n showRightSidebar: false,\r\n isMobile: false,\r\n showSidebar: false,\r\n leftMenu: false,\r\n}\r\n\r\nconst Layout = (state = INIT_STATE, action) => {\r\n switch (action.type) {\r\n case CHANGE_LAYOUT:\r\n return {\r\n ...state,\r\n layoutType: action.payload,\r\n }\r\n case CHANGE_PRELOADER:\r\n return {\r\n ...state,\r\n isPreloader: action.payload,\r\n }\r\n\r\n case CHANGE_LAYOUT_WIDTH:\r\n return {\r\n ...state,\r\n layoutWidth: action.payload,\r\n }\r\n case CHANGE_SIDEBAR_THEME:\r\n return {\r\n ...state,\r\n leftSideBarTheme: action.payload,\r\n }\r\n case CHANGE_SIDEBAR_THEME_IMAGE:\r\n return {\r\n ...state,\r\n leftSideBarThemeImage: action.payload,\r\n }\r\n case CHANGE_SIDEBAR_TYPE:\r\n return {\r\n ...state,\r\n leftSideBarType: action.payload.sidebarType,\r\n }\r\n case CHANGE_TOPBAR_THEME:\r\n return {\r\n ...state,\r\n topbarTheme: action.payload,\r\n }\r\n case SHOW_RIGHT_SIDEBAR:\r\n return {\r\n ...state,\r\n showRightSidebar: action.payload,\r\n }\r\n case SHOW_SIDEBAR:\r\n return {\r\n ...state,\r\n showSidebar: action.payload,\r\n }\r\n case TOGGLE_LEFTMENU:\r\n return {\r\n ...state,\r\n leftMenu: action.payload,\r\n }\r\n\r\n default:\r\n return state\r\n }\r\n}\r\n\r\nexport default Layout\r\n","import {\r\n LOGIN_USER,\r\n LOGIN_SUCCESS,\r\n LOGOUT_USER,\r\n LOGOUT_USER_SUCCESS,\r\n API_ERROR,\r\n} from \"./actionTypes\"\r\n\r\nconst initialState = {\r\n error: \"\",\r\n loading: false,\r\n}\r\n\r\nconst login = (state = initialState, action) => {\r\n switch (action.type) {\r\n case LOGIN_USER:\r\n state = {\r\n ...state,\r\n loading: true,\r\n }\r\n break\r\n case LOGIN_SUCCESS:\r\n state = {\r\n ...state,\r\n loading: false,\r\n }\r\n break\r\n case LOGOUT_USER:\r\n state = { ...state }\r\n break\r\n case LOGOUT_USER_SUCCESS:\r\n state = { ...state }\r\n break\r\n case API_ERROR:\r\n state = { ...state, error: action.payload, loading: false }\r\n break\r\n default:\r\n state = { ...state }\r\n break\r\n }\r\n return state\r\n}\r\n\r\nexport default login\r\n","import {\r\n REGISTER_USER,\r\n REGISTER_USER_SUCCESSFUL,\r\n REGISTER_USER_FAILED,\r\n} from \"./actionTypes\"\r\n\r\nconst initialState = {\r\n registrationError: null,\r\n message: null,\r\n loading: false,\r\n user: null,\r\n}\r\n\r\nconst account = (state = initialState, action) => {\r\n switch (action.type) {\r\n case REGISTER_USER:\r\n state = {\r\n ...state,\r\n loading: true,\r\n registrationError: null,\r\n }\r\n break\r\n case REGISTER_USER_SUCCESSFUL:\r\n state = {\r\n ...state,\r\n loading: false,\r\n user: action.payload,\r\n registrationError: null,\r\n }\r\n break\r\n case REGISTER_USER_FAILED:\r\n state = {\r\n ...state,\r\n user: null,\r\n loading: false,\r\n registrationError: action.payload,\r\n }\r\n break\r\n default:\r\n state = { ...state }\r\n break\r\n }\r\n return state\r\n}\r\n\r\nexport default account\r\n","import {\r\n FORGET_PASSWORD,\r\n FORGET_PASSWORD_SUCCESS,\r\n FORGET_PASSWORD_ERROR,\r\n} from \"./actionTypes\"\r\n\r\nconst initialState = {\r\n forgetSuccessMsg: null,\r\n forgetError: null,\r\n}\r\n\r\nconst forgetPassword = (state = initialState, action) => {\r\n switch (action.type) {\r\n case FORGET_PASSWORD:\r\n state = {\r\n ...state,\r\n forgetSuccessMsg: null,\r\n forgetError: null,\r\n }\r\n break\r\n case FORGET_PASSWORD_SUCCESS:\r\n state = {\r\n ...state,\r\n forgetSuccessMsg: action.payload,\r\n }\r\n break\r\n case FORGET_PASSWORD_ERROR:\r\n state = { ...state, forgetError: action.payload }\r\n break\r\n default:\r\n state = { ...state }\r\n break\r\n }\r\n return state\r\n}\r\n\r\nexport default forgetPassword\r\n","import { PROFILE_ERROR, PROFILE_SUCCESS, EDIT_PROFILE, RESET_PROFILE_FLAG } from \"./actionTypes\";\r\n\r\nconst initialState = {\r\n error: \"\",\r\n success: \"\",\r\n};\r\n\r\nconst profile = (state = initialState, action) => {\r\n switch (action.type) {\r\n case EDIT_PROFILE:\r\n state = { ...state };\r\n break;\r\n case PROFILE_SUCCESS:\r\n state = { ...state, success: action.payload };\r\n break;\r\n case PROFILE_ERROR:\r\n state = { ...state, error: action.payload };\r\n break;\r\n case RESET_PROFILE_FLAG:\r\n state = { ...state, success: null };\r\n break;\r\n default:\r\n state = { ...state };\r\n break;\r\n }\r\n return state;\r\n};\r\n\r\nexport default profile;\r\n","import {\r\n GET_CART_DATA_FAIL,\r\n GET_CART_DATA_SUCCESS,\r\n GET_CUSTOMERS_FAIL,\r\n GET_CUSTOMERS_SUCCESS,\r\n ADD_CUSTOMER_SUCCESS,\r\n ADD_CUSTOMER_FAIL,\r\n UPDATE_CUSTOMER_SUCCESS,\r\n UPDATE_CUSTOMER_FAIL,\r\n DELETE_CUSTOMER_SUCCESS,\r\n DELETE_CUSTOMER_FAIL,\r\n GET_ORDERS_FAIL,\r\n GET_ORDERS_SUCCESS,\r\n GET_PRODUCTS_FAIL,\r\n GET_PRODUCTS_SUCCESS,\r\n GET_SHOPS_FAIL,\r\n GET_SHOPS_SUCCESS,\r\n GET_PRODUCT_DETAIL_SUCCESS,\r\n GET_PRODUCT_DETAIL_FAIL,\r\n ADD_ORDER_SUCCESS,\r\n ADD_ORDER_FAIL,\r\n UPDATE_ORDER_SUCCESS,\r\n UPDATE_ORDER_FAIL,\r\n DELETE_ORDER_SUCCESS,\r\n DELETE_ORDER_FAIL,\r\n GET_PRODUCT_COMMENTS_SUCCESS,\r\n GET_PRODUCT_COMMENTS_FAIL,\r\n ON_LIKE_COMMENT_SUCCESS,\r\n ON_LIKE_REPLY_SUCCESS,\r\n ON_ADD_REPLY_SUCCESS,\r\n ON_ADD_COMMENT_SUCCESS,\r\n} from \"./actionTypes\";\r\n\r\nconst INIT_STATE = {\r\n products: [],\r\n product: {},\r\n orders: [],\r\n cartData: {},\r\n customers: [],\r\n shops: [],\r\n error: {},\r\n productComments: [],\r\n};\r\n\r\nconst Ecommerce = (state = INIT_STATE, action) => {\r\n switch (action.type) {\r\n case GET_PRODUCTS_SUCCESS:\r\n return {\r\n ...state,\r\n products: action.payload,\r\n };\r\n\r\n case GET_PRODUCTS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n case GET_PRODUCT_DETAIL_SUCCESS:\r\n return {\r\n ...state,\r\n product: action.payload,\r\n };\r\n\r\n case GET_PRODUCT_DETAIL_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n case GET_ORDERS_SUCCESS:\r\n return {\r\n ...state,\r\n orders: action.payload,\r\n };\r\n\r\n case GET_ORDERS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n case ADD_ORDER_SUCCESS:\r\n return {\r\n ...state,\r\n orders: [...state.orders, action.payload],\r\n };\r\n\r\n case ADD_ORDER_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n case UPDATE_ORDER_SUCCESS:\r\n return {\r\n ...state,\r\n orders: state.orders.map(order =>\r\n order.id === action.payload.id.toString()\r\n ? { order, ...action.payload }\r\n : order\r\n ),\r\n };\r\n\r\n case UPDATE_ORDER_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n case DELETE_ORDER_SUCCESS:\r\n return {\r\n ...state,\r\n orders: state.orders.filter(\r\n order => order.id.toString() !== action.payload.id.toString()\r\n ),\r\n };\r\n\r\n case DELETE_ORDER_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n case GET_CART_DATA_SUCCESS:\r\n return {\r\n ...state,\r\n cartData: action.payload,\r\n };\r\n\r\n case GET_CART_DATA_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n case GET_CUSTOMERS_SUCCESS:\r\n return {\r\n ...state,\r\n customers: action.payload,\r\n };\r\n\r\n case GET_CUSTOMERS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n case ADD_CUSTOMER_SUCCESS:\r\n return {\r\n ...state,\r\n customers: [...state.customers, action.payload],\r\n };\r\n\r\n case ADD_CUSTOMER_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n case UPDATE_CUSTOMER_SUCCESS:\r\n return {\r\n ...state,\r\n customers: state.customers.map(customer =>\r\n customer.id.toString() === action.payload.id.toString()\r\n ? { customer, ...action.payload }\r\n : customer\r\n ),\r\n };\r\n\r\n case UPDATE_CUSTOMER_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n case DELETE_CUSTOMER_SUCCESS:\r\n return {\r\n ...state,\r\n customers: state.customers.filter(\r\n customer => customer.id.toString() !== action.payload.id.toString()\r\n ),\r\n };\r\n\r\n case DELETE_CUSTOMER_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n case GET_SHOPS_SUCCESS:\r\n return {\r\n ...state,\r\n shops: action.payload,\r\n };\r\n\r\n case GET_SHOPS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n case GET_PRODUCT_COMMENTS_SUCCESS:\r\n case ON_LIKE_COMMENT_SUCCESS:\r\n case ON_LIKE_REPLY_SUCCESS:\r\n case ON_ADD_REPLY_SUCCESS:\r\n case ON_ADD_COMMENT_SUCCESS:\r\n return {\r\n ...state,\r\n productComments: action.payload,\r\n };\r\n\r\n case GET_PRODUCT_COMMENTS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n default:\r\n return state;\r\n }\r\n};\r\n\r\nexport default Ecommerce;\r\n","import {\r\n GET_EVENTS_SUCCESS,\r\n GET_EVENTS_FAIL,\r\n ADD_EVENT_SUCCESS,\r\n ADD_EVENT_FAIL,\r\n UPDATE_EVENT_SUCCESS,\r\n UPDATE_EVENT_FAIL,\r\n DELETE_EVENT_SUCCESS,\r\n DELETE_EVENT_FAIL,\r\n GET_CATEGORIES_SUCCESS,\r\n GET_CATEGORIES_FAIL,\r\n} from \"./actionTypes\";\r\n\r\nconst INIT_STATE = {\r\n events: [],\r\n categories: [],\r\n error: {},\r\n};\r\n\r\nconst Calendar = (state = INIT_STATE, action) => {\r\n switch (action.type) {\r\n case GET_EVENTS_SUCCESS:\r\n return {\r\n ...state,\r\n events: action.payload,\r\n };\r\n\r\n case GET_EVENTS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n case ADD_EVENT_SUCCESS:\r\n return {\r\n ...state,\r\n events: [...state.events, action.payload],\r\n };\r\n\r\n case ADD_EVENT_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n case UPDATE_EVENT_SUCCESS:\r\n return {\r\n ...state,\r\n events: state.events.map(event =>\r\n event.id.toString() === action.payload.id.toString()\r\n ? { event, ...action.payload }\r\n : event\r\n ),\r\n };\r\n\r\n case UPDATE_EVENT_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n case DELETE_EVENT_SUCCESS:\r\n return {\r\n ...state,\r\n events: state.events.filter(\r\n event => event.id.toString() !== action.payload.id.toString()\r\n ),\r\n };\r\n\r\n case DELETE_EVENT_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n case GET_CATEGORIES_SUCCESS:\r\n return {\r\n ...state,\r\n categories: action.payload,\r\n };\r\n\r\n case GET_CATEGORIES_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n default:\r\n return state;\r\n }\r\n};\r\n\r\nexport default Calendar;\r\n","import {\r\n GET_GROUPS_SUCCESS,\r\n GET_CHATS_SUCCESS,\r\n GET_GROUPS_FAIL,\r\n GET_CHATS_FAIL,\r\n GET_CONTACTS_SUCCESS,\r\n GET_CONTACTS_FAIL,\r\n GET_MESSAGES_SUCCESS,\r\n GET_MESSAGES_FAIL,\r\n POST_ADD_MESSAGE_SUCCESS,\r\n POST_ADD_MESSAGE_FAIL,\r\n} from \"./actionTypes\"\r\n\r\nconst INIT_STATE = {\r\n chats: [],\r\n groups: [],\r\n contacts: [],\r\n messages: [],\r\n error: {},\r\n}\r\n\r\nconst Calendar = (state = INIT_STATE, action) => {\r\n switch (action.type) {\r\n case GET_CHATS_SUCCESS:\r\n return {\r\n ...state,\r\n chats: action.payload,\r\n }\r\n\r\n case GET_CHATS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n case GET_GROUPS_SUCCESS:\r\n return {\r\n ...state,\r\n groups: action.payload,\r\n }\r\n\r\n case GET_GROUPS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n case GET_CONTACTS_SUCCESS:\r\n return {\r\n ...state,\r\n contacts: action.payload,\r\n }\r\n\r\n case GET_CONTACTS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n case GET_MESSAGES_SUCCESS:\r\n return {\r\n ...state,\r\n messages: action.payload,\r\n }\r\n\r\n case GET_MESSAGES_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n case POST_ADD_MESSAGE_SUCCESS:\r\n return {\r\n ...state,\r\n messages: [...state.messages, action.payload],\r\n }\r\n\r\n case POST_ADD_MESSAGE_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n default:\r\n return state\r\n }\r\n}\r\n\r\nexport default Calendar\r\n","import {\r\n GET_WALLET_FAIL,\r\n GET_WALLET_SUCCESS,\r\n GET_CRYPTO_ORDERS_SUCCESS,\r\n GET_CRYPTO_ORDERS_FAIL,\r\n} from \"./actionTypes\"\r\n\r\nconst INIT_STATE = {\r\n wallet: {},\r\n orders: [],\r\n}\r\n\r\nconst Crypto = (state = INIT_STATE, action) => {\r\n switch (action.type) {\r\n case GET_WALLET_SUCCESS:\r\n return {\r\n ...state,\r\n wallet: action.payload,\r\n }\r\n\r\n case GET_WALLET_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n case GET_CRYPTO_ORDERS_SUCCESS:\r\n return {\r\n ...state,\r\n orders: action.payload,\r\n }\r\n\r\n case GET_CRYPTO_ORDERS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n default:\r\n return state\r\n }\r\n}\r\n\r\nexport default Crypto\r\n","import {\r\n GET_INVOICES_FAIL,\r\n GET_INVOICES_SUCCESS,\r\n GET_INVOICE_DETAIL_SUCCESS,\r\n GET_INVOICE_DETAIL_FAIL,\r\n} from \"./actionTypes\"\r\n\r\nconst INIT_STATE = {\r\n invoices: [],\r\n invoiceDetail: {},\r\n error: {},\r\n}\r\n\r\nconst Invoices = (state = INIT_STATE, action) => {\r\n switch (action.type) {\r\n case GET_INVOICES_SUCCESS:\r\n return {\r\n ...state,\r\n invoices: action.payload,\r\n }\r\n\r\n case GET_INVOICES_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n case GET_INVOICE_DETAIL_SUCCESS:\r\n return {\r\n ...state,\r\n invoiceDetail: action.payload,\r\n }\r\n\r\n case GET_INVOICE_DETAIL_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n default:\r\n return state\r\n }\r\n}\r\n\r\nexport default Invoices\r\n","import {\r\n GET_PROJECTS_FAIL,\r\n GET_PROJECTS_SUCCESS,\r\n GET_PROJECT_DETAIL_FAIL,\r\n GET_PROJECT_DETAIL_SUCCESS,\r\n ADD_PROJECT_SUCCESS,\r\n ADD_PROJECT_FAIL,\r\n UPDATE_PROJECT_SUCCESS,\r\n UPDATE_PROJECT_FAIL,\r\n DELETE_PROJECT_SUCCESS,\r\n DELETE_PROJECT_FAIL,\r\n} from \"./actionTypes\"\r\n\r\nconst INIT_STATE = {\r\n projects: [],\r\n projectDetail: {},\r\n error: {},\r\n}\r\n\r\nconst projects = (state = INIT_STATE, action) => {\r\n switch (action.type) {\r\n case GET_PROJECTS_SUCCESS:\r\n return {\r\n ...state,\r\n projects: action.payload,\r\n }\r\n\r\n case GET_PROJECTS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n case ADD_PROJECT_SUCCESS:\r\n return {\r\n ...state,\r\n projects: [...state.projects, action.payload],\r\n }\r\n\r\n case ADD_PROJECT_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n case GET_PROJECT_DETAIL_SUCCESS:\r\n return {\r\n ...state,\r\n projectDetail: action.payload,\r\n }\r\n\r\n case UPDATE_PROJECT_SUCCESS:\r\n return {\r\n ...state,\r\n projects: state.projects.map(project =>\r\n project.id.toString() === action.payload.id.toString()\r\n ? { project, ...action.payload }\r\n : project\r\n ),\r\n }\r\n\r\n case UPDATE_PROJECT_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n case DELETE_PROJECT_SUCCESS:\r\n return {\r\n ...state,\r\n projects: state.projects.filter(\r\n project => project.id.toString() !== action.payload.id.toString()\r\n ),\r\n }\r\n\r\n case DELETE_PROJECT_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n\r\n case GET_PROJECT_DETAIL_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n default:\r\n return state\r\n }\r\n}\r\n\r\nexport default projects\r\n","import { GET_TASKS_SUCCESS, GET_TASKS_FAIL } from \"./actionTypes\"\r\n\r\nconst INIT_STATE = {\r\n tasks: [],\r\n error: {},\r\n}\r\n\r\nconst tasks = (state = INIT_STATE, action) => {\r\n switch (action.type) {\r\n case GET_TASKS_SUCCESS:\r\n return {\r\n ...state,\r\n tasks: action.payload,\r\n }\r\n\r\n case GET_TASKS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n default:\r\n return state\r\n }\r\n}\r\n\r\nexport default tasks\r\n","import {\r\n GET_USERS_SUCCESS,\r\n GET_USERS_FAIL,\r\n ADD_USER_SUCCESS,\r\n ADD_USER_FAIL,\r\n UPDATE_USER_SUCCESS,\r\n UPDATE_USER_FAIL,\r\n DELETE_USER_SUCCESS,\r\n DELETE_USER_FAIL,\r\n GET_USER_PROFILE_SUCCESS,\r\n GET_USER_PROFILE_FAIL,\r\n} from \"./actionTypes\"\r\n\r\nconst INIT_STATE = {\r\n users: [],\r\n userProfile: {},\r\n error: {},\r\n}\r\n\r\nconst contacts = (state = INIT_STATE, action) => {\r\n switch (action.type) {\r\n case GET_USERS_SUCCESS:\r\n return {\r\n ...state,\r\n users: action.payload,\r\n }\r\n\r\n case GET_USERS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n case ADD_USER_SUCCESS:\r\n\r\n return {\r\n ...state,\r\n users: [...state.users, action.payload],\r\n }\r\n\r\n case ADD_USER_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n case GET_USER_PROFILE_SUCCESS:\r\n return {\r\n ...state,\r\n userProfile: action.payload,\r\n }\r\n\r\n case UPDATE_USER_SUCCESS:\r\n return {\r\n ...state,\r\n users: state.users.map(user =>\r\n user.id.toString() === action.payload.id.toString()\r\n ? { user, ...action.payload }\r\n : user\r\n ),\r\n }\r\n \r\n case UPDATE_USER_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n \r\n case DELETE_USER_SUCCESS:\r\n return {\r\n ...state,\r\n users: state.users.filter(\r\n user => user.id.toString() !== action.payload.id.toString()\r\n ),\r\n }\r\n \r\n case DELETE_USER_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n case GET_USER_PROFILE_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n default:\r\n return state\r\n }\r\n}\r\n\r\nexport default contacts\r\n","import {\r\n GET_INBOX_MAILS_SUCCESS,\r\n GET_INBOX_MAILS_FAIL,\r\n ADD_INBOX_MAIL_SUCCESS,\r\n ADD_INBOX_MAIL_FAIL,\r\n DELETE_INBOX_MAIL_SUCCESS,\r\n DELETE_INBOX_MAIL_FAIL,\r\n GET_STARRED_MAILS_SUCCESS,\r\n GET_STARRED_MAILS_FAIL,\r\n GET_IMPORTANT_MAILS_SUCCESS,\r\n GET_IMPORTANT_MAILS_FAIL,\r\n GET_SENT_MAILS_SUCCESS,\r\n GET_SENT_MAILS_FAIL,\r\n GET_DRAFT_MAILS_SUCCESS,\r\n GET_DRAFT_MAILS_FAIL,\r\n GET_TRASH_MAILS_SUCCESS,\r\n GET_TRASH_MAILS_FAIL,\r\n} from \"./actionTypes\"\r\n\r\nconst INIT_STATE = {\r\n inboxmails: [],\r\n starredmails: [],\r\n importantmails: [],\r\n draftmails: [],\r\n sentmails: [],\r\n trashmails: [],\r\n error: {},\r\n}\r\n\r\nconst Mails = (state = INIT_STATE, action) => {\r\n switch (action.type) {\r\n case GET_INBOX_MAILS_SUCCESS:\r\n return {\r\n ...state,\r\n inboxmails: action.payload,\r\n }\r\n\r\n case GET_INBOX_MAILS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n case ADD_INBOX_MAIL_SUCCESS:\r\n return {\r\n ...state,\r\n inboxmails: [...state.inboxmails, action.payload],\r\n }\r\n\r\n case ADD_INBOX_MAIL_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n case DELETE_INBOX_MAIL_SUCCESS:\r\n return {\r\n ...state,\r\n inboxmails: state.inboxmails.filter(\r\n user => user.id.toString() !== action.payload.id.toString()\r\n ),\r\n }\r\n\r\n case DELETE_INBOX_MAIL_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n case GET_STARRED_MAILS_SUCCESS:\r\n return {\r\n ...state,\r\n starredmails: action.payload,\r\n }\r\n\r\n case GET_STARRED_MAILS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n\r\n\r\n case GET_IMPORTANT_MAILS_SUCCESS:\r\n return {\r\n ...state,\r\n importantmails: action.payload,\r\n }\r\n\r\n case GET_IMPORTANT_MAILS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n case GET_TRASH_MAILS_SUCCESS:\r\n return {\r\n ...state,\r\n trashmails: action.payload,\r\n }\r\n\r\n case GET_TRASH_MAILS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n case GET_DRAFT_MAILS_SUCCESS:\r\n return {\r\n ...state,\r\n draftmails: action.payload,\r\n }\r\n\r\n case GET_DRAFT_MAILS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n case GET_SENT_MAILS_SUCCESS:\r\n return {\r\n ...state,\r\n sentmails: action.payload,\r\n }\r\n\r\n case GET_SENT_MAILS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n }\r\n\r\n default:\r\n return state\r\n }\r\n}\r\n\r\nexport default Mails","import {\r\n API_SUCCESS,\r\n API_FAIL,\r\n GET_CHARTS_DATA\r\n} from \"./actionTypes\";\r\n\r\nconst INIT_STATE = {\r\n chartsData: []\r\n};\r\n\r\nconst Dashboard = (state = INIT_STATE, action) => {\r\n switch (action.type) {\r\n case API_SUCCESS:\r\n switch (action.payload.actionType) {\r\n case GET_CHARTS_DATA:\r\n return {\r\n ...state,\r\n chartsData: action.payload.data\r\n };\r\n default:\r\n return state;\r\n }\r\n case API_FAIL:\r\n switch (action.payload.actionType) {\r\n case GET_CHARTS_DATA:\r\n return {\r\n ...state,\r\n chartsDataError: action.payload.error\r\n };\r\n\r\n\r\n default:\r\n return state;\r\n }\r\n default:\r\n return state;\r\n }\r\n}\r\n\r\n\r\nexport default Dashboard;","import {\r\n API_SUCCESS,\r\n API_FAIL,\r\n GET_TOP_SELLING_PRODUCT,\r\n GET_EARNING_DATA\r\n} from \"./actionType\";\r\n\r\nconst INIT_STATE = {\r\n sellingData: [],\r\n earningChartData: []\r\n};\r\n\r\nconst DashboardSaas = (state = INIT_STATE, action) => {\r\n switch (action.type) {\r\n case API_SUCCESS:\r\n switch (action.payload.actionType) {\r\n case GET_TOP_SELLING_PRODUCT:\r\n return {\r\n ...state,\r\n sellingData: action.payload.data\r\n };\r\n\r\n case GET_EARNING_DATA:\r\n return {\r\n ...state,\r\n earningChartData: action.payload.data\r\n };\r\n default:\r\n return state;\r\n }\r\n case API_FAIL:\r\n switch (action.payload.actionType) {\r\n case GET_TOP_SELLING_PRODUCT:\r\n return {\r\n ...state,\r\n sellingDataError: action.payload.error\r\n };\r\n\r\n case GET_EARNING_DATA:\r\n return {\r\n ...state,\r\n earningChartDataError: action.payload.error\r\n };\r\n\r\n\r\n default:\r\n return state;\r\n }\r\n default:\r\n return state;\r\n }\r\n}\r\n\r\n\r\nexport default DashboardSaas;","import {\r\n GET_STATE_SUCCESS,\r\n GET_STATE_FAIL,\r\n GET_OCCUPATION_SUCCESS,\r\n GET_OCCUPATION_FAIL,\r\n GET_RELATEDPERSONTYPE_SUCCESS,\r\n GET_RELATEDPERSONTYPE_FAIL,\r\n GET_EDUCATION_SUCCESS,\r\n GET_EDUCATION_FAIL,\r\n GET_OCCUPATIONDETAILS,\r\n GET_OCCUPATIONDETAILS_SUCCESS,\r\n GET_OCCUPATIONDETAILS_FAIL,\r\n GET_ASSETDETAILS_SUCCESS,\r\n GET_ASSETDETAILS_FAIL,\r\n GET_OTHERBANKACCOUNTS,\r\n GET_OTHERBANKACCOUNTS_SUCCESS,\r\n GET_OTHERBANKACCOUNTS_FAIL,\r\n GET_ACCOUNTTYPE_SUCCESS,\r\n GET_ACCOUNTTYPE_FAIL,\r\n GET_ENTITYTYPE_SUCCESS,\r\n GET_ENTITYTYPE_FAIL,\r\n GET_LOCATION_SUCCESS,\r\n GET_LOCATION_FAIL,\r\n GET_BRANCH_SUCCESS,\r\n GET_BRANCH_FAIL,\r\n GET_POI_SUCCESS,\r\n GET_POI_FAIL\r\n\r\n} from \"./actionTypes\";\r\n\r\nconst INIT_STATE = {\r\n stateData: [],\r\n occupationData: [],\r\n relatedPersonTypeData: [],\r\n educationData: [],\r\n occupationDetailsData: [],\r\n assetDetailsData: [],\r\n otherBankAccountsData: [],\r\n accountTypeData: [],\r\n entityTypeData: [],\r\n locationData: [],\r\n branchData: [],\r\n poiData: [],\r\n};\r\n\r\nconst Registration = (state = INIT_STATE, action) => {\r\n \r\n switch (action.type) {\r\n //GetAll State\r\n case GET_STATE_SUCCESS:\r\n return {\r\n ...state,\r\n stateData: action.payload,\r\n };\r\n\r\n case GET_STATE_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n // GetALl Occupation\r\n case GET_OCCUPATION_SUCCESS:\r\n return {\r\n ...state,\r\n occupationData: action.payload,\r\n };\r\n case GET_OCCUPATION_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n //GetAll Related Person Type \r\n case GET_RELATEDPERSONTYPE_SUCCESS:\r\n return {\r\n ...state,\r\n relatedPersonTypeData: action.payload,\r\n };\r\n case GET_RELATEDPERSONTYPE_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n //GetAll Education\r\n case GET_EDUCATION_SUCCESS:\r\n return {\r\n ...state,\r\n educationData: action.payload,\r\n };\r\n case GET_EDUCATION_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n //GetAll OccupationDetails\r\n case GET_OCCUPATIONDETAILS_SUCCESS:\r\n return {\r\n ...state,\r\n occupationDetailsData: action.payload,\r\n };\r\n case GET_OCCUPATIONDETAILS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n //GetAll AssetDetails\r\n case GET_ASSETDETAILS_SUCCESS:\r\n return {\r\n ...state,\r\n assetDetailsData: action.payload,\r\n };\r\n case GET_ASSETDETAILS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n //GetAll OtherBankAccounts\r\n case GET_OTHERBANKACCOUNTS_SUCCESS:\r\n return {\r\n ...state,\r\n otherBankAccountsData: action.payload,\r\n };\r\n case GET_OTHERBANKACCOUNTS_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n //GetAll AccountType\r\n case GET_ACCOUNTTYPE_SUCCESS:\r\n return {\r\n ...state,\r\n accountTypeData: action.payload,\r\n };\r\n case GET_ACCOUNTTYPE_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n //GetAll EntityType\r\n case GET_ENTITYTYPE_SUCCESS:\r\n return {\r\n ...state,\r\n entityTypeData: action.payload,\r\n };\r\n case GET_ENTITYTYPE_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n //GetAll Location\r\n case GET_LOCATION_SUCCESS:\r\n return {\r\n ...state,\r\n locationData: action.payload,\r\n };\r\n case GET_LOCATION_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n // GetByLocationId Branch\r\n case GET_BRANCH_SUCCESS:\r\n return {\r\n ...state,\r\n branchData: action.payload,\r\n };\r\n case GET_BRANCH_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n //GetAll Poi\r\n case GET_POI_SUCCESS:\r\n return {\r\n ...state,\r\n poiData: action.payload,\r\n };\r\n case GET_POI_FAIL:\r\n return {\r\n ...state,\r\n error: action.payload,\r\n };\r\n\r\n default:\r\n return state;\r\n }\r\n};\r\n\r\nexport default Registration;","import { combineReducers } from \"redux\"\r\n\r\n// Front\r\nimport Layout from \"./layout/reducer\"\r\n\r\n// Authentication\r\nimport Login from \"./auth/login/reducer\"\r\nimport Account from \"./auth/register/reducer\"\r\nimport ForgetPassword from \"./auth/forgetpwd/reducer\"\r\nimport Profile from \"./auth/profile/reducer\"\r\n\r\n//E-commerce\r\nimport ecommerce from \"./e-commerce/reducer\"\r\n\r\n//Calendar\r\nimport calendar from \"./calendar/reducer\"\r\n\r\n//chat\r\nimport chat from \"./chat/reducer\"\r\n\r\n//crypto\r\nimport crypto from \"./crypto/reducer\"\r\n\r\n//invoices\r\nimport invoices from \"./invoices/reducer\"\r\n\r\n//projects\r\nimport projects from \"./projects/reducer\"\r\n\r\n//tasks\r\nimport tasks from \"./tasks/reducer\"\r\n\r\n//contacts\r\nimport contacts from \"./contacts/reducer\"\r\n\r\n//mails\r\nimport mails from \"./mails/reducer\";\r\n\r\n//Dashboard \r\nimport Dashboard from \"./dashboard/reducer\";\r\n\r\n//Dasboard saas\r\nimport DashboardSaas from \"./dashboard-saas/reducer\";\r\n\r\n//Read Registration\r\n\r\nimport Registration from \"./Registration/reducer\";\r\n\r\nconst rootReducer = combineReducers({\r\n // public\r\n Layout,\r\n Login,\r\n Account,\r\n ForgetPassword,\r\n Profile,\r\n ecommerce,\r\n calendar,\r\n chat,\r\n mails,\r\n crypto,\r\n invoices,\r\n projects,\r\n tasks,\r\n contacts,\r\n Dashboard,\r\n DashboardSaas,\r\n Registration\r\n})\r\n\r\nexport default rootReducer\r\n","import firebase from 'firebase/compat/app'\r\n\r\n// Add the Firebase products that you want to use\r\nimport \"firebase/compat/auth\";\r\nimport \"firebase/compat/firestore\";\r\n\r\nclass FirebaseAuthBackend {\r\n constructor(firebaseConfig) {\r\n if (firebaseConfig) {\r\n // Initialize Firebase\r\n firebase.initializeApp(firebaseConfig);\r\n firebase.auth().onAuthStateChanged(user => {\r\n if (user) {\r\n localStorage.setItem(\"authUser\", JSON.stringify(user));\r\n } else {\r\n localStorage.removeItem(\"authUser\");\r\n }\r\n });\r\n }\r\n }\r\n\r\n /**\r\n * Registers the user with given details\r\n */\r\n registerUser = (email, password) => {\r\n return new Promise((resolve, reject) => {\r\n firebase\r\n .auth()\r\n .createUserWithEmailAndPassword(email, password)\r\n .then(\r\n user => {\r\n resolve(firebase.auth().currentUser);\r\n },\r\n error => {\r\n reject(this._handleError(error));\r\n }\r\n );\r\n });\r\n };\r\n\r\n /**\r\n * Registers the user with given details\r\n */\r\n editProfileAPI = (email, password) => {\r\n return new Promise((resolve, reject) => {\r\n firebase\r\n .auth()\r\n .createUserWithEmailAndPassword(email, password)\r\n .then(\r\n user => {\r\n resolve(firebase.auth().currentUser);\r\n },\r\n error => {\r\n reject(this._handleError(error));\r\n }\r\n );\r\n });\r\n };\r\n\r\n /**\r\n * Login user with given details\r\n */\r\n loginUser = (email, password) => {\r\n return new Promise((resolve, reject) => {\r\n firebase\r\n .auth()\r\n .signInWithEmailAndPassword(email, password)\r\n .then(\r\n user => {\r\n resolve(firebase.auth().currentUser);\r\n },\r\n error => {\r\n reject(this._handleError(error));\r\n }\r\n );\r\n });\r\n };\r\n\r\n /**\r\n * forget Password user with given details\r\n */\r\n forgetPassword = email => {\r\n return new Promise((resolve, reject) => {\r\n firebase\r\n .auth()\r\n .sendPasswordResetEmail(email, {\r\n url:\r\n window.location.protocol + \"//\" + window.location.host + \"/login\",\r\n })\r\n .then(() => {\r\n resolve(true);\r\n })\r\n .catch(error => {\r\n reject(this._handleError(error));\r\n });\r\n });\r\n };\r\n\r\n /**\r\n * Logout the user\r\n */\r\n logout = () => {\r\n return new Promise((resolve, reject) => {\r\n firebase\r\n .auth()\r\n .signOut()\r\n .then(() => {\r\n resolve(true);\r\n })\r\n .catch(error => {\r\n reject(this._handleError(error));\r\n });\r\n });\r\n };\r\n\r\n /**\r\n * Social Login user with given details\r\n */\r\n socialLoginUser = (data, type) => {\r\n let credential = {};\r\n if (type === \"google\") {\r\n credential = firebase.auth.GoogleAuthProvider.credential(data.idToken, data.token);\r\n } else if (type === \"facebook\") {\r\n credential = firebase.auth.FacebookAuthProvider.credential(data.token);\r\n }\r\n return new Promise((resolve, reject) => {\r\n if (!!credential) {\r\n firebase.auth().signInWithCredential(credential)\r\n .then(user => {\r\n resolve(this.addNewUserToFirestore(user));\r\n })\r\n .catch(error => {\r\n reject(this._handleError(error));\r\n });\r\n } else {\r\n reject(this._handleError(error));\r\n }\r\n });\r\n };\r\n\r\n addNewUserToFirestore = (user) => {\r\n const collection = firebase.firestore().collection(\"users\");\r\n const { profile } = user.additionalUserInfo;\r\n const details = {\r\n firstName: profile.given_name ? profile.given_name : profile.first_name,\r\n lastName: profile.family_name ? profile.family_name : profile.last_name,\r\n fullName: profile.name,\r\n email: profile.email,\r\n picture: profile.picture,\r\n createdDtm: firebase.firestore.FieldValue.serverTimestamp(),\r\n lastLoginTime: firebase.firestore.FieldValue.serverTimestamp()\r\n };\r\n collection.doc(firebase.auth().currentUser.uid).set(details);\r\n return { user, details };\r\n };\r\n\r\n setLoggeedInUser = user => {\r\n localStorage.setItem(\"authUser\", JSON.stringify(user));\r\n };\r\n\r\n /**\r\n * Returns the authenticated user\r\n */\r\n getAuthenticatedUser = () => {\r\n if (!localStorage.getItem(\"authUser\")) return null;\r\n return JSON.parse(localStorage.getItem(\"authUser\"));\r\n };\r\n\r\n /**\r\n * Handle the error\r\n * @param {*} error\r\n */\r\n _handleError(error) {\r\n // var errorCode = error.code;\r\n var errorMessage = error.message;\r\n return errorMessage;\r\n }\r\n}\r\n\r\nlet _fireBaseBackend = null;\r\n\r\n/**\r\n * Initilize the backend\r\n * @param {*} config\r\n */\r\nconst initFirebaseBackend = config => {\r\n if (!_fireBaseBackend) {\r\n _fireBaseBackend = new FirebaseAuthBackend(config);\r\n }\r\n return _fireBaseBackend;\r\n};\r\n\r\n/**\r\n * Returns the firebase backend\r\n */\r\nconst getFirebaseBackend = () => {\r\n return _fireBaseBackend;\r\n};\r\n\r\nexport { initFirebaseBackend, getFirebaseBackend };\r\n","import { takeEvery, fork, put, all, call } from \"redux-saga/effects\"\r\n\r\n//Account Redux states\r\nimport { REGISTER_USER } from \"./actionTypes\"\r\nimport { registerUserSuccessful, registerUserFailed } from \"./actions\"\r\n\r\n//Include Both Helper File with needed methods\r\nimport { getFirebaseBackend } from \"../../../helpers/firebase_helper\"\r\nimport {\r\n postFakeRegister,\r\n postJwtRegister,\r\n} from \"../../../helpers/fakebackend_helper\"\r\n\r\n// initialize relavant method of both Auth\r\nconst fireBaseBackend = getFirebaseBackend()\r\n\r\n// Is user register successfull then direct plot user in redux.\r\nfunction* registerUser({ payload: { user } }) {\r\n try {\r\n if (process.env.REACT_APP_DEFAULTAUTH === \"firebase\") {\r\n const response = yield call(\r\n fireBaseBackend.registerUser,\r\n user.email,\r\n user.password\r\n )\r\n yield put(registerUserSuccessful(response))\r\n } else if (process.env.REACT_APP_DEFAULTAUTH === \"jwt\") {\r\n const response = yield call(postJwtRegister, \"/post-jwt-register\", user)\r\n yield put(registerUserSuccessful(response))\r\n } else if (process.env.REACT_APP_DEFAULTAUTH === \"fake\") {\r\n const response = yield call(postFakeRegister, user)\r\n yield put(registerUserSuccessful(response))\r\n }\r\n } catch (error) {\r\n yield put(registerUserFailed(error))\r\n }\r\n}\r\n\r\nexport function* watchUserRegister() {\r\n yield takeEvery(REGISTER_USER, registerUser)\r\n}\r\n\r\nfunction* accountSaga() {\r\n yield all([fork(watchUserRegister)])\r\n}\r\n\r\nexport default accountSaga\r\n","import { call, put, takeEvery, takeLatest } from \"redux-saga/effects\";\r\n\r\n// Login Redux States\r\nimport { LOGIN_USER, LOGOUT_USER, SOCIAL_LOGIN } from \"./actionTypes\";\r\nimport { apiError, loginSuccess, logoutUserSuccess } from \"./actions\";\r\n\r\n//Include Both Helper File with needed methods\r\nimport { getFirebaseBackend } from \"../../../helpers/firebase_helper\";\r\nimport {\r\n postFakeLogin,\r\n postJwtLogin,\r\n postSocialLogin,\r\n} from \"../../../helpers/fakebackend_helper\";\r\n\r\nconst fireBaseBackend = getFirebaseBackend();\r\n\r\nfunction* loginUser({ payload: { user, history } }) {\r\n try {\r\n debugger;\r\n if (process.env.REACT_APP_DEFAULTAUTH === \"firebase\") {\r\n const response = yield call(\r\n fireBaseBackend.loginUser,\r\n user.email,\r\n user.password\r\n );\r\n yield put(loginSuccess(response));\r\n } else if (process.env.REACT_APP_DEFAULTAUTH === \"jwt\") {\r\n const response = yield call(postJwtLogin, {\r\n guid: \"57179a1b-5f7b-48ed-82d3-1f77e591fe5d\",\r\n mobileNo: \"2222222222\",\r\n email: \"\",\r\n otp:\"1234\"\r\n });\r\n localStorage.setItem(\"authUser\", JSON.stringify(response));\r\n yield put(loginSuccess(response));\r\n } else if (process.env.REACT_APP_DEFAULTAUTH === \"fake\") {\r\n const response = yield call(postFakeLogin, {\r\n email: user.email,\r\n password: user.password,\r\n });\r\n localStorage.setItem(\"authUser\", JSON.stringify(response));\r\n yield put(loginSuccess(response));\r\n }\r\n history.push(\"/dashboard\");\r\n } catch (error) {\r\n yield put(apiError(error));\r\n }\r\n}\r\n\r\nfunction* logoutUser({ payload: { history } }) {\r\n try {\r\n localStorage.removeItem(\"authUser\");\r\n\r\n if (process.env.REACT_APP_DEFAULTAUTH === \"firebase\") {\r\n const response = yield call(fireBaseBackend.logout);\r\n yield put(logoutUserSuccess(response));\r\n }\r\n history.push(\"/login\");\r\n } catch (error) {\r\n yield put(apiError(error));\r\n }\r\n}\r\n\r\nfunction* socialLogin({ payload: { data, history, type } }) {\r\n try {\r\n if (process.env.REACT_APP_DEFAULTAUTH === \"firebase\") {\r\n const fireBaseBackend = getFirebaseBackend();\r\n const response = yield call(\r\n fireBaseBackend.socialLoginUser,\r\n data,\r\n type,\r\n );\r\n localStorage.setItem(\"authUser\", JSON.stringify(response));\r\n yield put(loginSuccess(response));\r\n } else {\r\n const response = yield call(postSocialLogin, data);\r\n localStorage.setItem(\"authUser\", JSON.stringify(response));\r\n yield put(loginSuccess(response));\r\n }\r\n history.push(\"/dashboard\");\r\n } catch (error) {\r\n yield put(apiError(error));\r\n }\r\n}\r\n\r\nfunction* authSaga() {\r\n yield takeEvery(LOGIN_USER, loginUser);\r\n yield takeLatest(SOCIAL_LOGIN, socialLogin);\r\n yield takeEvery(LOGOUT_USER, logoutUser);\r\n}\r\n\r\nexport default authSaga;\r\n","import { takeEvery, fork, put, all, call } from \"redux-saga/effects\"\r\n\r\n// Login Redux States\r\nimport { FORGET_PASSWORD } from \"./actionTypes\"\r\nimport { userForgetPasswordSuccess, userForgetPasswordError } from \"./actions\"\r\n\r\n//Include Both Helper File with needed methods\r\nimport { getFirebaseBackend } from \"../../../helpers/firebase_helper\"\r\nimport {\r\n postFakeForgetPwd,\r\n postJwtForgetPwd,\r\n} from \"../../../helpers/fakebackend_helper\"\r\n\r\nconst fireBaseBackend = getFirebaseBackend()\r\n\r\n//If user is send successfully send mail link then dispatch redux action's are directly from here.\r\nfunction* forgetUser({ payload: { user, history } }) {\r\n try {\r\n if (process.env.REACT_APP_DEFAULTAUTH === \"firebase\") {\r\n const response = yield call(fireBaseBackend.forgetPassword, user.email)\r\n if (response) {\r\n yield put(\r\n userForgetPasswordSuccess(\r\n \"Reset link are sended to your mailbox, check there first\"\r\n )\r\n )\r\n }\r\n } else if (process.env.REACT_APP_DEFAULTAUTH === \"jwt\") {\r\n const response = yield call(postJwtForgetPwd, \"/jwt-forget-pwd\", {\r\n email: user.email,\r\n })\r\n if (response) {\r\n yield put(\r\n userForgetPasswordSuccess(\r\n \"Reset link are sended to your mailbox, check there first\"\r\n )\r\n )\r\n }\r\n } else {\r\n const response = yield call(postFakeForgetPwd, \"/fake-forget-pwd\", {\r\n email: user.email,\r\n })\r\n if (response) {\r\n yield put(\r\n userForgetPasswordSuccess(\r\n \"Reset link are sended to your mailbox, check there first\"\r\n )\r\n )\r\n }\r\n }\r\n } catch (error) {\r\n yield put(userForgetPasswordError(error))\r\n }\r\n}\r\n\r\nexport function* watchUserPasswordForget() {\r\n yield takeEvery(FORGET_PASSWORD, forgetUser)\r\n}\r\n\r\nfunction* forgetPasswordSaga() {\r\n yield all([fork(watchUserPasswordForget)])\r\n}\r\n\r\nexport default forgetPasswordSaga\r\n","import { takeEvery, fork, put, all, call } from \"redux-saga/effects\"\r\n\r\n// Login Redux States\r\nimport { EDIT_PROFILE } from \"./actionTypes\"\r\nimport { profileSuccess, profileError } from \"./actions\"\r\n\r\n//Include Both Helper File with needed methods\r\nimport { getFirebaseBackend } from \"../../../helpers/firebase_helper\"\r\nimport {\r\n postFakeProfile,\r\n postJwtProfile,\r\n} from \"../../../helpers/fakebackend_helper\"\r\n\r\nconst fireBaseBackend = getFirebaseBackend()\r\n\r\nfunction* editProfile({ payload: { user } }) {\r\n try {\r\n if (process.env.REACT_APP_DEFAULTAUTH === \"firebase\") {\r\n const response = yield call(\r\n fireBaseBackend.editProfileAPI,\r\n user.username,\r\n user.idx\r\n )\r\n yield put(profileSuccess(response))\r\n } else if (process.env.REACT_APP_DEFAULTAUTH === \"jwt\") {\r\n const response = yield call(postJwtProfile, \"/post-jwt-profile\", {\r\n username: user.username,\r\n idx: user.idx,\r\n })\r\n yield put(profileSuccess(response))\r\n } else if (process.env.REACT_APP_DEFAULTAUTH === \"fake\") {\r\n const response = yield call(postFakeProfile, {\r\n username: user.username,\r\n idx: user.idx,\r\n })\r\n yield put(profileSuccess(response))\r\n }\r\n } catch (error) {\r\n yield put(profileError(error))\r\n }\r\n}\r\nexport function* watchProfile() {\r\n yield takeEvery(EDIT_PROFILE, editProfile)\r\n}\r\n\r\nfunction* ProfileSaga() {\r\n yield all([fork(watchProfile)])\r\n}\r\n\r\nexport default ProfileSaga\r\n","// @flow\r\nimport { all, call, fork, takeEvery, put } from \"redux-saga/effects\"\r\n\r\nimport {\r\n CHANGE_LAYOUT,\r\n CHANGE_LAYOUT_WIDTH,\r\n CHANGE_SIDEBAR_THEME,\r\n CHANGE_SIDEBAR_THEME_IMAGE,\r\n CHANGE_SIDEBAR_TYPE,\r\n CHANGE_TOPBAR_THEME,\r\n SHOW_RIGHT_SIDEBAR,\r\n} from \"./actionTypes\"\r\n\r\nimport {\r\n changeSidebarType as changeSidebarTypeAction,\r\n changeTopbarTheme as changeTopbarThemeAction,\r\n} from \"./actions\"\r\n\r\n/**\r\n * Changes the body attribute\r\n */\r\nfunction changeBodyAttribute(attribute, value) {\r\n if (document.body) document.body.setAttribute(attribute, value)\r\n return true\r\n}\r\n\r\n/**\r\n * Toggle the class on body\r\n * @param {*} cssClass\r\n */\r\nfunction manageBodyClass(cssClass, action = \"toggle\") {\r\n switch (action) {\r\n case \"add\":\r\n if (document.body) document.body.classList.add(cssClass)\r\n break\r\n case \"remove\":\r\n if (document.body) document.body.classList.remove(cssClass)\r\n break\r\n default:\r\n if (document.body) document.body.classList.toggle(cssClass)\r\n break\r\n }\r\n\r\n return true\r\n}\r\n\r\n/**\r\n * Changes the layout type\r\n * @param {*} param0\r\n */\r\nfunction* changeLayout({ payload: layout }) {\r\n try {\r\n if (layout === \"horizontal\") {\r\n yield put(changeTopbarThemeAction(\"dark\"))\r\n document.body.removeAttribute(\"data-sidebar\")\r\n document.body.removeAttribute(\"data-sidebar-image\")\r\n document.body.removeAttribute(\"data-sidebar-size\")\r\n } else {\r\n yield put(changeTopbarThemeAction(\"light\"))\r\n }\r\n yield call(changeBodyAttribute, \"data-layout\", layout)\r\n } catch (error) {}\r\n}\r\n\r\n/**\r\n * Changes the layout width\r\n * @param {*} param0\r\n */\r\nfunction* changeLayoutWidth({ payload: width }) {\r\n try {\r\n if (width === \"boxed\") {\r\n yield put(changeSidebarTypeAction(\"icon\"))\r\n yield call(changeBodyAttribute, \"data-layout-size\", width)\r\n yield call(changeBodyAttribute, \"data-layout-scrollable\", false)\r\n } else if (width === \"scrollable\") {\r\n yield put(changeSidebarTypeAction(\"default\"))\r\n yield call(changeBodyAttribute, \"data-layout-scrollable\", true)\r\n } else {\r\n yield put(changeSidebarTypeAction(\"default\"))\r\n yield call(changeBodyAttribute, \"data-layout-size\", width)\r\n yield call(changeBodyAttribute, \"data-layout-scrollable\", false)\r\n }\r\n } catch (error) {}\r\n}\r\n\r\n/**\r\n * Changes the left sidebar theme\r\n * @param {*} param0\r\n */\r\nfunction* changeLeftSidebarTheme({ payload: theme }) {\r\n try {\r\n yield call(changeBodyAttribute, \"data-sidebar\", theme)\r\n } catch (error) {}\r\n}\r\n\r\n/**\r\n * Changes the left sidebar theme Image\r\n * @param {*} param0\r\n */\r\n function* changeLeftSidebarThemeImage({ payload: theme }) {\r\n try {\r\n yield call(changeBodyAttribute, \"data-sidebar-image\", theme)\r\n } catch (error) {}\r\n}\r\n\r\n/**\r\n * Changes the topbar theme\r\n * @param {*} param0\r\n */\r\nfunction* changeTopbarTheme({ payload: theme }) {\r\n try {\r\n yield call(changeBodyAttribute, \"data-topbar\", theme)\r\n } catch (error) {}\r\n}\r\n\r\n/**\r\n * Changes the left sidebar type\r\n * @param {*} param0\r\n */\r\nfunction* changeLeftSidebarType({ payload: { sidebarType, isMobile } }) {\r\n try {\r\n switch (sidebarType) {\r\n case \"compact\":\r\n yield call(changeBodyAttribute, \"data-sidebar-size\", \"small\")\r\n yield call(manageBodyClass, \"sidebar-enable\", \"remove\")\r\n yield call(manageBodyClass, \"vertical-collpsed\", \"remove\")\r\n break\r\n case \"icon\":\r\n yield call(changeBodyAttribute, \"data-sidebar-size\", \"\")\r\n yield call(changeBodyAttribute, \"data-keep-enlarged\", \"true\")\r\n yield call(manageBodyClass, \"vertical-collpsed\", \"add\")\r\n break\r\n case \"condensed\":\r\n yield call(manageBodyClass, \"sidebar-enable\", \"add\")\r\n if (window.screen.width >= 992) {\r\n yield call(manageBodyClass, \"vertical-collpsed\", \"remove\")\r\n yield call(manageBodyClass, \"sidebar-enable\", \"remove\")\r\n yield call(manageBodyClass, \"vertical-collpsed\", \"add\")\r\n yield call(manageBodyClass, \"sidebar-enable\", \"add\")\r\n } else {\r\n yield call(manageBodyClass, \"sidebar-enable\", \"add\")\r\n yield call(manageBodyClass, \"vertical-collpsed\", \"add\")\r\n }\r\n break\r\n default:\r\n yield call(changeBodyAttribute, \"data-sidebar-size\", \"\")\r\n yield call(manageBodyClass, \"sidebar-enable\", \"remove\")\r\n if (!isMobile)\r\n yield call(manageBodyClass, \"vertical-collpsed\", \"remove\")\r\n break\r\n }\r\n } catch (error) {}\r\n}\r\n\r\n/**\r\n * Show the rightsidebar\r\n */\r\nfunction* showRightSidebar() {\r\n try {\r\n yield call(manageBodyClass, \"right-bar-enabled\", \"add\")\r\n } catch (error) {}\r\n}\r\n\r\n/**\r\n * Watchers\r\n */\r\nexport function* watchChangeLayoutType() {\r\n yield takeEvery(CHANGE_LAYOUT, changeLayout)\r\n}\r\n\r\nexport function* watchChangeLayoutWidth() {\r\n yield takeEvery(CHANGE_LAYOUT_WIDTH, changeLayoutWidth)\r\n}\r\n\r\nexport function* watchChangeLeftSidebarTheme() {\r\n yield takeEvery(CHANGE_SIDEBAR_THEME, changeLeftSidebarTheme)\r\n}\r\n\r\nexport function* watchChangeLeftSidebarThemeImage() {\r\n yield takeEvery(CHANGE_SIDEBAR_THEME_IMAGE, changeLeftSidebarThemeImage)\r\n}\r\n\r\nexport function* watchChangeLeftSidebarType() {\r\n yield takeEvery(CHANGE_SIDEBAR_TYPE, changeLeftSidebarType)\r\n}\r\n\r\nexport function* watchChangeTopbarTheme() {\r\n yield takeEvery(CHANGE_TOPBAR_THEME, changeTopbarTheme)\r\n}\r\n\r\nexport function* watchShowRightSidebar() {\r\n yield takeEvery(SHOW_RIGHT_SIDEBAR, showRightSidebar)\r\n}\r\n\r\nfunction* LayoutSaga() {\r\n yield all([\r\n fork(watchChangeLayoutType),\r\n fork(watchChangeLayoutWidth),\r\n fork(watchChangeLeftSidebarTheme),\r\n fork(watchChangeLeftSidebarThemeImage),\r\n fork(watchChangeLeftSidebarType),\r\n fork(watchShowRightSidebar),\r\n fork(watchChangeTopbarTheme),\r\n ])\r\n}\r\n\r\nexport default LayoutSaga\r\n","import { call, put, takeEvery } from \"redux-saga/effects\";\r\n\r\n// Ecommerce Redux States\r\nimport {\r\n GET_CART_DATA,\r\n GET_CUSTOMERS,\r\n GET_ORDERS,\r\n GET_PRODUCT_DETAIL,\r\n GET_PRODUCTS,\r\n GET_SHOPS,\r\n ADD_NEW_ORDER,\r\n DELETE_ORDER,\r\n UPDATE_ORDER,\r\n ADD_NEW_CUSTOMER,\r\n DELETE_CUSTOMER,\r\n UPDATE_CUSTOMER,\r\n GET_PRODUCT_COMMENTS,\r\n ON_LIKE_COMMENT,\r\n ON_LIKE_REPLY,\r\n ON_ADD_REPLY,\r\n ON_ADD_COMMENT,\r\n} from \"./actionTypes\";\r\nimport {\r\n getCartDataFail,\r\n getCartDataSuccess,\r\n getCustomersFail,\r\n getCustomersSuccess,\r\n getOrdersFail,\r\n getOrdersSuccess,\r\n getProductDetailFail,\r\n getProductDetailSuccess,\r\n getProductsFail,\r\n getProductsSuccess,\r\n getShopsFail,\r\n getShopsSuccess,\r\n addOrderFail,\r\n addOrderSuccess,\r\n updateOrderSuccess,\r\n updateOrderFail,\r\n deleteOrderSuccess,\r\n deleteOrderFail,\r\n addCustomerFail,\r\n addCustomerSuccess,\r\n updateCustomerSuccess,\r\n updateCustomerFail,\r\n deleteCustomerSuccess,\r\n deleteCustomerFail,\r\n getProductCommentsSuccess,\r\n getProductCommentsFail,\r\n onLikeCommentSuccess,\r\n onLikeCommentFail,\r\n onLikeReplySuccess,\r\n onLikeReplyFail,\r\n onAddReplySuccess,\r\n onAddReplyFail,\r\n onAddCommentSuccess,\r\n onAddCommentFail,\r\n} from \"./actions\";\r\n\r\n//Include Both Helper File with needed methods\r\nimport {\r\n getCartData,\r\n getCustomers,\r\n getOrders,\r\n getProducts,\r\n getShops,\r\n getProductDetail,\r\n addNewOrder,\r\n updateOrder,\r\n deleteOrder,\r\n addNewCustomer,\r\n updateCustomer,\r\n deleteCustomer,\r\n getProductComents as getProductComentsApi,\r\n onLikeComment as onLikeCommentApi,\r\n onLikeReply as onLikeReplyApi,\r\n onAddReply as onAddReplyApi,\r\n onAddComment as onAddCommentApi,\r\n} from \"helpers/fakebackend_helper\";\r\n\r\nfunction* fetchProducts() {\r\n try {\r\n const response = yield call(getProducts);\r\n yield put(getProductsSuccess(response));\r\n } catch (error) {\r\n yield put(getProductsFail(error));\r\n }\r\n}\r\n\r\nfunction* fetchProductDetail({ productId }) {\r\n try {\r\n const response = yield call(getProductDetail, productId);\r\n yield put(getProductDetailSuccess(response));\r\n } catch (error) {\r\n yield put(getProductDetailFail(error));\r\n }\r\n}\r\n\r\nfunction* fetchOrders() {\r\n try {\r\n const response = yield call(getOrders);\r\n yield put(getOrdersSuccess(response));\r\n } catch (error) {\r\n yield put(getOrdersFail(error));\r\n }\r\n}\r\n\r\nfunction* fetchCartData() {\r\n try {\r\n const response = yield call(getCartData);\r\n yield put(getCartDataSuccess(response));\r\n } catch (error) {\r\n yield put(getCartDataFail(error));\r\n }\r\n}\r\n\r\nfunction* fetchCustomers() {\r\n try {\r\n const response = yield call(getCustomers);\r\n yield put(getCustomersSuccess(response));\r\n } catch (error) {\r\n yield put(getCustomersFail(error));\r\n }\r\n}\r\n\r\nfunction* onUpdateCustomer({ payload: customer }) {\r\n try {\r\n const response = yield call(updateCustomer, customer);\r\n yield put(updateCustomerSuccess(response));\r\n } catch (error) {\r\n yield put(updateCustomerFail(error));\r\n }\r\n}\r\n\r\nfunction* onDeleteCustomer({ payload: customer }) {\r\n try {\r\n const response = yield call(deleteCustomer, customer);\r\n yield put(deleteCustomerSuccess(response));\r\n } catch (error) {\r\n yield put(deleteCustomerFail(error));\r\n }\r\n}\r\n\r\nfunction* onAddNewCustomer({ payload: customer }) {\r\n try {\r\n const response = yield call(addNewCustomer, customer);\r\n\r\n yield put(addCustomerSuccess(response));\r\n } catch (error) {\r\n yield put(addCustomerFail(error));\r\n }\r\n}\r\n\r\nfunction* fetchShops() {\r\n try {\r\n const response = yield call(getShops);\r\n yield put(getShopsSuccess(response));\r\n } catch (error) {\r\n yield put(getShopsFail(error));\r\n }\r\n}\r\n\r\nfunction* onUpdateOrder({ payload: order }) {\r\n try {\r\n const response = yield call(updateOrder, order);\r\n yield put(updateOrderSuccess(response));\r\n } catch (error) {\r\n yield put(updateOrderFail(error));\r\n }\r\n}\r\n\r\nfunction* onDeleteOrder({ payload: order }) {\r\n try {\r\n const response = yield call(deleteOrder, order);\r\n console.log(\"response\",response)\r\n yield put(deleteOrderSuccess(response));\r\n } catch (error) {\r\n console.log(\"error\",error)\r\n yield put(deleteOrderFail(error));\r\n }\r\n}\r\n\r\nfunction* onAddNewOrder({ payload: order }) {\r\n try {\r\n const response = yield call(addNewOrder, order);\r\n yield put(addOrderSuccess(response));\r\n } catch (error) {\r\n yield put(addOrderFail(error));\r\n }\r\n}\r\n\r\nfunction* getProductComents() {\r\n try {\r\n // todo - add product Id to the payload and api\r\n const response = yield call(getProductComentsApi);\r\n yield put(getProductCommentsSuccess(response));\r\n } catch (error) {\r\n yield put(getProductCommentsFail(error));\r\n }\r\n}\r\n\r\nfunction* onLikeComment({ payload: { commentId, productId } }) {\r\n try {\r\n // todo - add product Id to the payload and api\r\n const response = yield call(onLikeCommentApi, commentId, productId);\r\n yield put(onLikeCommentSuccess(response));\r\n } catch (error) {\r\n yield put(onLikeCommentFail(error));\r\n }\r\n}\r\n\r\nfunction* onLikeReply({ payload: { commentId, productId, replyId } }) {\r\n try {\r\n // todo - add product Id to the payload and api\r\n const response = yield call(onLikeReplyApi, commentId, productId, replyId);\r\n yield put(onLikeReplySuccess(response));\r\n } catch (error) {\r\n yield put(onLikeReplyFail(error));\r\n }\r\n}\r\n\r\nfunction* onAddReply({ payload: { commentId, productId, replyText } }) {\r\n try {\r\n const response = yield call(onAddReplyApi, commentId, productId, replyText);\r\n yield put(onAddReplySuccess(response));\r\n } catch (error) {\r\n yield put(onAddReplyFail(error));\r\n }\r\n}\r\n\r\nfunction* onAddComment({ payload: { productId, commentText } }) {\r\n try {\r\n const response = yield call(onAddCommentApi, productId, commentText);\r\n yield put(onAddCommentSuccess(response));\r\n } catch (error) {\r\n yield put(onAddCommentFail(error));\r\n }\r\n}\r\n\r\nfunction* ecommerceSaga() {\r\n yield takeEvery(GET_PRODUCTS, fetchProducts);\r\n yield takeEvery(GET_PRODUCT_DETAIL, fetchProductDetail);\r\n yield takeEvery(GET_ORDERS, fetchOrders);\r\n yield takeEvery(GET_CART_DATA, fetchCartData);\r\n yield takeEvery(GET_CUSTOMERS, fetchCustomers);\r\n yield takeEvery(ADD_NEW_CUSTOMER, onAddNewCustomer);\r\n yield takeEvery(UPDATE_CUSTOMER, onUpdateCustomer);\r\n yield takeEvery(DELETE_CUSTOMER, onDeleteCustomer);\r\n yield takeEvery(GET_SHOPS, fetchShops);\r\n yield takeEvery(ADD_NEW_ORDER, onAddNewOrder);\r\n yield takeEvery(UPDATE_ORDER, onUpdateOrder);\r\n yield takeEvery(DELETE_ORDER, onDeleteOrder);\r\n yield takeEvery(GET_PRODUCT_COMMENTS, getProductComents);\r\n yield takeEvery(ON_LIKE_COMMENT, onLikeComment);\r\n yield takeEvery(ON_LIKE_REPLY, onLikeReply);\r\n yield takeEvery(ON_ADD_REPLY, onAddReply);\r\n yield takeEvery(ON_ADD_COMMENT, onAddComment);\r\n}\r\n\r\nexport default ecommerceSaga;\r\n","import { takeEvery, put, call } from \"redux-saga/effects\"\r\n\r\n// Calender Redux States\r\nimport {\r\n ADD_NEW_EVENT,\r\n DELETE_EVENT,\r\n GET_CATEGORIES,\r\n GET_EVENTS,\r\n UPDATE_EVENT,\r\n} from \"./actionTypes\"\r\nimport {\r\n getEventsSuccess,\r\n getEventsFail,\r\n addEventFail,\r\n addEventSuccess,\r\n updateEventSuccess,\r\n updateEventFail,\r\n deleteEventSuccess,\r\n deleteEventFail,\r\n getCategoriesSuccess,\r\n getCategoriesFail,\r\n} from \"./actions\"\r\n\r\n//Include Both Helper File with needed methods\r\nimport {\r\n getEvents,\r\n addNewEvent,\r\n updateEvent,\r\n deleteEvent,\r\n getCategories,\r\n} from \"../../helpers/fakebackend_helper\"\r\n\r\nfunction* fetchEvents() {\r\n try {\r\n const response = yield call(getEvents)\r\n yield put(getEventsSuccess(response))\r\n } catch (error) {\r\n yield put(getEventsFail(error))\r\n }\r\n}\r\n\r\nfunction* onAddNewEvent({ payload: event }) {\r\n try {\r\n const response = yield call(addNewEvent, event)\r\n yield put(addEventSuccess(response))\r\n } catch (error) {\r\n yield put(addEventFail(error))\r\n }\r\n}\r\n\r\nfunction* onUpdateEvent({ payload: event }) {\r\n try {\r\n const response = yield call(updateEvent, event)\r\n yield put(updateEventSuccess(response))\r\n } catch (error) {\r\n yield put(updateEventFail(error))\r\n }\r\n}\r\n\r\nfunction* onDeleteEvent({ payload: event }) {\r\n try {\r\n const response = yield call(deleteEvent, event)\r\n yield put(deleteEventSuccess(response))\r\n } catch (error) {\r\n yield put(deleteEventFail(error))\r\n }\r\n}\r\n\r\nfunction* onGetCategories() {\r\n try {\r\n const response = yield call(getCategories)\r\n yield put(getCategoriesSuccess(response))\r\n } catch (error) {\r\n yield put(getCategoriesFail(error))\r\n }\r\n}\r\n\r\nfunction* calendarSaga() {\r\n yield takeEvery(GET_EVENTS, fetchEvents)\r\n yield takeEvery(ADD_NEW_EVENT, onAddNewEvent)\r\n yield takeEvery(UPDATE_EVENT, onUpdateEvent)\r\n yield takeEvery(DELETE_EVENT, onDeleteEvent)\r\n yield takeEvery(GET_CATEGORIES, onGetCategories)\r\n}\r\n\r\nexport default calendarSaga\r\n","import { takeEvery, put, call } from \"redux-saga/effects\";\r\n\r\n// Chat Redux States\r\nimport {\r\n GET_CHATS,\r\n GET_CONTACTS,\r\n GET_GROUPS,\r\n GET_MESSAGES,\r\n POST_ADD_MESSAGE,\r\n} from \"./actionTypes\";\r\nimport {\r\n getChatsSuccess,\r\n getChatsFail,\r\n getGroupsSuccess,\r\n getGroupsFail,\r\n getContactsSuccess,\r\n getContactsFail,\r\n getMessagesSuccess,\r\n getMessagesFail,\r\n addMessageSuccess,\r\n addMessageFail,\r\n} from \"./actions\";\r\n\r\n//Include Both Helper File with needed methods\r\nimport {\r\n getChats,\r\n getGroups,\r\n getContacts,\r\n getMessages,\r\n addMessage,\r\n} from \"../../helpers/fakebackend_helper\";\r\n\r\nfunction* onGetChats() {\r\n try {\r\n const response = yield call(getChats);\r\n yield put(getChatsSuccess(response));\r\n } catch (error) {\r\n yield put(getChatsFail(error));\r\n }\r\n}\r\n\r\nfunction* onGetGroups() {\r\n try {\r\n const response = yield call(getGroups);\r\n yield put(getGroupsSuccess(response));\r\n } catch (error) {\r\n yield put(getGroupsFail(error));\r\n }\r\n}\r\n\r\nfunction* onGetContacts() {\r\n try {\r\n const response = yield call(getContacts);\r\n yield put(getContactsSuccess(response));\r\n } catch (error) {\r\n yield put(getContactsFail(error));\r\n }\r\n}\r\n\r\nfunction* onGetMessages({ roomId }) {\r\n try {\r\n const response = yield call(getMessages, roomId);\r\n yield put(getMessagesSuccess(response));\r\n } catch (error) {\r\n yield put(getMessagesFail(error));\r\n }\r\n}\r\n\r\nfunction* onAddMessage({ message }) {\r\n try {\r\n const response = yield call(addMessage, message);\r\n yield put(addMessageSuccess(response));\r\n } catch (error) {\r\n yield put(addMessageFail(error));\r\n }\r\n}\r\n\r\nfunction* chatSaga() {\r\n yield takeEvery(GET_CHATS, onGetChats);\r\n yield takeEvery(GET_GROUPS, onGetGroups);\r\n yield takeEvery(GET_CONTACTS, onGetContacts);\r\n yield takeEvery(GET_MESSAGES, onGetMessages);\r\n yield takeEvery(POST_ADD_MESSAGE, onAddMessage);\r\n}\r\n\r\nexport default chatSaga;\r\n","import { call, put, takeEvery } from \"redux-saga/effects\"\r\n\r\n// Crypto Redux States\r\nimport { GET_WALLET, GET_CRYPTO_ORDERS } from \"./actionTypes\"\r\nimport {\r\n getWalletSuccess,\r\n getWalletFail,\r\n getCryptoOrdersSuccess,\r\n getCryptoOrdersFail,\r\n} from \"./actions\"\r\n\r\n//Include Both Helper File with needed methods\r\nimport { getWallet, getCryptoOrder } from \"helpers/fakebackend_helper\"\r\n\r\nfunction* fetchWallet() {\r\n try {\r\n const response = yield call(getWallet)\r\n yield put(getWalletSuccess(response))\r\n } catch (error) {\r\n yield put(getWalletFail(error))\r\n }\r\n}\r\n\r\nfunction* fetchCrypto() {\r\n try {\r\n const response = yield call(getCryptoOrder)\r\n yield put(getCryptoOrdersSuccess(response))\r\n } catch (error) {\r\n yield put(getCryptoOrdersFail(error))\r\n }\r\n}\r\n\r\nfunction* cryptoSaga() {\r\n yield takeEvery(GET_WALLET, fetchWallet)\r\n yield takeEvery(GET_CRYPTO_ORDERS, fetchCrypto)\r\n}\r\n\r\nexport default cryptoSaga\r\n","import { call, put, takeEvery } from \"redux-saga/effects\"\r\n\r\n// Crypto Redux States\r\nimport { GET_INVOICES, GET_INVOICE_DETAIL } from \"./actionTypes\"\r\nimport {\r\n getInvoicesSuccess,\r\n getInvoicesFail,\r\n getInvoiceDetailSuccess,\r\n getInvoiceDetailFail,\r\n} from \"./actions\"\r\n\r\n//Include Both Helper File with needed methods\r\nimport { getInvoices, getInvoiceDetail } from \"helpers/fakebackend_helper\"\r\n\r\nfunction* fetchInvoices() {\r\n try {\r\n const response = yield call(getInvoices)\r\n yield put(getInvoicesSuccess(response))\r\n } catch (error) {\r\n yield put(getInvoicesFail(error))\r\n }\r\n}\r\n\r\nfunction* fetchInvoiceDetail({ invoiceId }) {\r\n try {\r\n const response = yield call(getInvoiceDetail, invoiceId)\r\n yield put(getInvoiceDetailSuccess(response))\r\n } catch (error) {\r\n yield put(getInvoiceDetailFail(error))\r\n }\r\n}\r\n\r\nfunction* invoiceSaga() {\r\n yield takeEvery(GET_INVOICES, fetchInvoices)\r\n yield takeEvery(GET_INVOICE_DETAIL, fetchInvoiceDetail)\r\n}\r\n\r\nexport default invoiceSaga\r\n","import { call, put, takeEvery } from \"redux-saga/effects\"\r\n\r\n// Crypto Redux States\r\nimport { GET_PROJECTS, GET_PROJECT_DETAIL, ADD_NEW_PROJECT, DELETE_PROJECT, UPDATE_PROJECT } from \"./actionTypes\"\r\nimport {\r\n getProjectsSuccess,\r\n getProjectsFail,\r\n getProjectDetailSuccess,\r\n getProjectDetailFail,\r\n addProjectFail,\r\n addProjectSuccess,\r\n updateProjectSuccess,\r\n updateProjectFail,\r\n deleteProjectSuccess,\r\n deleteProjectFail,\r\n} from \"./actions\"\r\n\r\n//Include Both Helper File with needed methods\r\nimport { getProjects, getProjectsDetails, addNewProject, updateProject, deleteProject } from \"helpers/fakebackend_helper\"\r\n\r\nfunction* fetchProjects() {\r\n try {\r\n const response = yield call(getProjects)\r\n yield put(getProjectsSuccess(response))\r\n } catch (error) {\r\n yield put(getProjectsFail(error))\r\n }\r\n}\r\n\r\nfunction* fetchProjectDetail({ projectId }) {\r\n try {\r\n const response = yield call(getProjectsDetails, projectId)\r\n yield put(getProjectDetailSuccess(response))\r\n } catch (error) {\r\n yield put(getProjectDetailFail(error))\r\n }\r\n}\r\n\r\nfunction* onUpdateProject({ payload: project }) {\r\n try {\r\n const response = yield call(updateProject, project)\r\n yield put(updateProjectSuccess(response))\r\n } catch (error) {\r\n yield put(updateProjectFail(error))\r\n }\r\n}\r\n\r\nfunction* onDeleteProject({ payload: project }) {\r\n try {\r\n const response = yield call(deleteProject, project)\r\n yield put(deleteProjectSuccess(response))\r\n } catch (error) {\r\n yield put(deleteProjectFail(error))\r\n }\r\n}\r\n\r\nfunction* onAddNewProject({ payload: project }) {\r\n try {\r\n const response = yield call(addNewProject, project)\r\n yield put(addProjectSuccess(response))\r\n } catch (error) {\r\n\r\n yield put(addProjectFail(error))\r\n }\r\n}\r\n\r\nfunction* projectsSaga() {\r\n yield takeEvery(GET_PROJECTS, fetchProjects)\r\n yield takeEvery(GET_PROJECT_DETAIL, fetchProjectDetail)\r\n yield takeEvery(ADD_NEW_PROJECT, onAddNewProject)\r\n yield takeEvery(UPDATE_PROJECT, onUpdateProject)\r\n yield takeEvery(DELETE_PROJECT, onDeleteProject)\r\n}\r\n\r\nexport default projectsSaga\r\n","import { call, put, takeEvery } from \"redux-saga/effects\"\r\n\r\n// Crypto Redux States\r\nimport { GET_TASKS } from \"./actionTypes\"\r\nimport { getTasksSuccess, getTasksFail } from \"./actions\"\r\n\r\n//Include Both Helper File with needed methods\r\nimport { getTasks } from \"helpers/fakebackend_helper\"\r\n\r\nfunction* fetchTasks() {\r\n try {\r\n const response = yield call(getTasks)\r\n yield put(getTasksSuccess(response))\r\n } catch (error) {\r\n yield put(getTasksFail(error))\r\n }\r\n}\r\n\r\nfunction* tasksSaga() {\r\n yield takeEvery(GET_TASKS, fetchTasks)\r\n}\r\n\r\nexport default tasksSaga\r\n","import { call, put, takeEvery } from \"redux-saga/effects\"\r\n\r\n// Crypto Redux States\r\nimport {\r\n GET_INBOX_MAILS,\r\n ADD_NEW_INBOX_MAIL,\r\n DELETE_INBOX_MAIL,\r\n GET_STARRED_MAILS,\r\n GET_IMPORTANT_MAILS,\r\n GET_DRAFT_MAILS,\r\n GET_SENT_MAILS,\r\n GET_TRASH_MAILS,\r\n} from \"./actionTypes\"\r\n\r\nimport {\r\n getInboxMailsSuccess,\r\n getInboxMailsFail,\r\n addInboxMailFail,\r\n addInboxMailSuccess,\r\n deleteInboxMailSuccess,\r\n deleteInboxMailFail,\r\n getStarredMailsSuccess,\r\n getStarredMailsFail,\r\n getImportantMailsSuccess,\r\n getImportantMailsFail,\r\n getDraftMailsSuccess,\r\n getDraftMailsFail,\r\n getSentMailsSuccess,\r\n getSentMailsFail,\r\n getTrashMailsSuccess,\r\n getTrashMailsFail,\r\n} from \"./actions\"\r\n\r\n//Include Both Helper File with needed methods\r\nimport { \r\n getInboxMails,\r\n addNewInboxMail,\r\n deleteInboxMail,\r\n getStarredMails,\r\n getImportantMails,\r\n getDraftMails,\r\n getSentMails,\r\n getTrashMails,\r\n} from \"helpers/fakebackend_helper\"\r\n\r\n function* fetchInboxMails() {\r\n try {\r\n const response = yield call(getInboxMails)\r\n yield put(getInboxMailsSuccess(response))\r\n } catch (error) {\r\n yield put(getInboxMailsFail(error))\r\n }\r\n }\r\n\r\n function* fetchStarredMails() {\r\n try {\r\n const response = yield call(getStarredMails)\r\n yield put(getStarredMailsSuccess(response))\r\n } catch (error) {\r\n yield put(getStarredMailsFail(error))\r\n }\r\n }\r\n\r\n function* fetchImportantMails() {\r\n try {\r\n const response = yield call(getImportantMails)\r\n yield put(getImportantMailsSuccess(response))\r\n } catch (error) {\r\n yield put(getImportantMailsFail(error))\r\n }\r\n }\r\n\r\n function* fetchDraftMails() {\r\n try {\r\n const response = yield call(getDraftMails)\r\n yield put(getDraftMailsSuccess(response))\r\n } catch (error) {\r\n yield put(getDraftMailsFail(error))\r\n }\r\n }\r\n\r\n function* fetchSentMails() {\r\n try {\r\n const response = yield call(getSentMails)\r\n yield put(getSentMailsSuccess(response))\r\n } catch (error) {\r\n yield put(getSentMailsFail(error))\r\n }\r\n }\r\n\r\n function* fetchTrashMails() {\r\n try {\r\n const response = yield call(getTrashMails)\r\n yield put(getTrashMailsSuccess(response))\r\n } catch (error) {\r\n yield put(getTrashMailsFail(error))\r\n }\r\n }\r\n \r\n function* onAddNewInboxMail({ payload: inboxmail }) {\r\n try {\r\n const response = yield call(addNewInboxMail, inboxmail)\r\n yield put(addInboxMailSuccess(response))\r\n } catch (error) {\r\n \r\n yield put(addInboxMailFail(error))\r\n }\r\n }\r\n \r\n function* onDeleteInboxMail({ payload: inboxmail }) {\r\n try {\r\n const response = yield call(deleteInboxMail, inboxmail)\r\n yield put(deleteInboxMailSuccess(response))\r\n } catch (error) {\r\n yield put(deleteInboxMailFail(error))\r\n }\r\n }\r\n\r\n \r\n \r\n function* mailsSaga() {\r\n yield takeEvery(GET_INBOX_MAILS, fetchInboxMails)\r\n yield takeEvery(GET_STARRED_MAILS, fetchStarredMails)\r\n yield takeEvery(GET_IMPORTANT_MAILS, fetchImportantMails)\r\n yield takeEvery(GET_DRAFT_MAILS, fetchDraftMails)\r\n yield takeEvery(GET_SENT_MAILS, fetchSentMails)\r\n yield takeEvery(GET_TRASH_MAILS, fetchTrashMails)\r\n yield takeEvery(ADD_NEW_INBOX_MAIL, onAddNewInboxMail)\r\n yield takeEvery(DELETE_INBOX_MAIL, onDeleteInboxMail)\r\n }\r\n\r\nexport default mailsSaga","import { call, put, takeEvery } from \"redux-saga/effects\"\r\n\r\n// Crypto Redux States\r\nimport { GET_USERS, GET_USER_PROFILE , ADD_NEW_USER , DELETE_USER, UPDATE_USER } from \"./actionTypes\"\r\n\r\nimport {\r\n getUsersSuccess,\r\n getUsersFail,\r\n getUserProfileSuccess,\r\n getUserProfileFail,\r\n addUserFail,\r\n addUserSuccess,\r\n updateUserSuccess,\r\n updateUserFail,\r\n deleteUserSuccess,\r\n deleteUserFail,\r\n} from \"./actions\"\r\n\r\n//Include Both Helper File with needed methods\r\nimport { getUsers, getUserProfile , addNewUser, updateUser ,deleteUser } from \"../../helpers/fakebackend_helper\"\r\n\r\nfunction* fetchUsers() {\r\n try {\r\n const response = yield call(getUsers)\r\n yield put(getUsersSuccess(response))\r\n } catch (error) {\r\n yield put(getUsersFail(error))\r\n }\r\n}\r\n\r\nfunction* fetchUserProfile() {\r\n try {\r\n const response = yield call(getUserProfile)\r\n yield put(getUserProfileSuccess(response))\r\n } catch (error) {\r\n yield put(getUserProfileFail(error))\r\n }\r\n}\r\n\r\nfunction* onUpdateUser({ payload: user }) {\r\n try {\r\n const response = yield call(updateUser, user)\r\n yield put(updateUserSuccess(response))\r\n } catch (error) {\r\n yield put(updateUserFail(error))\r\n }\r\n}\r\n\r\nfunction* onDeleteUser({ payload: user }) {\r\n try {\r\n const response = yield call(deleteUser, user)\r\n yield put(deleteUserSuccess(response))\r\n } catch (error) {\r\n yield put(deleteUserFail(error))\r\n }\r\n}\r\n\r\nfunction* onAddNewUser({ payload: user }) {\r\n\r\n try {\r\n const response = yield call(addNewUser, user)\r\n\r\n yield put(addUserSuccess(response))\r\n } catch (error) {\r\n\r\n yield put(addUserFail(error))\r\n }\r\n}\r\n\r\nfunction* contactsSaga() {\r\n yield takeEvery(GET_USERS, fetchUsers)\r\n yield takeEvery(GET_USER_PROFILE, fetchUserProfile)\r\n yield takeEvery(ADD_NEW_USER, onAddNewUser)\r\n yield takeEvery(UPDATE_USER, onUpdateUser)\r\n yield takeEvery(DELETE_USER, onDeleteUser)\r\n}\r\n\r\nexport default contactsSaga;\r\n","import { call, put, takeEvery, all, fork } from \"redux-saga/effects\";\r\n\r\n// Crypto Redux States\r\nimport { GET_CHARTS_DATA } from \"./actionTypes\";\r\nimport { apiSuccess, apiFail } from \"./actions\";\r\n\r\n//Include Both Helper File with needed methods\r\nimport {\r\n getWeeklyData,\r\n getYearlyData,\r\n getMonthlyData\r\n}\r\n from \"../../helpers/fakebackend_helper\";\r\n\r\nfunction* getChartsData({ payload: periodType }) {\r\n try {\r\n var response;\r\n if (periodType == \"monthly\") {\r\n response = yield call(getWeeklyData, periodType);\r\n }\r\n if (periodType == \"yearly\") {\r\n response = yield call(getYearlyData, periodType);\r\n }\r\n if (periodType == \"weekly\") {\r\n response = yield call(getMonthlyData, periodType);\r\n }\r\n\r\n yield put(apiSuccess(GET_CHARTS_DATA, response));\r\n } catch (error) {\r\n yield put(apiFail(GET_CHARTS_DATA, error));\r\n }\r\n}\r\n\r\nexport function* watchGetChartsData() {\r\n yield takeEvery(GET_CHARTS_DATA, getChartsData);\r\n}\r\n\r\nfunction* dashboardSaga() {\r\n yield all([fork(watchGetChartsData)]);\r\n}\r\n\r\nexport default dashboardSaga;\r\n","import { call, put, takeEvery, all, fork } from \"redux-saga/effects\";\r\n\r\n// Crypto Redux States\r\nimport { GET_TOP_SELLING_PRODUCT, GET_EARNING_DATA } from \"./actionType\";\r\nimport { apiSuccess, apiFail } from \"./actions\";\r\n\r\n//Include Both Helper File with needed methods\r\nimport {\r\n topSellingData as topSellingDataApi,\r\n getEarningChartsData as getEarningChartsDataApi\r\n}\r\n from \"../../helpers/fakebackend_helper\";\r\n\r\nfunction* getSellingData({ payload: month }) {\r\n try {\r\n var response = yield call(topSellingDataApi, month);\r\n yield put(apiSuccess(GET_TOP_SELLING_PRODUCT, response));\r\n } catch (error) {\r\n yield put(apiFail(GET_TOP_SELLING_PRODUCT, error));\r\n }\r\n}\r\n\r\n\r\nfunction* getEarningChartsData({ payload: month }) {\r\n try {\r\n var response = yield call(getEarningChartsDataApi, month);\r\n yield put(apiSuccess(GET_EARNING_DATA, response));\r\n } catch (error) {\r\n yield put(apiFail(GET_EARNING_DATA, error));\r\n }\r\n}\r\n\r\nexport function* watchGetSellingdata() {\r\n yield takeEvery(GET_TOP_SELLING_PRODUCT, getSellingData);\r\n}\r\n\r\nexport function* watchGetEarningChartsData() {\r\n yield takeEvery(GET_EARNING_DATA, getEarningChartsData);\r\n}\r\n\r\n\r\nfunction* dashboardSaasSaga() {\r\n yield all([fork(watchGetSellingdata)],\r\n yield all([fork(watchGetEarningChartsData)])\r\n );\r\n}\r\n\r\nexport default dashboardSaasSaga;\r\n","import { takeEvery, put, call, all, fork } from \"redux-saga/effects\";\r\n\r\n// Registration Redux States\r\nimport {\r\n GET_STATE,\r\n GET_OCCUPATION,\r\n GET_RELATEDPERSONTYPE,\r\n GET_EDUCATION,\r\n GET_OCCUPATIONDETAILS,\r\n GET_ASSETDETAILS,\r\n GET_OTHERBANKACCOUNTS,\r\n GET_ACCOUNTTYPE,\r\n GET_ENTITYTYPE,\r\n GET_LOCATION,\r\n GET_BRANCH,\r\n GET_POI,\r\n} from \"./actionTypes\"\r\nimport {\r\n getStateSuccess,\r\n getStateFail,\r\n getOccupationSuccess,\r\n getOccupationFail,\r\n getRelatedPersonTypeSuccess,\r\n getRelatedPersonTypeFail,\r\n getEducationSuccess,\r\n getEducationFail,\r\n getOccupationDetailsSuccess,\r\n getOccupationDetailsFail,\r\n getAssetDetailsSuccess,\r\n getAssetDetailsFail,\r\n getOtherBankAccountsSuccess,\r\n getOtherBankAccountsFail,\r\n getAccountTypeSuccess,\r\n getAccountTypeFail,\r\n getEntityTypeSuccess,\r\n getEntityTypeFail,\r\n getLocationSuccess,\r\n getLocationFail,\r\n getBranchSuccess,\r\n getBranchFail,\r\n getPoiSuccess,\r\n getPoiFail\r\n} from \"./actions\"\r\n\r\nimport { getState } from \"../../helpers/fakebackend_helper\";\r\n\r\nimport { getOccupation } from \"../../helpers/fakebackend_helper\";\r\n\r\nimport { getRelatedPersonType } from \"../../helpers/fakebackend_helper\";\r\n\r\nimport { getEducation } from \"../../helpers/fakebackend_helper\";\r\n\r\nimport { getOccupationDetails } from \"../../helpers/fakebackend_helper\";\r\n\r\nimport { getAssetDetails } from \"../../helpers/fakebackend_helper\";\r\n\r\nimport { getOtherBankAccounts } from \"../../helpers/fakebackend_helper\";\r\n\r\nimport { getAccountType } from \"../../helpers/fakebackend_helper\";\r\n\r\nimport { getEntityType } from \"../../helpers/fakebackend_helper\";\r\n\r\nimport { getLocation } from \"../../helpers/fakebackend_helper\";\r\n\r\nimport { getBranch, LocationId } from \"../../helpers/fakebackend_helper\";\r\n\r\nimport { getPoi } from \"../../helpers/fakebackend_helper\";\r\n \r\n\r\n//GetAll State\r\nfunction* fetchStateData() {\r\n try {\r\n const response = yield call(getState)\r\n yield put(getStateSuccess(response))\r\n } catch (error) {\r\n yield put(getStateFail(error))\r\n }\r\n}\r\n\r\n//GetAll Occupation\r\nfunction* fetchOccupationData() {\r\n try {\r\n const response = yield call(getOccupation)\r\n yield put(getOccupationSuccess(response))\r\n } catch (error) {\r\n yield put(getOccupationFail(error))\r\n }\r\n}\r\n\r\n//GetAll Related_Person_Type\r\nfunction* fetchRelatedPersonTypeData() {\r\n try {\r\n const response = yield call(getRelatedPersonType)\r\n yield put(getRelatedPersonTypeSuccess(response))\r\n } catch (error) {\r\n yield put(getRelatedPersonTypeFail(error))\r\n }\r\n}\r\n\r\n//GetAll Education\r\nfunction* fetchEducationData() {\r\n try {\r\n const response = yield call(getEducation)\r\n yield put(getEducationSuccess(response))\r\n } catch (error) {\r\n yield put(getEducationFail(error))\r\n }\r\n}\r\n\r\n//GetAll OccupationDetails\r\nfunction* fetchOccupationDetailsData() {\r\n try {\r\n const response = yield call(getOccupationDetails)\r\n yield put(getOccupationDetailsSuccess(response))\r\n } catch (error) {\r\n yield put(getOccupationDetailsFail(error))\r\n }\r\n}\r\n\r\n//GetAll AssetDetails\r\nfunction* fetchAssetDetailsData() {\r\n try {\r\n const response = yield call(getAssetDetails)\r\n yield put(getAssetDetailsSuccess(response))\r\n } catch (error) {\r\n yield put(getAssetDetailsFail(error))\r\n }\r\n}\r\n\r\n //GetAll OtherBankAccounts\r\nfunction* fetchOtherBankAccountsData() {\r\n try {\r\n const response = yield call(getOtherBankAccounts)\r\n yield put(getOtherBankAccountsSuccess(response))\r\n } catch (error) {\r\n yield put(getOtherBankAccountsFail(error))\r\n }\r\n}\r\n\r\n//GetAll AccountType\r\nfunction* fetchAccountTypeData() {\r\n try {\r\n const response = yield call(getAccountType)\r\n yield put(getAccountTypeSuccess(response))\r\n } catch (error) {\r\n yield put(getAccountTypeFail(error))\r\n }\r\n}\r\n\r\n//GetAll EntityType\r\nfunction* fetchEntityTypeData() {\r\n try {\r\n const response = yield call(getEntityType)\r\n yield put(getEntityTypeSuccess(response))\r\n } catch (error) {\r\n yield put(getEntityTypeFail(error))\r\n }\r\n}\r\n\r\n//GetAll Location\r\nfunction* fetchLocationData() {\r\n try {\r\n const response = yield call(getLocation)\r\n yield put(getLocationSuccess(response))\r\n } catch (error) {\r\n yield put(getLocationFail(error))\r\n }\r\n}\r\n\r\n// GetByLocationId Branch\r\nfunction* onGetBranch({ LocationId }) {\r\n try {\r\n debugger;\r\n const response = yield call(getBranch, LocationId);\r\n yield put(getBranchSuccess(response));\r\n } catch (error) {\r\n yield put(getBranchFail(error));\r\n }\r\n}\r\n\r\n//GetAll Poi\r\nfunction* fetchpoiData() {\r\n try {\r\n const response = yield call(getPoi)\r\n yield put(getPoiSuccess(response))\r\n } catch (error) {\r\n yield put(getPoiFail(error))\r\n }\r\n}\r\n\r\nexport function* watchFetchStateData() {\r\n yield takeEvery(GET_STATE, fetchStateData);\r\n}\r\n\r\nexport function* watchFetchOccupationData() {\r\n yield takeEvery(GET_OCCUPATION, fetchOccupationData);\r\n}\r\n\r\nexport function* watchfetchRelatedPersonTypeData() {\r\n yield takeEvery(GET_RELATEDPERSONTYPE, fetchRelatedPersonTypeData);\r\n}\r\n\r\nexport function* watchFetchEducationData() {\r\n yield takeEvery(GET_EDUCATION, fetchEducationData);\r\n}\r\n\r\nexport function* watchFetchOccupationDetailsData() {\r\n yield takeEvery(GET_OCCUPATIONDETAILS, fetchOccupationDetailsData);\r\n}\r\n\r\nexport function* watchFetchAssetDetailsData() {\r\n yield takeEvery(GET_ASSETDETAILS, fetchAssetDetailsData);\r\n}\r\n\r\nexport function* watchFetchOtherBankAccountsData() {\r\n yield takeEvery(GET_OTHERBANKACCOUNTS, fetchOtherBankAccountsData);\r\n}\r\n\r\nexport function* watchFetchAccountTypeData() {\r\n yield takeEvery(GET_ACCOUNTTYPE, fetchAccountTypeData);\r\n}\r\n\r\nexport function* watchFetchEntityTypeData() {\r\n yield takeEvery(GET_ENTITYTYPE, fetchEntityTypeData);\r\n}\r\n\r\nexport function* watchFetchLocationData() {\r\n yield takeEvery(GET_LOCATION, fetchLocationData);\r\n}\r\n\r\nexport function* watchFetchpoiData() {\r\n yield takeEvery(GET_POI, fetchpoiData);\r\n}\r\n\r\nfunction* registrationSaga() {\r\n yield all([fork(watchFetchStateData)]);\r\n yield all([fork(watchFetchOccupationData)]);\r\n yield all([fork(watchfetchRelatedPersonTypeData)]);\r\n yield all([fork(watchFetchEducationData)]);\r\n yield all([fork(watchFetchOccupationDetailsData)]);\r\n yield all([fork(watchFetchAssetDetailsData)]);\r\n yield all([fork(watchFetchOtherBankAccountsData)]);\r\n yield all([fork(watchFetchAccountTypeData)]);\r\n yield all([fork(watchFetchEntityTypeData)]);\r\n yield all([fork(watchFetchLocationData)]);\r\n yield takeEvery(GET_BRANCH, onGetBranch);\r\n yield all([fork(watchFetchpoiData)]);\r\n}\r\n\r\nexport default registrationSaga;","import { all, fork } from \"redux-saga/effects\"\r\n\r\n//public\r\nimport AccountSaga from \"./auth/register/saga\"\r\nimport AuthSaga from \"./auth/login/saga\"\r\nimport ForgetSaga from \"./auth/forgetpwd/saga\"\r\nimport ProfileSaga from \"./auth/profile/saga\"\r\nimport LayoutSaga from \"./layout/saga\"\r\nimport ecommerceSaga from \"./e-commerce/saga\"\r\nimport calendarSaga from \"./calendar/saga\"\r\nimport chatSaga from \"./chat/saga\"\r\nimport cryptoSaga from \"./crypto/saga\"\r\nimport invoiceSaga from \"./invoices/saga\"\r\nimport projectsSaga from \"./projects/saga\"\r\nimport tasksSaga from \"./tasks/saga\"\r\nimport mailsSaga from \"./mails/saga\"\r\nimport contactsSaga from \"./contacts/saga\";\r\nimport dashboardSaga from \"./dashboard/saga\";\r\nimport dashboardSaasSaga from \"./dashboard-saas/saga\";\r\nimport registrationSaga from \"./Registration/saga\";\r\n\r\n\r\nexport default function* rootSaga() {\r\n yield all([\r\n //public\r\n fork(AccountSaga),\r\n fork(AuthSaga),\r\n fork(ForgetSaga),\r\n fork(ProfileSaga),\r\n fork(LayoutSaga),\r\n fork(ecommerceSaga),\r\n fork(calendarSaga),\r\n fork(chatSaga),\r\n fork(mailsSaga),\r\n fork(cryptoSaga),\r\n fork(invoiceSaga),\r\n fork(projectsSaga),\r\n fork(tasksSaga),\r\n fork(contactsSaga),\r\n fork(dashboardSaga),\r\n fork(dashboardSaasSaga),\r\n fork(registrationSaga),\r\n ])\r\n}\r\n","import { createStore, applyMiddleware, compose } from \"redux\"\r\nimport createSagaMiddleware from \"redux-saga\"\r\n\r\nimport rootReducer from \"./reducers\"\r\nimport rootSaga from \"./sagas\"\r\n\r\nconst sagaMiddleware = createSagaMiddleware()\r\nconst composeEnhancers = window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ || compose\r\n\r\nconst store = createStore(\r\n rootReducer,\r\n composeEnhancers(applyMiddleware(sagaMiddleware))\r\n)\r\nsagaMiddleware.run(rootSaga)\r\n\r\nexport default store\r\n","import React from \"react\"\r\nimport ReactDOM from \"react-dom\"\r\nimport App from \"./App\"\r\nimport * as serviceWorker from \"./serviceWorker\"\r\nimport { BrowserRouter } from \"react-router-dom\"\r\nimport \"./i18n\"\r\nimport { Provider } from \"react-redux\"\r\n\r\nimport store from \"./store\"\r\n\r\nconst app = (\r\n \r\n \r\n \r\n \r\n \r\n)\r\n\r\nReactDOM.render(app, document.getElementById(\"root\"))\r\nserviceWorker.unregister()\r\n"],"sourceRoot":""}