{"version":3,"sources":["images/white-logo.png","styles/globalStyle.js","styles/LayoutStyles.js","styles/formStyles.js","components/Button.js","components/Footer.js","components/Layout.js","helpers/api.js","components/RegistrationForm.js","styles/ButtonStyles.js","components/HolaJuan.js","components/Bar.js","components/Graphs.js","components/LoginForm.js","components/Home.js","components/PasswordChange.js","components/LandingPage.js","components/GestionarCuenta.js","App.js","index.js","images/background1.png","images/footer.png","images/color-logo.png","images/whitebackgroundhorizontal.png","images/pilar-logo-white.svg","images/icon1.png","images/icon2.png","images/icon3.png","images/icon4.png","images/icon5.png"],"names":["module","exports","GlobalStyle","createGlobalStyle","background","AppWrapper","styled","div","Header","header","img","ImageWrapperHeader","ImageWrapperFooter1","ImageWrapperFooter2","Title","Container","InputItem","label","DatosInvalidos","p","StyledButton","button","mainConnect","smallBlueButton","secondaryBlueButton","goBackButton","createAccount","Button","children","props","Footer","ImgWrapper","NoCuenta","FooterWrapper","MainFooter","src","logo","alt","logoFooter","LoginFooter","history","useHistory","style","textAlign","login","onClick","push","Layout","main","width","maxWidth","margin","whitePilarLogo","display","flexDirection","alignItems","title","LayoutLogin","axios","create","baseURL","HelperText","RegistrationForm","useState","form1","setForm1","form2","setForm2","emptyTextError","setEmptyTextError","wrongPassword","setWrongPassword","registrationFailed","setRegistrationFailed","phoneInputError","setPhoneInputError","nombre","apellido","dni","fechaNacimiento","email","celular","password","passwordRepeat","state","setState","handleInput","e","target","name","value","prevState","validateInput","formIsValid","length","validatePasswordMatch","passwordsValid","console","log","formatDate","splittedField","split","fechaDeNacimiento","dia","parseInt","mes","anio","Date","toISOString","type","onChange","required","data-validation","pattern","maxLength","mask","placeholder","color","href","preventDefault","maxlength","formatedDate","HolaJuan","StackedBarHorarios","data","this","height","options","responsive","maintainAspectRatio","legend","cornerRadius","scales","xAxes","stacked","barThickness","gridLines","yAxes","Component","Graphs","classNameName","labels","datasets","backgroundColor","borderColor","borderWidth","a","LoginForm","loggedIn","setLoggedIn","emptyInputError","setEmptyInputError","loginFailed","setLoginFailed","PasswordChange","formStatus","setFormStatus","resetFailed","setResetFailed","resetSuccess","passwordLengthError","setPasswordLengthError","smsCode","useEffect","url_string","URL","window","location","url","process","REACT_APP_URL","URLSearchParams","search","get","passwordIsValid","validatePassword","alert","LandingPage","flexWrap","justifyContent","icon1","icon2","icon3","icon4","icon5","GestionarCuenta","App","hashRequest","setHashRequest","searchParams","token","exact","path","ReactDOM","render","StrictMode","document","getElementById"],"mappings":"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","file":"static/js/main.ece39588.chunk.js","sourcesContent":["module.exports = __webpack_public_path__ + \"static/media/white-logo.fe7e1edf.png\";","import {createGlobalStyle} from \"styled-components\";\r\nimport background from \"../images/whitebackgroundhorizontal.png\"\r\n\r\nexport const GlobalStyle = createGlobalStyle`\r\n html {\r\n height: 100%;\r\n margin: 0;\r\n }\r\n \r\n body {\r\n font-family: 'Poppins', sans-serif;\r\n margin: 0;\r\n font-size: 14px;\r\n font-weight: 400;\r\n line-height: 1.5;\r\n color: #0069b7;\r\n text-align: left;\r\n height: 100%;\r\n margin: 0;\r\n ${'' /* background:white; */}\r\n background: url(${background}) no-repeat center center fixed; \r\n -webkit-background-size: cover;\r\n -moz-background-size: cover;\r\n -o-background-size: cover;\r\n background-size: cover;\r\n }\r\n #root {\r\n height:100%;\r\n }\r\n #background-video {\r\n width:100%;\r\n }\r\n`","import styled from \"styled-components\"\r\nimport img from \"../images/background1.png\"\r\n\r\nconst AppWrapper = styled.div`\r\n display: flex;\r\n flex-direction: column;\r\n height: 100%;\r\n justify-content: space-between;\r\n ${'' /* max-width: 650px; */}\r\n margin: 0 auto;\r\n`\r\nconst Header = styled.header`\r\n background: url(${img});\r\n background-size: cover;\r\n width:100%;\r\n padding:1em 0;\r\n color:white;\r\n text-align:center;\r\n`\r\nconst ImageWrapperHeader = styled.div`\r\n margin: 0 auto;\r\n max-width: 200px;\r\n width: 50%;\r\n \r\n img{\r\n width:100%;\r\n }\r\n`\r\nconst ImageWrapperFooter1 = styled.div`\r\n width: 35%;\r\n max-width: 120px;\r\n margin:0 auto;\r\n img {\r\n width:100%;\r\n }\r\n`\r\n\r\nconst ImageWrapperFooter2 = styled.div`\r\n width:70%;\r\n margin: 0 auto;\r\n max-width: 250px;\r\n img {\r\n width:100%;\r\n }\r\n`\r\n\r\nconst Title = styled.div`\r\n font-weight: 800;\r\n text-align: center;\r\n background: white;\r\n padding: 0.5em;\r\n border-radius: 45px;\r\n color: #0069b7;\r\n max-width: 150px;\r\n margin: 0 auto;\r\n font-size: .80em;\r\n`\r\n\r\nconst Footer = styled.div`\r\n width:100%;\r\n`\r\n\r\nexport {\r\n AppWrapper,\r\n Header,\r\n ImageWrapperHeader,\r\n ImageWrapperFooter1,\r\n ImageWrapperFooter2,\r\n Title,\r\n Footer\r\n}","import styled from 'styled-components'\r\n\r\nconst Container = styled.div`\r\n width: 70%;\r\n margin: 0 auto;\r\n text-align: center;\r\n color: #0069b7;\r\n font-size: .95em;\r\n max-width:500px;\r\n padding-top:1em;\r\n`\r\n\r\nconst InputItem = styled.label`\r\n display:flex;\r\n flex-direction:column;\r\n margin:1.25em 0;\r\n font-weight:600;\r\n font-size:.75em;\r\n\r\ninput {\r\n border: 1px solid #40daf0;\r\n border-radius: 50px;\r\n padding: .5em;\r\n margin-top: .5em;\r\n text-align:center;\r\n}\r\n`\r\nconst DatosInvalidos = styled.p`\r\n color:red;\r\n`\r\n\r\nexport {\r\n InputItem,\r\n Container,\r\n DatosInvalidos\r\n}","import React from 'react'\r\nimport styled from 'styled-components'\r\n\r\nconst StyledButton = styled.button`\r\n outline: 0;\r\n border: 0;\r\n &:hover {\r\n cursor:pointer;\r\n }\r\n ${({ mainConnect}) => mainConnect && `\r\n background: #0069b7;\r\n border: none;\r\n color: white;\r\n padding: 1em;\r\n border-radius: 45px;\r\n font-weight: 600;\r\n margin: 1em auto;\r\n display: flex;\r\n width: 100%;\r\n text-align: center;\r\n justify-content: center;\r\n `} \r\n\r\n ${({smallBlueButton}) => smallBlueButton && `\r\n background: #0069b7;\r\n border: 0;\r\n color: white;\r\n margin-top: 1em;\r\n margin-bottom:1em;\r\n padding: .5em 0;\r\n border-radius: 45px;\r\n width:150px;\r\n `}\r\n ${({secondaryBlueButton}) => secondaryBlueButton && `\r\n background: #0069b7;\r\n border: 0;\r\n color: white;\r\n margin-top: 1em;\r\n padding: .5em 2.5em;\r\n border-radius: 45px;\r\n max-width: 300px;\r\n margin-bottom:1em;\r\n `}\r\n ${({goBackButton}) => goBackButton && `\r\n font-weight: 700;\r\n background: #bfb5b5;\r\n width: 100px;\r\n margin: 0 auto;\r\n color: white;\r\n padding: .25em;\r\n `}\r\n ${({createAccount}) => createAccount && `\r\n outline: 0;\r\n border: 0;\r\n font-weight: 700;\r\n background: #bfb5b5;\r\n width: 140px;\r\n margin: 0 auto;\r\n color: white;\r\n padding: 0.5em 1em;\r\n border-radius: 45px;\r\n `}\r\n`;\r\n\r\nfunction Button({children, ...props}) {\r\n return (\r\n <StyledButton {...props}>{children}</StyledButton>\r\n )\r\n}\r\n\r\nexport default Button","import React from 'react'\r\nimport { ImageWrapperFooter1, ImageWrapperFooter2} from \"../styles/LayoutStyles\"\r\nimport Button from \"./Button\"\r\nimport logoFooter from \"../images/footer.png\"\r\nimport logo from \"../images/color-logo.png\"\r\nimport styled from \"styled-components\"\r\nimport { useHistory } from 'react-router-dom'\r\n\r\nconst Footer = styled.div`\r\n margin: 1em 0;\r\n background:white;\r\n`\r\n\r\nconst ImgWrapper = styled.div`\r\n width: 35%;\r\n margin: 0 auto;\r\n max-width: 140px;\r\n img {\r\n width:100%;\r\n }\r\n`\r\nconst NoCuenta = styled.p`\r\n color: #0a74be;\r\n font-weight: 900;\r\n margin-top: 3em;\r\n font-size: .75em;\r\n margin-bottom: 0;\r\n`\r\n\r\nconst FooterWrapper = styled.div`\r\n text-align: center;\r\n margin: 1em 0;\r\n background:White;\r\n`\r\n\r\nexport function MainFooter() {\r\n return (\r\n <Footer>\r\n <ImageWrapperFooter1>\r\n <img src={logo} alt=\"C360\" />\r\n </ImageWrapperFooter1>\r\n <ImageWrapperFooter2>\r\n <img src={logoFooter} alt=\"argentina Pilar Unidas\"/>\r\n </ImageWrapperFooter2>\r\n </Footer>\r\n )\r\n}\r\n\r\nexport function LoginFooter(props) {\r\n const history = useHistory()\r\n return(\r\n <FooterWrapper style={{textAlign:\"center\"}}>\r\n {props.login && <NoCuenta>NO TENÉS CUENTA?</NoCuenta> }\r\n <ImgWrapper>\r\n <img src={logo} alt=\"c360\"/>\r\n </ImgWrapper>\r\n <Button smallBlueButton onClick={() => history.push(`/register`)}>CREAR CUENTA</Button>\r\n <ImageWrapperFooter2>\r\n <img src={logoFooter} alt=\"argentina Pilar Unidas\"/>\r\n </ImageWrapperFooter2>\r\n </FooterWrapper>\r\n )\r\n}\r\n\r\n// export default {\r\n// MainFooter,\r\n// LoginFooter\r\n// }","import React from 'react'\r\nimport styled from \"styled-components\"\r\nimport logo from \"../images/white-logo.png\"\r\nimport { Container } from '../styles/formStyles'\r\nimport { Header, ImageWrapperHeader, Title } from \"../styles/LayoutStyles\"\r\nimport Button from './Button'\r\nimport { MainFooter, LoginFooter } from './Footer'\r\nimport { useHistory } from 'react-router-dom';\r\nimport whitePilarLogo from \"../images/pilar-logo-white.svg\"\r\n\r\n\r\nexport function Layout(props) {\r\n let history = useHistory();\r\n return (\r\n <>\r\n {props.main ? (\r\n <Header>\r\n <div style={{width:\"80%\", maxWidth: \"505px\", margin: \"0 auto\"}}>\r\n <ImageWrapperHeader>\r\n <img src={logo} alt=\"c360\" />\r\n <img src={whitePilarLogo} alt=\"pilar\"/>\r\n </ImageWrapperHeader>\r\n <h2>Bienvenidos al portal 360</h2>\r\n <p>Mediante su cuenta de Ciudadanos 360 usted podrá ingresar a todos los servicios que brinda la Municipalidad de Pilar obteniendo todos los beneficios que los pilarenses se merecen</p>\r\n <div style={{display:\"flex\", flexDirection:\"column\", alignItems: \"center\"}}>\r\n <Button smallBlueButton onClick={() => history.push(`/login`)}>Ingresar</Button>\r\n </div>\r\n </div>\r\n </Header>\r\n ):(\r\n <Header>\r\n <ImageWrapperHeader>\r\n <img src={logo} alt=\"c360\" />\r\n </ImageWrapperHeader>\r\n <Title>{props.title}</Title>\r\n </Header>\r\n )}\r\n <Container>\r\n {props.children}\r\n </Container>\r\n <MainFooter />\r\n </>\r\n )\r\n}\r\n\r\nexport function LayoutLogin(props) {\r\n return (\r\n <>\r\n <Header>\r\n <ImageWrapperHeader>\r\n <img src={logo} alt=\"c360\" />\r\n </ImageWrapperHeader>\r\n <Title>{props.title}</Title>\r\n </Header>\r\n <Container>\r\n {props.children}\r\n </Container>\r\n <LoginFooter login={props.login} />\r\n </>\r\n )\r\n}","import axios from 'axios'\r\n\r\nconst api = axios.create({\r\n baseURL: 'https://api.ciudadanos360.com'\r\n})\r\n\r\nexport const getHashRequest = (payload) => api.post('/login/GetHashRequest', payload)\r\n\r\nexport const iniciarSesion = (payload) => api.post('/login/IniciarSesion', payload)\r\n\r\nexport const registerUser = (payload) => api.post('/login/Registrar', payload)\r\n\r\nexport const SMSCambiarPassword = (payload) => api.post('/login/SMSCambiarPassword', payload)\r\n\r\nexport const SMSVerificarCodigo = (payload) => api.post('/login/SMSVerificarCodigo', payload)\r\n\r\nexport const cambiarPassword = (payload) => api.post('/login/SMSVerificarCodigo', payload)\r\n\r\nconst apis = {\r\n getHashRequest,\r\n iniciarSesion,\r\n registerUser,\r\n SMSCambiarPassword,\r\n SMSVerificarCodigo,\r\n cambiarPassword\r\n}\r\n\r\nexport default apis","import React, { useState } from 'react'\r\nimport { useHistory } from \"react-router-dom\"\r\nimport MaskedInput from 'react-maskedinput'\r\n\r\nimport {InputItem, DatosInvalidos } from \"../styles/formStyles\"\r\nimport Button from \"../components/Button\"\r\nimport { Layout } from \"./Layout\"\r\nimport { registerUser } from '../helpers/api'\r\nimport styled from \"styled-components\"\r\n\r\n\r\nconst HelperText = styled.div`\r\n margin: -1em 0 1em 0;\r\n padding: 0;\r\n font-size: .75em;\r\n`\r\n\r\nfunction RegistrationForm(props) {\r\n const [ form1, setForm1 ] = useState(true)\r\n const [ form2, setForm2 ] = useState(false)\r\n const [ emptyTextError, setEmptyTextError ] = useState(false)\r\n const [ wrongPassword, setWrongPassword ] = useState(false)\r\n const [ registrationFailed, setRegistrationFailed ] = useState(false)\r\n const [ backButton, setBackButton ] = useState(false)\r\n const [ phoneInputError, setPhoneInputError ] = useState(false)\r\n\r\n const [ state, setState ] = useState({\r\n nombre:\"\",\r\n apellido: \"\",\r\n dni: \"\",\r\n fechaNacimiento: false,\r\n email: \"\",\r\n celular: \"\",\r\n password: \"\",\r\n passwordRepeat: \"\"\r\n })\r\n\r\n let history = useHistory()\r\n\r\n const handleContinue = e => {\r\n e.preventDefault()\r\n let fieldsValidated = validateInput()\r\n if(fieldsValidated) {\r\n setForm1(false);\r\n setForm2(true);\r\n }\r\n }\r\n\r\n const handleInput = (e) => {\r\n const { name, value } = e.target\r\n setEmptyTextError(false)\r\n setWrongPassword(false)\r\n setPhoneInputError(false)\r\n setState( prevState => ({\r\n ...prevState,\r\n [name]:value\r\n }))\r\n }\r\n const handleRegisterSubmit = e => {\r\n e.preventDefault()\r\n let formatedDate = formatDate()\r\n console.log(formatedDate)\r\n let passwordsMatched = validatePasswordMatch() \r\n history.push(`/graphs`) \r\n }\r\n\r\n\r\n const validateInput = () => {\r\n let formIsValid = true;\r\n if(state.nombre.length < 2 || state.apellido.length < 2 || state.dni < 2 || state.fechaNacimiento === false) {\r\n formIsValid = false;\r\n setEmptyTextError(true)\r\n } \r\n return formIsValid;\r\n }\r\n\r\n const validatePhone = () => {\r\n let phoneIsValid = true;\r\n if(state.celular.length < 10 || state.celular.length > 10) {\r\n setPhoneInputError(true)\r\n phoneIsValid = false\r\n }\r\n console.log(\"phone is valid\", phoneIsValid)\r\n return phoneIsValid\r\n }\r\n const validatePasswordMatch = () => {\r\n let passwordsValid = true\r\n if(state.password.length < 1 || state.passwordRepeat.length < 1) {\r\n setEmptyTextError(true);\r\n setWrongPassword(false)\r\n passwordsValid = false;\r\n }\r\n if(state.password.length > 1 && state.passwordRepeat.length > 1 && state.password !== state.passwordRepeat) {\r\n passwordsValid = false;\r\n setWrongPassword(true);\r\n setEmptyTextError(false);\r\n }\r\n console.log(\"password is valid\", passwordsValid)\r\n return passwordsValid;\r\n }\r\n\r\n const formatDate = () => {\r\n let splittedField = state.fechaNacimiento.split('/');\r\n let fechaDeNacimiento = '';\r\n if(splittedField.length == 3){\r\n const dia = parseInt(splittedField[0]);\r\n const mes = parseInt(splittedField[1]) - 1;\r\n const anio = parseInt(splittedField[2]);\r\n fechaDeNacimiento = new Date(anio,mes,dia).toISOString(); \r\n }\r\n return fechaDeNacimiento\r\n }\r\n\r\n const goBackToForm1 = () => {\r\n setForm1(true);\r\n setForm2(false);\r\n setRegistrationFailed(false);\r\n }\r\n\r\n\r\n return (\r\n <Layout title={\"CREAR CUENTA\"}>\r\n {form1 && (\r\n <form>\r\n <InputItem>\r\n NOMBRE\r\n <input type=\"text\" name=\"nombre\" onChange={handleInput} required />\r\n </InputItem>\r\n <InputItem>\r\n APELLIDO\r\n <input type=\"text\" name=\"apellido\" onChange={handleInput}/>\r\n </InputItem>\r\n <InputItem>\r\n DNI\r\n <input type=\"text\" name=\"dni\" onChange={handleInput} required=\"true\" data-validation=\"required\" pattern=\"[0-9]*\" maxLength=\"8\"/>\r\n </InputItem>\r\n <InputItem>\r\n FECHA DE NACIMIENTO\r\n <MaskedInput mask=\"11/11/1111\" name=\"fechaNacimiento\" placeholder=\"dd/mm/yyyy\" onChange={handleInput}/>\r\n </InputItem>\r\n {emptyTextError && <DatosInvalidos>Los campos no pueden ser vacios</DatosInvalidos>}\r\n <p style={{color: \"black\"}}>Al hacer click en Siguiente, aceptas los <a href=\"https://ciudadanos360.com/privacidad/\">Términos y Condiciones</a> de Uso de Adfi company SRL.</p>\r\n <p style={{color: \"black\"}}>Para obtener mas información acerca de cómo Adfi Company SRL utiliza y protege tus datos personales, lee la <a href=\"#\">PolÃtica de Privacidad de Adfi Company</a>.</p>\r\n <Button secondaryBlueButton type=\"submit\" onClick={handleContinue}>SIGUIENTE</Button>\r\n </form>\r\n )}\r\n {form2 && (\r\n <form>\r\n <InputItem>\r\n CORREO ELECTRONICO\r\n <input type=\"email\" name=\"email\" onChange={handleInput}/>\r\n </InputItem>\r\n <InputItem>\r\n CELULAR\r\n {/* <input type=\"tel\" name=\"celular\" onChange={handleInput} /> */}\r\n <input onChange={handleInput} type=\"number\" name=\"celular\" required=\"\" data-validation=\"required\" pattern=\"[0-9]*\" maxlength=\"15\"/>\r\n </InputItem>\r\n <HelperText>Ingresar el número sin 0 ni 15, por ejemplo 1155667788</HelperText>\r\n <InputItem>\r\n CONTRASENA\r\n <input type=\"password\" name=\"password\" onChange={handleInput}/>\r\n </InputItem>\r\n <InputItem>\r\n REPETIR CONTRASENA\r\n <input type=\"password\" name=\"passwordRepeat\" onChange={handleInput}/>\r\n </InputItem>\r\n {wrongPassword && <DatosInvalidos>Las contraseñas ingresadas son diferentes</DatosInvalidos>}\r\n {emptyTextError && <DatosInvalidos>Las contraseñas no pueden ser vacios</DatosInvalidos>}\r\n {phoneInputError && <DatosInvalidos>El campo de celular es obligatorio, lo necesitaremos para recordarte la contraseña</DatosInvalidos>}\r\n <p style={{color: \"black\"}}>Al hacer click en Registrar, aceptas los <a href=\"https://ciudadanos360.com/privacidad/\">Términos y Condiciones</a> de Uso de Adfi company SRL.</p>\r\n <p style={{color: \"black\"}}>Para obtener mas información acerca de cómo Adfi Company SRL utiliza y protege tus datos personales, lee la <a href=\"#\">PolÃtica de Privacidad de Adfi Company</a>.</p>\r\n <Button secondaryBlueButton onClick={handleRegisterSubmit}>Registar</Button>\r\n {registrationFailed && (\r\n <>\r\n {/* <DatosInvalidos>El ciudadano ya fue dado de alta</DatosInvalidos> */}\r\n <DatosInvalidos>Los datos ingresados no son válidos</DatosInvalidos>\r\n <Button goBackButton onClick={goBackToForm1}>Regresar</Button>\r\n </>\r\n )}\r\n </form>\r\n )}\r\n </Layout>\r\n )\r\n}\r\n\r\nexport default RegistrationForm","import styled from \"styled-components\"\r\n\r\nconst MainConnectButton = styled.div`\r\n background: #0069b7;\r\n border: none;\r\n color: white;\r\n max-width: 400px;\r\n padding: .5em;\r\n border-radius: 45px;\r\n font-weight: 600;\r\n margin: 1em 0;\r\n`\r\nconst SecondaryBlueButton = styled.button`\r\n background: #0069b7;\r\n border: 0;\r\n color: white;\r\n margin-top: 1em;\r\n padding: .5em 2.5em;\r\n border-radius: 45px;\r\n max-width: 300px;\r\n margin-bottom:2em;\r\n`\r\n\r\nconst ConectarseButton = styled.div`\r\n background: white;\r\n width: 100px;\r\n margin: 0 auto;\r\n border-radius: 45px;\r\n color: #0069b7;\r\n padding: .25em 1em;\r\n font-weight: 700;\r\n`\r\n\r\nconst FbButton = styled.div`\r\n background:#225499;\r\n display:flex;\r\n justify-content: space-around;\r\n color: white;\r\n border-radius: 45px;\r\n margin: 1.5em 0;\r\n`\r\n\r\nconst GoogleButton = styled.div`\r\n display:flex;\r\n justify-content: space-around;\r\n color: grey;\r\n border:1px solid #9b9b9b;\r\n border-radius: 45px;\r\n margin: 1.5em 0;\r\n`\r\n\r\nconst C360Button = styled.div`\r\n display:flex;\r\n justify-content: space-around;\r\n color: #1acaf6;\r\n border:1px solid #1acaf6;\r\n border-radius: 45px;\r\n margin: 1.5em 0;\r\n`\r\nexport {\r\n MainConnectButton,\r\n SecondaryBlueButton,\r\n ConectarseButton,\r\n FbButton,\r\n GoogleButton,\r\n C360Button\r\n}","import React from 'react'\r\nimport { Layout } from './Layout'\r\nimport ConectarseButton from \"../styles/ButtonStyles\"\r\nimport Button from \"./Button\"\r\n\r\nfunction HolaJuan() {\r\n return (\r\n <>\r\n <Layout title={\"HOLA JUAN\"}>\r\n <div style={{textAlign:\"center\"}}>Bienvenidos!</div>\r\n {/* <Button mainConnect onClick={() => alert(\"connectado\")}>Conectarse</Button>\r\n <Button blue={true} onClick={()=> alert(\"Blue\")}>i am blue</Button>\r\n <Button pink={true} onClick={() => alert(\"pink button coming in hot\")}>I AM PINK</Button> */}\r\n </Layout>\r\n </>\r\n )\r\n}\r\n\r\nexport default HolaJuan","import React, { Component } from 'react'\r\nimport { Bar } from 'react-chartjs-2'\r\n\r\nexport class StackedBarHorarios extends Component {\r\n render() {\r\n return (\r\n <div>\r\n <Bar \r\n data={this.props.data}\r\n height={370}\r\n width={100}\r\n options={{\r\n responsive: true,\r\n maintainAspectRatio: false,\r\n legend:{display:false}, \r\n cornerRadius: 6,\r\n scales: {\r\n xAxes: [{\r\n stacked: true,\r\n barThickness: 10,\r\n gridLines:{\r\n\t\t\t\t\t display:false,\r\n\t\t\t\t } \r\n }],\r\n yAxes: [{\r\n stacked: true\r\n }]\r\n }\r\n }}\r\n />\r\n </div>\r\n )\r\n }\r\n}\r\n\r\nexport default StackedBarHorarios\r\n","import React, { useContext } from 'react'\r\n// import BoxHeader from '../../../components/app-layout/box-layout/BoxHeader'\r\n// import StackedBarHorarios from '../../../components/charts/StackedBarHorarios'\r\n// import { DashboardContext } from '../../../contexts/DashboardContext';\r\n// import NoDataMessage from '../../../components/app-layout/box-layout/NoDataMessage'\r\nimport StackedBarHorarios from \"./Bar\"\r\nimport { Layout } from './Layout'\r\nimport { Line } from 'react-chartjs-2';\r\n\r\nconst Graphs = () => {\r\n let horariosBarData ={\r\n labels:[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23],\r\n datasets: [\r\n {\r\n label:\"logins\",\r\n data:[25, 10, 19, 4, 56, 47, 41, 58, 19, 25, 10, 19, 4, 56, 47, 41, 58, 19, 4, 56, 47, 41, 58, 19 ],\r\n backgroundColor: '#229fda',\r\n borderColor: '#229fda',\r\n borderWidth: 20,\r\n },\r\n {\r\n label:\"logins\",\r\n data:[],\r\n backgroundColor: '#3e4145',\r\n }\r\n ]\r\n }\r\n let connectionsPerDateData = {\r\n labels:[\"01-01-2018\", \"02-01-2018\", \"03-01-2018\", \"04-01-2018\", \"05-01-2018\", \"06-01-2018\", \"07-01-2018\", \"08-01-2018\", \"09-01-2018\", \"10-01-2018\", \"11-01-2018\", \"12-01-2018\", \"13-01-2018\", \"14-01-2018\", \"15-01-2018\", \"16-01-2018\", \"17-01-2018\", \"18-01-2018\", \"19-01-2018\", \"20-01-2018\", \"21-01-2018\", \"22-01-2018\", \"23-01-2018\", \"24-01-2018\", \"25-01-2018\", \"26-01-2018\", \"27-01-2018\", \"28-01-2018\", \"29-01-2018\", \"30-01-2018\", \"31-01-2018\"],\r\n datasets: [\r\n {\r\n label:\"conexiones\",\r\n data:[0, 0, 0, 0, 0, 0, 1, 2, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,],\r\n borderColor: ['#44494e'],\r\n backgroundColor: ['rgba(69, 74, 79, 0.13)'],\r\n },\r\n {\r\n label:\"logins\",\r\n data:[0, 2, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 7, 0, 0, 0, 0, 0, 0, 4, 0, 0, 0, 0, 0, 0, 6, 0, 0, 0, 0],\r\n borderColor: ['#229fda'],\r\n backgroundColor: ['rgba(34, 158, 216, 0.14)']\r\n }\r\n ]\r\n }\r\n let dispositivosData ={\r\n labels:['smartphones', 'tablets', 'pc/mac', 'otro'],\r\n datasets: [\r\n {\r\n label:\"logins\",\r\n data:[54, 97, 78, 5],\r\n backgroundColor: '#229fda',\r\n borderColor: '#229fda',\r\n borderWidth: 20,\r\n },\r\n {\r\n label:\"logins\",\r\n data:[],\r\n backgroundColor: '#3e4145',\r\n }\r\n ]\r\n }\r\n\r\n return (\r\n <Layout title={\"BIENVENIDOS\"}>\r\n <div classNameName=\"horarios-graph\">\r\n <h3>Hourly Logins</h3>\r\n <StackedBarHorarios data={horariosBarData}/>\r\n </div>\r\n\r\n <div>\r\n <h3>Conexiones por fecha</h3>\r\n <Line\r\n data={connectionsPerDateData}\r\n height={210}\r\n width={100}\r\n options={{ \r\n maintainAspectRatio: false, \r\n legend:{display:false}\r\n }}\r\n />\r\n </div>\r\n\r\n <div classNameName=\"horarios-graph\">\r\n <h3>Dispositivos</h3>\r\n <StackedBarHorarios data={dispositivosData}/>\r\n </div>\r\n </Layout>\r\n )\r\n}\r\n\r\nexport default Graphs\r\n","import React, { useState, useEffect } from 'react'\r\nimport { useHistory } from 'react-router-dom';\r\nimport { getHashRequest, iniciarSesion } from \"../helpers/api\"\r\nimport { LayoutLogin } from \"./Layout\"\r\nimport Button from \"./Button\"\r\nimport Spinner from 'react-bootstrap/Spinner'\r\n\r\nimport styled from \"styled-components\"\r\nimport { MainConnectButton, SecondaryBlueButton } from \"../styles/ButtonStyles\"\r\nimport { InputItem, Container, DatosInvalidos } from \"../styles/formStyles\"\r\nimport HolaJuan from './HolaJuan';\r\nimport Graphs from './Graphs';\r\n\r\n//30149228\r\n//Favio1982123*\r\n\r\nconst SpinnerWrapper = styled.div`\r\n width:100px;\r\n margin:0 auto;\r\n \r\n img {\r\n width:100%;\r\n }\r\n `\r\n\r\nconst ForgotPassword = styled.a`\r\n font-size: .75em;\r\n font-weight: 700;\r\n &:hover {\r\n cursor:pointer;\r\n }\r\n`\r\n\r\nfunction LoginForm(props) {\r\n const [ state, setState ] = useState({\r\n dni: \"\",\r\n password: \"\"\r\n })\r\n const [ loggedIn, setLoggedIn ] = useState(false)\r\n const [ emptyInputError, setEmptyInputError ] = useState()\r\n const [ loginFailed, setLoginFailed ] = useState(false)\r\n const [ hashRequest, setHashRequest ] = useState()\r\n\r\n let history = useHistory();\r\n \r\n const handleInput = (e) => {\r\n const { name, value} = e.target\r\n setEmptyInputError(false)\r\n setLoginFailed(false)\r\n setState( prevState => ({\r\n ...prevState,\r\n [name]:value\r\n }))\r\n }\r\n const handleLogin = () => {\r\n let inputValidated = validateInput()\r\n if(inputValidated) {\r\n setLoggedIn(true)\r\n history.push(\"/graphs\")\r\n }\r\n }\r\n\r\n function validateInput() {\r\n let formIsValid = true;\r\n if(state.dni.length < 1 || state.password.length < 1) {\r\n formIsValid = false;\r\n setEmptyInputError(true)\r\n }\r\n\r\n return formIsValid;\r\n }\r\n return(\r\n <>\r\n <LayoutLogin title={\"LOGIN\"} login={true}>\r\n {!loggedIn && (\r\n <>\r\n <div>\r\n <InputItem>\r\n DNI\r\n <input type=\"number\" name=\"dni\" onChange={handleInput} value={state.dni}/>\r\n </InputItem>\r\n <InputItem>\r\n CONTRASEÑA\r\n <input type=\"password\" name=\"password\" onChange={handleInput} value={state.password}/>\r\n </InputItem>\r\n {loginFailed && <DatosInvalidos>Datos invalidos</DatosInvalidos>}\r\n {emptyInputError && <DatosInvalidos>Los campos no pueden estar vacios</DatosInvalidos>}\r\n <Button mainConnect onClick={handleLogin}>CONECTARSE</Button>\r\n {/* <ForgotPassword onClick={() => history.push(\"/password\")}>OLVIDASTE TU CONTRASEÑA</ForgotPassword> */}\r\n </div>\r\n </>\r\n )}\r\n {loggedIn && (\r\n <Graphs />\r\n )}\r\n \r\n </LayoutLogin>\r\n </>\r\n )\r\n}\r\n\r\nexport default LoginForm","import React from 'react'\r\nimport Layout from \"../components/Layout\"\r\nimport background from \"../images/background1.png\"\r\nimport logo from \"../images/white-logo.png\"\r\nimport styled from \"styled-components\"\r\nimport { ConectarseButton } from \"../styles/ButtonStyles\"\r\n\r\nconst ImageWrapper = styled.div`\r\n background: url(${background}) no-repeat center center fixed; \r\n -webkit-background-size: cover;\r\n -moz-background-size: cover;\r\n -o-background-size: cover;\r\n background-size: cover;\r\n height:100%;\r\n text-align:center;\r\n display: flex;\r\n flex-direction: column;\r\n justify-content: center;\r\n`\r\n\r\nconst LogoWrapper = styled.div`\r\n width:75%;\r\n margin:0 auto;\r\n max-width: 315px;\r\n img{\r\n width:100%\r\n }\r\n`\r\n\r\nfunction Home() {\r\n return (\r\n <>\r\n <ImageWrapper>\r\n <LogoWrapper>\r\n <img src={logo} alt=\"C360\" />\r\n </LogoWrapper>\r\n <ConectarseButton>Conectarse</ConectarseButton>\r\n </ImageWrapper>\r\n </>\r\n )\r\n}\r\n\r\nexport default Home","import React, { useState, useEffect } from 'react'\r\nimport { useHistory } from 'react-router-dom'\r\nimport MaskedInput from 'react-maskedinput'\r\nimport styled from \"styled-components\"\r\n\r\nimport { SMSCambiarPassword, SMSVerificarCodigo, cambiarPassword } from \"../helpers/api\"\r\nimport { Layout } from \"./Layout\"\r\nimport Button from \"./Button\"\r\nimport { InputItem, DatosInvalidos } from \"../styles/formStyles\"\r\n\r\nconst HelperText = styled.p`\r\n margin-bottom:2em;\r\n`\r\n\r\nfunction PasswordChange(props) {\r\n const [ formStatus, setFormStatus ] = useState(\"DNICHECK\")\r\n const [ emptyTextError, setEmptyTextError ] = useState()\r\n const [ resetFailed, setResetFailed ] = useState()\r\n const [ resetSuccess, setResetSuccess ] = useState(false)\r\n const [ passwordLengthError, setPasswordLengthError ] = useState()\r\n const [ wrongPassword, setWrongPassword ] = useState(false)\r\n // const [ smsCode, setSMSCode ] = useState(\"\")\r\n \r\n const [ state, setState ] = useState({\r\n dni: \"\",\r\n password: \"\",\r\n passwordRepeat: \"\",\r\n fechaNacimiento:false,\r\n smsCode: \"\"\r\n })\r\n let history = useHistory();\r\n \r\n\r\n useEffect(() => {\r\n //GET PARAMS FROM URL AND SAVE IT IN CONTEXT PROBABLY\r\n \r\n const url_string = new URL(window.location.href)\r\n const url = process.env.REACT_APP_URL ? new URL(process.env.REACT_APP_URL) : new URL(url_string.href)\r\n let searchParams = new URLSearchParams(url.search)\r\n let token = searchParams.get(\"token\") \r\n // setHashRequest(token) \r\n },[])\r\n\r\n\r\n const handleInput = (e) => {\r\n const { name, value } = e.target\r\n setEmptyTextError(false)\r\n setPasswordLengthError(false)\r\n setResetFailed(false)\r\n setWrongPassword(false)\r\n setState( prevState => ({\r\n ...prevState,\r\n [name]:value\r\n }))\r\n }\r\n\r\n const handleCheckDNI = () => {\r\n //endpoint checkDNI\r\n //on success\r\n if(state.dni.length != 0 && state.fechaNacimiento != false ) {\r\n setFormStatus(\"VALIDATESMS\")\r\n setEmptyTextError(false)\r\n } else {\r\n setEmptyTextError(true)\r\n }\r\n }\r\n\r\n const handleValidateSMS = () => {\r\n //endpoint\r\n //on success \r\n if(state.smsCode.length != 0) {\r\n setFormStatus(\"CHANGEPASSWORD\")\r\n setEmptyTextError(false)\r\n } else {\r\n setEmptyTextError(true)\r\n }\r\n }\r\n\r\n function handleChangePassword() {\r\n if(validatePassword() && validatePasswordMatch()) {\r\n alert(\"Cambiaste la contrasena con exito\")\r\n history.push(`/`)\r\n }\r\n }\r\n\r\n function validatePassword() {\r\n let passwordIsValid = true\r\n if(state.password.length > 0 && state.password.length < 6) {\r\n passwordIsValid = false\r\n setPasswordLengthError(true)\r\n }\r\n console.log(\"passwordIsValid\", passwordIsValid)\r\n\r\n return passwordIsValid\r\n }\r\n\r\n const validatePasswordMatch = () => {\r\n let passwordsValid = true\r\n if(state.password.length < 1 || state.passwordRepeat.length < 1) {\r\n setEmptyTextError(true);\r\n setWrongPassword(false)\r\n passwordsValid = false;\r\n }\r\n if(state.password.length > 1 && state.passwordRepeat.length > 1 && state.password !== state.passwordRepeat) {\r\n passwordsValid = false;\r\n setWrongPassword(true);\r\n setEmptyTextError(false);\r\n }\r\n console.log(\"validatePasswordMatch\", passwordsValid)\r\n\r\n return passwordsValid;\r\n }\r\n return(\r\n <>\r\n <Layout title={\"BIENVENIDOS\"} login={true}>\r\n {formStatus === \"DNICHECK\" && (\r\n <div>\r\n <HelperText>Para modificar tu contraseña, <br></br> por favor ingresá tu DNI</HelperText>\r\n <InputItem>\r\n DNI\r\n <input type=\"number\" name=\"dni\" onChange={handleInput} value={state.dni}/>\r\n </InputItem>\r\n <InputItem>\r\n FECHA DE NACIMIENTO\r\n <MaskedInput mask=\"11/11/1111\" name=\"fechaNacimiento\" placeholder=\"dd/mm/yyyy\" onChange={handleInput}/>\r\n </InputItem>\r\n <Button mainConnect onClick={handleCheckDNI}>Continuar</Button>\r\n </div>\r\n )}\r\n {formStatus === \"VALIDATESMS\" && (\r\n <div>\r\n <HelperText>Te envÃamos un mensaje de texto con las instrucciones para cambiar la contraseña</HelperText>\r\n <InputItem>\r\n Código de SMS\r\n <input onChange={handleInput} type=\"number\" name=\"smsCode\" required=\"\" data-validation=\"required\" placeholder=\"Código\" pattern=\"[0-9]*\" maxlength=\"4\"/>\r\n </InputItem>\r\n <Button mainConnect onClick={handleValidateSMS}>Verificar</Button>\r\n </div>\r\n )}\r\n {formStatus === \"CHANGEPASSWORD\" && (\r\n <div>\r\n <HelperText>Porfavor ingrese la nueva contraseña</HelperText>\r\n <InputItem>\r\n NUEVA CONSTRASEÑA\r\n <input type=\"password\" name=\"password\" onChange={handleInput} value={state.password}/>\r\n </InputItem>\r\n <InputItem>\r\n REPETIR CONTRASENA\r\n <input type=\"password\" name=\"passwordRepeat\" onChange={handleInput}/>\r\n </InputItem>\r\n <Button mainConnect onClick={handleChangePassword}>Cambiar</Button>\r\n </div>\r\n )}\r\n {emptyTextError && <DatosInvalidos>Los campos no pueden estar vacios</DatosInvalidos>}\r\n {passwordLengthError && <DatosInvalidos>La contraseña tiene que tener por lo menos 6 characters</DatosInvalidos>}\r\n {wrongPassword && <DatosInvalidos>Las contraseñas ingresadas son diferentes</DatosInvalidos>}\r\n {resetFailed && (\r\n <>\r\n <DatosInvalidos>Los datos ingresados no son válidos. Probá de nuevo o crea una cuenta</DatosInvalidos>\r\n <Button createAccount onClick={() => history.push(`/register`)}>CREAR CUENTA</Button>\r\n </>\r\n )}\r\n {resetSuccess && (\r\n <>\r\n <p>El cambio de contraseña fue exitoso. Logeate de nuevo</p>\r\n <Button smallBlueButton onClick={() => history.push(`/`)}>Ingresa</Button>\r\n </>\r\n )}\r\n </Layout>\r\n </>\r\n )\r\n}\r\n\r\nexport default PasswordChange","import React from 'react'\r\nimport { Header, ImageWrapperHeader } from \"../styles/LayoutStyles\"\r\nimport Button from './Button'\r\nimport { Layout } from './Layout'\r\nimport { useHistory } from 'react-router-dom'\r\nimport icon1 from \"../images/icon1.png\"\r\nimport icon2 from \"../images/icon2.png\"\r\nimport icon3 from \"../images/icon3.png\"\r\nimport icon4 from \"../images/icon4.png\"\r\nimport icon5 from \"../images/icon5.png\"\r\n\r\n\r\n\r\nfunction LandingPage() {\r\n const history = useHistory()\r\n return(\r\n <Layout main>\r\n <div>\r\n <h3>Cuidadanos 360</h3>\r\n <p>A traves de este portal usted podrá realizar acciones en las siquientes categorÃas:</p>\r\n </div>\r\n <div style={{display:\"flex\", flexWrap:\"wrap\", justifyContent:\"space-between\", alignItems: \"baseline\", margin: \"4em 0 8em 0\"}}>\r\n <div style={{width:\"50px\", margin:\"0 1em\"}}>\r\n <img src={icon1} alt=\"icon\" style={{width:\"100%\"}}/>\r\n <p>Educación</p>\r\n </div>\r\n <div style={{width:\"50px\", margin:\"0 1em\"}}>\r\n <img src={icon2} alt=\"icon\" style={{width:\"100%\"}}/>\r\n <p>Salud</p>\r\n </div>\r\n <div style={{width:\"50px\", margin:\"0 1em\"}}>\r\n <img src={icon3} alt=\"icon\" style={{width:\"100%\"}}/>\r\n <p>Cultura</p>\r\n </div>\r\n <div style={{width:\"50px\", margin:\"0 1em\"}}>\r\n <img src={icon4} alt=\"icon\" style={{width:\"100%\"}}/>\r\n <p>Seguridad</p>\r\n </div>\r\n <div style={{width:\"50px\", margin:\"0 1em\"}}>\r\n <img src={icon5} alt=\"icon\" style={{width:\"100%\"}}/>\r\n <p>Transporte</p>\r\n </div>\r\n </div>\r\n <div style={{display:\"flex\", flexDirection:\"column\", alignItems: \"center\"}}>\r\n <Button smallBlueButton onClick={() => history.push(`/register`)}>Crear Cuenta</Button>\r\n <Button smallBlueButton onClick={() => history.push(`/gestionar`)}>Gestionar Cuenta</Button>\r\n </div>\r\n </Layout>\r\n )\r\n}\r\n\r\nexport default LandingPage","import React, { useState } from 'react'\r\nimport { useHistory } from \"react-router-dom\"\r\nimport MaskedInput from 'react-maskedinput'\r\n\r\nimport {InputItem, DatosInvalidos } from \"../styles/formStyles\"\r\nimport Button from \"../components/Button\"\r\nimport { Layout } from \"./Layout\"\r\nimport { registerUser } from '../helpers/api'\r\nimport styled from \"styled-components\"\r\n\r\n\r\nconst HelperText = styled.div`\r\n margin: -1em 0 1em 0;\r\n padding: 0;\r\n font-size: .75em;\r\n`\r\n\r\nfunction GestionarCuenta(props) {\r\n const [ form1, setForm1 ] = useState(true)\r\n const [ form2, setForm2 ] = useState(false)\r\n const [ emptyTextError, setEmptyTextError ] = useState(false)\r\n const [ wrongPassword, setWrongPassword ] = useState(false)\r\n const [ registrationFailed, setRegistrationFailed ] = useState(false)\r\n const [ backButton, setBackButton ] = useState(false)\r\n const [ phoneInputError, setPhoneInputError ] = useState(false)\r\n\r\n const [ state, setState ] = useState({\r\n nombre:\"\",\r\n apellido: \"\",\r\n dni: \"\",\r\n fechaNacimiento: false,\r\n email: \"\",\r\n celular: \"\",\r\n password: \"\",\r\n passwordRepeat: \"\"\r\n })\r\n\r\n let history = useHistory()\r\n\r\n const handleContinue = e => {\r\n e.preventDefault()\r\n // let fieldsValidated = validateInput()\r\n // if(fieldsValidated) {\r\n setForm1(false);\r\n setForm2(true);\r\n // }\r\n }\r\n\r\n const handleInput = (e) => {\r\n const { name, value } = e.target\r\n setEmptyTextError(false)\r\n setWrongPassword(false)\r\n setPhoneInputError(false)\r\n setState( prevState => ({\r\n ...prevState,\r\n [name]:value\r\n }))\r\n }\r\n const handleRegisterSubmit = e => {\r\n e.preventDefault()\r\n let passwordsMatched = validatePasswordMatch() \r\n history.push(`/hola`) \r\n }\r\n\r\n\r\n const validateInput = () => {\r\n let formIsValid = true;\r\n if(state.nombre.length < 2 || state.apellido.length < 2 || state.dni < 2 || state.fechaNacimiento === false) {\r\n formIsValid = false;\r\n setEmptyTextError(true)\r\n } \r\n return formIsValid;\r\n }\r\n\r\n const validatePhone = () => {\r\n let phoneIsValid = true;\r\n if(state.celular.length < 10 || state.celular.length > 10) {\r\n setPhoneInputError(true)\r\n phoneIsValid = false\r\n }\r\n console.log(\"phone is valid\", phoneIsValid)\r\n return phoneIsValid\r\n }\r\n const validatePasswordMatch = () => {\r\n let passwordsValid = true\r\n if(state.password.length < 1 || state.passwordRepeat.length < 1) {\r\n setEmptyTextError(true);\r\n setWrongPassword(false)\r\n passwordsValid = false;\r\n }\r\n if(state.password.length > 1 && state.passwordRepeat.length > 1 && state.password !== state.passwordRepeat) {\r\n passwordsValid = false;\r\n setWrongPassword(true);\r\n setEmptyTextError(false);\r\n }\r\n console.log(\"password is valid\", passwordsValid)\r\n return passwordsValid;\r\n }\r\n\r\n const goBackToForm1 = () => {\r\n setForm1(true);\r\n setForm2(false);\r\n setRegistrationFailed(false);\r\n }\r\n\r\n\r\n return (\r\n <Layout title={\"EDITAR PERFIL C360\"}>\r\n {form1 && (\r\n <form>\r\n <InputItem>\r\n NOMBRE\r\n <input type=\"text\" name=\"nombre\" onChange={handleInput} required />\r\n </InputItem>\r\n <InputItem>\r\n APELLIDO\r\n <input type=\"text\" name=\"apellido\" onChange={handleInput}/>\r\n </InputItem>\r\n <InputItem>\r\n DNI\r\n <input type=\"text\" name=\"dni\" onChange={handleInput} required=\"true\" data-validation=\"required\" pattern=\"[0-9]*\" maxLength=\"8\"/>\r\n </InputItem>\r\n <InputItem>\r\n FECHA DE NACIMIENTO\r\n <MaskedInput mask=\"11/11/1111\" name=\"fechaNacimiento\" placeholder=\"dd/mm/yyyy\" onChange={handleInput}/>\r\n </InputItem>\r\n {emptyTextError && <DatosInvalidos>Los campos no pueden ser vacios</DatosInvalidos>}\r\n <Button secondaryBlueButton type=\"submit\" onClick={handleContinue}>SIGUIENTE</Button>\r\n </form>\r\n )}\r\n {form2 && (\r\n <form>\r\n <InputItem>\r\n CORREO ELECTRONICO\r\n <input type=\"email\" name=\"email\" onChange={handleInput}/>\r\n </InputItem>\r\n <InputItem>\r\n CELULAR\r\n {/* <input type=\"tel\" name=\"celular\" onChange={handleInput} /> */}\r\n <input onChange={handleInput} type=\"number\" name=\"celular\" required=\"\" data-validation=\"required\" pattern=\"[0-9]*\" maxlength=\"15\"/>\r\n </InputItem>\r\n <HelperText>Ingresar el número sin 0 ni 15, por ejemplo 1155667788</HelperText>\r\n <InputItem>\r\n CONTRASENA\r\n <input type=\"password\" name=\"password\" onChange={handleInput}/>\r\n </InputItem>\r\n <InputItem>\r\n REPETIR CONTRASENA\r\n <input type=\"password\" name=\"passwordRepeat\" onChange={handleInput}/>\r\n </InputItem>\r\n {wrongPassword && <DatosInvalidos>Las contraseñas ingresadas son diferentes</DatosInvalidos>}\r\n {emptyTextError && <DatosInvalidos>Las contraseñas no pueden ser vacios</DatosInvalidos>}\r\n {phoneInputError && <DatosInvalidos>El campo de celular es obligatorio, lo necesitaremos para recordarte la contraseña</DatosInvalidos>}\r\n <Button secondaryBlueButton onClick={handleRegisterSubmit}>Registar</Button>\r\n {registrationFailed && (\r\n <>\r\n {/* <DatosInvalidos>El ciudadano ya fue dado de alta</DatosInvalidos> */}\r\n <DatosInvalidos>Los datos ingresados no son válidos</DatosInvalidos>\r\n <Button goBackButton onClick={goBackToForm1}>Guardar</Button>\r\n </>\r\n )}\r\n </form>\r\n )}\r\n </Layout>\r\n )\r\n}\r\n\r\nexport default GestionarCuenta","import React, { useEffect, useState } from 'react'\r\nimport { GlobalStyle } from \"./styles/globalStyle\"\r\nimport { AppWrapper } from \"./styles/LayoutStyles\"\r\nimport {\r\n BrowserRouter as Router,\r\n Switch,\r\n Route,\r\n Link\r\n} from \"react-router-dom\";\r\n\r\nimport RegistrationForm from \"./components/RegistrationForm\"\r\nimport LoginForm from './components/LoginForm'\r\nimport LoginOptions from './components/LoginOptions'\r\nimport Home from \"./components/Home\"\r\nimport HolaJuan from './components/HolaJuan';\r\nimport PasswordChange from './components/PasswordChange'\r\nimport { getHashRequest } from \"./helpers/api\"\r\nimport LandingPage from './components/LandingPage';\r\nimport GestionarCuenta from './components/GestionarCuenta'\r\nimport Graphs from './components/Graphs';\r\n\r\nfunction App() {\r\n const [ hashRequest, setHashRequest ] = useState()\r\n\r\n useEffect(() => {\r\n //GET PARAMS FROM URL AND SAVE IT IN CONTEXT PROBABLY\r\n \r\n const url_string = new URL(window.location.href)\r\n const url = process.env.REACT_APP_URL ? new URL(process.env.REACT_APP_URL) : new URL(url_string.href)\r\n let searchParams = new URLSearchParams(url.search)\r\n let token = searchParams.get(\"token\") \r\n setHashRequest(token) \r\n \r\n console.log(\"url_string: \", url_string)\r\n console.log(\"url: \", url)\r\n console.log(\"searchParams: \", searchParams)\r\n\r\n let mounted = true\r\n \r\n },[])\r\n\r\n console.log(\"hashrequest: \", hashRequest)\r\n\r\n return (\r\n <AppWrapper>\r\n <GlobalStyle />\r\n {/* <RegistrationForm /> */}\r\n <Router>\r\n <Switch>\r\n <Route exact path=\"/\">\r\n <LandingPage />\r\n </Route>\r\n <Route path=\"/login\">\r\n <LoginForm hashRequest={hashRequest}/>\r\n </Route>\r\n <Route path=\"/register\">\r\n <RegistrationForm hashRequest={hashRequest} />\r\n </Route>\r\n <Route path=\"/gestionar\">\r\n <GestionarCuenta hashRequest={hashRequest} />\r\n </Route>\r\n <Route path=\"/password\">\r\n <PasswordChange hashRequest={hashRequest} />\r\n </Route>\r\n <Route path=\"/graphs\">\r\n <Graphs hashRequest={hashRequest} />\r\n </Route>\r\n <Route path=\"/hola\">\r\n <HolaJuan />\r\n </Route>\r\n </Switch>\r\n </Router>\r\n </AppWrapper>\r\n )\r\n}\r\n\r\nexport default App","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport App from './App';\n\nReactDOM.render(\n <React.StrictMode>\n <App />\n </React.StrictMode>,\n document.getElementById('root')\n);\n\n\n","module.exports = __webpack_public_path__ + \"static/media/background1.d8052a91.png\";","module.exports = __webpack_public_path__ + \"static/media/footer.4dc94e00.png\";","module.exports = __webpack_public_path__ + \"static/media/color-logo.94f64c52.png\";","module.exports = __webpack_public_path__ + \"static/media/whitebackgroundhorizontal.7e02ec3e.png\";","module.exports = __webpack_public_path__ + \"static/media/pilar-logo-white.e258b385.svg\";","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\""],"sourceRoot":""}