{"version":3,"sources":["images/logo.svg","images/logo-image-white.png","images/onboarding.png","images/hero-image.svg","images/empty-listing.svg","images/hero-image-2.svg","images/hero-image-3.svg","images/hero-image-4.svg","images/hero-image-5.svg","images/hero-image-6.svg","images/hero-image-7.svg","images/plus.svg","images/github.svg","images/linkedin.svg","images/add-file.svg","images/people2.png","images/emptyNotifications.svg","images/add-user.svg","images/resetPassword.svg","images/man-working.svg","images/big-leaf-plant.svg","images/treasure-chest.svg","images/hanging-bulbs.svg","images/right-drawn-arrow.svg","images/empty-matching.svg","images/empty-matching-animated.svg","images/pool-recommendation.svg","images/screened-pipe.svg","common/navigation-menu/navigation-menu.js","common/navigation/profile-dropdown/profileDropdown.js","services/notifications/getNotifications.js","services/notifications/updateAllNotificationAsSeen.js","controllers/notifications/updateAllNotificationAsSeen.js","controllers/notifications/getNotifications.js","common/navigation/notification/emptyNotification.js","controllers/notifications/formatNotifications.js","common/navigation/notification/notificationTypes/leadsNotification.js","common/navigation/notification/notificationTypes/applicantsNotification.js","common/navigation/notification/notificationTypes/missingJobFieldsNotification.js","common/navigation/notification/notificationList.js","common/navigation/notification/notification.js","common/navigation/menu/menu.js","common/navigation/navigation.js","common/auto-suggest/autoSuggest.js","common/chip/chip.js","common/chip-checkbox/chipCheckbox.js","common/radio/radio.js","common/slider/slider.js","common/avatar/avatar.js","common/snackbar/snackbar.js","common/charts/barChart.js","common/charts/funnelChart.js","common/charts/radarChart.js","common/charts/heatMap.js","common/image-viewer/imageViewer.js","utils/constants.js","controllers/taxonomies.js","controllers/job.js","core/srIconButton/srIconButton.js","services/authentication/signup.js","services/authentication/verifyEmail.js","services/authentication/resendVerificationEmail.js","controllers/authenticationController.js","utils/date.js","controllers/user/toggleMenu.js","../node_modules/@material-ui/core/esm/InputLabel/InputLabel.js","../node_modules/@material-ui/core/esm/TextField/TextField.js","../node_modules/@material-ui/core/esm/FormHelperText/FormHelperText.js","../node_modules/@material-ui/icons/esm/Copyright.js","common/footer/footer.js","common/topBar/topBar.js","../node_modules/@material-ui/icons/esm/Favorite.js","../node_modules/@material-ui/core/esm/InputAdornment/InputAdornment.js","../node_modules/@material-ui/icons/esm/Visibility.js","../node_modules/@material-ui/icons/esm/VisibilityOff.js","components/login/login.js","components/login/loginContainer.js"],"names":["useStyles","makeStyles","theme","root","color","background","paper","marginRight","spacing","modal","maxWidth","margin","padding","height","overflow","connect","state","selectedJob","job","props","classes","React","useState","showMenu","setShowMenu","showModal","setShowModal","anchorRef","useRef","errorFlag","jobRole","changeLocation","location","history","push","fetchJobTitles","value","a","jobTitles","titles","response","map","title","handleClose","event","handleModalOpen","handleModalClose","IconButton","ref","aria-controls","undefined","aria-haspopup","onClick","prevOpen","Add","Popper","open","anchorEl","current","role","transition","disablePortal","TransitionProps","placement","Grow","style","transformOrigin","Paper","ClickAwayListener","onClickAway","MenuList","autoFocusItem","id","MenuItem","src","IMG_FILE_ICON","alt","Modal","onClose","aria-labelledby","aria-describedby","className","Grid","container","item","xs","borderBottom","position","Typography","variant","top","right","gutterBottom","Button","placeholder","name","onChange","e","target","updateJob","fetchSuggestions","onSelect","suggestion","errorMessage","ProfileDropdown","handleToggle","currentTarget","setState","this","userName","logout","width","fontSize","modifiers","offset","Box","Tune","ExitToApp","PureComponent","getNotificationsService","Authorization","userId","pageParams","options","method","headers","params","getParamsBuilder","fetchLib","SERVICE_URL","status","getStatus","getJson","data","updateAllNotificationAsSeenService","updateAllNotificationAsSeen","authorization","getAuthorization","uid","getStore","user","details","getNotifications","isLoadMore","notifications","paginationParams","page","size","newNotifications","notificationsList","list","content","dispatch","type","SET_NOTIFICATIONS","count","notificationCount","currentPage","pageSize","hasMore","totalPage","toggleNotificationBar","showNotifications","document","body","emptyNotificationsText","lineHeight","letterSpacing","emptyNotificationsContainer","display","alignItems","justifyContent","flexDirection","emptyNotificationsImage","EmptyNotification","IMG_EMPTY_NOTIFICATIONS","getDateInNotificationFormat","date","sendInNormalFormat","months","d","getDate","m","getMonth","y","getFullYear","suffix","getNumberSuffix","i","j","k","getTimeAMPMFormat","hours","getHours","minutes","getMinutes","ampm","NotificationContainer","textAlign","fontWeight","LineWeight","marginBottom","icon","borderRadius","detailsContainer","notificationText","link","LeadsNotification","notification","time","jsonMessage","url","window","origin","jobId","href","rel","ApplicantsNotification","missingField","marginLeft","missingFieldIcon","MissingJobFieldsNotification","skillsContainer","missingFields","field","Icon","WorkOutlineIcon","Experience","SignalCellularAltIcon","Skills","StarsIcon","renderField","NotificationsContainer","dateTitle","marginTop","loadMoreButtonContainer","loadMoreButton","minWidth","boxShadow","backgroundColor","NotificationList","loadMore","listWithDates","Date","creationTime","JSON","parse","message","uniqueDates","reduce","acc","dateObject","formattedDate","returnDate","isToday","notificationList","dates","formatNotifications","datesArray","Object","keys","notificationType","renderNotification","drawerContainer","backdrop","zIndex","notificationHeader","headerText","headerCloseIcon","cursor","Notification","isOpen","toggleView","useSelector","hasNotifications","Boolean","length","useEffect","Backdrop","Drawer","anchor","paddingTop","menuItem","borderLeft","paddingLeft","menuItemSelected","Menu","useHistory","selectedPath","pathname","MENU_MAP","FindInPage","onRouteChange","BubbleChart","PaymentSharp","MonetizationOn","navigateTo","RenderMenuItem","isSelected","clsx","Navigation","toggleNotificationView","isMenuOpen","AppBar","Toolbar","MenuIcon","toggleMenu","selected","IMG_LOGO","paddingRight","alignSelf","Badge","badgeContent","overlap","Notifications","withRouter","AutoSuggest","onClear","suggestions","onFetch","reason","getSuggestions","renderSuggestion","getSuggestionValue","onEnter","enableSelectionOnEnter","key","trim","renderInputComponent","onKeyPress","InputComponent","onSuggestionSelected","onSuggestionsFetchRequested","onSuggestionsClearRequested","inputProps","defaultProps","CommonChip","onDelete","onDeleteChip","label","onHover","showDelete","deleteChip","clickable","isPrimary","Chip","onMouseEnter","onMouseLeave","avatar","Avatar","Check","CommonRadio","items","FormControl","component","mb","FormLabel","RadioGroup","row","FormControlLabel","control","Radio","labelPlacement","uuid","SenseLoafSlider","withStyles","valueLabel","left","Slider","CommonSlider","sliderValue","prevProps","max","valueLabelFormat","v","onChangeCommitted","valueLabelDisplay","CommonAvatar","generateColor","str","s","l","hash","charCodeAt","getInitials","split","substring","toUpperCase","slice","join","initials","border","CommonSnackbar","getMessage","flag","autoCloseSnackbar","setFlag","Snackbar","anchorOrigin","vertical","horizontal","autoHideDuration","ContentProps","BarChart","tooltipLabel","credits","enabled","colors","chart","text","xAxis","categories","lineWidth","labels","align","reserveSpace","format","formatter","o","useHTML","yAxis","tickLength","gridLineWidth","plotOptions","column","pointPadding","borderWidth","states","hover","tooltip","borderColor","shadow","shape","distance","pointFormat","headerFormat","legend","series","highcharts","Highcharts","HighchartsMore","labelNumber","fontFamily","fontStyle","labelText","FunnelChart","chartLabels","tickAmount","min","point","index","x","polygon","enableMouseTracking","immutable","RadarChart","polar","pane","startAngle","endAngle","tickInterval","pointStart","pointInterval","pointFormatter","HighchartsHeatmap","HeatMap","labelsX","labelsY","days","reversed","opposite","showLastLabel","colorAxis","minColor","maxColor","dataLabels","ImageViewer","children","initialScale","disablePadding","minScale","centerZoomedOut","centerOnInit","minPositionX","minPositionY","zoomIn","zoomOut","resetTransform","Fragment","wrapperStyle","contentStyle","DEFAULT_PERKS","DEFAULT_JOB_TITLES","CLOSING_JOB_CHIPS","REJECT_CANDIDATE_CHIPS","DEFAULT_LOCATIONS_INDIA","DEFAULT_LOCATIONS_USA","TALENT_STATUS","SOURCE","APPLICANTS","LEADS","applicantsTab","tabLabel","sideBarLinks","displayLabel","statusTypes","favourite","leadsTab","favouriteLinks","applied","candidates","reached","NO_CANDIDATE_ERRORS","shortlisted","interview","hired","offered","rejected","default","CREATE_JOB_IGNORE_FIELDS","JOB_DISPLAY_TYPE","CREATE","EDIT","CANDIDATE_LISTING_SORT_OPTIONS","MONTH_SHORT","search","autoSuggestionService","console","error","company","jobTitlesService","skillsRecommendation","skillsArray","skillsRecommendationService","skills","skillService","getjobs","filter","prevPage","listing","selectedPage","resetJoblist","getJobsService","contentPromise","getJobStatsByIdService","then","jobStatusCounts","totalApplicants","totalLeads","totalScreened","Promise","all","getJobStatsByUserIdService","jobStatsData","stats","Array","isArray","forEach","jobStatus","toLowerCase","SET_JOB_LISTING","deleteJobs","jobids","deleteJobsService","editJob","organizationId","organizationInfo","jobDetails","editJobService","getPoolSize","createJob","createJobService","getJobById","getJobByIdService","SET_SELECTED_JOB","initializeJob","RESET_SELECTED_JOB","payload","UPDATE_SELECTED_JOB","isFiltered","appliedFilters","from","to","addCollege","college","ADD_COLLEGE","removeCollege","REMOVE_COLLEGE","addDomain","domain","ADD_DOMAIN","removeDomain","REMOVE_DOMAIN","fill","selectedIcon","SrIconButton","disabled","WrapInTooltip","signupService","signupFields","stringify","verifyEmailService","verifyEmailPayload","resendVerificationEmailService","emailId","address","login","password","loginService","authToken","setAuthorization","getUserDetails","msg","onBoarded","signup","firstName","lastName","workEmail","companyName","enterPassword","organizationName","phone","subscribedProduct","timeZone","faultDetail","verifyEmail","secretCode","resendVerificationEmail","dateDiff","date1","date2","dt1Date","dt1Month","dt1Year","dt2","dt2Year","dt2Month","dt2Date","dt2Hours","Math","floor","UTC","today","getDateByMonthAndYear","month","year","SET_MENU_VISIBILITY","InputLabel","_props$disableAnimati","disableAnimation","shrinkProp","shrink","other","_objectWithoutProperties","muiFormControl","useFormControl","filled","focused","adornedStart","fcs","formControlState","_extends","formControl","animated","marginDense","outlined","required","asterisk","transform","transitions","create","duration","shorter","easing","easeOut","pointerEvents","variantComponent","standard","Input","FilledInput","OutlinedInput","TextField","autoComplete","_props$autoFocus","autoFocus","_props$color","defaultValue","_props$disabled","_props$error","FormHelperTextProps","_props$fullWidth","fullWidth","helperText","hiddenLabel","InputLabelProps","InputProps","inputRef","_props$multiline","multiline","onBlur","onFocus","_props$required","rows","rowsMax","_props$select","select","SelectProps","_props$variant","InputMore","notched","_InputLabelProps$requ","displayRequired","native","helperTextId","concat","inputLabelId","InputElement","htmlFor","Select","labelId","input","FormHelperText","_props$component","Component","contained","dangerouslySetInnerHTML","__html","palette","secondary","typography","caption","main","createSvgIcon","Footer","IMG_LOGO_WHITE","Copyright","Favorite","TopBar","InputAdornment","_props$disablePointer","disablePointerEvents","_props$disableTypogra","disableTypography","variantProp","FormControlContext","Provider","positionStart","positionEnd","maxHeight","whiteSpace","Login","preventDefault","email","onLogin","showPassword","onChangePasswordVisibility","onClickForgotPassword","onClickSignup","IMG_PLUS","mt","endAdornment","aria-label","onMouseDown","Visibility","VisibilityOff","LoginContainer","onChangeHandler","onLoginHandler","loading","localStorage","getItem","setItem","prevState"],"mappings":"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","file":"static/js/18.a9b89fc8.chunk.js","sourcesContent":["export default __webpack_public_path__ + \"static/media/logo.53d5d978.svg\";","export default \"\"","export default __webpack_public_path__ + \"static/media/onboarding.46653535.png\";","export default __webpack_public_path__ + \"static/media/hero-image.6089457e.svg\";","export default __webpack_public_path__ + \"static/media/empty-listing.34aef5e4.svg\";","export default __webpack_public_path__ + \"static/media/hero-image-2.78a7e2ec.svg\";","export default __webpack_public_path__ + \"static/media/hero-image-3.c1ca8d7d.svg\";","export default __webpack_public_path__ + \"static/media/hero-image-4.cac42305.svg\";","export default __webpack_public_path__ + \"static/media/hero-image-5.4e4c55e9.svg\";","export default __webpack_public_path__ + \"static/media/hero-image-6.1a9f0779.svg\";","export default __webpack_public_path__ + \"static/media/hero-image-7.403765d8.svg\";","export default __webpack_public_path__ + \"static/media/plus.7c053453.svg\";","export default __webpack_public_path__ + \"static/media/github.e7bda480.svg\";","export default __webpack_public_path__ + \"static/media/linkedin.b4a49baa.svg\";","export default __webpack_public_path__ + \"static/media/add-file.3ad2b9e3.svg\";","export default __webpack_public_path__ + \"static/media/people2.168ece9f.png\";","export default __webpack_public_path__ + \"static/media/emptyNotifications.e729ed87.svg\";","export default __webpack_public_path__ + \"static/media/add-user.45de2c18.svg\";","export default __webpack_public_path__ + \"static/media/resetPassword.bb889e6f.svg\";","export default __webpack_public_path__ + \"static/media/man-working.fa3827d2.svg\";","export default __webpack_public_path__ + \"static/media/big-leaf-plant.153953f8.svg\";","export default __webpack_public_path__ + \"static/media/treasure-chest.f9c6bf6c.svg\";","export default __webpack_public_path__ + \"static/media/hanging-bulbs.585bf65f.svg\";","export default __webpack_public_path__ + \"static/media/right-drawn-arrow.7bc1b07e.svg\";","export default __webpack_public_path__ + \"static/media/empty-matching.8fb3a76e.svg\";","export default __webpack_public_path__ + \"static/media/empty-matching-animated.28f0948b.svg\";","export default __webpack_public_path__ + \"static/media/pool-recommendation.dbf84142.svg\";","export default __webpack_public_path__ + \"static/media/screened-pipe.82819705.svg\";","import React from 'react';\nimport IconButton from '@material-ui/core/IconButton';\nimport ClickAwayListener from '@material-ui/core/ClickAwayListener';\nimport { connect } from 'react-redux';\nimport Grow from '@material-ui/core/Grow';\nimport Paper from '@material-ui/core/Paper';\nimport Popper from '@material-ui/core/Popper';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport MenuList from '@material-ui/core/MenuList';\nimport Grid from '@material-ui/core/Grid';\nimport Button from '@material-ui/core/Button';\nimport Typography from '@material-ui/core/Typography';\nimport Modal from '@material-ui/core/Modal';\nimport CloseIcon from '@material-ui/icons/Close';\nimport { makeStyles } from '@material-ui/core/styles';\nimport { Add } from '@material-ui/icons';\nimport { IMG_FILE_ICON } from 'images';\nimport { jobTitles } from 'controllers/taxonomies';\nimport { AutoSuggest } from '../../common';\nimport { updateJob } from 'controllers/job';\n\nconst useStyles = makeStyles((theme) => ({\n root: {\n color: '#ffffff',\n background: '#49515a',\n },\n paper: {\n marginRight: theme.spacing(2),\n },\n modal: {\n background: '#ffffff',\n maxWidth: '888px',\n margin: '66px auto 0',\n padding: '1px',\n height: 'calc(100vh - 132px)',\n overflow: 'auto',\n },\n}));\n\nfunction NavigationMenu(props) {\n const classes = useStyles();\n const [showMenu, setShowMenu] = React.useState(false);\n const [showModal, setShowModal] = React.useState(false);\n const anchorRef = React.useRef(null);\n const { errorFlag, jobRole } = props;\n\n const changeLocation = (location) => () => {\n const { history } = props;\n history.push(location);\n };\n\n const fetchJobTitles = async (value) => {\n const titles = await jobTitles(value);\n return await titles.response.map((title) => title['job title']);\n };\n\n const handleToggle = () => {\n setShowMenu((prevOpen) => !prevOpen);\n };\n\n const handleClose = (event) => {\n setShowMenu(false);\n };\n\n const handleModalOpen = () => {\n // setShowModal(true);\n // setShowMenu(false);\n changeLocation('/create-job')();\n };\n\n const handleModalClose = () => {\n setShowModal(false);\n };\n\n const onUpdateJobHandler = (e) => {\n if (e.target.name) {\n updateJob({\n [e.target.name]: e.target.value,\n });\n }\n };\n\n const onSelectJobRole = (e, value) => {\n const { history } = props;\n updateJob({\n jobRole: value.suggestion,\n });\n history.push('/create-job');\n };\n\n return (\n
\n
\n \n \n \n \n {({ TransitionProps, placement }) => (\n \n \n \n \n \n \n Create Job\n \n \n \n \n \n )}\n \n
\n \n
\n \n \n Create new Job descreption\n \n \n \n \n \n \n Create from Scratch\n \n \n CREATE\n \n \n \n \n Create from previous Job Decreptions\n \n \n Select the Job description from the list of previously create\n and tailor it to suit your current requirement.\n \n \n \n \n
\n \n
\n );\n}\n\nconst mapStateToProps = (state) => {\n const { selectedJob } = state.job;\n return {\n ...selectedJob,\n };\n};\n\nexport default connect(mapStateToProps, null)(NavigationMenu);\n","import React, { PureComponent } from 'react';\nimport ClickAwayListener from '@material-ui/core/ClickAwayListener';\nimport Grow from '@material-ui/core/Grow';\nimport Paper from '@material-ui/core/Paper';\nimport Popper from '@material-ui/core/Popper';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport MenuList from '@material-ui/core/MenuList';\nimport { Avatar } from 'common';\nimport { Box, Typography } from '@material-ui/core';\nimport './profileDropdown.scss';\nimport { ExitToApp, Tune } from '@material-ui/icons';\n\nclass ProfileDropdown extends PureComponent {\n constructor() {\n super();\n this.state = {\n anchorEl: null,\n open: false,\n };\n }\n\n handleToggle = (event = {}) => {\n if (event.currentTarget) {\n this.setState({\n anchorEl: event.currentTarget,\n open: true,\n });\n\n return true;\n }\n\n this.setState({\n open: false,\n anchorEl: null,\n });\n };\n\n handleClose = () => {\n this.handleToggle();\n };\n\n render() {\n const { userName, logout, changeLocation } = this.props;\n const { open, anchorEl } = this.state;\n\n return (\n
\n
\n \n \n {({ TransitionProps }) => (\n \n \n \n \n \n \n Signed in as\n \n \n {userName}\n \n \n
\n \n Apps & Integrations\n \n \n Log out\n \n
\n
\n
\n
\n )}\n \n
\n
\n );\n }\n}\n\nexport default ProfileDropdown;\n","import { fetchLib, getJson, getStatus, getParamsBuilder } from 'utils';\nimport { SERVICE_URL } from '../constants';\n\nexport const getNotificationsService = async (\n Authorization,\n userId,\n pageParams\n) => {\n const options = {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json',\n Authorization,\n },\n };\n\n const params = getParamsBuilder(pageParams);\n\n const response = await fetchLib(\n `${SERVICE_URL}api/notification/${userId}${params}`,\n options\n );\n const status = getStatus(response);\n const data = await getJson(response);\n\n return {\n status,\n data,\n };\n};\n","import { fetchLib, getStatus } from 'utils';\nimport { SERVICE_URL } from '../constants';\n\nexport const updateAllNotificationAsSeenService = async (\n Authorization,\n userId\n) => {\n const options = {\n method: 'PATCH',\n headers: {\n 'Content-Type': 'application/json',\n Authorization,\n },\n };\n\n const response = await fetchLib(\n `${SERVICE_URL}api/notification/${userId}`,\n options\n );\n const status = getStatus(response);\n\n return {\n status,\n };\n};\n","import { getAuthorization, getStore } from 'controllers/controller';\nimport { updateAllNotificationAsSeenService } from 'services/notifications/updateAllNotificationAsSeen';\n\nexport const updateAllNotificationAsSeen = async () => {\n const authorization = getAuthorization();\n const uid = getStore().user.details.userId;\n\n await updateAllNotificationAsSeenService(authorization, uid);\n\n return true;\n};\n","import { SET_NOTIFICATIONS } from 'actions/constants';\nimport { dispatch, getAuthorization, getStore } from 'controllers/controller';\nimport { getNotificationsService } from 'services/notifications/getNotifications';\nimport { updateAllNotificationAsSeen } from './updateAllNotificationAsSeen';\n\nexport const getNotifications = async (isLoadMore = false) => {\n const authorization = getAuthorization();\n const uid = getStore().user.details.userId;\n const notifications = getStore().user.notifications;\n const paginationParams = {\n page: isLoadMore ? notifications.page + 1 : 0,\n size: notifications.size,\n };\n\n const { data } = await getNotificationsService(\n authorization,\n uid,\n paginationParams\n );\n\n const newNotifications = data.response;\n\n const notificationsList = isLoadMore\n ? [...notifications.list, ...newNotifications.content]\n : newNotifications.content;\n\n dispatch({\n type: SET_NOTIFICATIONS,\n notifications: {\n list: notificationsList,\n count: newNotifications.notificationCount,\n page: newNotifications.currentPage,\n size: newNotifications.pageSize,\n hasMore: newNotifications.totalPage > newNotifications.currentPage + 1,\n },\n });\n};\n\nexport const toggleNotificationBar = (showNotifications) => {\n const { count } = getStore().user.notifications;\n\n if (!showNotifications) {\n document.body.style.overflow = 'auto';\n getNotifications();\n } else {\n document.body.style.overflow = 'hidden';\n\n if (count) {\n updateAllNotificationAsSeen();\n }\n }\n\n dispatch({\n type: SET_NOTIFICATIONS,\n notifications: { showNotifications },\n });\n};\n","import React from 'react';\nimport { Grid, makeStyles, Typography } from '@material-ui/core';\nimport { IMG_EMPTY_NOTIFICATIONS } from 'images';\n\nconst useStyles = makeStyles({\n emptyNotificationsText: {\n fontSize: '16px',\n lineHeight: '20px',\n letterSpacing: '0.49px',\n color: 'rgba(0,0,0,0.87)',\n },\n emptyNotificationsContainer: {\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n flexDirection: 'column',\n },\n emptyNotificationsImage: {\n padding: '55px 0 24px',\n },\n});\n\nexport const EmptyNotification = () => {\n const classes = useStyles();\n\n return (\n \n \n \n All notifications are caught up.\n \n \n );\n};\n","import { isToday } from 'utils/date';\n\nexport const formatNotifications = (list = []) => {\n const listWithDates = list.map((notification) => ({\n ...notification,\n time: getTimeAMPMFormat(new Date(notification.creationTime)),\n date: getDateInNotificationFormat(\n new Date(notification.creationTime),\n true\n ),\n jsonMessage: JSON.parse(notification.message),\n }));\n const uniqueDates = listWithDates.reduce((acc, { creationTime, date }) => {\n const dateObject = new Date(creationTime);\n const formattedDate = getDateInNotificationFormat(dateObject);\n const isTodaysDate = isToday(dateObject);\n const returnDate = isTodaysDate ? 'Today' : formattedDate;\n return { ...acc, [date]: returnDate };\n }, {});\n\n const notificationList = listWithDates.reduce((acc, notification) => {\n if (acc[notification.date]) {\n return {\n ...acc,\n [notification.date]: [...acc[notification.date], notification],\n };\n }\n\n return { ...acc, [notification.date]: [notification] };\n }, {});\n\n return { dates: uniqueDates, list: notificationList };\n};\n\nconst getDateInNotificationFormat = (date, sendInNormalFormat = false) => {\n const months = [\n '',\n 'Jan',\n 'Feb',\n 'March',\n 'April',\n 'May',\n 'June',\n 'July',\n 'August',\n 'September',\n 'Oct',\n 'Nov',\n 'Dec',\n ];\n\n const d = date.getDate();\n const m = date.getMonth();\n const y = date.getFullYear();\n\n const suffix = getNumberSuffix(d);\n\n if (sendInNormalFormat) {\n return `${d}-${m}-${y}`;\n }\n return `${suffix} ${months[m]} ${y}`;\n};\n\nconst getNumberSuffix = (i) => {\n const j = i % 10;\n const k = i % 100;\n\n if (j === 1 && k !== 11) {\n return i + 'st';\n }\n\n if (j === 2 && k !== 12) {\n return i + 'nd';\n }\n\n if (j === 3 && k !== 13) {\n return i + 'rd';\n }\n\n return i + 'th';\n};\n\nconst getTimeAMPMFormat = (date) => {\n let hours = date.getHours();\n let minutes = date.getMinutes();\n const ampm = hours >= 12 ? 'PM' : 'AM';\n hours = hours % 12;\n hours = hours ? hours : 12; // the hour '0' should be '12'\n hours = hours < 10 ? '0' + hours : hours;\n // appending zero in the start if hours less than 10\n minutes = minutes < 10 ? '0' + minutes : minutes;\n return hours + ':' + minutes + ' ' + ampm;\n};\n","import React from 'react';\nimport { Grid, makeStyles, Typography } from '@material-ui/core';\nimport GroupIcon from '@material-ui/icons/Group';\n\nconst useStyles = makeStyles({\n NotificationContainer: {\n padding: '10px 3.5px 20.5px 13px',\n borderBottom: '1px solid rgba(0, 0, 0, 0.2)',\n },\n date: {\n color: '#a4a8ac',\n textAlign: 'right',\n fontSize: '12px',\n fontWeight: 'normal',\n LineWeight: 1.67,\n letterSpacing: '0.22px',\n marginBottom: '3px',\n },\n icon: {\n background: '#fedb75',\n height: '24px',\n width: '24px',\n padding: '4px',\n borderRadius: '100%',\n marginRight: '15.5px',\n },\n detailsContainer: {\n display: 'flex',\n },\n notificationText: {\n fontWeight: 'normal',\n fontSize: '14px',\n lineHeight: 1.43,\n letterSpacing: '0.25px',\n color: '#49515a',\n },\n link: {\n color: '#4b8c6f',\n\n '&:visited': {\n color: '#4b8c6f',\n },\n },\n});\n\nexport const LeadsNotification = ({ notification = {} }) => {\n const classes = useStyles();\n const { time, jsonMessage } = notification;\n const url = `${window.location.origin}/pool-recommendation/${jsonMessage.jobId}`;\n\n return (\n \n {time}\n
\n \n
\n You have {jsonMessage.count} new Leads for{' '}\n \n {jsonMessage.jobRole}\n {' '}\n job post\n
\n
\n
\n );\n};\n","import React from 'react';\nimport { Grid, makeStyles, Typography } from '@material-ui/core';\nimport FaceIcon from '@material-ui/icons/Face';\n\nconst useStyles = makeStyles({\n NotificationContainer: {\n padding: '10px 3.5px 20.5px 13px',\n borderBottom: '1px solid rgba(0, 0, 0, 0.2)',\n },\n date: {\n color: '#a4a8ac',\n textAlign: 'right',\n fontSize: '12px',\n fontWeight: 'normal',\n LineWeight: 1.67,\n letterSpacing: '0.22px',\n marginBottom: '3px',\n },\n icon: {\n background: '#d7e5df',\n height: '24px',\n width: '24px',\n padding: '4px',\n borderRadius: '100%',\n marginRight: '15.5px',\n },\n detailsContainer: {\n display: 'flex',\n },\n notificationText: {\n fontWeight: 'normal',\n fontSize: '14px',\n lineHeight: 1.43,\n letterSpacing: '0.25px',\n color: '#49515a',\n },\n link: {\n color: '#4b8c6f',\n\n '&:visited': {\n color: '#4b8c6f',\n },\n },\n});\n\nexport const ApplicantsNotification = ({ notification = {} }) => {\n const classes = useStyles();\n const { time, jsonMessage } = notification;\n const url = `${window.location.origin}/screened-pipe/${jsonMessage.jobId}`;\n\n return (\n \n {time}\n
\n \n
\n You have {jsonMessage.count} new Applicants for{' '}\n \n {jsonMessage.jobRole}\n {' '}\n job post\n
\n
\n
\n );\n};\n","import React from 'react';\nimport { Grid, makeStyles, Typography } from '@material-ui/core';\nimport ErrorOutlineIcon from '@material-ui/icons/ErrorOutline';\nimport WorkOutlineIcon from '@material-ui/icons/WorkOutline';\nimport SignalCellularAltIcon from '@material-ui/icons/SignalCellularAlt';\nimport StarsIcon from '@material-ui/icons/Stars';\n\nconst useStyles = makeStyles({\n NotificationContainer: {\n padding: '10px 3.5px 20.5px 13px',\n borderBottom: '1px solid rgba(0, 0, 0, 0.2)',\n },\n date: {\n color: '#a4a8ac',\n textAlign: 'right',\n fontSize: '12px',\n fontWeight: 'normal',\n LineWeight: 1.67,\n letterSpacing: '0.22px',\n marginBottom: '3px',\n },\n icon: {\n background: '#fdd6be',\n height: '24px',\n width: '24px',\n padding: '4px',\n borderRadius: '100%',\n marginRight: '15.5px',\n },\n detailsContainer: {\n display: 'flex',\n alignItems: 'end',\n },\n notificationText: {\n fontWeight: 'normal',\n fontSize: '14px',\n lineHeight: 1.43,\n letterSpacing: '0.25px',\n color: '#49515a',\n marginBottom: '10px',\n },\n link: {\n color: '#4b8c6f',\n\n '&:visited': {\n color: '#4b8c6f',\n },\n },\n missingField: {\n marginLeft: '36px',\n display: 'flex',\n alignItems: 'center',\n padding: '6px 0',\n color: '#49515a',\n fontSize: '14px',\n lineHeight: 1.43,\n letterSpacing: '0.25px',\n },\n missingFieldIcon: {\n marginRight: '17.5px',\n height: '24px',\n width: '24px',\n },\n});\n\nexport const MissingJobFieldsNotification = ({ notification = {} }) => {\n const classes = useStyles();\n const { time, jsonMessage } = notification;\n const url = `${window.location.origin}/job/${jsonMessage.jobId}/edit`;\n\n const renderField = (field) => {\n const ICON_MAPPING = {\n 'Job Title': WorkOutlineIcon,\n Experience: SignalCellularAltIcon,\n Skills: StarsIcon,\n };\n\n const Icon = ICON_MAPPING[field];\n\n return (\n \n {Icon && }\n {field}\n \n );\n };\n\n return (\n \n {time}\n
\n \n
\n We have found few Missing fields in{' '}\n \n {jsonMessage.jobRole}\n \n . Please update so that we can find the relevant candidate.\n
\n
\n
\n {jsonMessage.missingFields.map((field) => renderField(field))}\n
\n
\n );\n};\n","import React from 'react';\nimport { Button, Grid, makeStyles, Typography } from '@material-ui/core';\nimport { formatNotifications } from 'controllers/notifications/formatNotifications';\nimport { LeadsNotification } from './notificationTypes/leadsNotification';\nimport { ApplicantsNotification } from './notificationTypes/applicantsNotification';\nimport { MissingJobFieldsNotification } from './notificationTypes/missingJobFieldsNotification';\n\nconst useStyles = makeStyles({\n NotificationsContainer: {\n display: 'flex',\n flexDirection: 'column',\n padding: '5px 19px',\n height: 'calc(100vh - 54px)',\n overflow: 'auto',\n },\n dateTitle: {\n marginTop: '18px',\n color: '#49515a',\n lineHeight: 1.43,\n letterSpacing: '0.25px',\n fontSize: '14px',\n fontWeight: 'normal',\n },\n loadMoreButtonContainer: {\n padding: '38px 10px',\n textAlign: 'center',\n },\n loadMoreButton: {\n minWidth: '140px',\n height: '34.2px',\n padding: '8px 22px 7.2px 23px',\n borderRadius: '4px',\n boxShadow: '0 1px 3px 0 rgba(0, 0, 0, 0.2)',\n backgroundColor: '#c8dad2',\n color: '#4b8c6f',\n fontSize: '14px',\n fontWeight: 500,\n },\n});\n\nexport const NotificationList = ({\n notifications = [],\n loadMore,\n hasMore = false,\n}) => {\n const classes = useStyles();\n const { dates, list } = formatNotifications(notifications);\n const datesArray = Object.keys(dates);\n\n const renderNotification = (notification) => {\n if (notification.notificationType === 'APPLICANTS_NOTIFICATION') {\n return ;\n } else if (notification.notificationType === 'LEADS_NOTIFICATION') {\n return ;\n } else if (notification.notificationType === 'MISSING_JOB_FIELDS') {\n return ;\n }\n\n return false;\n };\n\n return (\n \n {datesArray.map((d) => (\n <>\n \n {dates[d]}\n \n \n {list[d].map((notification) => renderNotification(notification))}\n \n \n ))}\n {hasMore && (\n
\n \n
\n )}\n
\n );\n};\n","import {\n Backdrop,\n Drawer,\n Grid,\n makeStyles,\n Typography,\n} from '@material-ui/core';\nimport { Close } from '@material-ui/icons';\nimport { getNotifications } from 'controllers/notifications/getNotifications';\nimport React, { useEffect } from 'react';\nimport { useSelector } from 'react-redux';\nimport { EmptyNotification } from './emptyNotification';\nimport { NotificationList } from './notificationList';\n\nconst useStyles = makeStyles({\n drawerContainer: {\n width: '400px',\n },\n backdrop: {\n zIndex: 1101,\n backgroundColor: 'rgba(0, 0, 0, 0.25)',\n },\n notificationHeader: {\n padding: '16px',\n borderBottom: '1px solid rgba(0, 0, 0, 0.12)',\n display: 'flex',\n justifyContent: 'space-between',\n },\n headerText: {\n fontSize: '16px',\n lineHeight: '20px',\n letterSpacing: '0.49px',\n color: 'rgba(0,0,0,0.87)',\n },\n headerCloseIcon: {\n color: 'rgba(0,0,0,0.87)',\n height: '20px',\n width: '20px',\n cursor: 'pointer',\n },\n});\n\nexport const Notification = ({ isOpen = true, toggleView }) => {\n const classes = useStyles();\n const notifications = useSelector((state) => state.user.notifications);\n const hasNotifications = Boolean(\n notifications.list && notifications.list.length\n );\n\n useEffect(() => {\n getNotifications();\n }, []);\n\n const loadMore = () => {\n getNotifications(true);\n };\n\n return (\n <>\n \n \n \n \n \n Notification\n \n \n \n {hasNotifications ? (\n \n ) : (\n \n )}\n \n \n \n );\n};\n","import React from 'react';\nimport {\n Backdrop,\n Drawer,\n Grid,\n makeStyles,\n Typography,\n} from '@material-ui/core';\nimport {\n BubbleChart,\n // PeopleAlt,\n // RecentActors,\n // WbSunny,\n FindInPage,\n PaymentSharp,\n MonetizationOn,\n} from '@material-ui/icons';\nimport clsx from 'clsx';\nimport { useHistory } from 'react-router';\n// import { resetJoblist } from \"controllers/job\";\n\nconst useStyles = makeStyles({\n drawerContainer: {\n width: 250,\n zIndex: 1001,\n marginTop: 54,\n paddingTop: 11,\n },\n backdrop: {\n zIndex: 1000,\n backgroundColor: 'rgba(0, 0, 0, 0.25)',\n },\n menuItem: {\n borderLeft: '2px solid #fff',\n paddingLeft: 22,\n margin: '21px 0',\n display: 'flex',\n alignItems: 'center',\n cursor: 'pointer',\n fontSize: '16px',\n fontWeight: 500,\n letterSpacing: '0.21px',\n color: '#49515a',\n\n '& svg': {\n marginRight: 8,\n },\n '&:hover': {\n color: '#4b8c6f',\n },\n },\n menuItemSelected: {\n color: '#4b8c6f',\n borderLeft: '2px solid #4b8c6f',\n\n '&:hover': {\n cursor: 'default',\n },\n },\n});\n\nexport const Menu = ({ isOpen = true, toggleView }) => {\n const classes = useStyles();\n const history = useHistory();\n const selectedPath = history.location.pathname;\n\n const MENU_MAP = [\n {\n Icon: FindInPage,\n title: 'Resume Parser',\n link: '/resume-parser',\n onRouteChange: () => {},\n },\n {\n Icon: BubbleChart,\n title: 'Semantic Matching',\n link: '/talent-ai-matching',\n onRouteChange: () => {},\n },\n // {\n // Icon: PeopleAlt,\n // title: 'Pool Recommendation',\n // link: '/pool-recommendation',\n // onRouteChange: resetJoblist,\n // },\n // {\n // Icon: RecentActors,\n // title: 'Screened Pipe',\n // link: '/screened-pipe',\n // onRouteChange: resetJoblist,\n // },\n {\n title: 'lineBreak',\n },\n {\n Icon: PaymentSharp,\n title: 'Analyse IDs',\n link: '/analyse-ids',\n onRouteChange: () => {},\n },\n {\n Icon: MonetizationOn,\n title: 'Analyse Expense',\n link: '/analyse-expense',\n onRouteChange: () => {},\n },\n // {\n // Icon: WbSunny,\n // title: 'Ideal Talent Matching',\n // link: '/ideal-talent-matching',\n // onRouteChange: () => {},\n // },\n\n // {\n // Icon: PeopleAlt,\n // title: 'Skills Recommendation',\n // link: '/skills-recommendation',\n // },\n ];\n\n const navigateTo = (link, onRouteChange) => () => {\n if (link === selectedPath) {\n return false;\n }\n\n onRouteChange();\n history.push(link);\n toggleView();\n };\n\n const RenderMenuItem = ({ Icon, title, link, onRouteChange }) => {\n if (title === 'lineBreak') {\n return
;\n }\n\n const isSelected = selectedPath === link;\n\n return (\n \n {title}\n \n );\n };\n\n return (\n <>\n \n \n \n \n {MENU_MAP.map((props, i) => (\n \n ))}\n \n \n \n \n );\n};\n","import React, { PureComponent, Fragment } from 'react';\nimport { connect } from 'react-redux';\nimport { withRouter } from 'react-router';\nimport { Menu as MenuIcon, Notifications } from '@material-ui/icons';\nimport { AppBar, Toolbar, Box, Badge } from '@material-ui/core';\n\nimport { IMG_LOGO } from 'images';\nimport { logout } from 'controllers/authenticationController';\nimport NavigationMenu from '../navigation-menu/navigation-menu';\nimport ProfileDropdown from './profile-dropdown/profileDropdown';\n\nimport './navigation.scss';\nimport { Notification } from './notification/notification';\nimport { Menu } from './menu/menu';\nimport { toggleNotificationBar } from 'controllers/notifications/getNotifications';\nimport SrIconButton from 'core/srIconButton/srIconButton';\nimport { toggleMenu } from 'controllers/user/toggleMenu';\nclass Navigation extends PureComponent {\n changeLocation = (location) => () => {\n const { history } = this.props;\n history.push(location);\n };\n\n logout = () => {\n logout();\n this.changeLocation('/login')();\n };\n\n toggleNotificationView = () => {\n const { showNotifications } = this.props;\n\n toggleNotificationBar(!showNotifications);\n };\n\n render() {\n const {\n userName,\n notificationCount,\n showNotifications,\n isMenuOpen,\n history,\n } = this.props;\n\n return (\n \n \n \n \n \"\"\n \n \n {/* THIS ALSO CONTAINS CREATE JOB MODAL */}\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n );\n }\n}\n\nconst mapStateToProps = (state) => ({\n userName: state.user.details.userName,\n notificationCount: state.user.notifications.count,\n showNotifications: state.user.notifications.showNotifications,\n isMenuOpen: state.user.isMenuOpen,\n});\n\nexport default connect(mapStateToProps, null)(withRouter(Navigation));\n","import React, { PureComponent } from 'react';\nimport Autosuggest from 'react-autosuggest';\nimport './autoSuggest.scss';\n\nexport class AutoSuggest extends PureComponent {\n constructor() {\n super();\n this.state = {\n suggestions: [],\n };\n }\n\n onClear = () => {\n this.setState({\n suggestions: [],\n });\n };\n\n onFetch = ({ value, reason }) => {\n if (reason === 'input-focused') {\n return;\n }\n this.getSuggestions(value);\n };\n\n getSuggestions = async (value) => {\n const { fetchSuggestions } = this.props;\n const suggestions = await fetchSuggestions(value);\n\n this.setState({ suggestions });\n };\n\n renderSuggestion = (suggestion) =>
{suggestion}
;\n\n getSuggestionValue = (suggestion) => {\n return suggestion;\n };\n\n onEnter = (e) => {\n const { value, onSelect, enableSelectionOnEnter } = this.props;\n if (e.key === 'Enter' && enableSelectionOnEnter && Boolean(value.trim())) {\n onSelect(e, { suggestion: value });\n }\n };\n\n renderInputComponent = (props) => {\n return ;\n };\n\n render() {\n const { suggestions } = this.state;\n const {\n value,\n name,\n placeholder,\n onChange,\n onSelect,\n errorFlag,\n errorMessage,\n InputComponent = this.renderInputComponent,\n } = this.props;\n\n return (\n
\n \n

{errorMessage}

\n
\n );\n }\n}\n\nAutoSuggest.defaultProps = {\n placeholder: 'Please Select',\n value: '',\n name: '',\n onChange: () => {},\n fetchSuggestions: () => {},\n enableSelectionOnEnter: false,\n};\n","import React, { PureComponent } from 'react';\nimport { Chip } from '@material-ui/core';\nimport './chip.scss';\n\nexport class CommonChip extends PureComponent {\n constructor() {\n super();\n this.state = {\n selected: false,\n };\n }\n\n onDelete = () => {\n const { onDeleteChip, label } = this.props;\n onDeleteChip(label);\n };\n\n onHover = (selected) => () => {\n this.setState({\n selected,\n });\n };\n\n onClick = () => {\n const { onClick, label } = this.props;\n onClick(label);\n };\n\n render() {\n const { selected } = this.state;\n const {\n label,\n onDeleteChip,\n onClick,\n classes,\n showDelete = false,\n } = this.props;\n const deleteChip = onDeleteChip\n ? { onDelete: selected || showDelete ? this.onDelete : false }\n : {};\n const clickable = Boolean(onClick) ? { onClick: this.onClick } : {};\n const isPrimary = !Boolean(clickable) || (!selected && onDeleteChip);\n\n return (\n \n );\n }\n}\n\nCommonChip.defaultProps = {\n classes: '',\n onDeleteChip: false,\n onClick: false,\n};\n","import React, { PureComponent } from 'react';\nimport { Chip, Avatar } from '@material-ui/core';\nimport { Check } from '@material-ui/icons';\nimport './chipCheckbox.scss';\n\nexport class ChipCheckbox extends PureComponent {\n constructor() {\n super();\n this.state = {\n selected: false,\n };\n }\n\n // onDelete = () => {\n // const { onDeleteChip, label } = this.props;\n // onDeleteChip(label);\n // };\n\n // onHover = selected => () => {\n // this.setState({\n // selected\n // });\n // };\n\n onClick = () => {\n const { onClick, label } = this.props;\n this.setState({ selected: !this.state.selected });\n onClick(label, this.state.selected);\n };\n\n render() {\n const { selected } = this.state;\n const { label, onClick, classes } = this.props;\n const clickable = Boolean(onClick) ? { onClick: this.onClick } : {};\n\n return (\n \n \n \n ) : null\n }\n label={label}\n className={`chip${\n this.state.selected\n ? ' chip-selected chip-checkbox '\n : ' chip-checkbox '\n } ${classes}`}\n color={this.state.selected ? 'primary' : 'default'}\n {...clickable}\n />\n );\n }\n}\n\nChipCheckbox.defaultProps = {\n classes: '',\n onDeleteChip: false,\n onClick: false,\n};\n","import React, { PureComponent } from 'react';\nimport {\n FormControl,\n Box,\n FormLabel,\n RadioGroup,\n FormControlLabel,\n Radio,\n} from '@material-ui/core';\nimport { uuid } from 'utils';\nimport './radio.scss';\n\nexport class CommonRadio extends PureComponent {\n constructor() {\n super();\n this.state = {\n selected: false,\n };\n }\n\n render() {\n const {\n label,\n value,\n onChange,\n name,\n items,\n errorFlag,\n errorMessage,\n } = this.props;\n\n return (\n
\n \n \n \n {label}\n \n \n \n {items.map(({ value, label }) => {\n return (\n }\n label={label}\n labelPlacement=\"end\"\n />\n );\n })}\n \n

{errorMessage}

\n
\n
\n );\n }\n}\n\nCommonRadio.defaultProps = {\n placeholder: 'Please Select',\n value: '',\n name: '',\n onChange: () => {},\n fetchSuggestions: () => {},\n};\n","import React, { PureComponent } from 'react';\nimport { Slider } from '@material-ui/core';\nimport { withStyles } from '@material-ui/core/styles';\nimport './slider.scss';\n\nconst SenseLoafSlider = withStyles({\n valueLabel: {\n left: 'calc(-50% + -4px)',\n top: -22,\n fontSize: '14px',\n '& *': {\n background: 'transparent',\n color: '#000',\n },\n },\n})(Slider);\n\nclass CommonSlider extends PureComponent {\n constructor(props) {\n super(props);\n this.state = {\n sliderValue: props.value || 0,\n };\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps.value !== this.props.value) {\n this.setState({\n sliderValue: this.props.value,\n });\n }\n }\n\n onChange = (e, sliderValue) => {\n this.setState({\n sliderValue,\n });\n };\n\n render() {\n const { max, onChange, valueLabelFormat } = this.props;\n const { sliderValue } = this.state;\n const valueLabel = valueLabelFormat ? valueLabelFormat : (v) => v;\n return (\n \n );\n }\n}\n\nexport default CommonSlider;\n","import React, { PureComponent } from 'react';\nimport { Avatar } from '@material-ui/core';\nimport './avatar.scss';\n\nexport class CommonAvatar extends PureComponent {\n generateColor = (str, s, l) => {\n var hash = 0;\n for (var i = 0; i < str.length; i++) {\n hash = str.charCodeAt(i) + ((hash << 5) - hash);\n }\n\n var h = hash % 360;\n return 'hsl(' + h + ', ' + s + '%, ' + l + '%)';\n };\n\n getInitials = (name) => {\n return name\n .trim()\n .split(' ')\n .map((name) => name.substring(0, 1).toUpperCase())\n .slice(0, 1)\n .join('');\n };\n\n render() {\n const { name, style = {}, onClick = () => {}, className = '' } = this.props;\n const color = this.generateColor(name, 40, 40);\n const backgroundColor = this.generateColor(name, 35, 80);\n const initials = this.getInitials(name);\n\n return (\n \n {initials}\n \n );\n }\n}\n","import React, { PureComponent } from 'react';\nimport { Snackbar } from '@material-ui/core';\nimport CheckCircleIcon from '@material-ui/icons/CheckCircle';\nimport { setFlag } from 'controllers/flags';\n\nimport './snackbar.scss';\n\nexport class CommonSnackbar extends PureComponent {\n componentWillUnmount() {\n this.handleClose();\n }\n\n getMessage = () => {\n const { message, type } = this.props;\n\n if (type === 'success') {\n return (\n \n \n {message}\n \n );\n }\n\n return {message};\n };\n\n handleClose = () => {\n const { flag, autoCloseSnackbar } = this.props;\n if (autoCloseSnackbar !== false) {\n setFlag(flag, false);\n }\n };\n\n render() {\n const { open, type } = this.props;\n\n return (\n \n );\n }\n}\n\nCommonSnackbar.defaultProps = {\n classes: '',\n open: false,\n message: '',\n handleClose: () => {},\n type: 'default',\n flag: '',\n};\n","import React from 'react';\nimport Highcharts from 'highcharts';\nimport HighchartsReact from 'highcharts-react-official';\n\nconst BarChart = ({ data, tooltipLabel }) => {\n const options = {\n credits: {\n enabled: false,\n },\n colors: ['#4b8c6f'],\n chart: {\n type: 'column',\n },\n title: {\n text: '',\n },\n xAxis: {\n categories: data.map(({ name }) => name),\n lineWidth: 0,\n labels: {\n align: 'center',\n reserveSpace: true,\n format: '
{text}
',\n formatter: (o) => {\n return `
${o.value\n .split(' ')\n .join('
')}
`;\n },\n useHTML: true,\n },\n },\n yAxis: {\n tickLength: 1,\n gridLineWidth: 0,\n title: {\n text: '',\n },\n },\n plotOptions: {\n column: {\n pointPadding: 0.2,\n borderWidth: 0,\n borderRadius: 4,\n states: {\n hover: {\n color: '#4b8c6f80',\n },\n },\n },\n },\n tooltip: {\n backgroundColor: '#fff',\n borderRadius: 4,\n borderColor: '#ddd',\n borderWidth: 1,\n shadow: false,\n shape: 'rect',\n distance: 24,\n pointFormat: `{point.y}
${tooltipLabel}`,\n headerFormat: '',\n },\n legend: {\n enabled: false,\n },\n series: [\n {\n data,\n },\n ],\n };\n\n return (\n
\n \n
\n );\n};\n\nexport default BarChart;\n","import React from 'react';\nimport Highcharts from 'highcharts';\nimport HighchartsReact from 'highcharts-react-official';\nimport HighchartsMore from 'highcharts/highcharts-more';\nimport { makeStyles } from '@material-ui/core';\n\nHighchartsMore(Highcharts);\n\nconst useStyles = makeStyles(() => ({\n labelNumber: {\n fontFamily: 'Roboto',\n fontSize: 16,\n fontStyle: 'normal',\n letterSpacing: 0,\n textAlign: 'left',\n color: '#000000',\n },\n labelText: {\n fontFamily: 'Roboto',\n fontSize: 12,\n fontWeight: 'normal',\n fontStyle: 'normal',\n letterSpacing: 0,\n textAlign: 'left',\n color: '#000000',\n },\n}));\n\nconst FunnelChart = ({ data = [], chartLabels = [] }) => {\n const classes = useStyles();\n const labels = chartLabels.map(\n ({ count, value }) =>\n `${count}
${value}`\n );\n\n const options = {\n credits: {\n enabled: false,\n },\n chart: {\n type: 'polygon',\n },\n title: {\n text: '',\n },\n colors: ['#4b8c6f', '#6fa38c', '#d7e5df', '#d7e5df'],\n xAxis: {\n tickLength: 0,\n tickAmount: 5,\n lineWidth: 0,\n gridLineWidth: 1,\n min: 0,\n max: 40,\n labels: {\n formatter: (point) => {\n const index = point.value / 10 - 1;\n\n if (index < 0) {\n return '';\n }\n\n return labels[index];\n },\n y: -350,\n x: -140,\n align: 'left',\n enabled: true,\n },\n },\n\n yAxis: {\n max: 60,\n gridLineWidth: 0,\n title: {\n text: '',\n },\n labels: {\n enabled: false,\n },\n },\n legend: {\n enabled: false,\n },\n tooltip: {\n enabled: false,\n },\n plotOptions: {\n polygon: {\n enableMouseTracking: false,\n },\n },\n series: data,\n };\n\n return (\n
\n \n
\n );\n};\n\nexport default FunnelChart;\n","import React from 'react';\nimport Highcharts from 'highcharts';\nimport HighchartsReact from 'highcharts-react-official';\nimport HighchartsMore from 'highcharts/highcharts-more';\n\nHighchartsMore(Highcharts);\n\nconst RadarChart = ({ data = [], labels = [] }) => {\n const options = {\n credits: {\n enabled: false,\n },\n colors: ['#4b8c6f80'],\n chart: {\n polar: true,\n },\n title: {\n text: '',\n },\n pane: {\n startAngle: 0,\n endAngle: 360,\n },\n xAxis: {\n tickInterval: 45,\n min: 0,\n max: 360,\n labels: {\n formatter: function () {\n return labels[this.value / 45];\n },\n },\n },\n yAxis: {\n min: 0,\n labels: {\n enabled: false,\n },\n },\n plotOptions: {\n series: {\n pointStart: 0,\n pointInterval: 45,\n },\n },\n tooltip: {\n backgroundColor: '#fff',\n borderRadius: 4,\n borderColor: '#ddd',\n borderWidth: 1,\n shadow: false,\n shape: 'rect',\n distance: 24,\n pointFormatter: function () {\n return `${this.y}
${labels[this.index]}`;\n },\n headerFormat: '',\n },\n legend: {\n enabled: false,\n },\n series: [\n {\n type: 'area',\n name: 'Area',\n data,\n },\n ],\n };\n\n return (\n
\n \n
\n );\n};\n\nexport default RadarChart;\n","import React from 'react';\nimport Highcharts from 'highcharts';\nimport HighchartsReact from 'highcharts-react-official';\nimport HighchartsHeatmap from 'highcharts/modules/heatmap';\n\nHighchartsHeatmap(Highcharts);\n\nconst HeatMap = ({ data = [], labelsX = [], labelsY = [] }) => {\n const days = [\n 'Monday',\n 'Tuesday',\n 'Wednesday',\n 'Thursday',\n 'Friday',\n 'Saturday',\n 'Sunday',\n ];\n\n const options = {\n credits: {\n enabled: false,\n },\n colors: ['#fff'],\n chart: {\n type: 'heatmap',\n },\n title: {\n text: '',\n },\n xAxis: {\n categories: labelsX,\n lineWidth: 0,\n },\n\n yAxis: {\n categories: labelsY,\n title: null,\n reversed: true,\n opposite: true,\n gridLineWidth: 0,\n tickInterval: 2,\n showLastLabel: false,\n },\n colorAxis: {\n min: 0,\n minColor: '#d7e5df',\n maxColor: '#4b8c6f',\n },\n tooltip: {\n backgroundColor: '#fff',\n borderRadius: 4,\n borderColor: '#ddd',\n borderWidth: 1,\n shadow: false,\n shape: 'rect',\n distance: 24,\n pointFormatter: function () {\n return `${this.value}
${days[this.x]} - ${labelsY[this.y]}`;\n },\n headerFormat: '',\n },\n legend: {\n enabled: false,\n },\n series: [\n {\n name: '',\n borderWidth: 4,\n data,\n dataLabels: {\n enabled: false,\n },\n states: {\n hover: {\n enabled: false,\n },\n },\n },\n ],\n };\n\n return (\n
\n \n
\n );\n};\n\nexport default HeatMap;\n","import React from 'react';\n\nimport { TransformWrapper, TransformComponent } from 'react-zoom-pan-pinch';\n\nexport const ImageViewer = ({ children }) => {\n return (\n \n {({ zoomIn, zoomOut, resetTransform, ...rest }) => (\n \n
\n \n \n \n
\n \n {children}\n \n
\n )}\n \n );\n};\n","export const DEFAULT_PERKS = [\n 'Free coffee',\n 'Early stock',\n 'Gym',\n 'Canteen',\n 'Free Beverage',\n 'Shower',\n 'Free Parking',\n 'Free Lunch',\n 'In house trainings',\n 'Startup Atmosphere',\n 'No dress code',\n 'Modern office',\n];\n\nexport const DEFAULT_JOB_TITLES = [\n {\n 'job title': 'Network Administrator',\n },\n {\n 'job title': 'Senior Software Engineer',\n },\n {\n 'job title': 'Network Systems Administrator',\n },\n {\n 'job title': 'Software Architect',\n },\n {\n 'job title': 'Senior Web Administrator',\n },\n];\n\nexport const CLOSING_JOB_CHIPS = [\n 'Job fulfilled',\n 'Hiring freeze',\n 'Hire - Backfill',\n 'Job on Hold',\n 'Not filling',\n];\n\nexport const REJECT_CANDIDATE_CHIPS = [\n 'All positions filled',\n 'Less experience',\n 'No required skills',\n 'High budget expectation',\n 'Location inappropriate',\n];\n\nexport const DEFAULT_LOCATIONS_INDIA = [\n 'Bengaluru, India',\n 'Hyderabad, India',\n 'Pune, India',\n 'Chennai, India',\n 'Gurgaon, India',\n];\n\nexport const DEFAULT_LOCATIONS_USA = [\n 'Boston, United States',\n 'San Jose, United States',\n 'Austin, United States',\n 'Washington, United States',\n 'Seattle, United States',\n];\n\nexport const IGNORE_VALIDATION_FIELDS = ['histories'];\n\nexport const TALENT_STATUS = {\n SOURCE: {\n APPLICANTS: 'applicants',\n LEADS: 'leads',\n },\n applicantsTab: {\n tabLabel: 'Applicants',\n sideBarLinks: [\n { displayLabel: 'Applied', value: 'Applied' },\n { displayLabel: 'Shortlisted', value: 'Shortlisted' },\n { displayLabel: 'Interview', value: 'Interview' },\n { displayLabel: 'Hired', value: 'Hired' },\n { displayLabel: 'Offered', value: 'Offered' },\n { displayLabel: 'Rejected', value: 'Rejected' },\n { displayLabel: 'Favourite', value: 'AppFavourite' },\n ],\n statusTypes: [\n 'Shortlisted',\n 'Interview',\n 'Hired',\n 'Offered',\n 'Rejected',\n 'AppFavourite',\n 'Applied',\n ],\n favourite: [\n 'Applied',\n 'Shortlisted',\n 'Interview',\n 'Hired',\n 'Offered',\n 'Rejected',\n ],\n },\n leadsTab: {\n tabLabel: 'Leads',\n sideBarLinks: [\n { displayLabel: 'AllLeads', value: 'Lead' },\n { displayLabel: 'Reached', value: 'Reached' },\n { displayLabel: 'Favourite', value: 'LeadsFavourite' },\n { displayLabel: 'Rejected', value: 'LeadRejected' },\n ],\n statusTypes: ['Lead', 'Reached', 'LeadsFavourite', 'LeadRejected'],\n favourite: ['Lead', 'Reached'],\n },\n favouriteLinks: ['AppFavourite', 'LeadsFavourite', 'TalentConnectFavourite'],\n applied: 'Applied',\n candidates: 'Applied',\n reached: 'Reached',\n};\n\nexport const NO_CANDIDATE_ERRORS = {\n candidates:\n 'Sit Back and Relax! We are constantly reaching out to Talents for this Job.',\n shortlisted: 'No Talent is shortlisted yet.',\n interview: 'No Talent for interview yet.',\n hired: 'No Talent for hire yet.',\n offered: 'No Talent offered yet.',\n rejected: 'No Talent rejected.',\n default: 'No talent found',\n};\n\nexport const CREATE_JOB_IGNORE_FIELDS = [\n 'jobLink',\n 'closingDetail',\n 'histories',\n 'companyLogoUrl',\n 'userId',\n 'organizationId',\n 'currencyValue',\n 'lookForSchools',\n 'domains',\n 'perks',\n 'lookForJobRoles',\n 'lookForLocations',\n 'sharedTo',\n 'location',\n 'foundedYear',\n 'companySize',\n 'aboutCompany',\n 'currency',\n 'maxExperience',\n 'minExperience',\n 'minSalary',\n 'maxSalary',\n 'currencyValue',\n 'salaryTime',\n 'jobDescription',\n];\n\nexport const JOB_DISPLAY_TYPE = {\n CREATE: 'CREATE_JOB',\n EDIT: 'EDIT_JOB',\n};\n\nexport const CANDIDATE_LISTING_SORT_OPTIONS = [\n {\n id: 'overallScore',\n value: 'Overall Score',\n },\n {\n id: 'skillMatchScore',\n value: 'Skills relevance',\n },\n {\n id: 'expMatchScore',\n value: 'Experience relevance',\n },\n {\n id: 'titleMatchScore',\n value: 'Job title relevance',\n },\n];\n\nexport const MONTH_SHORT = [\n 'JAN',\n 'FEB',\n 'MAR',\n 'APR',\n 'MAY',\n 'JUNE',\n 'JULY',\n 'AUG',\n 'SEPT',\n 'OCT',\n 'NOV',\n 'DEC',\n];\n","import {\n autoSuggestionService,\n jobTitlesService,\n skillsRecommendationService,\n skillService,\n} from 'services';\nimport { getAuthorization } from './controller';\n\nexport const location = async (search) => {\n const authorization = getAuthorization();\n const { status, data } = await autoSuggestionService(\n authorization,\n 'location',\n search\n );\n\n if (status !== 200) {\n console.error('Error', status);\n return false;\n }\n\n return data;\n};\n\nexport const company = async (search) => {\n const authorization = getAuthorization();\n const { status, data } = await autoSuggestionService(\n authorization,\n 'company',\n search\n );\n\n if (status !== 200) {\n console.error('Error', status);\n return false;\n }\n\n return data;\n};\n\nexport const jobTitles = async (search) => {\n const authorization = getAuthorization();\n const { status, data } = await jobTitlesService(authorization, search);\n\n if (status !== 200) {\n console.error('Error', status);\n return false;\n }\n\n return data;\n};\n\nexport const skillsRecommendation = async (skillsArray) => {\n const authorization = getAuthorization();\n const { status, data } = await skillsRecommendationService(\n authorization,\n skillsArray\n );\n\n if (status !== 200) {\n console.error('Error', status);\n return false;\n }\n\n return data;\n};\n\nexport const skills = async (search) => {\n const authorization = getAuthorization();\n const { status, data } = await skillService(authorization, search);\n if (status !== 200) {\n console.error('Error', status);\n return false;\n }\n\n return data;\n};\n","import {\n getJobsService,\n deleteJobsService,\n editJobService,\n createJobService,\n getJobByIdService,\n getJobStatsByIdService,\n getJobStatsByUserIdService,\n} from 'services';\nimport { getAuthorization, getStore, dispatch } from './controller';\nimport {\n SET_JOB_LISTING,\n UPDATE_SELECTED_JOB,\n SET_SELECTED_JOB,\n RESET_SELECTED_JOB,\n ADD_COLLEGE,\n REMOVE_COLLEGE,\n REMOVE_DOMAIN,\n ADD_DOMAIN,\n} from 'actions/constants';\nimport { setFlag } from './flags';\n\nexport const getjobs = async (page = 'false', filter, userId) => {\n const prevPage = getStore().job.listing.currentPage;\n const selectedPage = page !== 'false' ? page : prevPage;\n\n resetJoblist();\n\n const authorization = getAuthorization();\n const search = {\n page: selectedPage || 0,\n size: 10,\n filter: Boolean(filter && Object.keys(filter).length),\n };\n const uid = getStore().user.details.userId;\n const { status, data } = await getJobsService(\n authorization,\n uid,\n search,\n filter\n );\n\n let contentPromise = data.response.content.map((job) =>\n getJobStatsByIdService(authorization, job.jobId).then(({ data }) => {\n const jobStatusCounts = {};\n const { totalApplicants, totalLeads, totalScreened } = data.response;\n jobStatusCounts['totalCandidates'] = totalScreened;\n jobStatusCounts['leadsCount'] = totalLeads;\n jobStatusCounts['appliedCount'] = totalApplicants;\n\n return {\n ...job,\n ...jobStatusCounts,\n };\n })\n );\n\n data.response.content = await Promise.all(contentPromise);\n const jobStatsData = await getJobStatsByUserIdService(authorization, userId);\n const stats = {};\n if (jobStatsData.data.response && Array.isArray(jobStatsData.data.response)) {\n jobStatsData.data.response.forEach((job) => {\n const jobStatus = job.jobStatus.toLowerCase();\n stats[jobStatus] = job.count;\n });\n }\n dispatch({\n type: SET_JOB_LISTING,\n listing: {\n ...data.response,\n stats,\n },\n });\n\n if (status !== 200) {\n console.error('Error', status);\n return false;\n }\n\n return data;\n};\n\nexport const resetJoblist = () => {\n dispatch({\n type: SET_JOB_LISTING,\n listing: {},\n });\n};\n\nexport const deleteJobs = async (jobids) => {\n const authorization = getAuthorization();\n\n const { status } = await deleteJobsService(authorization, jobids);\n\n if (status !== 200) {\n console.error('Error', status);\n return false;\n }\n\n if (jobids.length > 1) {\n setFlag('deleteJobs', true);\n } else {\n setFlag('deleteJob', true);\n }\n\n return true;\n};\n\nexport const editJob = async (details) => {\n const authorization = getAuthorization();\n const {\n organizationInfo: { organizationId },\n } = getStore().user.details;\n let jobDetails = {};\n if (!details || Object.keys(details).length === 0) {\n const selectedJob = getStore().job.selectedJob;\n jobDetails = {\n ...jobDetails,\n ...selectedJob,\n organizationId,\n };\n } else {\n jobDetails = {\n ...details,\n organizationId,\n };\n }\n\n const { status } = await editJobService(authorization, jobDetails);\n\n if (status !== 200) {\n console.error('Error', status);\n return false;\n }\n setFlag('editJob', true);\n\n return true;\n};\n\nexport const getPoolSize = (details) => {\n //const authorization = getAuthorization();\n};\n\nexport const createJob = async () => {\n const authorization = getAuthorization();\n const { selectedJob } = getStore().job;\n const { userId } = getStore().user.details;\n\n const details = {\n ...selectedJob,\n userId,\n };\n\n const { status } = await createJobService(authorization, details);\n\n if (status !== 200) {\n console.error('Error', status);\n return false;\n }\n\n setFlag('createJob', true);\n return true;\n};\n\nexport const getJobById = async (id) => {\n const authorization = getAuthorization();\n const { status, data } = await getJobByIdService(authorization, id);\n\n if (status !== 200) {\n console.error('Error', status);\n return false;\n }\n dispatch({\n type: SET_SELECTED_JOB,\n selectedJob: data.response,\n });\n};\n\nexport const initializeJob = () => {\n const { organizationInfo } = getStore().user.details;\n dispatch({\n type: RESET_SELECTED_JOB,\n payload: {\n organizationInfo,\n },\n });\n};\n\nexport const updateJob = (jobDetails) => {\n dispatch({\n type: UPDATE_SELECTED_JOB,\n jobDetails,\n });\n};\n\nexport const isFiltered = (appliedFilters) => {\n const {\n from = '',\n to = '',\n jobRole = {},\n location = {},\n jobStatus = '',\n } = appliedFilters;\n\n return Boolean(\n from ||\n to ||\n Object.keys(jobRole).length ||\n Object.keys(location).length ||\n jobStatus\n );\n};\n\nexport const addCollege = (college) => {\n dispatch({\n type: ADD_COLLEGE,\n payload: { college },\n });\n};\n\nexport const removeCollege = (college) => {\n dispatch({\n type: REMOVE_COLLEGE,\n payload: { college },\n });\n};\n\nexport const addDomain = (domain) => {\n dispatch({\n type: ADD_DOMAIN,\n payload: { domain },\n });\n};\n\nexport const removeDomain = (domain) => {\n dispatch({\n type: REMOVE_DOMAIN,\n payload: { domain },\n });\n};\n","import React from 'react';\n\nimport { IconButton, makeStyles, Tooltip } from '@material-ui/core';\nimport clsx from 'clsx';\n\nconst useStyles = makeStyles({\n icon: {\n height: 38,\n width: 38,\n\n '& svg': {\n width: 24,\n height: 24,\n },\n '&:hover': {\n background: 'rgba(75, 140, 111, 0.18)',\n\n '& svg': {\n fill: '#4b8c6f',\n },\n },\n },\n selectedIcon: {\n '& svg': {\n fill: '#4b8c6f',\n },\n },\n});\n\nexport const SrIconButton = ({\n Icon,\n selected = false,\n tooltip = false,\n disabled = false,\n ...props\n}) => {\n const classes = useStyles();\n\n const WrapInTooltip = ({ children }) => {\n if (tooltip) {\n return (\n \n {disabled ? {children} : children}\n \n );\n }\n return children;\n };\n\n return (\n \n \n \n \n \n );\n};\n\nexport default SrIconButton;\n","import { fetchLib, getJson, getStatus } from 'utils';\nimport { SERVICE_URL } from '../constants';\n\nexport const signupService = async (signupFields) => {\n const options = {\n method: 'POST',\n body: JSON.stringify(signupFields),\n headers: {\n 'Content-Type': 'application/json',\n },\n };\n\n const response = await fetchLib(`${SERVICE_URL}api/v2/sign-up`, options);\n const status = getStatus(response);\n const data = await getJson(response);\n\n return {\n status,\n data,\n };\n};\n","import { fetchLib, getJson, getStatus } from 'utils';\nimport { SERVICE_URL } from '../constants';\n\nexport const verifyEmailService = async (verifyEmailPayload) => {\n const options = {\n method: 'POST',\n body: JSON.stringify(verifyEmailPayload),\n headers: {\n 'Content-Type': 'application/json',\n },\n };\n\n const response = await fetchLib(`${SERVICE_URL}api/v2/verify-email`, options);\n const status = getStatus(response);\n if (status === 200) {\n return {\n status,\n data: true,\n };\n }\n const data = await getJson(response);\n\n return {\n status,\n data,\n };\n};\n","import { fetchLib, getJson, getStatus } from 'utils';\nimport { SERVICE_URL } from '../constants';\n\nexport const resendVerificationEmailService = async (emailId) => {\n const options = {\n method: 'POST',\n body: JSON.stringify({ address: emailId }),\n headers: {\n 'Content-Type': 'application/json',\n },\n };\n\n const response = await fetchLib(`${SERVICE_URL}api/v2/resend-mail`, options);\n const status = getStatus(response);\n if (status === 200) {\n return {\n status,\n data: true,\n };\n }\n const data = await getJson(response);\n\n return {\n status,\n data,\n };\n};\n","import { loginService } from 'services';\nimport { getUserDetails } from './userController';\nimport { setAuthorization } from './controller';\nimport { setFlag } from './flags';\nimport { signupService } from 'services/authentication/signup';\nimport { verifyEmailService } from 'services/authentication/verifyEmail';\nimport { resendVerificationEmailService } from 'services/authentication/resendVerificationEmail';\n\nexport const login = async (emailId, password) => {\n try {\n const { status, authToken } = await loginService(emailId, password);\n\n await setAuthorization(authToken);\n\n const user = await getUserDetails();\n\n if (status !== 200) {\n console.error('Error', status);\n return {\n error: true,\n msg: 'Email and/or password is wrong.',\n };\n }\n setFlag('login', true);\n return user.response && user.response.onBoarded;\n } catch (e) {\n console.error(e);\n return {\n error: true,\n msg: 'Email and/or password is wrong.',\n };\n }\n};\n\nexport const signup = async ({\n firstName,\n lastName,\n workEmail,\n companyName,\n enterPassword,\n}) => {\n try {\n const { status, data } = await signupService({\n emailId: workEmail,\n organizationName: companyName,\n password: enterPassword,\n phone: '0',\n subscribedProduct: ['API'],\n timeZone: '',\n userName: firstName + ' ' + lastName,\n });\n\n if (status !== 201) {\n console.error('Error', data);\n return {\n error: true,\n msg:\n data.response &&\n data.response.error &&\n data.response.error.faultDetail\n ? data.response.error.faultDetail[0]\n : 'Some error occured while signing up. Please contact support.',\n };\n }\n setFlag('login', true);\n return data.response && data.response.onBoarded;\n } catch (e) {\n console.error(e);\n return {\n error: true,\n msg:\n e.response && e.response.error && e.response.error.faultDetail\n ? e.response.error.faultDetail[0]\n : 'Some error occured while signing up. Please contact support.',\n };\n }\n};\n\nexport const verifyEmail = async ({ emailId, secretCode }) => {\n try {\n const { status, data } = await verifyEmailService({ emailId, secretCode });\n\n if (status !== 200) {\n console.error('Error', data);\n return {\n error: true,\n msg:\n data.response &&\n data.response.error &&\n data.response.error.faultDetail\n ? data.response.error.faultDetail[0]\n : 'OTP is not valid.',\n };\n }\n\n return true;\n } catch (e) {\n console.error(e);\n return {\n error: true,\n msg:\n e.response && e.response.error && e.response.error.faultDetail\n ? e.response.error.faultDetail[0]\n : 'OTP is not valid.',\n };\n }\n};\n\nexport const resendVerificationEmail = async (emailId) => {\n try {\n const { status, data } = await resendVerificationEmailService(emailId);\n\n if (status !== 200) {\n console.error('Error', data);\n return {\n error: true,\n msg:\n data.response &&\n data.response.error &&\n data.response.error.faultDetail\n ? data.response.error.faultDetail[0]\n : 'Some error occured. Please contact support.',\n };\n }\n\n return true;\n } catch (e) {\n console.error(e);\n return {\n error: true,\n msg:\n e.response && e.response.error && e.response.error.faultDetail\n ? e.response.error.faultDetail[0]\n : 'Some error occured. Please contact support.',\n };\n }\n};\n\nexport const logout = () => {\n setAuthorization();\n};\n","import { MONTH_SHORT } from './constants';\n\nexport const dateDiff = (date1, date2) => {\n let [dt1Date, dt1Month, dt1Year] = date1.split('/');\n const dt2 = new Date(date2);\n\n dt1Month = dt1Month - 1;\n const dt1Hours = 0;\n\n const dt2Year = dt2.getFullYear();\n const dt2Month = dt2.getMonth();\n const dt2Date = dt2.getDate();\n const dt2Hours = dt2.getHours();\n\n if (dt1Year === dt2Year && dt1Month === dt2Month && dt1Date === dt2Date) {\n return (\n Math.floor(\n (Date.UTC(dt2Year, dt2Month, dt2Date, dt2Hours) -\n Date.UTC(dt1Year, dt1Month, dt1Date, dt1Hours)) /\n (1000 * 60 * 60)\n ) + ' hour(s)'\n );\n } else {\n return (\n Math.floor(\n (Date.UTC(dt2Year, dt2Month, dt2Date) -\n Date.UTC(dt1Year, dt1Month, dt1Date)) /\n (1000 * 60 * 60 * 24)\n ) + ' day(s)'\n );\n }\n};\n\nexport const getDateInUSFormat = (date) => {\n if (date) {\n let [day, month, year] = date.split('/');\n const dateStr = new Date(year, month, day).toLocaleDateString('en-US');\n return dateStr ? dateStr : '';\n }\n return '';\n};\n\nexport const isToday = (date) => {\n const today = new Date();\n return (\n date.getDate() === today.getDate() &&\n date.getMonth() === today.getMonth() &&\n date.getFullYear() === today.getFullYear()\n );\n};\n\nexport const getDateByMonthAndYear = (month, year) => {\n if (month === -1 || year === -1) {\n return 'Present';\n }\n\n if (!month && !year) {\n return '';\n }\n\n return `${MONTH_SHORT[month] || ''} ${year}`;\n};\n","import { SET_MENU_VISIBILITY } from 'actions/constants';\nimport { dispatch, getStore } from 'controllers/controller';\n\nexport const toggleMenu = () => {\n const isMenuOpen = getStore().user.isMenuOpen;\n\n dispatch({\n type: SET_MENU_VISIBILITY,\n isMenuOpen: !isMenuOpen,\n });\n};\n","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport formControlState from '../FormControl/formControlState';\nimport useFormControl from '../FormControl/useFormControl';\nimport withStyles from '../styles/withStyles';\nimport FormLabel from '../FormLabel';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n display: 'block',\n transformOrigin: 'top left'\n },\n\n /* Pseudo-class applied to the root element if `focused={true}`. */\n focused: {},\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Pseudo-class applied to the root element if `error={true}`. */\n error: {},\n\n /* Pseudo-class applied to the root element if `required={true}`. */\n required: {},\n\n /* Pseudo-class applied to the asterisk element. */\n asterisk: {},\n\n /* Styles applied to the root element if the component is a descendant of `FormControl`. */\n formControl: {\n position: 'absolute',\n left: 0,\n top: 0,\n // slight alteration to spec spacing to match visual spec result\n transform: 'translate(0, 24px) scale(1)'\n },\n\n /* Styles applied to the root element if `margin=\"dense\"`. */\n marginDense: {\n // Compensation for the `Input.inputDense` style.\n transform: 'translate(0, 21px) scale(1)'\n },\n\n /* Styles applied to the `input` element if `shrink={true}`. */\n shrink: {\n transform: 'translate(0, 1.5px) scale(0.75)',\n transformOrigin: 'top left'\n },\n\n /* Styles applied to the `input` element if `disableAnimation={false}`. */\n animated: {\n transition: theme.transitions.create(['color', 'transform'], {\n duration: theme.transitions.duration.shorter,\n easing: theme.transitions.easing.easeOut\n })\n },\n\n /* Styles applied to the root element if `variant=\"filled\"`. */\n filled: {\n // Chrome's autofill feature gives the input field a yellow background.\n // Since the input field is behind the label in the HTML tree,\n // the input field is drawn last and hides the label with an opaque background color.\n // zIndex: 1 will raise the label above opaque background-colors of input.\n zIndex: 1,\n pointerEvents: 'none',\n transform: 'translate(12px, 20px) scale(1)',\n '&$marginDense': {\n transform: 'translate(12px, 17px) scale(1)'\n },\n '&$shrink': {\n transform: 'translate(12px, 10px) scale(0.75)',\n '&$marginDense': {\n transform: 'translate(12px, 7px) scale(0.75)'\n }\n }\n },\n\n /* Styles applied to the root element if `variant=\"outlined\"`. */\n outlined: {\n // see comment above on filled.zIndex\n zIndex: 1,\n pointerEvents: 'none',\n transform: 'translate(14px, 20px) scale(1)',\n '&$marginDense': {\n transform: 'translate(14px, 12px) scale(1)'\n },\n '&$shrink': {\n transform: 'translate(14px, -6px) scale(0.75)'\n }\n }\n };\n};\nvar InputLabel = /*#__PURE__*/React.forwardRef(function InputLabel(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$disableAnimati = props.disableAnimation,\n disableAnimation = _props$disableAnimati === void 0 ? false : _props$disableAnimati,\n margin = props.margin,\n shrinkProp = props.shrink,\n variant = props.variant,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"disableAnimation\", \"margin\", \"shrink\", \"variant\"]);\n\n var muiFormControl = useFormControl();\n var shrink = shrinkProp;\n\n if (typeof shrink === 'undefined' && muiFormControl) {\n shrink = muiFormControl.filled || muiFormControl.focused || muiFormControl.adornedStart;\n }\n\n var fcs = formControlState({\n props: props,\n muiFormControl: muiFormControl,\n states: ['margin', 'variant']\n });\n return /*#__PURE__*/React.createElement(FormLabel, _extends({\n \"data-shrink\": shrink,\n className: clsx(classes.root, className, muiFormControl && classes.formControl, !disableAnimation && classes.animated, shrink && classes.shrink, fcs.margin === 'dense' && classes.marginDense, {\n 'filled': classes.filled,\n 'outlined': classes.outlined\n }[fcs.variant]),\n classes: {\n focused: classes.focused,\n disabled: classes.disabled,\n error: classes.error,\n required: classes.required,\n asterisk: classes.asterisk\n },\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? InputLabel.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * The contents of the `InputLabel`.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * If `true`, the transition animation is disabled.\n */\n disableAnimation: PropTypes.bool,\n\n /**\n * If `true`, apply disabled class.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the label will be displayed in an error state.\n */\n error: PropTypes.bool,\n\n /**\n * If `true`, the input of this label is focused.\n */\n focused: PropTypes.bool,\n\n /**\n * If `dense`, will adjust vertical spacing. This is normally obtained via context from\n * FormControl.\n */\n margin: PropTypes.oneOf(['dense']),\n\n /**\n * if `true`, the label will indicate that the input is required.\n */\n required: PropTypes.bool,\n\n /**\n * If `true`, the label is shrunk.\n */\n shrink: PropTypes.bool,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['filled', 'outlined', 'standard'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiInputLabel'\n})(InputLabel);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport Input from '../Input';\nimport FilledInput from '../FilledInput';\nimport OutlinedInput from '../OutlinedInput';\nimport InputLabel from '../InputLabel';\nimport FormControl from '../FormControl';\nimport FormHelperText from '../FormHelperText';\nimport Select from '../Select';\nimport withStyles from '../styles/withStyles';\nvar variantComponent = {\n standard: Input,\n filled: FilledInput,\n outlined: OutlinedInput\n};\nexport var styles = {\n /* Styles applied to the root element. */\n root: {}\n};\n/**\n * The `TextField` is a convenience wrapper for the most common cases (80%).\n * It cannot be all things to all people, otherwise the API would grow out of control.\n *\n * ## Advanced Configuration\n *\n * It's important to understand that the text field is a simple abstraction\n * on top of the following components:\n *\n * - [FormControl](/api/form-control/)\n * - [InputLabel](/api/input-label/)\n * - [FilledInput](/api/filled-input/)\n * - [OutlinedInput](/api/outlined-input/)\n * - [Input](/api/input/)\n * - [FormHelperText](/api/form-helper-text/)\n *\n * If you wish to alter the props applied to the `input` element, you can do so as follows:\n *\n * ```jsx\n * const inputProps = {\n * step: 300,\n * };\n *\n * return ;\n * ```\n *\n * For advanced cases, please look at the source of TextField by clicking on the\n * \"Edit this page\" button above. Consider either:\n *\n * - using the upper case props for passing values directly to the components\n * - using the underlying components directly as shown in the demos\n */\n\nvar TextField = /*#__PURE__*/React.forwardRef(function TextField(props, ref) {\n var autoComplete = props.autoComplete,\n _props$autoFocus = props.autoFocus,\n autoFocus = _props$autoFocus === void 0 ? false : _props$autoFocus,\n children = props.children,\n classes = props.classes,\n className = props.className,\n _props$color = props.color,\n color = _props$color === void 0 ? 'primary' : _props$color,\n defaultValue = props.defaultValue,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$error = props.error,\n error = _props$error === void 0 ? false : _props$error,\n FormHelperTextProps = props.FormHelperTextProps,\n _props$fullWidth = props.fullWidth,\n fullWidth = _props$fullWidth === void 0 ? false : _props$fullWidth,\n helperText = props.helperText,\n hiddenLabel = props.hiddenLabel,\n id = props.id,\n InputLabelProps = props.InputLabelProps,\n inputProps = props.inputProps,\n InputProps = props.InputProps,\n inputRef = props.inputRef,\n label = props.label,\n _props$multiline = props.multiline,\n multiline = _props$multiline === void 0 ? false : _props$multiline,\n name = props.name,\n onBlur = props.onBlur,\n onChange = props.onChange,\n onFocus = props.onFocus,\n placeholder = props.placeholder,\n _props$required = props.required,\n required = _props$required === void 0 ? false : _props$required,\n rows = props.rows,\n rowsMax = props.rowsMax,\n _props$select = props.select,\n select = _props$select === void 0 ? false : _props$select,\n SelectProps = props.SelectProps,\n type = props.type,\n value = props.value,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'standard' : _props$variant,\n other = _objectWithoutProperties(props, [\"autoComplete\", \"autoFocus\", \"children\", \"classes\", \"className\", \"color\", \"defaultValue\", \"disabled\", \"error\", \"FormHelperTextProps\", \"fullWidth\", \"helperText\", \"hiddenLabel\", \"id\", \"InputLabelProps\", \"inputProps\", \"InputProps\", \"inputRef\", \"label\", \"multiline\", \"name\", \"onBlur\", \"onChange\", \"onFocus\", \"placeholder\", \"required\", \"rows\", \"rowsMax\", \"select\", \"SelectProps\", \"type\", \"value\", \"variant\"]);\n\n if (process.env.NODE_ENV !== 'production') {\n if (select && !children) {\n console.error('Material-UI: `children` must be passed when using the `TextField` component with `select`.');\n }\n }\n\n var InputMore = {};\n\n if (variant === 'outlined') {\n if (InputLabelProps && typeof InputLabelProps.shrink !== 'undefined') {\n InputMore.notched = InputLabelProps.shrink;\n }\n\n if (label) {\n var _InputLabelProps$requ;\n\n var displayRequired = (_InputLabelProps$requ = InputLabelProps === null || InputLabelProps === void 0 ? void 0 : InputLabelProps.required) !== null && _InputLabelProps$requ !== void 0 ? _InputLabelProps$requ : required;\n InputMore.label = /*#__PURE__*/React.createElement(React.Fragment, null, label, displayRequired && \"\\xA0*\");\n }\n }\n\n if (select) {\n // unset defaults from textbox inputs\n if (!SelectProps || !SelectProps.native) {\n InputMore.id = undefined;\n }\n\n InputMore['aria-describedby'] = undefined;\n }\n\n var helperTextId = helperText && id ? \"\".concat(id, \"-helper-text\") : undefined;\n var inputLabelId = label && id ? \"\".concat(id, \"-label\") : undefined;\n var InputComponent = variantComponent[variant];\n var InputElement = /*#__PURE__*/React.createElement(InputComponent, _extends({\n \"aria-describedby\": helperTextId,\n autoComplete: autoComplete,\n autoFocus: autoFocus,\n defaultValue: defaultValue,\n fullWidth: fullWidth,\n multiline: multiline,\n name: name,\n rows: rows,\n rowsMax: rowsMax,\n type: type,\n value: value,\n id: id,\n inputRef: inputRef,\n onBlur: onBlur,\n onChange: onChange,\n onFocus: onFocus,\n placeholder: placeholder,\n inputProps: inputProps\n }, InputMore, InputProps));\n return /*#__PURE__*/React.createElement(FormControl, _extends({\n className: clsx(classes.root, className),\n disabled: disabled,\n error: error,\n fullWidth: fullWidth,\n hiddenLabel: hiddenLabel,\n ref: ref,\n required: required,\n color: color,\n variant: variant\n }, other), label && /*#__PURE__*/React.createElement(InputLabel, _extends({\n htmlFor: id,\n id: inputLabelId\n }, InputLabelProps), label), select ? /*#__PURE__*/React.createElement(Select, _extends({\n \"aria-describedby\": helperTextId,\n id: id,\n labelId: inputLabelId,\n value: value,\n input: InputElement\n }, SelectProps), children) : InputElement, helperText && /*#__PURE__*/React.createElement(FormHelperText, _extends({\n id: helperTextId\n }, FormHelperTextProps), helperText));\n});\nprocess.env.NODE_ENV !== \"production\" ? TextField.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * This prop helps users to fill forms faster, especially on mobile devices.\n * The name can be confusing, as it's more like an autofill.\n * You can learn more about it [following the specification](https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#autofill).\n */\n autoComplete: PropTypes.string,\n\n /**\n * If `true`, the `input` element will be focused during the first mount.\n */\n autoFocus: PropTypes.bool,\n\n /**\n * @ignore\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * The default value of the `input` element.\n */\n defaultValue: PropTypes.any,\n\n /**\n * If `true`, the `input` element will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the label will be displayed in an error state.\n */\n error: PropTypes.bool,\n\n /**\n * Props applied to the [`FormHelperText`](/api/form-helper-text/) element.\n */\n FormHelperTextProps: PropTypes.object,\n\n /**\n * If `true`, the input will take up the full width of its container.\n */\n fullWidth: PropTypes.bool,\n\n /**\n * The helper text content.\n */\n helperText: PropTypes.node,\n\n /**\n * @ignore\n */\n hiddenLabel: PropTypes.bool,\n\n /**\n * The id of the `input` element.\n * Use this prop to make `label` and `helperText` accessible for screen readers.\n */\n id: PropTypes.string,\n\n /**\n * Props applied to the [`InputLabel`](/api/input-label/) element.\n */\n InputLabelProps: PropTypes.object,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Props applied to the Input element.\n * It will be a [`FilledInput`](/api/filled-input/),\n * [`OutlinedInput`](/api/outlined-input/) or [`Input`](/api/input/)\n * component depending on the `variant` prop value.\n */\n InputProps: PropTypes.object,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /**\n * The label content.\n */\n label: PropTypes.node,\n\n /**\n * If `dense` or `normal`, will adjust vertical spacing of this and contained components.\n */\n margin: PropTypes.oneOf(['dense', 'none', 'normal']),\n\n /**\n * If `true`, a textarea element will be rendered instead of an input.\n */\n multiline: PropTypes.bool,\n\n /**\n * Name attribute of the `input` element.\n */\n name: PropTypes.string,\n\n /**\n * @ignore\n */\n onBlur: PropTypes.func,\n\n /**\n * Callback fired when the value is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (string).\n */\n onChange: PropTypes.func,\n\n /**\n * @ignore\n */\n onFocus: PropTypes.func,\n\n /**\n * The short hint displayed in the input before the user enters a value.\n */\n placeholder: PropTypes.string,\n\n /**\n * If `true`, the label is displayed as required and the `input` element` will be required.\n */\n required: PropTypes.bool,\n\n /**\n * Number of rows to display when multiline option is set to true.\n */\n rows: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n /**\n * Maximum number of rows to display when multiline option is set to true.\n */\n rowsMax: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n /**\n * Render a [`Select`](/api/select/) element while passing the Input element to `Select` as `input` parameter.\n * If this option is set you must pass the options of the select as children.\n */\n select: PropTypes.bool,\n\n /**\n * Props applied to the [`Select`](/api/select/) element.\n */\n SelectProps: PropTypes.object,\n\n /**\n * The size of the text field.\n */\n size: PropTypes.oneOf(['medium', 'small']),\n\n /**\n * Type of the `input` element. It should be [a valid HTML5 input type](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Form_%3Cinput%3E_types).\n */\n type: PropTypes.string,\n\n /**\n * The value of the `input` element, required for a controlled component.\n */\n value: PropTypes.any,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['filled', 'outlined', 'standard'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiTextField'\n})(TextField);","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport formControlState from '../FormControl/formControlState';\nimport useFormControl from '../FormControl/useFormControl';\nimport withStyles from '../styles/withStyles';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: _extends({\n color: theme.palette.text.secondary\n }, theme.typography.caption, {\n textAlign: 'left',\n marginTop: 3,\n margin: 0,\n '&$disabled': {\n color: theme.palette.text.disabled\n },\n '&$error': {\n color: theme.palette.error.main\n }\n }),\n\n /* Pseudo-class applied to the root element if `error={true}`. */\n error: {},\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the root element if `margin=\"dense\"`. */\n marginDense: {\n marginTop: 4\n },\n\n /* Styles applied to the root element if `variant=\"filled\"` or `variant=\"outlined\"`. */\n contained: {\n marginLeft: 14,\n marginRight: 14\n },\n\n /* Pseudo-class applied to the root element if `focused={true}`. */\n focused: {},\n\n /* Pseudo-class applied to the root element if `filled={true}`. */\n filled: {},\n\n /* Pseudo-class applied to the root element if `required={true}`. */\n required: {}\n };\n};\nvar FormHelperText = /*#__PURE__*/React.forwardRef(function FormHelperText(props, ref) {\n var children = props.children,\n classes = props.classes,\n className = props.className,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'p' : _props$component,\n disabled = props.disabled,\n error = props.error,\n filled = props.filled,\n focused = props.focused,\n margin = props.margin,\n required = props.required,\n variant = props.variant,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"className\", \"component\", \"disabled\", \"error\", \"filled\", \"focused\", \"margin\", \"required\", \"variant\"]);\n\n var muiFormControl = useFormControl();\n var fcs = formControlState({\n props: props,\n muiFormControl: muiFormControl,\n states: ['variant', 'margin', 'disabled', 'error', 'filled', 'focused', 'required']\n });\n return /*#__PURE__*/React.createElement(Component, _extends({\n className: clsx(classes.root, (fcs.variant === 'filled' || fcs.variant === 'outlined') && classes.contained, className, fcs.disabled && classes.disabled, fcs.error && classes.error, fcs.filled && classes.filled, fcs.focused && classes.focused, fcs.required && classes.required, fcs.margin === 'dense' && classes.marginDense),\n ref: ref\n }, other), children === ' ' ?\n /*#__PURE__*/\n // eslint-disable-next-line react/no-danger\n React.createElement(\"span\", {\n dangerouslySetInnerHTML: {\n __html: '​'\n }\n }) : children);\n});\nprocess.env.NODE_ENV !== \"production\" ? FormHelperText.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * The content of the component.\n *\n * If `' '` is provided, the component reserves one line height for displaying a future message.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes\n /* @typescript-to-proptypes-ignore */\n .elementType,\n\n /**\n * If `true`, the helper text should be displayed in a disabled state.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, helper text should be displayed in an error state.\n */\n error: PropTypes.bool,\n\n /**\n * If `true`, the helper text should use filled classes key.\n */\n filled: PropTypes.bool,\n\n /**\n * If `true`, the helper text should use focused classes key.\n */\n focused: PropTypes.bool,\n\n /**\n * If `dense`, will adjust vertical spacing. This is normally obtained via context from\n * FormControl.\n */\n margin: PropTypes.oneOf(['dense']),\n\n /**\n * If `true`, the helper text should use required classes key.\n */\n required: PropTypes.bool,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['filled', 'outlined', 'standard'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiFormHelperText'\n})(FormHelperText);","import * as React from 'react';\nimport createSvgIcon from './utils/createSvgIcon';\nexport default createSvgIcon( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M11.88 9.14c1.28.06 1.61 1.15 1.63 1.66h1.79c-.08-1.98-1.49-3.19-3.45-3.19C9.64 7.61 8 9 8 12.14c0 1.94.93 4.24 3.84 4.24 2.22 0 3.41-1.65 3.44-2.95h-1.79c-.03.59-.45 1.38-1.63 1.44-1.31-.04-1.86-1.06-1.86-2.73 0-2.89 1.28-2.98 1.88-3zM12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8z\"\n}), 'Copyright');","import React from 'react';\nimport { Grid, Typography, Box } from '@material-ui/core';\nimport { Copyright, Favorite } from '@material-ui/icons';\nimport { IMG_LOGO_WHITE } from 'images';\nimport './footer.scss';\nimport { useHistory } from 'react-router-dom';\n\nconst Footer = () => {\n const history = useHistory();\n\n return (\n
\n \n \n \n \n \n \n {new Date().getFullYear()} Senseloaf Pvt LTD\n \n \n \n About\n \n history.push('/terms-of-service')}\n >\n Terms\n \n history.push('/privacy-policy')}\n >\n Privacy\n \n \n Made with{' '}\n \n \n \n {' '}\n BLR\n \n \n \n \n \n
\n );\n};\n\nexport default Footer;\n","import React from 'react';\nimport { Grid, Box } from '@material-ui/core';\nimport { IMG_LOGO } from 'images';\nimport './topBar.scss';\n\nconst TopBar = () => {\n return (\n
\n \n \n \n \n \n \n \n
\n );\n};\n\nexport default TopBar;\n","import * as React from 'react';\nimport createSvgIcon from './utils/createSvgIcon';\nexport default createSvgIcon( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z\"\n}), 'Favorite');","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport Typography from '../Typography';\nimport withStyles from '../styles/withStyles';\nimport FormControlContext, { useFormControl } from '../FormControl/FormControlContext';\nexport var styles = {\n /* Styles applied to the root element. */\n root: {\n display: 'flex',\n height: '0.01em',\n // Fix IE 11 flexbox alignment. To remove at some point.\n maxHeight: '2em',\n alignItems: 'center',\n whiteSpace: 'nowrap'\n },\n\n /* Styles applied to the root element if `variant=\"filled\"`. */\n filled: {\n '&$positionStart:not($hiddenLabel)': {\n marginTop: 16\n }\n },\n\n /* Styles applied to the root element if `position=\"start\"`. */\n positionStart: {\n marginRight: 8\n },\n\n /* Styles applied to the root element if `position=\"end\"`. */\n positionEnd: {\n marginLeft: 8\n },\n\n /* Styles applied to the root element if `disablePointerEvents=true`. */\n disablePointerEvents: {\n pointerEvents: 'none'\n },\n\n /* Styles applied if the adornment is used inside . */\n hiddenLabel: {},\n\n /* Styles applied if the adornment is used inside . */\n marginDense: {}\n};\nvar InputAdornment = /*#__PURE__*/React.forwardRef(function InputAdornment(props, ref) {\n var children = props.children,\n classes = props.classes,\n className = props.className,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'div' : _props$component,\n _props$disablePointer = props.disablePointerEvents,\n disablePointerEvents = _props$disablePointer === void 0 ? false : _props$disablePointer,\n _props$disableTypogra = props.disableTypography,\n disableTypography = _props$disableTypogra === void 0 ? false : _props$disableTypogra,\n position = props.position,\n variantProp = props.variant,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"className\", \"component\", \"disablePointerEvents\", \"disableTypography\", \"position\", \"variant\"]);\n\n var muiFormControl = useFormControl() || {};\n var variant = variantProp;\n\n if (variantProp && muiFormControl.variant) {\n if (process.env.NODE_ENV !== 'production') {\n if (variantProp === muiFormControl.variant) {\n console.error('Material-UI: The `InputAdornment` variant infers the variant prop ' + 'you do not have to provide one.');\n }\n }\n }\n\n if (muiFormControl && !variant) {\n variant = muiFormControl.variant;\n }\n\n return /*#__PURE__*/React.createElement(FormControlContext.Provider, {\n value: null\n }, /*#__PURE__*/React.createElement(Component, _extends({\n className: clsx(classes.root, className, disablePointerEvents && classes.disablePointerEvents, muiFormControl.hiddenLabel && classes.hiddenLabel, variant === 'filled' && classes.filled, {\n 'start': classes.positionStart,\n 'end': classes.positionEnd\n }[position], muiFormControl.margin === 'dense' && classes.marginDense),\n ref: ref\n }, other), typeof children === 'string' && !disableTypography ? /*#__PURE__*/React.createElement(Typography, {\n color: \"textSecondary\"\n }, children) : children));\n});\nprocess.env.NODE_ENV !== \"production\" ? InputAdornment.propTypes = {\n /**\n * The content of the component, normally an `IconButton` or string.\n */\n children: PropTypes.node.isRequired,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes\n /* @typescript-to-proptypes-ignore */\n .elementType,\n\n /**\n * Disable pointer events on the root.\n * This allows for the content of the adornment to focus the input on click.\n */\n disablePointerEvents: PropTypes.bool,\n\n /**\n * If children is a string then disable wrapping in a Typography component.\n */\n disableTypography: PropTypes.bool,\n\n /**\n * @ignore\n */\n muiFormControl: PropTypes.object,\n\n /**\n * The position this adornment should appear relative to the `Input`.\n */\n position: PropTypes.oneOf(['start', 'end']),\n\n /**\n * The variant to use.\n * Note: If you are using the `TextField` component or the `FormControl` component\n * you do not have to set this manually.\n */\n variant: PropTypes.oneOf(['standard', 'outlined', 'filled'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiInputAdornment'\n})(InputAdornment);","import * as React from 'react';\nimport createSvgIcon from './utils/createSvgIcon';\nexport default createSvgIcon( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M12 4.5C7 4.5 2.73 7.61 1 12c1.73 4.39 6 7.5 11 7.5s9.27-3.11 11-7.5c-1.73-4.39-6-7.5-11-7.5zM12 17c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5zm0-8c-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3-1.34-3-3-3z\"\n}), 'Visibility');","import * as React from 'react';\nimport createSvgIcon from './utils/createSvgIcon';\nexport default createSvgIcon( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M12 7c2.76 0 5 2.24 5 5 0 .65-.13 1.26-.36 1.83l2.92 2.92c1.51-1.26 2.7-2.89 3.43-4.75-1.73-4.39-6-7.5-11-7.5-1.4 0-2.74.25-3.98.7l2.16 2.16C10.74 7.13 11.35 7 12 7zM2 4.27l2.28 2.28.46.46C3.08 8.3 1.78 10.02 1 12c1.73 4.39 6 7.5 11 7.5 1.55 0 3.03-.3 4.38-.84l.42.42L19.73 22 21 20.73 3.27 3 2 4.27zM7.53 9.8l1.55 1.55c-.05.21-.08.43-.08.65 0 1.66 1.34 3 3 3 .22 0 .44-.03.65-.08l1.55 1.55c-.67.33-1.41.53-2.2.53-2.76 0-5-2.24-5-5 0-.79.2-1.53.53-2.2zm4.31-.78l3.15 3.15.02-.16c0-1.66-1.34-3-3-3l-.17.01z\"\n}), 'VisibilityOff');","import React, { PureComponent } from 'react';\nimport {\n Button,\n Grid,\n Typography,\n Box,\n TextField,\n InputAdornment,\n IconButton,\n} from '@material-ui/core';\nimport { Visibility, VisibilityOff } from '@material-ui/icons';\nimport { IMG_PLUS } from 'images';\nimport './login.scss';\nimport Footer from 'common/footer/footer';\nimport TopBar from 'common/topBar/topBar';\n\nclass Login extends PureComponent {\n preventDefault = (e) => {\n e.preventDefault();\n };\n\n render() {\n const {\n email,\n password,\n error,\n onChange,\n onLogin,\n showPassword,\n onChangePasswordVisibility,\n onClickForgotPassword,\n onClickSignup,\n } = this.props;\n\n return (\n
\n \n \n \n \"Senseloaf\"\n \n \n \n Welcome Back!\n \n \n \n \n Login using your registered email.\n \n \n \n {error}\n \n \n \n \n {showPassword ? : }\n \n \n ),\n }}\n />\n \n \n Forgot password\n \n \n Signup\n \n \n \n \n Login\n \n \n \n \n \n \n
\n
\n );\n }\n}\n\nexport default Login;\n","import React, { Component, Fragment } from 'react';\nimport Login from './login';\nimport { login } from 'controllers/authenticationController';\nimport { Loader } from 'common';\nimport { toggleMenu } from 'controllers/user/toggleMenu';\nclass LoginContainer extends Component {\n constructor() {\n super();\n this.state = {\n emailId: '',\n password: '',\n loading: false,\n error: false,\n showPassword: true,\n };\n }\n\n onChangeHandler = (e) => {\n this.setState({\n [e.target.name]: e.target.value,\n });\n };\n\n onLoginHandler = async () => {\n const { emailId, password } = this.state;\n const { history } = this.props;\n\n this.setState({\n loading: true,\n error: false,\n });\n const response = await login(emailId, password);\n\n this.setState({\n loading: false,\n error: response.msg || false,\n });\n\n if (response && !response.error) {\n const pathname = localStorage.getItem('pathname');\n\n if (pathname) {\n localStorage.setItem('pathname', '');\n history.push(pathname);\n } else {\n history.push('/resume-parser');\n toggleMenu();\n }\n } else if (!response) {\n history.push(`/verify-email?emailid=${emailId}`);\n }\n };\n\n onChangePasswordVisibility = () => {\n this.setState((prevState) => ({\n showPassword: !prevState.showPassword,\n }));\n };\n\n onClickForgotPassword = () => {\n const { history } = this.props;\n\n history.push('/reset-password');\n };\n\n onClickSignup = () => {\n const { history } = this.props;\n\n history.push('/signup');\n };\n\n render() {\n const { emailId, password, loading, error, showPassword } = this.state;\n\n return (\n \n \n {loading ? : null}\n \n );\n }\n}\n\nexport default LoginContainer;\n"],"sourceRoot":""}