{"version":3,"sources":["configs/constants.ts","configs/endpoints.ts","logo/Logo.tsx","services/cookieStorageSync.ts","store/ducks/session.ts","store/ducks/tasks.ts","services/utility.ts","store/ducks/projects.ts","store/ducks/sections.ts","store/ducks/labels.ts","store/ducks/todoFilters.ts","store/index.ts","services/axioService.ts","containers/login/Login.tsx","containers/register/Register.tsx","containers/privateRoute/PrivateRoute.tsx","components/profileItemView/ProfileItemView.tsx","containers/accountLogoutDropdown/AccountLogoutDropdown.tsx","containers/appsDropdown/AppsDropdown.tsx","containers/header/Header.tsx","components/upcomingBadge/UpcomingBadge.tsx","components/sider/Sider.tsx","hocs/withAccountLayout/withAccountLayout.tsx","containers/cityModal/CityModal.tsx","containers/countryModal/CountryModal.tsx","containers/dobModal/DOBModal.tsx","containers/genderModal/GenderModal.tsx","containers/nameModal/NameModal.tsx","containers/passwordModal/PasswordModal.tsx","containers/phoneModal/PhoneModal.tsx","containers/professionModal/ProfessionModal.tsx","containers/picModal/PicModal.tsx","containers/account/Account.tsx","containers/sessionDestroy/SessionDestroy.tsx","components/forgotPasswordSuccess/ForgotPasswordSuccess.tsx","containers/accountRecovery/AccountRecovery.tsx","containers/resetPassword/ResetPassword.tsx","containers/sessionAuthorize/SessionAuthorize.tsx","containers/verifyEmail/VerifyEmail.tsx","App/App.tsx","serviceWorker.ts","index.tsx"],"names":["SERVER_LOGIN_GRANT_TYPE","process","REACT_APP_LOGIN_GRANT_TYPE","SERVER_LOGIN_CLIENT_ID","REACT_APP_LOGIN_CLIENT_ID","SERVER_LOGIN_CLIENT_SCOPE","REACT_APP_LOGIN_CLIENT_SCOPE","SERVER_LOGIN_APP_NAME","REACT_APP_LOGIN_APP_NAME","SERVER_REGISTER_ENDPOINT","REACT_APP_REGISTER_USER_ENDPOINT","SERVER_LOGIN_ENDPOINT","REACT_APP_LOGIN_USER_ENDPOINT","SERVER_LOGOUT_ENDPOINT","REACT_APP_LOGOUT_USER_ENDPOINT","SERVER_FORGOT_PASSWORD_ENDPOINT","REACT_APP_FORGOT_PASSWORD_ENDPOINT","SERVER_RESET_PASSWORD_ENDPOINT","REACT_APP_RESET_PASSWORD_ENDPOINT","SERVER_CHANGE_PASSWORD_ENDPOINT","REACT_APP_CHANGE_PASSWORD_ENDPOINT","SERVER_USER_PROFILE_ENDPOINT","REACT_APP_USER_PROFILE_ENDPOINT","SERVER_EMAIL_VERIFY_ENDPOINT","REACT_APP_EMAIL_VERIFY_ENDPOINT","SERVER_SEND_EMAIL_ENDPOINT","REACT_APP_SEND_EMAIL_ENDPOINT","SERVER_AVATAR_ENDPOINT","REACT_APP_AVATAR_ENDPOINT","SERVER_GOOGLE_AUTH_LINK","REACT_APP_GOOGLE_AUTH_LINK","SERVER_APPLE_AUTH_LINK","REACT_APP_FACEBOOK_AUTH_LINK","REACT_APP_APPLE_AUTH_LINK","BLOG_ENDPOINT","REACT_APP_TODO_ENDPOINT","REACT_APP_BLOG_ENDPOINT","TERMS_OF_SERVICE_ENDPOINT","REACT_APP_TERMS_OF_SERVICE_ENDPOINT","PRIVACY_POLICY_ENDPOINT","REACT_APP_PRIVACY_POLICY_ENDPOINT","VIRTUNUS_HOME_ENDPOINT","REACT_APP_VIRTUNUS_HOME_ENDPOINT","Logo","href","src","width","alt","getDomain","url","subdomain","domainUrl","replace","split","slice","length","join","indexOf","SET_SESSION_TOKEN","SET_SESSION_INFO","RESET_SESSION","setSessionToken","token","type","setSessionUserInfo","userInfo","initialState","SeamlessImmutable","getSessionToken","state","getSessionUserInfo","isAuthenticated","SET_TASKS","SET_TASK","UPDATE_TASKS","FIX_TASK_ORDERS","SET_PROJECTS","UPDATE_PROJECTS","SET_PROJECT","FIX_PROJECT_ORDERS","SET_PROJECTS_SYNCED_STATUS","SET_SECTIONS","SET_SECTION","UPDATE_SECTIONS","FIX_SECTION_ORDERS","SET_LABELS","UPDATE_LABELS","SET_LABEL","FIX_LABEL_ORDERS","SET_LABELS_SYNCED_STATUS","SET_TODO_FILTERS","SET_TODO_FILTER","FIX_TODO_FILTER_ORDERS","defaultReducers","action","asMutable","deep","projects","lodash","filter","iterateProj","ids","includes","id","iterateProject","project","parent","parentId","map","index","order","synced","status","sections","iterateSection","section","iter","projectId","orderBy","tasks","iterateTask","task","sectionId","labels","iterateLabel","label","todoFilters","iterateTodoFilter","todoFilter","reducers","withReduxStateSync","combineReducers","middlewares","createStateSyncMiddleware","composeEnhancers","window","__REDUX_DEVTOOLS_EXTENSION_COMPOSE__","compose","persistedState","serializedState","Cookies","get","JSON","parse","err","loadState","immutablePersistedState","store","createStore","applyMiddleware","subscribe","stringify","domain","REACT_APP_STATUS","location","hostname","set","expires","exception","console","error","saveState","getState","initStateWithPrevTab","POST","axioGet","a","params","isProtected","config","headers","Accept","Authorization","axios","response","axioPost","post","axioService","mapDispatchToProps","setSessionTokenActionCreator","ConnectedLogin","connect","props","useState","isEmailFocued","setIsEmailFocued","isPasswordFocued","setIsPasswordFocued","useLocation","passwordRef","useHistory","React","useRef","emailRef","loading","setLoading","errorMessage","setErrorMessage","isPasswordVisible","setIsPasswordVisible","useEffect","current","focus","handlePasswordVisibility","blur","onFinish","values","grant_type","client_id","client_secret","username","password","scope","app_name","data","access_token","message","errorMsg","errors","Object","keys","iterErrorField","key","className","sessionStorage","setItem","queryString","search","spinning","closable","onClose","description","showIcon","name","initialValues","remember","validateTrigger","onFinishFailed","errorInfo","Item","clsx","rules","required","size","onFocus","onBlur","placeholder","ref","prefix","min","suffix","onClick","htmlType","to","height","viewBox","fill","xmlns","d","ConnectedRegister","history","nameRef","passwordConfirmationRef","isNameFocused","setIsNameFocused","isEmailFocused","setIsEmailFocused","isPasswordFocused","setIsPasswordFocused","isConfirmPasswordFocused","setIsConfirmPasswordFocused","isPasswordConfirmationVisible","setIsPasswordConfirmationVisible","handlePasswordConfirmationVisibility","email","password_confirmation","success","push","getFieldValue","validator","rule","value","Promise","reject","resolve","extra","target","ConnectedPrivateRoute","parentProps","Component","component","rest","render","pathname","from","ProfileItemView","requestedHandler","ConnectedAccountLogoutDropdown","avatar","ConnectedAppsDropdown","ConnectedHeader","isEmailSend","setIsEmailSend","sendVerificationEmail","is_email_verified","banner","trigger","overlay","placement","UpcomingBadge","Sider","withAccountLayout","CityModal","visible","cancelHandler","selected","saveHandler","text","setText","confirmHandler","request","FormData","append","title","okText","onOk","onCancel","okButtonProps","disabled","onPressEnter","onChange","event","CountryModal","DOBModal","defaultValue","moment","date","dateString","allowClear","disabledDate","isAfter","GENDER_OPTIONS","GenderModal","Group","options","NameModal","PasswordModal","confirmText","setConfirmText","currentPassword","setCurrentPassword","Password","iconRender","PhoneModal","ProfessionModal","PicModal","files","setFiles","useDropzone","accept","maxFiles","onDrop","acceptedFiles","file","assign","preview","URL","createObjectURL","getRootProps","getInputProps","forEach","revokeObjectURL","confirmRequest","setUserInfoActionCreator","picModalVisible","setPicModalVisible","nameModalVisible","setNameModalVisible","dobModalVisible","setDobModalVisible","genderModalVisible","setGenderModalVisible","professionModalVisible","setProfessionModalVisible","countryModalVisible","setCountryModalVisible","cityModalVisible","setCityModalVisible","passwordModalVisible","setPasswordModalVisible","phoneModalVisible","setPhoneModalVisible","date_of_birth","gender","profession","city","country","mobile","requested","resetSessionActionCreator","ConnectedSessionDestroy","clearSession","app","guest","tip","ForgotPasswordSuccess","ConnectedAccountRecovery","successMessage","setSuccessMessage","ConnectedResetPassword","onAlertClose","ConnectedSessionAuthorize","ConnectedVerifyEmail","useParams","hash","setError","signature","setTimeout","runEmailVerification","setSessionUserInfoActionCreator","ConnectedApp","document","body","style","setProperty","afterGettingUser","fetchProfile","getItem","redirectEndpoint","Fragment","path","Account","Boolean","match","ReactDOM","StrictMode","DndProvider","backend","HTML5Backend","getElementById","navigator","serviceWorker","ready","then","registration","unregister","catch"],"mappings":"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","file":"static/js/main.f30a7664.chunk.js","sourcesContent":["/** global constants */\n\n/** server login grant type */\nexport const SERVER_LOGIN_GRANT_TYPE =\n process.env.REACT_APP_LOGIN_GRANT_TYPE || 'password';\n\n/** server login client id */\nexport const SERVER_LOGIN_CLIENT_ID =\n process.env.REACT_APP_LOGIN_CLIENT_ID || '2';\n\n/** server login client secret */\nexport const SERVER_LOGIN_CLIENT_SECRET =\n process.env.REACT_APP_LOGIN_CLIENT_SECRET ||\n 'UF9kmGh5ks1y7UOn8yqTEXkq6CvXSpekQdy9tryb';\n\n/** server login client scope */\nexport const SERVER_LOGIN_CLIENT_SCOPE =\n process.env.REACT_APP_LOGIN_CLIENT_SCOPE || '*';\n\n/** server login app name */\nexport const SERVER_LOGIN_APP_NAME =\n process.env.REACT_APP_LOGIN_APP_NAME || 'virtunus_auth';\n","/** local */\n\n/** local login endpoint */\nexport const LOCAL_LOGIN_ENDPOINT = `/login`;\n\n/** local register endpoint */\nexport const LOCAL_REGISTER_ENDPOINT = `/register`;\n\n/** local forgot password endpoint */\nexport const LOCAL_FORGOT_PASSWORD_ENDPOINT = `/forgot-password`;\n\n/** local reset password endpoint */\nexport const LOCAL_RESET_PASSWORD_ENDPOINT = `/reset-password`;\n\n/** local logout endpoint */\nexport const LOCAL_LOGOUT_ENDPOINT = `/logout`;\n\n/** local logout endpoint */\nexport const LOCAL_AUTHORIZE_ENDPOINT = `/authorize`;\n\n/** local verify email endpoint */\nexport const LOCAL_VERIFY_EMAIL_ENDPOINT = `/email/verify/:id/:hash`;\n\n/** local personal info endpoint */\nexport const LOCAL_PERSONAL_INFO_ENDPOINT = `/account/personal-info`;\n\n/** server */\n\n/** server register endpoint */\nexport const SERVER_REGISTER_ENDPOINT =\n process.env.REACT_APP_REGISTER_USER_ENDPOINT ||\n `${process.env.REACT_APP_SERVER_ENDPOINT}/auth/register`;\n\n/** server login endpoint */\nexport const SERVER_LOGIN_ENDPOINT =\n process.env.REACT_APP_LOGIN_USER_ENDPOINT ||\n `${process.env.REACT_APP_SERVER_ENDPOINT}/oauth/token`;\n\n/** server login endpoint */\nexport const SERVER_LOGOUT_ENDPOINT =\n process.env.REACT_APP_LOGOUT_USER_ENDPOINT ||\n `${process.env.REACT_APP_SERVER_ENDPOINT}/auth/logout`;\n\n/** server forgot password endpoint */\nexport const SERVER_FORGOT_PASSWORD_ENDPOINT =\n process.env.REACT_APP_FORGOT_PASSWORD_ENDPOINT ||\n `${process.env.REACT_APP_SERVER_ENDPOINT}/auth/forgot-password`;\n\n/** server reset password endpoint */\nexport const SERVER_RESET_PASSWORD_ENDPOINT =\n process.env.REACT_APP_RESET_PASSWORD_ENDPOINT ||\n `${process.env.REACT_APP_SERVER_ENDPOINT}/auth/reset-password`;\n\n/** server change password endpoint */\nexport const SERVER_CHANGE_PASSWORD_ENDPOINT =\n process.env.REACT_APP_CHANGE_PASSWORD_ENDPOINT ||\n `${process.env.REACT_APP_SERVER_ENDPOINT}/auth/change-password`;\n\n/** server profile endpoint */\nexport const SERVER_USER_PROFILE_ENDPOINT =\n process.env.REACT_APP_USER_PROFILE_ENDPOINT ||\n `${process.env.REACT_APP_SERVER_ENDPOINT}/auth/profile/basic`;\n\n/** server email verify endpoint */\nexport const SERVER_EMAIL_VERIFY_ENDPOINT =\n process.env.REACT_APP_EMAIL_VERIFY_ENDPOINT ||\n `${process.env.REACT_APP_SERVER_ENDPOINT}/auth/email/verify`;\n\n/** server send email endpoint */\nexport const SERVER_SEND_EMAIL_ENDPOINT =\n process.env.REACT_APP_SEND_EMAIL_ENDPOINT ||\n `${process.env.REACT_APP_SERVER_ENDPOINT}/auth/email/verification-notification`;\n\n/** server avatar endpoint */\nexport const SERVER_AVATAR_ENDPOINT =\n process.env.REACT_APP_AVATAR_ENDPOINT ||\n `${process.env.REACT_APP_SERVER_ENDPOINT}/auth/profile/change-avatar`;\n\n/** auth endpoints */\n\n/** google auth endpoint */\nexport const SERVER_GOOGLE_AUTH_LINK =\n process.env.REACT_APP_GOOGLE_AUTH_LINK ||\n `${process.env.REACT_APP_SERVER_ENDPOINT}/auth/login/google`;\n\n/** facebook auth endpoint */\nexport const SERVER_FACEBOOK_AUTH_LINK =\n process.env.REACT_APP_FACEBOOK_AUTH_LINK ||\n `${process.env.REACT_APP_SERVER_ENDPOINT}/auth/login/facebook`;\n\n/** apple auth endpoint */\nexport const SERVER_APPLE_AUTH_LINK =\n process.env.REACT_APP_APPLE_AUTH_LINK ||\n `${process.env.REACT_APP_SERVER_ENDPOINT}/auth/login/apple`;\n\n/** apps */\n\n/** Todo app endpoint */\nexport const TODO_APP_ENDPOINT = process.env.REACT_APP_TODO_ENDPOINT || '';\n\n/** Tips app endpoint */\nexport const TIPS_APP_ENDPOINT = process.env.REACT_APP_TIPS_ENDPOINT || '';\n\n/** sample app authorize endpoint */\nexport const APP_AUTHORIZE_ENDPOINT =\n process.env.REACT_APP_AUTHORIZE_ENDPOINT || '';\n\n/** external */\nexport const BLOG_ENDPOINT = process.env.REACT_APP_BLOG_ENDPOINT || '';\nexport const TERMS_OF_SERVICE_ENDPOINT =\n process.env.REACT_APP_TERMS_OF_SERVICE_ENDPOINT ||\n 'https://virtunus.com/terms-of-service/';\nexport const PRIVACY_POLICY_ENDPOINT =\n process.env.REACT_APP_PRIVACY_POLICY_ENDPOINT ||\n 'https://virtunus.com/privacy-policy/';\nexport const VIRTUNUS_HOME_ENDPOINT =\n process.env.REACT_APP_VIRTUNUS_HOME_ENDPOINT || 'https://app.upstride.co/';\n","import React from 'react';\nimport { VIRTUNUS_HOME_ENDPOINT } from '../configs/endpoints';\n\nexport default function Logo() {\n return (\n <>\n \n \"Logo\"\n \n \n );\n}\n","import Cookies from 'js-cookie';\n\n/** the local storage key name */\nconst LOCAL_STORAGE_KEY_NAME =\n process.env.REACT_APP_STORE_KEY || 'virtunus_state';\n\n/**\n * loadState retrieves the store saved in local storage\n * @returns {any} - state that is previously stored in local storage; otherwise undefined\n */\nexport const loadState = (): any => {\n try {\n // const serializedState = localStorage.getItem(LOCAL_STORAGE_KEY_NAME);\n const serializedState: any = Cookies.get(LOCAL_STORAGE_KEY_NAME);\n if (serializedState === null) {\n return undefined;\n }\n return JSON.parse(serializedState);\n } catch (err) {\n return undefined;\n }\n};\n\nexport const getDomain = (url: string, subdomain: boolean): string => {\n subdomain = subdomain || false;\n\n let domainUrl: any = url.replace(/(https?:\\/\\/)?(www.)?/i, '');\n\n if (!subdomain) {\n domainUrl = domainUrl.split('.');\n\n domainUrl = domainUrl.slice(domainUrl.length - 2).join('.');\n }\n\n if (domainUrl.indexOf('/') !== -1) {\n return domainUrl.split('/')[0];\n }\n\n return domainUrl;\n};\n/**\n * saveState saves the requested store state in local storage\n * @params {any} - state that is requested to be saved in local storage\n */\nexport const saveState = (state: any): void => {\n try {\n const serializedState = JSON.stringify(state);\n const domain =\n process.env.REACT_APP_STATUS === 'development'\n ? 'localhost'\n : '.' + getDomain(window.location.hostname, false);\n Cookies.set(LOCAL_STORAGE_KEY_NAME, serializedState, {\n expires: 90,\n domain: domain,\n });\n } catch (exception) {\n console.error(exception);\n }\n};\n","import { AnyAction, Store } from 'redux';\nimport SeamlessImmutable from 'seamless-immutable';\n\n/** interface for flexible object */\nexport interface FlexObj {\n [key: string]: any;\n}\n\n/** The reducer name */\nexport const reducerName = 'session';\n\n// actions\n/** action types */\nexport const SET_SESSION_TOKEN = 'virtunus/reducer/session/SET_SESSION_TOKEN';\nexport const SET_SESSION_INFO = 'virtunus/reducer/session/SET_SESSION_INFO';\nexport const RESET_SESSION = 'virtunus/reducer/session/RESET_SESSION';\n\n/** interface for SET_SESSION_TOKEN action */\nexport interface SetSessionTokenAction extends AnyAction {\n token: string;\n type: typeof SET_SESSION_TOKEN;\n}\n\n/** interface for SET_SESSION_INFO action */\nexport interface SetSessionUserInfoAction extends AnyAction {\n userInfo: FlexObj;\n type: typeof SET_SESSION_INFO;\n}\n\n/** interface for RESET_SESSION action */\nexport interface ResetSessionAction extends AnyAction {\n type: typeof RESET_SESSION;\n}\n\n/** Create type for session reducer actions */\nexport type ListTableActionTypes =\n | SetSessionTokenAction\n | SetSessionUserInfoAction\n | ResetSessionAction\n | AnyAction;\n\n// action creators\n\n/** set session token action creator\n * @param {string} token - token to be set\n * @returns {SetSessionTokenAction} - an action to set session token in store\n */\nexport const setSessionToken = (token: string): SetSessionTokenAction => ({\n token,\n type: SET_SESSION_TOKEN,\n});\n\n/** set session info action creator\n * @param {FlexObj} userInfo - info about user to be set\n * @returns {SetSessionUserInfoAction} - an action to set session info in store\n */\nexport const setSessionUserInfo = (\n userInfo: FlexObj\n): SetSessionUserInfoAction => ({\n type: SET_SESSION_INFO,\n userInfo,\n});\n\n/** reset session action creator\n * @returns {ResetSesssionAction} - an action to reset session in store\n */\nexport const resetSession = (): ResetSessionAction => ({\n type: RESET_SESSION,\n});\n\n// the reducer\n\n/** interface for session state in redux store */\ninterface SessionState {\n token: string;\n userInfo: FlexObj;\n}\n\n/** Create an immutable session state */\nexport type ImmutableListTableState = SeamlessImmutable.ImmutableObject<\n SessionState\n>;\n\n/** initial session state */\nconst initialState: ImmutableListTableState = SeamlessImmutable({\n token: '',\n userInfo: {},\n});\n\n/** the session reducer function */\nexport default function reducer(\n state: ImmutableListTableState = initialState,\n action: ListTableActionTypes\n): ImmutableListTableState {\n switch (action.type) {\n case SET_SESSION_TOKEN:\n return SeamlessImmutable({\n ...state.asMutable({ deep: true }),\n token: action.token,\n });\n case SET_SESSION_INFO:\n return SeamlessImmutable({\n ...state.asMutable({ deep: true }),\n userInfo: action.userInfo,\n });\n case RESET_SESSION:\n return initialState;\n default:\n return state;\n }\n}\n\n// selectors\n\n/** returns the session token\n * @param {Partial} state - the redux store\n * @return { string } - the existing session token\n */\nexport function getSessionToken(state: Partial): string {\n return (state as any)[reducerName].token;\n}\n\n/** returns the session user info\n * @param {Partial} state - the redux store\n * @return { FlexObj } - the existing user info\n */\nexport function getSessionUserInfo(state: Partial): FlexObj {\n return (state as any)[reducerName].userInfo;\n}\n\n/** checks user authentication\n * @param {Partial} state - the redux store\n * @return { boolean } - true if authenticated; otherwise, false\n */\nexport function isAuthenticated(state: Partial): boolean {\n return (state as any)[reducerName].token !== '';\n}\n\n/** returns the session user name if present\n * @param {Partial} state - the redux store\n * @return { string } - the existing user name or empty string\n */\nexport function getSessionUserName(state: Partial): string {\n return (state as any)[reducerName].userInfo.title || '';\n}\n","import { AnyAction, Store } from 'redux';\nimport SeamlessImmutable from 'seamless-immutable';\nimport lodash from 'lodash';\n\n/** reminder types */\n\n/** time reminder types */\nexport const TIME_REMINDER_TYPE = 'TIME_REMINDER';\nexport type TIME_REMINDER_TYPE = typeof TIME_REMINDER_TYPE;\n\n/** location reminder types */\nexport const LOCATION_REMINDER_TYPE = 'LOCATION_REMINDER';\nexport type LOCATION_REMINDER_TYPE = typeof LOCATION_REMINDER_TYPE;\n\n/** interface of Time Reminder object */\nexport interface TimeReminderObj {\n type: TIME_REMINDER_TYPE;\n date: string;\n time: string;\n}\n\n/** interface of Location Reminder object */\nexport interface LocationReminderObj {\n type: LOCATION_REMINDER_TYPE;\n location: string;\n trigger: string;\n}\n\n/** interface for task object */\nexport interface TaskObj {\n id: string;\n title: string;\n projectId: string;\n sectionId: string;\n priority: string;\n dueDate: string;\n dueTime: string;\n parent: string;\n order: number;\n expanded: boolean;\n completed: boolean;\n labels: string[];\n reminders: Array;\n}\n\n/** The reducer name */\nexport const reducerName = 'tasks';\n\n// actions\n/** action types */\nexport const SET_TASKS = 'virtunus/reducer/tasks/SET_TASKS';\nexport const SET_TASK = 'virtunus/reducer/tasks/SET_TASK';\nexport const UPDATE_TASKS = 'virtunus/reducer/tasks/UPDATE_TASKS';\nexport const FIX_TASK_ORDERS = 'virtunus/reducer/tasks/FIX_TASK_ORDERS';\n\n/** interface for SET_TASKS action */\nexport interface SetTasksAction extends AnyAction {\n tasks: TaskObj[];\n type: typeof SET_TASKS;\n}\n\n/** interface for SET_TASK action */\nexport interface SetTaskAction extends AnyAction {\n task: TaskObj;\n type: typeof SET_TASK;\n}\n\n/** interface for UPDATE_TASKS action */\nexport interface UpdateTasksAction extends AnyAction {\n tasks: TaskObj[];\n type: typeof UPDATE_TASKS;\n}\n\n/** interface for FIX_TASK_ORDERS action */\nexport interface FixTaskOrdersAction extends AnyAction {\n parentId: string;\n type: typeof FIX_TASK_ORDERS;\n}\n\n/** Create type for task reducer actions */\nexport type TasksActionTypes =\n | SetTasksAction\n | SetTaskAction\n | UpdateTasksAction\n | FixTaskOrdersAction\n | AnyAction;\n\n// action creators\n\n/** set tasks action creator\n * @param {TaskObj[]} tasks - an array of task items\n * @returns {SetTasksAction} - an action to set tasks in store\n */\nexport const setTasks = (tasks: TaskObj[]): SetTasksAction => {\n return {\n tasks,\n type: SET_TASKS,\n };\n};\n\n/** set task action creator\n * @param {TaskObj} task - a task object\n * @returns {SetTaskAction} - an action to set task in store\n */\nexport const setTask = (task: TaskObj): SetTaskAction => ({\n task,\n type: SET_TASK,\n});\n\n/** update tasks action creator\n * @param {TaskObj[]} tasks - an array of task items\n * @returns {UpdateTasksAction} - an action to update tasks in store\n */\nexport const updateTasks = (tasks: TaskObj[]): UpdateTasksAction => {\n const ids = tasks.map((task: TaskObj) => task.id);\n return {\n tasks,\n ids,\n type: UPDATE_TASKS,\n };\n};\n\n/**\n * set the task orders correctly\n * @param {string} projectId - the project id\n * @param {string} sectionId - the section id\n * @param {string} parentId - the parent task id\n * @returns {FixTaskOrdersAction} - an action to fix the tasks order given the parent task id\n */\nexport const fixTaskOrders = (\n projectId: string,\n sectionId: string,\n parentId: string\n): FixTaskOrdersAction => ({\n projectId,\n sectionId,\n parentId,\n type: FIX_TASK_ORDERS,\n});\n\n// the reducer\n\n/** interface for tasks state in redux store */\ntype TasksState = TaskObj[];\n\n/** Create an immutable tasks state */\nexport type ImmutableTasksState = SeamlessImmutable.ImmutableArray;\n\n/** initial tasks state */\nconst initialState: ImmutableTasksState = SeamlessImmutable([]);\n\n/** the tasks reducer function */\nexport default function reducer(\n state: ImmutableTasksState = initialState,\n action: TasksActionTypes\n): ImmutableTasksState {\n switch (action.type) {\n case SET_TASKS:\n return SeamlessImmutable(action.tasks);\n case SET_TASK:\n return SeamlessImmutable([\n ...lodash.filter(\n state.asMutable({ deep: true }),\n (iterateTask: TaskObj) => iterateTask.id !== action.task.id\n ),\n action.task,\n ]);\n case UPDATE_TASKS:\n return SeamlessImmutable([\n ...lodash.filter(\n state.asMutable({ deep: true }),\n (iterateTask: TaskObj) => !action.ids.includes(iterateTask.id)\n ),\n ...action.tasks,\n ]);\n case FIX_TASK_ORDERS:\n return SeamlessImmutable([\n ...lodash.filter(\n state as any,\n (iterateTask: TaskObj) =>\n !(\n iterateTask.parent === action.parentId &&\n iterateTask.projectId === action.projectId &&\n iterateTask.sectionId === action.sectionId\n )\n ),\n ...lodash.map(\n lodash.orderBy(\n lodash.filter(\n state,\n (iterateTask: TaskObj) =>\n iterateTask.parent === action.parentId &&\n iterateTask.projectId === action.projectId &&\n iterateTask.sectionId === action.sectionId\n ),\n ['order'],\n ['asc']\n ),\n (iterateTask: TaskObj, index: number) => ({\n ...iterateTask,\n order: index,\n })\n ),\n ]);\n default:\n return state;\n }\n}\n\n// selectors\n\n/** returns the tasks list\n * @param {Partial} state - the redux store\n * @return { TaskObj[] } - the existing tasks\n */\nexport function getTasks(state: Partial): TaskObj[] {\n return (state as any)[reducerName];\n}\n\n/** returns the tasks list length\n * @param {Partial} state - the redux store\n * @return { number } - the existing tasks length\n */\nexport function getTasksLength(state: Partial): number {\n return (state as any)[reducerName].length;\n}\n\n/** returns the next available order of new task\n * @param {Partial} state - the redux store\n * @param {projectId} string - project id\n * @param {sectionId} string - section id\n * @return { number } - the new available order index\n */\nexport function getNewTasksOrderIndex(\n state: Partial,\n projectId: string,\n sectionId: string\n): number {\n return lodash.filter((state as any)[reducerName], { projectId, sectionId })\n .length;\n}\n\n/** returns the tasks related to project id and section id\n * @param {Partial} state - the redux store\n * @param {projectId} string - project id\n * @param {sectionId} string - section id\n * @return { TaskObj } - the tasks list related to project id and section id\n */\nexport function getProjectAndSectionBasedTasks(\n state: Partial,\n projectId: string,\n sectionId: string\n): TaskObj[] {\n return lodash.filter((state as any)[reducerName], { projectId, sectionId });\n}\n\n/** returns the tasks count present in the project\n * @param {Partial} state - the redux store\n * @param {number} projectId - the requested project id\n * @return { number } - the existing tasks count\n */\nexport function getTasksCountByProjectId(\n state: Partial,\n projectId: string\n): number {\n return lodash.filter((state as any)[reducerName], { projectId }).length;\n}\n\n/** returns the tasks present with the label id\n * @param {Partial} state - the redux store\n * @param {number} labelId - the requested label id\n * @return { number } - the existing tasks\n */\nexport function getTasksByLabelId(\n state: Partial,\n labelId: string\n): TaskObj[] {\n return lodash.filter((state as any)[reducerName], (iterTask: TaskObj) =>\n iterTask.labels.includes(labelId)\n );\n}\n\n/** returns the tasks count present with the label id\n * @param {Partial} state - the redux store\n * @param {number} labelId - the requested label id\n * @return { number } - the existing tasks count\n */\nexport function getTasksCountByLabelId(\n state: Partial,\n labelId: string\n): number {\n return lodash.filter((state as any)[reducerName], (iterTask: TaskObj) =>\n iterTask.labels.includes(labelId)\n ).length;\n}\n\n/** returns the task obj given task id if exists; otherwise, null\n * @param {Partial} state - the redux store\n * @param {string} taskId - the task id\n * @return { ProjectObj | null } - the existing task or null\n */\nexport function getTaskById(state: Partial, taskId: string): TaskObj {\n return lodash.find((state as any)[reducerName], { id: taskId }) || null;\n}\n","import lodash from 'lodash';\nimport store from '../store';\nimport { getTasks, TaskObj, updateTasks } from '../store/ducks/tasks';\n\n/**\n * compares and checks whether two tree nodes are equal\n * @param treeNodeA - the first tree node\n * @param treeNodeB - the second tree node\n * @returns {boolean} - true if tree nodes are equal; otherwise false\n */\nexport const customTreeNodeComparator = (treeNodeA: any, treeNodeB: any) => {\n return (\n treeNodeA.id === treeNodeB.id &&\n treeNodeA.parent === treeNodeB.parent &&\n treeNodeA.order === treeNodeB.order &&\n treeNodeA.expanded === treeNodeB.expanded\n );\n};\n\n/**\n * flatDataBasedOnHeightIterator recursively iterates through data and adds rows that satisfy the height condition\n * @param {any} data - the rows of data to be filterd\n * @param {any} filteredRows - the rows of data after filter\n * @param {string} parent - the current parent id of iterator\n * @param {number} height - the current height of iterator\n * @param {number} maxheight - the maximum height that is allowed\n */\nconst flatDataBasedOnHeightIterator = (\n data: any,\n filteredRows: any,\n parent: string,\n height: number,\n maxheight: number\n) => {\n const tmpContainer = lodash.filter(data, { parent });\n if (tmpContainer.length === 0 || height > maxheight) {\n return;\n }\n tmpContainer.forEach((node: any) => {\n flatDataBasedOnHeightIterator(\n data,\n filteredRows,\n node.id,\n height + 1,\n maxheight\n );\n filteredRows.push(node);\n });\n return;\n};\n\n/**\n * getFlatDataBasedOnHeight filters the input data based on their height. Height starts from 0.\n * @param {any} data - the input data\n * @param {number} maxheight - the maximum height that is allowed. 0 represents only root rows.\n * @returns {any} - filtered rows\n */\nexport const getFlatDataBasedOnHeight = (data: any, maxheight: number): any => {\n const filteredRows: any = [];\n flatDataBasedOnHeightIterator(data, filteredRows, '', 0, maxheight);\n return filteredRows;\n};\n\n/**\n * recursively iterates the dataset to find the maximum height\n * @param data - the input dataset\n * @param currentParent - the current parent of the iterator\n * @param {number} currentHeight - the current height of the iterator\n * @returns {number} - returns the max height based on current parent\n */\nconst maxHeightIterator = (\n data: any,\n currentParent: string,\n currentHeight: number\n): number => {\n const tmpContainer = lodash.filter(data, { parent: currentParent });\n if (tmpContainer.length === 0) {\n return currentHeight;\n }\n let maxHeight = currentHeight;\n tmpContainer.forEach((iterObj: any) => {\n const childHeight = maxHeightIterator(data, iterObj.id, currentHeight + 1);\n if (maxHeight < childHeight) {\n maxHeight = childHeight;\n }\n });\n return maxHeight;\n};\n\n/**\n * returns the max height or depth of root node\n * @param {any} data - the input data set\n * @param {string} rootId - the root or start node id\n * @returns {number} - returns the max height or depth of the root node\n */\nexport const getMaxHeight = (data: any, rootId: string): number => {\n return maxHeightIterator(data, rootId, 0);\n};\n\n/**\n * iterates the tree flat data to look and push favourite items\n * @param {FavouriteIteratorType[]} data - the flat data\n * @param {number} currentParent - the current iterator parent\n * @param {FavouriteIteratorType[]} favourties - the favourites container to push into\n */\nconst favouriteIterator = (\n data: FavouriteIteratorType[],\n currentParent: string,\n favourties: FavouriteIteratorType[]\n) => {\n const tmpContainer = lodash.orderBy(\n lodash.filter(data, { parent: currentParent }),\n ['order'],\n ['asc']\n );\n if (tmpContainer.length === 0) {\n return;\n }\n tmpContainer.forEach((iterObj: any) => {\n if (iterObj.isFavourite) {\n favourties.push(iterObj);\n }\n favouriteIterator(data, iterObj.id, favourties);\n });\n return;\n};\n\n/**\n * returns the list of favourites with the tree order\n * @param {FavouriteType[]} data - the flat rows of data\n * @returns {FavouriteType[]} - the list of favourite items\n */\nexport const getFavourites = (\n data: FavouriteType[]\n): FavouriteType[] => {\n const favourites: FavouriteType[] = [];\n favouriteIterator(data, '', favourites);\n return favourites;\n};\n\n/**\n * iterator for the transfer sub tasks list\n * @param {TaskObj[]} transferTasks - the tasks that will be transfered\n * @param {TaskObj[]} currentTasks - the current tasks at the store\n * @param {string} parentId - the parent task id\n * @param {string} projectId - the project id where the tasks will be transfered\n */\nconst transferSubTasksListIterator = (\n transferTasks: TaskObj[],\n currentTasks: TaskObj[],\n parentId: string,\n projectId: string\n) => {\n const immediateTasks = lodash.filter(currentTasks, { parent: parentId });\n immediateTasks.forEach((iterTask) => {\n transferSubTasksListIterator(\n transferTasks,\n currentTasks,\n iterTask.id,\n projectId\n );\n //TODO: need to change sync status when this becomes available\n transferTasks.push({ ...iterTask, projectId, sectionId: '' });\n });\n};\n\n/**\n * transfers the sub tasks to the requested project id\n * @param {string} parentId - the requested parent id\n * @param {string} projectId - the requested project id\n */\nexport const transferSubTaskListByParent = (\n parentId: string,\n projectId: string\n) => {\n const currentTasks = getTasks((store as any).getState());\n const transferTasks: TaskObj[] = [];\n transferSubTasksListIterator(\n transferTasks,\n currentTasks,\n parentId,\n projectId\n );\n (store as any).dispatch(updateTasks(transferTasks));\n};\n\n/**\n * complete sub tasks list iterator\n * @param {TaskObj[]} completeTasks - the tasks that will be completed\n * @param {TaskObj[]} currentTasks - the current tasks at the store\n * @param {string} parentId - the parent task id\n */\nconst completeSubTasksListIterator = (\n completeTasks: TaskObj[],\n currentTasks: TaskObj[],\n parentId: string\n) => {\n const immediateTasks = lodash.filter(currentTasks, { parent: parentId });\n immediateTasks.forEach((iterTask) => {\n completeSubTasksListIterator(completeTasks, currentTasks, iterTask.id);\n //TODO: need to change sync status when this becomes available\n completeTasks.push({ ...iterTask, completed: true });\n });\n};\n\n/**\n * completes the sub tasks given the parent id\n * @param {string} parentId - the requested parent id\n */\nexport const completeSubTaskListByParent = (parentId: string) => {\n const currentTasks = getTasks((store as any).getState());\n const completeTasks: TaskObj[] = [];\n completeSubTasksListIterator(completeTasks, currentTasks, parentId);\n (store as any).dispatch(updateTasks(completeTasks));\n};\n","import { AnyAction, Store } from 'redux';\nimport SeamlessImmutable from 'seamless-immutable';\nimport lodash from 'lodash';\nimport { getMaxHeight } from '../../services/utility';\n\n/** interface for ProjectObj object */\nexport interface ProjectObj {\n id: string;\n title: string;\n color: string;\n order: number;\n isFavourite: boolean;\n isHidden: boolean;\n parent: string;\n expanded: boolean;\n synced: boolean;\n}\n\n/** The reducer name */\nexport const reducerName = 'projects';\n\n// actions\n/** action types */\nexport const SET_PROJECTS = 'virtunus/reducer/projects/SET_PROJECTS';\nexport const UPDATE_PROJECTS = 'virtunus/reducer/projects/UPDATE_PROJECTS';\nexport const SET_PROJECT = 'virtunus/reducer/projects/SET_PROJECT';\nexport const FIX_PROJECT_ORDERS =\n 'virtunus/reducer/projects/FIX_PROJECT_ORDERS';\nexport const SET_PROJECTS_SYNCED_STATUS =\n 'virtunus/reducer/projects/SET_PROJECTS_SYNCED_STATUS';\n\n/** interface for SET_PROJECTS action */\nexport interface SetProjectsAction extends AnyAction {\n projects: ProjectObj[];\n type: typeof SET_PROJECTS;\n}\n\n/** interface for UPDATE_PROJECTS action */\nexport interface UpdateProjectsAction extends AnyAction {\n projects: ProjectObj[];\n type: typeof UPDATE_PROJECTS;\n ids: string[];\n}\n\n/** interface for SET_PROJECT action */\nexport interface SetProjectAction extends AnyAction {\n project: ProjectObj;\n type: typeof SET_PROJECT;\n}\n\n/** interface for FIX_PROJECT_ORDERS action */\nexport interface FixProjectOrdersAction extends AnyAction {\n parentId: string;\n type: typeof FIX_PROJECT_ORDERS;\n}\n\n/** interface for SET_PROJECTS_SYNCED_STATUS action */\nexport interface SetProjectsSyncedStatusAction extends AnyAction {\n status: boolean;\n type: typeof SET_PROJECTS_SYNCED_STATUS;\n ids: string[];\n}\n\n/** Create type for project reducer actions */\nexport type ProjectsActionTypes =\n | SetProjectsAction\n | UpdateProjectsAction\n | SetProjectAction\n | FixProjectOrdersAction\n | SetProjectsSyncedStatusAction\n | AnyAction;\n\n// action creators\n\n/** set projects action creator\n * @param {ProjectObj} projects - an array of project items\n * @returns {SetProjectsAction} - an action to set projects in store\n */\nexport const setProjects = (projects: ProjectObj[]): SetProjectsAction => ({\n projects,\n type: SET_PROJECTS,\n});\n\n/** update projects action creator\n * @param {ProjectObj} projects - an array of project items\n * @returns {UpdateProjectsAction} - an action to update projects in store\n */\nexport const updateProjects = (\n projects: ProjectObj[]\n): UpdateProjectsAction => {\n const ids = projects.map((project: ProjectObj) => project.id);\n return {\n projects,\n type: UPDATE_PROJECTS,\n ids,\n };\n};\n\n/** set projects action creator\n * @param {ProjectObj} project - a project object\n * @returns {SetProjectAction} - an action to set project in store\n */\nexport const setProject = (project: ProjectObj): SetProjectAction => ({\n project,\n type: SET_PROJECT,\n});\n\n/**\n * set the project orders correctly\n * @param {string} parentId - the parent project id\n * @returns {FixProjectOrdersAction} - an action to fix the projects order given the parent project id\n */\nexport const fixProjectOrders = (parentId: string): FixProjectOrdersAction => ({\n parentId,\n type: FIX_PROJECT_ORDERS,\n});\n\n/** set projects synced status action creator\n * @param {string[]} ids - an array of project ids\n * @param {boolean} status - the synced status to set\n * @returns {SetProjectsSyncedStatusAction} - an action to set projects synced status in store\n */\nexport const setProjectsSyncedStatus = (\n ids: string[],\n status: boolean\n): SetProjectsSyncedStatusAction => ({\n status,\n type: SET_PROJECTS_SYNCED_STATUS,\n ids,\n});\n\n// the reducer\n\n/** interface for projects state in redux store */\ntype ProjectsState = ProjectObj[];\n\n/** Create an immutable projects state */\nexport type ImmutableProjectsState = SeamlessImmutable.ImmutableArray<\n ProjectsState\n>;\n\n/** initial projects state */\nconst initialState: ImmutableProjectsState = SeamlessImmutable([]);\n\n/** the projects reducer function */\nexport default function reducer(\n state: ImmutableProjectsState = initialState,\n action: ProjectsActionTypes\n): ImmutableProjectsState {\n switch (action.type) {\n case SET_PROJECTS:\n return SeamlessImmutable(action.projects);\n case UPDATE_PROJECTS:\n return SeamlessImmutable([\n ...lodash.filter(\n state.asMutable({ deep: true }),\n (iterateProj: ProjectObj) => !action.ids.includes(iterateProj.id)\n ),\n ...action.projects,\n ]);\n case SET_PROJECT:\n return SeamlessImmutable([\n ...lodash.filter(\n state.asMutable({ deep: true }),\n (iterateProject: ProjectObj) =>\n iterateProject.id !== action.project.id\n ),\n action.project,\n ]);\n case FIX_PROJECT_ORDERS:\n return SeamlessImmutable([\n ...lodash.filter(\n state as any,\n (iterateProject: ProjectObj) =>\n iterateProject.parent !== action.parentId\n ),\n ...lodash.map(\n lodash.filter(\n state,\n (iterateProject: ProjectObj) =>\n iterateProject.parent === action.parentId\n ),\n (iterateProject: ProjectObj, index: number) => ({\n ...iterateProject,\n order: index,\n })\n ),\n ]);\n case SET_PROJECTS_SYNCED_STATUS:\n return SeamlessImmutable(\n lodash.map(state, (iterateProject: ProjectObj) => {\n return action.ids.includes(iterateProject.id)\n ? { ...iterateProject, synced: action.status }\n : iterateProject;\n }) as any\n );\n default:\n return state;\n }\n}\n\n// selectors\n\n/** returns the projects list\n * @param {Partial} state - the redux store\n * @return { ProjectObj[] } - the existing projects\n */\nexport function getProjects(state: Partial): ProjectObj[] {\n return (state as any)[reducerName];\n}\n\n/** returns the projects list length\n * @param {Partial} state - the redux store\n * @return { number } - the existing projects length\n */\nexport function getProjectsLength(state: Partial): number {\n return (state as any)[reducerName].length;\n}\n\n/** returns the project obj given project id if exists; otherwise, null\n * @param {Partial} state - the redux store\n * @param {string} projectId - the project id\n * @return { ProjectObj | null } - the existing project or null\n */\nexport function getProjectById(\n state: Partial,\n projectId: string\n): ProjectObj {\n return lodash.find((state as any)[reducerName], { id: projectId }) || null;\n}\n\n/** returns the new available order in list given a project id as parent\n * @param {Partial} state - the redux store\n * @param {string} project - the project id\n * @return { number } - the new available order\n */\nexport function getNewProjectOrderbyProjectId(\n state: Partial,\n projectId: string\n): number {\n return lodash.filter((state as any)[reducerName], { parent: projectId })\n .length;\n}\n\n/** returns the maximum height or depth given a project id\n * @param {Partial} state - the redux store\n * @param {string} project - the project id\n * @return { number } - the maximum height\n */\nexport function getMaxHeightOfProject(\n state: Partial,\n projectId: string\n): number {\n return getMaxHeight((state as any)[reducerName], projectId);\n}\n\n/**\n * returns the list of unsynced projects\n * @param {Partial} state - the redux store\n * @returns {ProjectObj[]} - the list of unsynced projects\n */\nexport function getUnsyncedProjects(state: Partial): ProjectObj[] {\n return lodash.filter((state as any)[reducerName], { synced: false });\n}\n","import { AnyAction, Store } from 'redux';\nimport SeamlessImmutable from 'seamless-immutable';\nimport lodash from 'lodash';\n\n/** interface for section object */\nexport interface SectionObj {\n id: string;\n title: string;\n projectId: string;\n order: number;\n parent: string;\n expanded: boolean;\n bodyExpanded: boolean;\n}\n\n/** The reducer name */\nexport const reducerName = 'sections';\n\n// actions\n/** action types */\nexport const SET_SECTIONS = 'virtunus/reducer/sections/SET_SECTIONS';\nexport const SET_SECTION = 'virtunus/reducer/sections/SET_SECTION';\nexport const UPDATE_SECTIONS = 'virtunus/reducer/sections/UPDATE_SECTIONS';\nexport const FIX_SECTION_ORDERS =\n 'virtunus/reducer/sections/FIX_SECTION_ORDERS';\n\n/** interface for SET_SECTIONS action */\nexport interface SetSectionsAction extends AnyAction {\n sections: SectionObj[];\n type: typeof SET_SECTIONS;\n}\n\n/** interface for SET_SECTION action */\nexport interface SetSectionAction extends AnyAction {\n section: SectionObj;\n type: typeof SET_SECTION;\n}\n\n/** interface for UPDATE_SECTIONS action */\nexport interface UpdateSectionsAction extends AnyAction {\n sections: SectionObj[];\n type: typeof UPDATE_SECTIONS;\n}\n\n/** interface for FIX_SECTION_ORDERS action */\nexport interface FixSectionOrdersAction extends AnyAction {\n projectId: string;\n type: typeof FIX_SECTION_ORDERS;\n}\n\n/** Create type for section reducer actions */\nexport type SectionsActionTypes =\n | SetSectionsAction\n | SetSectionAction\n | UpdateSectionsAction\n | FixSectionOrdersAction\n | AnyAction;\n\n// action creators\n\n/** set sections action creator\n * @param {SectionObj} sections - an array of section items\n * @returns {SetSectionsAction} - an action to set sections in store\n */\nexport const setSections = (sections: SectionObj[]): SetSectionsAction => {\n return {\n sections,\n type: SET_SECTIONS,\n };\n};\n\n/** set sections action creator\n * @param {SectionObj} section - a section object\n * @returns {SetSectionAction} - an action to set section in store\n */\nexport const setSection = (section: SectionObj): SetSectionAction => ({\n section,\n type: SET_SECTION,\n});\n\n/** update sections action creator\n * @param {SectionObj[]} sections - an array of section items\n * @returns {SetSectionsAction} - an action to update sections in store\n */\nexport const updateSections = (\n sections: SectionObj[]\n): UpdateSectionsAction => {\n const ids = sections.map((section: SectionObj) => section.id);\n return {\n sections,\n ids,\n type: UPDATE_SECTIONS,\n };\n};\n\n/**\n * set the section orders correctly based on project id\n * @param {string} projectId - requested project id\n * @returns {FixSectionOrdersAction} - an action to fix the sections order given the parent project id\n */\nexport const fixSectionOrders = (\n projectId: string\n): FixSectionOrdersAction => ({\n projectId,\n type: FIX_SECTION_ORDERS,\n});\n\n// the reducer\n\n/** interface for sections state in redux store */\ntype SectionsState = SectionObj[];\n\n/** Create an immutable sections state */\nexport type ImmutableSectionsState = SeamlessImmutable.ImmutableArray<\n SectionsState\n>;\n\n/** initial section state */\nconst initialState: ImmutableSectionsState = SeamlessImmutable([]);\n\n/** the sections reducer function */\nexport default function reducer(\n state: ImmutableSectionsState = initialState,\n action: SectionsActionTypes\n): ImmutableSectionsState {\n switch (action.type) {\n case SET_SECTIONS:\n return SeamlessImmutable(action.sections);\n case SET_SECTION:\n return SeamlessImmutable([\n ...lodash.filter(\n state.asMutable({ deep: true }),\n (iterateSection: SectionObj) =>\n iterateSection.id !== action.section.id\n ),\n action.section,\n ]);\n case UPDATE_SECTIONS:\n return SeamlessImmutable([\n ...lodash.filter(\n state.asMutable({ deep: true }),\n (iterateSection: SectionObj) =>\n !action.ids.includes(iterateSection.id)\n ),\n ...action.sections,\n ]);\n case FIX_SECTION_ORDERS:\n return SeamlessImmutable([\n ...lodash.filter(\n state,\n (iter: SectionObj) => iter.projectId !== action.projectId\n ),\n ...lodash.map(\n lodash.orderBy(\n lodash.filter(\n state,\n (iter: SectionObj) => iter.projectId === action.projectId\n ),\n ['order'],\n ['asc']\n ),\n (iterateSection: SectionObj, index: number) => ({\n ...iterateSection,\n order: index,\n })\n ),\n ] as any);\n default:\n return state;\n }\n}\n\n// selectors\n\n/** returns the sections list\n * @param {Partial} state - the redux store\n * @return { SectionObj[] } - the existing sections\n */\nexport function getSections(state: Partial): SectionObj[] {\n return (state as any)[reducerName];\n}\n\n/** returns the sections list length\n * @param {Partial} state - the redux store\n * @return { number } - the existing sections length\n */\nexport function getSectionsLength(state: Partial): number {\n return (state as any)[reducerName].length;\n}\n\n/** returns the sections list of given project id\n * @param {Partial} state - the redux store\n * @param {string} projectId - the project id\n * @return { SectionObj[] } - the existing sections list with the given project id\n */\nexport function getSectionsByProjectId(\n state: Partial,\n projectId: string\n): SectionObj[] {\n return lodash.filter((state as any)[reducerName], { projectId });\n}\n\n/** returns the next available order of new section\n * @param {Partial} state - the redux store\n * @param {projectId} string - project id\n * @return { number } - the new available order index\n */\nexport function getNewSectionOrderIndex(\n state: Partial,\n projectId: string\n): number {\n return lodash.filter((state as any)[reducerName], { projectId }).length;\n}\n\n/**\n * returns the section info based on the given section id\n * @param {Partial} state - the redux state\n * @param {string} sectionId - the requested section id\n * @returns {SectionObj | null} - the section info obj if present; otherwise null\n */\nexport function getSectionById(\n state: Partial,\n sectionId: string\n): SectionObj | null {\n return lodash.find((state as any)[reducerName], { id: sectionId }) || null;\n}\n","import { AnyAction, Store } from 'redux';\nimport SeamlessImmutable from 'seamless-immutable';\nimport lodash from 'lodash';\nimport { getMaxHeight } from '../../services/utility';\n\n/** interface for LabelObj object */\nexport interface LabelObj {\n id: string;\n title: string;\n color: string;\n order: number;\n isFavourite: boolean;\n isHidden: boolean;\n parent: string;\n expanded: boolean;\n synced: boolean;\n}\n\n/** The reducer name */\nexport const reducerName = 'labels';\n\n// actions\n/** action types */\nexport const SET_LABELS = 'virtunus/reducer/labels/SET_LABELS';\nexport const UPDATE_LABELS = 'virtunus/reducer/labels/UPDATE_LABELS';\nexport const SET_LABEL = 'virtunus/reducer/labels/SET_LABEL';\nexport const FIX_LABEL_ORDERS = 'virtunus/reducer/labels/FIX_LABEL_ORDERS';\nexport const SET_LABELS_SYNCED_STATUS =\n 'virtunus/reducer/labels/SET_LABELS_SYNCED_STATUS';\n\n/** interface for SET_LABELS action */\nexport interface SetLabelsAction extends AnyAction {\n labels: LabelObj[];\n type: typeof SET_LABELS;\n}\n\n/** interface for UPDATE_LABELS action */\nexport interface UpdateLabelsAction extends AnyAction {\n labels: LabelObj[];\n type: typeof UPDATE_LABELS;\n}\n\n/** interface for SET_LABEL action */\nexport interface SetLabelAction extends AnyAction {\n label: LabelObj;\n type: typeof SET_LABEL;\n}\n\n/** interface for FIX_LABEL_ORDERS action */\nexport interface FixLabelOrdersAction extends AnyAction {\n parentId: string;\n type: typeof FIX_LABEL_ORDERS;\n}\n\n/** interface for SET_LABELS_SYNCED_STATUS action */\nexport interface SetLabelsSyncedStatusAction extends AnyAction {\n status: boolean;\n type: typeof SET_LABELS_SYNCED_STATUS;\n ids: string[];\n}\n\n/** Create type for label reducer actions */\nexport type LabelsActionTypes =\n | SetLabelsAction\n | UpdateLabelsAction\n | SetLabelAction\n | FixLabelOrdersAction\n | SetLabelsSyncedStatusAction\n | AnyAction;\n\n// action creators\n\n/** set labels action creator\n * @param {LabelObj} labels - an array of label items\n * @returns {SetLabelsAction} - an action to set labels in store\n */\nexport const setLabels = (labels: LabelObj[]): SetLabelsAction => {\n return {\n labels,\n type: SET_LABELS,\n };\n};\n\n/** update labels action creator\n * @param {labelObj} projects - an array of label items\n * @returns {UpdateLabelsAction} - an action to update labels in store\n */\nexport const updateLabels = (labels: LabelObj[]): UpdateLabelsAction => {\n const ids = labels.map((label: LabelObj) => label.id);\n return {\n labels,\n type: UPDATE_LABELS,\n ids,\n };\n};\n\n/** set labels action creator\n * @param {LabelObj} label - a label object\n * @returns {SetLabelAction} - an action to set label in store\n */\nexport const setLabel = (label: LabelObj): SetLabelAction => ({\n label,\n type: SET_LABEL,\n});\n\n/**\n * fixes the order of labels given a parent id\n * @param {string} parentId - the parent id\n * @returns {FixLabelOrdersAction} - an action to fix the order of labels respect to a parent id\n */\nexport const fixLabelOrders = (parentId: string): FixLabelOrdersAction => ({\n parentId,\n type: FIX_LABEL_ORDERS,\n});\n\n/** set labels synced status action creator\n * @param {string[]} ids - an array of label ids\n * @param {boolean} status - the synced status to set\n * @returns {SetLabelsSyncedStatusAction} - an action to set labels synced status in store\n */\nexport const setLabelsSyncedStatus = (\n ids: string[],\n status: boolean\n): SetLabelsSyncedStatusAction => ({\n status,\n type: SET_LABELS_SYNCED_STATUS,\n ids,\n});\n\n// the reducer\n\n/** interface for labels state in redux store */\ntype LabelsState = LabelObj[];\n\n/** Create an immutable labels state */\nexport type ImmutableLabelsState = SeamlessImmutable.ImmutableArray<\n LabelsState\n>;\n\n/** initial labels state */\nconst initialState: ImmutableLabelsState = SeamlessImmutable([]);\n\n/** the labels reducer function */\nexport default function reducer(\n state: ImmutableLabelsState = initialState,\n action: LabelsActionTypes\n): ImmutableLabelsState {\n switch (action.type) {\n case SET_LABELS:\n return SeamlessImmutable(action.labels);\n case SET_LABEL:\n return SeamlessImmutable([\n ...lodash.filter(\n state.asMutable({ deep: true }),\n (iterateLabel: LabelObj) => iterateLabel.id !== action.label.id\n ),\n action.label,\n ]);\n case UPDATE_LABELS:\n return SeamlessImmutable([\n ...lodash.filter(\n state.asMutable({ deep: true }),\n (iterateLabel: LabelObj) => !action.ids.includes(iterateLabel.id)\n ),\n ...action.labels,\n ]);\n case FIX_LABEL_ORDERS:\n return SeamlessImmutable([\n ...lodash.filter(\n state as any,\n (iterateLabel: LabelObj) => iterateLabel.parent !== action.parentId\n ),\n ...lodash.map(\n lodash.filter(\n state,\n (iterateLabel: LabelObj) => iterateLabel.parent === action.parentId\n ),\n (iterateLabel: LabelObj, index: number) => ({\n ...iterateLabel,\n order: index,\n })\n ),\n ]);\n case SET_LABELS_SYNCED_STATUS:\n return SeamlessImmutable(\n lodash.map(state, (iterateLabel: LabelObj) => {\n return action.ids.includes(iterateLabel.id)\n ? { ...iterateLabel, synced: action.status }\n : iterateLabel;\n }) as any\n );\n default:\n return state;\n }\n}\n\n// selectors\n\n/** returns the labels list\n * @param {Partial} state - the redux store\n * @return { LabelObj[] } - the existing labels\n */\nexport function getLabels(state: Partial): LabelObj[] {\n return (state as any)[reducerName];\n}\n\n/** returns the labels list length\n * @param {Partial} state - the redux store\n * @return { number } - the existing labels length\n */\nexport function getLabelsLength(state: Partial): number {\n return (state as any)[reducerName].length;\n}\n\n/** returns the label obj given label id if exists; otherwise, null\n * @param {Partial} state - the redux store\n * @param {string} labelId - the label id\n * @return { LabelObj | null } - the existing label or null\n */\nexport function getLabelById(state: Partial, labelId: string): LabelObj {\n return lodash.find((state as any)[reducerName], { id: labelId }) || null;\n}\n\n/** returns the new available order in list given a label id as parent\n * @param {Partial} state - the redux store\n * @param {string} label - the label id\n * @return { number } - the new available order\n */\nexport function getNewLabelOrderbyLabelId(\n state: Partial,\n labelId: string\n): number {\n return lodash.filter((state as any)[reducerName], { parent: labelId }).length;\n}\n\n/** returns the maximum height or depth given a label id\n * @param {Partial} state - the redux store\n * @param {string} label - the label id\n * @return { number } - the maximum height\n */\nexport function getMaxHeightOfLabel(\n state: Partial,\n labelId: string\n): number {\n return getMaxHeight((state as any)[reducerName], labelId);\n}\n\n/**\n * returns the list of unsynced labels\n * @param {Partial} state - the redux store\n * @returns {LabelObj[]} - the list of unsynced labels\n */\nexport function getUnsyncedLabels(state: Partial): LabelObj[] {\n return lodash.filter((state as any)[reducerName], { synced: false });\n}\n","import { AnyAction, Store } from 'redux';\nimport SeamlessImmutable from 'seamless-immutable';\nimport lodash from 'lodash';\nimport { getMaxHeight } from '../../services/utility';\n\n/** interface for TodoFilterObj object */\nexport interface TodoFilterObj {\n id: string;\n title: string;\n color: string;\n order: number;\n isFavourite: boolean;\n isHidden: boolean;\n parent: string;\n expanded: boolean;\n query: string;\n}\n\n/** The reducer name */\nexport const reducerName = 'todoFilters';\n\n// actions\n/** action types */\nexport const SET_TODO_FILTERS = 'virtunus/reducer/todoFilters/SET_TODO_FILTERS';\nexport const SET_TODO_FILTER = 'virtunus/reducer/todoFilters/SET_TODO_FILTER';\nexport const FIX_TODO_FILTER_ORDERS =\n 'virtunus/reducer/todoFilters/FIX_TODO_FILTER_ORDERS';\n\n/** interface for SET_TODO_FILTERS action */\nexport interface SetTodoFiltersAction extends AnyAction {\n todoFilters: TodoFilterObj[];\n type: typeof SET_TODO_FILTERS;\n}\n\n/** interface for SET_TODO_FILTER action */\nexport interface SetTodoFilterAction extends AnyAction {\n todoFilter: TodoFilterObj;\n type: typeof SET_TODO_FILTER;\n}\n\n/** interface for FIX_TODO_FILTER_ORDERS action */\nexport interface FixTodoFilterOrdersAction extends AnyAction {\n parentId: string;\n type: typeof FIX_TODO_FILTER_ORDERS;\n}\n\n/** Create type for todoFilter reducer actions */\nexport type TodoFiltersActionTypes =\n | SetTodoFiltersAction\n | SetTodoFilterAction\n | FixTodoFilterOrdersAction\n | AnyAction;\n\n// action creators\n\n/** set todoFilters action creator\n * @param {TodoFilterObj} todoFilters - an array of todoFilter items\n * @returns {SetTodoFiltersAction} - an action to set todoFilters in store\n */\nexport const setTodoFilters = (\n todoFilters: TodoFilterObj[]\n): SetTodoFiltersAction => {\n return {\n todoFilters,\n type: SET_TODO_FILTERS,\n };\n};\n\n/** set todoFilters action creator\n * @param {TodoFilterObj} todoFilter - a todoFilter object\n * @returns {SetTodoFilterAction} - an action to set todoFilter in store\n */\nexport const setTodoFilter = (\n todoFilter: TodoFilterObj\n): SetTodoFilterAction => ({\n todoFilter,\n type: SET_TODO_FILTER,\n});\n\nexport const fixTodoFilterOrders = (\n parentId: string\n): FixTodoFilterOrdersAction => ({\n parentId,\n type: FIX_TODO_FILTER_ORDERS,\n});\n\n// the reducer\n\n/** interface for todoFilters state in redux store */\ntype TodoFiltersState = TodoFilterObj[];\n\n/** Create an immutable todoFilters state */\nexport type ImmutableTodoFiltersState = SeamlessImmutable.ImmutableArray<\n TodoFiltersState\n>;\n\n/** initial todoFilters state */\nconst initialState: ImmutableTodoFiltersState = SeamlessImmutable([]);\n\n/** the todoFilters reducer function */\nexport default function reducer(\n state: ImmutableTodoFiltersState = initialState,\n action: TodoFiltersActionTypes\n): ImmutableTodoFiltersState {\n switch (action.type) {\n case SET_TODO_FILTERS:\n return SeamlessImmutable(action.todoFilters);\n case SET_TODO_FILTER:\n return SeamlessImmutable([\n ...lodash.filter(\n state.asMutable({ deep: true }),\n (iterateTodoFilter: TodoFilterObj) =>\n iterateTodoFilter.id !== action.todoFilter.id\n ),\n action.todoFilter,\n ]);\n case FIX_TODO_FILTER_ORDERS:\n return SeamlessImmutable([\n ...lodash.filter(\n state as any,\n (iterateTodoFilter: TodoFilterObj) =>\n iterateTodoFilter.parent !== action.parentId\n ),\n ...lodash.map(\n lodash.filter(\n state,\n (iterateTodoFilter: TodoFilterObj) =>\n iterateTodoFilter.parent === action.parentId\n ),\n (iterateTodoFilter: TodoFilterObj, index: number) => ({\n ...iterateTodoFilter,\n order: index,\n })\n ),\n ]);\n default:\n return state;\n }\n}\n\n// selectors\n\n/** returns the todoFilters list\n * @param {Partial} state - the redux store\n * @return { TodoFilterObj[] } - the existing todoFilters\n */\nexport function getTodoFilters(state: Partial): TodoFilterObj[] {\n return (state as any)[reducerName];\n}\n\n/** returns the todoFilters list length\n * @param {Partial} state - the redux store\n * @return { number } - the existing todoFilters length\n */\nexport function getTodoFiltersLength(state: Partial): number {\n return (state as any)[reducerName].length;\n}\n\n/** returns the todoFilter obj given todoFilter id if exists; otherwise, null\n * @param {Partial} state - the redux store\n * @param {string} todoFilterId - the todoFilter id\n * @return { TodoFilterObj | null } - the existing todoFilter or null\n */\nexport function getTodoFilterById(\n state: Partial,\n todoFilterId: string\n): TodoFilterObj {\n return lodash.find((state as any)[reducerName], { id: todoFilterId }) || null;\n}\n\n/** returns the new available order in list given a todoFilter id as parent\n * @param {Partial} state - the redux store\n * @param {string} todoFilter - the todoFilter id\n * @return { number } - the new available order\n */\nexport function getNewTodoFilterOrderbyTodoFilterId(\n state: Partial,\n todoFilterId: string\n): number {\n return lodash.filter((state as any)[reducerName], { parent: todoFilterId })\n .length;\n}\n\n/** returns the maximum height or depth given a todoFilter id\n * @param {Partial} state - the redux store\n * @param {string} todoFilter - the todoFilter id\n * @return { number } - the maximum height\n */\nexport function getMaxHeightOfTodoFilter(\n state: Partial,\n todoFilterId: string\n): number {\n return getMaxHeight((state as any)[reducerName], todoFilterId);\n}\n","import { applyMiddleware, combineReducers, createStore, compose } from 'redux';\nimport {\n createStateSyncMiddleware,\n initStateWithPrevTab,\n withReduxStateSync,\n} from 'redux-state-sync';\nimport SeamlessImmutable from 'seamless-immutable';\nimport { loadState, saveState } from '../services/cookieStorageSync';\nimport session, { reducerName as sessionReducer } from './ducks/session';\nimport projects, { reducerName as projectsReducer } from './ducks/projects';\nimport sections, { reducerName as sectionsReducer } from './ducks/sections';\nimport tasks, { reducerName as tasksReducer } from './ducks/tasks';\nimport labels, { reducerName as labelsReducer } from './ducks/labels';\nimport todoFilters, {\n reducerName as todoFiltersReducer,\n} from './ducks/todoFilters';\n\n// reducers\n/** Initial reducers in the reducer registry */\nconst defaultReducers: any = {};\n\n/** Add session reducer to registry */\ndefaultReducers[sessionReducer] = session;\n/** Add projects reducer to registry */\ndefaultReducers[projectsReducer] = projects;\n/** Add sections reducer to registry */\ndefaultReducers[sectionsReducer] = sections;\n/** Add tasks reducer to registry */\ndefaultReducers[tasksReducer] = tasks;\n/** Add labels reducer to registry */\ndefaultReducers[labelsReducer] = labels;\n/** Add todoFilters reducer to registry */\ndefaultReducers[todoFiltersReducer] = todoFilters;\n\n/** Create reducers from default reducers obj */\nconst reducers = withReduxStateSync(\n combineReducers(defaultReducers) as any,\n (state: any) => SeamlessImmutable(state)\n);\n\n// middleware\nconst config = {};\nconst middlewares = [createStateSyncMiddleware(config)];\n\n/** Create composer for redux dev tools */\nconst composeEnhancers =\n (window as any).__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ || compose;\n\n// store\n/** The initial store */\nconst persistedState = loadState();\nconst immutablePersistedState = SeamlessImmutable(persistedState);\nconst store = createStore(\n reducers,\n immutablePersistedState,\n composeEnhancers(applyMiddleware(...middlewares))\n);\n\n/** Keep saving the store on local storage */\nstore.subscribe(() => {\n saveState({\n [sessionReducer]: (store as any).getState()[sessionReducer],\n });\n});\ninitStateWithPrevTab(store);\n\nexport default store;\n","import axios from 'axios';\nimport { LOCAL_LOGOUT_ENDPOINT } from '../configs/endpoints';\nimport store from '../store';\nimport { getSessionToken } from '../store/ducks/session';\n\n/** Interface to describe a flexible object */\ninterface FlexObj {\n [key: string]: any;\n}\n\n// Request types\n/** GET REQUEST TYPE */\nexport const GET = 'GET';\ntype GET = typeof GET;\n\n/** POST REQUEST TYPE */\nexport const POST = 'POST';\ntype POST = typeof POST;\n\n/**\n * axioGet makes a get request using the axio libary\n * @param {string} url - the url where the get request will be made\n * @param {FlexObj | FlexObj[]} params - the parameters that will be passed\n * @param {boolean} isProtected - if true, access token will be included in header; otherwise, not.\n * @returns {any} - response returned by the server if successful\n */\nexport const axioGet = async (\n url: string,\n params: FlexObj | FlexObj[] = {},\n isProtected = false\n) => {\n /** retrieve the access token from redux store */\n const token = getSessionToken((store as any).getState());\n\n const config = isProtected\n ? {\n headers: {\n Accept: `application/json`,\n Authorization: `Bearer ${token}`,\n },\n }\n : { headers: { Accept: `application/json` } };\n const response = await axios.get(url, {\n ...config,\n params,\n });\n return await response;\n};\n\n/**\n * axioPost makes a post request using the axio libary\n * @param {string} url - the url where the post request will be made\n * @param {FlexObj | FlexObj[]} params - the parameters that will be passed\n * @param {boolean} isProtected - if true, access token will be included in header; otherwise, not.\n * @returns {any} - response returned by the server if successful\n */\nexport const axioPost = async (\n url: string,\n params: FlexObj | FlexObj[] = {},\n isProtected = false\n) => {\n /** retrieve the access token from redux store */\n const token = getSessionToken((store as any).getState());\n\n const config = isProtected\n ? {\n headers: {\n Accept: `application/json`,\n Authorization: `Bearer ${token}`,\n },\n }\n : { headers: { Accept: `application/json` } };\n const response = await axios.post(url, params, config);\n return await response;\n};\n\n/**\n * axioService makes a server request using the axio libary\n * @param {GET|POST} type - the type of request\n * @param {string} url - the url where the request will be made\n * @param {FlexObj | FlexObj[]} params - the parameters that will be passed\n * @param {boolean} isProtected - if true, access token will be included in header; otherwise, not.\n * @returns {any} - response returned by the server if successful; otherwise, error object\n */\nexport const axioService = async (\n type: GET | POST,\n url: string,\n params: FlexObj | FlexObj[] = {},\n isProtected = false\n) => {\n let response;\n try {\n if (type == POST) {\n response = await axioPost(url, params, isProtected);\n } else {\n response = await axioGet(url, params, isProtected);\n }\n return await response;\n } catch (e) {\n if (e.response.status === 401) {\n /** resets the session if there is a token */\n const token = getSessionToken((store as any).getState());\n if (token !== '') {\n window.location.href = LOCAL_LOGOUT_ENDPOINT;\n throw e;\n } else {\n throw e;\n }\n } else {\n throw e;\n }\n }\n};\n","import { Alert, Button, Card, Form, Input, Spin } from 'antd';\nimport { Store } from 'antd/lib/form/interface';\nimport clsx from 'clsx';\nimport queryString from 'query-string';\nimport React, { useState } from 'react';\nimport { connect } from 'react-redux';\nimport { Link, useHistory, useLocation } from 'react-router-dom';\nimport {\n SERVER_LOGIN_APP_NAME,\n SERVER_LOGIN_CLIENT_ID,\n SERVER_LOGIN_CLIENT_SCOPE,\n SERVER_LOGIN_CLIENT_SECRET,\n SERVER_LOGIN_GRANT_TYPE,\n} from '../../configs/constants';\nimport {\n APP_AUTHORIZE_ENDPOINT,\n LOCAL_FORGOT_PASSWORD_ENDPOINT,\n LOCAL_PERSONAL_INFO_ENDPOINT,\n LOCAL_REGISTER_ENDPOINT,\n SERVER_APPLE_AUTH_LINK,\n SERVER_FACEBOOK_AUTH_LINK,\n SERVER_GOOGLE_AUTH_LINK,\n SERVER_LOGIN_ENDPOINT,\n} from '../../configs/endpoints';\nimport Logo from '../../logo/Logo';\nimport { axioService, POST } from '../../services/axioService';\nimport { getSessionToken, setSessionToken } from '../../store/ducks/session';\n\n/** interface to describe Login props*/\ninterface LoginProps {\n token: string;\n setSessionTokenActionCreator: typeof setSessionToken;\n}\n\nconst Login: React.FC = (props: LoginProps) => {\n const { setSessionTokenActionCreator, token } = props;\n const [isEmailFocued, setIsEmailFocued] = useState(false);\n const [isPasswordFocued, setIsPasswordFocued] = useState(false);\n const location = useLocation();\n const history = useHistory();\n const passwordRef = React.useRef(null);\n const emailRef = React.useRef(null);\n\n // React states\n /** manages loading while processing register request */\n const [loading, setLoading] = React.useState(false);\n /** error message to show if occurs */\n const [errorMessage, setErrorMessage] = React.useState('');\n /** status to manage password visibility */\n const [isPasswordVisible, setIsPasswordVisible] = React.useState(\n false\n );\n\n /** cycles */\n\n React.useEffect(() => {\n emailRef.current?.focus();\n }, []);\n\n /** handlers */\n\n /** toggles the password input visibility */\n const handlePasswordVisibility = () => {\n setIsPasswordVisible(!isPasswordVisible);\n passwordRef.current.blur();\n };\n\n /**\n * onFinish is called when form validation passes\n * @param {any} values - containing the key-value user response\n */\n const onFinish = async (values: any) => {\n try {\n setLoading(true);\n const response = await axioService(\n POST,\n SERVER_LOGIN_ENDPOINT,\n {\n grant_type: SERVER_LOGIN_GRANT_TYPE,\n client_id: SERVER_LOGIN_CLIENT_ID,\n client_secret: SERVER_LOGIN_CLIENT_SECRET,\n username: values.username,\n password: values.password,\n scope: SERVER_LOGIN_CLIENT_SCOPE,\n app_name: SERVER_LOGIN_APP_NAME,\n },\n false\n );\n setSessionTokenActionCreator(response.data.access_token || '');\n setLoading(false);\n } catch (exception) {\n /** console error the exception */\n console.error(exception);\n setLoading(false);\n if (\n (exception as any).response &&\n (exception as any).response.data &&\n (exception as any).response.data.message\n ) {\n /** create the error msg from server response */\n const errorMsg = (\n
\n {(exception as any).response.data.message}
\n
    \n {(exception as any).response.data.errors &&\n Object.keys((exception as any).response.data.errors).map(\n (iterErrorField) => (\n
  • \n {iterErrorField}{' '}\n :{' '}\n {(exception as any).response.data.errors[iterErrorField]}\n
  • \n )\n )}\n
\n
\n );\n setErrorMessage(errorMsg);\n } else {\n setErrorMessage('There is a network error !!!');\n }\n }\n };\n\n /**\n * onFinishFailed is called when form validation fails\n * @param {any} errorInfo - containing the respective error information\n */\n const onFinishFailed = (errorInfo: any) => {\n console.error('Failed:', errorInfo);\n };\n\n /** onAlertClose is used to close alert message */\n const onAlertClose = () => setErrorMessage('');\n\n /** google login handler */\n const googleLoginHandler = () => {\n window.location.href = SERVER_GOOGLE_AUTH_LINK;\n };\n\n /** facebook login handler */\n const facebookLoginHandler = () => {\n window.location.href = SERVER_FACEBOOK_AUTH_LINK;\n };\n\n /** apple login handler */\n const appleLoginHandler = () => {\n window.location.href = SERVER_APPLE_AUTH_LINK;\n };\n\n /** any redirection to app is required */\n window.sessionStorage.setItem(\n 'app',\n (queryString.parse(location.search)['app'] as string) || ''\n );\n\n window.sessionStorage.setItem(\n 'redirect',\n (queryString.parse(location.search)['redirect'] as string) || '/'\n );\n if (token !== '') {\n // const app = window.sessionStorage.getItem('app');\n // const redirectEndpoint = window.sessionStorage.getItem('redirect');\n // if (app !== '') {\n // if (app === 'devtipslocal') {\n // window.location.href = `http://localhost:3000/authorize?token=${token}`;\n // } else {\n // window.location.href =\n // APP_AUTHORIZE_ENDPOINT !== ''\n // ? `${APP_AUTHORIZE_ENDPOINT}?redirect=${redirectEndpoint}`\n // : `https://${app}.virtunus.com?redirect=${redirectEndpoint}`;\n // }\n // } else {\n // history.push(LOCAL_PERSONAL_INFO_ENDPOINT);\n // }\n }\n\n return (\n \n {errorMessage !== '' && (\n \n )}\n
\n
\n
\n \n
\n \n \n

Sign in

\n \n setIsEmailFocued(true)}\n onBlur={() => setIsEmailFocued(false)}\n placeholder={!isEmailFocued ? 'Enter your email address' : ''}\n ref={emailRef}\n prefix={\"icon\"}\n />\n \n \n setIsPasswordFocued(true)}\n onBlur={() => setIsPasswordFocued(false)}\n placeholder={!isPasswordFocued ? 'Password' : ''}\n type={isPasswordVisible ? 'text' : 'password'}\n prefix={\"icon\"}\n ref={passwordRef}\n suffix={\n !isPasswordVisible ? (\n \n ) : (\n \n )\n }\n />\n \n \n Sign In\n \n
\n \n

Forgot Password?

\n \n
\n
\n

Or

\n
\n
\n \n
\n \n \"Icon\"\n \n Sign in with Google\n
\n \n {/* \n
\n \n \n \n \n \n Sign in with Facebook\n
\n */}\n \n
\n \n \n \n \n \n Sign in with Apple\n
\n \n
\n

\n \n Don't have an account?{' '}\n \n \n Register Now\n \n

\n
\n \n \n
\n
\n \n );\n};\n\n/** connect the component to the store */\n\n/** Interface to describe props from mapStateToProps */\ninterface DispatchedStateProps {\n token: string;\n}\n\n/** Map props to state */\nconst mapStateToProps = (state: Partial): DispatchedStateProps => {\n const result = {\n token: getSessionToken(state),\n };\n return result;\n};\n\n/** map props to actions */\nconst mapDispatchToProps = {\n setSessionTokenActionCreator: setSessionToken,\n};\n\n/** connect Login to the redux store */\nconst ConnectedLogin = connect(mapStateToProps, mapDispatchToProps)(Login);\n\nexport default ConnectedLogin;\n","import { Alert, Button, Card, Form, Input, Spin, message } from 'antd';\nimport { Store } from 'antd/lib/form/interface';\nimport clsx from 'clsx';\nimport React, { useState } from 'react';\nimport { connect } from 'react-redux';\nimport { Link, Redirect, useHistory, useLocation } from 'react-router-dom';\nimport {\n LOCAL_LOGIN_ENDPOINT,\n LOCAL_PERSONAL_INFO_ENDPOINT,\n PRIVACY_POLICY_ENDPOINT,\n SERVER_APPLE_AUTH_LINK,\n SERVER_FACEBOOK_AUTH_LINK,\n SERVER_GOOGLE_AUTH_LINK,\n SERVER_REGISTER_ENDPOINT,\n TERMS_OF_SERVICE_ENDPOINT,\n} from '../../configs/endpoints';\nimport Logo from '../../logo/Logo';\nimport { POST, axioService } from '../../services/axioService';\nimport { getSessionToken } from '../../store/ducks/session';\n\n/** interface to describe register props */\ninterface RegisterProps {\n token: string;\n}\n\n/** the Register component */\nconst Register: React.FC = (props: RegisterProps) => {\n const { token } = props;\n const location = useLocation();\n const history = useHistory();\n const nameRef = React.useRef(null);\n const passwordRef = React.useRef(null);\n const passwordConfirmationRef = React.useRef(null);\n const [isNameFocused, setIsNameFocused] = useState(false);\n const [isEmailFocused, setIsEmailFocused] = useState(false);\n const [isPasswordFocused, setIsPasswordFocused] = useState(false);\n const [isConfirmPasswordFocused, setIsConfirmPasswordFocused] = useState<\n boolean\n >(false);\n\n // React states\n /** manages loading while processing register request */\n const [loading, setLoading] = React.useState(false);\n /** error message to show if occurs */\n const [errorMessage, setErrorMessage] = React.useState('');\n /** status to manage password visibility */\n const [isPasswordVisible, setIsPasswordVisible] = React.useState(\n false\n );\n\n /** cycles */\n\n React.useEffect(() => {\n nameRef.current?.focus();\n }, []);\n\n /** handlers */\n\n /** status to manage password confirmation visibility */\n const [\n isPasswordConfirmationVisible,\n setIsPasswordConfirmationVisible,\n ] = React.useState(false);\n\n /** toggles the password input visibility */\n const handlePasswordVisibility = () => {\n setIsPasswordVisible(!isPasswordVisible);\n passwordRef.current.blur();\n };\n\n /** toggles the password confirmation input visibility */\n const handlePasswordConfirmationVisibility = () => {\n setIsPasswordConfirmationVisible(!isPasswordConfirmationVisible);\n passwordConfirmationRef.current.blur();\n };\n\n /**\n * onFinish is called when form validation passes\n * @param {any} values - containing the key-value user response\n */\n const onFinish = async (values: any) => {\n try {\n setLoading(true);\n const response = await axioService(\n POST,\n SERVER_REGISTER_ENDPOINT,\n {\n name: values.name,\n email: values.email,\n password: values.password,\n password_confirmation: values.password_confirmation,\n },\n false\n );\n /** redirects on successful login */\n message.success(\n 'Registration Successful, Please check your email to verify'\n );\n if (response.status === 201) {\n history.push(LOCAL_LOGIN_ENDPOINT + location.search);\n }\n setLoading(false);\n } catch (exception) {\n /** console error the exception */\n console.error(exception);\n setLoading(false);\n if (\n (exception as any).response &&\n (exception as any).response.data &&\n (exception as any).response.data.message\n ) {\n /** create the error msg from server response */\n const errorMsg = (\n
\n {(exception as any).response.data.message}
\n
    \n {(exception as any).response.data.errors &&\n Object.keys((exception as any).response.data.errors).map(\n (iterErrorField) => (\n
  • \n {iterErrorField}{' '}\n :{' '}\n {(exception as any).response.data.errors[iterErrorField]}\n
  • \n )\n )}\n
\n
\n );\n setErrorMessage(errorMsg);\n } else {\n setErrorMessage('There is a network error !!!');\n }\n }\n };\n\n /**\n * onFinishFailed is called when form validation fails\n * @param {any} errorInfo - containing the respective error information\n */\n const onFinishFailed = (errorInfo: any) => {\n // eslint-disable-next-line no-console\n console.error('Failed:', errorInfo);\n };\n\n /** onAlertClose is used to close alert message */\n const onAlertClose = () => setErrorMessage('');\n\n /** google login handler */\n const googleLoginHandler = () => {\n window.location.href = SERVER_GOOGLE_AUTH_LINK;\n };\n\n /** facebook login handler */\n const facebookLoginHandler = () => {\n window.location.href = SERVER_FACEBOOK_AUTH_LINK;\n };\n\n /** apple login handler */\n const appleLoginHandler = () => {\n window.location.href = SERVER_APPLE_AUTH_LINK;\n };\n\n return (\n \n {errorMessage !== '' && (\n \n )}\n
\n
\n {token !== '' && }\n
\n \n
\n \n \n

Create a new account

\n \n setIsNameFocused(true)}\n onBlur={() => setIsNameFocused(false)}\n placeholder={!isNameFocused ? 'Write your name' : ''}\n prefix={\"user\"}\n />\n \n \n setIsEmailFocused(true)}\n onBlur={() => setIsEmailFocused(false)}\n placeholder={\n !isEmailFocused ? 'Enter your email address' : ''\n }\n prefix={\"icon\"}\n />\n \n \n setIsPasswordFocused(true)}\n onBlur={() => setIsPasswordFocused(false)}\n placeholder={!isPasswordFocused ? 'Password' : ''}\n prefix={\"icon\"}\n type={isPasswordVisible ? 'text' : 'password'}\n ref={passwordRef}\n suffix={\n !isPasswordVisible ? (\n \n ) : (\n \n )\n }\n />\n \n ({\n validator(rule, value) {\n if (!value || getFieldValue('password') === value) {\n return Promise.resolve();\n }\n return Promise.reject(\n 'The two passwords that you entered do not match!'\n );\n },\n }),\n ]}\n >\n setIsConfirmPasswordFocused(true)}\n onBlur={() => setIsConfirmPasswordFocused(false)}\n placeholder={\n !isConfirmPasswordFocused ? 'Confirm Password' : ''\n }\n prefix={\"icon\"}\n type={isPasswordConfirmationVisible ? 'text' : 'password'}\n ref={passwordConfirmationRef}\n suffix={\n isPasswordConfirmationVisible ? (\n \n ) : (\n \n )\n }\n />\n \n \n By creating an account, you agree with our{' '}\n \n terms of service\n {' '}\n and{' '}\n \n privacy policy\n \n .\n
\n }\n >\n \n Sign up\n \n
\n

Or

\n
\n
\n \n
\n \n \"Icon\"\n \n Sign up with Google\n
\n \n {/* \n
\n \n \n \n \n \n Sign up with Facebook\n
\n */}\n \n
\n \n \n \n \n \n Sign up with Apple\n
\n \n
\n

\n \n Already have an account?{' '}\n \n \n Sign in\n \n

\n
\n \n \n
\n
\n \n );\n};\n\n/** connect the component to the store */\n\n/** Interface to describe props from mapStateToProps */\ninterface DispatchedStateProps {\n token: string;\n}\n\n/** Map props to state */\nconst mapStateToProps = (state: Partial): DispatchedStateProps => {\n const result = {\n token: getSessionToken(state),\n };\n return result;\n};\n\n/** map props to actions */\nconst mapDispatchToProps = {};\n\n/** connect Register to the redux store */\nconst ConnectedRegister = connect(\n mapStateToProps,\n mapDispatchToProps\n)(Register);\n\nexport default ConnectedRegister;\n","import * as React from 'react';\nimport { connect } from 'react-redux';\nimport { Redirect, Route } from 'react-router-dom';\nimport { Store } from 'redux';\nimport { LOCAL_LOGIN_ENDPOINT } from '../../configs/endpoints';\nimport { isAuthenticated } from '../../store/ducks/session';\n\nconst PrivateRoute: React.FC = ({\n component: Component,\n isAuthenticated,\n ...rest\n}: any) => (\n \n isAuthenticated === true ? (\n \n ) : (\n \n )\n }\n />\n);\n\n/** connect the component to the store */\n\n/** Map props to state */\nconst mapStateToProps = (state: Partial, parentProps: any): any => {\n const result = {\n ...parentProps,\n isAuthenticated: isAuthenticated(state),\n };\n return result;\n};\n\n/** connect SignIn to the redux store */\nconst ConnectedPrivateRoute = connect(mapStateToProps, {})(PrivateRoute);\n\nexport default ConnectedPrivateRoute;\n","import clsx from 'clsx';\nimport React from 'react';\nimport './ProfileItemView.scss';\n\ninterface ProfileItemViewProps {\n label: string;\n value: string;\n requestedHandler?: () => void;\n}\n\nconst ProfileItemView: React.FC = (\n props: ProfileItemViewProps\n) => {\n const { label, value, requestedHandler } = props;\n\n return (\n
\n
\n
{label}
\n
\n \n {value || `----------`}\n
\n {requestedHandler && (\n
\n Change {label}{' '}\n
\n )}\n
\n );\n};\n\nexport default ProfileItemView;\n","import React from 'react';\nimport './AccountLogoutDropdown.scss';\nimport { Avatar, Divider } from 'antd';\nimport { Link } from 'react-router-dom';\nimport { LOCAL_LOGOUT_ENDPOINT } from '../../configs/endpoints';\nimport { FlexObj, getSessionUserInfo } from '../../store/ducks/session';\nimport { Store } from 'redux';\nimport { connect } from 'react-redux';\n\ninterface AccountLogoutDropdownProps {\n userInfo: FlexObj;\n}\n\nconst AccountLogoutDropdown: React.FC = (\n props: AccountLogoutDropdownProps\n) => {\n const { userInfo } = props;\n\n return (\n
\n
\n \n
{userInfo?.name?.slice(0, 2)}
\n
\n
\n
{userInfo.name || ''}
\n
{userInfo.email || ''}
\n \n
\n \n Sign Out{' '}\n \n
\n \n
\n
Terms of Service
\n
\n
Privacy Policy
\n
\n
\n );\n};\n\n/** connect the component to the store */\n\n/** Interface to describe props from mapStateToProps */\ninterface DispatchedStateProps {\n userInfo: FlexObj;\n}\n\n/** Map props to state */\nconst mapStateToProps = (state: Partial): DispatchedStateProps => {\n const result = {\n userInfo: getSessionUserInfo(state),\n };\n return result;\n};\n\n/** map props to actions */\nconst mapDispatchToProps = {};\n\n/** connect AccountLogoutDropdown to the redux store */\nconst ConnectedAccountLogoutDropdown = connect(\n mapStateToProps,\n mapDispatchToProps\n)(AccountLogoutDropdown);\n\nexport default ConnectedAccountLogoutDropdown;\n","import { Avatar } from 'antd';\nimport React from 'react';\nimport { connect } from 'react-redux';\nimport { Store } from 'redux';\nimport { TIPS_APP_ENDPOINT, TODO_APP_ENDPOINT } from '../../configs/endpoints';\nimport { FlexObj, getSessionUserInfo } from '../../store/ducks/session';\nimport './AppsDropdown.scss';\n\ninterface AppsDropdownInterface {\n userInfo: FlexObj;\n}\n\nconst AppsDropdown: React.FC = (\n props: AppsDropdownInterface\n) => {\n const { userInfo } = props;\n\n const navigateToTodo = () => {\n window.location.href = TODO_APP_ENDPOINT;\n };\n\n const navigateToTips = () => {\n window.location.href = TIPS_APP_ENDPOINT;\n };\n\n return (\n
\n
\n
\n \n
{userInfo?.name?.slice(0, 2)}
\n
\n
\n
Account
\n
\n
\n
\n \n
\n
Upstride
\n
\n
\n );\n};\n\n/** connect the component to the store */\n\n/** Interface to describe props from mapStateToProps */\ninterface DispatchedStateProps {\n userInfo: FlexObj;\n}\n\n/** Map props to state */\nconst mapStateToProps = (state: Partial): DispatchedStateProps => {\n const result = {\n userInfo: getSessionUserInfo(state),\n };\n return result;\n};\n\n/** map props to actions */\nconst mapDispatchToProps = {};\n\n/** connect AppsDropdown to the redux store */\nconst ConnectedAppsDropdown = connect(\n mapStateToProps,\n mapDispatchToProps\n)(AppsDropdown);\n\nexport default ConnectedAppsDropdown;\n","import { Alert, Avatar, Dropdown } from 'antd';\nimport { Store } from 'antd/lib/form/interface';\nimport React from 'react';\nimport { connect } from 'react-redux';\nimport { SERVER_SEND_EMAIL_ENDPOINT } from '../../configs/endpoints';\nimport { axioService, POST } from '../../services/axioService';\nimport { FlexObj, getSessionUserInfo } from '../../store/ducks/session';\nimport AccountLogoutDropdown from '../accountLogoutDropdown/AccountLogoutDropdown';\nimport AppsDropdown from '../appsDropdown/AppsDropdown';\nimport './Header.scss';\n\ninterface HeaderProps {\n userInfo: FlexObj;\n}\n\nconst Header: React.FC = (props: HeaderProps) => {\n const { userInfo } = props;\n const [isEmailSend, setIsEmailSend] = React.useState(false);\n\n const sendVerificationEmail = async () => {\n try {\n await axioService(POST, SERVER_SEND_EMAIL_ENDPOINT, {}, true);\n setIsEmailSend(true);\n } catch (Exception) {\n console.error(Exception);\n }\n };\n\n return (\n
\n
\n {!userInfo.is_email_verified && (\n \n Email is not verified yet! Please verify your email by clicking\n on verification link.{' '}\n {!isEmailSend ? (\n \n Send verification email\n \n ) : (\n \n Message Sent.{' '}\n \n Resend\n \n \n )}\n .\n
\n }\n banner\n closable\n />\n )}\n
\n
\n \"\"\n
Account
\n
\n
\n
\n
Settings
\n }\n placement=\"bottomRight\"\n >\n
\n \n
\n \n }\n placement=\"bottomRight\"\n >\n
\n \n
{userInfo?.name?.slice(0, 2)}
\n
\n
\n \n
\n
\n
\n );\n};\n\n/** connect the component to the store */\n\n/** Interface to describe props from mapStateToProps */\ninterface DispatchedStateProps {\n userInfo: FlexObj;\n}\n\n/** Map props to state */\nconst mapStateToProps = (state: Partial): DispatchedStateProps => {\n const result = {\n userInfo: getSessionUserInfo(state),\n };\n return result;\n};\n\n/** map props to actions */\nconst mapDispatchToProps = {};\n\n/** connect Header to the redux store */\nconst ConnectedHeader = connect(mapStateToProps, mapDispatchToProps)(Header);\n\nexport default ConnectedHeader;\n","import React from 'react';\nimport './UpcomingBadge.scss';\n\nconst UpcomingBadge = () => {\n return (\n
\n Upcoming \n
\n );\n};\n\nexport default UpcomingBadge;\n","import { Divider } from 'antd';\nimport React from 'react';\nimport { BLOG_ENDPOINT } from '../../configs/endpoints';\nimport UpcomingBadge from '../upcomingBadge/UpcomingBadge';\nimport './Sider.scss';\n\nconst Sider: React.FC = () => {\n const navigateToBlog = () => {\n window.location.href = BLOG_ENDPOINT;\n };\n\n return (\n
\n
Personal Info
\n
\n Apps \n
\n
\n Security & Activity \n
\n \n
\n About \n
\n
\n Blog\n
\n
\n );\n};\n\nexport default Sider;\n","import React from 'react';\nimport Header from '../../containers/header/Header';\nimport Sider from '../../components/sider/Sider';\nimport './withAccountLayout.scss';\n\n/**\n * withAccountLayout hoc method wraps the passing component with todo header and sider\n * @param {React.ComponentType} Component - a component that needs the todo layout\n * @returns a component containing all the todo layout components as well as the passed component\n */\nfunction withAccountLayout(\n Component: React.ComponentType\n) {\n return (props: ComponentPropsType) => {\n {\n return (\n
\n
\n
\n
\n
\n
\n
\n \n
\n
\n \n
\n
\n
\n
\n );\n }\n };\n}\n\nexport default withAccountLayout;\n","import { Input, Modal } from 'antd';\nimport React from 'react';\nimport { SERVER_USER_PROFILE_ENDPOINT } from '../../configs/endpoints';\nimport { axioService, POST } from '../../services/axioService';\nimport './CityModal.scss';\n\n/** inteface to describe CityModal props */\ninterface CityModalProps {\n selected: string;\n saveHandler: (requested: string) => void;\n visible: boolean;\n cancelHandler: () => void;\n}\n\nconst CityModal: React.FC = (props: CityModalProps) => {\n const { visible, cancelHandler, selected, saveHandler } = props;\n\n /** manages the input text state */\n const [text, setText] = React.useState('');\n\n /** resets the input on modal visibility change */\n React.useEffect(() => setText(''), [visible]);\n\n /**\n * handles the onchange request\n * @param {React.ChangeEvent} event - the react onchange event\n */\n const onChangeHandler = (event: React.ChangeEvent) => {\n setText(event.target.value);\n };\n\n /** handles the save request after confirm */\n const confirmHandler = async () => {\n if (text === '') return;\n try {\n /** create the form data request */\n const request = new FormData();\n request.append('city', text);\n await axioService(POST, SERVER_USER_PROFILE_ENDPOINT, request, true);\n saveHandler(text);\n setText('');\n } catch (exception) {\n console.error(exception);\n }\n };\n\n return (\n \n
\n
Existing City
\n
\n \n
\n
\n
\n
New City
\n
\n \n
\n
\n \n );\n};\n\nexport default CityModal;\n","import { Input, Modal } from 'antd';\nimport React from 'react';\nimport { SERVER_USER_PROFILE_ENDPOINT } from '../../configs/endpoints';\nimport { axioService, POST } from '../../services/axioService';\nimport './CountryModal.scss';\n\n/** interface to describe CountryModal props */\ninterface CountryModalProps {\n selected: string;\n saveHandler: (requested: string) => void;\n visible: boolean;\n cancelHandler: () => void;\n}\n\nconst CountryModal: React.FC = (\n props: CountryModalProps\n) => {\n const { visible, cancelHandler, selected, saveHandler } = props;\n\n /** manages the input state */\n const [text, setText] = React.useState('');\n\n /** resets the input on modal visibility */\n React.useEffect(() => setText(''), [visible]);\n\n /**\n * handles the onchange request\n * @param {React.ChangeEvent} event - the react change event\n */\n const onChangeHandler = (event: React.ChangeEvent) => {\n setText(event.target.value);\n };\n\n /** handles the save request after confirm */\n const confirmHandler = async () => {\n if (text === '') return;\n try {\n /** create the form data request */\n const request = new FormData();\n request.append('country', text);\n await axioService(POST, SERVER_USER_PROFILE_ENDPOINT, request, true);\n saveHandler(text);\n setText('');\n } catch (exception) {\n console.error(exception);\n }\n };\n\n return (\n \n
\n
Existing Country
\n
\n \n
\n
\n
\n
New Country
\n
\n \n
\n
\n \n );\n};\n\nexport default CountryModal;\n","import { DatePicker, Input, Modal } from 'antd';\nimport moment from 'moment';\nimport React from 'react';\nimport { SERVER_USER_PROFILE_ENDPOINT } from '../../configs/endpoints';\nimport { axioService, POST } from '../../services/axioService';\nimport './DOBModal.scss';\n\ninterface DOBModalProps {\n selected: string;\n saveHandler: (requested: string) => void;\n visible: boolean;\n cancelHandler: () => void;\n}\n\nconst DOBModal: React.FC = (props: DOBModalProps) => {\n const { visible, cancelHandler, selected, saveHandler } = props;\n\n /** manages the input text */\n const [text, setText] = React.useState('');\n\n /** resets the text on modal visibility change */\n React.useEffect(() => setText(''), [visible]);\n\n /**\n * manages the onchange request\n * @param {any} date - the moment date\n * @param {any} dateString - the string date\n */\n const onChangeHandler = (date: any, dateString: string): any => {\n setText(dateString);\n };\n\n /** manages the save request */\n const confirmHandler = async () => {\n if (text === '') return;\n try {\n /** create the form data request */\n const request = new FormData();\n request.append('date_of_birth', text);\n await axioService(POST, SERVER_USER_PROFILE_ENDPOINT, request, true);\n saveHandler(text);\n setText('');\n } catch (exception) {\n console.error(exception);\n }\n };\n\n return (\n \n
\n
Existing Birthday
\n
\n \n
\n
\n
\n
New Birthday
\n
\n !d || d.isAfter(moment())}\n />\n
\n
\n \n );\n};\n\nexport default DOBModal;\n","import { Input, Modal, Radio } from 'antd';\nimport React from 'react';\nimport { SERVER_USER_PROFILE_ENDPOINT } from '../../configs/endpoints';\nimport { axioService, POST } from '../../services/axioService';\nimport './GenderModal.scss';\n\ninterface GenderModalProps {\n selected: string;\n saveHandler: (requested: string) => void;\n visible: boolean;\n cancelHandler: () => void;\n}\n\nconst GENDER_OPTIONS = ['Male', 'Female'];\n\nconst GenderModal: React.FC = (props: GenderModalProps) => {\n const { visible, cancelHandler, selected, saveHandler } = props;\n\n /** manages the input text */\n const [text, setText] = React.useState('');\n\n /** resets input on modal visibility change */\n React.useEffect(() => setText(''), [visible]);\n\n /**\n * on change request handler\n * @param {any} event - the radio button event\n */\n const onChangeHandler = (event: any) => {\n setText(event.target.value);\n };\n\n /** manages the confirm save request */\n const confirmHandler = async () => {\n if (text === '') return;\n try {\n /** create the form data request */\n const request = new FormData();\n request.append('gender', text);\n await axioService(POST, SERVER_USER_PROFILE_ENDPOINT, request, true);\n saveHandler(text);\n setText('');\n } catch (exception) {\n console.error(exception);\n }\n };\n\n return (\n \n
\n
Existing Gender
\n
\n \n
\n
\n
\n
New Gender
\n
\n \n
\n
\n \n );\n};\n\nexport default GenderModal;\n","import { Input, Modal } from 'antd';\nimport React from 'react';\nimport { SERVER_USER_PROFILE_ENDPOINT } from '../../configs/endpoints';\nimport { axioService, POST } from '../../services/axioService';\nimport './NameModal.scss';\n\ninterface NameModalProps {\n selected: string;\n saveHandler: (requested: string) => void;\n visible: boolean;\n cancelHandler: () => void;\n}\n\nconst NameModal: React.FC = (props: NameModalProps) => {\n const { visible, cancelHandler, selected, saveHandler } = props;\n\n /** manages the state of input text */\n const [text, setText] = React.useState('');\n\n /** resets text if modal opens/closes */\n React.useEffect(() => setText(''), [visible]);\n\n /**\n * handles the onChange request\n * @param {React.ChangeEvent} event - the react onchange event\n */\n const onChangeHandler = (event: React.ChangeEvent) => {\n setText(event.target.value);\n };\n\n /** confirms the save request */\n const confirmHandler = async () => {\n if (text === '') return;\n try {\n /** create the form data request */\n const request = new FormData();\n request.append('name', text);\n await axioService(POST, SERVER_USER_PROFILE_ENDPOINT, request, true);\n saveHandler(text);\n setText('');\n } catch (exception) {\n console.error(exception);\n }\n };\n\n return (\n \n
\n
Existing Name
\n
\n \n
\n
\n
\n
New Name
\n
\n \n
\n
\n \n );\n};\n\nexport default NameModal;\n","import { Input, Modal } from 'antd';\nimport React from 'react';\nimport { SERVER_CHANGE_PASSWORD_ENDPOINT } from '../../configs/endpoints';\nimport { axioService, POST } from '../../services/axioService';\nimport './PasswordModal.scss';\n\n/** interface to describe PasswordModal props */\ninterface PasswordModalProps {\n visible: boolean;\n cancelHandler: () => void;\n}\n\nconst PasswordModal: React.FC = (\n props: PasswordModalProps\n) => {\n const { visible, cancelHandler } = props;\n\n /** manages the new password field */\n const [text, setText] = React.useState('');\n /** manages the new password confirmation field */\n const [confirmText, setConfirmText] = React.useState('');\n /** manages the current password field */\n const [currentPassword, setCurrentPassword] = React.useState('');\n\n /** resets the inputs on modal visibility change */\n React.useEffect(() => {\n setText('');\n setConfirmText('');\n setCurrentPassword('');\n }, [visible]);\n\n /** handles the onchange request of new password */\n const onChangeHandlerOne = (event: React.ChangeEvent) => {\n setText(event.target.value);\n };\n\n /** handles the onchange request of password confirmation text */\n const onChangeHandlerTwo = (event: React.ChangeEvent) => {\n setConfirmText(event.target.value);\n };\n\n /** handles the onchange request of current password */\n const onChangeHandlerThree = (event: React.ChangeEvent) => {\n setCurrentPassword(event.target.value);\n };\n\n /** handles the save request after confirm */\n const confirmHandler = async () => {\n if (\n text === '' ||\n confirmText === '' ||\n text !== confirmText ||\n text.length < 8 ||\n currentPassword.length < 8\n )\n return;\n\n try {\n /** create the form data request */\n const request = new FormData();\n request.append('current_password', currentPassword);\n request.append('password', text);\n request.append('password_confirmation', confirmText);\n await axioService(POST, SERVER_CHANGE_PASSWORD_ENDPOINT, request, true);\n setConfirmText('');\n setText('');\n setCurrentPassword('');\n cancelHandler();\n } catch (exception) {\n console.error(exception);\n }\n };\n\n return (\n \n
\n
Current Password
\n
\n \n visible ? (\n
\n \n
\n ) : (\n
\n \n
\n )\n }\n />\n
\n
\n
\n
New Password
\n
\n \n visible ? (\n
\n \n
\n ) : (\n
\n \n
\n )\n }\n />\n
\n
\n
\n
Confirm Password
\n
\n \n visible ? (\n
\n \n
\n ) : (\n
\n \n
\n )\n }\n />\n
\n
\n
\n Password needs to be minimum 8 characters\n
\n \n );\n};\n\nexport default PasswordModal;\n","import { Input, Modal } from 'antd';\nimport React from 'react';\nimport { SERVER_USER_PROFILE_ENDPOINT } from '../../configs/endpoints';\nimport { axioService, POST } from '../../services/axioService';\nimport './PhoneModal.scss';\n\n/** interface to describe phone modal props */\ninterface PhoneModalProps {\n selected: string;\n saveHandler: (requested: string) => void;\n visible: boolean;\n cancelHandler: () => void;\n}\n\nconst PhoneModal: React.FC = (props: PhoneModalProps) => {\n const { visible, cancelHandler, selected, saveHandler } = props;\n\n /** manages the text input state */\n const [text, setText] = React.useState('');\n\n /** resets the input on modal visibility */\n React.useEffect(() => setText(''), [visible]);\n\n /**\n * handles the on change request\n * @param {React.ChangeEvent} event - the on change event\n */\n const onChangeHandler = (event: React.ChangeEvent) => {\n setText(event.target.value);\n };\n\n /** handles the save request after confirm */\n const confirmHandler = async () => {\n if (text === '') return;\n try {\n /** create the form data request */\n const request = new FormData();\n request.append('mobile', text);\n await axioService(POST, SERVER_USER_PROFILE_ENDPOINT, request, true);\n saveHandler(text);\n setText('');\n } catch (exception) {\n console.error(exception);\n }\n };\n\n return (\n \n
\n
Existing Phone
\n
\n \n
\n
\n
\n
New Phone
\n
\n \n
\n
\n \n );\n};\n\nexport default PhoneModal;\n","import { Input, Modal } from 'antd';\nimport React from 'react';\nimport { SERVER_USER_PROFILE_ENDPOINT } from '../../configs/endpoints';\nimport { axioService, POST } from '../../services/axioService';\nimport './ProfessionModal.scss';\n\ninterface ProfessionModalProps {\n selected: string;\n saveHandler: (requested: string) => void;\n visible: boolean;\n cancelHandler: () => void;\n}\n\nconst ProfessionModal: React.FC = (\n props: ProfessionModalProps\n) => {\n const { visible, cancelHandler, selected, saveHandler } = props;\n\n /** manages the input text */\n const [text, setText] = React.useState('');\n\n /** resets the input on modal visibility */\n React.useEffect(() => setText(''), [visible]);\n\n /**\n * manages the onchange input request\n * @param {React.ChangeEvent} event - the on change event\n */\n const onChangeHandler = (event: React.ChangeEvent) => {\n setText(event.target.value);\n };\n\n /** manages the save request after confirm */\n const confirmHandler = async () => {\n if (text === '') return;\n try {\n /** create the form data request */\n const request = new FormData();\n request.append('profession', text);\n await axioService(POST, SERVER_USER_PROFILE_ENDPOINT, request, true);\n saveHandler(text);\n setText('');\n } catch (exception) {\n console.error(exception);\n }\n };\n\n return (\n \n
\n
Existing Profession
\n
\n \n
\n
\n
\n
New Profession
\n
\n \n
\n
\n \n );\n};\n\nexport default ProfessionModal;\n","import { Modal } from 'antd';\nimport React from 'react';\nimport { useDropzone } from 'react-dropzone';\nimport { SERVER_AVATAR_ENDPOINT } from '../../configs/endpoints';\nimport { axioService, POST } from '../../services/axioService';\nimport './PicModal.scss';\n\ninterface PicModalProps {\n saveHandler: (requested: string) => void;\n visible: boolean;\n cancelHandler: () => void;\n}\n\nconst PicModal: React.FC = (props: PicModalProps) => {\n const { visible, cancelHandler, saveHandler } = props;\n\n /** keeps track of the pic file */\n const [files, setFiles] = React.useState([]);\n\n const { getRootProps, getInputProps } = useDropzone({\n accept: 'image/*',\n maxFiles: 1,\n onDrop: (acceptedFiles) => {\n setFiles(\n acceptedFiles.map((file) =>\n Object.assign(file, {\n preview: URL.createObjectURL(file),\n })\n )\n );\n },\n });\n\n React.useEffect(\n () => () => {\n // Make sure to revoke the data uris to avoid memory leaks\n files.forEach((file: any) => URL.revokeObjectURL(file.preview));\n },\n [files]\n );\n\n React.useEffect(\n () => () => {\n // Make sure to revoke the data uris to avoid memory leaks\n files.forEach((file: any) => URL.revokeObjectURL(file.preview));\n setFiles([]);\n },\n [visible]\n );\n\n /** removes the pic of current upload */\n const removeCurrentUpload = () => setFiles([]);\n\n /** confirms the save request */\n const confirmRequest = async () => {\n if (files.length === 0) return;\n try {\n /** create the form data request */\n const request = new FormData();\n request.append('avatar', files[0]);\n const response: any = await axioService(\n POST,\n SERVER_AVATAR_ENDPOINT,\n request,\n true\n );\n saveHandler(response.data.avatar);\n cancelHandler();\n } catch (exception) {\n console.error(exception);\n }\n };\n\n return (\n \n
\n {files.length > 0 ? (\n
\n
\n \"\"\n
\n \n
\n
\n
\n ) : (\n
\n \n

Drag and drop an image, or click to select file

\n
\n )}\n
\n \n );\n};\n\nexport default PicModal;\n","import { Divider } from 'antd';\nimport Avatar from 'antd/lib/avatar/avatar';\nimport React from 'react';\nimport { connect } from 'react-redux';\nimport { Store } from 'redux';\nimport ProfileItemView from '../../components/profileItemView/ProfileItemView';\nimport withAccountLayout from '../../hocs/withAccountLayout/withAccountLayout';\nimport {\n FlexObj,\n getSessionUserInfo,\n setSessionUserInfo,\n} from '../../store/ducks/session';\nimport CityModal from '../cityModal/CityModal';\nimport CountryModal from '../countryModal/CountryModal';\nimport DOBModal from '../dobModal/DOBModal';\nimport GenderModal from '../genderModal/GenderModal';\nimport NameModal from '../nameModal/NameModal';\nimport PasswordModal from '../passwordModal/PasswordModal';\nimport PhoneModal from '../phoneModal/PhoneModal';\nimport ProfessionModal from '../professionModal/ProfessionModal';\nimport './Account.scss';\nimport PicModal from '../picModal/PicModal';\n\n/** interface to describe account props */\ninterface AccountProps {\n userInfo: FlexObj;\n setUserInfoActionCreator: typeof setSessionUserInfo;\n}\n\nconst Account: React.FC = (props: AccountProps) => {\n const { userInfo, setUserInfoActionCreator } = props;\n\n /** manages the visibility of picture/avatar modal */\n const [picModalVisible, setPicModalVisible] = React.useState(false);\n\n /** manages the visibility of name modal */\n const [nameModalVisible, setNameModalVisible] = React.useState(\n false\n );\n\n /** manages the visibility of date of birth modal */\n const [dobModalVisible, setDobModalVisible] = React.useState(false);\n\n /** manages the visibility of gender modal */\n const [genderModalVisible, setGenderModalVisible] = React.useState(\n false\n );\n\n /** manages the visibility of profession modal */\n const [professionModalVisible, setProfessionModalVisible] = React.useState<\n boolean\n >(false);\n\n /** manages the visibility of country modal */\n const [countryModalVisible, setCountryModalVisible] = React.useState(\n false\n );\n\n /** manages the visibility of city modal */\n const [cityModalVisible, setCityModalVisible] = React.useState(\n false\n );\n\n /** manages the visibility of password modal */\n const [passwordModalVisible, setPasswordModalVisible] = React.useState<\n boolean\n >(false);\n\n /** manages the visibility of phone modal */\n const [phoneModalVisible, setPhoneModalVisible] = React.useState(\n false\n );\n\n /** pic */\n\n /**\n * manages the save request of pic\n * @param {string} requested - the pic/avatar link to save\n */\n const savePic = (requested: string) => {\n setUserInfoActionCreator({ ...userInfo, avatar: requested });\n setPicModalVisible(false);\n };\n\n /** opens the pic/avatar upload modal */\n const openPicModal = () => setPicModalVisible(true);\n\n /** closes the avatar upload modal */\n const closePicModal = () => setPicModalVisible(false);\n\n /** name */\n\n /**\n * manages the save request of name\n * @param {string} requested - the name to save\n */\n const saveName = (requested: string) => {\n setUserInfoActionCreator({ ...userInfo, name: requested });\n setNameModalVisible(false);\n };\n\n /** opens the name modal */\n const openNameModal = () => setNameModalVisible(true);\n\n /** closes the name modal */\n const closeNameModal = () => setNameModalVisible(false);\n\n /** date of birth */\n\n /**\n * manages the save request of date of birth\n * @param {string} requested - the date of birth to save\n */\n const saveDob = (requested: string) => {\n setUserInfoActionCreator({ ...userInfo, date_of_birth: requested });\n setDobModalVisible(false);\n };\n\n /** opens the date of birth modal */\n const openDobModal = () => setDobModalVisible(true);\n\n /** closes the date of birth modal */\n const closeDobModal = () => setDobModalVisible(false);\n\n /** gender */\n\n /**\n * manages the save request of gender\n * @param {string} requested - the gender to save\n */\n const saveGender = (requested: string) => {\n setUserInfoActionCreator({ ...userInfo, gender: requested });\n setGenderModalVisible(false);\n };\n\n /** opens the gender modal */\n const openGenderModal = () => setGenderModalVisible(true);\n\n /** closes the gender modal */\n const closeGenderModal = () => setGenderModalVisible(false);\n\n /** profession */\n\n /**\n * manages the save request of profession\n * @param {string} requested - the profession to save\n */\n const saveProfession = (requested: string) => {\n setUserInfoActionCreator({ ...userInfo, profession: requested });\n setProfessionModalVisible(false);\n };\n\n /** opens the profession modal */\n const openProfessionModal = () => setProfessionModalVisible(true);\n\n /** closes the profession modal */\n const closeProfessionModal = () => setProfessionModalVisible(false);\n\n /** city */\n\n /**\n * manages the save request of city\n * @param {string} requested - the city to save\n */\n const saveCity = (requested: string) => {\n setUserInfoActionCreator({ ...userInfo, city: requested });\n setCityModalVisible(false);\n };\n\n /** opens the city modal */\n const openCityModal = () => setCityModalVisible(true);\n\n /** closes the city modal */\n const closeCityModal = () => setCityModalVisible(false);\n\n /** country */\n\n /**\n * manages the save request of country\n * @param {string} requested - the country to save\n */\n const saveCountry = (requested: string) => {\n setUserInfoActionCreator({ ...userInfo, country: requested });\n setCountryModalVisible(false);\n };\n\n /** opens the country modal */\n const openCountryModal = () => setCountryModalVisible(true);\n\n /** closes the country modal */\n const closeCountryModal = () => setCountryModalVisible(false);\n\n /** password */\n\n /** opens the password modal */\n const openPasswordModal = () => setPasswordModalVisible(true);\n\n /** closes the password modal */\n const closePasswordModal = () => setPasswordModalVisible(false);\n\n /** phone */\n\n /**\n * manages the save request of phone\n * @param {string} requested - the phone to save\n */\n const savePhone = (requested: string) => {\n setUserInfoActionCreator({ ...userInfo, mobile: requested });\n setPhoneModalVisible(false);\n };\n\n /** opens the phone modal */\n const openPhoneModal = () => setPhoneModalVisible(true);\n\n /** closes the phone modal */\n const closePhoneModal = () => setPhoneModalVisible(false);\n\n return (\n
\n
\n
\n \n
{userInfo?.name?.slice(0, 2)}
\n
\n
\n \n
\n
\n
\n
{userInfo.name || ''}
\n
\n Connected to{' '}\n
\n 1 App\n
\n
\n
\n
\n \n
\n
Profile
\n
\n \n \n \n \n \n \n
\n
\n \n
\n
\n
\n \n
\n
\n
\n
\n
\n
\n
\n
\n
\n ) as any\n }\n />\n
\n
\n \n
\n
Contact Info
\n
\n \n {userInfo.email}{' '}\n {userInfo.is_email_verified ? (\n
verified
\n ) : (\n
unverified
\n )}\n
\n ) as any\n }\n />\n \n
\n
\n \n \n \n \n \n \n \n \n \n
\n );\n};\n\n/** connect the component to the store */\n\n/** Interface to describe props from mapStateToProps */\ninterface DispatchedStateProps {\n userInfo: FlexObj;\n}\n\n/** Map props to state */\nconst mapStateToProps = (state: Partial): DispatchedStateProps => {\n const result = {\n userInfo: getSessionUserInfo(state),\n };\n return result;\n};\n\n/** map props to actions */\nconst mapDispatchToProps = {\n setUserInfoActionCreator: setSessionUserInfo,\n};\n\n/** connect Account to the redux store */\nconst ConnectedAccount = connect(mapStateToProps, mapDispatchToProps)(Account);\n\nexport default withAccountLayout(ConnectedAccount);\n","import { Spin } from 'antd';\nimport queryString from 'query-string';\nimport React from 'react';\nimport { connect } from 'react-redux';\nimport { useHistory, useLocation } from 'react-router-dom';\nimport { Store } from 'redux';\nimport {\n LOCAL_LOGIN_ENDPOINT,\n SERVER_LOGOUT_ENDPOINT,\n} from '../../configs/endpoints';\nimport { POST, axioService } from '../../services/axioService';\nimport { getSessionToken, resetSession } from '../../store/ducks/session';\nimport './SessionDestroy.scss';\nimport { getDomain } from '../../services/cookieStorageSync';\n\n/** interface to describe SessionDestroy props*/\ninterface SessionDestroyProps {\n token: string;\n resetSessionActionCreator: typeof resetSession;\n}\n\nconst SessionDestroy = (props: SessionDestroyProps) => {\n const { resetSessionActionCreator } = props;\n const location = useLocation();\n const history = useHistory();\n\n const clearSession = async () => {\n try {\n await axioService(POST, SERVER_LOGOUT_ENDPOINT, {}, true);\n } catch (exception) {\n console.error(exception);\n }\n resetSessionActionCreator();\n\n const app = queryString.parse(location.search)['app'] || '';\n const guest = queryString.parse(location.search)['guest'] || '';\n\n if (app !== '' && guest !== '') {\n window.location.href = `https://app.upstride.co/`;\n } else {\n history.push(LOCAL_LOGIN_ENDPOINT + location.search);\n }\n };\n\n /** destroys the session */\n React.useEffect(() => {\n clearSession();\n }, []);\n\n return (\n \n
\n
\n );\n};\n\n/** connect the component to the store */\n\n/** Interface to describe props from mapStateToProps */\ninterface DispatchedStateProps {\n token: string;\n}\n\n/** Map props to state */\nconst mapStateToProps = (state: Partial): DispatchedStateProps => {\n const result = {\n token: getSessionToken(state),\n };\n return result;\n};\n\n/** map props to actions */\nconst mapDispatchToProps = {\n resetSessionActionCreator: resetSession,\n};\n\n/** connect SessionDestroy to the redux store */\nconst ConnectedSessionDestroy = connect(\n mapStateToProps,\n mapDispatchToProps\n)(SessionDestroy);\n\nexport default ConnectedSessionDestroy;\n","import { Card } from 'antd';\nimport React from 'react';\nimport { Link } from 'react-router-dom';\nimport { LOCAL_LOGIN_ENDPOINT } from '../../configs/endpoints';\nimport './ForgotPasswordSuccess.scss';\nexport default function ForgotPasswordSuccess() {\n return (\n
\n \n \"Preview\"\n

Please check your mail

\n

\n {' '}\n We just mailed you with the instruction to reset your password\n

\n
\n

\n Back to Sign In\n

\n
\n
\n
\n );\n}\n","import React from 'react';\nimport { Form, Card, Input, Button, Spin, Alert } from 'antd';\nimport { connect } from 'react-redux';\nimport { getSessionToken } from '../../store/ducks/session';\nimport { Store } from 'antd/lib/form/interface';\nimport { Link, Redirect } from 'react-router-dom';\nimport { POST, axioService } from '../../services/axioService';\nimport {\n LOCAL_LOGIN_ENDPOINT,\n LOCAL_PERSONAL_INFO_ENDPOINT,\n SERVER_FORGOT_PASSWORD_ENDPOINT,\n} from '../../configs/endpoints';\nimport Logo from '../../logo/Logo';\nimport clsx from 'clsx';\nimport ForgotPasswordSuccess from '../../components/forgotPasswordSuccess/ForgotPasswordSuccess';\n\n/** interface to describe Recovery props*/\ninterface AccountRecoveryProps {\n token: string;\n}\n\nconst AccountRecovery: React.FC = (\n props: AccountRecoveryProps\n) => {\n const { token } = props;\n const emailRef = React.useRef(null);\n\n // React states\n const [isEmailFocused, setIsEmailFocused] = React.useState(false);\n /** manages loading while processing account recovery request */\n const [loading, setLoading] = React.useState(false);\n /** error message to show if occurs */\n const [errorMessage, setErrorMessage] = React.useState('');\n /** success message to show if occurs */\n const [successMessage, setSuccessMessage] = React.useState('');\n\n /** cycles */\n\n React.useEffect(() => {\n emailRef.current?.focus();\n }, []);\n\n /** handlers */\n\n /**\n * onFinish is called when form validation passes\n * @param {any} values - containing the key-value user response\n */\n const onFinish = async (values: any) => {\n try {\n setLoading(true);\n const response = await axioService(\n POST,\n SERVER_FORGOT_PASSWORD_ENDPOINT,\n {\n email: values.username,\n },\n false\n );\n setSuccessMessage(response.data.message || 'Email sent!!!');\n setLoading(false);\n } catch (exception) {\n /** console error the exception */\n console.error(exception);\n setLoading(false);\n if (\n exception.response &&\n exception.response.data &&\n exception.response.data.message\n ) {\n /** create the error msg from server response */\n const errorMsg = (\n
\n {exception.response.data.message}
\n
    \n {exception.response.data.errors &&\n Object.keys(exception.response.data.errors).map(\n (iterErrorField) => (\n
  • \n {iterErrorField}{' '}\n : {exception.response.data.errors[iterErrorField]}\n
  • \n )\n )}\n
\n
\n );\n setErrorMessage(errorMsg);\n } else {\n setErrorMessage(\n
\n {'There is a network error or connectivity issue!!! '}\n
\n {'Please try again after some time.'}\n
\n );\n }\n }\n };\n\n /**\n * onFinishFailed is called when form validation fails\n * @param {any} errorInfo - containing the respective error information\n */\n const onFinishFailed = (errorInfo: any) => {\n console.error('Failed:', errorInfo);\n };\n\n /** onAlertClose is used to close alert message */\n const onAlertClose = () => setErrorMessage('');\n\n return (\n \n {errorMessage !== '' && (\n \n )}\n
\n {token !== '' && }\n
\n
\n \n
\n {successMessage ? (\n \n ) : (\n \n \n

Forgot Password ?

\n
\n Enter your user account 's verified email address and we\n will send you a password reset link.\n
\n \n setIsEmailFocused(true)}\n onBlur={() => setIsEmailFocused(false)}\n placeholder={\n !isEmailFocused ? 'Enter your email address' : ''\n }\n prefix={\"icon\"}\n />\n \n \n Send Reset Password Email\n \n
\n

\n Back to Sign In\n

\n
\n
\n \n )}\n
\n
\n
\n );\n};\n\n/** connect the component to the store */\n\n/** Interface to describe props from mapStateToProps */\ninterface DispatchedStateProps {\n token: string;\n}\n\n/** Map props to state */\nconst mapStateToProps = (state: Partial): DispatchedStateProps => {\n const result = {\n token: getSessionToken(state),\n };\n return result;\n};\n\n/** map props to actions */\nconst mapDispatchToProps = {};\n\n/** connect AccountRecovery to the redux store */\nconst ConnectedAccountRecovery = connect(\n mapStateToProps,\n mapDispatchToProps\n)(AccountRecovery);\n\nexport default ConnectedAccountRecovery;\n","import { Alert, Button, Card, Form, Input, Spin } from 'antd';\nimport { Store } from 'antd/lib/form/interface';\nimport clsx from 'clsx';\nimport queryString from 'query-string';\nimport React from 'react';\nimport { connect } from 'react-redux';\nimport { Link, Redirect, useLocation } from 'react-router-dom';\nimport {\n LOCAL_LOGIN_ENDPOINT,\n LOCAL_PERSONAL_INFO_ENDPOINT,\n SERVER_RESET_PASSWORD_ENDPOINT,\n} from '../../configs/endpoints';\nimport Logo from '../../logo/Logo';\nimport { POST, axioService } from '../../services/axioService';\nimport { getSessionToken } from '../../store/ducks/session';\nimport './ResetPassword.scss';\n\n/** interface to describe Recovery props*/\ninterface ResetPasswordProps {\n token: string;\n}\n\nconst ResetPassword: React.FC = (\n props: ResetPasswordProps\n) => {\n const { token } = props;\n const location = useLocation();\n const [isPasswordFocused, setIsPasswordFocused] = React.useState(false);\n const [\n isConfirmPasswordFocused,\n setIsConfirmPasswordFocused,\n ] = React.useState(false);\n const passwordRef = React.useRef(null);\n const passwordConfirmationRef = React.useRef(null);\n const emailRef = React.useRef(null);\n\n // React states\n /** manages loading while processing account recovery request */\n const [loading, setLoading] = React.useState(false);\n /** error message to show if occurs */\n const [errorMessage, setErrorMessage] = React.useState('');\n /** success message to show if occurs */\n const [successMessage, setSuccessMessage] = React.useState('');\n /** status to manage password visibility */\n const [isPasswordVisible, setIsPasswordVisible] = React.useState(\n false\n );\n\n /** cycles */\n\n React.useEffect(() => {\n emailRef.current?.focus();\n }, []);\n\n /** handlers */\n\n /** status to manage password confirmation visibility */\n const [\n isPasswordConfirmationVisible,\n setIsPasswordConfirmationVisible,\n ] = React.useState(false);\n\n /** toggles the password input visibility */\n const handlePasswordVisibility = () => {\n setIsPasswordVisible(!isPasswordVisible);\n passwordRef.current.blur();\n };\n\n /** toggles the password confirmation input visibility */\n const handlePasswordConfirmationVisibility = () => {\n setIsPasswordConfirmationVisible(!isPasswordConfirmationVisible);\n passwordConfirmationRef.current.blur();\n };\n\n /**\n * onFinish is called when form validation passes\n * @param {any} values - containing the key-value user response\n */\n const onFinish = async (values: any) => {\n try {\n setLoading(true);\n const response = await axioService(\n POST,\n SERVER_RESET_PASSWORD_ENDPOINT,\n {\n token: queryString.parse(location.search)['token'] || '',\n email: values.username,\n password: values.password,\n password_confirmation: values.password_confirmation,\n },\n false\n );\n setLoading(false);\n window.location.href = '/login';\n } catch (exception) {\n /** console error the exception */\n console.error(exception);\n setLoading(false);\n if (\n exception.response &&\n exception.response.data &&\n exception.response.data.message\n ) {\n /** create the error msg from server response */\n const errorMsg = (\n
\n {exception.response.data.message}
\n
    \n {exception.response.data.errors &&\n Object.keys(exception.response.data.errors).map(\n (iterErrorField) => (\n
  • \n {iterErrorField}{' '}\n : {exception.response.data.errors[iterErrorField]}\n
  • \n )\n )}\n
\n
\n );\n setErrorMessage(errorMsg);\n } else {\n setErrorMessage(\n
\n {'There is a network error or connectivity issue!!! '}\n
\n {'Please try again after some time.'}\n
\n );\n }\n }\n };\n\n /**\n * onFinishFailed is called when form validation fails\n * @param {any} errorInfo - containing the respective error information\n */\n const onFinishFailed = (errorInfo: any) => {\n console.error('Failed:', errorInfo);\n };\n\n /** onAlertClose is used to close alert message */\n const onAlertClose = () => setErrorMessage('');\n\n return (\n \n {errorMessage !== '' && (\n \n )}\n {successMessage !== '' && (\n \n )}\n
\n {token !== '' && }\n
\n
\n \n
\n \n \n

Reset Password

\n
\n Enter your user account's verified email address and a new\n password for your account.\n
\n \n }\n />\n \n\n \n setIsPasswordFocused(true)}\n onBlur={() => setIsPasswordFocused(false)}\n placeholder={!isPasswordFocused ? 'New Password' : ''}\n prefix={\"icon\"}\n type={isPasswordVisible ? 'text' : 'password'}\n ref={passwordRef}\n suffix={\n isPasswordVisible ? (\n \n ) : (\n \n )\n }\n />\n \n ({\n validator(rule, value) {\n if (!value || getFieldValue('password') === value) {\n return Promise.resolve();\n }\n return Promise.reject(\n 'The two passwords that you entered do not match!'\n );\n },\n }),\n ]}\n >\n setIsConfirmPasswordFocused(true)}\n onBlur={() => setIsConfirmPasswordFocused(false)}\n placeholder={\n !isConfirmPasswordFocused ? 'Confirm Password' : ''\n }\n prefix={\"icon\"}\n type={isPasswordConfirmationVisible ? 'text' : 'password'}\n ref={passwordConfirmationRef}\n suffix={\n isPasswordConfirmationVisible ? (\n \n ) : (\n \n )\n }\n />\n \n \n Reset Password\n \n
\n

\n Back to Sign In\n

\n
\n
\n \n
\n
\n
\n );\n};\n\n/** connect the component to the store */\n\n/** Interface to describe props from mapStateToProps */\ninterface DispatchedStateProps {\n token: string;\n}\n\n/** Map props to state */\nconst mapStateToProps = (state: Partial): DispatchedStateProps => {\n const result = {\n token: getSessionToken(state),\n };\n return result;\n};\n\n/** map props to actions */\nconst mapDispatchToProps = {};\n\n/** connect ResetPassword to the redux store */\nconst ConnectedResetPassword = connect(\n mapStateToProps,\n mapDispatchToProps\n)(ResetPassword);\n\nexport default ConnectedResetPassword;\n","import queryString from 'query-string';\nimport React from 'react';\nimport { connect } from 'react-redux';\nimport { useLocation } from 'react-router-dom';\nimport { Store } from 'redux';\nimport { getSessionToken, setSessionToken } from '../../store/ducks/session';\nimport './SessionAuthorize.scss';\n\n/** interface to describe SessionAuthorize props*/\ninterface SessionAuthorizeProps {\n token: string;\n setSessionTokenActionCreator: typeof setSessionToken;\n}\n\nconst SessionAuthorize = (props: SessionAuthorizeProps) => {\n const { setSessionTokenActionCreator } = props;\n const location = useLocation();\n /** destroys the session token */\n React.useEffect(() => {\n const token = (queryString.parse(location.search)['token'] as string) || '';\n setSessionTokenActionCreator(token);\n }, []);\n\n return
Authorizing...
;\n};\n\n/** connect the component to the store */\n/** Interface to describe props from mapStateToProps */\ninterface DispatchedStateProps {\n token: string;\n}\n\n/** Map props to state */\nconst mapStateToProps = (state: Partial): DispatchedStateProps => {\n const result = {\n token: getSessionToken(state),\n };\n return result;\n};\n\n/** map props to actions */\nconst mapDispatchToProps = {\n setSessionTokenActionCreator: setSessionToken,\n};\n\n/** connect SessionAuthorize to the redux store */\nconst ConnectedSessionAuthorize = connect(\n mapStateToProps,\n mapDispatchToProps\n)(SessionAuthorize);\n\nexport default ConnectedSessionAuthorize;\n","import React from 'react';\nimport { connect } from 'react-redux';\nimport { useHistory, useLocation, useParams } from 'react-router-dom';\nimport { Store } from 'redux';\nimport { SERVER_EMAIL_VERIFY_ENDPOINT } from '../../configs/endpoints';\nimport {\n FlexObj,\n getSessionUserInfo,\n setSessionUserInfo,\n} from '../../store/ducks/session';\nimport './VerifyEmail.scss';\nimport queryString from 'query-string';\nimport { Spin } from 'antd';\nimport { axioService, GET } from '../../services/axioService';\n\n/** interface to describe VerifyEmail props*/\ninterface VerifyEmailProps {\n userInfo: FlexObj;\n setUserInfoActionCreator: typeof setSessionUserInfo;\n}\n\nconst VerifyEmail = (props: VerifyEmailProps) => {\n const { userInfo, setUserInfoActionCreator } = props;\n const location = useLocation();\n const history = useHistory();\n const { id, hash } = useParams() as any;\n\n const [loading, setLoading] = React.useState(true);\n const [error, setError] = React.useState(false);\n\n /** destroys the session token */\n React.useEffect(() => {\n const runEmailVerification = async () => {\n const expires =\n (queryString.parse(location.search)['expires'] as string) || '';\n\n const signature =\n (queryString.parse(location.search)['signature'] as string) || '';\n\n try {\n await axioService(\n GET,\n `${SERVER_EMAIL_VERIFY_ENDPOINT}/${id}/${hash}`,\n { expires, signature },\n true\n );\n setLoading(false);\n\n setUserInfoActionCreator({ ...userInfo, is_email_verified: true });\n } catch (Exception) {\n console.error(Exception);\n setLoading(false);\n setError(true);\n }\n setTimeout(() => history.push('/'), 1500);\n };\n runEmailVerification();\n }, []);\n\n return (\n
\n
\n {loading ? (\n \n ) : !error ? (\n \n Email verification{' '}\n successful !\n \n ) : (\n \n Email verification{' '}\n unsuccessful !\n \n )}\n
\n
\n );\n};\n\n/** connect the component to the store */\n\n/** Interface to describe props from mapStateToProps */\ninterface DispatchedStateProps {\n userInfo: FlexObj;\n}\n\n/** Map props to state */\nconst mapStateToProps = (state: Partial): DispatchedStateProps => {\n const result = {\n userInfo: getSessionUserInfo(state),\n };\n return result;\n};\n\n/** map props to actions */\nconst mapDispatchToProps = {\n setUserInfoActionCreator: setSessionUserInfo,\n};\n\n/** connect VerifyEmail to the redux store */\nconst ConnectedVerifyEmail = connect(\n mapStateToProps,\n mapDispatchToProps\n)(VerifyEmail);\n\nexport default ConnectedVerifyEmail;\n","import React from 'react';\nimport './App.scss';\nimport Login from '../containers/login/Login';\nimport Register from '../containers/register/Register';\nimport { Switch, Route, Redirect, useHistory } from 'react-router-dom';\nimport ConnectedPrivateRoute from '../containers/privateRoute/PrivateRoute';\nimport Account from '../containers/account/Account';\nimport '@fortawesome/fontawesome-free/css/all.min.css';\nimport ConnectedSessionDestroy from '../containers/sessionDestroy/SessionDestroy';\nimport {\n APP_AUTHORIZE_ENDPOINT,\n LOCAL_AUTHORIZE_ENDPOINT,\n LOCAL_FORGOT_PASSWORD_ENDPOINT,\n LOCAL_LOGIN_ENDPOINT,\n LOCAL_LOGOUT_ENDPOINT,\n LOCAL_PERSONAL_INFO_ENDPOINT,\n LOCAL_REGISTER_ENDPOINT,\n LOCAL_RESET_PASSWORD_ENDPOINT,\n LOCAL_VERIFY_EMAIL_ENDPOINT,\n SERVER_USER_PROFILE_ENDPOINT,\n} from '../configs/endpoints';\nimport { Store } from 'redux';\nimport { getSessionToken, setSessionUserInfo } from '../store/ducks/session';\nimport { connect } from 'react-redux';\nimport { axioService, GET } from '../services/axioService';\nimport ConnectedAccountRecovery from '../containers/accountRecovery/AccountRecovery';\nimport ConnectedResetPassword from '../containers/resetPassword/ResetPassword';\nimport ConnectedSessionAuthorize from '../containers/sessionAuthorize/SessionAuthorize';\nimport ConnectedVerifyEmail from '../containers/verifyEmail/VerifyEmail';\nimport { getDomain } from '../services/cookieStorageSync';\n\ninterface AppProps {\n token: string;\n setSessionUserInfoActionCreator: typeof setSessionUserInfo;\n}\n\nconst App: React.FC = (props: AppProps) => {\n const { token, setSessionUserInfoActionCreator } = props;\n const history = useHistory();\n\n /** sets the theme colors */\n React.useEffect(() => {\n // sets the theme colors\n document.body.style.setProperty('--theme-dark', '#2777f4');\n document.body.style.setProperty('--theme-primary', '#1f89f6');\n document.body.style.setProperty('--theme-light', '#1897f8');\n document.body.style.setProperty('--theme-hover-light', '#dde4fc');\n }, []);\n\n /** fetches initial data based on login */\n React.useEffect(() => {\n const fetchProfile = async () => {\n try {\n const response = await axioService(\n GET,\n SERVER_USER_PROFILE_ENDPOINT,\n {},\n true\n );\n setSessionUserInfoActionCreator(response.data.data);\n afterGettingUser();\n } catch (exception) {\n /** console error the exception */\n console.error(exception);\n }\n };\n if (token !== '') {\n fetchProfile();\n }\n }, [token]);\n\n const afterGettingUser = () => {\n const app = window.sessionStorage.getItem('app');\n const redirectEndpoint = window.sessionStorage.getItem('redirect');\n if (app !== '') {\n if (app === 'devtipslocal') {\n window.location.href = `http://localhost:3000/authorize?token=${token}`;\n } else {\n const domain = getDomain(window.location.hostname, false);\n window.location.href =\n APP_AUTHORIZE_ENDPOINT !== ''\n ? `${APP_AUTHORIZE_ENDPOINT}?redirect=${redirectEndpoint}`\n : `https://${app}.${domain}?redirect=${redirectEndpoint}`;\n }\n } else {\n history.push(LOCAL_PERSONAL_INFO_ENDPOINT);\n }\n };\n\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n );\n};\n\n/** connect the component to the store */\n\n/** Interface to describe props from mapStateToProps */\ninterface DispatchedStateProps {\n token: string;\n}\n\n/** Map props to state */\nconst mapStateToProps = (state: Partial): DispatchedStateProps => {\n const result = {\n token: getSessionToken(state),\n };\n return result;\n};\n\n/** map props to actions */\nconst mapDispatchToProps = {\n setSessionUserInfoActionCreator: setSessionUserInfo,\n};\n\n/** connect App to the redux store */\nconst ConnectedApp = connect(mapStateToProps, mapDispatchToProps)(App);\n\n/** the default export */\nexport default ConnectedApp;\n","// This optional code is used to register a service worker.\n// register() is not called by default.\n\n// This lets the app load faster on subsequent visits in production, and gives\n// it offline capabilities. However, it also means that developers (and users)\n// will only see deployed updates on subsequent visits to a page, after all the\n// existing tabs open on the page have been closed, since previously cached\n// resources are updated in the background.\n\n// To learn more about the benefits of this model and instructions on how to\n// opt-in, read https://bit.ly/CRA-PWA\n\nconst isLocalhost = Boolean(\n window.location.hostname === 'localhost' ||\n // [::1] is the IPv6 localhost address.\n window.location.hostname === '[::1]' ||\n // 127.0.0.0/8 are considered localhost for IPv4.\n window.location.hostname.match(\n /^127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/\n )\n);\n\ntype Config = {\n onSuccess?: (registration: ServiceWorkerRegistration) => void;\n onUpdate?: (registration: ServiceWorkerRegistration) => void;\n};\n\nexport function register(config?: Config) {\n if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {\n // The URL constructor is available in all browsers that support SW.\n const publicUrl = new URL(process.env.PUBLIC_URL, window.location.href);\n if (publicUrl.origin !== window.location.origin) {\n // Our service worker won't work if PUBLIC_URL is on a different origin\n // from what our page is served on. This might happen if a CDN is used to\n // serve assets; see https://github.com/facebook/create-react-app/issues/2374\n return;\n }\n\n window.addEventListener('load', () => {\n const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;\n\n if (isLocalhost) {\n // This is running on localhost. Let's check if a service worker still exists or not.\n checkValidServiceWorker(swUrl, config);\n\n // Add some additional logging to localhost, pointing developers to the\n // service worker/PWA documentation.\n navigator.serviceWorker.ready.then(() => {\n // eslint-disable-next-line no-console\n console.log(\n 'This web app is being served cache-first by a service ' +\n 'worker. To learn more, visit https://bit.ly/CRA-PWA'\n );\n });\n } else {\n // Is not localhost. Just register service worker\n registerValidSW(swUrl, config);\n }\n });\n }\n}\n\nfunction registerValidSW(swUrl: string, config?: Config) {\n navigator.serviceWorker\n .register(swUrl)\n .then((registration) => {\n registration.onupdatefound = () => {\n const installingWorker = registration.installing;\n if (installingWorker == null) {\n return;\n }\n installingWorker.onstatechange = () => {\n if (installingWorker.state === 'installed') {\n if (navigator.serviceWorker.controller) {\n // At this point, the updated precached content has been fetched,\n // but the previous service worker will still serve the older\n // content until all client tabs are closed.\n // eslint-disable-next-line no-console\n console.log(\n 'New content is available and will be used when all ' +\n 'tabs for this page are closed. See https://bit.ly/CRA-PWA.'\n );\n\n // Execute callback\n if (config && config.onUpdate) {\n config.onUpdate(registration);\n }\n } else {\n // At this point, everything has been precached.\n // It's the perfect time to display a\n // \"Content is cached for offline use.\" message.\n // eslint-disable-next-line no-console\n console.log('Content is cached for offline use.');\n\n // Execute callback\n if (config && config.onSuccess) {\n config.onSuccess(registration);\n }\n }\n }\n };\n };\n })\n .catch((error) => {\n // eslint-disable-next-line no-console\n console.error('Error during service worker registration:', error);\n });\n}\n\nfunction checkValidServiceWorker(swUrl: string, config?: Config) {\n // Check if the service worker can be found. If it can't reload the page.\n fetch(swUrl, {\n headers: { 'Service-Worker': 'script' },\n })\n .then((response) => {\n // Ensure service worker exists, and that we really are getting a JS file.\n const contentType = response.headers.get('content-type');\n if (\n response.status === 404 ||\n (contentType != null && contentType.indexOf('javascript') === -1)\n ) {\n // No service worker found. Probably a different app. Reload the page.\n navigator.serviceWorker.ready.then((registration) => {\n registration.unregister().then(() => {\n window.location.reload();\n });\n });\n } else {\n // Service worker found. Proceed as normal.\n registerValidSW(swUrl, config);\n }\n })\n .catch(() => {\n // eslint-disable-next-line no-console\n console.log(\n 'No internet connection found. App is running in offline mode.'\n );\n });\n}\n\nexport function unregister() {\n if ('serviceWorker' in navigator) {\n navigator.serviceWorker.ready\n .then((registration) => {\n registration.unregister();\n })\n .catch((error) => {\n // eslint-disable-next-line no-console\n console.error(error.message);\n });\n }\n}\n","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport './index.scss';\nimport App from './App/App';\nimport * as serviceWorker from './serviceWorker';\nimport { BrowserRouter as Router } from 'react-router-dom';\nimport { Provider } from 'react-redux';\nimport store from './store';\nimport { HTML5Backend } from 'react-dnd-html5-backend';\nimport { DndProvider } from 'react-dnd';\n\nReactDOM.render(\n \n \n \n \n \n \n \n \n ,\n document.getElementById('root')\n);\n// If you want your app to work offline and load faster, you can change\n// unregister() to register() below. Note this comes with some pitfalls.\n// Learn more about service workers: https://bit.ly/CRA-PWA\nserviceWorker.unregister();\n"],"sourceRoot":""}