{"version":3,"sources":["assets/Ceapia-01.png","assets/Ceapia-02.png","services/api.ts","hooks/Auth.tsx","components/Input/styles.ts","components/Input/index.tsx","components/Button/styles.ts","components/Button/index.tsx","components/Alert/index.tsx","utils/getValidationErrors.ts","pages/Login/styles.ts","pages/Login/index.tsx","routes/Route.tsx","components/DialogForm/styles.ts","components/DialogForm/index.tsx","pages/Dashboard/styles.ts","pages/AnnualRegistation/styles.ts","pages/AnnualRegistation/index.tsx","pages/Preceptorships/styles.ts","pages/Preceptorships/index.tsx","pages/Dashboard/index.tsx","pages/NotFound/index.tsx","routes/index.tsx","hooks/index.tsx","styles/global.ts","App.tsx","index.tsx"],"names":["module","exports","api","axios","create","baseURL","process","AuthContext","createContext","AuthProvider","children","useState","token","localStorage","getItem","user","JSON","parse","data","setData","login","useCallback","a","email","password","post","response","student","name","firstName","lastName","groups","setItem","stringify","logout","removeItem","Provider","value","useAuth","context","useContext","Error","Container","styled","div","Input","label","rest","inputRef","useRef","useField","fieldName","defaultValue","error","registerField","useEffect","ref","current","path","TextField","helperText","inputProps","Button","button","Alert","type","onClose","React","open","setOpen","handleClose","event","reason","Snackbar","autoHideDuration","elevation","variant","severity","getValidationErrors","err","validationErrors","inner","forEach","message","Content","FormContainer","FormContent","Form","AlertContainer","Login","formRef","loading","setLoading","alert","setAlert","history","useHistory","handleAlertClose","handleSubmit","setErrors","schema","Yup","shape","required","validate","abortEarly","push","errors","src","Logo","alt","onSubmit","placeholder","color","CircularProgress","size","Route","isPrivate","Component","component","render","location","to","pathname","state","from","FormActions","useStyles","makeStyles","theme","createStyles","paper","minHeight","maxHeight","content","width","actions","margin","DialogForm","title","initialData","classes","Dialog","fullWidth","maxWidth","DialogTitle","DialogContent","className","Save","onClick","Header","Link","root","display","appBar","background","zIndex","drawer","transition","transitions","easing","sharp","duration","leavingScreen","appBarShift","marginLeft","enteringScreen","menuButton","marginRight","menuAccount","marginTop","hide","flexShrink","whiteSpace","drawerOpen","drawerClose","overflowX","spacing","breakpoints","up","toolbar","alignItems","justifyContent","padding","mixins","flexGrow","media","height","paddingTop","expand","transform","shortest","expandOpen","avatar","backgroundColor","backdrop","Admins","useRouteMatch","studentGroup","setStudentGroup","canSeePreceptorships","setCanSeePreceptorships","registration","setRegistration","isActive","Authorization","get","headers","registrationResponse","userAvailableSchedules","schedules","filter","schedule","includes","group","map","Date","startTime","now","nextSchedule","closestTo","selectedSchedule","find","isEqual","inSchedule","isAfter","finishedAllRounds","every","isBefore","endTime","length","getRegistration","handleAlert","Breadcrumbs","aria-label","href","Typography","Backdrop","Card","CardContent","key","_id","CardHeader","Avatar","year","subheader","moment","createdAt","format","align","studentSchedule","Chip","style","fontWeight","CardActions","disableSpacing","Tooltip","IconButton","disabled","socket","socketio","io","reconnection","reconnectionDelay","timeout","weekDays","1","2","3","4","5","6","0","PreceptorshipsList","useParams","id","groupId","preceptorships","setPreceptorships","signedIn","setSignedIn","handleVacancy","action","currentPreceptorships","findPrecepIdx","findGroupIdx","payload","findIndex","precep","preceptorship","vacancy","placesLeft","students","pop","date","order","init","preceptorshipsResponse","signedPreceptorshipsResponse","getPreceptorships","on","precepSocket","handleStudentSign","preceptorshipId","registrationId","newSignedPreceptorship","renderSubscribeButton","isSubscribed","isFull","totalStudents","isFilled","v","Check","weekday","Divider","coordinators","coord","room","hasProjector","DesktopMac","Dashboard","useTheme","formRefUpdate","myDataOpen","setMyDataOpen","anchorEl","setAnchorEl","openMenu","Boolean","handleMyDataOpen","handleMyDataClose","passwordConfirm","oneOf","put","window","reload","CssBaseline","AppBar","position","clsx","Toolbar","aria-controls","aria-haspopup","currentTarget","orientation","flexItem","opacity","boxShadow","split","Menu","keepMounted","MenuItem","exact","Registration","Preceptorships","NotFound","Routes","hooks","createGlobalStyle","App","ReactDOM","StrictMode","document","getElementById"],"mappings":"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","file":"static/js/main.ebcd53a2.chunk.js","sourcesContent":["module.exports = \"\"","module.exports = \"\"","import axios from 'axios';\r\n\r\nconst api = axios.create({\r\n baseURL: process.env.REACT_APP_PRECEPTORIA_API,\r\n});\r\n\r\nexport default api;\r\n","import React, { createContext, useCallback, useState, useContext } from 'react';\r\n\r\nimport api from '../services/api';\r\n\r\ninterface User {\r\n name: string;\r\n email: string;\r\n groups: string[];\r\n}\r\n\r\ninterface AuthState {\r\n token: string;\r\n user: User;\r\n}\r\n\r\ninterface LoginCredentials {\r\n email: string;\r\n password: string;\r\n}\r\n\r\ninterface AuthContextData {\r\n token: string;\r\n user: User;\r\n login(credeitnals: LoginCredentials): Promise;\r\n logout(): void;\r\n}\r\n\r\nconst AuthContext = createContext({} as AuthContextData);\r\n\r\nconst AuthProvider: React.FC = ({ children }) => {\r\n const [data, setData] = useState(() => {\r\n const token = localStorage.getItem('@PRECEPTORIA:token');\r\n const user = localStorage.getItem('@PRECEPTORIA:user');\r\n\r\n if (token && user) {\r\n return { token, user: JSON.parse(user) };\r\n }\r\n\r\n return {} as AuthState;\r\n });\r\n\r\n const login = useCallback(async ({ email, password }) => {\r\n const response = await api.post('/login', {\r\n email,\r\n password,\r\n });\r\n\r\n const { token, student } = response.data;\r\n\r\n const user = {\r\n name: `${student.firstName} ${student.lastName}`,\r\n email: student.email,\r\n groups: student.groups,\r\n };\r\n\r\n localStorage.setItem('@PRECEPTORIA:token', token);\r\n localStorage.setItem('@PRECEPTORIA:user', JSON.stringify(user));\r\n\r\n setData({ token, user });\r\n }, []);\r\n\r\n const logout = useCallback(() => {\r\n localStorage.removeItem('@PRECEPTORIA:token');\r\n localStorage.removeItem('@PRECEPTORIA:user');\r\n\r\n setData({} as AuthState);\r\n }, []);\r\n\r\n return (\r\n \r\n {children}\r\n \r\n );\r\n};\r\n\r\nfunction useAuth(): AuthContextData {\r\n const context = useContext(AuthContext);\r\n\r\n if (!context) {\r\n throw new Error('useAuth must be used within an AuthProvider');\r\n }\r\n\r\n return context;\r\n}\r\n\r\nexport { useAuth, AuthProvider };\r\n","import styled from 'styled-components';\r\n\r\nexport const Container = styled.div`\r\n margin: 1%;\r\n width: 100%;\r\n\r\n * {\r\n width: 100%;\r\n }\r\n`;\r\n","import React, {\r\n InputHTMLAttributes,\r\n useEffect,\r\n useRef,\r\n} from 'react';\r\n\r\nimport { useField } from '@unform/core';\r\nimport TextField from '@material-ui/core/TextField';\r\n\r\nimport { Container } from './styles';\r\n\r\ninterface InputProps extends InputHTMLAttributes {\r\n name: string;\r\n label: string;\r\n}\r\n\r\nconst Input: React.FC = ({ name, label, ...rest }) => {\r\n const inputRef = useRef(null);\r\n\r\n const { fieldName, defaultValue, error, registerField } = useField(name);\r\n\r\n useEffect(() => {\r\n registerField({\r\n name: fieldName,\r\n ref: inputRef.current,\r\n path: 'value',\r\n });\r\n }, [fieldName, registerField]);\r\n\r\n return (\r\n \r\n \r\n \r\n );\r\n};\r\n\r\nexport default Input;\r\n","import styled from 'styled-components';\r\nimport Button from '@material-ui/core/Button';\r\n\r\nexport const Container = styled(Button)`\r\n`;\r\n","import React from 'react';\r\nimport { ButtonProps } from '@material-ui/core/Button';\r\n\r\nimport { Container } from './styles';\r\n\r\nconst button: React.FC = ({ children, ...rest }) => (\r\n \r\n {children}\r\n \r\n);\r\n\r\nexport default button;\r\n","import React from 'react';\r\nimport Snackbar from '@material-ui/core/Snackbar';\r\nimport MuiAlert from '@material-ui/lab/Alert';\r\n\r\ninterface AlertComponentProps {\r\n type: 'success' | 'info' | 'warning' | 'error';\r\n onClose?(): void;\r\n}\r\n\r\nconst Alert: React.FC = ({ type, onClose, ...rest }) => {\r\n const [open, setOpen] = React.useState(true);\r\n\r\n const handleClose = (event?: React.SyntheticEvent, reason?: string) => {\r\n if (reason === 'clickaway') {\r\n return;\r\n }\r\n\r\n setOpen(false);\r\n\r\n if (onClose) onClose();\r\n };\r\n\r\n return (\r\n \r\n \r\n \r\n );\r\n};\r\n\r\nexport default Alert;\r\n","import { ValidationError } from 'yup';\r\n\r\ninterface Errors {\r\n [key: string]: string;\r\n}\r\n\r\nexport default function getValidationErrors(err: ValidationError): Errors {\r\n const validationErrors: Errors = {};\r\n\r\n err.inner.forEach((error) => {\r\n validationErrors[error.path] = error.message;\r\n });\r\n\r\n return validationErrors;\r\n}\r\n","import styled from 'styled-components';\r\nimport { Form } from '@unform/web';\r\n\r\nexport const Container = styled.div`\r\n width: 100%;\r\n height: 100vh;\r\n display: flex;\r\n padding: 2%;\r\n justify-content: center;\r\n`;\r\n\r\nexport const Content = styled.div`\r\n min-width: 30%;\r\n display: flex;\r\n flex-direction: column;\r\n justify-content: space-between;\r\n`;\r\n\r\nexport const FormContainer = styled.div`\r\n align-self: center;\r\n\r\n h2,\r\n h3 {\r\n text-align: center;\r\n font-weight: normal;\r\n }\r\n`;\r\n\r\nexport const FormContent = styled(Form)`\r\n * {\r\n width: 100%;\r\n padding: 2% 0;\r\n }\r\n`;\r\n\r\nexport const AlertContainer = styled.div`\r\n width: 100%;\r\n`;\r\n","import React, { useRef, useCallback, useState } from 'react';\r\nimport CircularProgress from '@material-ui/core/CircularProgress';\r\nimport { FormHandles } from '@unform/core';\r\nimport { useHistory } from 'react-router-dom';\r\nimport * as Yup from 'yup';\r\n\r\nimport { useAuth } from '../../hooks/Auth';\r\nimport Logo from '../../assets/Ceapia-01.png';\r\n\r\nimport Input from '../../components/Input';\r\nimport Button from '../../components/Button';\r\nimport Alert from '../../components/Alert';\r\n\r\nimport getValidationErrors from '../../utils/getValidationErrors';\r\n\r\nimport {\r\n Container,\r\n Content,\r\n FormContainer,\r\n FormContent,\r\n AlertContainer,\r\n} from './styles';\r\n\r\ninterface LoginFormData {\r\n email: string;\r\n password: string;\r\n}\r\n\r\nconst Login: React.FC = () => {\r\n const formRef = useRef(null);\r\n const [loading, setLoading] = useState(false);\r\n const [alert, setAlert] = useState(false);\r\n\r\n const { login } = useAuth();\r\n const history = useHistory();\r\n\r\n const handleAlertClose = useCallback(() => {\r\n setAlert(false);\r\n }, []);\r\n\r\n const handleSubmit = useCallback(async (data: LoginFormData) => {\r\n setLoading(true);\r\n\r\n try {\r\n formRef.current?.setErrors({});\r\n\r\n const schema = Yup.object().shape({\r\n email: Yup.string()\r\n .email('Digite um e-mail válido.')\r\n .required('E-mail obrigatório.'),\r\n password: Yup.string().required('Senha obrigatória.'),\r\n });\r\n\r\n await schema.validate(data, { abortEarly: false });\r\n\r\n await login({\r\n email: data.email,\r\n password: data.password,\r\n });\r\n\r\n history.push('/dashboard');\r\n } catch (error) {\r\n if (error instanceof Yup.ValidationError) {\r\n const errors = getValidationErrors(error);\r\n\r\n formRef.current?.setErrors(errors);\r\n } else {\r\n return setAlert(true);\r\n }\r\n } finally {\r\n setLoading(false);\r\n }\r\n }, []);\r\n\r\n return (\r\n \r\n \r\n \r\n \"Logo\"\r\n\r\n

PRECEPTORIA

\r\n\r\n \r\n \r\n\r\n \r\n\r\n \r\n \r\n
\r\n\r\n {alert && (\r\n \r\n \r\n Credenciais inválidas.\r\n \r\n \r\n )}\r\n
\r\n
\r\n );\r\n};\r\n\r\nexport default Login;\r\n","import React from 'react';\r\n\r\nimport {\r\n RouteProps as ReactDomRouterProps,\r\n Route as ReactDomRoute,\r\n Redirect,\r\n} from 'react-router-dom';\r\n\r\nimport { useAuth } from '../hooks/Auth';\r\n\r\ninterface RouterProps extends ReactDomRouterProps {\r\n isPrivate?: boolean;\r\n component: React.FC;\r\n}\r\n\r\nconst Route: React.FC = ({\r\n isPrivate = false,\r\n component: Component,\r\n ...rest\r\n}) => {\r\n const { token } = useAuth();\r\n\r\n return (\r\n {\r\n return isPrivate === !!token ? (\r\n \r\n ) : (\r\n \r\n );\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default Route;\r\n","import styled from 'styled-components';\r\nimport { makeStyles, Theme, createStyles } from '@material-ui/core/styles';\r\nimport { Form } from '@unform/web';\r\n\r\nexport const Container = styled.div``;\r\n\r\nexport const FormContainer = styled(Form)`\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n\r\n .row {\r\n width: 100%;\r\n display: flex;\r\n justify-content: space-around;\r\n align-items: center;\r\n margin: 1%;\r\n padding: 1%;\r\n }\r\n`;\r\n\r\nexport const FormActions = styled.div`\r\n display: flex;\r\n justify-content: center;\r\n\r\n * {\r\n margin: 2%;\r\n }\r\n`;\r\n\r\nexport const useStyles = makeStyles((theme: Theme) =>\r\n createStyles({\r\n paper: {\r\n minHeight: 'fit-content',\r\n maxHeight: 'fit-content',\r\n },\r\n content: {\r\n width: '100%',\r\n },\r\n actions: {\r\n margin: '20px',\r\n },\r\n }),\r\n);\r\n","import React from 'react';\r\nimport { FormHandles } from '@unform/core';\r\n\r\nimport { Save } from '@material-ui/icons';\r\n\r\nimport { Button, DialogTitle, DialogContent, Dialog } from '@material-ui/core';\r\n\r\nimport { Container, FormContainer, FormActions, useStyles } from './styles';\r\n\r\ninterface DialogFormProps {\r\n open: boolean;\r\n handleClose(): void;\r\n handleSubmit(data: any): void;\r\n formRef: React.RefObject;\r\n title: string;\r\n initialData?: any;\r\n}\r\n\r\nconst DialogForm: React.FC = ({\r\n children,\r\n open,\r\n handleClose,\r\n handleSubmit,\r\n formRef,\r\n title,\r\n initialData,\r\n}) => {\r\n const classes = useStyles();\r\n\r\n return (\r\n \r\n \r\n {title}\r\n \r\n \r\n
{children}
\r\n\r\n \r\n \r\n \r\n Cancelar\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n );\r\n};\r\n\r\nexport default DialogForm;\r\n","import styled from 'styled-components';\r\n\r\nimport { createStyles, makeStyles, Theme } from '@material-ui/core/styles';\r\nimport { Link } from 'react-router-dom';\r\n\r\nexport const Container = styled.div`\r\n width: 100%;\r\n`;\r\n\r\nexport const Header = styled.div`\r\n display: flex;\r\n min-height: 20vh;\r\n flex-direction: column;\r\n align-items: space-around;\r\n justify-content: center;\r\n color: #4f4f4f;\r\n\r\n * {\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n }\r\n\r\n @media (max-height: 550px) {\r\n min-height: 30vh;\r\n }\r\n\r\n @media (max-height: 300px) {\r\n min-height: 40vh;\r\n }\r\n`;\r\n\r\nexport const StyledLink = styled(Link)`\r\n color: #4472ca;\r\n display: flex;\r\n text-decoration: none;\r\n color: #000000;\r\n`;\r\n\r\nconst drawerWidth = 240;\r\n\r\nexport const useStyles = makeStyles((theme: Theme) =>\r\n createStyles({\r\n root: {\r\n display: 'flex',\r\n },\r\n appBar: {\r\n background: '#fff',\r\n zIndex: theme.zIndex.drawer + 1,\r\n transition: theme.transitions.create(['width', 'margin'], {\r\n easing: theme.transitions.easing.sharp,\r\n duration: theme.transitions.duration.leavingScreen,\r\n }),\r\n },\r\n appBarShift: {\r\n marginLeft: drawerWidth,\r\n width: `calc(100% - ${drawerWidth}px)`,\r\n transition: theme.transitions.create(['width', 'margin'], {\r\n easing: theme.transitions.easing.sharp,\r\n duration: theme.transitions.duration.enteringScreen,\r\n }),\r\n },\r\n menuButton: {\r\n marginRight: 36,\r\n },\r\n menuAccount: {\r\n marginTop: 36,\r\n },\r\n hide: {\r\n display: 'none',\r\n },\r\n drawer: {\r\n width: drawerWidth,\r\n flexShrink: 0,\r\n whiteSpace: 'nowrap',\r\n },\r\n drawerOpen: {\r\n width: drawerWidth,\r\n transition: theme.transitions.create('width', {\r\n easing: theme.transitions.easing.sharp,\r\n duration: theme.transitions.duration.enteringScreen,\r\n }),\r\n },\r\n drawerClose: {\r\n transition: theme.transitions.create('width', {\r\n easing: theme.transitions.easing.sharp,\r\n duration: theme.transitions.duration.leavingScreen,\r\n }),\r\n overflowX: 'hidden',\r\n width: theme.spacing(7) + 1,\r\n [theme.breakpoints.up('sm')]: {\r\n width: theme.spacing(9) + 1,\r\n },\r\n },\r\n toolbar: {\r\n display: 'flex',\r\n alignItems: 'center',\r\n justifyContent: 'space-between',\r\n padding: theme.spacing(0, 1),\r\n ...theme.mixins.toolbar,\r\n },\r\n content: {\r\n flexGrow: 1,\r\n padding: theme.spacing(3),\r\n },\r\n }),\r\n);\r\n","import styled from 'styled-components';\r\nimport { Link } from 'react-router-dom';\r\n\r\nimport { makeStyles, Theme, createStyles } from '@material-ui/core/styles';\r\n\r\nexport const Container = styled.div`\r\n display: flex;\r\n justify-content: center;\r\n flex-direction: column;\r\n\r\n .registration-card {\r\n display: flex;\r\n justify-content: center;\r\n\r\n @media (max-width: 650px) {\r\n width: 100%;\r\n }\r\n }\r\n\r\n .card-content {\r\n div {\r\n margin: 1%;\r\n }\r\n\r\n .schedules {\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n margin-top: 10px;\r\n }\r\n }\r\n`;\r\n\r\nexport const StyledLink = styled(Link)`\r\n color: #4472ca;\r\n display: flex;\r\n text-decoration: none;\r\n color: #000000;\r\n`;\r\n\r\nexport const useStyles = makeStyles((theme: Theme) =>\r\n createStyles({\r\n root: {},\r\n media: {\r\n height: 0,\r\n paddingTop: '56.25%',\r\n },\r\n expand: {\r\n transform: 'rotate(0deg)',\r\n marginLeft: 'auto',\r\n transition: theme.transitions.create('transform', {\r\n duration: theme.transitions.duration.shortest,\r\n }),\r\n },\r\n expandOpen: {\r\n transform: 'rotate(180deg)',\r\n },\r\n avatar: {\r\n backgroundColor: '#4472CA',\r\n padding: 30,\r\n },\r\n backdrop: {\r\n zIndex: theme.zIndex.drawer + 1,\r\n color: '#fff',\r\n },\r\n }),\r\n);\r\n","import React, { useState, useEffect, useCallback } from 'react';\r\nimport { useHistory, useRouteMatch } from 'react-router-dom';\r\n\r\nimport moment from 'moment';\r\nimport { closestTo, isAfter, isBefore, isEqual } from 'date-fns';\r\n\r\nimport {\r\n Button,\r\n Typography,\r\n Tooltip,\r\n Avatar,\r\n CardActions,\r\n CardContent,\r\n CardHeader,\r\n Card,\r\n Chip,\r\n IconButton,\r\n Breadcrumbs,\r\n Link,\r\n Backdrop,\r\n CircularProgress,\r\n} from '@material-ui/core';\r\n\r\nimport { Container, useStyles } from './styles';\r\n\r\nimport api from '../../services/api';\r\nimport Alert from '../../components/Alert';\r\nimport { useAuth } from '../../hooks/Auth';\r\n\r\nimport { AnnualRegistration, Schedule } from './dtos';\r\n\r\nimport { AlertProps } from '../../utils/dtos';\r\n\r\nconst Admins: React.FC = () => {\r\n const classes = useStyles();\r\n const history = useHistory();\r\n const { path } = useRouteMatch();\r\n const { token, user } = useAuth();\r\n const [studentGroup, setStudentGroup] = useState('');\r\n\r\n const [canSeePreceptorships, setCanSeePreceptorships] = useState(\r\n true,\r\n );\r\n\r\n const [registration, setRegistration] = useState(\r\n null,\r\n );\r\n\r\n const [alert, setAlert] = useState({\r\n isActive: false,\r\n });\r\n\r\n const [loading, setLoading] = useState(true);\r\n\r\n const Authorization = `Bearer ${token}`;\r\n\r\n useEffect(() => {\r\n async function getRegistration() {\r\n try {\r\n const registrationResponse = await api.get(\r\n '/students/annualRegistration',\r\n {\r\n headers: {\r\n Authorization,\r\n },\r\n },\r\n );\r\n\r\n setRegistration(registrationResponse.data);\r\n\r\n const userAvailableSchedules: Date[] = registrationResponse.data.schedules\r\n .filter((schedule: Schedule) => user.groups.includes(schedule.group))\r\n .map((schedule: Schedule) => new Date(schedule.startTime));\r\n\r\n const now = new Date();\r\n\r\n const nextSchedule = closestTo(now, userAvailableSchedules);\r\n\r\n const selectedSchedule: Schedule = registrationResponse.data.schedules.find(\r\n (schedule: Schedule) =>\r\n isEqual(new Date(schedule.startTime), nextSchedule),\r\n );\r\n\r\n setStudentGroup(selectedSchedule.group);\r\n\r\n const inSchedule = isAfter(now, nextSchedule);\r\n\r\n const finishedAllRounds = registrationResponse.data.schedules.every(\r\n (schedule: Schedule) => isBefore(new Date(schedule.endTime), now),\r\n );\r\n\r\n if (\r\n !userAvailableSchedules.length ||\r\n !inSchedule ||\r\n (isBefore(new Date(selectedSchedule.endTime), now) &&\r\n !finishedAllRounds)\r\n )\r\n setCanSeePreceptorships(false);\r\n\r\n setAlert({\r\n isActive: true,\r\n type: 'success',\r\n message: 'Inscrição anual encontrada com sucesso.',\r\n });\r\n } catch (error) {\r\n if (error.message.includes('401')) {\r\n setAlert({\r\n isActive: true,\r\n type: 'warning',\r\n message: 'Sessão expirada, faça o login novamente.',\r\n });\r\n } else {\r\n setAlert({\r\n isActive: true,\r\n type: 'error',\r\n message: 'Erro ao buscar inscrição anual.',\r\n });\r\n }\r\n } finally {\r\n setLoading(false);\r\n }\r\n }\r\n\r\n getRegistration();\r\n }, []);\r\n\r\n const handleAlert = useCallback(() => {\r\n setAlert({ isActive: false });\r\n }, []);\r\n\r\n return (\r\n \r\n \r\n \r\n Dashboard\r\n \r\n Incrições anuais\r\n \r\n\r\n \r\n \r\n \r\n\r\n
\r\n {!loading && !registration && (\r\n \r\n \r\n \r\n Não existem inscrições ativas este ano.\r\n \r\n \r\n \r\n )}\r\n\r\n {registration && (\r\n \r\n {registration.year}\r\n }\r\n title={registration.name}\r\n subheader={`Inscrições abertas em ${moment(\r\n registration.createdAt,\r\n ).format('DD/MM/YYYY')}`}\r\n />\r\n\r\n \r\n \r\n Seus horários de inscrição:\r\n \r\n\r\n \r\n {registration.schedules\r\n .filter((schedule) => user.groups.includes(schedule.group))\r\n .map((studentSchedule) => (\r\n \r\n ))}\r\n \r\n \r\n\r\n \r\n \r\n {canSeePreceptorships\r\n ? 'Clique para ver as turmas!'\r\n : 'Fora de horário! Recarregue esta página nas datas e horários acima.'}\r\n \r\n )}\r\n >\r\n \r\n \r\n history.push(\r\n `${path}/registration/${registration._id}/student/${studentGroup}`,\r\n )\r\n }\r\n >\r\n Ver horários\r\n \r\n \r\n \r\n \r\n \r\n )}\r\n
\r\n\r\n {alert.isActive && (\r\n \r\n {alert.message}\r\n \r\n )}\r\n
\r\n );\r\n};\r\n\r\nexport default Admins;\r\n","import styled from 'styled-components';\r\nimport { makeStyles, Theme, createStyles } from '@material-ui/core/styles';\r\n\r\nexport const Container = styled.div`\r\n display: flex;\r\n flex-direction: column;\r\n\r\n .cards-container {\r\n display: flex;\r\n flex-wrap: wrap;\r\n justify-content: center;\r\n\r\n @media (max-width: 1170px) {\r\n flex-direction: column;\r\n align-items: center;\r\n }\r\n }\r\n\r\n .preceptorships-card {\r\n margin: 1%;\r\n width: 40%;\r\n\r\n @media (max-width: 1170px) {\r\n width: 100%;\r\n }\r\n }\r\n`;\r\n\r\nexport const useStyles = makeStyles((theme: Theme) =>\r\n createStyles({\r\n root: {\r\n maxWidth: 1000,\r\n },\r\n media: {\r\n height: 0,\r\n paddingTop: '56.25%',\r\n },\r\n expand: {\r\n transform: 'rotate(0deg)',\r\n marginLeft: 'auto',\r\n transition: theme.transitions.create('transform', {\r\n duration: theme.transitions.duration.shortest,\r\n }),\r\n },\r\n expandOpen: {\r\n transform: 'rotate(180deg)',\r\n },\r\n avatar: {\r\n backgroundColor: '#4472CA',\r\n },\r\n backdrop: {\r\n zIndex: theme.zIndex.drawer + 1,\r\n color: '#fff',\r\n },\r\n }),\r\n);\r\n","import React, { useState, useCallback, useEffect, useRef } from 'react';\r\nimport { useParams } from 'react-router-dom';\r\nimport moment from 'moment';\r\nimport socketio from 'socket.io-client';\r\n\r\nimport { Check, DesktopMac } from '@material-ui/icons';\r\n\r\nimport {\r\n Button,\r\n Typography,\r\n IconButton,\r\n CardActions,\r\n CardContent,\r\n CardHeader,\r\n Card,\r\n Tooltip,\r\n Backdrop,\r\n CircularProgress,\r\n Chip,\r\n Divider,\r\n Breadcrumbs,\r\n Link,\r\n} from '@material-ui/core';\r\n\r\nimport { Container, useStyles } from './styles';\r\n\r\nimport api from '../../services/api';\r\nimport Alert from '../../components/Alert';\r\n\r\nimport { useAuth } from '../../hooks/Auth';\r\nimport { AlertProps } from '../../utils/dtos';\r\n\r\nimport { Preceptorships } from './dtos';\r\n\r\nconst socket = socketio.io(process.env.REACT_APP_PRECEPTORIA_API, {\r\n reconnection: true,\r\n reconnectionDelay: 2000,\r\n timeout: 60000,\r\n});\r\n\r\ninterface PreceptorshipSocket {\r\n preceptorship: string;\r\n group: string;\r\n}\r\n\r\ninterface ActionReducer {\r\n type: string;\r\n payload?: PreceptorshipSocket;\r\n init?: Preceptorships[];\r\n}\r\n\r\ninterface Weekdays {\r\n [key: number]: string;\r\n}\r\n\r\nconst weekDays: Weekdays = {\r\n 1: 'Segunda',\r\n 2: 'Terça',\r\n 3: 'Quarta',\r\n 4: 'Quinta',\r\n 5: 'Sexta',\r\n 6: 'Sábado',\r\n 0: 'Domingo',\r\n};\r\n\r\nconst PreceptorshipsList: React.FC = () => {\r\n const classes = useStyles();\r\n const { token } = useAuth();\r\n const { id, groupId } = useParams();\r\n\r\n const [preceptorships, setPreceptorships] = useState([]);\r\n const ref = useRef(preceptorships);\r\n const [signedIn, setSignedIn] = useState(null);\r\n\r\n const [alert, setAlert] = useState({\r\n isActive: false,\r\n });\r\n\r\n const [loading, setLoading] = useState(true);\r\n\r\n const Authorization = `Bearer ${token}`;\r\n\r\n const handleVacancy = useCallback(\r\n (action: ActionReducer) => {\r\n const currentPreceptorships = ref.current;\r\n let findPrecepIdx = -1;\r\n let findGroupIdx = -1;\r\n\r\n if (action.payload) {\r\n findPrecepIdx = currentPreceptorships.findIndex(\r\n (precep) => precep._id === action.payload?.preceptorship,\r\n );\r\n\r\n findGroupIdx = currentPreceptorships[findPrecepIdx].vacancy.findIndex(\r\n (vacancy) => vacancy.group._id === action.payload?.group,\r\n );\r\n }\r\n\r\n switch (action.type) {\r\n case 'increment':\r\n if (action.payload && findPrecepIdx >= 0 && findGroupIdx >= 0) {\r\n currentPreceptorships[findPrecepIdx].vacancy[findGroupIdx]\r\n .placesLeft++;\r\n }\r\n\r\n currentPreceptorships[findPrecepIdx].students.pop();\r\n ref.current = currentPreceptorships;\r\n setPreceptorships([...currentPreceptorships]);\r\n break;\r\n case 'decrement':\r\n if (action.payload && findPrecepIdx >= 0 && findGroupIdx >= 0) {\r\n currentPreceptorships[findPrecepIdx].vacancy[findGroupIdx]\r\n .placesLeft--;\r\n }\r\n\r\n currentPreceptorships[findPrecepIdx].students.push({\r\n _id: 'fake id',\r\n date: new Date(),\r\n group: 'fake group',\r\n order: 1,\r\n student: 'fake student',\r\n });\r\n ref.current = currentPreceptorships;\r\n setPreceptorships([...currentPreceptorships]);\r\n break;\r\n case 'fetch':\r\n ref.current = action.init || [];\r\n setPreceptorships(action.init || []);\r\n break;\r\n default:\r\n break;\r\n }\r\n },\r\n [ref],\r\n );\r\n\r\n useEffect(() => {\r\n async function getPreceptorships() {\r\n try {\r\n const preceptorshipsResponse = await api.get(\r\n `/students/annualRegistration/${id}/preceptorships`,\r\n {\r\n headers: {\r\n Authorization,\r\n },\r\n },\r\n );\r\n\r\n const signedPreceptorshipsResponse = await api.get(\r\n `/students/annualRegistration/${id}/signedPreceptorships`,\r\n {\r\n headers: {\r\n Authorization,\r\n },\r\n },\r\n );\r\n\r\n if (signedPreceptorshipsResponse.data.length) {\r\n setSignedIn(signedPreceptorshipsResponse.data[0]);\r\n }\r\n\r\n handleVacancy({\r\n type: 'fetch',\r\n init: preceptorshipsResponse.data,\r\n });\r\n\r\n setAlert({\r\n isActive: true,\r\n type: 'success',\r\n message: 'Preceptorias listadas com sucesso.',\r\n });\r\n } catch (error) {\r\n setAlert({\r\n isActive: true,\r\n type: 'error',\r\n message: 'Erro ao listar preceptorias.',\r\n });\r\n } finally {\r\n setLoading(false);\r\n }\r\n }\r\n\r\n getPreceptorships();\r\n }, [handleVacancy]);\r\n\r\n useEffect(() => {\r\n socket.on('increment', (precepSocket: PreceptorshipSocket) => {\r\n handleVacancy({ type: 'increment', payload: precepSocket });\r\n });\r\n }, [handleVacancy]);\r\n\r\n useEffect(() => {\r\n socket.on('decrement', (precepSocket: PreceptorshipSocket) => {\r\n handleVacancy({ type: 'decrement', payload: precepSocket });\r\n });\r\n }, [handleVacancy]);\r\n\r\n const handleAlert = useCallback(() => {\r\n setAlert({ isActive: false });\r\n }, []);\r\n\r\n const handleStudentSign = useCallback(\r\n async (preceptorshipId) => {\r\n setLoading(true);\r\n\r\n try {\r\n // const signedPreceptorshipsResponse = await api.get(\r\n // `/students/annualRegistration/${id}/signedPreceptorships`,\r\n // {\r\n // headers: {\r\n // Authorization,\r\n // },\r\n // },\r\n // );\r\n\r\n // if (signedPreceptorshipsResponse.data.length) {\r\n // const preceptorshipToUnsignId =\r\n // signedPreceptorshipsResponse.data[0]._id;\r\n\r\n // await api.delete(\r\n // `/students/signPreceptorship/${preceptorshipToUnsignId}`,\r\n // {\r\n // headers: {\r\n // Authorization,\r\n // },\r\n // },\r\n // );\r\n // }\r\n\r\n const newSignedPreceptorship = await api.post(\r\n `/students/signPreceptorship`,\r\n {\r\n groupId,\r\n preceptorshipId,\r\n registrationId: id,\r\n },\r\n {\r\n headers: {\r\n Authorization,\r\n },\r\n },\r\n );\r\n\r\n setSignedIn(newSignedPreceptorship.data);\r\n\r\n setAlert({\r\n isActive: true,\r\n type: 'success',\r\n message: 'Incrição realizada com sucesso!',\r\n });\r\n } catch (error) {\r\n setAlert({\r\n isActive: true,\r\n type: 'error',\r\n message: 'Erro ao inscrever-se em uma preceptoria.',\r\n });\r\n } finally {\r\n setLoading(false);\r\n }\r\n },\r\n [id, groupId, Authorization],\r\n );\r\n\r\n const renderSubscribeButton = useCallback(\r\n (preceptorship: Preceptorships) => {\r\n const isSubscribed = signedIn?._id === preceptorship._id;\r\n const isFull =\r\n preceptorship.totalStudents === preceptorship.students.length;\r\n const isFilled =\r\n preceptorship.vacancy.find((v) => v.group._id === groupId)\r\n ?.placesLeft === 0;\r\n\r\n let label;\r\n\r\n if (isSubscribed) {\r\n label = 'Inscrito';\r\n } else if (isFilled || isFull) {\r\n label = 'Lotado';\r\n } else {\r\n label = 'Inscrever-se';\r\n }\r\n\r\n return (\r\n <>\r\n handleStudentSign(preceptorship._id)}\r\n >\r\n {label}\r\n \r\n\r\n {isSubscribed && }\r\n \r\n );\r\n },\r\n [signedIn, groupId, handleStudentSign],\r\n );\r\n\r\n return (\r\n \r\n \r\n \r\n Dashboard\r\n \r\n \r\n Incrições anuais\r\n \r\n Turmas Preceptorias\r\n \r\n\r\n
\r\n {!preceptorships.length && !loading && (\r\n \r\n \r\n \r\n Nenhuma turma cadastrada para esse ano.\r\n \r\n \r\n \r\n )}\r\n\r\n \r\n \r\n \r\n\r\n {preceptorships?.map((preceptorship) => (\r\n
\r\n \r\n \r\n }\r\n subheader={`${moment(preceptorship.startTime).format(\r\n 'HH:mm',\r\n )} às ${moment(preceptorship.endTime).format('HH:mm')}`}\r\n />\r\n\r\n \r\n\r\n \r\n \r\n Coordenadores\r\n \r\n\r\n \r\n {preceptorship.coordinators.map((coord) => (\r\n \r\n ))}\r\n \r\n\r\n \r\n Distribuição das Vagas\r\n \r\n\r\n \r\n {preceptorship.vacancy.map((v) => (\r\n \r\n ))}\r\n \r\n \r\n\r\n \r\n \r\n {renderSubscribeButton(preceptorship)}\r\n \r\n\r\n
\r\n \r\n \r\n \r\n
\r\n \r\n
\r\n
\r\n ))}\r\n
\r\n\r\n {alert.isActive && (\r\n \r\n {alert.message}\r\n \r\n )}\r\n
\r\n );\r\n};\r\n\r\nexport default PreceptorshipsList;\r\n","import React, { useCallback, useState, useRef } from 'react';\r\nimport clsx from 'clsx';\r\nimport * as Yup from 'yup';\r\nimport { FormHandles } from '@unform/core';\r\n\r\nimport {\r\n AppBar,\r\n Toolbar,\r\n MenuItem,\r\n Menu,\r\n CssBaseline,\r\n IconButton,\r\n useTheme,\r\n Divider,\r\n Avatar,\r\n} from '@material-ui/core';\r\n\r\nimport { Switch, useRouteMatch } from 'react-router-dom';\r\n\r\nimport { useAuth } from '../../hooks/Auth';\r\nimport Logo from '../../assets/Ceapia-02.png';\r\nimport Route from '../../routes/Route';\r\n\r\nimport Input from '../../components/Input';\r\nimport Alert from '../../components/Alert';\r\nimport DialogForm from '../../components/DialogForm';\r\n\r\nimport { UpdateAdminData } from './dtos';\r\nimport { Container, Header, useStyles } from './styles';\r\n\r\nimport api from '../../services/api';\r\nimport Registration from '../AnnualRegistation';\r\nimport Preceptorships from '../Preceptorships';\r\n\r\nimport { AlertProps } from '../../utils/dtos';\r\nimport getValidationErrors from '../../utils/getValidationErrors';\r\n\r\nconst Dashboard: React.FC = () => {\r\n const classes = useStyles();\r\n const theme = useTheme();\r\n const [open, setOpen] = useState(false);\r\n const formRefUpdate = useRef(null);\r\n const [myDataOpen, setMyDataOpen] = useState(false);\r\n // const [admin, setAdmin] = useState({} as Admin);\r\n const [alert, setAlert] = useState({\r\n isActive: false,\r\n });\r\n\r\n const [anchorEl, setAnchorEl] = React.useState(null);\r\n const openMenu = Boolean(anchorEl);\r\n\r\n const { logout, user, token } = useAuth();\r\n const { path } = useRouteMatch();\r\n\r\n const Authorization = `Bearer ${token}`;\r\n\r\n const handleMenu = (event: React.MouseEvent) => {\r\n setAnchorEl(event.currentTarget);\r\n };\r\n\r\n const handleClose = () => {\r\n setAnchorEl(null);\r\n };\r\n\r\n const handleAlert = useCallback(() => {\r\n setAlert({ isActive: false });\r\n }, []);\r\n\r\n const handleMyDataOpen = useCallback(async () => {\r\n try {\r\n const response = await api.get(`/admins/me`, {\r\n headers: {\r\n Authorization,\r\n },\r\n });\r\n\r\n // setAdmin(response.data);\r\n setMyDataOpen(true);\r\n } catch (error) {\r\n setAlert({\r\n isActive: true,\r\n type: 'error',\r\n message: 'Erro ao buscar dados do perfil.',\r\n });\r\n } finally {\r\n handleClose();\r\n }\r\n }, []);\r\n\r\n const handleMyDataClose = () => {\r\n setMyDataOpen(false);\r\n };\r\n\r\n const handleSubmit = useCallback(async (data: UpdateAdminData) => {\r\n try {\r\n formRefUpdate.current?.setErrors({});\r\n\r\n const schema = Yup.object().shape({\r\n name: Yup.string().required('Nome obrigatório'),\r\n email: Yup.string()\r\n .email('Digite um e-mail válido.')\r\n .required('E-mail obrigatório.'),\r\n password: Yup.string(),\r\n passwordConfirm: Yup.string().oneOf(\r\n [Yup.ref('password')],\r\n 'Senhas devem ser iguais.',\r\n ),\r\n });\r\n\r\n await schema.validate(data, { abortEarly: false });\r\n\r\n const { password } = data;\r\n\r\n if (!password) {\r\n delete data.password;\r\n delete data.passwordConfirm;\r\n }\r\n\r\n await api.put(`/admins`, data, {\r\n headers: {\r\n Authorization,\r\n },\r\n });\r\n\r\n setAlert({\r\n isActive: true,\r\n type: 'success',\r\n message: 'Perfil atualizado com sucesso.',\r\n });\r\n\r\n handleMyDataClose();\r\n window.location.reload(false);\r\n } catch (error) {\r\n if (error instanceof Yup.ValidationError) {\r\n const errors = getValidationErrors(error);\r\n\r\n formRefUpdate.current?.setErrors(errors);\r\n } else {\r\n setAlert({\r\n isActive: true,\r\n type: 'error',\r\n message: 'Erro ao atualizar perfil.',\r\n });\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\n \r\n \r\n
\r\n \r\n \r\n \r\n
\r\n \r\n
\r\n\r\n
\r\n \r\n \r\n\r\n \r\n {`${user.name.split(' ')[0][0]}${user.name.split(' ')[1][0]}`}\r\n \r\n \r\n\r\n \r\n Meus dados\r\n Sair\r\n \r\n
\r\n
\r\n \r\n\r\n
\r\n
\r\n\r\n
\r\n
\r\n

{`Bem-vindo, ${user.name}`}

\r\n {user.email}\r\n
\r\n
\r\n\r\n \r\n\r\n \r\n \r\n \r\n \r\n
\r\n
\r\n );\r\n {alert.isActive && (\r\n \r\n {alert.message}\r\n \r\n )}\r\n
\r\n );\r\n};\r\n\r\nexport default Dashboard;\r\n","import React from 'react';\r\n\r\nconst NotFound: React.FC = () => {\r\n return

Not Found

;\r\n};\r\n\r\nexport default NotFound;\r\n","import React from 'react';\r\nimport { Switch } from 'react-router-dom';\r\n\r\nimport Login from '../pages/Login';\r\nimport Dashboard from '../pages/Dashboard';\r\nimport NotFound from '../pages/NotFound';\r\n\r\nimport Route from './Route';\r\n\r\nconst Routes: React.FC = () => (\r\n \r\n \r\n \r\n \r\n \r\n);\r\n\r\nexport default Routes;\r\n","import React from 'react';\r\n\r\nimport { AuthProvider } from './Auth';\r\n\r\nconst hooks: React.FC = ({ children }) => (\r\n \r\n {children}\r\n \r\n);\r\n\r\nexport default hooks;\r\n","import { createGlobalStyle } from 'styled-components';\r\n\r\nexport default createGlobalStyle`\r\n * {\r\n margin: 0;\r\n padding: 0;\r\n box-sizing: border-box;\r\n outline: 0;\r\n }\r\n\r\n body {\r\n background: #f4f4f4;\r\n -webkit-font-smoothing: antialiased;\r\n }\r\n\r\n body, input, button {\r\n font-family: 'Roboto', sans-serif;\r\n font-size: 16px;\r\n }\r\n\r\n h1, h2, h3, h4, h5, h6, strong {\r\n font-weight: 500;\r\n }\r\n\r\n button {\r\n cursor: pointer;\r\n }\r\n\r\n.student-card, .admin-card, .group-card, .coordinator-card, .room-card, .registration-card {\r\n * {\r\n max-width: 100%;\r\n }\r\n}\r\n`;\r\n\r\n// https://coolors.co/e63946-f1faee-a8dadc-457b9d-1d3557\r\n// https://coolors.co/c5d5ea-759eb8-7392b7-b3c5d7-d8e1e9\r\n// https://coolors.co/d64045-e9fff9-9ed8db-467599-1d3354\r\n// https://coolors.co/0a369d-4472ca-5e7ce2-92b4f4-cfdee7\r\n","import React from 'react';\r\nimport { BrowserRouter } from 'react-router-dom';\r\n\r\nimport Routes from './routes';\r\nimport Providers from './hooks';\r\n\r\nimport GlobalStyle from './styles/global';\r\n\r\nfunction App() {\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\nexport default App;\r\n","import React from 'react';\r\nimport ReactDOM from 'react-dom';\r\n\r\nimport App from './App';\r\n\r\nReactDOM.render(\r\n \r\n \r\n ,\r\n document.getElementById('root')\r\n);\r\n"],"sourceRoot":""}