\n Sweet! Your new password has now been set and you can sign in now.\n
\n }\n />\n );\n }\n\n // Enter new password page\n return (\n \n \n \n New password\n \n \n setShowPassword(!showPassword)}\n >\n {\n showPassword ?\n :\n \n }\n \n \n }\n onChange={(e) => setPassword(e.target.value)}\n />\n \n {formFieldError.password}\n \n \n \n \n Repeat new password\n \n \n setShowConfirmPassword(!showConfirmPassword)}\n >\n {\n showConfirmPassword ?\n :\n \n }\n \n \n }\n onChange={(e) => setConfirmPassword(e.target.value)}\n />\n \n {formFieldError.confirmPassword}\n \n \n \n \n \n \n );\n}\n\nexport default ResetPassword;","export default \"\"","import { useState } from 'react';\nimport { Navigate, useNavigate } from 'react-router-dom';\n\nimport {\n FormControlLabel,\n Grid,\n InputAdornment,\n IconButton,\n Button as MuiButton,\n Typography\n} from '@material-ui/core';\nimport { styled } from '@material-ui/core/styles';\n\nimport Auth from '../../auth/auth';\nimport { Button } from '../common';\nimport AuthLayout from './AuthLayout';\nimport { \n AuthFormGroup,\n AuthFormLabel,\n AuthTextField,\n AuthLink,\n AuthCheckbox,\n StyledVisibilitySvg,\n StyledInvisibilitySvg,\n} from './AuthObjects';\nimport FieldHelperText from './FieldHelperText';\n\n\nconst SignUpBox = styled('div')({\n borderTop: '2px solid #BDBEBF',\n marginTop: '32px',\n width: '100%',\n});\n\nconst SignUpText = styled(Typography)({\n fontFamily: \"'Montserrat', sans-serif\",\n fontWeight: 700,\n fontSize: '24px',\n lineHeight: '28px',\n marginTop: '32px',\n textAlign: 'center',\n});\n\nconst SignUpButton = styled(MuiButton)({\n border: '2px solid #BDBEBF',\n borderRadius: '10px',\n color: '#636364',\n fontFamily: \"'Montserrat', sans-serif\",\n fontSize: '18px',\n fontWeight: 700,\n marginTop: '24px',\n height: '64px',\n textTransform: 'none',\n});\n\nfunction SignIn() {\n const navigate = useNavigate();\n // form input\n const [email, setEmail] = useState();\n const [password, setPassword] = useState();\n const [rememberMe, setRememberMe] = useState(false);\n\n const [showPassword, setShowPassword] = useState(false);\n const [formLoading, setFormLoading] = useState(false);\n\n const [errorMessage, setErrorMessage] = useState();\n const [erroredFields, setErroredFields] = useState({});\n\n /**\n * Callback function when login succeeeded. Redirect to previous page\n * if there's any, otherwise redirect to homepage.\n */\n function onLoginSuccess() {\n navigate('/downloads');\n }\n\n /**\n * Callback function when login failed. Display error.\n * @param {String} errorMessage A general error message of the failure.\n * @param {object} erroredFields An object with the error associated with each field.\n */\n function onLoginFailure(errorMessage, erroredFields) {\n setErrorMessage(errorMessage);\n setErroredFields(erroredFields || {});\n setFormLoading(false);\n }\n\n /**\n * Callback function when field value changes. Update the field value and remove the\n * error of the field.\n * @param {String} field The filed that's updated.\n * @param {String} value The new value of the field.\n */\n function removeErroredField(field) {\n delete erroredFields[field];\n setErroredFields(erroredFields);\n }\n\n /**\n * When confirm button is clicked, verify the user email and password.\n * @param {Event} event The event for clicking confirm button.\n */\n async function onSubmit(event) {\n event.preventDefault();\n setFormLoading(true);\n Auth.login(email, password, onLoginSuccess, onLoginFailure);\n }\n\n function handleClickShowPassword() {\n setShowPassword(!showPassword);\n }\n\n function handleRememberMeClicked() {\n setRememberMe(!rememberMe);\n }\n\n if (Auth.getUser()) {\n return \n }\n\n return (\n \n \n \n Email\n \n {\n setEmail(e.target.value);\n removeErroredField(\"email\");\n }}\n />\n \n {erroredFields.email}\n \n \n \n \n Password\n \n {\n setPassword(e.target.value);\n removeErroredField(\"password\");\n }}\n endAdornment={\n \n \n {\n showPassword ?\n :\n \n }\n \n \n }\n />\n \n {erroredFields.password}\n \n \n \n \n \n {/* TODO: Enable this link when we are ready to support reseting password */}\n \n Forgot password?\n \n \n \n }\n label=\"Remember me\" />\n \n \n \n \n \n \n \n Don't have an account?\n {\n navigate('/signup');\n }}\n >\n Sign up\n \n \n \n );\n}\n\nexport default SignIn;\n","import { useState } from 'react';\nimport { Navigate, useNavigate, useSearchParams } from 'react-router-dom';\n\nimport styled from '@emotion/styled';\nimport { InputAdornment, IconButton } from \"@material-ui/core\";\n\nimport Auth from '../../auth/auth';\nimport { Button } from '../common';\nimport AuthLayout from './AuthLayout';\nimport {\n AuthFooterText,\n AuthFormGroup,\n AuthFormLabel,\n AuthLink,\n AuthTextField,\n StyledVisibilitySvg,\n StyledInvisibilitySvg,\n} from './AuthObjects';\nimport FieldHelperText from './FieldHelperText';\n\n\nconst SignUpLink = styled(AuthLink)({\n marginLeft: '4px',\n});\n\nfunction SignUp() {\n const navigate = useNavigate();\n const [searchParams] = useSearchParams();\n const [invitationCode, setInvitationCode] = useState(searchParams.get(\"code\") || \"\");\n const [email, setEmail] = useState(null);\n const [username, setUsername] = useState(null);\n const [password, setPassword] = useState(null);\n const [confirmPassword, setConfirmPassword] = useState(null);\n const [errorMessage, setErrorMessage] = useState(null);\n const [erroredFields, setErroredFields] = useState({});\n const [showPassword, setShowPassword] = useState(false);\n const [showConfirmPassword, setShowConfirmPassword] = useState(false);\n const [formLoading, setFormLoading] = useState(false);\n\n /**\n * Handler when the signup button is clicked. Register using the form data.\n * @param {MouseEvent} e The event object for the click.\n */\n function onSignUpClick(e) {\n e.preventDefault();\n setFormLoading(true);\n Auth.register(\n invitationCode,\n email,\n username,\n password,\n confirmPassword,\n onRegisterSuccess, \n onRegisterFailure);\n }\n\n /**\n * Callback function after registration is successful. Redirect to\n * the homepage.\n */\n function onRegisterSuccess() {\n navigate('/downloads', {state: {prevPage: \"signup\"}});\n }\n\n /**\n * Callback function after registration failed. Display error message\n * on the screen.\n * @param {String} errorMessage: An error message to be displayed on the page.\n * @param {Map[String, String]} erroredFields: A list of name of the errored fields.\n */\n function onRegisterFailure(errorMessage, erroredFields) {\n setErrorMessage(errorMessage);\n setErroredFields(erroredFields || {});\n setFormLoading(false);\n }\n\n if (Auth.getUser()) {\n return ;\n }\n\n return (\n \n \n \n What's your invitation code?\n \n setInvitationCode(e.target.value)}\n />\n \n {erroredFields['invitationCode']}\n \n \n \n What's your email?\n setEmail(e.target.value)}\n />\n \n {erroredFields['email']}\n \n \n \n What's your username?\n setUsername(e.target.value)}\n />\n \n {erroredFields['username'] || \"This appears on your profile.\"}\n \n \n \n Create your password\n setPassword(e.target.value)}\n endAdornment={\n \n setShowPassword(!showPassword)}\n >\n {\n showPassword ?\n :\n \n }\n \n \n }\n />\n \n {erroredFields['password']}\n \n \n \n Confirm your password\n setConfirmPassword(e.target.value)}\n endAdornment={\n \n setShowConfirmPassword(!showConfirmPassword)}\n >\n {\n showConfirmPassword ?\n :\n \n }\n \n \n }\n />\n \n {erroredFields['confirmPassword']}\n \n \n \n \n \n \n Have an account?\n \n Sign in\n \n \n \n );\n}\n\nexport default SignUp;","import './app.css';\n\nimport React, { Component } from 'react';\nimport {\n BrowserRouter as Router,\n Route,\n Routes,\n // Link\n} from 'react-router-dom';\n\nimport Auth from './auth/auth';\nimport ProtectedRoute from './auth/protectedRoute';\n\nimport Downloads from './downloads';\nimport Homepage from './homepage';\nimport { ForgotPassword, ResetPassword, SignIn, SignUp } from './components/auth';\n// import User from './components/user';\n\nclass App extends Component {\n constructor() {\n super();\n this.state = {\n authLoaded: false\n };\n Auth.loadAuth().then(() => this.setState({ authLoaded: true}));\n }\n\n render() {\n if (!this.state.authLoaded) {\n return \n }\n\n return (\n \n \n } />\n }/>\n \n }/>\n }/>\n\n {/* navigation bar */}\n {/* */}\n\n {/*
*/}\n \n } />\n } />\n {/*
*/}\n \n \n );\n }\n}\n\nexport default App;\n","const reportWebVitals = onPerfEntry => {\n if (onPerfEntry && onPerfEntry instanceof Function) {\n import('web-vitals').then(({ getCLS, getFID, getFCP, getLCP, getTTFB }) => {\n getCLS(onPerfEntry);\n getFID(onPerfEntry);\n getFCP(onPerfEntry);\n getLCP(onPerfEntry);\n getTTFB(onPerfEntry);\n });\n }\n};\n\nexport default reportWebVitals;\n","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport { Provider } from \"react-redux\";\nimport './index.css';\nimport App from './app';\nimport reportWebVitals from './reportWebVitals';\nimport store from './store/store';\n\nReactDOM.render(\n \n \n ,\n document.getElementById('root')\n);\n\n// If you want to start measuring performance in your app, pass a function\n// to log results (for example: reportWebVitals(console.log))\n// or send to an analytics endpoint. Learn more: https://bit.ly/CRA-vitals\nreportWebVitals();\n"],"sourceRoot":""}