{"version":3,"sources":["components/common/helpers/roles.ts","components/common/helpers/rules.ts","components/common/helpers/status.ts","components/common/helpers/recaptcha-res.ts","components/common/helpers/messages.ts","components/common/services/http-requester.ts","components/common/services/projects-svc.ts","components/common/services/patients-svc.ts","components/common/services/utils-svc.ts","components/common/services/users-svc.ts","components/common/services/payment-svc.ts","components/common/services/data-svc.ts","components/modules/new-project/constants.ts","components/modules/new-project/actionTypes.js","components/modules/new-project/actions.ts","components/modules/new-project/model.ts","components/common/static/loading-animation/loader.tsx","components/common/static/textbox.tsx","components/common/static/numberbox.tsx","components/common/static/dropdown.tsx","components/common/static/textarea.tsx","components/common/static/toggle-btn.tsx","components/common/static/date-menu.tsx","components/modules/new-project/components/project-info/general.tsx","components/common/static/toggle-btn-nonCMS.tsx","components/modules/new-project/components/project-info/patients.tsx","components/modules/new-project/components/project-info/index.tsx","components/common/static/emailbox.tsx","components/modules/new-project/components/researcher-info/personal.tsx","components/modules/new-project/components/researcher-info/company.tsx","components/modules/new-project/components/researcher-info/index.tsx","components/common/static/multiselect.tsx","components/common/static/GDPR-toggle.tsx","components/modules/new-project/components/patient-info/additional.tsx","components/common/static/select-menu.tsx","components/common/static/async-select-menu.tsx","components/common/static/checkbox-toggle.tsx","components/modules/new-project/components/patient-info/disease.tsx","components/modules/new-project/components/patient-info/index.tsx","components/common/static/confirm-page.tsx","components/modules/new-project/components/component-root.tsx","components/modules/new-project/containers/component-root.tsx","components/modules/new-project/reducer.ts","components/modules/new-project/index.ts","components/modules/patient-profile/constants.ts","components/modules/patient-profile/actionTypes.js","components/modules/patient-profile/model.ts","components/modules/patient-profile/actions.ts","components/modules/patient-profile/components/personal-info/generic.tsx","components/modules/patient-profile/components/personal-info/specific.tsx","components/modules/patient-profile/components/personal-info/index.tsx","components/modules/patient-profile/components/experience-info/disease-exp.tsx","components/modules/patient-profile/components/experience-info/proj-exp.tsx","components/modules/patient-profile/components/experience-info/index.tsx","components/modules/patient-profile/components/preference-info/comp-req.tsx","components/modules/patient-profile/components/preference-info/proj-req.tsx","components/modules/patient-profile/components/preference-info/index.tsx","components/modules/patient-profile/components/component-root.tsx","components/modules/patient-profile/containers/component-root.tsx","components/modules/patient-profile/reducer.ts","components/modules/patient-profile/index.ts","components/modules/home/constants.ts","components/modules/home/actionType.js","components/modules/home/actions.ts","images/net_ball_half.png","images/net_ball_light.png","components/modules/home/components/testimonials.tsx","images/why-eupati/why1.png","images/why-eupati/why2.png","images/why-eupati/why4.png","images/why-eupati/why5.png","images/why-eupati/why6.png","images/why-eupati/why9.png","components/api-authorization/ApiAuthorizationConstants.js","components/api-authorization/AuthorizeService.js","components/common/static/auth-context.tsx","components/modules/home/components/component-root.tsx","images/researcher.png","images/patient.png","images/why-eupati/why3.png","images/why-eupati/why7.png","images/why-eupati/why8.png","images/net_ball_partial.png","images/patient-engagement-tools/engagement_separator.png","images/patient-engagement-tools/roadmap.png","images/patient-engagement-tools/guidances.png","images/faq/faq_separator.png","images/faq/how_does_work.png","components/modules/home/containers/component-root.tsx","components/modules/home/reducer.ts","components/modules/home/index.ts","components/modules/admin/all-projects/constants.ts","components/modules/admin/all-projects/actionTypes.js","components/modules/admin/all-projects/model.ts","components/modules/admin/all-projects/actions.ts","components/common/static/arrows-menu.tsx","components/common/static/patient-details.tsx","components/common/static/popup-modal.tsx","components/common/static/react-table-checkbox.tsx","components/common/static/matched-patients-grid.tsx","components/common/static/manual-search/index.tsx","components/common/static/project-details.tsx","components/common/static/global-filter.tsx","components/common/static/projects-grid.tsx","components/modules/admin/all-projects/components/component-root.tsx","components/modules/admin/all-projects/containers/component-root.tsx","components/common/static/csv-import/csv-mapping-helper.ts","components/modules/admin/all-projects/reducer.ts","components/modules/admin/all-projects/index.ts","components/modules/admin/import-patients/constants.ts","components/modules/admin/import-patients/actionTypes.js","components/modules/admin/import-patients/actions.ts","components/common/static/csv-import/csv-mapping.tsx","components/modules/admin/import-patients/model.ts","components/common/static/import-preview-grid.tsx","components/modules/admin/import-patients/components/component-root.tsx","components/modules/admin/import-patients/containers/component-root.tsx","components/modules/admin/import-patients/reducer.ts","components/modules/admin/import-patients/index.ts","components/modules/admin/all-patients/constants.ts","components/modules/admin/all-patients/actionTypes.js","components/modules/admin/all-patients/actions.ts","components/common/static/confirm-deny-modal.tsx","components/common/static/patients-grid.tsx","components/modules/admin/all-patients/components/component-root.tsx","components/modules/admin/all-patients/containers/component-root.tsx","components/modules/admin/all-patients/reducer.ts","components/modules/admin/all-patients/index.ts","components/modules/admin/admins-ls/constants.ts","components/modules/admin/admins-ls/actionTypes.js","components/modules/admin/admins-ls/actions.ts","components/common/static/admins-grid.tsx","components/modules/admin/admins-ls/components/component-root.tsx","components/modules/admin/admins-ls/containers/component-root.tsx","components/modules/admin/admins-ls/reducer.ts","components/modules/admin/admins-ls/index.ts","components/modules/admin/content-editor/constants.ts","components/modules/admin/content-editor/actionTypes.js","components/modules/admin/content-editor/actions.ts","components/common/static/tinymce-editor.tsx","components/modules/admin/content-editor/components/component-root.tsx","components/modules/admin/content-editor/containers/component-root.tsx","components/modules/admin/content-editor/reducer.ts","components/modules/admin/content-editor/models.ts","components/modules/admin/content-editor/index.ts","components/modules/admin/price-catalog/constants.ts","components/modules/admin/price-catalog/actionTypes.js","components/modules/admin/price-catalog/actions.ts","components/common/helpers/pricing-list.ts","components/common/static/prices-grid.tsx","components/modules/admin/price-catalog/components/component-root.tsx","components/modules/admin/price-catalog/containers/component-root.tsx","components/modules/admin/price-catalog/reducer.ts","components/modules/admin/price-catalog/index.ts","components/modules/pricing/constants.ts","components/modules/pricing/actionType.js","components/modules/pricing/actions.ts","images/pricing/asterics.png","components/modules/pricing/components/basic-plan.tsx","components/modules/pricing/components/tailor-made-plan.tsx","components/modules/pricing/components/custom-plan.tsx","components/modules/pricing/components/component-root.tsx","components/modules/pricing/containers/component-root.tsx","components/modules/pricing/reducer.ts","components/modules/pricing/index.ts","components/modules/admin/content-management/constants.ts","components/modules/admin/content-management/actionTypes.js","components/modules/admin/content-management/actions.ts","components/modules/admin/content-management/components/content.tsx","components/modules/admin/content-management/components/component-root.tsx","components/modules/admin/content-management/containers/component-root.tsx","components/modules/admin/content-management/reducer.ts","components/modules/admin/content-management/model.ts","components/modules/admin/content-management/index.ts","components/modules/admin/email-templates/constants.ts","components/modules/admin/email-templates/actionTypes.js","components/modules/admin/email-templates/models.ts","components/modules/admin/email-templates/actions.ts","components/common/static/template-editor.tsx","components/common/static/actions-template-menu.tsx","components/modules/admin/email-templates/components/component-root.tsx","components/modules/admin/email-templates/containers/component-root.tsx","components/modules/admin/email-templates/reducer.ts","components/modules/admin/email-templates/index.ts","components/modules/confirm/constants.ts","components/modules/confirm/actionTypes.js","components/modules/confirm/actions.ts","components/modules/confirm/components/component-root.tsx","components/modules/confirm/containers/component-root.tsx","components/modules/confirm/reducer.ts","components/modules/confirm/index.ts","components/modules/payment/constants.ts","components/modules/payment/actionType.js","components/modules/payment/actions.ts","components/common/static/checkout-outcome.tsx","components/common/static/stripe-card.tsx","components/modules/payment/components/component-root.tsx","components/modules/payment/containers/component-root.tsx","components/modules/payment/reducer.ts","components/modules/payment/index.ts","store/index.ts","components/common/static/routes/admin-routes.js","components/common/static/routes/protected-route.js","images/logo.jpg","components/api-authorization/Login.js","components/api-authorization/LoginMenu.js","components/common/static/navbar.tsx","components/common/static/footer.tsx","components/common/static/Layout.tsx","components/api-authorization/Logout.js","components/api-authorization/ApiAuthorizationRoutes.js","App.tsx","registerServiceWorker.ts","index.tsx","store/configureStore.ts"],"names":["roles","requiredMessage","required","selectOptionMessage","notRequired","projectStatus","patientStatus","response","FAIL_AUTH_MSG","ADMIN_ACCESS_DENIED_MSG","SUCC_UPDATED_CATALOGS","INVALID_PRICING_DATA","INVALID_PAYMENT_METHOD","EMAILS_COPIED_MSG","SELECTED_ALL_MSG","REMOVE_ADMIN_SUCC_MSG","APPROVE_ADMIN_SUCC_MSG","REMOVE_PT_SUCC_MSG","ADD_PT_TO_PROJ_MSG","CONFIRM_PATIENT_MSG","DEL_PT_FROM_PROJ_MSG","ARCHIVE_PROJ_SUCC_MSG","SAVED_NEW_PRICES_MSG","SEND_EMAILS_SUCC_MSG","INVALID_NUMERIC_INPUT","CANCEL_PRICES_UPDATE","EMAIL_TEMPLATE_CREATED","EMAIL_TEMPLATE_UPDATED","FILL_ALL_FIELD_ERR_MSG","ANSWER_SUBMIT_SUCC","SUCC_ASSIGN_ACTIONS_TO_TEMPLATE","axios","require","HttpRequester","rootUrl","url","this","error","console","JSON","stringify","msg","message","data","status","path","that","Promise","resolve","reject","fullPath","get","then","result","handleError","content","post","headers","baseUrl","ProjectsSvc","httpRequester","httpGet","project","httpPost","id","inputModel","PatientSvc","patient","patientData","patientsData","UtilsSvc","condition","uid","tokenObj","name","contentData","UsersSvc","admin","PaymentSvc","DataSvc","projectsSvc","patientSvc","utilsSvc","usersSvc","paymentSvc","NAME","SET_PROJECTS_LOADING","SET_PROJECT","SET_LOOKUP_DATA","SET_IS_USER_REAL","setProjectLoading","isLoading","type","t","payload","setProject","setLookUpData","setIsUserReal","isUserReal","getLookUpDataAsync","dispatch","getState","getLookUpData","saveNewProjectAsync","newProject","saveNewProject","verifyUserTokenAsync","token","verifyUserByRecaptchaToken","recaptchaToken","Res","emptyProject","overview","projectTypeId","projectActivityId","projectNumberOfPatientsNeeded","interactionTypeId","roleAndExpectations","startDate","undefined","endDate","timeRequired","isCompensationProvided","compensation","isThereTravelReimbursement","equipmentRequirements","responseDeadline","diseases","noDiseaseExpertiseRequired","searchDiseaseTherapeuticArea","price","plan","package","paymentMethod","patientExpertises","patientExpertisesDescription","countries","languages","otherInformation","pocFirstName","projectTypeDescription","pocLastName","pocOrganisation","pocOrganisationTypeId","pocOrganisationTypeDescription","pocJobTitle","pocCountryId","pocPhoneNumber","pocEmail","isGDPRConsentGiven","matchedPatients","confirmedPatients","EupatiLoader","className","props","text","React","EupatiTextbox","Form","Group","Control","fieldType","value","placeholder","onChange","e","errorMsg","EupatiNumberbox","EupatiDropdown","state","vals","compare","bind","values","fieldName","toLowerCase","includes","setState","sort","a","b","optionsComponent","dropdownComponent","length","map","x","i","key","defaultOptionText","disabled","as","style","width","EupatiTextarea","element","height","current","scrollHeight","rows","rowsCount","placeholderMsg","isDisabled","ref","EupatiToggleBtn","returnProperIconType","icon","valuesComponent","btnComponent","ToggleButton","faDotCircle","clear","display","overflow","whiteSpace","trim","ToggleButtonGroup","EupatiDateMenu","toString","ProjectGeneralInfo","history","useHistory","useForm","handleSubmit","control","watch","errors","reset","formState","fieldsData","adjustFieldsValues","onSubmit","toast","Messages","push","updatedProject","Object","assign","showPatientsInfoSection","Label","defaultValue","returnProperDefaultValue","rules","Rules","render","field","returnProperLookUpData","projectId","projectTypes","find","toggleField","Button","variant","onClick","prevPage","EupatiNonCMSToggleBtn","isMoreThanTwoOptions","pop","ProjectPatientsInfo","nextPage","val","fieldToggle","hidePatientsInfoSection","ProjectInfo","useState","showSecondSubComponent","nextBtnClicked","setNextBtnClicked","toggleSectionVisibility","margin","EupatiEmailbox","PersonalInfo","showCompanyInfoSection","visibility","CompanyInfo","faInfoCircle","findLookUpData","orgTypeId","organisationTypes","hideCompanyInfoSection","ResearcherInfo","ALL_ELEMENTS_OPTION","EupatiMultiselect","handleOnChange","ids","forEach","multiSelectComponent","border","faCheckSquare","EupatiGDPRBtn","gdprComponent","href","target","PatientsAdditionalInfo","submitProject","ptExpertises","otherType","ot","some","hidePatientsAdditionalInfoSection","EupatiSelect","mapOptionsToValues","options","item","option","label","langCompare","mapArrayToValues","arr","newElement","returnComponentStyles","continentsBoldStyles","multiValueLabel","base","backgroundColor","color","padding","paddingLeft","multiValueRemove","cursor","dropdownIndicator","indicatorsContainer","fontWeight","menu","position","menuList","regularStyles","event","isMulti","styles","EupatiDiseaseAsyncSelect","mapDiseaseOptionsToValues","treeNumbers","loadAutocompleteOptions","inputValue","applyFiltersTimeoutId","clearTimeout","setTimeout","getMeshRecommendations","diseaseOptions","m","join","originalTerm","loadOptions","EupatiCheckbox","checked","CUSTOM_SPAN_STYLES","PatientsDiseaseInfo","showPatientsAdditionalInfoSection","multiline","isAutocomplete","flexDirection","fontSize","noDiseaseExpertise","PatientInfo","EupatiConfirmPage","marginTop","to","ComponentRoot","showComponentByIndex","nextPageHandler","previousPageHandler","historyState","location","window","initialProjectData","submitNewProject","prevState","lookUpDataType","lookUpData","filter","dataType","mainComponent","loadingComponent","spanStyles","borderRadius","action","onVerify","connect","globalState","Constants","Actions","RootComponent","initialState","setProjectsLoading","actions","components","Components","containers","Containers","constants","reducer","Root","SET_PATIENTS_LOADING","SET_PATIENT_INFO","SET_PATIENT_DATA_LOADING","defaultPatientInfo","firstName","lastName","phoneNumber","email","birthYear","genderTypeId","countryId","countriesWithExperience","isPOAffiliated","patientOrganisation","patientExperienceId","projectTypeExperiences","projectTypeExperiencesDescription","patientExpertiseDescription","genderTypeDescription","organisationPreferenceDescription","projectPreferenceDescription","isEligibleForCompensation","isAvailableForNoCompensation","projectPreferences","organisationPreferences","activityPreferenceId","matchedProjects","confirmedProjects","isBannedFromSearch","setPatientLoading","setPatientInfo","setPatientDataLoading","isPatientDataLoaded","updatePatientAsync","updatePatient","getRidOfIncorrectNullValues","saveNewPatientAsync","savePatient","getPatientInfoByIdAsync","patientId","getPatientById","getPatientInfoByUserIdAsync","userId","getPatientByUserId","object","updatedPatientObject","PatientGenericInfo","editedPatientInfo","showPatientSpecificInfoSection","PatientSpecificInfo","otherGenderType","gt","fieldGenderTypeToggle","fieldIsPOAffiliatedToggle","hidePatientSpecificInfoSection","PatientGeneralInfo","PatientsDiseaseExpInfo","hidePatientsDiseaseExpInfo","PatientsProjectExpInfo","showPatientsDiseaseExpInfo","togglePtExpertiseField","projTypeExp","toggleProjTypeExpField","PatientExpcInfo","PatientProjectReqInfo","orderLookUpOptionsByNameLength","showPatientCompensationReqInfo","projPrefs","toggleProjPrefField","orgTypes","toggleOrgPrefField","PatientCompensationReqInfo","isNewPatient","submitNewPatient","hidePatientCompensationReqInfo","RequirementsInfo","showLoadingComponent","locationState","setPatientData","isUserPatient","setUserPatientData","SET_HOME_LOADING","SET_HOME_LOGGED_IN","setHomeLoading","setHomeLoggedInStatus","isLoggedIn","setUserStatusAsync","isUserAdmin","Testimonials","carouselProps","autoPlay","interval","centerMode","centerSlidePercentage","infiniteLoop","showStatus","showThumbs","ApplicationName","QueryParameterNames","LogoutActions","LoginActions","prefix","ApplicationPaths","DefaultLoginRedirectPath","ApiAuthorizationClientConfigurationUrl","ApiAuthorizationPrefix","Login","LoginFailed","LoginCallback","Register","Profile","LogOut","LoggedOut","LogOutCallback","IdentityRegisterPath","IdentityManagePath","AuthorizeService","_callbacks","_nextSubscriptionId","_user","_isAuthenticated","_timesCalled","_popUpDisabled","getUser","user","profile","ensureUserManagerInitialized","userManager","promise","res","access_token","signinSilent","createArguments","silentUser","updateState","log","success","Error","signinPopup","popUpUser","signinRedirect","redirect","signinCallback","signoutPopup","signoutRedirect","signoutCallback","notifySubscribers","callback","subscription","subscriptionId","subscriptionIndex","index","found","splice","useReplaceToNavigate","AuthenticationResultStatus","Fail","Success","Redirect","fetch","ok","json","settings","automaticSilentRenew","includeIdTokenInSilentRenew","userStore","WebStorageStateStore","UserManager","events","addUserSignedOut","removeUser","authService","defaultState","userIdentity","AuthenticationContext","createContext","AuthenticationProvider","children","setIsUserAdmin","setUserIdentity","Provider","authenticateUser","role","toUpperCase","Roles","sub","context","setUserStatus","whyComponent","noteComponent","statsComponent","patientEngagementComponent","testimonialComponent","faqComponent","PatientBtn","withRouter","pathname","ResearcherBtn","Card","boxShadow","Img","src","Body","Title","textAlign","Text","imgWhy1","imgWhy2","imgWhy4","imgWhy5","imgWhy6","imgWhy9","imgNetBallHalf","faCheck","imgNetBallLight","contextType","isAdmin","SET_LOADING","SET_PROJECTS","SET_PROJECTS_FILTER","SET_MATCHED_PATIENTS","SET_MATCHED_PATIENTS_LOADING","SET_PROJECT_DATA","SET_PROJECT_LOADING","SET_TEMPLATES_LOADING","SET_EMAIL_TEMPLATES","SET_SINGLE_EMAIL_TEMPLATE","defaultEmailTemplate","subject","htmlContent","setLoading","setProjects","projects","setIsProjectsLoading","isProjectsLoading","setProjectsFilter","setMatchedPatients","setMatchedPatientsLoading","isMatchedPatientsLoading","setProjectData","setEmailTemplates","emailTemplates","setSingleEmailTemplate","singleEmailTemplate","setEmailTemplateLoading","emailTemplateLoading","getAllFilteredProjectsAsync","getAllProjects","projectStatusId","updateSearchPatients","searchData","projectName","searchPatients","pt","getProjectDataByIdAsync","getProjectById","removePatientFromProjectAsync","removePatientFromProject","addPatientToProjectAsync","assignPatientToProject","changePatientStatusToConfirmAsync","changePatientStatusToConfirm","changeProjectStatusAsync","statusId","changeProjectStatus","submitEmailDataAsync","sendEmail","catch","getAllEmailTemplatesAsync","getAllEmailTemplates","getEmailTemplateByNameAsync","getEmailTemplateByName","EupatiArrowsMenu","isBtnDisabled","setIsBtnDisabled","btnCursorProps","setBtnCursorProps","displayStylesProp","backBtnHandler","faArrowLeft","leftArrowText","isForwardArrowAvail","forwardBtnHandler","rightArrowText","assignPatientFromProject","EupatiPatientDetails","backBtnClicked","returnValueById","returnJoinedArrayValues","propName","projectPropId","propType","propValue","fieldProps","patientInfo","d","Table","striped","bordered","hover","escape_quotes","EmailModalPopup","isMaxSize","setIsMaxSize","singleTemplateData","setSingleTemplateData","targetedPeople","recipients","split","submitRequest","returnHtmlContent","patients","tp","handleTemplateOnChange","parseInt","selectTemplateByIndex","handleEditorChange","updatedHtmlContent","trigger","btnText","modal","close","onFocus","stopPropagation","faWindowClose","faWindowMaximize","faWindowMinimize","templates","dropdownValues","apiKey","init","menubar","convert_urls","relative_urls","remove_script_host","plugins","toolbar","content_style","onEditorChange","Check","forwardRef","indeterminate","rest","defaultRef","useRef","resolvedRef","useEffect","EupatiPatientsGrid","allTemplates","setAllTemplates","setDropdownValue","localeCompare","templatesToLookUpOptions","returnLookUpValueByTypeAndId","rightBtnHandler","rightBtnText","removePatient","deleteProjectPatient","addPatient","patientSearchData","addProjectPatient","useMemo","concat","country","expertises","pe","columns","Header","accessor","useTable","useRowSelect","hooks","isManualSearchBtnClicked","visibleColumns","cols","getToggleAllRowsSelectedProps","Cell","row","getToggleRowSelectedProps","getTableProps","getTableBodyProps","headerGroups","prepareRow","selectedFlatRows","toggleAllRowsSelected","headerGroup","getHeaderGroupProps","col","getHeaderProps","getRowProps","cells","cell","getCellProps","original","patientProfileBtnHandler","toggleComponents","leftBtnText","isConfirmed","changePatientStatus","isPatientProfileClicked","backToProjectProfile","alignItems","justifyContent","marginBottom","resetValues","selectedTemplate","EupatiManualMatch","isSubmitBtnClicked","setIsSubmitBtnClicked","setIsPatientProfileClicked","ptSearchData","setPtSearchData","loadingComp","patientsGridComp","EupatiProjectDetails","manualSearchBtnHandler","convertDate","setProjectById","date","pad","Date","getDate","getMonth","getFullYear","s","page","document","getElementById","html2canvas","canvas","imgData","toDataURL","pdf","jsPDF","addImage","open","output","backToAllProjects","textDecoration","downloadPDF","GlobalFilter","setFilter","OUTLINE_PADDING_STYLE","paddingRight","PRIMARY_PADDING_STYLE","EupatiAllProjectsGrid","isDetailsBtnClicked","setIsDetailsBtnClicked","clickedProjectId","setClickedProjectId","changeProjectStatusHandler","findIndex","unshift","projectsDetailsComp","projectStatusHandler","isProjectLoading","statuses","createdOn","org","statusText","useGlobalFilter","useSortBy","usePagination","previousPage","canNextPage","canPreviousPage","pageOptions","gotoPage","pageCount","setPageSize","setGlobalFilter","globalFilter","pageSize","pageIndex","getSortByToggleProps","isSorted","isSortedDesc","faSortAlphaDown","faSortAlphaUp","colSpan","min","preventDefault","pageNum","Number","projectsFilter","isNaN","ProjectStatus","filename","uniqid","faFileExcel","newMappedObj","SET_IS_DATA_SUBMITTED","SET_LOOK_UP_DATA","setIsDataSubmitted","isDataSubmitted","submitMatchedDataAsync","importPatients","CSVMappingComponent","mapping","selectMatchingCsvColumn","finishMapping","mapItem","objectProperty","csvColumnName","isOptionSelected","objPropsOptions","keys","csvObject","k","mappingComponent","objectProperties","p","FormGroup","ImportProperties","csvDataToJson","mappedData","j","ImportPreviewGrid","lookUpOptions","errorMessage","lookUpValue","expertise","isMappingMode","isPreviewMode","csvImportTypeHandler","readCSVData","handleReadingError","activateMapping","submitData","fileInfo","debug","err","patientExpertise","l","md","submitPatientsData","uploadCSVComponent","csvMappingComponent","previewComponent","confirmPage","cssClass","onFileLoaded","parserOptions","header","dynamicTyping","skipEmptyLines","encoding","transformHeader","replace","onError","inputId","inputName","inputStyle","csvMappingProps","previewData","slice","mappedPreviewData","FormLabel","getLookUpDate","SET_PATIENTS","SET_PATIENT_INFO_LOADING","setPatients","setIsPatientsLoading","isPatientsLoading","setPatientInfoLoading","isPatientInfoLoading","getAllPatientsAsync","getAllPatients","getPatientByIdAsync","removePatientByIdAsync","ConfirmDenyModal","toLocaleUpperCase","params","handleRemove","targetId","EupatiAllPatients","patientsDetailsComp","handleRemovePatient","removePatientById","phone","gender","patientExperience","activityPreference","pp","pte","op","c","loadComp","patientDetails","showPatientDetails","handlePatientDetails","setPatientsLoading","SET_ADMINS_LOADING","SET_ADMINS","setIsAdminsLoading","isAdminsLoading","setAdmins","admins","getAllAdminsAsync","getAllAdmins","removeAdminAsync","ownerId","getEupatiUserById","removeAdmin","approveAdminAsync","getAdminById","approveAdmin","EupatiAllAdminsGrid","contextData","useContext","handleOnRemove","Parser","setAdminsData","mainComp","removeAdminData","Component","setAdminsLoading","SET_CONTENT_LOADING","SET_CONTENT_RESPONSE","setContentLoading","isContentLoading","setContentResponse","contentResponse","getContentByNameAsync","getContent","updateContentAsync","updateContent","TinyMCEditor","editorRef","onInit","evt","editor","initialValue","setup","ui","registry","addButton","onAction","_","insertContent","pageName","rawDraftContent","SET_IS_CATALOGS_LOADING","SET_CATALOGS_DATA","setIsCatalogsLoading","isCatalogsLoading","setCatalogsData","catalogsData","getCatalogsPricesAsync","getPriceCatalogs","updateCatalogsPricesAsync","updatePriceCatalogs","CATALOG_TYPES","Basic","TailorMade","CATEGORY_NAMES","Researcher","Industry","Academia","OPTION_NAMES","CONVERTED_NAMES","EupatiPricesGrid","isEditBtnClicked","setIsEditBtnClicked","tempData","setTempData","formatNumber","num","Math","round","toFixed","convertCategoriesNames","convertOptionsNames","category","info","setCatalogsPrices","updateCatalogsPrices","catalogIndex","convertCatalogTypesNames","categoryOptionsData","categoryIndex","basePrice","updatedData","onChangeBasePriceHandler","parseFloat","additionalOptionsData","optionIndex","onChangeOptionsPriceHandler","totalPrice","SET_PRICING_LOADING","SET_PRICING_LOGGED_IN","SET_IS_USER_ADMIN","setPricingLoading","setPricingLoggedInStatus","getCatalogsPricesDataAsync","BasicPlanComponent","bgColor","selectedOption","setSelectedOption","faChevronDown","setIcon","faChevronUp","paymentIcon","setPaymentIcon","selectedPaymentMethod","setSelectedPaymentMethod","defaultPaymentMethod","setDefaultPaymentMethod","updatePaymentMethodOnClick","method","paymentMethods","pm","selectedOptionStyle","submitBtn","pricingCard","Accordion","Toggle","eventKey","returnIcon","Collapse","basicPlanCategories","categoryName","updatedState","priceChanged","paymentOptions","top","left","methodIndex","paymentsCard","submitBasic","defaultActiveKey","astericsImg","paddingTop","minHeight","DEFAULT_COLOR_SELECTED","DEFAULT_OPTIONS_MENU","TailorMadeComponent","additionals","updateAdditionalOptionsOnClick","updatedAdditionals","updatedText","removeItemFromAdditionals","addItemToAdditionals","displayCategoryNameWithOptions","optionNames","o","categoriesCard","tailorMadePlanCategories","optionsBlock","Fragment","optionName","faSquare","submitTailorMade","CustomPlanComponent","contactUsBtn","paddingBottom","lineHeight","returnCategoriesArrayByCatalogType","catalogType","priceCatalog","catalogData","tabs","Nav","Item","Link","tabContents","Tab","Pane","Container","Content","HtmlToReactParser","EupatiPrivacyPage","reactElement","parse","reactHtml","ReactDOMServer","renderToStaticMarkup","contentName","dangerouslySetInnerHTML","__html","CURRENT_PATH","substring","SET_EMAIL_TEMPLATES_LOADING","SET_EMAIL_TEMPLATE_DATA","SET_SINGLE_EMAIL_TEMPLATE_LOADING","SET_SINGLE_EMAIL_TEMPLATE_DATA","SET_PROJECT_MODEL_PROPS_NAMES","SET_PATIENT_MODEL_PROPS_NAMES","SET_TRIGGERS_MENU_OPTIONS","SET_TRIGGERS_MENU_OPTIONS_LOADING","SET_RECEIVERS_MENU_OPTIONS","SET_CHOOSEN_RECEIVERS","emptyTemplate","setIsEmailTemplatesLoading","isEmailTemplatesLoading","setEmailTemplatesData","emailTemplatesData","setIsSingleEmailTemplateLoading","isSingleEmailTemplateLoading","setSingleEmailTemplateData","emailTemplateData","setProjectModelPropsNames","projectModelPropsNames","setPatientModelPropsNames","patientModelPropsNames","setTriggersMenuOptions","emailAutomationTriggers","setTriggersMenuOptionsLoading","isTriggersMenuOptionsLoading","setReceiversMenuOptions","receiversMenuOptions","setChoosenReceivers","choosenReceivers","setAllEmailTemplatesAsync","setEmailTemplateByIdAsync","getEmailTemplate","createNewEmailTemplateAsync","addEmailTemplate","updateEmailTemplateDataAsync","alterEmailTemplateData","removeEmailTemplateDataAsync","removeEmailTemplate","setModelsPropsNamesAsync","getClassPropertiesNames","projectProps","items","patientsProps","setTriggersMenuOptionsAsync","getEmailAutomationTriggers","assignActionsToEmailTemplateAsync","assignActionsToEmailTemplate","misallocateActionsFromEmailTemplateAsync","misallocateActionsFromEmailTemplate","emailTemplateId","setReceiversMenuOptionsAsync","setEmailTriggerTemplateBeneficiariesAsync","getEmailTriggerTemplateBeneficiaries","randomstring","EmailTemplateEditor","eupatiURL","emailTemplateName","setEmailTemplateName","emailTemplateSubject","setEmailTemplateSubject","updatedEmailTemplateData","onSaveTemplateChangesHandler","onBackToAllHandler","properties","title","generate","addNestedMenuItem","getSubmenuItems","projectPropsNames","patientPropsNames","ActionsTemplateMenu","emailTemplate","eta","templateTriggers","setTemplateTriggers","assignActionsToTemplate","receivers","triggersMenuOptions","tt","EmailTemplates","isCreateTemplateClicked","setIsCreateTemplateClicked","isEditTemplateClicked","setIsEditTemplateClicked","isActionsBtnClicked","setIsActionsBtnClicked","getAllTemplates","getTriggersMenuOptions","getReceiversMenuOptions","getModelsPropsName","getSingleTemplate","onRemoveTemplateHandler","emailTemplatesComp","etd","emailTemplateEditor","singleEmailTemplateData","updateEmailTemplate","createEmailTemplate","emailTemplatesActionsComp","filteredTriggersMenuOptions","tmo","etda","setEmailTemplatesLoading","setSingleEmailTemplateLoading","changePatientStatusAsync","addSurveyAnswerAsync","addSurveyAnswer","addProjectFeedbackAsync","addFeedback","CONFRIM_PATH","REJECT_PATH","regex","DEFAULT_HTML","EmailResponsePage","html","setHtml","setText","setUID","pid","setPID","matches","setMatches","match","matchAll","sid","txt","addProjectFeedback","feedback","SET_PAYMENT_LOADING","SET_LOOKUP_DATA_LOADING","SET_PAYMENT_RESPONSE","SET_ALL_COUNTRIES_DATA","SET_ALL_COUNTRIES_LOADING","setPaymentLoading","setLookUpDataLoading","setPaymentResponse","model","setAllCountriesData","setAllCountriesLoading","getAllCountriesAsync","getAllCountries","createPaymentIntentAsync","createPaymentIntent","CheckoutResult","isFail","startLoading","swapComponents","clientSecret","StripeCard","elements","useElements","stripe","useStripe","setIsLoading","setMessage","shouldRenderSubComp","setShouldRenderSubComp","isPaymentFailed","setIsPaymentFailed","city","line1","line2","zip","cardElement","getElement","CardElement","confirmCardPayment","payment_method","card","billing_details","address","returnCountryCode","postal_code","stripeError","paymentIntent","code","shouldSwap","subComp","htmlFor","hidePostalCode","isLookUpDataLoading","isPaymentLoading","isCountriesLoading","paymentResponse","reducers","contentManagement","homePage","paymentPage","payment","patientProfile","emailResponse","allAdmins","adminsLs","allPatients","allProjects","contentEditor","pricingPage","pricing","AdminRoute","component","restOfProps","ProtectedRoute","loginHelper","fromQuery","URLSearchParams","search","startsWith","origin","returnUrl","login","getReturnUrl","processLoginCallback","redirectToProfile","redirectToRegister","signIn","navigateToReturnUrl","completeSignIn","redirectToApiAuthorizationPath","encodeURI","apiAuthorizationPath","redirectUrl","LoginMenu","isAuthenticated","userName","_subscription","subscribe","populateState","signInSilent","unsubscribe","all","profilePath","logoutPath","local","authenticatedView","registerPath","loginPath","anonymousView","NavItem","NavLink","tag","NavBar","forceUpdate","prevProps","ImgCard","Image","logo","rounded","Navbar","Brand","faHome","marginLeft","expand","collapseOnSelect","Footer","currentYear","PureComponent","Layout","Logout","isReady","authenticated","logout","processLogoutCallback","populateAuthenticationState","signOut","completeSignOut","ApiAuthorizationRoutes","loginAction","logoutAction","App","handler","closest","stopImmediatePropagation","addEventListener","removeEventListener","autoClose","transition","Slide","hideProgressBar","background","buttonStyle","buttonClasses","expires","exact","HomePage","PricingPage","NewProjectPage","ContentManagement","PatientInfoPage","AdminProjectsPage","AdminImportPatients","AdminPatientsPage","AdminLsPage","ContentEditor","PriceCatalog","isLocalhost","Boolean","hostname","registerValidSW","swUrl","navigator","serviceWorker","register","registration","onupdatefound","installingWorker","installing","onstatechange","controller","getElementsByTagName","getAttribute","createBrowserHistory","basename","store","middleware","thunk","routerMiddleware","rootReducer","combineReducers","router","connectRouter","enhancers","windowIfDefined","__REDUX_DEVTOOLS_EXTENSION__","createStore","compose","applyMiddleware","configureStore","ReactDOM","reCaptchaKey","URL","process","contentType","indexOf","ready","unregister","reload","checkValidServiceWorker","registerServiceWorker"],"mappings":"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","file":"static/js/main.4203772c.chunk.js","sourcesContent":["export const roles = ({\r\n Admin: 'EUPATIADMIN',\r\n Patient: 'EUPATIPATIENT',\r\n Member: 'EUPATIMEMBER'\r\n});","export const requiredMessage = ({\r\n required: \"This field is required\"\r\n});\r\n\r\nexport const selectOptionMessage = ({\r\n required: \"It is required to select an option\"\r\n});\r\n\r\nexport const notRequired = ({\r\n required: false\r\n});","//based on Models.Enums.Status\r\nexport const projectStatus = ({\r\n inProgressStatusID: 1,\r\n archivedStatusID: 2,\r\n pendingAcceptanceStatusID: 3,\r\n declinedStatusID: 4\r\n});\r\n\r\n//based on Models.Enums.StatusType\r\nexport const patientStatus = ({\r\n matchedStatusID: 1,\r\n confirmedStatusID: 2,\r\n notInterestedStatusID: 3\r\n});","export const response = ({\r\n success: 'Server-side Google reCaptcha validation successfull',\r\n failure: 'invalid-input-response'\r\n});","export const FAIL_AUTH_MSG = 'We cannot validate, that you are not a robot. Please, refresh the page and try again.';\r\n\r\nexport const ADMIN_ACCESS_DENIED_MSG = 'You are not a patient.';\r\n\r\nexport const SUCC_UPDATED_CATALOGS = 'You have successfully updated the catalogues prices.';\r\n\r\nexport const INVALID_PRICING_DATA = 'You have to select Pricing option, even if a free service applies to you.';\r\n\r\nexport const INVALID_PAYMENT_METHOD = 'You have to select Payment option, even if a free service applies to you.';\r\n\r\nexport const EMAILS_COPIED_MSG = 'Emails were copied to the clipboard.';\r\n\r\nexport const SELECTED_ALL_MSG = 'You have successfully selected all emails.'\r\n\r\nexport const REMOVE_ADMIN_SUCC_MSG = 'You have successfully removed the admin.';\r\n\r\nexport const APPROVE_ADMIN_SUCC_MSG = 'You have successfully approved the admin.'\r\n\r\nexport const REMOVE_PT_SUCC_MSG = 'You have successfully removed the patient.';\r\n\r\nexport const ADD_PT_TO_PROJ_MSG = 'You have successfully assigned patient to project.';\r\n\r\nexport const CONFIRM_PATIENT_MSG = 'You have successfully changed patient status to confirmed.';\r\n\r\nexport const DEL_PT_FROM_PROJ_MSG = 'You have successfully removed patient from project.';\r\n\r\nexport const ARCHIVE_PROJ_SUCC_MSG = 'You have changed the status of the project.';\r\n\r\nexport const SAVED_NEW_PRICES_MSG = 'You have successfully updated the prices.';\r\n\r\nexport const SEND_EMAILS_SUCC_MSG = 'You have successfully sent an email.';\r\n\r\nexport const INVALID_NUMERIC_INPUT = 'Price field expect a numeric value.';\r\n\r\nexport const CANCEL_PRICES_UPDATE = 'You have cancelled the prices update.';\r\n\r\nexport const EMAIL_TEMPLATE_CREATED = 'You have successfully created a new template.';\r\n\r\nexport const EMAIL_TEMPLATE_UPDATED = 'You have successfully updated the template.';\r\n\r\nexport const FILL_ALL_FIELD_ERR_MSG = 'Please fill in all the fields.';\r\n\r\nexport const ANSWER_SUBMIT_SUCC = 'You have successfully submitted your application.';\r\n\r\nexport const SUCC_ASSIGN_ACTIONS_TO_TEMPLATE = 'You have successfully assigned actions to email template.'","// request docs here: https://www.npmjs.com/package/request-promise\r\n//import * as request from \"request-promise-native\";\r\nconst axios = require('axios');\r\n\r\nexport default class HttpRequester {\r\n\turl: string;\r\n\r\n\tconstructor(rootUrl = '/') {\r\n\t\tthis.url = rootUrl;\r\n\t}\r\n\r\n\thandleError(error: any) {\r\n\t\tconsole.error(JSON.stringify(error)); //this does not output the complete error?!?!?\r\n\t\tlet msg = error.message;\t\t\r\n\t\r\n\t\t//see if the back end dev has put in some nice description\r\n\t\tif (typeof (error.response) != 'undefined' && typeof (error.response.data) != 'undefined') {\t\t\t\r\n\t\t\tmsg = error.response.data;\r\n\t\t}\r\n\t\t\r\n\t\tif (error.status === 403 && msg === '') {\r\n\t\t\tmsg = \"You don't have sufficient rights to perform this action. Contact us through the live chat.\";\r\n\t\t}\r\n\r\n\t\treturn msg;\r\n\t}\r\n\r\n\thttpGet(path: string) {\r\n\t\tvar that = this;\r\n\t\tvar promise = new Promise(function(resolve, reject) {\r\n\t\t\tlet fullPath = that.url + path;\r\n\r\n\t\t\taxios.get(fullPath).then(\r\n\t\t\t\tfunction(result: any) {\r\n\t\t\t\t\tresolve(result.data);\r\n\t\t\t\t},\r\n\t\t\t\tfunction(error: any) {\r\n\t\t\t\t\tlet msg = that.handleError(error);\r\n\t\t\t\t\treject(msg);\r\n\t\t\t\t}\r\n\t\t\t);\r\n\t\t});\r\n\r\n\t\treturn promise;\r\n\t}\r\n\r\n\thttpPost(path: string, content: any) {\r\n\t\tvar that = this;\r\n\t\t\r\n\t\tvar promise = new Promise(function (resolve, reject) {\r\n\t\t\tlet fullPath = that.url + path;\r\n\t\t\t\r\n\t\t\taxios.post(fullPath, content, { headers: { 'Content-Type': 'application/json' } }).then(\r\n\t\t\t\tfunction (result: any) {\r\n\t\t\t\t\tresolve(result.data);\r\n\t\t\t\t},\r\n\t\t\t\tfunction (error: any) {\r\n\t\t\t\t\tlet msg = that.handleError(error);\r\n\t\t\t\t\treject(msg);\r\n\t\t\t\t}\r\n\t\t\t);\r\n\t\t});\r\n\r\n\t\treturn promise;\r\n\t}\r\n}\r\n","import { ProjectFeedbackData, ProjectPatientData, ProjectStatusData } from '../models/input-models';\r\nimport { Project } from '../models/main-models';\r\nimport HttpRequester from './http-requester';\r\n\r\n//declare var baseUrl: string;\r\nvar baseUrl = \"/projects\";\r\n\r\nexport default class ProjectsSvc {\r\n\thttpRequester: HttpRequester;\r\n\r\n\tconstructor() {\r\n\t\tthis.httpRequester = new HttpRequester('/api');\r\n\t}\r\n\r\n\tgetAllProjects() {\r\n\t\treturn this.httpRequester.httpGet(\r\n\t\t\t`${baseUrl}/all`\r\n\t\t);\r\n\t}\r\n\r\n\tsaveNewProject(project: Project) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/savenewproject`,\r\n\t\t\tproject\r\n\t\t);\r\n\t}\r\n\r\n\tgetProjectById(id: string) {\r\n\t\treturn this.httpRequester.httpGet(\r\n\t\t\t`${baseUrl}/getproject?id=${id}`\r\n\t\t);\r\n\t}\r\n\r\n\tchangeProjectStatus(inputModel: ProjectStatusData) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/changestatus`,\r\n\t\t\tinputModel\r\n\t\t);\r\n\t}\r\n\r\n\tassignPatientToProject(inputModel: ProjectPatientData) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/assignpatient`,\r\n\t\t\tinputModel\r\n\t\t);\r\n\t}\r\n\r\n\tremovePatientFromProject(inputModel: ProjectPatientData) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/removepatient`,\r\n\t\t\tinputModel\r\n\t\t);\r\n\t}\r\n\r\n\tchangePatientStatusToConfirm(inputModel: ProjectPatientData) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/confirmpatient`,\r\n\t\t\tinputModel\r\n\t\t)\r\n\t}\r\n\r\n\taddFeedback(inputModel: ProjectFeedbackData) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/addfeedback`,\r\n\t\t\tinputModel\r\n\t\t)\r\n\t}\r\n}\r\n","import { ChangePatientStatusData, PatientSearchData, PatientsImportData, SurveyAnswerData } from '../models/input-models';\r\nimport { Patient } from '../models/main-models';\r\nimport HttpRequester from './http-requester';\r\n\r\n//declare var baseUrl: string;\r\nvar baseUrl = '/patients';\r\n\r\nexport default class PatientSvc {\r\n\thttpRequester: HttpRequester;\r\n\r\n\tconstructor() {\r\n\t\tthis.httpRequester = new HttpRequester('/api');\r\n\t}\r\n\r\n\tsavePatient(patient: Patient) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/savepatient`,\r\n\t\t\tpatient\r\n\t\t);\r\n\t}\r\n\r\n\tgetPatientByUserId(id: string) {\r\n\t\treturn this.httpRequester.httpGet(\r\n\t\t\t`${baseUrl}/getpatientbyuserid?userId=${id}`\r\n\t\t);\r\n\t}\r\n\r\n\tgetPatientById(id: string) {\r\n\t\treturn this.httpRequester.httpGet(\r\n\t\t\t`${baseUrl}/getpatientbyid?patientId=${id}`\r\n\t\t)\r\n\t}\r\n\r\n\tsearchPatients(patientData?: PatientSearchData) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/searchpatients`,\r\n\t\t\tpatientData\r\n\t\t);\r\n\t}\r\n\r\n\timportPatients(patientsData: PatientsImportData) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/importpatients`,\r\n\t\t\tpatientsData\r\n\t\t)\r\n\t}\r\n\r\n\tgetAllPatients() {\r\n\t\treturn this.httpRequester.httpGet(\r\n\t\t\t`${baseUrl}/all`\r\n\t\t)\r\n\t}\r\n\r\n\tupdatePatient(patient: Patient) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/updatepatient`,\r\n\t\t\tpatient\r\n\t\t)\r\n\t}\r\n\r\n\tremovePatient(patient: Patient) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/removepatient`,\r\n\t\t\tpatient\r\n\t\t)\r\n\t}\r\n\r\n\tchangePatientStatus(data: ChangePatientStatusData) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/changepatientstatus`,\r\n\t\t\tdata\r\n\t\t)\r\n\t}\r\n\r\n\taddSurveyAnswer(data: SurveyAnswerData) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/addsurveyanswer`,\r\n\t\t\tdata\r\n\t\t)\r\n\t}\r\n}","import { AdminVerifyModel, ActionsTemplateData, CatalogData, ChangePatientStatusData, ContentData, EmailTemplateData, RequestData, SurveyAnswerData } from '../models/input-models';\r\nimport HttpRequester from './http-requester';\r\n\r\n//declare var baseUrl: string;\r\nvar baseUrl = '/utils';\r\n\r\nexport default class UtilsSvc {\r\n\thttpRequester: HttpRequester;\r\n\r\n\tconstructor() {\r\n\t\tthis.httpRequester = new HttpRequester('/api');\r\n\t}\r\n\r\n\tgetLookUpData() {\r\n\t\treturn this.httpRequester.httpGet(\r\n\t\t\t`${baseUrl}/getlookupdata`\r\n\t\t);\r\n\t}\r\n\r\n\tgetMeshRecommendations(condition: string) {\r\n\t\treturn this.httpRequester.httpGet(\r\n\t\t\t`${baseUrl}/getmeshrecommendations?condition=${condition}`\r\n\t\t)\r\n\t}\r\n\r\n\tgetMeshRecordParents(uid: string) {\r\n\t\treturn this.httpRequester.httpGet(\r\n\t\t\t`${baseUrl}/getmeshrecordparents?uid=${uid}`\r\n\t\t)\r\n\t}\r\n\r\n\tverifyUserByRecaptchaToken(tokenObj: any) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/verifyuserbyrecaptchatoken`,\r\n\t\t\ttokenObj\r\n\t\t)\r\n\t}\r\n\r\n\tgetContent(name: string) {\r\n\t\treturn this.httpRequester.httpGet(\r\n\t\t\t`${baseUrl}/getcontent?name=${name}`\r\n\t\t)\r\n\t}\r\n\r\n\tupdateContent(contentData: ContentData) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/updatecontent`,\r\n\t\t\tcontentData\r\n\t\t)\r\n\t}\r\n\r\n\tgetPriceCatalogs() {\r\n\t\treturn this.httpRequester.httpGet(\r\n\t\t\t`${baseUrl}/getpricecatalogs`\r\n\t\t)\r\n\t}\r\n\r\n\tupdatePriceCatalogs(data: CatalogData[]) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/updatepricecatalogs`,\r\n\t\t\tdata\r\n\t\t)\r\n\t}\r\n\r\n\tsendEmail(data: RequestData) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/sendemail`,\r\n\t\t\tdata\r\n\t\t)\r\n\t}\r\n\r\n\tgetAllEmailTemplates() {\r\n\t\treturn this.httpRequester.httpGet(\r\n\t\t\t`${baseUrl}/getallemailtemplates`\r\n\t\t)\r\n\t}\r\n\r\n\tgetEmailTemplateByName(name: string) {\r\n\t\treturn this.httpRequester.httpGet(\r\n\t\t\t`${baseUrl}/getemailtemplatebyname?name=${name}`\r\n\t\t)\r\n\t}\r\n\r\n\tgetEmailTemplate(id: string) {\r\n\t\treturn this.httpRequester.httpGet(\r\n\t\t\t`${baseUrl}/getemailtemplate?id=${id}`\r\n\t\t)\r\n\t}\r\n\r\n\taddEmailTemplate(data: EmailTemplateData) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/addemailtemplate`,\r\n\t\t\tdata\r\n\t\t)\r\n\t}\r\n\r\n\talterEmailTemplateData(data: EmailTemplateData) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/alteremailtemplatedata`,\r\n\t\t\tdata\r\n\t\t)\r\n\t}\r\n\r\n\tremoveEmailTemplate(data: EmailTemplateData) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/removeemailtemplate`,\r\n\t\t\tdata\r\n\t\t)\r\n\t}\r\n\r\n\tgetClassPropertiesNames(id: AdminVerifyModel) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/getclasspropertiesnames`,\r\n\t\t\tid\r\n\t\t)\r\n\t}\r\n\r\n\tgetEmailAutomationTriggers() {\r\n\t\treturn this.httpRequester.httpGet(\r\n\t\t\t`${baseUrl}/getemailautomationtriggers`\r\n\t\t)\r\n\t}\r\n\r\n\tassignActionsToEmailTemplate(data: ActionsTemplateData) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/assignactionstoemailtemplate`,\r\n\t\t\tdata\r\n\t\t)\r\n\t}\r\n\r\n\tmisallocateActionsFromEmailTemplate(data: ActionsTemplateData) {\r\n\t\treturn this.httpRequester.httpPost(\r\n\t\t\t`${baseUrl}/misallocateactionsfromemailtemplate`,\r\n\t\t\tdata\r\n\t\t)\r\n\t}\r\n\r\n\tgetEmailTriggerTemplateBeneficiaries(id: string) {\r\n\t\treturn this.httpRequester.httpGet(\r\n\t\t\t`${baseUrl}/getemailtriggertemplatebeneficiaries?id=${id}`\r\n\t\t)\r\n\t}\r\n\r\n\tgetAllCountries() {\r\n\t\treturn this.httpRequester.httpGet(\r\n\t\t\t`${baseUrl}/getallcountries`\r\n\t\t)\r\n\t}\r\n}\r\n","import { User } from '../models/main-models';\r\nimport HttpRequester from './http-requester';\r\n\r\n//declare var baseUrl: string;\r\nvar baseUrl = '/users';\r\n\r\nexport default class UsersSvc {\r\n httpRequester: HttpRequester;\r\n\r\n constructor() {\r\n this.httpRequester = new HttpRequester('/api');\r\n }\r\n\r\n getAllAdmins() {\r\n return this.httpRequester.httpGet(`${baseUrl}/getalladmins`);\r\n }\r\n\r\n removeAdmin(admin: User) {\r\n return this.httpRequester.httpPost(`${baseUrl}/removeadmin`, admin);\r\n }\r\n\r\n approveAdmin(admin: User) {\r\n return this.httpRequester.httpPost(`${baseUrl}/approveadmin`, admin);\r\n }\r\n\r\n getAdminById(id: string) {\r\n return this.httpRequester.httpGet(`${baseUrl}/getadminbyid/?id=${id}`);\r\n }\r\n\r\n getEupatiUserById(id: string) {\r\n return this.httpRequester.httpGet(`${baseUrl}/geteupatiuserbyid/?id=${id}`);\r\n }\r\n}\r\n","import { PaymentIntentCreateModel } from \"../models/input-models\";\r\nimport HttpRequester from \"./http-requester\";\r\n\r\n//declare var baseUrl: string;\r\nvar baseUrl = '/payments';\r\n\r\nexport default class PaymentSvc {\r\n httpRequester: HttpRequester;\r\n\r\n constructor() {\r\n this.httpRequester = new HttpRequester('/api');\r\n }\r\n\r\n getStripeConfig() {\r\n return this.httpRequester.httpGet(\r\n `${baseUrl}/getstripeconfig`\r\n );\r\n }\r\n\r\n createPaymentIntent(data: PaymentIntentCreateModel) {\r\n return this.httpRequester.httpPost(\r\n `${baseUrl}/createpaymentintent`,\r\n data\r\n );\r\n }\r\n}","import ProjectsSvc from './projects-svc';\r\nimport PatientSvc from './patients-svc';\r\nimport UtilsSvc from './utils-svc';\r\nimport UsersSvc from './users-svc';\r\nimport PaymentSvc from './payment-svc';\r\n\r\nexport default class DataSvc {\r\n\tpublic static projectsSvc: ProjectsSvc = new ProjectsSvc();\r\n\tpublic static patientSvc: PatientSvc = new PatientSvc();\r\n\tpublic static utilsSvc: UtilsSvc = new UtilsSvc();\r\n\tpublic static usersSvc: UsersSvc = new UsersSvc();\r\n\tpublic static paymentSvc: PaymentSvc = new PaymentSvc();\r\n}","// constants.ts\r\n\r\nexport const NAME = 'newProject';","import { NAME } from \"./constants\";\r\n\r\nexport const SET_PROJECTS_LOADING = `${NAME}/SET_PROJECTS_LOADING`;\r\n\r\nexport const SET_PROJECT = `${NAME}/SET_PROJECT`;\r\n\r\nexport const SET_LOOKUP_DATA = `${NAME}/SET_LOOKUP_DATA`;\r\n\r\nexport const SUBMIT_NEW_PROJECT = `${NAME}/SUBMIT_NEW_PROJECT`;\r\n\r\nexport const SET_IS_USER_REAL = `${NAME}/SET_IS_USER_REAL`;","// matching/actions.js\r\nimport { Res } from '../../common/helpers';\r\nimport { LookUpData } from '../../common/models/input-models';\r\nimport { Project } from '../../common/models/main-models';\r\nimport DataSvc from '../../common/services/data-svc';\r\nimport * as t from './actionTypes';\r\n\r\nexport const setProjectLoading = (isLoading: boolean) => ({\r\n type: t.SET_PROJECTS_LOADING,\r\n payload: isLoading,\r\n});\r\n\r\nexport const setProject = (project: Project) => ({\r\n type: t.SET_PROJECT,\r\n payload: project\r\n});\r\n\r\nexport const setLookUpData = (data: LookUpData[]) => ({\r\n type: t.SET_LOOKUP_DATA,\r\n payload: data\r\n});\r\n\r\nexport const setIsUserReal = (isUserReal: boolean) => ({\r\n type: t.SET_IS_USER_REAL,\r\n payload: isUserReal\r\n});\r\n\r\nexport const getLookUpDataAsync = () => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setProjectLoading(true));\r\n DataSvc.utilsSvc.getLookUpData().then(\r\n (result: any) => {\r\n dispatch(setLookUpData(result));\r\n dispatch(setProjectLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n );\r\n };\r\n};\r\n\r\nexport const saveNewProjectAsync = (newProject: Project) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setProjectLoading(true));\r\n DataSvc.projectsSvc.saveNewProject(newProject);\r\n dispatch(setProjectLoading(false));\r\n };\r\n};\r\n\r\nexport const verifyUserTokenAsync = (token: string) => {\r\n return (dispatch: any, getState: any) => {\r\n DataSvc.utilsSvc.verifyUserByRecaptchaToken({ recaptchaToken: token }).then(\r\n (result: any) => {\r\n if (result !== Res.success) {\r\n dispatch(setIsUserReal(false));\r\n }\r\n },\r\n (error) => { console.error(error); }\r\n );\r\n }\r\n}","// model.js\r\n// This is the model of our module state (e.g. return type of the reducer)\r\n\r\nimport { LookUpData, MeshData } from \"../../common/models/input-models\";\r\nimport { Project } from \"../../common/models/main-models\";\r\n\r\nexport type State = {\r\n project: Project;\r\n isLoading: boolean;\r\n lookUpData: LookUpData[];\r\n isUserReal: boolean;\r\n};\r\n\r\nexport const emptyProject = {\r\n id: '',\r\n name: '',\r\n overview: '',\r\n projectTypeId: 0,\r\n projectActivityId: 0,\r\n projectNumberOfPatientsNeeded: 0,\r\n interactionTypeId: 0,\r\n roleAndExpectations: '',\r\n startDate: undefined,\r\n endDate: undefined,\r\n timeRequired: '',\r\n isCompensationProvided: null as any,\r\n compensation: '',\r\n isThereTravelReimbursement: null as any,\r\n equipmentRequirements: '',\r\n responseDeadline: undefined,\r\n diseases: [],\r\n noDiseaseExpertiseRequired: false,\r\n searchDiseaseTherapeuticArea: false,\r\n price: -1,\r\n plan: '',\r\n package: '',\r\n paymentMethod: '',\r\n // diseaseNames: [],\r\n // diseasesTreeIds: [],\r\n // diseaseMeshId: '',\r\n // diseaseTANames: '',\r\n //diseaseTAMeshId: '',\r\n patientExpertises: [],\r\n patientExpertisesDescription: '',\r\n countries: [],\r\n languages: [],\r\n otherInformation: '',\r\n pocFirstName: '',\r\n projectTypeDescription: '',\r\n pocLastName: '',\r\n pocOrganisation: '',\r\n pocOrganisationTypeId: 0,\r\n pocOrganisationTypeDescription: '',\r\n pocJobTitle: '',\r\n pocCountryId: 0,\r\n pocPhoneNumber: '',\r\n pocEmail: '',\r\n isGDPRConsentGiven: false,\r\n matchedPatients: [],\r\n confirmedPatients: []\r\n} as Project;","import * as React from 'react';\r\nimport './loader.scss';\r\n\r\ntype OwnProps = { \r\n text?: string;\r\n };\r\n\r\ntype OwnState = {};\r\n\r\ntype DispatchProps = {};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nlet defaultLoadingText = 'Loading...';\r\n\r\nclass EupatiLoader extends React.Component<Props, OwnState> {\r\n render() {\r\n return (\r\n <div className='eupati-loader'>\r\n <div className='eupati-loader-circle'></div>\r\n <span className='eupati-loader-text'>{this.props.text ? this.props.text : defaultLoadingText}</span>\r\n </div>\r\n )\r\n }\r\n}\r\n\r\nexport default EupatiLoader;","import * as React from 'react';\r\nimport { Form } from 'react-bootstrap';\r\n\r\ntype OwnProps = {\r\n value: string;\r\n errorMsg: string;\r\n fieldType?: string;\r\n placeholder?: string;\r\n};\r\n\r\nexport type DispatchProps = {\r\n onChange: (e: any) => void;\r\n};\r\n\r\ntype OwnState = {};\r\n\r\ntype Props = DispatchProps & OwnProps;\r\n\r\nexport default class EupatiTextbox extends React.Component<Props, OwnState> {\r\n\r\n render() {\r\n return (\r\n <>\r\n <Form.Group>\r\n <Form.Control\r\n type={typeof this.props.fieldType === 'undefined' ? 'text' : this.props.fieldType}\r\n value={this.props.value}\r\n className=\"eupati-textbox\"\r\n placeholder={this.props.placeholder}\r\n onChange={(e) => this.props.onChange(e)}\r\n />\r\n {!!this.props.errorMsg &&\r\n <span className='text-danger'>{this.props.errorMsg}</span>\r\n }\r\n </Form.Group>\r\n </>\r\n );\r\n }\r\n}\r\n","import * as React from 'react';\r\nimport { Form } from 'react-bootstrap';\r\n\r\ntype OwnProps = {\r\n value: number;\r\n errorMsg: string;\r\n fieldType?: string;\r\n placeholder?: string;\r\n};\r\n\r\nexport type DispatchProps = {\r\n onChange: (e: any) => void;\r\n};\r\n\r\ntype OwnState = {};\r\n\r\ntype Props = DispatchProps & OwnProps;\r\n\r\nexport default class EupatiNumberbox extends React.Component<Props, OwnState> {\r\n\r\n render() {\r\n return (\r\n <>\r\n <Form.Group>\r\n <Form.Control\r\n type={typeof this.props.fieldType === 'undefined' ? 'number' : this.props.fieldType}\r\n value={this.props.value}\r\n className=\"eupati-numberbox\"\r\n placeholder={this.props.placeholder}\r\n onChange={(e) => this.props.onChange(e)}\r\n />\r\n {!!this.props.errorMsg &&\r\n <span className='text-danger'>{this.props.errorMsg}</span>\r\n }\r\n </Form.Group>\r\n </>\r\n );\r\n }\r\n}\r\n","import * as React from 'react';\r\nimport { Form } from 'react-bootstrap';\r\nimport { LookUpOptions } from '../models/input-models';\r\n\r\ntype OwnProps = {\r\n fieldName: string;\r\n values: LookUpOptions[] | null;\r\n errorMsg: string;\r\n value?: number;\r\n defaultOptionText?: string;\r\n width?: string;\r\n};\r\n\r\nexport type DispatchProps = {\r\n onChange: (e: any) => void;\r\n};\r\n\r\ntype OwnState = {\r\n vals: LookUpOptions[] | null;\r\n}\r\n\r\ntype Props = DispatchProps & OwnProps;\r\n\r\nclass EupatiDropdown extends React.Component<Props, OwnState> {\r\n\r\n constructor(props: any) {\r\n super(props);\r\n\r\n this.state = {\r\n vals: [],\r\n };\r\n\r\n this.compare = this.compare.bind(this);\r\n }\r\n\r\n componentDidMount() {\r\n if (this.props.values !== null) {\r\n if (this.props.fieldName.toLowerCase().includes('country')) {\r\n this.setState({ vals: [...this.props.values].sort(this.compare) });\r\n }\r\n else {\r\n this.setState({ vals: [...this.props.values] });\r\n }\r\n }\r\n }\r\n\r\n compare(a: any, b: any) {\r\n if (a.name < b.name) {\r\n return -1;\r\n }\r\n if (a.name > b.name) {\r\n return 1;\r\n }\r\n return 0;\r\n }\r\n\r\n render() {\r\n\r\n let optionsComponent: any;\r\n\r\n let dropdownComponent: any;\r\n\r\n if (this.props.values &&\r\n this.props.values.length > 0) {\r\n\r\n optionsComponent = this.state.vals?.map((x, i) => {\r\n if (i === 0) {\r\n return (\r\n <React.Fragment key={i + 'a'} >\r\n {typeof this.props.defaultOptionText !== 'undefined' &&\r\n <option\r\n key={'default-option'}\r\n className='option-item'\r\n value=''\r\n >\r\n {this.props.defaultOptionText ? this.props.defaultOptionText : \"Please select...\"}\r\n </option>\r\n }\r\n\r\n <option\r\n key={i}\r\n className='option-item'\r\n value={x.id}\r\n >\r\n {x.name}\r\n </option>\r\n </React.Fragment>\r\n );\r\n } else {\r\n return (\r\n <option\r\n key={i}\r\n className='option-item'\r\n value={x.id}\r\n >\r\n {x.name}\r\n </option>\r\n );\r\n }\r\n });\r\n }\r\n else {\r\n optionsComponent = (\r\n <option\r\n key='option-disabled'\r\n className='option-item'\r\n disabled={true}\r\n >\r\n No options available...\r\n </option>\r\n );\r\n }\r\n\r\n dropdownComponent = (\r\n <Form.Control\r\n as='select'\r\n className=\"eupati-dropdown\"\r\n value={this.props.value}\r\n onChange={(e) => this.props.onChange(e)}\r\n style={{ width: this.props.width ? this.props.width : '100%' }}\r\n >\r\n {optionsComponent}\r\n </Form.Control>\r\n );\r\n\r\n return (\r\n <>\r\n {dropdownComponent}\r\n {!!this.props.errorMsg &&\r\n <span className='text-danger'>{this.props.errorMsg}</span>\r\n }\r\n </>\r\n );\r\n }\r\n}\r\n\r\nexport default EupatiDropdown;\r\n","import * as React from 'react';\r\nimport { Form } from 'react-bootstrap';\r\n\r\ntype OwnProps = {\r\n value: string;\r\n errorMsg: string;\r\n rowsCount?: number;\r\n placeholderMsg?: string;\r\n isDisabled?: boolean;\r\n};\r\n\r\nexport type DispatchProps = {\r\n onChange: (e: any) => void;\r\n};\r\n\r\ntype OwnState = {};\r\n\r\ntype Props = DispatchProps & OwnProps;\r\n\r\n//const DEFAULT_ELEMENT_HEIGHT = 41; // rowsCount: 1\r\nexport default class EupatiTextarea extends React.Component<Props, OwnState> {\r\n element: any;\r\n\r\n constructor(props: any) {\r\n super(props);\r\n this.element = React.createRef();\r\n }\r\n\r\n componentDidMount() {\r\n const height = this.element.current.scrollHeight;\r\n this.element.current.style.height = `${height}px`;\r\n }\r\n\r\n // handleKeyDown(e: any) {\r\n // e.target.style.height = 'inherit';\r\n // e.target.style.height = `${e.target.scrollHeight}px`;\r\n // if (e.target.scrollHeight === DEFAULT_ELEMENT_HEIGHT) {\r\n // e.target.style.height = 'inherit';\r\n // }\r\n // }\r\n\r\n render() {\r\n return (\r\n <>\r\n <Form.Group>\r\n <Form.Control\r\n as='textarea'\r\n value={this.props.value}\r\n className=\"eupati-textbox\"\r\n rows={this.props.rowsCount ? this.props.rowsCount : 3}\r\n placeholder={this.props.placeholderMsg ? this.props.placeholderMsg : 'Please type in your information...'}\r\n disabled={this.props.isDisabled === undefined ? false : this.props.isDisabled}\r\n onChange={(e) => this.props.onChange(e)}\r\n //onKeyDown={this.handleKeyDown.bind(this)}\r\n ref={this.element}\r\n />\r\n {!!this.props.errorMsg &&\r\n <span className='text-danger'>{this.props.errorMsg}</span>\r\n }\r\n </Form.Group>\r\n </>\r\n );\r\n }\r\n}\r\n","import * as React from 'react';\r\nimport { ToggleButton, ToggleButtonGroup, ToggleButtonProps } from 'react-bootstrap';\r\nimport { LookUpOptions } from '../models/input-models';\r\n\r\nimport { IconProp } from '@fortawesome/fontawesome-svg-core';\r\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\r\nimport { faDotCircle } from '@fortawesome/fontawesome-free-regular';\r\n\r\ntype OwnProps = {\r\n fieldName: string;\r\n values: LookUpOptions[] | null;\r\n value: number;\r\n errorMsg: string;\r\n};\r\n\r\ntype OwnState = {};\r\n\r\ntype DispatchProps = {\r\n onChange: (e: any) => void;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nclass EupatiToggleBtn extends React.Component<Props, OwnState> {\r\n\r\n constructor(props: any) {\r\n super(props);\r\n\r\n this.returnProperIconType = this.returnProperIconType.bind(this);\r\n }\r\n\r\n returnProperIconType(icon: any) {\r\n return icon as IconProp;\r\n }\r\n\r\n render() {\r\n\r\n let valuesComponent: any;\r\n\r\n let btnComponent: any;\r\n\r\n valuesComponent = this.props.values?.map((x, i) => {\r\n return (\r\n <ToggleButton\r\n key={i}\r\n type='radio'\r\n value={x.id}\r\n name={this.props.fieldName}\r\n >\r\n <div className='toggle-btn'>\r\n <FontAwesomeIcon \r\n icon={this.returnProperIconType(faDotCircle)}\r\n className='toggle-btn-circle'\r\n />\r\n </div>\r\n <div className='check-btn-text'><span style={{ clear: 'both', display: 'inline-block', overflow: 'hidden', whiteSpace: 'nowrap' }}>{x.name.trim()}</span></div>\r\n </ToggleButton>\r\n )\r\n });\r\n\r\n btnComponent = (\r\n <ToggleButtonGroup\r\n id={this.props.fieldName}\r\n className={this.props.fieldName}\r\n value={this.props.value}\r\n name={this.props.fieldName}\r\n onChange={(e: any) => this.props.onChange(e)}\r\n >\r\n {valuesComponent}\r\n </ToggleButtonGroup>\r\n );\r\n\r\n return (\r\n <>\r\n {btnComponent}\r\n {!!this.props.errorMsg &&\r\n <span className='text-danger'>{this.props.errorMsg}</span>\r\n }\r\n </>\r\n );\r\n }\r\n}\r\n\r\nexport default EupatiToggleBtn;","import * as React from 'react';\r\nimport { Form } from 'react-bootstrap';\r\n\r\ntype OwnProps = {\r\n value: Date;\r\n errorMsg: string;\r\n};\r\n\r\nexport type DispatchProps = {\r\n onChange: (e: any) => void;\r\n};\r\n\r\ntype Props = DispatchProps & OwnProps;\r\n\r\nexport default class EupatiDateMenu extends React.Component<Props> {\r\n\r\n render() {\r\n return (\r\n <>\r\n <Form.Group>\r\n <Form.Control\r\n type='date'\r\n className=\"eupati-datemenu\"\r\n value={this.props.value.toString()}\r\n onChange={(e) => this.props.onChange(e)}\r\n />\r\n {!!this.props.errorMsg &&\r\n <span className='text-danger'>{this.props.errorMsg}</span>\r\n }\r\n </Form.Group>\r\n </>\r\n );\r\n }\r\n}\r\n","import React from \"react\";\r\nimport { Button, Form } from \"react-bootstrap\";\r\nimport { useForm, Controller } from \"react-hook-form\";\r\nimport EupatiTextbox from \"../../../../common/static/textbox\";\r\nimport EupatiNumberbox from \"../../../../common/static/numberbox\";\r\nimport EupatiDropdown from \"../../../../common/static/dropdown\";\r\nimport EupatiTextarea from \"../../../../common/static/textarea\";\r\nimport { Rules } from \"../../../../common/helpers\";\r\nimport { Messages } from \"../../../../common/helpers\";\r\nimport { useHistory } from \"react-router\";\r\nimport EupatiToggleBtn from \"../../../../common/static/toggle-btn\";\r\nimport EupatiDateMenu from \"../../../../common/static/date-menu\";\r\nimport { Project } from \"../../../../common/models/main-models\";\r\nimport { LookUpData, LookUpOptions } from \"../../../../common/models/input-models\";\r\nimport { toast } from 'react-toastify';\r\n\r\ntype OwnProps = {\r\n project: Project,\r\n isUserReal: boolean\r\n};\r\n\r\ntype DispatchProps = {\r\n prevPage: () => void;\r\n setProject: (project: Project) => void;\r\n showPatientsInfoSection: () => void;\r\n returnProperDefaultValue: (val: any) => any;\r\n returnProperLookUpData: (dataType: any) => LookUpOptions[] | null;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\ntype FieldProps = {\r\n name: string,\r\n projectTypeId: number,\r\n projectTypeDescription: string,\r\n roleAndExpectations: string,\r\n projectActivityId: number,\r\n projectNumberOfPatientsNeeded: number,\r\n interactionTypeId: number,\r\n startDate?: Date,\r\n endDate?: Date,\r\n responseDeadline?: Date\r\n};\r\n\r\nexport default function ProjectGeneralInfo(props: Props) {\r\n\r\n const history = useHistory();\r\n\r\n const { handleSubmit, control, watch, reset, formState: { errors } } = useForm();\r\n\r\n const fieldsData = {\r\n name: watch(\"name\") as string,\r\n projectTypeId: watch(\"projectTypeId\") as number,\r\n projectTypeDescription: watch(\"projectTypeDescription\") as string,\r\n roleAndExpectations: watch(\"roleAndExpectations\") as string,\r\n projectActivityId: watch(\"projectActivityId\") as number,\r\n projectNumberOfPatientsNeeded: watch(\"projectActivityId\") as number,\r\n interactionTypeId: watch(\"interactionTypeId\") as number,\r\n startDate: watch(\"startDate\") as Date | undefined,\r\n endDate: watch(\"endDate\") as Date | undefined,\r\n responseDeadline: watch(\"responseDeadline\") as Date | undefined\r\n } as FieldProps;\r\n\r\n const onSubmit = (data: any) => {\r\n if (!props.isUserReal) {\r\n toast.error(Messages.FAIL_AUTH_MSG);\r\n return history.push('/');\r\n }\r\n\r\n const updatedProject = Object.assign(props.project, data);\r\n props.setProject(updatedProject);\r\n props.showPatientsInfoSection();\r\n }\r\n\r\n const onBackHandler = () => {\r\n if (!props.isUserReal) {\r\n toast.error(Messages.FAIL_AUTH_MSG);\r\n return history.push('/');\r\n }\r\n\r\n if (adjustFieldsValues() === 0) {\r\n const updatedProject = Object.assign(props.project, fieldsData);\r\n props.setProject(updatedProject);\r\n }\r\n props.prevPage();\r\n }\r\n\r\n const toggleField = () => {\r\n let projectId = 0;\r\n if (fieldsData.projectTypeId !== undefined && fieldsData.projectTypeId !== null) {\r\n projectId = fieldsData.projectTypeId;\r\n }\r\n else if (props.project.projectTypeId !== undefined && props.project.projectTypeId !== null) {\r\n projectId = props.project.projectTypeId;\r\n }\r\n\r\n const projectTypes = props.returnProperLookUpData('projectType');\r\n return projectTypes?.find(x => x.id.toString() === projectId.toString())?.name.toLowerCase().includes('other');\r\n }\r\n\r\n const adjustFieldsValues = () => {\r\n if (fieldsData.name === undefined &&\r\n fieldsData.projectTypeId === undefined &&\r\n fieldsData.projectTypeDescription === undefined &&\r\n fieldsData.roleAndExpectations === undefined &&\r\n fieldsData.projectActivityId === undefined &&\r\n fieldsData.interactionTypeId === undefined &&\r\n fieldsData.startDate === undefined &&\r\n fieldsData.endDate === undefined &&\r\n fieldsData.responseDeadline === undefined) {\r\n return 1;\r\n }\r\n\r\n if (fieldsData.name === undefined &&\r\n props.project.name !== undefined) {\r\n fieldsData.name = props.project.name;\r\n }\r\n\r\n if (fieldsData.projectTypeId === undefined &&\r\n props.project.projectTypeId !== undefined) {\r\n fieldsData.projectTypeId = props.project.projectTypeId;\r\n }\r\n\r\n if (fieldsData.projectTypeDescription === undefined &&\r\n props.project.projectTypeDescription !== undefined) {\r\n fieldsData.projectTypeDescription = props.project.projectTypeDescription;\r\n }\r\n\r\n if (fieldsData.roleAndExpectations === undefined &&\r\n props.project.roleAndExpectations !== undefined) {\r\n fieldsData.roleAndExpectations = props.project.roleAndExpectations;\r\n }\r\n\r\n if (fieldsData.projectActivityId === undefined &&\r\n props.project.projectActivityId !== undefined) {\r\n fieldsData.projectActivityId = props.project.projectActivityId;\r\n }\r\n\r\n if (fieldsData.projectNumberOfPatientsNeeded === undefined &&\r\n props.project.projectNumberOfPatientsNeeded !== undefined) {\r\n fieldsData.projectNumberOfPatientsNeeded = props.project.projectNumberOfPatientsNeeded;\r\n }\r\n\r\n if (fieldsData.interactionTypeId === undefined &&\r\n props.project.interactionTypeId !== undefined) {\r\n fieldsData.interactionTypeId = props.project.interactionTypeId;\r\n }\r\n\r\n if (fieldsData.startDate === undefined &&\r\n props.project.startDate !== undefined) {\r\n fieldsData.startDate = props.project.startDate;\r\n }\r\n\r\n if (fieldsData.endDate === undefined &&\r\n props.project.endDate !== undefined) {\r\n fieldsData.endDate = props.project.endDate;\r\n }\r\n\r\n if (fieldsData.responseDeadline === undefined &&\r\n props.project.responseDeadline !== undefined) {\r\n fieldsData.responseDeadline = props.project.responseDeadline;\r\n }\r\n\r\n return 0;\r\n }\r\n\r\n return (\r\n <Form className='project' onSubmit={handleSubmit(onSubmit)}>\r\n <Form.Group className='project-info'>\r\n <Form.Group className='lcolumn'>\r\n\r\n <Form.Group id='p-name' className='project-info-field mb-3'>\r\n <Form.Label>Project name</Form.Label>\r\n <Controller\r\n name='name'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.name)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.name?.message,\r\n placeholder: 'Please type project name'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='p-projTp' className='project-info-field mb-3'>\r\n <Form.Label>Project type</Form.Label>\r\n <Controller\r\n name='projectTypeId'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.projectTypeId)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiDropdown\r\n {...{\r\n ...field,\r\n errorMsg: errors?.projectTypeId?.message,\r\n fieldName: 'projectTypeId',\r\n values: props.returnProperLookUpData('projectType'),\r\n defaultOptionText: ''\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n {toggleField() &&\r\n <Form.Group id='p-projTpDescr' className='project-info-field mb-3'>\r\n <Form.Label>Other project type description</Form.Label>\r\n <Controller\r\n name='projectTypeDescription'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.projectTypeDescription)}\r\n rules={Rules.notRequired}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.projectTypeDescription?.message,\r\n placeholder: 'Please type project type'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n }\r\n\r\n <Form.Group id='p-roleAndExpctons' className='project-info-field mb-3'>\r\n <Form.Label>Patients role and expectations</Form.Label>\r\n <Controller\r\n name='roleAndExpectations'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.roleAndExpectations)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextarea\r\n {...{\r\n ...field,\r\n errorMsg: errors?.roleAndExpectations?.message\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='p-projAct' className='project-info-field mb-4'>\r\n <Form.Label>Activity</Form.Label>\r\n <Controller\r\n name='projectActivityId'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.projectActivityId)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiToggleBtn\r\n {...{\r\n ...field,\r\n fieldName: 'projectActivityId',\r\n values: props.returnProperLookUpData('activityType'),\r\n errorMsg: errors?.projectActivityId?.message\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='p-intractnTp' className='project-info-field mb-4'>\r\n <Form.Label>Interaction type</Form.Label>\r\n <Controller\r\n name='interactionTypeId'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.interactionTypeId)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiToggleBtn\r\n {...{\r\n ...field,\r\n fieldName: 'interactionTypeId',\r\n values: props.returnProperLookUpData('interactionType'),\r\n errorMsg: errors?.interactionTypeId?.message\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='p-projHowManyPatients' className='project-info-field mb-12'>\r\n <Form.Label>How many patients are you looking for?</Form.Label>\r\n <Controller\r\n name='projectNumberOfPatientsNeeded'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.projectNumberOfPatientsNeeded)}\r\n rules={Rules.notRequired}\r\n render={({ field }) =>\r\n <EupatiNumberbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.projectTypeDescription?.message,\r\n placeholder: 'Please enter how many patients you are looking for'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='p-startDate' className='project-info-field mb-3'>\r\n <Form.Label>Start date</Form.Label>\r\n <Controller\r\n name='startDate'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.startDate)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiDateMenu\r\n {...{\r\n ...field,\r\n errorMsg: errors?.startDate?.message\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='p-endDate' className='project-info-field mb-3'>\r\n <Form.Label>End date</Form.Label>\r\n <Controller\r\n name='endDate'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.endDate)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiDateMenu\r\n {...{\r\n ...field,\r\n errorMsg: errors?.endDate?.message\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='p-resDedln' className='project-info-field mb-3'>\r\n <Form.Label>Response deadline</Form.Label>\r\n <Controller\r\n name='responseDeadline'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.responseDeadline)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiDateMenu\r\n {...{\r\n ...field,\r\n errorMsg: errors?.responseDeadline?.message\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='p-btns' className='project-info-field'>\r\n <Button className='bck' variant='secondary' onClick={onBackHandler}>Back</Button>\r\n <Button className='nxt' variant='primary' type='submit'>Next</Button>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form>\r\n )\r\n}","import * as React from 'react';\r\nimport { ToggleButton, ToggleButtonGroup, ToggleButtonProps } from 'react-bootstrap';\r\n\r\nimport { IconProp } from '@fortawesome/fontawesome-svg-core';\r\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\r\nimport { faDotCircle } from '@fortawesome/fontawesome-free-regular';\r\n\r\ntype OwnProps = {\r\n fieldName: string;\r\n value: number;\r\n errorMsg: string;\r\n isMoreThanTwoOptions: boolean;\r\n};\r\n\r\ntype OwnState = {};\r\n\r\ntype DispatchProps = {\r\n onChange: (e: any) => void;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nclass EupatiNonCMSToggleBtn extends React.Component<Props, OwnState> {\r\n\r\n constructor(props: any) {\r\n super(props);\r\n\r\n this.returnProperIconType = this.returnProperIconType.bind(this);\r\n }\r\n\r\n returnProperIconType(icon: any) {\r\n return icon as IconProp;\r\n }\r\n\r\n render() {\r\n\r\n let values = [\r\n {\r\n id: true,\r\n name: 'Yes'\r\n },\r\n {\r\n id: false,\r\n name: 'No'\r\n },\r\n {\r\n id: null,\r\n name: 'Maybe'\r\n }\r\n ];\r\n\r\n let valuesComponent: any;\r\n\r\n let btnComponent: any;\r\n\r\n if (!this.props.isMoreThanTwoOptions) {\r\n if (values.length > 2) {\r\n values.pop();\r\n }\r\n }\r\n\r\n valuesComponent = values?.map((x, i) => {\r\n return (\r\n <ToggleButton\r\n key={i}\r\n name={this.props.fieldName}\r\n className='radio-item'\r\n value={`${x.id}`}\r\n type='radio'\r\n >\r\n <div className='toggle-btn'>\r\n <FontAwesomeIcon\r\n icon={this.returnProperIconType(faDotCircle)}\r\n className='toggle-btn-circle'\r\n />\r\n </div>\r\n <div className='check-btn-text'>{x.name}</div>\r\n </ToggleButton>\r\n )\r\n });\r\n\r\n btnComponent = (\r\n <React.Fragment key={'abcde'}>\r\n <ToggleButtonGroup\r\n id={this.props.fieldName}\r\n className='radio-items'\r\n onChange={(e: any) => this.props.onChange(e)}\r\n value={`${this.props.value}`}\r\n name={this.props.fieldName}\r\n type='radio'\r\n >\r\n {valuesComponent}\r\n </ToggleButtonGroup>\r\n {!!this.props.errorMsg &&\r\n <span className='text-danger'>{this.props.errorMsg}</span>\r\n }\r\n </React.Fragment>\r\n );\r\n\r\n return (\r\n <>\r\n {btnComponent}\r\n </>\r\n );\r\n }\r\n}\r\n\r\nexport default EupatiNonCMSToggleBtn;","import React from \"react\";\r\nimport { Form, Button } from \"react-bootstrap\";\r\nimport { Controller, useForm } from 'react-hook-form';\r\nimport EupatiNonCMSToggleBtn from \"../../../../common/static/toggle-btn-nonCMS\";\r\nimport EupatiTextbox from \"../../../../common/static/textbox\";\r\nimport { Rules, Messages } from \"../../../../common/helpers\";\r\nimport { useHistory } from \"react-router\";\r\nimport EupatiTextarea from \"../../../../common/static/textarea\";\r\nimport { Project } from \"../../../../common/models/main-models\";\r\nimport { LookUpOptions } from \"../../../../common/models/input-models\";\r\nimport { toast } from 'react-toastify';\r\n\r\ntype OwnProps = {\r\n project: Project,\r\n isUserReal: boolean\r\n}\r\n\r\ntype DispatchProps = {\r\n setProject: (project: Project) => void;\r\n returnProperDefaultValue: (val: any) => any;\r\n returnProperLookUpData: (dataType: any) => LookUpOptions[] | null;\r\n hidePatientsInfoSection: () => void;\r\n nextPage: () => void;\r\n}\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\ntype FieldProps = {\r\n equipmentRequirements: string,\r\n timeRequired: string,\r\n overview: string,\r\n isThereTravelReimbursement?: number,\r\n isCompensationProvided?: number,\r\n compensation: string;\r\n};\r\n\r\nexport default function ProjectPatientsInfo(props: Props) {\r\n\r\n const history = useHistory();\r\n\r\n const { handleSubmit, control, watch, formState: { errors } } = useForm();\r\n\r\n const fieldsData = {\r\n equipmentRequirements: watch(\"equipmentRequirements\") as string,\r\n timeRequired: watch(\"timeRequired\") as string,\r\n overview: watch(\"overview\") as string,\r\n isThereTravelReimbursement: watch(\"isThereTravelReimbursement\") as number | undefined,\r\n isCompensationProvided: watch(\"isCompensationProvided\") as number | undefined,\r\n compensation: watch(\"compensation\") as string\r\n } as FieldProps;\r\n\r\n const onSubmit = (data: any) => {\r\n if (!props.isUserReal) {\r\n toast.error(Messages.FAIL_AUTH_MSG);\r\n return history.push('/');\r\n }\r\n\r\n const updatedProject = Object.assign(props.project, data);\r\n props.setProject(updatedProject);\r\n props.nextPage();\r\n }\r\n\r\n const onBackHandler = () => {\r\n if (!props.isUserReal) {\r\n toast.error(Messages.FAIL_AUTH_MSG);\r\n return history.push('/');\r\n }\r\n\r\n if (adjustFieldsValues() === 0) {\r\n const updatedProject = Object.assign(props.project, fieldsData);\r\n props.setProject(updatedProject);\r\n }\r\n props.hidePatientsInfoSection();\r\n }\r\n\r\n const fieldToggle = () => {\r\n let val = '';\r\n if (fieldsData.isCompensationProvided !== undefined && fieldsData.isCompensationProvided !== null) {\r\n val = fieldsData.isCompensationProvided.toString();\r\n }\r\n else if (props.project.isCompensationProvided !== undefined && props.project.isCompensationProvided !== null) {\r\n val = props.project.isCompensationProvided.toString();\r\n }\r\n\r\n return val === 'true' ? true : false;\r\n }\r\n\r\n const adjustFieldsValues = () => {\r\n if (fieldsData.equipmentRequirements === undefined &&\r\n fieldsData.timeRequired === undefined &&\r\n fieldsData.overview === undefined &&\r\n fieldsData.isThereTravelReimbursement === undefined &&\r\n fieldsData.isCompensationProvided === undefined &&\r\n fieldsData.compensation === undefined) {\r\n return 1;\r\n }\r\n\r\n if (fieldsData.equipmentRequirements === undefined &&\r\n props.project.equipmentRequirements !== undefined) {\r\n fieldsData.equipmentRequirements = props.project.equipmentRequirements;\r\n }\r\n\r\n if (fieldsData.timeRequired === undefined &&\r\n props.project.timeRequired !== undefined) {\r\n fieldsData.timeRequired = props.project.timeRequired;\r\n }\r\n\r\n if (fieldsData.overview === undefined &&\r\n props.project.overview !== undefined) {\r\n fieldsData.overview = props.project.overview;\r\n }\r\n\r\n if (fieldsData.isThereTravelReimbursement === undefined &&\r\n props.project.isThereTravelReimbursement !== undefined) {\r\n fieldsData.isThereTravelReimbursement = props.project.isThereTravelReimbursement;\r\n }\r\n\r\n if (fieldsData.isCompensationProvided === undefined &&\r\n props.project.isCompensationProvided !== undefined) {\r\n fieldsData.isCompensationProvided = props.project.isCompensationProvided;\r\n }\r\n\r\n if (fieldsData.compensation === undefined &&\r\n props.project.compensation !== undefined) {\r\n fieldsData.compensation = props.project.compensation;\r\n }\r\n\r\n return 0;\r\n }\r\n\r\n return (\r\n <Form className='project' onSubmit={handleSubmit(onSubmit)}>\r\n <Form.Group className='project-info'>\r\n <Form.Group className='rcolumn'>\r\n\r\n <Form.Group id='p-equptReq' className='project-info-field mb-3'>\r\n <Form.Label>Equipment requirements</Form.Label>\r\n <Controller\r\n name='equipmentRequirements'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.equipmentRequirements)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextarea\r\n {...{\r\n ...field,\r\n errorMsg: errors?.equipmentRequirements?.message\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='p-timeReq' className='project-info-field mb-3'>\r\n <Form.Label>Time required</Form.Label>\r\n <Controller\r\n name='timeRequired'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.timeRequired)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextarea\r\n {...{\r\n ...field,\r\n errorMsg: errors?.timeRequired?.message\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='p-overview' className='project-info-field mb-3'>\r\n <Form.Label>Project overview</Form.Label>\r\n <Controller\r\n name='overview'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.overview)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextarea\r\n {...{\r\n ...field,\r\n errorMsg: errors?.overview?.message,\r\n rowsCount: 8\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='p-trvlReimb' className='project-info-field mb-5'>\r\n <Form.Label>Travel reimbursement</Form.Label>\r\n <Controller\r\n name='isThereTravelReimbursement'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.isThereTravelReimbursement)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiNonCMSToggleBtn\r\n {...{\r\n ...field,\r\n fieldName: 'isThereTravelReimbursement',\r\n errorMsg: errors?.isThereTravelReimbursement?.message,\r\n isMoreThanTwoOptions: false\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='p-compProv' className='project-info-field mb-5'>\r\n <Form.Label>Compensation provided</Form.Label>\r\n <Controller\r\n name='isCompensationProvided'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.isCompensationProvided)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiNonCMSToggleBtn\r\n {...{\r\n ...field,\r\n fieldName: 'isCompensationProvided',\r\n errorMsg: errors?.isCompensationProvided?.message,\r\n isMoreThanTwoOptions: false\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n {fieldToggle() &&\r\n <Form.Group id='p-comp' className='project-info-field mb-5'>\r\n <Form.Label>Amount</Form.Label>\r\n <Controller\r\n name='compensation'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.compensation)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.compensation?.message,\r\n placeholder: 'Please type compensation amount'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n }\r\n\r\n <Form.Group id='p-btns' className='project-info-field'>\r\n <Button className='bck' variant='secondary' onClick={onBackHandler}>Back</Button>\r\n <Button className='nxt' variant='primary' type='submit'>Next</Button>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form>\r\n )\r\n}","import React, { useState } from 'react';\r\nimport { LookUpOptions } from '../../../../common/models/input-models';\r\nimport { Project } from '../../../../common/models/main-models';\r\nimport ProjectGeneralInfo from './general';\r\nimport ProjectPatientsInfo from './patients';\r\n\r\ntype OwnProps = {\r\n project: Project,\r\n isUserReal: boolean,\r\n showSecondSubComponent: boolean\r\n};\r\n\r\ntype DispatchProps = {\r\n setProject: (project: Project) => void;\r\n nextPage: () => void;\r\n prevPage: () => void;\r\n returnProperDefaultValue: (val: any) => any;\r\n setIsUserReal: (token: string) => void;\r\n returnProperLookUpData: (dataType: any) => LookUpOptions[] | null;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nexport default function ProjectInfo(props: Props) {\r\n const [nextBtnClicked, setNextBtnClicked] = useState<boolean>(props.showSecondSubComponent);\r\n\r\n const toggleSectionVisibility = () => {\r\n setNextBtnClicked(!nextBtnClicked);\r\n //window.scrollTo(0, 0);\r\n }\r\n\r\n return (\r\n <div style={{ margin: '0 0 7.5rem 0' }}>\r\n\r\n {nextBtnClicked &&\r\n <ProjectGeneralInfo\r\n {...{\r\n project: props.project,\r\n setProject: props.setProject,\r\n returnProperDefaultValue: props.returnProperDefaultValue,\r\n returnProperLookUpData: props.returnProperLookUpData,\r\n showPatientsInfoSection: toggleSectionVisibility,\r\n isUserReal: props.isUserReal,\r\n prevPage: props.prevPage\r\n }}\r\n />\r\n }\r\n\r\n {!nextBtnClicked &&\r\n <ProjectPatientsInfo\r\n {...{\r\n project: props.project,\r\n setProject: props.setProject,\r\n returnProperDefaultValue: props.returnProperDefaultValue,\r\n returnProperLookUpData: props.returnProperLookUpData,\r\n hidePatientsInfoSection: toggleSectionVisibility,\r\n isUserReal: props.isUserReal,\r\n nextPage: props.nextPage\r\n }}\r\n />\r\n }\r\n\r\n </div>\r\n )\r\n}","import * as React from 'react';\r\nimport { Form } from 'react-bootstrap';\r\n\r\ntype OwnProps = {\r\n value: string;\r\n errorMsg: string;\r\n};\r\n\r\nexport type DispatchProps = {\r\n onChange: (e: any) => void;\r\n};\r\n\r\ntype OwnState = {};\r\n\r\ntype Props = DispatchProps & OwnProps;\r\n\r\nexport default class EupatiEmailbox extends React.Component<Props, OwnState> {\r\n\r\n render() {\r\n return (\r\n <>\r\n <Form.Group>\r\n <Form.Control\r\n type='email'\r\n value={this.props.value}\r\n className=\"eupati-textbox\"\r\n placeholder=\"Please type email\"\r\n onChange={(e) => this.props.onChange(e)}\r\n />\r\n {!!this.props.errorMsg &&\r\n <span className='text-danger'>{this.props.errorMsg}</span>\r\n }\r\n </Form.Group>\r\n </>\r\n );\r\n }\r\n}\r\n","import React from \"react\";\r\nimport { Button, Form } from \"react-bootstrap\";\r\nimport { useForm, Controller } from \"react-hook-form\";\r\nimport { Rules } from \"../../../../common/helpers\";\r\nimport EupatiTextbox from \"../../../../common/static/textbox\";\r\nimport EupatiEmailbox from \"../../../../common/static/emailbox\";\r\nimport { useHistory } from \"react-router\";\r\nimport { Messages } from \"../../../../common/helpers\";\r\nimport { Project } from \"../../../../common/models/main-models\";\r\nimport { LookUpOptions } from '../../../../common/models/input-models';\r\nimport { toast } from 'react-toastify';\r\n\r\ntype OwnProps = {\r\n project: Project,\r\n isUserReal: boolean\r\n};\r\n\r\ntype DispatchProps = {\r\n showCompanyInfoSection: () => void;\r\n setProject: (project: Project) => void;\r\n returnProperDefaultValue: (val: any) => any;\r\n findLookUpData: (lookUpDataType?: string) => LookUpOptions[] | null;\r\n}\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nexport default function PersonalInfo(props: Props) {\r\n\r\n const history = useHistory();\r\n\r\n const { handleSubmit, control, reset, formState: { errors } } = useForm();\r\n\r\n const onSubmit = (data: any) => {\r\n if (!props.isUserReal) {\r\n toast.error(Messages.FAIL_AUTH_MSG);\r\n return history.push('/');\r\n }\r\n\r\n const updatedProject = Object.assign(props.project, data);\r\n props.setProject(updatedProject);\r\n props.showCompanyInfoSection();\r\n }\r\n\r\n return (\r\n <Form className='researcher' onSubmit={handleSubmit(onSubmit)}>\r\n <Form.Group className='researcher-info'>\r\n <Form.Group className=\"lcolumn\">\r\n\r\n <Form.Group id='r-fname' className='researcher-info-field mb-3'>\r\n <Form.Label>First name</Form.Label>\r\n <Controller\r\n name='pocFirstName'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.pocFirstName)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.pocFirstName?.message,\r\n placeholder: 'Please type first name'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='r-lname' className='researcher-info-field mb-3'>\r\n <Form.Label>Surname</Form.Label>\r\n <Controller\r\n name='pocLastName'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.pocLastName)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.pocLastName?.message,\r\n placeholder: 'Please type last name'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='r-tel' className='researcher-info-field mb-3'>\r\n <Form.Label>Phone</Form.Label>\r\n <Controller\r\n name='pocPhoneNumber'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.pocPhoneNumber)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.pocPhoneNumber?.message,\r\n placeholder: 'Please type phone number'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='r-email' className='researcher-info-field mb-3'>\r\n <Form.Label>Email</Form.Label>\r\n <Controller\r\n name='pocEmail'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.pocEmail)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiEmailbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.pocEmail?.message\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='r-btns' className='researcher-info-field'>\r\n <Button className='bck' style={{ visibility: 'hidden' }} variant='secondary' disabled>Back</Button>\r\n <Button className='nxt' variant='primary' type='submit'>Next</Button>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form>\r\n )\r\n}","import React from \"react\";\r\nimport { Button, Form } from \"react-bootstrap\";\r\nimport { useForm, Controller } from \"react-hook-form\";\r\nimport { Rules } from \"../../../../common/helpers\";\r\nimport EupatiTextbox from \"../../../../common/static/textbox\";\r\nimport EupatiDropdown from \"../../../../common/static/dropdown\";\r\nimport EupatiToggleBtn from \"../../../../common/static/toggle-btn\";\r\nimport { useHistory } from \"react-router\";\r\nimport { Messages } from \"../../../../common/helpers\";\r\nimport { Project } from \"../../../../common/models/main-models\";\r\nimport { LookUpOptions } from \"../../../../common/models/input-models\";\r\nimport { toast } from 'react-toastify';\r\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\r\nimport { faInfoCircle } from '@fortawesome/fontawesome-free-solid';\r\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\r\nimport ReactTooltip from 'react-tooltip';\r\n\r\ntype OwnProps = {\r\n project: Project,\r\n isUserReal: boolean\r\n};\r\n\r\ntype DispatchProps = {\r\n nextPage: () => void;\r\n hideCompanyInfoSection: () => void;\r\n setProject: (project: Project) => void;\r\n returnProperDefaultValue: (val: any) => any;\r\n findLookUpData: (lookUpDataType?: string) => LookUpOptions[] | null;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\ntype FieldProps = {\r\n pocOrganisation: string,\r\n pocJobTitle: string,\r\n pocCountryId: number,\r\n pocOrganisationTypeId: number,\r\n pocOrganisationTypeDescription: string\r\n};\r\n\r\nexport default function CompanyInfo(props: Props) {\r\n\r\n const history = useHistory();\r\n\r\n const { handleSubmit, control, watch, reset, formState: { errors } } = useForm();\r\n\r\n const fieldsData = {\r\n pocOrganisation: watch(\"pocOrganisation\") as string,\r\n pocJobTitle: watch(\"pocJobTitle\") as string,\r\n pocCountryId: watch(\"pocCountryId\") as number,\r\n pocOrganisationTypeId: watch(\"pocOrganisationTypeId\") as number,\r\n pocOrganisationTypeDescription: watch(\"pocOrganisationTypeDescription\") as string\r\n } as FieldProps;\r\n\r\n const onSubmit = (data: any) => {\r\n if (!props.isUserReal) {\r\n toast.error(Messages.FAIL_AUTH_MSG);\r\n return history.push('/');\r\n }\r\n\r\n const updatedProject = Object.assign(props.project, data);\r\n props.setProject(updatedProject);\r\n props.nextPage();\r\n }\r\n\r\n const onBackHandler = () => {\r\n if (!props.isUserReal) {\r\n toast.error(Messages.FAIL_AUTH_MSG);\r\n return history.push('/');\r\n }\r\n\r\n if (adjustFieldsValues() === 0) {\r\n const updatedProject = Object.assign(props.project, fieldsData);\r\n props.setProject(updatedProject);\r\n }\r\n props.hideCompanyInfoSection();\r\n }\r\n\r\n const returnProperIconType = (icon: any) => {\r\n return icon as IconProp;\r\n }\r\n\r\n const toggleField = () => {\r\n let orgTypeId = 0;\r\n if (fieldsData.pocOrganisationTypeId !== undefined && fieldsData.pocOrganisationTypeId !== null) {\r\n orgTypeId = fieldsData.pocOrganisationTypeId;\r\n }\r\n else if (props.project.pocOrganisationTypeId !== undefined && props.project.pocOrganisationTypeId !== null) {\r\n orgTypeId = props.project.pocOrganisationTypeId;\r\n }\r\n\r\n const organisationTypes = props.findLookUpData('organisationType');\r\n return organisationTypes?.find(x => x.id.toString() === orgTypeId.toString())?.name.toLowerCase().includes('other');\r\n }\r\n\r\n const adjustFieldsValues = () => {\r\n if (fieldsData.pocOrganisation === undefined &&\r\n fieldsData.pocJobTitle === undefined &&\r\n fieldsData.pocCountryId === undefined &&\r\n fieldsData.pocOrganisationTypeId === undefined &&\r\n fieldsData.pocOrganisationTypeDescription === undefined) {\r\n return 1;\r\n }\r\n\r\n if (fieldsData.pocOrganisation === undefined &&\r\n props.project.pocOrganisation !== undefined) {\r\n fieldsData.pocOrganisation = props.project.pocOrganisation;\r\n }\r\n\r\n if (fieldsData.pocJobTitle === undefined &&\r\n props.project.pocJobTitle !== undefined) {\r\n fieldsData.pocJobTitle = props.project.pocJobTitle;\r\n }\r\n\r\n if (fieldsData.pocCountryId === undefined &&\r\n props.project.pocCountryId !== undefined) {\r\n fieldsData.pocCountryId = props.project.pocCountryId;\r\n }\r\n\r\n if (fieldsData.pocOrganisationTypeId === undefined &&\r\n props.project.pocOrganisationTypeId !== undefined) {\r\n fieldsData.pocOrganisationTypeId = props.project.pocOrganisationTypeId;\r\n }\r\n\r\n if (fieldsData.pocOrganisationTypeDescription === undefined &&\r\n props.project.pocOrganisationTypeDescription !== undefined) {\r\n fieldsData.pocOrganisationTypeDescription = props.project.pocOrganisationTypeDescription;\r\n }\r\n\r\n return 0;\r\n }\r\n\r\n return (\r\n <Form className='researcher' onSubmit={handleSubmit(onSubmit)}>\r\n <Form.Group className='researcher-info'>\r\n <Form.Group className='rcolumn'>\r\n\r\n <Form.Group id='r-org' className='researcher-info-field mb-3'>\r\n <Form.Label>Company</Form.Label>\r\n <Controller\r\n name='pocOrganisation'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.pocOrganisation)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.pocOrganisation?.message,\r\n placeholder: 'Please type company name'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='r-jobTitle' className='researcher-info-field mb-3'>\r\n <Form.Label>Job title</Form.Label>\r\n <Controller\r\n name='pocJobTitle'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.pocJobTitle)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.pocJobTitle?.message,\r\n placeholder: 'Please type job title'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='r-country' className='researcher-info-field'>\r\n <Form.Label>Country <FontAwesomeIcon data-tip data-for='ctryInfo' icon={returnProperIconType(faInfoCircle)} /> <ReactTooltip id='ctryInfo'><span>Country, where your organisation is based.</span></ReactTooltip> </Form.Label>\r\n <Controller\r\n name='pocCountryId'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.pocCountryId)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiDropdown\r\n {...{\r\n ...field,\r\n errorMsg: errors?.pocCountryId?.message,\r\n fieldName: 'pocCountryId',\r\n values: props.findLookUpData('country'),\r\n defaultOptionText: 'Select country...'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='r-orgType' className='researcher-info-field'>\r\n <Form.Label>Organization type</Form.Label>\r\n <Controller\r\n name='pocOrganisationTypeId'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.pocOrganisationTypeId)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiToggleBtn\r\n {...{\r\n ...field,\r\n fieldName: 'pocOrganisationTypeId',\r\n values: props.findLookUpData('organisationType'),\r\n errorMsg: errors?.pocOrganisationTypeId?.message\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n {toggleField() &&\r\n <Form.Group id='r-orgTypeDescr' className='researcher-info-field'>\r\n <Form.Label>Organization type description</Form.Label>\r\n <Controller\r\n name='pocOrganisationTypeDescription'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.pocOrganisationTypeDescription)}\r\n rules={Rules.notRequired}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.pocOrganisationTypeDescription?.message,\r\n placeholder: 'Please type organization type'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n }\r\n\r\n <Form.Group id='r-btns' className='researcher-info-field'>\r\n <Button className='bck' variant='secondary' onClick={onBackHandler}>Back</Button>\r\n <Button className='nxt' variant='primary' type='submit'>Next</Button>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form>\r\n )\r\n}","import React, { useState } from \"react\";\r\nimport PersonalInfo from \"./personal\";\r\nimport CompanyInfo from \"./company\";\r\nimport { Project } from \"../../../../common/models/main-models\";\r\nimport { LookUpData, LookUpOptions } from \"../../../../common/models/input-models\";\r\n\r\ntype OwnProps = {\r\n project: Project,\r\n lookUpData: LookUpData[],\r\n isUserReal: boolean,\r\n showSecondSubComponent: boolean\r\n};\r\n\r\ntype DispatchProps = {\r\n nextPage: () => void;\r\n setIsUserReal: (token: string) => void;\r\n setProject: (project: Project) => void;\r\n returnProperDefaultValue: (val: any) => any;\r\n findLookUpData: (lookUpDataType?: string) => LookUpOptions[] | null;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nexport default function ResearcherInfo(props: Props) {\r\n const [nextBtnClicked, setNextBtnClicked] = useState<boolean>(props.showSecondSubComponent);\r\n\r\n const toggleSectionVisibility = () => {\r\n setNextBtnClicked(!nextBtnClicked);\r\n //window.scrollTo(0, 0);\r\n }\r\n\r\n return (\r\n <div style={{ margin: '0 0 7.5rem 0' }}>\r\n\r\n {nextBtnClicked &&\r\n <PersonalInfo\r\n {...{\r\n project: props.project,\r\n setProject: props.setProject,\r\n returnProperDefaultValue: props.returnProperDefaultValue,\r\n findLookUpData: props.findLookUpData,\r\n isUserReal: props.isUserReal,\r\n showCompanyInfoSection: toggleSectionVisibility\r\n }}\r\n />\r\n }\r\n\r\n {!nextBtnClicked &&\r\n <CompanyInfo\r\n {...{\r\n project: props.project,\r\n setProject: props.setProject,\r\n returnProperDefaultValue: props.returnProperDefaultValue,\r\n findLookUpData: props.findLookUpData,\r\n hideCompanyInfoSection: toggleSectionVisibility,\r\n isUserReal: props.isUserReal,\r\n nextPage: props.nextPage\r\n }}\r\n />\r\n }\r\n </div>\r\n );\r\n}","import * as React from 'react';\r\nimport { ToggleButtonGroup, ToggleButton } from 'react-bootstrap';\r\nimport { LookUpOptions } from '../models/input-models';\r\nimport { IconProp } from '@fortawesome/fontawesome-svg-core';\r\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\r\nimport { faCheckSquare } from '@fortawesome/fontawesome-free-regular';\r\n\r\ntype OwnProps = {\r\n fieldName: string;\r\n values: LookUpOptions[] | null;\r\n value: any[];\r\n errorMsg: string;\r\n};\r\n\r\ntype DispatchProps = {\r\n onChange: (e: any) => void;\r\n};\r\n\r\ntype OwnState = {\r\n vals: any[];\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nconst ALL_ELEMENTS_OPTION = { id: 1312, name: \"All\" };\r\nexport default class EupatiMultiselect extends React.Component<Props, OwnState> {\r\n\r\n constructor(props: any) {\r\n super(props);\r\n\r\n this.state = {\r\n vals: []\r\n };\r\n\r\n this.returnProperIconType = this.returnProperIconType.bind(this);\r\n this.handleOnChange = this.handleOnChange.bind(this);\r\n this.compare = this.compare.bind(this);\r\n }\r\n\r\n componentDidMount() {\r\n if (this.props.values !== null) {\r\n this.setState({ vals: [...this.props.values, ALL_ELEMENTS_OPTION] });\r\n }\r\n }\r\n\r\n returnProperIconType(icon: any) {\r\n return icon as IconProp;\r\n }\r\n\r\n compare(a: any, b: any) {\r\n if (a.name < b.name) {\r\n return -1;\r\n }\r\n if (a.name > b.name) {\r\n return 1;\r\n }\r\n return 0;\r\n }\r\n\r\n handleOnChange(e: any) {\r\n if (e.includes(ALL_ELEMENTS_OPTION.id)) {\r\n const ids: any[] = [];\r\n this.state.vals.forEach(x => { if (x.id !== ALL_ELEMENTS_OPTION.id) { ids.push(x.id) } });\r\n this.props.onChange(ids);\r\n }\r\n else {\r\n this.props.onChange(e);\r\n }\r\n }\r\n\r\n render() {\r\n let valuesComponent: any;\r\n\r\n let multiSelectComponent: any;\r\n\r\n if (this.props.values) {\r\n\r\n if (this.props.values.length > 3) {\r\n valuesComponent = this.state.vals.sort(this.compare).map((x, i) => {\r\n return (\r\n <ToggleButton\r\n key={i}\r\n value={x.id}\r\n type='checkbox'\r\n className={this.props?.value?.length === this.props?.values?.length ? 'active' : ''}\r\n name={this.props.fieldName}\r\n style={{ border: '0' }}\r\n >\r\n <div className='toggle-btn'>\r\n <FontAwesomeIcon\r\n icon={this.returnProperIconType(faCheckSquare)}\r\n className='toggle-btn-circle'\r\n />\r\n </div>\r\n <div className='check-btn-text'>{x.name}</div>\r\n </ToggleButton>\r\n )\r\n });\r\n } else {\r\n valuesComponent = this.state.vals.map((x, i) => {\r\n if (x.id !== 1312) {\r\n return (\r\n <ToggleButton\r\n key={i}\r\n value={x.id}\r\n type='checkbox'\r\n name={this.props.fieldName}\r\n >\r\n <div className='toggle-btn'>\r\n <FontAwesomeIcon\r\n icon={this.returnProperIconType(faCheckSquare)}\r\n className='toggle-btn-circle'\r\n />\r\n </div>\r\n <div className='check-btn-text'>{x.name}</div>\r\n </ToggleButton>\r\n )\r\n }\r\n });\r\n }\r\n }\r\n\r\n multiSelectComponent = (\r\n <ToggleButtonGroup\r\n id={this.props.fieldName}\r\n className={this.props.fieldName}\r\n value={this.props.value}\r\n type='checkbox'\r\n onChange={(e) => this.handleOnChange(e)}\r\n >\r\n {valuesComponent}\r\n </ToggleButtonGroup>\r\n )\r\n\r\n return (\r\n <>\r\n {multiSelectComponent}\r\n {!!this.props.errorMsg &&\r\n <span className='text-danger'>{this.props.errorMsg}</span>\r\n }\r\n </>\r\n )\r\n }\r\n}","import * as React from 'react';\r\nimport { ToggleButtonGroup, ToggleButton } from 'react-bootstrap';\r\nimport { IconProp } from '@fortawesome/fontawesome-svg-core';\r\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\r\nimport { faCheckSquare } from '@fortawesome/fontawesome-free-solid';\r\nimport { Link, NavLink } from 'react-router-dom';\r\n\r\ntype OwnProps = {\r\n fieldName: string;\r\n value: any;\r\n errorMsg: string;\r\n};\r\n\r\ntype DispatchProps = {\r\n onChange: (e: any) => void;\r\n};\r\n\r\ntype OwnState = {};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nexport default class EupatiGDPRBtn extends React.Component<Props, OwnState> {\r\n\r\n constructor(props: any) {\r\n super(props);\r\n\r\n this.returnProperIconType = this.returnProperIconType.bind(this);\r\n }\r\n\r\n returnProperIconType(icon: any) {\r\n return icon as IconProp;\r\n }\r\n\r\n render() {\r\n let valuesComponent: any;\r\n\r\n let gdprComponent: any;\r\n\r\n let values = [\r\n {\r\n id: true,\r\n name: 'I agree to '\r\n }\r\n ];\r\n\r\n valuesComponent = values.map((x, i) => {\r\n return (\r\n <ToggleButton\r\n key={i}\r\n value={x.id.toString()}\r\n type='radio'\r\n name={this.props.fieldName}\r\n >\r\n <div className='toggle-btn'>\r\n <FontAwesomeIcon\r\n icon={this.returnProperIconType(faCheckSquare)}\r\n className='toggle-btn-circle'\r\n />\r\n </div>\r\n <div className='check-btn-text'>{x.name}<a href='https://toolbox.eupati.eu/glossary/gdpr/' target=\"_blank\" >terms and conditions</a></div>\r\n </ToggleButton>\r\n )\r\n });\r\n\r\n gdprComponent = (\r\n <ToggleButtonGroup\r\n id={this.props.fieldName}\r\n className={this.props.fieldName}\r\n value={this.props.value.toString()}\r\n name={this.props.fieldName}\r\n type='radio'\r\n onChange={(e) => this.props.onChange(e)}\r\n >\r\n {valuesComponent}\r\n </ToggleButtonGroup>\r\n )\r\n\r\n return (\r\n <>\r\n {gdprComponent}\r\n {!!this.props.errorMsg &&\r\n <span className='text-danger'>{this.props.errorMsg}</span>\r\n }\r\n </>\r\n )\r\n }\r\n}","import React from 'react';\r\nimport { Controller, useForm } from 'react-hook-form';\r\nimport { Button, Form } from 'react-bootstrap';\r\nimport { Rules, Messages } from '../../../../common/helpers';\r\nimport EupatiMultiselect from '../../../../common/static/multiselect';\r\nimport EupatiGDPRBtn from '../../../../common/static/GDPR-toggle';\r\nimport { useHistory } from 'react-router';\r\nimport EupatiTextarea from '../../../../common/static/textarea';\r\nimport { Project } from '../../../../common/models/main-models';\r\nimport { LookUpOptions } from '../../../../common/models/input-models';\r\nimport EupatiTextbox from '../../../../common/static/textbox';\r\nimport { toast } from 'react-toastify';\r\n\r\ntype OwnProps = {\r\n project: Project,\r\n isUserReal: boolean,\r\n};\r\n\r\ntype DispatchProps = {\r\n setProject: (project: Project) => void;\r\n submitProject: (project: Project) => void;\r\n returnProperDefaultValue: (val: any) => any;\r\n hidePatientsAdditionalInfoSection: () => void;\r\n findLookUpData: (lookUpDataType?: string) => LookUpOptions[] | null;\r\n nextPage: () => void;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\ntype FieldsProps = {\r\n patientExpertises: number[],\r\n patientExpertisesDescription: string,\r\n otherInformation: string,\r\n isGDPRConsentGiven: boolean\r\n};\r\n\r\nexport default function PatientsAdditionalInfo(props: Props) {\r\n\r\n const history = useHistory();\r\n\r\n const { handleSubmit, control, watch, formState: { errors } } = useForm();\r\n\r\n const fieldsData = {\r\n patientExpertises: watch(\"patientExpertises\") as number[],\r\n patientExpertisesDescription: watch(\"patientExpertisesDescription\") as string,\r\n otherInformation: watch(\"otherInformation\") as string,\r\n isGDPRConsentGiven: watch(\"isGDPRConsentGiven\") as boolean\r\n } as FieldsProps;\r\n\r\n const onSubmit = (data: any) => {\r\n if (!props.isUserReal) {\r\n toast.error(Messages.FAIL_AUTH_MSG);\r\n return history.push('/');\r\n }\r\n\r\n const updatedProject = Object.assign(props.project, Object.assign(data));\r\n props.submitProject(updatedProject);\r\n props.nextPage();\r\n }\r\n\r\n const onBackHandler = () => {\r\n if (!props.isUserReal) {\r\n toast.error(Messages.FAIL_AUTH_MSG);\r\n return history.push('/');\r\n }\r\n\r\n if (adjustFieldsValues() === 0) {\r\n const updatedProject = Object.assign(props.project, Object.assign(fieldsData));\r\n props.setProject(updatedProject);\r\n }\r\n props.hidePatientsAdditionalInfoSection();\r\n }\r\n\r\n const adjustFieldsValues = () => {\r\n if (fieldsData.patientExpertises === undefined &&\r\n fieldsData.patientExpertisesDescription === undefined &&\r\n fieldsData.otherInformation === undefined &&\r\n fieldsData.isGDPRConsentGiven === undefined) {\r\n return 1; // if user hasn't changed anything\r\n }\r\n\r\n if (fieldsData.patientExpertises === undefined &&\r\n props.project.patientExpertises !== undefined) {\r\n fieldsData.patientExpertises = [...props.project.patientExpertises];\r\n }\r\n\r\n if (fieldsData.patientExpertisesDescription === undefined &&\r\n props.project.patientExpertisesDescription !== undefined) {\r\n fieldsData.patientExpertisesDescription = props.project.patientExpertisesDescription;\r\n }\r\n\r\n if (fieldsData.otherInformation === undefined &&\r\n props.project.otherInformation !== undefined) {\r\n fieldsData.otherInformation = props.project.otherInformation;\r\n }\r\n\r\n if (fieldsData.isGDPRConsentGiven === undefined &&\r\n props.project.isGDPRConsentGiven !== undefined) {\r\n fieldsData.isGDPRConsentGiven = props.project.isGDPRConsentGiven;\r\n }\r\n\r\n return 0;\r\n }\r\n\r\n const toggleField = () => {\r\n let ptExpertises: number[] = [];\r\n if (fieldsData.patientExpertises !== undefined && fieldsData.patientExpertises !== null) {\r\n ptExpertises = [...fieldsData.patientExpertises];\r\n }\r\n else if (props.project.patientExpertises !== undefined && props.project.patientExpertises !== null) {\r\n ptExpertises = [...props.project.patientExpertises];\r\n }\r\n\r\n let otherType = props.findLookUpData('expertise')?.find(ot => ot.name.toLowerCase().includes('other'));\r\n return ptExpertises?.some((x) => x === otherType?.id) ? true : false;\r\n }\r\n\r\n return (\r\n <Form className='pt' onSubmit={handleSubmit(onSubmit)}>\r\n <Form.Group className='pt-info'>\r\n <Form.Group className='rcolumn'>\r\n\r\n <Form.Group id='pt-lvlExprt' className='pt-info-field mb-4'>\r\n <Form.Label>Level of expertise (multiple answers possible)</Form.Label>\r\n <Controller\r\n name='patientExpertises'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.patientExpertises)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiMultiselect\r\n {...{\r\n ...field,\r\n fieldName: 'patientExpertises',\r\n values: props.findLookUpData('expertise'),\r\n errorMsg: errors?.patientExpertises?.message\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n {toggleField() &&\r\n <Form.Group id='pt-lvlExprtDescr' className='pt-info-field mb-4'>\r\n <Form.Label>Please specify your level of expertise</Form.Label>\r\n <Controller\r\n name='patientExpertisesDescription'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.patientExpertisesDescription)}\r\n rules={Rules.notRequired}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.patientExpertisesDescription?.message,\r\n placeholder: 'Please type level of expertise'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n }\r\n\r\n <Form.Group id='pt-otherInfo' className='pt-info-field mb-3'>\r\n <Form.Label>Additional patient information</Form.Label>\r\n <Controller\r\n name='otherInformation'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.otherInformation)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextarea\r\n {...{\r\n ...field,\r\n errorMsg: errors?.otherInformation?.message,\r\n rowsCount: 8\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='pt-gdpr' className='pt-info-field mb-4'>\r\n <Controller\r\n name='isGDPRConsentGiven'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.isGDPRConsentGiven)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiGDPRBtn\r\n {...{\r\n ...field,\r\n fieldName: 'isGDPRConsentGiven',\r\n errorMsg: errors?.isGDPRConsentGiven?.message\r\n }}\r\n />\r\n }\r\n />\r\n <small className='google-message'>\r\n This site is protected by reCAPTCHA and the Google\r\n <a className='google-message-privacy' href=\"https://policies.google.com/privacy\" target=\"_blank\"> Privacy Policy</a> and\r\n <a className='google-message-tos' href=\"https://policies.google.com/terms\" target=\"_blank\"> Terms of Service</a> apply.\r\n </small>\r\n </Form.Group>\r\n\r\n <Form.Group id='pt-btns' className='pt-info-field'>\r\n <Button className='bck' variant='secondary' onClick={onBackHandler} >Back</Button>\r\n <Button className='nxt' variant='primary' type='submit'>Submit</Button>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form>\r\n )\r\n}","//R.S docs: https://www.npmjs.com/package/react-select\r\nimport * as React from 'react';\r\nimport { Form } from 'react-bootstrap';\r\nimport Select from 'react-select';\r\nimport { LookUpOptions } from '../models/input-models';\r\nimport './static.scss';\r\n\r\ntype OwnProps = {\r\n value: any[];\r\n errorMsg: string;\r\n values: LookUpOptions[] | null;\r\n placeholder?: string;\r\n};\r\n\r\nexport type DispatchProps = {\r\n onChange: (e: any) => void;\r\n};\r\n\r\ntype OwnState = {};\r\n\r\ntype Props = DispatchProps & OwnProps;\r\n\r\nconst CONTINENTS_LIST = ['Worldwide', 'Asia', 'Africa', 'North America', 'South America', 'Antarctica', 'Europe'];\r\nexport default class EupatiSelect extends React.Component<Props, OwnState> {\r\n\r\n constructor(props: any) {\r\n super(props);\r\n\r\n this.handleOnChange = this.handleOnChange.bind(this);\r\n this.mapOptionsToValues = this.mapOptionsToValues.bind(this);\r\n this.mapArrayToValues = this.mapArrayToValues.bind(this);\r\n this.returnComponentStyles = this.returnComponentStyles.bind(this);\r\n this.langCompare = this.langCompare.bind(this);\r\n }\r\n\r\n handleOnChange(event: any) {\r\n this.props.onChange(Object.values(event).map((key: any) => key.value));\r\n }\r\n\r\n mapOptionsToValues = (options: any) => {\r\n const isCountry = (item: any) => item.name.toLowerCase() === 'worldwide';\r\n if (options.length) {\r\n if (options.some(isCountry)) {\r\n return options.map((option: any) => ({\r\n value: option.id,\r\n label: option.name\r\n }));\r\n }\r\n\r\n return options.sort(this.langCompare).map((option: any) => ({\r\n value: option.id,\r\n label: option.name\r\n }));\r\n }\r\n }\r\n\r\n mapArrayToValues = (arr: any) => {\r\n if (arr.length) {\r\n return arr.map((element: any) => {\r\n let newElement = this.props?.values?.find((x) => x.id === element);\r\n return { value: newElement?.id, label: newElement?.name };\r\n });\r\n }\r\n }\r\n\r\n langCompare = (a: any, b: any) => {\r\n if (a.name < b.name) {\r\n return -1;\r\n }\r\n if (a.name > b.name) {\r\n return 1;\r\n }\r\n return 0;\r\n }\r\n\r\n returnComponentStyles = () => {\r\n\r\n const continentsBoldStyles = {\r\n multiValueLabel: (base: any) => ({ ...base, backgroundColor: '#DAEEF2', color: '#000', padding: '4px 8px', paddingLeft: '8px' }),\r\n multiValueRemove: (base: any) => ({ ...base, backgroundColor: '#DAEEF2', color: '#808080', cursor: 'pointer', \"&:hover\": { backgroundColor: '#00A4B6', color: '#fff' } }),\r\n dropdownIndicator: (base: any) => ({ ...base, cursor: 'pointer' }),\r\n indicatorsContainer: (base: any) => ({ ...base, cursor: 'pointer', backgroundColor: '#DAEEF2', color: '#808080', \"&:hover\": { backgroundColor: '#00A4B6', color: '#fff' } }),\r\n option: (base: any) => (\r\n {\r\n ...base,\r\n \"&:nth-of-type(1)\": { fontWeight: 'bold' },\r\n \"&:nth-of-type(2)\": { fontWeight: 'bold' },\r\n \"&:nth-of-type(3)\": { fontWeight: 'bold' },\r\n \"&:nth-of-type(4)\": { fontWeight: 'bold' },\r\n \"&:nth-of-type(5)\": { fontWeight: 'bold' },\r\n \"&:nth-of-type(6)\": { fontWeight: 'bold' },\r\n \"&:nth-of-type(7)\": { fontWeight: 'bold' },\r\n \"&:nth-of-type(8)\": { fontWeight: 'bold' }\r\n }\r\n ),\r\n menu: (base: any) => ({ ...base, position: 'relative', backgroundColor: '#fff' }),\r\n menuList: (base: any) => ({ ...base, position: 'relative', backgroundColor: '#fff' })\r\n }\r\n\r\n const regularStyles = {\r\n multiValueLabel: (base: any) => ({ ...base, backgroundColor: '#DAEEF2', color: '#000', padding: '4px 8px', paddingLeft: '8px' }),\r\n multiValueRemove: (base: any) => ({ ...base, backgroundColor: '#DAEEF2', color: '#808080', cursor: 'pointer', \"&:hover\": { backgroundColor: '#00A4B6', color: '#fff' } }),\r\n dropdownIndicator: (base: any) => ({ ...base, cursor: 'pointer' }),\r\n indicatorsContainer: (base: any) => ({ ...base, cursor: 'pointer', backgroundColor: '#DAEEF2', color: '#808080', \"&:hover\": { backgroundColor: '#00A4B6', color: '#fff' } }),\r\n menu: (base: any) => ({ ...base, position: 'relative', backgroundColor: '#fff' }),\r\n menuList: (base: any) => ({ ...base, position: 'relative', backgroundColor: '#fff' })\r\n }\r\n\r\n\r\n if (this.props?.values !== null) {\r\n return this.props?.values[0]?.name?.toLowerCase() === 'worldwide' ? continentsBoldStyles : regularStyles;\r\n }\r\n\r\n return regularStyles;\r\n }\r\n\r\n render() {\r\n return (\r\n <>\r\n <Form.Group>\r\n <Select\r\n isMulti={true}\r\n placeholder={this.props.placeholder ? this.props.placeholder : 'Please select an option...'}\r\n options={this.mapOptionsToValues(this.props.values)}\r\n defaultValue={this.mapArrayToValues(this.props.value)}\r\n onChange={e => this.handleOnChange(e)}\r\n className='select-dropdown'\r\n styles={this.returnComponentStyles()}\r\n />\r\n {!!this.props.errorMsg &&\r\n <span className='text-danger'>{this.props.errorMsg}</span>\r\n }\r\n </Form.Group>\r\n </>\r\n );\r\n }\r\n}\r\n","//R.S docs: https://www.npmjs.com/package/react-select\r\nimport * as React from 'react';\r\nimport { Form } from 'react-bootstrap';\r\nimport Async from 'react-select/async';\r\nimport { LookUpOptions } from '../models/input-models';\r\nimport { DiseaseInfo } from '../models/main-models';\r\nimport DataSvc from '../services/data-svc';\r\nimport './static.scss';\r\n\r\ntype OwnProps = {\r\n value: any[];\r\n errorMsg: string;\r\n placeholder?: string;\r\n};\r\n\r\nexport type DispatchProps = {\r\n onChange: (e: any) => void;\r\n};\r\n\r\ntype OwnState = { applyFiltersTimeoutId: any; };\r\n\r\ntype Props = DispatchProps & OwnProps;\r\n\r\nexport default class EupatiDiseaseAsyncSelect extends React.Component<Props, OwnState> {\r\n constructor(props: any) {\r\n super(props);\r\n\r\n this.handleOnChange = this.handleOnChange.bind(this);\r\n this.mapOptionsToValues = this.mapOptionsToValues.bind(this);\r\n this.returnComponentStyles = this.returnComponentStyles.bind(this);\r\n\r\n this.state = {\r\n applyFiltersTimeoutId: undefined\r\n };\r\n }\r\n\r\n handleOnChange(event: any) {\r\n this.props?.onChange(Object.values(event).map((key: any) => ({ name: key.label, treeNumbers: key.value } as DiseaseInfo)));\r\n }\r\n\r\n mapOptionsToValues = (options: any) => {\r\n return options?.map((option: any) => ({\r\n value: option.id,\r\n label: option.name\r\n }));\r\n }\r\n\r\n mapDiseaseOptionsToValues = (options: any) => {\r\n return options?.map((option: any) => ({\r\n value: option.treeNumbers,\r\n label: option.name\r\n }));\r\n }\r\n\r\n returnComponentStyles = () => {\r\n\r\n const regularStyles = {\r\n multiValueLabel: (base: any) => ({ ...base, backgroundColor: '#DAEEF2', color: '#000', padding: '4px 8px', paddingLeft: '8px' }),\r\n multiValueRemove: (base: any) => ({ ...base, backgroundColor: '#DAEEF2', color: '#808080', cursor: 'pointer', \"&:hover\": { backgroundColor: '#00A4B6', color: '#fff' } }),\r\n dropdownIndicator: (base: any) => ({ ...base, cursor: 'pointer' }),\r\n indicatorsContainer: (base: any) => ({ ...base, cursor: 'pointer', backgroundColor: '#DAEEF2', color: '#808080', \"&:hover\": { backgroundColor: '#00A4B6', color: '#fff' } }),\r\n menu: (base: any) => ({ ...base, position: 'relative', backgroundColor: '#fff' }),\r\n menuList: (base: any) => ({ ...base, position: 'relative', backgroundColor: '#fff' })\r\n }\r\n\r\n\r\n return regularStyles;\r\n }\r\n\r\n loadAutocompleteOptions = async (inputValue: string) => {\r\n return new Promise<LookUpOptions[]>((resolve) => {\r\n if (inputValue && inputValue.length > 2) {\r\n if (this.state.applyFiltersTimeoutId) {\r\n clearTimeout(this.state.applyFiltersTimeoutId);\r\n }\r\n\r\n var that = this;\r\n this.setState({\r\n applyFiltersTimeoutId: setTimeout(function () {\r\n that.setState({ applyFiltersTimeoutId: undefined });\r\n DataSvc.utilsSvc.getMeshRecommendations(inputValue).then((result: any) => {\r\n const diseaseOptions = result.map((m: any, i: any) => {\r\n return { id: m.treeNumbers.join(\";\"), name: m.originalTerm } as LookUpOptions;\r\n });\r\n\r\n resolve(that.mapOptionsToValues(diseaseOptions));\r\n },\r\n (error) => { console.error(error); })\r\n }, 800),\r\n });\r\n } else {\r\n resolve([]);\r\n }\r\n });\r\n }\r\n\r\n render() {\r\n return (\r\n <>\r\n <Form.Group>\r\n <Async\r\n isMulti={true}\r\n placeholder={this.props.placeholder ? this.props.placeholder : 'Enter a disease to get suggestions'}\r\n defaultValue={this.mapDiseaseOptionsToValues(this.props.value)}\r\n onChange={e => this.handleOnChange(e)}\r\n className='select-dropdown'\r\n styles={this.returnComponentStyles()}\r\n loadOptions={this.loadAutocompleteOptions}\r\n />\r\n {!!this.props.errorMsg &&\r\n <span className='text-danger'>{this.props.errorMsg}</span>\r\n }\r\n </Form.Group>\r\n </>\r\n );\r\n }\r\n}\r\n","import * as React from 'react';\r\nimport { Form } from 'react-bootstrap';\r\nimport { IconProp } from '@fortawesome/fontawesome-svg-core';\r\n\r\ntype OwnProps = {\r\n fieldName: string;\r\n text: string;\r\n value: boolean;\r\n errorMsg: string;\r\n};\r\n\r\ntype OwnState = {};\r\n\r\ntype DispatchProps = {\r\n onChange: (e: any) => void;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nclass EupatiCheckbox extends React.Component<Props, OwnState> {\r\n\r\n constructor(props: any) {\r\n super(props);\r\n\r\n this.returnProperIconType = this.returnProperIconType.bind(this);\r\n }\r\n\r\n returnProperIconType(icon: any) {\r\n return icon as IconProp;\r\n }\r\n\r\n render() {\r\n\r\n let btnComponent: any;\r\n\r\n btnComponent = (\r\n <Form.Group>\r\n <label className=\"form-check-container\">{this.props.text}\r\n <input\r\n id={this.props.fieldName}\r\n className='form-check-input'\r\n type=\"checkbox\"\r\n checked={this.props.value}\r\n onChange={(e: any) => this.props.onChange(e)}\r\n />\r\n <span className=\"form-check-checkmark\"></span>\r\n </label>\r\n\r\n </Form.Group>\r\n );\r\n\r\n return (\r\n <>\r\n {btnComponent}\r\n {!!this.props.errorMsg &&\r\n <span className='text-danger'>{this.props.errorMsg}</span>\r\n }\r\n </>\r\n );\r\n }\r\n}\r\n\r\nexport default EupatiCheckbox;","\r\nimport React from \"react\";\r\nimport { Button, Form } from \"react-bootstrap\";\r\nimport { Controller, useForm } from 'react-hook-form';\r\nimport { Rules, Messages } from \"../../../../common/helpers\";\r\nimport { useHistory } from \"react-router\";\r\nimport EupatiSelect from \"../../../../common/static/select-menu\";\r\nimport EupatiDiseaseAsyncSelect from \"../../../../common/static/async-select-menu\";\r\nimport EupatiCheckbox from \"../../../../common/static/checkbox-toggle\";\r\nimport { DiseaseInfo, Project } from \"../../../../common/models/main-models\";\r\nimport { LookUpOptions } from \"../../../../common/models/input-models\";\r\nimport { toast } from 'react-toastify';\r\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport { faInfoCircle } from '@fortawesome/fontawesome-free-solid';\r\nimport ReactTooltip from 'react-tooltip';\r\n\r\ntype OwnProps = {\r\n project: Project,\r\n isUserReal: boolean\r\n};\r\n\r\ntype DispatchProps = {\r\n setProject: (project: Project) => void;\r\n returnProperDefaultValue: (val: any) => any;\r\n showPatientsAdditionalInfoSection: () => void;\r\n returnProperIconType: (icon: any) => IconProp;\r\n findLookUpData: (lookUpDataType?: string) => LookUpOptions[] | null;\r\n prevPage: () => void;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\ntype FieldsProps = {\r\n countries: string[],\r\n languages: string[],\r\n diseases: DiseaseInfo[],\r\n noDiseaseExpertiseRequired: boolean;\r\n searchDiseaseTherapeuticArea: boolean;\r\n};\r\n\r\nconst CUSTOM_SPAN_STYLES = ({\r\n boldFont: {\r\n fontWeight: 600\r\n }\r\n});\r\nexport default function PatientsDiseaseInfo(props: Props) {\r\n\r\n const history = useHistory();\r\n\r\n const { handleSubmit, control, watch, formState: { errors } } = useForm();\r\n\r\n const fieldsData = {\r\n countries: watch(\"countries\") as string[],\r\n languages: watch(\"languages\") as string[],\r\n diseases: watch(\"diseases\") as DiseaseInfo[],\r\n noDiseaseExpertiseRequired: watch(\"noDiseaseExpertiseRequired\") as boolean,\r\n searchDiseaseTherapeuticArea: watch(\"searchDiseaseTherapeuticArea\") as boolean\r\n } as FieldsProps;\r\n\r\n const onSubmit = (data: any) => {\r\n if (!props.isUserReal) {\r\n toast.error(Messages.FAIL_AUTH_MSG);\r\n return history.push('/');\r\n }\r\n\r\n const updatedProject = Object.assign(props.project, data);\r\n props.setProject(updatedProject);\r\n props.showPatientsAdditionalInfoSection();\r\n }\r\n\r\n const onBackHandler = () => {\r\n if (!props.isUserReal) {\r\n toast.error(Messages.FAIL_AUTH_MSG);\r\n return history.push('/');\r\n }\r\n\r\n if (adjustFieldsValues() === 0) {\r\n const updatedProject = Object.assign(props.project, fieldsData);\r\n props.setProject(updatedProject);\r\n }\r\n props.prevPage();\r\n }\r\n\r\n const adjustFieldsValues = () => {\r\n if (fieldsData.countries === undefined &&\r\n fieldsData.languages === undefined &&\r\n fieldsData.diseases === undefined &&\r\n fieldsData.noDiseaseExpertiseRequired === undefined &&\r\n fieldsData.searchDiseaseTherapeuticArea === undefined) {\r\n return 1;\r\n }\r\n\r\n if (fieldsData.countries === undefined &&\r\n props.project.countries !== undefined) {\r\n fieldsData.countries = [...props.project.countries];\r\n }\r\n\r\n if (fieldsData.languages === undefined &&\r\n props.project.languages !== undefined) {\r\n fieldsData.languages = [...props.project.languages];\r\n }\r\n\r\n if (fieldsData.diseases === undefined &&\r\n props.project.diseases !== undefined) {\r\n fieldsData.diseases = [...props.project.diseases];\r\n }\r\n\r\n if (fieldsData.noDiseaseExpertiseRequired === undefined &&\r\n props.project.noDiseaseExpertiseRequired !== undefined) {\r\n fieldsData.noDiseaseExpertiseRequired = props.project.noDiseaseExpertiseRequired;\r\n }\r\n\r\n if (fieldsData.searchDiseaseTherapeuticArea === undefined &&\r\n props.project.searchDiseaseTherapeuticArea !== undefined) {\r\n fieldsData.searchDiseaseTherapeuticArea = props.project.searchDiseaseTherapeuticArea;\r\n }\r\n\r\n return 0;\r\n }\r\n\r\n const returnProperIconType = (icon: any) => {\r\n return icon as IconProp;\r\n }\r\n\r\n const toggleDiseaseClarificationField = () => {\r\n if (fieldsData.diseases === undefined || fieldsData.diseases === null) {\r\n return false;\r\n }\r\n else if (fieldsData.diseases.length === 0) {\r\n return false;\r\n }\r\n\r\n return true;\r\n }\r\n\r\n return (\r\n <Form className='pt' onSubmit={handleSubmit(onSubmit)}>\r\n <Form.Group className='pt-info'>\r\n <Form.Group className='lcolumn'>\r\n\r\n <Form.Group id='pt-ctrys' className='pt-info-field mb-5'>\r\n <Form.Label>Countries</Form.Label>\r\n <FontAwesomeIcon data-tip data-for='countriesInfo' icon={returnProperIconType(faInfoCircle)} />\r\n <ReactTooltip id='countriesInfo'>\r\n <span>Country(ies) where relevant patient engagement experience.</span>\r\n </ReactTooltip>\r\n <FontAwesomeIcon data-tip data-for='countriesControlInfo' icon={returnProperIconType(faInfoCircle)} />\r\n <ReactTooltip\r\n id='countriesControlInfo'\r\n multiline={true}>\r\n <span>\r\n It is possible to select multiple countries or continents.\r\n <br />\r\n You can achive that by typing their names in the input field.\r\n <br />\r\n Moreover, you can also pick them from the dropdown menu.\r\n <br />\r\n </span>\r\n </ReactTooltip>\r\n <Controller\r\n name='countries'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.countries)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiSelect\r\n {...{\r\n ...field,\r\n values: props.findLookUpData('countryWithContinents'),\r\n errorMsg: errors?.countries?.message,\r\n isAutocomplete: false\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='pt-langs' className='pt-info-field mb-5'>\r\n <Form.Label>Languages</Form.Label>\r\n <FontAwesomeIcon data-tip data-for='languagesControlInfo' icon={returnProperIconType(faInfoCircle)} />\r\n <ReactTooltip\r\n id='languagesControlInfo'\r\n multiline={true}>\r\n <span>\r\n It is possible to select multiple languages.\r\n <br />\r\n You can achive that by typing their names in the input field.\r\n <br />\r\n Moreover, you can also pick them from the dropdown menu.\r\n <br />\r\n </span>\r\n </ReactTooltip>\r\n <Controller\r\n name='languages'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.project.languages)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiSelect\r\n {...{\r\n ...field,\r\n values: props.findLookUpData('language'),\r\n errorMsg: errors?.languages?.message,\r\n isAutocomplete: false\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='pt-diseaseName' className='pt-info-field mb-5'>\r\n <Form.Label style={{ display: 'flex', flexDirection: 'column' }}>\r\n <span style={{ ...CUSTOM_SPAN_STYLES.boldFont }}>\r\n Therapeutic Areas or Diseases\r\n <FontAwesomeIcon data-tip data-for='diseasesControlInfo' icon={returnProperIconType(faInfoCircle)} />\r\n <ReactTooltip\r\n id='diseasesControlInfo'\r\n multiline={true}>\r\n <span>\r\n It is possible to select multiple diseases.\r\n <br />\r\n You can achive that by typing their names in the input field.\r\n <br />\r\n Moreover, you can also pick them from the dropdown menu.\r\n <br />\r\n </span>\r\n </ReactTooltip>\r\n </span>\r\n <span>\r\n <small style={{ fontSize: '11px' }}>\r\n Diseases are listed according to the US National Library of Medicine.\r\n You can find the controlled vocabulary, Medical Subject Headings (MEsH), <a href='https://meshb.nlm.nih.gov/search' target='_blank' >here.*</a>\r\n </small>\r\n </span>\r\n </Form.Label>\r\n\r\n <Controller\r\n name='diseases'\r\n control={control}\r\n defaultValue={props.project.diseases}\r\n rules={Rules.notRequired}\r\n render={({ field }) =>\r\n <EupatiDiseaseAsyncSelect\r\n {...{\r\n ...field,\r\n errorMsg: errors?.diseases?.message\r\n }}\r\n />\r\n }\r\n />\r\n {toggleDiseaseClarificationField() === false ? (\r\n <Controller\r\n name='noDiseaseExpertiseRequired'\r\n control={control}\r\n defaultValue={props.project.noDiseaseExpertiseRequired}\r\n rules={Rules.notRequired}\r\n render={({ field }) =>\r\n <EupatiCheckbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.noDiseaseExpertise?.message,\r\n fieldName: 'noDiseaseExpertiseRequired',\r\n text: 'No specific disease experience is required'\r\n }}\r\n />\r\n }\r\n />\r\n ) : (\r\n <Controller\r\n name='searchDiseaseTherapeuticArea'\r\n control={control}\r\n defaultValue={props.project.searchDiseaseTherapeuticArea}\r\n rules={Rules.notRequired}\r\n render={({ field }) =>\r\n <EupatiCheckbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.searchDiseaseTherapeuticArea?.message,\r\n fieldName: 'searchDiseaseTherapeuticArea',\r\n text: 'Match patients in the therapeutic area(s) as well(i.e. If Breast Cancer is selected, it would broaden the match to all Oncology experts).'\r\n }}\r\n />\r\n }\r\n />\r\n )}\r\n </Form.Group>\r\n\r\n <Form.Group id='pt-btns' className='pt-info-field'>\r\n <Button className='bck' variant='secondary' onClick={onBackHandler} >Back</Button>\r\n <Button className='nxt' variant='primary' type='submit'>Next</Button>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form >\r\n )\r\n}","import { IconProp } from '@fortawesome/fontawesome-svg-core';\r\nimport React, { useState } from 'react';\r\nimport { LookUpOptions } from '../../../../common/models/input-models';\r\nimport { Project } from '../../../../common/models/main-models';\r\nimport PatientsAdditionalInfo from './additional';\r\nimport PatientsDiseaseInfo from './disease';\r\n\r\ntype OwnProps = {\r\n project: Project,\r\n isUserReal: boolean,\r\n showSecondSubComponent: boolean\r\n};\r\n\r\ntype DispatchProps = {\r\n prevPage: () => void;\r\n nextPage: () => void;\r\n setProject: (project: Project) => void;\r\n setIsUserReal: (token: string) => void;\r\n submitProject: (project: Project) => void;\r\n returnProperDefaultValue: (val: any) => any;\r\n findLookUpData: (lookUpDataType?: string) => LookUpOptions[] | null;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nexport default function PatientInfo(props: Props) {\r\n const [nextBtnClicked, setNextBtnClicked] = useState<boolean>(props.showSecondSubComponent);\r\n\r\n const toggleSectionVisibility = () => {\r\n setNextBtnClicked(!nextBtnClicked);\r\n //window.scrollTo(0, 0);\r\n }\r\n\r\n function returnProperIconType(icon: any) {\r\n return icon as IconProp;\r\n }\r\n\r\n return (\r\n <div style={{ margin: '0 0 7.5rem 0' }}>\r\n\r\n {nextBtnClicked &&\r\n <PatientsDiseaseInfo\r\n {...{\r\n project: props.project,\r\n setProject: props.setProject,\r\n returnProperDefaultValue: props.returnProperDefaultValue,\r\n showPatientsAdditionalInfoSection: toggleSectionVisibility,\r\n isUserReal: props.isUserReal,\r\n returnProperIconType: returnProperIconType,\r\n findLookUpData: props.findLookUpData,\r\n prevPage: props.prevPage\r\n }}\r\n />\r\n }\r\n\r\n {!nextBtnClicked &&\r\n <PatientsAdditionalInfo\r\n {...{\r\n project: props.project,\r\n submitProject: props.submitProject,\r\n nextPage: props.nextPage,\r\n setProject: props.setProject,\r\n hidePatientsAdditionalInfoSection: toggleSectionVisibility,\r\n returnProperDefaultValue: props.returnProperDefaultValue,\r\n isUserReal: props.isUserReal,\r\n findLookUpData: props.findLookUpData\r\n }}\r\n />\r\n }\r\n </div>\r\n )\r\n}","import * as React from 'react';\r\nimport { Form } from 'react-bootstrap';\r\nimport { NavLink } from 'react-router-dom';\r\n\r\ntype OwnProps = {};\r\n\r\nexport type DispatchProps = {};\r\n\r\ntype Props = {} & DispatchProps & OwnProps;\r\n\r\ntype OwnState = {};\r\n\r\nexport default class EupatiConfirmPage extends React.Component<Props, OwnState> {\r\n render() {\r\n return (\r\n <div style={{ marginTop: '5rem' }}>\r\n <Form.Group className='confirm-page-wrapper'>\r\n <h2>Thanks for your submission!</h2>\r\n <h4>We will contact you soon.</h4>\r\n <li className='nav-item'>\r\n <NavLink className='confirm-page-btn nav-link' to='/' style={{ color: '#fff' }}>Back To EUPATI</NavLink>\r\n </li>\r\n </Form.Group>\r\n </div>\r\n );\r\n }\r\n}","import * as React from 'react';\r\nimport { emptyProject, State } from '../model';\r\nimport '../style.scss';\r\nimport { Project } from '../../../common/models/main-models';\r\nimport EupatiLoader from '../../../common/static/loading-animation/loader';\r\nimport ProjectInfo from './project-info';\r\nimport ResearcherInfo from './researcher-info';\r\nimport PatientInfo from './patient-info';\r\nimport EupatiConfirmPage from '../../../common/static/confirm-page';\r\nimport { GoogleReCaptcha } from 'react-google-recaptcha-v3';\r\nimport { Form } from 'react-bootstrap';\r\nimport { RouteComponentProps } from '@reach/router';\r\nimport { INVALID_PRICING_DATA } from '../../../common/helpers/messages';\r\nimport { toast } from 'react-toastify';\r\n\r\ntype OwnProps = {};\r\n\r\nexport type DispatchProps = {\r\n\tsetProject: (project: Project) => void;\r\n\tsetLookUpData: () => void;\r\n\tsubmitNewProject: (project: Project) => void;\r\n\tsetIsUserReal: (token: string) => void;\r\n};\r\n\r\ntype Props = State & DispatchProps & OwnProps & RouteComponentProps<{ location: { state: { price: number, plan: string, package: string, paymentMethod: string } } }>;\r\n\r\ntype OwnState = {\r\n\tshowComponentByIndex: number;\r\n\tshowSecondSubComponent: boolean;\r\n};\r\n\r\nclass ComponentRoot extends React.Component<Props, OwnState> {\r\n\r\n\tconstructor(props: any) {\r\n\t\tsuper(props);\r\n\r\n\t\tthis.state = {\r\n\t\t\tshowComponentByIndex: 0,\r\n\t\t\tshowSecondSubComponent: true\t// when this is \"true\" on render it will show the first subcomponent (ResearcherInfo --> PersonalInfo).\r\n\t\t}\r\n\r\n\t\tthis.submitProject = this.submitProject.bind(this);\r\n\t\tthis.nextPageHandler = this.nextPageHandler.bind(this);\r\n\t\tthis.previousPageHandler = this.previousPageHandler.bind(this);\r\n\t\tthis.findLookUpData = this.findLookUpData.bind(this);\r\n\t\tthis.returnProperDefaultValue = this.returnProperDefaultValue.bind(this);\r\n\t\tthis.returnProperLookUpData = this.returnProperLookUpData.bind(this);\r\n\t}\r\n\r\n\tcomponentDidMount() {\r\n\t\tconst historyState = this.props.location?.state;\r\n\t\tif (historyState === undefined || historyState.price < 0 ||\r\n\t\t\thistoryState.package === '' || historyState.paymentMethod === '') {\r\n\t\t\ttoast.error(INVALID_PRICING_DATA);\r\n\t\t\twindow.location.href = '/pricing';\r\n\t\t}\r\n\t\tconst initialProjectData = Object.assign(emptyProject, { ...historyState });\r\n\t\tthis.props.setLookUpData();\r\n\t\tthis.props.setProject(initialProjectData);\r\n\t}\r\n\r\n\tsubmitProject() {\r\n\t\tthis.props.submitNewProject(this.props.project);\r\n\t}\r\n\r\n\tnextPageHandler() {\r\n\t\tif (this.state.showComponentByIndex !== 3) {\r\n\t\t\tthis.setState(prevState => ({\r\n\t\t\t\tshowComponentByIndex: prevState.showComponentByIndex + 1,\r\n\t\t\t\tshowSecondSubComponent: true\r\n\t\t\t}));\r\n\t\t}\r\n\t\t//window.scrollTo(0, 0);\r\n\t}\r\n\r\n\tpreviousPageHandler() {\r\n\t\tif (this.state.showComponentByIndex !== 0) {\r\n\t\t\tthis.setState(prevState => ({\r\n\t\t\t\tshowComponentByIndex: prevState.showComponentByIndex - 1,\r\n\t\t\t\tshowSecondSubComponent: false\r\n\t\t\t}));\r\n\t\t}\r\n\t\t//window.scrollTo(0, 0);\r\n\t}\r\n\r\n\tfindLookUpData(lookUpDataType?: string) {\r\n\t\tif (this.props.lookUpData &&\r\n\t\t\tthis.props.lookUpData.length > 0) {\r\n\t\t\treturn this.props.lookUpData?.filter((x: any) => x.name == lookUpDataType)[0]?.data;\r\n\t\t}\r\n\r\n\t\treturn [];\r\n\t}\r\n\r\n\treturnProperDefaultValue(val: any) {\r\n\t\treturn val ? val : '';\r\n\t}\r\n\r\n\treturnProperLookUpData(dataType: any) {\r\n\t\treturn typeof dataType !== 'undefined' ? this.findLookUpData(dataType) : null\r\n\t}\r\n\r\n\trender() {\r\n\r\n\t\tlet mainComponent: any;\r\n\r\n\t\tlet loadingComponent = (\r\n\t\t\t<div className='loader-wrapper'>\r\n\t\t\t\t<EupatiLoader />\r\n\t\t\t</div>\r\n\t\t);\r\n\r\n\t\tconst props = {\r\n\t\t\tproject: this.props.project,\r\n\t\t\tlookUpData: this.props.lookUpData,\r\n\t\t\tisUserReal: this.props.isUserReal,\r\n\t\t\tshowSecondSubComponent: this.state.showSecondSubComponent,\r\n\t\t\tsetProject: this.props.setProject,\r\n\t\t\tnextPage: this.nextPageHandler,\r\n\t\t\tprevPage: this.previousPageHandler,\r\n\t\t\tsubmitProject: this.props.submitNewProject,\r\n\t\t\tfindLookUpData: this.findLookUpData,\r\n\t\t\treturnProperDefaultValue: this.returnProperDefaultValue,\r\n\t\t\tsetIsUserReal: this.props.setIsUserReal,\r\n\t\t\treturnProperLookUpData: this.returnProperLookUpData\r\n\t\t};\r\n\r\n\t\tconst spanStyles = {\r\n\t\t\tfontWeight: 'bolder',\r\n\t\t\t//textDecoration: 'underline',\r\n\t\t\tbackgroundColor: '#00749F',\r\n\t\t\tborderRadius: '30px',\r\n\t\t\tcolor: '#fff'\r\n\t\t} as any;\r\n\r\n\t\tif (this.props.isLoading) {\r\n\t\t\tmainComponent = loadingComponent;\r\n\t\t}\r\n\t\telse {\r\n\t\t\tmainComponent = (\r\n\t\t\t\t<>\r\n\t\t\t\t\t<GoogleReCaptcha action='newProjectPage' onVerify={token => this.props.setIsUserReal(token)} />\r\n\t\t\t\t\t<h2 className='heading' style={this.state.showComponentByIndex === 3 ? { display: 'none' } : {}}>Project Request</h2>\r\n\t\t\t\t\t{this.state.showComponentByIndex !== 3 &&\r\n\t\t\t\t\t\t<Form.Group className='titles-wrapper'>\r\n\t\t\t\t\t\t\t<div className='titles'>\r\n\t\t\t\t\t\t\t\t<div className='titles-title' style={this.state.showComponentByIndex === 0 ? { ...spanStyles } : {}}>\r\n\t\t\t\t\t\t\t\t\t<span >1. Personal info</span>\r\n\t\t\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t\t\t<div className='titles-title' style={this.state.showComponentByIndex === 1 ? { ...spanStyles } : {}}>\r\n\t\t\t\t\t\t\t\t\t<span >2. Project data</span>\r\n\t\t\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t\t\t<div className='titles-title' style={this.state.showComponentByIndex === 2 ? { ...spanStyles } : {}}>\r\n\t\t\t\t\t\t\t\t\t<span >3. EUPATI Experts</span>\r\n\t\t\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t</Form.Group>\r\n\t\t\t\t\t}\r\n\t\t\t\t\t{this.state.showComponentByIndex === 0 && <ResearcherInfo {...props} />}\r\n\t\t\t\t\t{this.state.showComponentByIndex === 1 && <ProjectInfo {...props} />}\r\n\t\t\t\t\t{this.state.showComponentByIndex === 2 && <PatientInfo {...props} />}\r\n\t\t\t\t\t{this.state.showComponentByIndex === 3 && <EupatiConfirmPage />}\r\n\t\t\t\t</>\r\n\t\t\t)\r\n\t\t}\r\n\r\n\t\treturn (\r\n\t\t\t<>\r\n\t\t\t\t{mainComponent}\r\n\t\t\t</>\r\n\t\t);\r\n\t}\r\n}\r\n\r\nexport default ComponentRoot;","import { default as RootComponent, DispatchProps } from '../components/component-root';\r\nimport * as Actions from '../actions';\r\nimport * as Constants from '../constants';\r\nimport { State } from '../model';\r\nimport { connect } from 'react-redux';\r\nimport { Project } from '../../../common/models/main-models';\r\n\r\nexport function mapStateToProps(globalState: any) {\r\n let name = Constants.NAME;\r\n let pageState = globalState[name] as State;\r\n return pageState;\r\n}\r\n\r\nexport function mapDispatchToProps(dispatch: any) {\r\n return {\r\n setProject: (project: Project) => dispatch(Actions.setProject(project)),\r\n setLookUpData: () => dispatch(Actions.getLookUpDataAsync()),\r\n submitNewProject: (project: Project) => dispatch(Actions.saveNewProjectAsync(project)),\r\n setIsUserReal: (token: string) => dispatch(Actions.verifyUserTokenAsync(token))\r\n } as DispatchProps;\r\n}\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(RootComponent);","import { LookUpData, MeshData } from '../../common/models/input-models';\r\nimport { Project } from '../../common/models/main-models';\r\nimport * as t from './actionTypes';\r\nimport { emptyProject, State } from './model';\r\n\r\nconst initialState: State = {\r\n project: emptyProject,\r\n isLoading: false,\r\n lookUpData: [],\r\n isUserReal: true\r\n};\r\n\r\nexport default (state = initialState, action: any): State => {\r\n switch (action.type) {\r\n case t.SET_PROJECTS_LOADING:\r\n return setProjectsLoading(state, action.payload);\r\n case t.SET_PROJECT:\r\n return setProject(state, action.payload);\r\n case t.SET_LOOKUP_DATA:\r\n return setLookUpData(state, action.payload);\r\n case t.SET_IS_USER_REAL:\r\n return setIsUserReal(state, action.payload);\r\n default:\r\n return state;\r\n }\r\n};\r\n\r\nconst setIsUserReal = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n setIsUserReal: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setProjectsLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setProject = (state: State, val: Project): State => {\r\n let newState = {\r\n ...state,\r\n project: { ...val }\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setLookUpData = (state: State, val: LookUpData[]): State => {\r\n let newState = {\r\n ...state,\r\n lookUpData: [...val]\r\n } as State;\r\n\r\n return newState;\r\n}\r\n","import * as Actions from './actions';\r\nimport * as Components from './components/index';\r\nimport * as Containers from './containers/index';\r\nimport * as Constants from './constants';\r\nimport Reducer from './reducer';\r\n\r\nexport default {\r\n actions: Actions,\r\n components: Components,\r\n containers: Containers,\r\n constants: Constants,\r\n reducer: Reducer\r\n};\r\n\r\nexport const Root = Containers.ComponentRoot;","// constants.ts\r\nexport const NAME = 'patientProfile';","// actionTypes.js\r\nimport { NAME } from './constants';\r\n\r\nexport const SET_PATIENTS_LOADING = `${NAME}/SET_PATIENTS_LOADING`;\r\n\r\nexport const SET_LOOKUP_DATA = `${NAME}/SET_LOOKUP_DATA`;\r\n\r\nexport const SET_PATIENT_INFO = `${NAME}/SET_PATIENT_INFO`;\r\n\r\nexport const SET_PATIENT_DATA_LOADING = `${NAME}/SET_PATIENT_DATA_LOADING`;","// model.js\r\n// This is the model of our module state (e.g. return type of the reducer)\r\n\r\nimport { LookUpData, MeshData } from \"../../common/models/input-models\";\r\nimport { Patient } from \"../../common/models/main-models\";\r\n\r\nexport type State = {\r\n patient: Patient;\r\n isLoading: boolean;\r\n lookUpData: LookUpData[];\r\n isPatientDataLoaded: boolean;\r\n};\r\n\r\nexport const defaultPatientInfo = {\r\n id: '',\r\n firstName: '',\r\n lastName: '',\r\n phoneNumber: '',\r\n email: '',\r\n birthYear: undefined,\r\n genderTypeId: 0,\r\n countryId: 0,\r\n languages: [],\r\n countriesWithExperience: [],\r\n isPOAffiliated: false,\r\n patientOrganisation: '',\r\n\r\n diseases: [],\r\n noDiseaseExpertise: false,\r\n // diseaseName: '',\r\n // diseaseMeshId: '',\r\n // diseaseTAName: '',\r\n // diseaseTAMeshId: '',\r\n patientExperienceId: 0,\r\n patientExpertises: [],\r\n projectTypeExperiences: [],\r\n projectTypeExperiencesDescription: '',\r\n otherInformation: '',\r\n patientExpertiseDescription: '',\r\n genderTypeDescription: '',\r\n organisationPreferenceDescription: '',\r\n projectPreferenceDescription: '',\r\n\r\n isEligibleForCompensation: false,\r\n isAvailableForNoCompensation: false,\r\n projectPreferences: [],\r\n organisationPreferences: [],\r\n activityPreferenceId: 0,\r\n\r\n matchedProjects: [],\r\n confirmedProjects: [],\r\n isBannedFromSearch: false,\r\n isGDPRConsentGiven: false,\r\n} as Patient;","// matching/actions.js\r\nimport { LookUpData } from '../../common/models/input-models';\r\nimport { Patient } from '../../common/models/main-models';\r\nimport DataSvc from '../../common/services/data-svc';\r\nimport * as t from './actionTypes';\r\nimport { defaultPatientInfo } from './model';\r\n\r\nexport const setPatientLoading = (isLoading: boolean) => ({\r\n type: t.SET_PATIENTS_LOADING,\r\n payload: isLoading,\r\n});\r\n\r\nexport const setLookUpData = (data: LookUpData[]) => ({\r\n type: t.SET_LOOKUP_DATA,\r\n payload: data\r\n});\r\n\r\nexport const setPatientInfo = (patient: Patient) => ({\r\n type: t.SET_PATIENT_INFO,\r\n payload: patient\r\n});\r\n\r\nexport const setPatientDataLoading = (isPatientDataLoaded: boolean) => ({\r\n type: t.SET_PATIENT_DATA_LOADING,\r\n payload: isPatientDataLoaded\r\n});\r\n\r\nexport const getLookUpDataAsync = () => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setPatientLoading(true));\r\n DataSvc.utilsSvc.getLookUpData().then(\r\n (result: any) => {\r\n dispatch(setLookUpData(result));\r\n dispatch(setPatientLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n );\r\n };\r\n};\r\n\r\nexport const updatePatientAsync = (patient: Patient) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setPatientLoading(true));\r\n DataSvc.patientSvc.updatePatient(getRidOfIncorrectNullValues(patient)).then(\r\n (result: any) => {\r\n dispatch(setPatientInfo(result));\r\n dispatch(setPatientLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const saveNewPatientAsync = (patient: Patient) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setPatientLoading(true));\r\n DataSvc.patientSvc.savePatient(getRidOfIncorrectNullValues(patient)).then(\r\n () => {\r\n dispatch(setPatientInfo(defaultPatientInfo)); // return to default state on submit\r\n dispatch(setPatientLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const getPatientInfoByIdAsync = (patientId?: string) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setPatientDataLoading(true));\r\n if (patientId) {\r\n DataSvc.patientSvc.getPatientById(patientId).then(\r\n (result: any) => {\r\n dispatch(setPatientInfo(result));\r\n dispatch(setPatientDataLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n else {\r\n dispatch(setPatientInfo(defaultPatientInfo));\r\n dispatch(setPatientDataLoading(false));\r\n }\r\n };\r\n};\r\n\r\nexport const getPatientInfoByUserIdAsync = (userId?: string) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setPatientDataLoading(true));\r\n if (userId) {\r\n DataSvc.patientSvc.getPatientByUserId(userId).then(\r\n (result: any) => {\r\n dispatch(setPatientInfo(result));\r\n dispatch(setPatientDataLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n }\r\n}\r\n\r\nfunction getRidOfIncorrectNullValues(object: any) {\r\n var updatedPatientObject = { ...object };\r\n if (updatedPatientObject.isAvailableForNoCompensation === 'null') {\r\n updatedPatientObject.isAvailableForNoCompensation = null;\r\n }\r\n if (updatedPatientObject.isEligibleForCompensation === 'null') {\r\n updatedPatientObject.isEligibleForCompensation = null;\r\n }\r\n return updatedPatientObject;\r\n}","import React from \"react\";\r\nimport { Button, Form } from \"react-bootstrap\";\r\nimport { useForm, Controller } from \"react-hook-form\";\r\nimport { Rules } from \"../../../../common/helpers\";\r\nimport EupatiTextbox from \"../../../../common/static/textbox\";\r\nimport EupatiEmailbox from \"../../../../common/static/emailbox\";\r\nimport { Patient } from \"../../../../common/models/main-models\";\r\n\r\ntype OwnProps = {\r\n patient: Patient\r\n};\r\n\r\ntype DispatchProps = {\r\n setPatientInfo: (patient: Patient) => void;\r\n showPatientSpecificInfoSection: () => void;\r\n returnProperDefaultValue: (val: any) => any;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nexport default function PatientGenericInfo(props: Props) {\r\n\r\n const { handleSubmit, control, watch, formState: { errors } } = useForm();\r\n\r\n const onSubmit = (data: any) => {\r\n const editedPatientInfo = Object.assign(props.patient, data);\r\n props.setPatientInfo(editedPatientInfo);\r\n props.showPatientSpecificInfoSection();\r\n }\r\n\r\n return (\r\n <Form className='profile' onSubmit={handleSubmit(onSubmit)}>\r\n <Form.Group className='profile-info'>\r\n <Form.Group className='lcolumn'>\r\n\r\n <Form.Group id='pt-fname' className='profile-info-field mb-3'>\r\n <Form.Label>First name</Form.Label>\r\n <Controller\r\n name='firstName'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.firstName)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.firstName?.message,\r\n placeholder: 'Please type first name'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='pt-lname' className='profile-info-field mb-3'>\r\n <Form.Label>Surname</Form.Label>\r\n <Controller\r\n name='lastName'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.lastName)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.lastName?.message,\r\n placeholder: 'Please type last name'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='pt-tel' className='profile-info-field mb-3'>\r\n <Form.Label>Phone</Form.Label>\r\n <Controller\r\n name='phoneNumber'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.phoneNumber)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.phoneNumber?.message,\r\n placeholder: 'Please type phone number'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='pt-year' className='profile-info-field mb-3'>\r\n <Form.Label>Year of birth</Form.Label>\r\n <Controller\r\n name='birthYear'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.birthYear)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.birthYear?.message,\r\n fieldType: 'number',\r\n placeholder: 'Please type year of birth'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='pt-email' className='profile-info-field mb-3'>\r\n <Form.Label>Email</Form.Label>\r\n <Controller\r\n name='email'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.email)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiEmailbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.email?.message\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n\r\n <Form.Group id='pt-btns'>\r\n <Button className='bck' variant='secondary' type='submit' style={{ visibility: 'hidden' }}>Back</Button>\r\n <Button className='nxt' variant='primary' type='submit'>Next</Button>\r\n </Form.Group>\r\n\r\n </Form.Group>\r\n </Form.Group>\r\n </Form>\r\n )\r\n}","import React from \"react\";\r\nimport { Button, Form } from \"react-bootstrap\";\r\nimport { useForm, Controller } from \"react-hook-form\";\r\nimport { Rules } from \"../../../../common/helpers\";\r\nimport EupatiDropdown from \"../../../../common/static/dropdown\";\r\nimport EupatiSelect from \"../../../../common/static/select-menu\";\r\nimport EupatiTextbox from \"../../../../common/static/textbox\";\r\nimport EupatiNonCMSToggleBtn from \"../../../../common/static/toggle-btn-nonCMS\";\r\nimport EupatiToggleBtn from \"../../../../common/static/toggle-btn\";\r\nimport { Patient } from \"../../../../common/models/main-models\";\r\nimport { LookUpOptions } from \"../../../../common/models/input-models\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport { faInfoCircle } from '@fortawesome/fontawesome-free-solid';\r\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\r\nimport ReactTooltip from 'react-tooltip';\r\n\r\ntype OwnProps = {\r\n patient: Patient\r\n};\r\n\r\ntype DispatchProps = {\r\n nextPage: () => void;\r\n setPatientInfo: (patient: Patient) => void;\r\n hidePatientSpecificInfoSection: () => void;\r\n returnProperDefaultValue: (val: any) => any;\r\n findLookUpData: (lookUpDataType?: string) => LookUpOptions[] | null;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\ntype FieldProps = {\r\n countryId?: number,\r\n languages: string[],\r\n countriesWithExperience: string[],\r\n genderTypeId?: number,\r\n genderTypeDescription: string,\r\n isPOAffiliated?: boolean,\r\n patientOrganisation: string\r\n};\r\n\r\nexport default function PatientSpecificInfo(props: Props) {\r\n\r\n const { handleSubmit, control, watch, formState: { errors } } = useForm();\r\n\r\n const fieldsData = {\r\n countryId: watch(\"countryId\") as number | undefined,\r\n languages: watch(\"languages\") as string[],\r\n countriesWithExperience: watch(\"countriesWithExperience\") as string[],\r\n genderTypeId: watch(\"genderTypeId\") as number | undefined,\r\n genderTypeDescription: watch(\"genderTypeDescription\") as string,\r\n isPOAffiliated: watch(\"isPOAffiliated\") as boolean | undefined,\r\n patientOrganisation: watch(\"patientOrganisation\") as string\r\n } as FieldProps;\r\n\r\n const onSubmit = (data: any) => {\r\n const editedPatientInfo = Object.assign(props.patient, data);\r\n props.setPatientInfo(editedPatientInfo);\r\n props.nextPage();\r\n }\r\n\r\n const onBackHandler = () => {\r\n if (adjustFieldsValues() === 0) {\r\n const editedPatientInfo = Object.assign(props.patient, fieldsData);\r\n props.setPatientInfo(editedPatientInfo);\r\n }\r\n props.hidePatientSpecificInfoSection();\r\n }\r\n\r\n const returnProperIconType = (icon: any) => {\r\n return icon as IconProp;\r\n }\r\n\r\n const fieldIsPOAffiliatedToggle = () => {\r\n if (fieldsData?.isPOAffiliated?.toString() === \"true\") {\r\n return true;\r\n }\r\n else if (fieldsData?.isPOAffiliated?.toString() === \"false\") {\r\n return false;\r\n }\r\n\r\n if (props.patient.isPOAffiliated !== undefined &&\r\n props.patient.isPOAffiliated !== null) {\r\n if (props?.patient?.isPOAffiliated.toString() === \"true\") {\r\n return true;\r\n }\r\n }\r\n\r\n return false;\r\n }\r\n\r\n const fieldGenderTypeToggle = () => {\r\n const otherGenderType = props.findLookUpData(\"genderType\")?.find(gt => gt.name.toLowerCase().includes('other'));\r\n if (fieldsData.genderTypeId !== undefined && fieldsData.genderTypeId !== null) {\r\n return otherGenderType?.id === fieldsData.genderTypeId ? true : false;\r\n }\r\n if (props.patient.genderTypeId !== undefined && props.patient.genderTypeId !== null) {\r\n return otherGenderType?.id.toString() === props.patient.genderTypeId.toString() ? true : false;\r\n }\r\n\r\n return false;\r\n }\r\n\r\n const checkNullOrUndefined = (val: any) => {\r\n return typeof val === undefined || val === null || val === 0 ? true : false;\r\n }\r\n\r\n const adjustFieldsValues = () => {\r\n if (fieldsData.countryId === undefined &&\r\n fieldsData.languages === undefined &&\r\n fieldsData.countriesWithExperience === undefined &&\r\n fieldsData.genderTypeId === undefined &&\r\n fieldsData.genderTypeDescription === undefined &&\r\n fieldsData.isPOAffiliated === undefined &&\r\n fieldsData.patientOrganisation === undefined) {\r\n return 1;\r\n }\r\n\r\n if (fieldsData.countryId === undefined &&\r\n props.patient.countryId !== undefined) {\r\n fieldsData.countryId = props.patient.countryId;\r\n }\r\n\r\n if (fieldsData.languages === undefined &&\r\n props.patient.languages !== undefined) {\r\n fieldsData.languages = [...props.patient.languages];\r\n }\r\n\r\n if (fieldsData.countriesWithExperience === undefined &&\r\n props.patient.countriesWithExperience !== undefined) {\r\n fieldsData.countriesWithExperience = [...props.patient.countriesWithExperience];\r\n }\r\n\r\n if (fieldsData.genderTypeId === undefined &&\r\n props.patient.genderTypeId !== undefined) {\r\n fieldsData.genderTypeId = props.patient.genderTypeId;\r\n }\r\n\r\n if (fieldsData.genderTypeDescription === undefined &&\r\n props.patient.genderTypeDescription !== undefined) {\r\n fieldsData.genderTypeDescription = props.patient.genderTypeDescription;\r\n }\r\n\r\n if (fieldsData.isPOAffiliated === undefined &&\r\n props.patient.isPOAffiliated !== undefined) {\r\n fieldsData.isPOAffiliated = props.patient.isPOAffiliated;\r\n }\r\n\r\n if (fieldsData.patientOrganisation === undefined &&\r\n props.patient.patientOrganisation !== undefined) {\r\n fieldsData.patientOrganisation = props.patient.patientOrganisation;\r\n }\r\n\r\n return 0;\r\n }\r\n\r\n return (\r\n <Form className='profile' onSubmit={handleSubmit(onSubmit)}>\r\n <Form.Group className='profile-info'>\r\n <Form.Group className='rcolumn'>\r\n\r\n <Form.Group id='pt-ctry' className='profile-info-field mb-4'>\r\n <Form.Label>Country of residence</Form.Label>\r\n <Controller\r\n name='countryId'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.countryId)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiDropdown\r\n {...{\r\n ...field,\r\n errorMsg: errors?.countryId?.message,\r\n values: props.findLookUpData('country'),\r\n fieldName: 'countryId',\r\n defaultOptionText: checkNullOrUndefined(props.patient.countryId) ? 'Please select country...' : undefined\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='pt-lang' className='profile-info-field mb-4'>\r\n <Form.Label>Languages</Form.Label>\r\n <FontAwesomeIcon data-tip data-for='languagesControlInfo' icon={returnProperIconType(faInfoCircle)} />\r\n <ReactTooltip\r\n id='languagesControlInfo'\r\n multiline={true}>\r\n <span>\r\n It is possible to select multiple languages.\r\n <br />\r\n You can achive that by typing their names in the input field.\r\n <br />\r\n Moreover, you can also pick them from the dropdown menu.\r\n <br />\r\n </span>\r\n </ReactTooltip>\r\n <Controller\r\n name='languages'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.languages)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiSelect\r\n {...{\r\n ...field,\r\n errorMsg: errors?.languages?.message,\r\n values: props.findLookUpData('language'),\r\n placeholder: 'Select languages...',\r\n isAutocomplete: false\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='pt-otherCtry' className='profile-info-field mb-4'>\r\n <Form.Label >Other country(ies) experience</Form.Label>\r\n <FontAwesomeIcon data-tip data-for='otherCtryInfo' icon={returnProperIconType(faInfoCircle)} />\r\n <ReactTooltip id='otherCtryInfo'>\r\n <span>Country(ies) in which you have experience relevant to patient engagement</span>\r\n </ReactTooltip>\r\n <FontAwesomeIcon data-tip data-for='otherCtryControlInfo' icon={returnProperIconType(faInfoCircle)} />\r\n <ReactTooltip\r\n id='otherCtryControlInfo'\r\n multiline={true}>\r\n <span>\r\n It is possible to select multiple countries or continents.\r\n <br />\r\n You can achive that by typing their names in the input field.\r\n <br />\r\n Moreover, you can also pick them from the dropdown menu.\r\n <br />\r\n </span>\r\n </ReactTooltip>\r\n <Controller\r\n name='countriesWithExperience'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.countriesWithExperience)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiSelect\r\n {...{\r\n ...field,\r\n errorMsg: errors?.countriesWithExperience?.message,\r\n values: props.findLookUpData('countryWithContinents'),\r\n isAutocomplete: false\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='pt-gender' className='profile-info-field mb-4'>\r\n <Form.Label>Gender</Form.Label>\r\n <Controller\r\n name='genderTypeId'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.genderTypeId)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiToggleBtn\r\n {...{\r\n ...field,\r\n errorMsg: errors?.genderTypeId?.message,\r\n fieldName: 'genderTypeId',\r\n values: props.findLookUpData('genderType')\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n {fieldGenderTypeToggle() &&\r\n <Form.Group id='pt-genderDescr' className='profile-info-field mb-4'>\r\n <Form.Label>Please specify the gender type</Form.Label>\r\n <Controller\r\n name='genderTypeDescription'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.genderTypeDescription)}\r\n rules={Rules.notRequired}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.genderTypeDescription?.message,\r\n placeholder: 'Please specify gender type'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n }\r\n\r\n <div>\r\n <Form.Group id='pt-poa' className='profile-info-field mb-3'>\r\n <Form.Label>Affiliation to a patient organisation</Form.Label>\r\n <Controller\r\n name='isPOAffiliated'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.isPOAffiliated)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiNonCMSToggleBtn\r\n {...{\r\n ...field,\r\n errorMsg: errors?.isPOAffiliated?.message,\r\n fieldName: 'isPOAffiliated',\r\n isMoreThanTwoOptions: false\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n {fieldIsPOAffiliatedToggle() &&\r\n <Form.Group id='pt-org' className='profile-info-field mb-4'>\r\n <Form.Label>Patient organisation</Form.Label>\r\n <Controller\r\n name='patientOrganisation'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.patientOrganisation)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.patientOrganisation?.message,\r\n placeholder: 'Please type patient organisation'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n }\r\n </div>\r\n\r\n <Form.Group id='pt-btns'>\r\n <Button className='bck' variant='secondary' type='submit' onClick={onBackHandler}>Back</Button>\r\n <Button className='nxt' variant='primary' type='submit'>Next</Button>\r\n </Form.Group>\r\n\r\n </Form.Group>\r\n </Form.Group>\r\n </Form>\r\n )\r\n}","import React, { useState } from \"react\";\r\nimport { LookUpData, LookUpOptions } from \"../../../../common/models/input-models\";\r\nimport { Patient } from \"../../../../common/models/main-models\";\r\nimport PatientGenericInfo from \"./generic\";\r\nimport PatientSpecificInfo from \"./specific\";\r\n\r\ntype OwnProps = {\r\n patient: Patient,\r\n lookUpData: LookUpData[],\r\n showSecondSubComponent: boolean\r\n};\r\n\r\ntype DispatchProps = {\r\n nextPage: () => void;\r\n prevPage: () => void;\r\n savePatient: (project: Patient) => void;\r\n setPatientInfo: (project: Patient) => void;\r\n returnProperDefaultValue: (val: any) => any;\r\n findLookUpData: (lookUpDataType?: string) => LookUpOptions[] | null;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nexport default function PatientGeneralInfo(props: Props) {\r\n const [nextBtnClicked, setNextBtnClicked] = useState<boolean>(props.showSecondSubComponent);\r\n\r\n const toggleSectionVisibility = () => {\r\n setNextBtnClicked(!nextBtnClicked);\r\n }\r\n\r\n return (\r\n <div style={{ margin: '0 0 7.5rem 0' }}>\r\n\r\n {nextBtnClicked &&\r\n <PatientGenericInfo\r\n {...{\r\n ...props,\r\n showPatientSpecificInfoSection: toggleSectionVisibility\r\n }}\r\n />\r\n }\r\n\r\n {!nextBtnClicked &&\r\n <PatientSpecificInfo\r\n {...{\r\n ...props,\r\n hidePatientSpecificInfoSection: toggleSectionVisibility\r\n }}\r\n />\r\n }\r\n\r\n </div>\r\n );\r\n}","import React, { useState, useEffect } from \"react\";\r\nimport { Button, Form } from \"react-bootstrap\";\r\nimport { useForm, Controller } from \"react-hook-form\";\r\nimport EupatiDiseaseAsyncSelect from \"../../../../common/static/async-select-menu\";\r\nimport { Rules } from \"../../../../common/helpers\";\r\nimport EupatiToggleBtn from \"../../../../common/static/toggle-btn\";\r\nimport EupatiTextarea from \"../../../../common/static/textarea\";\r\nimport { DiseaseInfo, Patient } from \"../../../../common/models/main-models\";\r\nimport { LookUpOptions } from \"../../../../common/models/input-models\";\r\nimport EupatiCheckbox from \"../../../../common/static/checkbox-toggle\";\r\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport { faInfoCircle } from '@fortawesome/fontawesome-free-solid';\r\nimport ReactTooltip from 'react-tooltip';\r\n\r\ntype OwnProps = {\r\n patient: Patient\r\n};\r\n\r\ntype DispatchProps = {\r\n nextPage: () => void;\r\n setPatientInfo: (patient: Patient) => void;\r\n hidePatientsDiseaseExpInfo: () => void;\r\n returnProperDefaultValue: (val: any) => any;\r\n findLookUpData: (lookUpDataType?: string) => LookUpOptions[] | null;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\ntype FieldProps = {\r\n diseases: DiseaseInfo[],\r\n noDiseaseExpertise: boolean,\r\n patientExperienceId: number,\r\n otherInformation: string\r\n};\r\n\r\nconst CUSTOM_SPAN_STYLES = ({\r\n boldFont: {\r\n fontWeight: 600\r\n }\r\n});\r\nexport default function PatientsDiseaseExpInfo(props: Props) {\r\n const { handleSubmit, control, watch, formState: { errors } } = useForm();\r\n\r\n const fieldsData = {\r\n diseases: watch(\"diseases\") as DiseaseInfo[],\r\n noDiseaseExpertise: watch(\"noDiseaseExpertise\") as boolean,\r\n patientExperienceId: watch(\"patientExperienceId\") as number,\r\n otherInformation: watch(\"otherInformation\") as string\r\n } as FieldProps;\r\n\r\n const onSubmit = (data: any) => {\r\n const editedPatientInfo = Object.assign(props.patient, data);\r\n props.setPatientInfo(editedPatientInfo);\r\n props.nextPage();\r\n }\r\n\r\n function onBackHandler() {\r\n if (adjustFieldsValues() === 0) {\r\n const editedPatientInfo = Object.assign(props.patient, fieldsData);\r\n props.setPatientInfo(editedPatientInfo);\r\n }\r\n props.hidePatientsDiseaseExpInfo();\r\n }\r\n\r\n const adjustFieldsValues = () => {\r\n if (fieldsData.diseases === undefined &&\r\n fieldsData.noDiseaseExpertise === undefined &&\r\n fieldsData.patientExperienceId === undefined &&\r\n fieldsData.otherInformation === undefined) {\r\n return 1; // if user hasn't changed anything\r\n }\r\n\r\n if (fieldsData.diseases === undefined &&\r\n props.patient.diseases.length >= 0) {\r\n fieldsData.diseases = [...props.patient.diseases];\r\n }\r\n\r\n if (fieldsData.noDiseaseExpertise === undefined &&\r\n props.patient.noDiseaseExpertise !== undefined) {\r\n fieldsData.noDiseaseExpertise = props.patient.noDiseaseExpertise;\r\n }\r\n\r\n if (fieldsData.otherInformation === undefined &&\r\n props.patient.otherInformation !== undefined) {\r\n fieldsData.otherInformation = props.patient.otherInformation;\r\n }\r\n\r\n if (fieldsData.patientExperienceId === undefined &&\r\n props.patient.patientExperienceId !== undefined) {\r\n fieldsData.patientExperienceId = props.patient.patientExperienceId;\r\n }\r\n\r\n return 0;\r\n }\r\n\r\n const returnProperIconType = (icon: any) => {\r\n return icon as IconProp;\r\n }\r\n\r\n return (\r\n <Form className='experience' onSubmit={handleSubmit(onSubmit)}>\r\n <Form.Group className='experience-info'>\r\n <Form.Group className='rcolumn'>\r\n <Form.Group id='pt-disease-name' className='experience-info-field mb-3'>\r\n <Form.Label style={{ display: 'flex', flexDirection: 'column' }}>\r\n <span style={{ ...CUSTOM_SPAN_STYLES.boldFont }}>\r\n Disease experience\r\n <FontAwesomeIcon data-tip data-for='expDiseasesControlInfo' icon={returnProperIconType(faInfoCircle)} />\r\n <ReactTooltip\r\n id='expDiseasesControlInfo'\r\n multiline={true}\r\n >\r\n <span>\r\n It is possible to select multiple diseases.\r\n <br />\r\n You can achive that by typing their names in the input field.\r\n <br />\r\n Moreover, you can also pick them from the dropdown menu.\r\n <br />\r\n </span>\r\n </ReactTooltip>\r\n </span>\r\n <span>\r\n <small style={{ fontSize: '11px' }}>\r\n Diseases are listed according to the US National Library of Medicine.\r\n You can find the controlled vocabulary, Medical Subject Headings (MEsH), <a href='https://meshb.nlm.nih.gov/search' target='_blank' >here.*</a>\r\n </small>\r\n </span>\r\n </Form.Label>\r\n <Controller\r\n name='diseases'\r\n control={control}\r\n defaultValue={props?.patient?.diseases}\r\n rules={Rules.notRequired}\r\n render={({ field }) =>\r\n <EupatiDiseaseAsyncSelect\r\n {...{\r\n ...field,\r\n errorMsg: errors?.diseases?.message\r\n }}\r\n />\r\n }\r\n />\r\n <Controller\r\n name='noDiseaseExpertise'\r\n control={control}\r\n defaultValue={props.patient.noDiseaseExpertise}\r\n rules={Rules.notRequired}\r\n render={({ field }) =>\r\n <EupatiCheckbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.noDiseaseExpertise?.message,\r\n fieldName: 'noDiseaseExpertise',\r\n text: 'I have no specific disease experience'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='pt-expc' className='experience-info-field mb-3'>\r\n <Form.Label>Level of experience with disease</Form.Label>\r\n <Controller\r\n name='patientExperienceId'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.patientExperienceId)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiToggleBtn\r\n {...{\r\n ...field,\r\n errorMsg: errors?.patientExperienceId?.message,\r\n fieldName: 'patientExperienceId',\r\n values: props.findLookUpData('patientExperiense')\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='pt-otherInfo' className='experience-info-field mb-3'>\r\n <Form.Label>Other relevant information</Form.Label>\r\n <Controller\r\n name='otherInformation'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.otherInformation)}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextarea\r\n {...{\r\n ...field,\r\n errorMsg: errors?.otherInformation?.message,\r\n rowsCount: 8\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='pt-btns'>\r\n <Button className='bck' variant='secondary' type='submit' onClick={onBackHandler}>Back</Button>\r\n <Button className='nxt' variant='primary' type='submit'>Next</Button>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form >\r\n )\r\n}","import React from \"react\";\r\nimport { Button, Form } from \"react-bootstrap\";\r\nimport { useForm, Controller } from \"react-hook-form\";\r\nimport EupatiMultiselect from \"../../../../common/static/multiselect\";\r\nimport { Rules } from \"../../../../common/helpers\";\r\nimport { Patient } from \"../../../../common/models/main-models\";\r\nimport { LookUpOptions } from \"../../../../common/models/input-models\";\r\nimport EupatiTextbox from \"../../../../common/static/textbox\";\r\n\r\ntype OwnProps = {\r\n patient: Patient\r\n};\r\n\r\ntype DispatchProps = {\r\n prevPage: () => void;\r\n showPatientsDiseaseExpInfo: () => void;\r\n setPatientInfo: (patient: Patient) => void;\r\n returnProperDefaultValue: (val: any) => any;\r\n findLookUpData: (lookUpDataType?: string) => LookUpOptions[] | null;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\ntype FieldProps = {\r\n patientExpertises: number[],\r\n patientExpertiseDescription: string,\r\n projectTypeExperiences: number[],\r\n projectTypeExperiencesDescription: string\r\n};\r\n\r\nexport default function PatientsProjectExpInfo(props: Props) {\r\n const { handleSubmit, control, watch, formState: { errors } } = useForm();\r\n\r\n const fieldsData = {\r\n patientExpertises: watch(\"patientExpertises\") as number[],\r\n projectTypeExperiences: watch(\"projectTypeExperiences\") as number[],\r\n patientExpertiseDescription: watch(\"patientExpertiseDescription\") as string,\r\n projectTypeExperiencesDescription: watch(\"projectTypeExperiencesDescription\") as string\r\n } as FieldProps;\r\n\r\n const onSubmit = (data: any) => {\r\n const editedPatientInfo = Object.assign(props.patient, Object.assign(data));\r\n props.setPatientInfo(editedPatientInfo);\r\n props.showPatientsDiseaseExpInfo();\r\n }\r\n\r\n const onBackHandler = () => {\r\n if (adjustFieldsValues() === 0) {\r\n const editedPatientInfo = Object.assign(props.patient, Object.assign(fieldsData));\r\n props.setPatientInfo(editedPatientInfo);\r\n }\r\n props.prevPage();\r\n }\r\n\r\n const adjustFieldsValues = () => {\r\n if (fieldsData.patientExpertises === undefined &&\r\n fieldsData.projectTypeExperiences === undefined &&\r\n fieldsData.patientExpertiseDescription === undefined &&\r\n fieldsData.projectTypeExperiencesDescription === undefined) {\r\n return 1; // if user hasn't changed anything\r\n }\r\n\r\n if (fieldsData.patientExpertises === undefined &&\r\n props.patient.patientExpertises !== undefined) {\r\n fieldsData.patientExpertises = props.patient.patientExpertises;\r\n }\r\n\r\n if (fieldsData.projectTypeExperiences === undefined &&\r\n props.patient.projectTypeExperiences !== undefined) {\r\n fieldsData.projectTypeExperiences = [...props.patient.projectTypeExperiences];\r\n }\r\n\r\n if (fieldsData.projectTypeExperiencesDescription === undefined &&\r\n props.patient.projectTypeExperiencesDescription !== undefined) {\r\n fieldsData.projectTypeExperiencesDescription = props.patient.projectTypeExperiencesDescription;\r\n }\r\n\r\n if (fieldsData.patientExpertiseDescription === undefined &&\r\n props.patient.patientExpertiseDescription !== undefined) {\r\n fieldsData.patientExpertiseDescription = props.patient.patientExpertiseDescription;\r\n }\r\n\r\n return 0;\r\n }\r\n\r\n const toggleProjTypeExpField = () => {\r\n let projTypeExp: number[] = [];\r\n if (fieldsData.projectTypeExperiences !== undefined && fieldsData.projectTypeExperiences !== null) {\r\n projTypeExp = [...fieldsData.projectTypeExperiences];\r\n }\r\n else if (props.patient.projectTypeExperiences !== undefined && props.patient.projectTypeExperiences !== null) {\r\n projTypeExp = [...props.patient.projectTypeExperiences];\r\n }\r\n\r\n //if (orgTypes.length > 1) { return false; }\r\n let otherType = props.findLookUpData('projectType')?.find(ot => ot.name.toLowerCase().includes('other')); // gets { id: 3, name: 'Other' }\r\n return projTypeExp?.some((x) => x === otherType?.id) ? true : false;\r\n }\r\n\r\n const togglePtExpertiseField = () => {\r\n let ptExpertises: number[] = [];\r\n if (fieldsData.patientExpertises !== undefined && fieldsData.patientExpertises !== null) {\r\n ptExpertises = [...fieldsData.patientExpertises];\r\n }\r\n else if (props.patient.patientExpertises !== undefined && props.patient.patientExpertises !== null) {\r\n ptExpertises = [...props.patient.patientExpertises];\r\n }\r\n\r\n //if (orgTypes.length > 1) { return false; }\r\n let otherType = props.findLookUpData('expertise')?.find(ot => ot.name.toLowerCase().includes('other')); // gets { id: 3, name: 'Other' }\r\n return ptExpertises?.some((x) => x === otherType?.id) ? true : false;\r\n }\r\n\r\n return (\r\n <Form className='experience' onSubmit={handleSubmit(onSubmit)}>\r\n <Form.Group className='experience-info'>\r\n <Form.Group className='lcolumn'>\r\n\r\n <Form.Group id='pt-expertise' className='experience-info-field mb-4'>\r\n <Form.Label>Level of expertise (multiple answers possible)</Form.Label>\r\n <Controller\r\n name='patientExpertises'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.patientExpertises)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiMultiselect\r\n {...{\r\n ...field,\r\n errorMsg: errors?.message,\r\n fieldName: 'patientExpertises',\r\n values: props.findLookUpData('expertise')\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n {togglePtExpertiseField() &&\r\n <Form.Group id='pt-expertiseDescr' className='experience-info-field mb-4'>\r\n <Form.Label>Please specify level of expertise</Form.Label>\r\n <Controller\r\n name='patientExpertiseDescription'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.patientExpertiseDescription)}\r\n rules={Rules.notRequired}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.patientExpertiseDescription?.message,\r\n placeholder: 'Please type level of expertise'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n }\r\n\r\n <Form.Group id='pt-expcProj' className='experience-info-field mb-4'>\r\n <Form.Label>Type of project experience (multiple answers possible)</Form.Label>\r\n <Controller\r\n name='projectTypeExperiences'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.projectTypeExperiences)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiMultiselect\r\n {...{\r\n ...field,\r\n errorMsg: errors?.projectTypeExperiences?.message,\r\n fieldName: 'projectTypeExperiences',\r\n values: props.findLookUpData('projectType')\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n {toggleProjTypeExpField() &&\r\n <Form.Group id='pt-expcProjDescr' className='experience-info-field mb-4' >\r\n <Form.Label>Please specify the type of project</Form.Label>\r\n <Controller\r\n name='projectTypeExperiencesDescription'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.projectTypeExperiencesDescription)}\r\n rules={Rules.notRequired}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.projectTypeExperiencesDescription?.message,\r\n placeholder: 'Please specify project type'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n }\r\n\r\n <Form.Group id='pt-btns'>\r\n <Button className='bck' variant='secondary' type='submit' onClick={onBackHandler}>Back</Button>\r\n <Button className='nxt' variant='primary' type='submit'>Next</Button>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form>\r\n )\r\n}","import React, { useState } from \"react\";\r\nimport { LookUpData, LookUpOptions } from \"../../../../common/models/input-models\";\r\nimport { Patient } from \"../../../../common/models/main-models\";\r\nimport PatientsDiseaseExpInfo from \"./disease-exp\";\r\nimport PatientsProjectExpInfo from \"./proj-exp\";\r\n\r\ntype OwnProps = {\r\n patient: Patient,\r\n lookUpData: LookUpData[],\r\n showSecondSubComponent: boolean\r\n};\r\n\r\ntype DispatchProps = {\r\n setPatientInfo: (patient: Patient) => void;\r\n nextPage: () => void;\r\n prevPage: () => void;\r\n returnProperDefaultValue: (val: any) => any;\r\n findLookUpData: (lookUpDataType?: string) => LookUpOptions[] | null;\r\n savePatient: (patient: Patient) => void;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nexport default function PatientExpcInfo(props: Props) {\r\n const [nextBtnClicked, setNextBtnClicked] = useState<boolean>(props.showSecondSubComponent);\r\n\r\n const toggleSectionVisibility = () => {\r\n setNextBtnClicked(!nextBtnClicked);\r\n }\r\n\r\n return (\r\n <div style={{ margin: '0 0 7.5rem 0' }}>\r\n\r\n {nextBtnClicked &&\r\n <PatientsProjectExpInfo\r\n {...{\r\n ...props,\r\n showPatientsDiseaseExpInfo: toggleSectionVisibility\r\n }}\r\n />\r\n }\r\n\r\n {!nextBtnClicked &&\r\n <PatientsDiseaseExpInfo\r\n {...{\r\n ...props,\r\n hidePatientsDiseaseExpInfo: toggleSectionVisibility\r\n }}\r\n />\r\n }\r\n </div>\r\n );\r\n}","import React from \"react\";\r\nimport { useForm, Controller } from \"react-hook-form\";\r\nimport { Button, Form } from 'react-bootstrap';\r\nimport { Rules } from \"../../../../common/helpers\";\r\nimport EupatiMultiselect from \"../../../../common/static/multiselect\";\r\nimport { Patient } from \"../../../../common/models/main-models\";\r\nimport { LookUpOptions } from \"../../../../common/models/input-models\";\r\nimport EupatiTextbox from \"../../../../common/static/textbox\";\r\n\r\ntype OwnProps = {\r\n patient: Patient\r\n};\r\n\r\ntype DispatchProps = {\r\n prevPage: () => void;\r\n setPatientInfo: (patient: Patient) => void;\r\n showPatientCompensationReqInfo: () => void;\r\n returnProperDefaultValue: (val: any) => any;\r\n findLookUpData: (lookUpDataType?: string) => LookUpOptions[] | null;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\ntype FieldsProps = {\r\n projectPreferences: number[],\r\n projectPreferenceDescription: string,\r\n organisationPreferences: number[],\r\n organisationPreferenceDescription: string\r\n};\r\n\r\nexport default function PatientProjectReqInfo(props: Props) {\r\n\r\n const { handleSubmit, control, watch, formState: { errors } } = useForm();\r\n\r\n const fieldsData = {\r\n projectPreferences: watch(\"projectPreferences\") as number[],\r\n projectPreferenceDescription: watch(\"projectPreferenceDescription\") as string,\r\n organisationPreferences: watch(\"organisationPreferences\") as number[],\r\n organisationPreferenceDescription: watch(\"organisationPreferenceDescription\") as string\r\n } as FieldsProps;\r\n\r\n const onSubmit = (data: any) => {\r\n const editedPatientInfo = Object.assign(props.patient, data);\r\n props.setPatientInfo(editedPatientInfo);\r\n props.showPatientCompensationReqInfo();\r\n }\r\n\r\n function onBackHandler() {\r\n if (adjustFieldsValues() === 0) {\r\n const editedPatientInfo = Object.assign(props.patient, fieldsData);\r\n props.setPatientInfo(editedPatientInfo);\r\n }\r\n props.prevPage();\r\n }\r\n\r\n const orderLookUpOptionsByNameLength = (options: LookUpOptions[] | null) => {\r\n if (options !== null) {\r\n return options.sort((a, b) => a.name.length - b.name.length);\r\n }\r\n\r\n return null;\r\n }\r\n\r\n const toggleOrgPrefField = () => {\r\n let orgTypes: number[] = [];\r\n if (fieldsData.organisationPreferences !== undefined && fieldsData.organisationPreferences !== null) {\r\n orgTypes = [...fieldsData.organisationPreferences];\r\n }\r\n else if (props.patient.organisationPreferences !== undefined && props.patient.organisationPreferences !== null) {\r\n orgTypes = [...props.patient.organisationPreferences];\r\n }\r\n\r\n //if (orgTypes.length > 1) { return false; }\r\n let otherType = props.findLookUpData('organisationType')?.find(ot => ot.name.toLowerCase().includes('other')); // gets { id: 3, name: 'Other' }\r\n return orgTypes?.some((x) => x === otherType?.id) ? true : false;\r\n }\r\n\r\n const toggleProjPrefField = () => {\r\n let projPrefs: number[] = [];\r\n if (fieldsData.projectPreferences !== undefined && fieldsData.projectPreferences !== null) {\r\n projPrefs = [...fieldsData.projectPreferences];\r\n }\r\n else if (props.patient.projectPreferences !== undefined && props.patient.projectPreferences !== null) {\r\n projPrefs = [...props.patient.projectPreferences];\r\n }\r\n\r\n //if (orgTypes.length > 1) { return false; }\r\n let otherType = props.findLookUpData('projectType')?.find(ot => ot.name.toLowerCase().includes('other')); // gets { id: 3, name: 'Other' }\r\n return projPrefs?.some((x) => x === otherType?.id) ? true : false;\r\n }\r\n\r\n const adjustFieldsValues = () => {\r\n if (fieldsData.projectPreferences === undefined &&\r\n fieldsData.organisationPreferences === undefined &&\r\n fieldsData.projectPreferenceDescription === undefined &&\r\n fieldsData.organisationPreferenceDescription === undefined) {\r\n return 1; // if user hasn't changed anything\r\n }\r\n\r\n if (fieldsData.projectPreferences === undefined &&\r\n props.patient.projectPreferences !== undefined) {\r\n fieldsData.projectPreferences = [...props.patient.projectPreferences];\r\n }\r\n\r\n if (fieldsData.organisationPreferences === undefined &&\r\n props.patient.organisationPreferences !== undefined) {\r\n fieldsData.organisationPreferences = [...props.patient.organisationPreferences];\r\n }\r\n\r\n if (fieldsData.projectPreferenceDescription === undefined &&\r\n props.patient.projectPreferenceDescription !== undefined) {\r\n fieldsData.projectPreferenceDescription = props.patient.projectPreferenceDescription;\r\n }\r\n\r\n if (fieldsData.organisationPreferenceDescription === undefined &&\r\n props.patient.organisationPreferenceDescription !== undefined) {\r\n fieldsData.organisationPreferenceDescription = props.patient.organisationPreferenceDescription;\r\n }\r\n\r\n return 0;\r\n }\r\n\r\n return (\r\n <Form className='requirements' onSubmit={handleSubmit(onSubmit)}>\r\n <Form.Group className='requirements-info'>\r\n <Form.Group className='lcolumn'>\r\n\r\n <Form.Group id='pt-tpProj' className='requirements-info-field mb-3'>\r\n <Form.Label>Preference on types of projects (multiple answers possible)</Form.Label>\r\n <Controller\r\n name='projectPreferences'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.projectPreferences)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiMultiselect\r\n {...{\r\n ...field,\r\n errorMsg: errors?.projectPreferences?.message,\r\n fieldName: 'projectPreferences',\r\n values: props.findLookUpData('projectType')\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n {toggleProjPrefField() &&\r\n <Form.Group id='pt-projPrefDescr' className='requirements-info-field mb-3'>\r\n <Form.Label>Please specify project preference</Form.Label>\r\n <Controller\r\n name='projectPreferenceDescription'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.projectPreferenceDescription)}\r\n rules={Rules.notRequired}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.projectPreferenceDescription?.message,\r\n placeholder: 'Please type project preference'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n }\r\n\r\n <Form.Group id='pt-orgTp' className='requirements-info-field mb-3'>\r\n <Form.Label>Preference on types of organisation (multiple answers possible)</Form.Label>\r\n <Controller\r\n name='organisationPreferences'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.organisationPreferences)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiMultiselect\r\n {...{\r\n ...field,\r\n errorMsg: errors?.projectPreferences?.message,\r\n fieldName: 'organisationPreferences',\r\n values: orderLookUpOptionsByNameLength(props.findLookUpData('organisationType'))\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n {toggleOrgPrefField() &&\r\n <Form.Group id='pt-orgTpDescr' className='requirements-info-field mb-3'>\r\n <Form.Label>Please specify organisation preference</Form.Label>\r\n <Controller\r\n name='organisationPreferenceDescription'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.organisationPreferenceDescription)}\r\n rules={Rules.notRequired}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.organisationPreferenceDescription?.message,\r\n placeholder: 'Please type organisation preference'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n }\r\n\r\n <Form.Group id='pt-btns'>\r\n <Button className='bck' variant='secondary' type='submit' onClick={onBackHandler}>Back</Button>\r\n <Button className='nxt' variant='primary' type='submit'>Next</Button>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form>\r\n )\r\n}","import React from \"react\";\r\nimport { useForm, Controller } from \"react-hook-form\";\r\nimport { Button, Form } from 'react-bootstrap';\r\nimport { Rules } from \"../../../../common/helpers\";\r\nimport EupatiNonCMSToggleBtn from \"../../../../common/static/toggle-btn-nonCMS\";\r\nimport EupatiToggleBtn from \"../../../../common/static/toggle-btn\";\r\nimport EupatiGDPRBtn from \"../../../../common/static/GDPR-toggle\";\r\nimport { Patient } from \"../../../../common/models/main-models\";\r\nimport { LookUpOptions } from \"../../../../common/models/input-models\";\r\n\r\ntype OwnProps = {\r\n patient: Patient,\r\n isNewPatient: boolean\r\n};\r\n\r\ntype DispatchProps = {\r\n nextPage: () => void;\r\n prevPage: () => void;\r\n savePatient: (patient: Patient) => void;\r\n hidePatientCompensationReqInfo: () => void;\r\n setPatientInfo: (patient: Patient) => void;\r\n returnProperDefaultValue: (val: any) => any;\r\n findLookUpData: (lookUpDataType?: string) => LookUpOptions[] | null;\r\n submitNewPatient: (patient: Patient) => void;\r\n};\r\n\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\ntype FieldProps = {\r\n isEligibleForCompensation?: boolean,\r\n isAvailableForNoCompensation?: boolean,\r\n activityPreferenceId?: number,\r\n isGDPRConsentGiven: boolean\r\n};\r\n\r\nexport default function PatientCompensationReqInfo(props: Props) {\r\n\r\n const { handleSubmit, control, watch, formState: { errors } } = useForm();\r\n\r\n const fieldsData = {\r\n isEligibleForCompensation: watch(\"isEligibleForCompensation\") as boolean | undefined,\r\n isAvailableForNoCompensation: watch(\"isAvailableForNoCompensation\") as boolean | undefined,\r\n activityPreferenceId: watch(\"activityPreferenceId\") as number | undefined,\r\n isGDPRConsentGiven: watch(\"isGDPRConsentGiven\") as boolean,\r\n } as FieldProps;\r\n\r\n const onSubmit = (data: any) => {\r\n const editedPatientInfo = Object.assign(props.patient, data);\r\n switch (props.isNewPatient) {\r\n case true:\r\n props.submitNewPatient(editedPatientInfo);\r\n break;\r\n case false:\r\n props.savePatient(editedPatientInfo);\r\n break;\r\n }\r\n props.nextPage();\r\n }\r\n\r\n function onBackHandler() {\r\n if (adjustFieldsValues() === 0) {\r\n const editedPatientInfo = Object.assign(props.patient, fieldsData);\r\n props.setPatientInfo(editedPatientInfo);\r\n }\r\n props.hidePatientCompensationReqInfo();\r\n }\r\n\r\n const adjustFieldsValues = () => {\r\n if (fieldsData.isEligibleForCompensation === undefined &&\r\n fieldsData.isAvailableForNoCompensation === undefined &&\r\n fieldsData.activityPreferenceId === undefined &&\r\n fieldsData.isGDPRConsentGiven === undefined) {\r\n return 1; // if user hasn't changed anything\r\n }\r\n\r\n if (fieldsData.isEligibleForCompensation === undefined &&\r\n props.patient.isEligibleForCompensation !== undefined) {\r\n fieldsData.isEligibleForCompensation = props.patient.isEligibleForCompensation;\r\n }\r\n\r\n if (fieldsData.isAvailableForNoCompensation === undefined &&\r\n props.patient.isAvailableForNoCompensation !== undefined) {\r\n fieldsData.isAvailableForNoCompensation = props.patient.isAvailableForNoCompensation;\r\n }\r\n\r\n if (fieldsData.activityPreferenceId === undefined &&\r\n props.patient.activityPreferenceId !== undefined) {\r\n fieldsData.activityPreferenceId = props.patient.activityPreferenceId;\r\n }\r\n\r\n if (fieldsData.isGDPRConsentGiven === undefined &&\r\n props.patient.isGDPRConsentGiven !== undefined) {\r\n fieldsData.isGDPRConsentGiven = props.patient.isGDPRConsentGiven;\r\n }\r\n\r\n return 0;\r\n }\r\n\r\n return (\r\n <Form className='requirements' onSubmit={handleSubmit(onSubmit)}>\r\n <Form.Group className='requirements-info'>\r\n <Form.Group className='rcolumn'>\r\n <Form.Group id='pt-compEligbl' className='requirements-info-field mb-3'>\r\n <Form.Label>Are you eligible to receive compensation?</Form.Label>\r\n <Controller\r\n name='isEligibleForCompensation'\r\n control={control}\r\n defaultValue={props.patient.isEligibleForCompensation !== undefined ? `${props.patient.isEligibleForCompensation}` : ''}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiNonCMSToggleBtn\r\n {...{\r\n ...field,\r\n errorMsg: errors?.isEligibleForCompensation?.message,\r\n fieldName: 'isEligibleForCompensation',\r\n isMoreThanTwoOptions: true\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='pt-noCompAvlbl' className='requirements-info-field mb-3'>\r\n <Form.Label>Are you available for voluntary work?</Form.Label>\r\n <Controller\r\n name='isAvailableForNoCompensation'\r\n control={control}\r\n defaultValue={props.patient.isAvailableForNoCompensation !== undefined ? `${props.patient.isAvailableForNoCompensation}` : ''}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiNonCMSToggleBtn\r\n {...{\r\n ...field,\r\n errorMsg: errors?.isAvailableForNoCompensation?.message,\r\n fieldName: 'isAvailableForNoCompensation',\r\n isMoreThanTwoOptions: true\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='pt-expcProj' className='requirements-info-field mb-3'>\r\n <Form.Label>Preference for an individual or group projects</Form.Label>\r\n <Controller\r\n name='activityPreferenceId'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.activityPreferenceId)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiToggleBtn\r\n {...{\r\n ...field,\r\n errorMsg: errors?.activityPreferenceId?.message,\r\n fieldName: 'activityPreferenceId',\r\n values: props.findLookUpData('activityType')\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group id='pt-gdpr' className='requirements-info-field mb-4'>\r\n <Controller\r\n name='isGDPRConsentGiven'\r\n control={control}\r\n defaultValue={props.returnProperDefaultValue(props.patient.isGDPRConsentGiven)}\r\n rules={Rules.selectOptionMessage}\r\n render={({ field }) =>\r\n <EupatiGDPRBtn\r\n {...{\r\n ...field,\r\n fieldName: 'isGDPRConsentGiven',\r\n errorMsg: errors?.isGDPRConsentGiven?.message\r\n }}\r\n />\r\n }\r\n />\r\n <small className='google-message'>\r\n This site is protected by reCAPTCHA and the Google\r\n <a className='google-message-privacy' href=\"https://policies.google.com/privacy\" target=\"_blank\"> Privacy Policy</a> and\r\n <a className='google-message-tos' href=\"https://policies.google.com/terms\" target=\"_blank\"> Terms of Service</a> apply.\r\n </small>\r\n </Form.Group>\r\n\r\n <Form.Group id='pt-btns'>\r\n <Button className='bck' variant='secondary' type='submit' onClick={onBackHandler}>Back</Button>\r\n <Button className='nxt' variant='primary' type='submit'>Submit</Button>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form.Group>\r\n </Form>\r\n )\r\n}","import React, { useState } from \"react\";\r\nimport { LookUpOptions } from \"../../../../common/models/input-models\";\r\nimport { Patient } from \"../../../../common/models/main-models\";\r\nimport PatientProjectReqInfo from \"./comp-req\";\r\nimport PatientCompensationReqInfo from \"./proj-req\";\r\n\r\ntype OwnProps = {\r\n patient: Patient,\r\n isNewPatient: boolean,\r\n showSecondSubComponent: boolean\r\n};\r\n\r\ntype DispatchProps = {\r\n nextPage: () => void;\r\n prevPage: () => void;\r\n savePatient: (project: Patient) => void;\r\n setPatientInfo: (project: Patient) => void;\r\n returnProperDefaultValue: (val: any) => any;\r\n findLookUpData: (lookUpDataType?: string) => LookUpOptions[] | null;\r\n submitNewPatient: (patient: Patient) => void;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nexport default function RequirementsInfo(props: Props) {\r\n\r\n const [nextBtnClicked, setNextBtnClicked] = useState<boolean>(props.showSecondSubComponent);\r\n\r\n const toggleSectionVisibility = () => {\r\n setNextBtnClicked(!nextBtnClicked);\r\n }\r\n\r\n return (\r\n <div style={{ margin: '0 0 7.5rem 0' }}>\r\n\r\n {nextBtnClicked &&\r\n <PatientProjectReqInfo\r\n {...{\r\n ...props,\r\n showPatientCompensationReqInfo: toggleSectionVisibility\r\n }}\r\n />\r\n }\r\n\r\n {!nextBtnClicked &&\r\n // GDPR here...\r\n <PatientCompensationReqInfo\r\n {...{\r\n ...props,\r\n hidePatientCompensationReqInfo: toggleSectionVisibility\r\n }}\r\n />\r\n }\r\n\r\n\r\n </div>\r\n );\r\n}","import * as React from 'react';\r\nimport { Form } from 'react-bootstrap';\r\nimport { Patient } from '../../../common/models/main-models';\r\nimport EupatiLoader from '../../../common/static/loading-animation/loader';\r\nimport { State } from '../model';\r\nimport PatientGeneralInfo from './personal-info';\r\nimport PatientExpcInfo from './experience-info';\r\nimport RequirementsInfo from './preference-info';\r\nimport EupatiConfirmPage from '../../../common/static/confirm-page';\r\nimport { RouteComponentProps } from '@reach/router';\r\nimport '../style.scss';\r\nimport { toast } from 'react-toastify';\r\n\r\ntype OwnProps = {};\r\n\r\nexport type DispatchProps = {\r\n setPatientInfo: (patient: Patient) => void;\r\n setLookUpData: () => void;\r\n savePatient: (patient: Patient) => void;\r\n setPatientData: (id?: string) => void;\r\n setUserPatientData: (userId?: string) => void;\r\n submitNewPatient: (patient: Patient) => void;\r\n};\r\n\r\ntype Props = State & DispatchProps & OwnProps & RouteComponentProps<{ location: { state: { userId: string, patientId: string, isNewPatient: boolean, isUserPatient: boolean } } }>;\r\n\r\ntype OwnState = {\r\n showComponentByIndex: number;\r\n showSecondSubComponent: boolean;\r\n};\r\n\r\nclass ComponentRoot extends React.Component<Props, OwnState> {\r\n\r\n constructor(props: any) {\r\n super(props);\r\n\r\n this.state = {\r\n showComponentByIndex: 0,\r\n showSecondSubComponent: true // when this is \"true\" on render it will show the first subcomponent (PatientGeneralInfo --> PatientGenericInfo).\r\n }\r\n\r\n this.nextPageHandler = this.nextPageHandler.bind(this);\r\n this.previousPageHandler = this.previousPageHandler.bind(this);\r\n this.returnProperDefaultValue = this.returnProperDefaultValue.bind(this);\r\n this.findLookUpData = this.findLookUpData.bind(this);\r\n this.showLoadingComponent = this.showLoadingComponent.bind(this);\r\n }\r\n\r\n componentDidMount() {\r\n this.props.setLookUpData();\r\n const locationState = this.props.location?.state;\r\n if (locationState === undefined || locationState === null) {\r\n return toast.error(\"Something went wrong! Try again later.\"); // unauthorized access\r\n }\r\n else if (locationState.isNewPatient === false) {\r\n this.props.setPatientData(locationState.patientId); // admin edit patient\r\n }\r\n else if (locationState.isNewPatient === true) {\r\n this.props.setPatientData(); // admin add patient\r\n }\r\n else if (locationState.isUserPatient === true) {\r\n this.props.setUserPatientData(locationState.userId); // user access patient profile\r\n }\r\n }\r\n\r\n nextPageHandler() {\r\n if (this.state.showComponentByIndex !== 3) {\r\n this.setState(prevState => ({\r\n showComponentByIndex: prevState.showComponentByIndex + 1,\r\n showSecondSubComponent: true\r\n }));\r\n }\r\n //window.scrollTo(0, 0);\r\n }\r\n\r\n previousPageHandler() {\r\n if (this.state.showComponentByIndex !== 0) {\r\n this.setState(prevState => ({\r\n showComponentByIndex: prevState.showComponentByIndex - 1,\r\n showSecondSubComponent: false\r\n }));\r\n }\r\n //window.scrollTo(0, 0);\r\n }\r\n\r\n findLookUpData(lookUpDataType?: string) {\r\n if (this.props.lookUpData &&\r\n this.props.lookUpData.length > 0) {\r\n return this.props.lookUpData?.filter((x: any) => x.name == lookUpDataType)[0]?.data;\r\n }\r\n\r\n return [];\r\n }\r\n\r\n returnProperDefaultValue = (val: any) => {\r\n if (typeof val === 'undefined' || val === null) {\r\n return '';\r\n } else if (typeof val === 'boolean') {\r\n return val.toString(); // it doesn't set default val when 'false'\r\n }\r\n\r\n return val;\r\n }\r\n\r\n showLoadingComponent = (isNewPatient?: boolean) => {\r\n if (isNewPatient && !this.props.isLoading) {\r\n return false;\r\n }\r\n else if (this.props.isLoading || this.props.isPatientDataLoaded) {\r\n return true;\r\n }\r\n }\r\n\r\n render() {\r\n\r\n let mainComponent: any;\r\n\r\n let loadingComponent = (\r\n <div className='loader-wrapper'>\r\n <EupatiLoader />\r\n </div>\r\n );\r\n\r\n const props = {\r\n patient: this.props.patient,\r\n lookUpData: this.props.lookUpData,\r\n isNewPatient: typeof this.props.location?.state?.isNewPatient === 'undefined' ? false : this.props.location?.state?.isNewPatient,\r\n showSecondSubComponent: this.state.showSecondSubComponent,\r\n setPatientInfo: this.props.setPatientInfo,\r\n nextPage: this.nextPageHandler,\r\n prevPage: this.previousPageHandler,\r\n returnProperDefaultValue: this.returnProperDefaultValue,\r\n findLookUpData: this.findLookUpData,\r\n savePatient: this.props.savePatient,\r\n submitNewPatient: this.props.submitNewPatient\r\n };\r\n\r\n const spanStyles = {\r\n fontWeight: 'bolder',\r\n //textDecoration: 'underline',\r\n backgroundColor: '#00749F',\r\n borderRadius: '30px',\r\n color: '#fff'\r\n } as any;\r\n\r\n if (this.showLoadingComponent(this.props.location?.state?.isNewPatient)) {\r\n mainComponent = loadingComponent;\r\n }\r\n else {\r\n mainComponent = (\r\n <>\r\n <h2 className='heading' style={this.state.showComponentByIndex === 3 ? { display: 'none' } : {}}>Patient Profile</h2>\r\n {this.state.showComponentByIndex !== 3 &&\r\n <Form.Group className='titles-wrapper'>\r\n <div className='titles'>\r\n <div className='titles-title' style={this.state.showComponentByIndex === 0 ? { ...spanStyles } : {}}>\r\n <span>1. General</span>\r\n </div>\r\n <div className='titles-title' style={this.state.showComponentByIndex === 1 ? { ...spanStyles } : {}}>\r\n <span>2. Experience</span>\r\n </div>\r\n <div className='titles-title' style={this.state.showComponentByIndex === 2 ? { ...spanStyles } : {}}>\r\n <span>3. Preferences</span>\r\n </div>\r\n </div>\r\n </Form.Group>\r\n }\r\n {this.state.showComponentByIndex === 0 && <PatientGeneralInfo {...props} />}\r\n {this.state.showComponentByIndex === 1 && <PatientExpcInfo {...props} />}\r\n {this.state.showComponentByIndex === 2 && <RequirementsInfo {...props} />}\r\n {this.state.showComponentByIndex === 3 && <EupatiConfirmPage />}\r\n </>\r\n )\r\n }\r\n\r\n return (\r\n <>\r\n {mainComponent}\r\n </>\r\n );\r\n }\r\n}\r\n\r\nexport default ComponentRoot;","import { default as RootComponent, DispatchProps } from '../components/component-root'\r\nimport * as Constants from '../constants';\r\nimport * as Actions from '../actions';\r\nimport { State } from '../model';\r\nimport { connect } from 'react-redux';\r\nimport { Patient } from '../../../common/models/main-models';\r\n\r\nexport function mapStateToProps(globalState: any) {\r\n let name = Constants.NAME;\r\n let pageState = globalState[name] as State;\r\n return pageState;\r\n}\r\n\r\nexport function mapDispatchToProps(dispatch: any) {\r\n return {\r\n setLookUpData: () => dispatch(Actions.getLookUpDataAsync()),\r\n setPatientInfo: (patient: Patient) => dispatch(Actions.setPatientInfo(patient)),\r\n savePatient: (patient: Patient) => dispatch(Actions.updatePatientAsync(patient)),\r\n setPatientData: (patientId?: string) => dispatch(Actions.getPatientInfoByIdAsync(patientId)),\r\n setUserPatientData: (userId?: string) => dispatch(Actions.getPatientInfoByUserIdAsync(userId)),\r\n submitNewPatient: (patient: Patient) => dispatch(Actions.saveNewPatientAsync(patient)),\r\n } as DispatchProps;\r\n}\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(RootComponent);","import { LookUpData, MeshData } from '../../common/models/input-models';\r\nimport { Patient } from '../../common/models/main-models';\r\nimport * as t from './actionTypes';\r\nimport { defaultPatientInfo, State } from './model';\r\n\r\nconst initialState: State = {\r\n patient: defaultPatientInfo,\r\n isLoading: true,\r\n lookUpData: [],\r\n isPatientDataLoaded: true\r\n};\r\n\r\nexport default (state = initialState, action: any): State => {\r\n switch (action.type) {\r\n case t.SET_LOOKUP_DATA:\r\n return setLookUpData(state, action.payload);\r\n case t.SET_PATIENT_INFO:\r\n return setPatientInfo(state, action.payload);\r\n case t.SET_PATIENTS_LOADING:\r\n return setPatientLoading(state, action.payload);\r\n case t.SET_PATIENT_DATA_LOADING:\r\n return setPatientDataLoading(state, action.payload);\r\n default:\r\n return state;\r\n }\r\n};\r\n\r\nconst setLookUpData = (state: State, val: LookUpData[]): State => {\r\n let newState = {\r\n ...state,\r\n lookUpData: [...val]\r\n } as State;\r\n\r\n return newState;\r\n};\r\n\r\nconst setPatientInfo = (state: State, val: Patient): State => {\r\n let newState = {\r\n ...state,\r\n patient: {...val}\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setPatientLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n\t\t...state,\r\n isLoading: val\r\n\t} as State;\r\n\r\n\treturn newState;\r\n}\r\n\r\nconst setPatientDataLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isPatientDataLoaded: val\r\n } as State;\r\n\r\n return newState;\r\n}","import * as Actions from './actions';\r\nimport * as Components from './components/index';\r\nimport * as Containers from './containers/index';\r\nimport * as Constants from './constants';\r\nimport Reducer from './reducer';\r\n\r\nexport default {\r\n actions: Actions,\r\n components: Components,\r\n containers: Containers,\r\n constants: Constants,\r\n reducer: Reducer\r\n};\r\n\r\nexport const Root = Containers.ComponentRoot;","// constants.ts\r\n\r\nexport const NAME = 'homePage';","import { NAME } from \"./constants\";\r\n\r\nexport const SET_HOME_LOADING = `${NAME}/SET_HOME_LOADING`;\r\n\r\nexport const SET_HOME_LOGGED_IN = `${NAME}/SET_HOME_LOGGED_IN`;\r\n\r\nexport const SET_IS_USER_REAL = `${NAME}/SET_IS_USER_REAL`;\r\n\r\nexport const SET_IS_USER_ADMIN = `${NAME}/SET_IS_USER_ADMIN`;","// matching/actions.js\r\n\r\nimport DataSvc from '../../common/services/data-svc';\r\nimport * as t from './actionType';\r\nimport { Res } from '../../common/helpers';\r\n\r\nexport const setHomeLoading = (isLoading: boolean) => ({\r\n type: t.SET_HOME_LOADING,\r\n payload: isLoading,\r\n});\r\n\r\nexport const setHomeLoggedInStatus = (isLoggedIn: boolean) => ({\r\n type: t.SET_HOME_LOGGED_IN,\r\n payload: isLoggedIn\r\n});\r\n\r\nexport const setIsUserReal = (isUserReal: boolean) => ({\r\n type: t.SET_IS_USER_REAL,\r\n payload: isUserReal\r\n});\r\n\r\nexport const verifyUserTokenAsync = (token: string) => {\r\n return (dispatch: any, getState: any) => {\r\n DataSvc.utilsSvc.verifyUserByRecaptchaToken({ recaptchaToken: token }).then(\r\n (result: any) => {\r\n if (result !== Res.success) {\r\n dispatch(setIsUserReal(false));\r\n }\r\n },\r\n (error) => { console.error(error); }\r\n );\r\n }\r\n}\r\n\r\nexport const setUserStatusAsync = (isUserAdmin: boolean) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setHomeLoading(true));\r\n if (isUserAdmin !== undefined) {\r\n dispatch(setHomeLoggedInStatus(true));\r\n }\r\n else {\r\n dispatch(setHomeLoggedInStatus(false));\r\n }\r\n //isUserAdmin !== undefined ? dispatch(setHomeLoggedInStatus(true)) : dispatch(setHomeLoggedInStatus(false));\r\n dispatch(setHomeLoading(false));\r\n }\r\n}","export default __webpack_public_path__ + \"static/media/net_ball_half.ab9dbdd5.png\";","export default __webpack_public_path__ + \"static/media/net_ball_light.8ca2031d.png\";","import * as React from 'react';\r\nimport { Carousel } from 'react-responsive-carousel';\r\nimport \"../../../../styles/carousel.css\";\r\n\r\ntype OwnProps = {};\r\n\r\nexport type DispatchProps = {};\r\n\r\ntype OwnState = {};\r\n\r\ntype Props = DispatchProps & OwnProps;\r\n\r\nexport default class Testimonials extends React.Component<Props, OwnState> {\r\n\r\n render() {\r\n const carouselProps = {\r\n autoPlay: true,\r\n interval: 5000,\r\n centerMode: true,\r\n centerSlidePercentage: 100,\r\n infiniteLoop: true,\r\n showStatus: false,\r\n showThumbs: false\r\n }\r\n return (\r\n <>\r\n <section className='testimonials-sec'>\r\n <div className='testimonials-sec-txt'>\r\n <h5 className='testimonials-sec-txt-title mb-4'>What People are Saying</h5>\r\n </div>\r\n <div className='testimonials-sec-content'>\r\n <Carousel {...carouselProps}>\r\n <div className='testimonials-sec-content-card'>\r\n <div className='testimonials-sec-content-card-quotes'></div>\r\n <div className='testimonials-sec-content-card-text'>There's a certain responsibility that comes with being a EUPATI fellow. We need to use what we have learned to make a real difference! EUPATIConnect means that I am working with trusted partners on topics that matter to patients. We learn from each other and make meaningful solutions together.</div>\r\n <div className='testimonials-sec-content-card-profile-image image-joana' />\r\n <div className='testimonials-sec-content-card-profile-name'>Joan Jordan</div>\r\n <div className='testimonials-sec-content-card-profile-title'>EUPATI Patient Expert</div>\r\n </div>\r\n <div className='testimonials-sec-content-card'>\r\n <div className='testimonials-sec-content-card-quotes'></div>\r\n <div className='testimonials-sec-content-card-text'>I had the opportunity to be involved as Patient Advisor in several clinical research projects, especially working on the study protocols and the development of patient relevant material. The involvement of a EUPATI Patient Expert means that any clinical research becomes more focused on the patients’ real needs as well as having the voice of the patient included in all steps.</div>\r\n <div className='testimonials-sec-content-card-profile-image image-paola' />\r\n <div className='testimonials-sec-content-card-profile-name'>Paola Kruger</div>\r\n <div className='testimonials-sec-content-card-profile-title'>EUPATI Patient Expert</div>\r\n </div>\r\n <div className='testimonials-sec-content-card'>\r\n <div className='testimonials-sec-content-card-quotes'></div>\r\n <div className='testimonials-sec-content-card-text'>We received some great insights in interviews with EUPATI fellows. Withing 24 hours of placing a request, we were connected to three patients. All interviews were completed in 2 days and gave us a great understanding of the patient perspective.</div>\r\n <div className='testimonials-sec-content-card-profile-image image-ankita' />\r\n <div className='testimonials-sec-content-card-profile-name'>Dr Ankita Batla</div>\r\n <div className='testimonials-sec-content-card-profile-title'>VMLY&Rx | Chief Medical Office Lead-Health Insights and Patient Partnerships</div>\r\n </div>\r\n <div className='testimonials-sec-content-card'>\r\n <div className='testimonials-sec-content-card-quotes'></div>\r\n <div className='testimonials-sec-content-card-text'>We had a fantastic response following our request for patient review of our informed consent (ICF) template. EUPATI fellows had some hugely valuable feedback which will be used to inform our future ICF template to make it clearer and more user friendly.</div>\r\n <div className='testimonials-sec-content-card-profile-image image-kay' />\r\n <div className='testimonials-sec-content-card-profile-name'>Kay Warner</div>\r\n <div className='testimonials-sec-content-card-profile-title'>GSK</div>\r\n </div>\r\n </Carousel>\r\n </div>\r\n </section>\r\n </>\r\n );\r\n }\r\n}\r\n","export default __webpack_public_path__ + \"static/media/why1.203b1954.png\";","export default __webpack_public_path__ + \"static/media/why2.f9b4b22b.png\";","export default __webpack_public_path__ + \"static/media/why4.de557ce8.png\";","export default __webpack_public_path__ + \"static/media/why5.3a8914dc.png\";","export default __webpack_public_path__ + \"static/media/why6.3431a77d.png\";","export default __webpack_public_path__ + \"static/media/why9.cf5aa1ad.png\";","export const ApplicationName = 'EUPATIConnect';\r\n\r\nexport const QueryParameterNames = {\r\n ReturnUrl: 'returnUrl',\r\n Message: 'message'\r\n};\r\n\r\nexport const LogoutActions = {\r\n LogoutCallback: 'logout-callback',\r\n Logout: 'logout',\r\n LoggedOut: 'logged-out'\r\n};\r\n\r\nexport const LoginActions = {\r\n Login: 'login',\r\n LoginCallback: 'login-callback',\r\n LoginFailed: 'login-failed',\r\n Profile: 'profile',\r\n Register: 'register'\r\n};\r\n\r\nconst prefix = '/authentication';\r\n\r\nexport const ApplicationPaths = {\r\n DefaultLoginRedirectPath: '/',\r\n ApiAuthorizationClientConfigurationUrl: `_configuration/${ApplicationName}`,\r\n ApiAuthorizationPrefix: prefix,\r\n //Login: `${prefix}/${LoginActions.Login}`,\r\n Login: `validate`,\r\n LoginFailed: `${prefix}/${LoginActions.LoginFailed}`,\r\n LoginCallback: `${prefix}/${LoginActions.LoginCallback}`,\r\n Register: `${prefix}/${LoginActions.Register}`,\r\n Profile: `${prefix}/${LoginActions.Profile}`,\r\n LogOut: `${prefix}/${LogoutActions.Logout}`,\r\n LoggedOut: `${prefix}/${LogoutActions.LoggedOut}`,\r\n LogOutCallback: `${prefix}/${LogoutActions.LogoutCallback}`,\r\n IdentityRegisterPath: 'Identity/Account/Register',\r\n IdentityManagePath: 'Identity/Account/Manage/Email'\r\n};\r\n","import { UserManager, WebStorageStateStore } from 'oidc-client';\r\nimport { ApplicationPaths, ApplicationName } from './ApiAuthorizationConstants';\r\n\r\nexport class AuthorizeService {\r\n _callbacks = [];\r\n _nextSubscriptionId = 0;\r\n _user = null;\r\n _isAuthenticated = false;\r\n _timesCalled = 0;\r\n\r\n // By default pop ups are disabled because they don't work properly on Edge.\r\n // If you want to enable pop up authentication simply set this flag to false.\r\n _popUpDisabled = true;\r\n\r\n async isAuthenticated() {\r\n const user = await this.getUser();\r\n return !!user;\r\n }\r\n\r\n async getUser() {\r\n if (this._user && this._user.profile) {\r\n return this._user.profile;\r\n }\r\n\r\n await this.ensureUserManagerInitialized();\r\n let user = await this.userManager.getUser();\r\n\r\n if (!user) {\r\n const that = this;\r\n const promise = new Promise((resolve, reject) => {\r\n setTimeout(function () {\r\n that.userManager.getUser().then(res => {\r\n resolve(res);\r\n });\r\n }, 1312);\r\n });\r\n user = await promise;\r\n }\r\n\r\n return user && user.profile;\r\n }\r\n\r\n async getAccessToken() {\r\n await this.ensureUserManagerInitialized();\r\n const user = await this.userManager.getUser();\r\n return user && user.access_token;\r\n }\r\n\r\n async signInSilent() {\r\n await this.ensureUserManagerInitialized();\r\n try {\r\n const silentUser = await this.userManager.signinSilent(this.createArguments());\r\n this.updateState(silentUser);\r\n } catch (silentError) {\r\n console.log(\"Silent authentication error: \", silentError);\r\n }\r\n }\r\n\r\n // We try to authenticate the user in three different ways:\r\n // 1) We try to see if we can authenticate the user silently. This happens\r\n // when the user is already logged in on the IdP and is done using a hidden iframe\r\n // on the client.\r\n // 2) We try to authenticate the user using a PopUp Window. This might fail if there is a\r\n // Pop-Up blocker or the user has disabled PopUps.\r\n // 3) If the two methods above fail, we redirect the browser to the IdP to perform a traditional\r\n // redirect flow.\r\n async signIn(state) {\r\n await this.ensureUserManagerInitialized();\r\n try {\r\n const silentUser = await this.userManager.signinSilent(this.createArguments());\r\n this.updateState(silentUser);\r\n return this.success(state);\r\n } catch (silentError) {\r\n // User might not be authenticated, fallback to popup authentication\r\n console.log(\"Silent authentication error: \", silentError);\r\n\r\n try {\r\n if (this._popUpDisabled) {\r\n throw new Error('Popup disabled. Change \\'AuthorizeService.js:AuthorizeService._popupDisabled\\' to false to enable it.')\r\n }\r\n\r\n const popUpUser = await this.userManager.signinPopup(this.createArguments());\r\n this.updateState(popUpUser);\r\n return this.success(state);\r\n } catch (popUpError) {\r\n if (popUpError.message === \"Popup window closed\") {\r\n // The user explicitly cancelled the login action by closing an opened popup.\r\n return this.error(\"The user closed the window.\");\r\n } else if (!this._popUpDisabled) {\r\n console.log(\"Popup authentication error: \", popUpError);\r\n }\r\n\r\n // PopUps might be blocked by the user, fallback to redirect\r\n try {\r\n await this.userManager.signinRedirect(this.createArguments(state));\r\n return this.redirect();\r\n } catch (redirectError) {\r\n console.log(\"Redirect authentication error: \", redirectError);\r\n return this.error(redirectError);\r\n }\r\n }\r\n }\r\n }\r\n\r\n async completeSignIn(url) {\r\n try {\r\n await this.ensureUserManagerInitialized();\r\n const user = await this.userManager.signinCallback(url);\r\n this.updateState(user);\r\n return this.success(user && user.state);\r\n } catch (error) {\r\n console.log('There was an error signing in: ', error);\r\n return this.error('There was an error signing in.');\r\n }\r\n }\r\n\r\n // We try to sign out the user in two different ways:\r\n // 1) We try to do a sign-out using a PopUp Window. This might fail if there is a\r\n // Pop-Up blocker or the user has disabled PopUps.\r\n // 2) If the method above fails, we redirect the browser to the IdP to perform a traditional\r\n // post logout redirect flow.\r\n async signOut(state) {\r\n await this.ensureUserManagerInitialized();\r\n try {\r\n if (this._popUpDisabled) {\r\n throw new Error('Popup disabled. Change \\'AuthorizeService.js:AuthorizeService._popupDisabled\\' to false to enable it.')\r\n }\r\n\r\n await this.userManager.signoutPopup(this.createArguments());\r\n this.updateState(undefined);\r\n return this.success(state);\r\n } catch (popupSignOutError) {\r\n console.log(\"Popup signout error: \", popupSignOutError);\r\n try {\r\n await this.userManager.signoutRedirect(this.createArguments(state));\r\n return this.redirect();\r\n } catch (redirectSignOutError) {\r\n console.log(\"Redirect signout error: \", redirectSignOutError);\r\n return this.error(redirectSignOutError);\r\n }\r\n }\r\n }\r\n\r\n async completeSignOut(url) {\r\n await this.ensureUserManagerInitialized();\r\n try {\r\n const response = await this.userManager.signoutCallback(url);\r\n this.updateState(null);\r\n return this.success(response && response.data);\r\n } catch (error) {\r\n console.log(`There was an error trying to log out '${error}'.`);\r\n return this.error(error);\r\n }\r\n }\r\n\r\n updateState(user) {\r\n this._user = user;\r\n this._isAuthenticated = !!this._user;\r\n this.notifySubscribers();\r\n }\r\n\r\n subscribe(callback) {\r\n this._callbacks.push({ callback, subscription: this._nextSubscriptionId++ });\r\n return this._nextSubscriptionId - 1;\r\n }\r\n\r\n unsubscribe(subscriptionId) {\r\n const subscriptionIndex = this._callbacks\r\n .map((element, index) => element.subscription === subscriptionId ? { found: true, index } : { found: false })\r\n .filter(element => element.found === true);\r\n if (subscriptionIndex.length !== 1) {\r\n throw new Error(`Found an invalid number of subscriptions ${subscriptionIndex.length}`);\r\n }\r\n\r\n this._callbacks.splice(subscriptionIndex[0].index, 1);\r\n }\r\n\r\n notifySubscribers() {\r\n for (let i = 0; i < this._callbacks.length; i++) {\r\n const callback = this._callbacks[i].callback;\r\n callback();\r\n }\r\n }\r\n\r\n createArguments(state) {\r\n return { useReplaceToNavigate: true, data: state };\r\n }\r\n\r\n error(message) {\r\n return { status: AuthenticationResultStatus.Fail, message };\r\n }\r\n\r\n success(state) {\r\n return { status: AuthenticationResultStatus.Success, state };\r\n }\r\n\r\n redirect() {\r\n return { status: AuthenticationResultStatus.Redirect };\r\n }\r\n\r\n async ensureUserManagerInitialized() {\r\n if (this.userManager !== undefined) {\r\n return;\r\n }\r\n\r\n let response = await fetch(ApplicationPaths.ApiAuthorizationClientConfigurationUrl);\r\n if (!response.ok) {\r\n throw new Error(`Could not load settings for '${ApplicationName}'`);\r\n }\r\n\r\n let settings = await response.json();\r\n settings.automaticSilentRenew = true;\r\n settings.includeIdTokenInSilentRenew = true;\r\n settings.userStore = new WebStorageStateStore({\r\n prefix: ApplicationName\r\n });\r\n\r\n this.userManager = new UserManager(settings);\r\n\r\n this.userManager.events.addUserSignedOut(async () => {\r\n await this.userManager.removeUser();\r\n this.updateState(undefined);\r\n });\r\n }\r\n\r\n static get instance() { return authService }\r\n}\r\n\r\nconst authService = new AuthorizeService();\r\n\r\nexport default authService;\r\n\r\nexport const AuthenticationResultStatus = {\r\n Redirect: 'redirect',\r\n Success: 'success',\r\n Fail: 'fail'\r\n};\r\n","import React, { useState, FC, useContext } from 'react';\r\nimport authService from '../../api-authorization/AuthorizeService';\r\nimport { Roles } from '../helpers';\r\n\r\ninterface IAuthenticationContext {\r\n isUserAdmin: boolean;\r\n userIdentity: string;\r\n authenticateUser?: () => void;\r\n}\r\n\r\nconst defaultState = {\r\n isUserAdmin: false,\r\n userIdentity: ''\r\n};\r\n\r\nconst AuthenticationContext = React.createContext<IAuthenticationContext>(defaultState);\r\n\r\nexport default AuthenticationContext;\r\n\r\nexport const AuthenticationProvider: FC = ({ children }) => {\r\n const [isUserAdmin, setIsUserAdmin] = useState<any>(undefined);\r\n const [userIdentity, setUserIdentity] = useState<string>('');\r\n\r\n const authenticateUser = () => {\r\n // res.sub ==> current user id\r\n authService.getUser().then(res => {\r\n if (res === undefined || res === null) { return setIsUserAdmin(null); }\r\n switch (res.role.toUpperCase() === Roles.Admin) {\r\n case true:\r\n setIsUserAdmin(true);\r\n setUserIdentity(res.sub);\r\n break;\r\n case false:\r\n setIsUserAdmin(false);\r\n setUserIdentity(res.sub);\r\n break;\r\n }\r\n })\r\n };\r\n\r\n return (\r\n <AuthenticationContext.Provider\r\n value={{\r\n isUserAdmin: isUserAdmin,\r\n userIdentity: userIdentity,\r\n authenticateUser: authenticateUser\r\n }}\r\n >\r\n {children}\r\n </AuthenticationContext.Provider>\r\n );\r\n};\r\n\r\nexport const useAuthenticationContext = () => useContext(AuthenticationContext);","import * as React from 'react';\r\nimport { Button, Card, Form } from 'react-bootstrap';\r\nimport { withRouter } from 'react-router';\r\nimport EupatiLoader from '../../../common/static/loading-animation/loader';\r\nimport { State } from '../model';\r\nimport '../style.scss';\r\nimport researcher from '../../../../images/researcher.png';\r\nimport patient from '../../../../images/patient.png';\r\nimport { GoogleReCaptcha } from 'react-google-recaptcha-v3';\r\nimport { FAIL_AUTH_MSG, ADMIN_ACCESS_DENIED_MSG } from '../../../common/helpers/messages';\r\nimport imgRoadmap from '../../../../images/patient-engagement-tools/roadmap.png';\r\nimport imgGuidances from '../../../../images/patient-engagement-tools/guidances.png';\r\nimport imgParadigmTools from '../../../../images/patient-engagement-tools/paradigm_tools.png';\r\nimport imgEngagementSeparator from '../../../../images/patient-engagement-tools/engagement_separator.png';\r\nimport imgFaqSeparator from '../../../../images/faq/faq_separator.png';\r\nimport imgFaqHowDoesWork from '../../../../images/faq/how_does_work.png';\r\nimport imgFaqWhatIsEupati from '../../../../images/faq/what_is_eupati.png';\r\nimport imgNetBall from '../../../../images/net_ball.png';\r\nimport imgNetBallHalf from '../../../../images/net_ball_half.png';\r\nimport imgNetBallLight from '../../../../images/net_ball_light.png';\r\nimport imgNetBallPartial from '../../../../images/net_ball_partial.png';\r\nimport Testimonials from './testimonials';\r\nimport imgWhy1 from '../../../../images/why-eupati/why1.png';\r\nimport imgWhy2 from '../../../../images/why-eupati/why2.png';\r\nimport imgWhy3 from '../../../../images/why-eupati/why3.png';\r\nimport imgWhy4 from '../../../../images/why-eupati/why4.png';\r\nimport imgWhy5 from '../../../../images/why-eupati/why5.png';\r\nimport imgWhy6 from '../../../../images/why-eupati/why6.png';\r\nimport imgWhy7 from '../../../../images/why-eupati/why7.png';\r\nimport imgWhy8 from '../../../../images/why-eupati/why8.png';\r\nimport imgWhy9 from '../../../../images/why-eupati/why9.png';\r\nimport { toast } from 'react-toastify';\r\nimport AuthenticationContext from '../../../common/static/auth-context';\r\nimport { faCheck } from '@fortawesome/fontawesome-free-solid';\r\nimport TinyMCEditor from '../../../common/static/tinymce-editor';\r\nimport { IconProp } from '@fortawesome/fontawesome-svg-core';\r\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\r\n\r\ntype OwnProps = {};\r\n\r\nexport type DispatchProps = {\r\n setIsUserReal: (token: string) => void;\r\n setUserStatus: (isAdmin: boolean) => void;\r\n};\r\n\r\ntype Props = State & DispatchProps & OwnProps;\r\n\r\ntype OwnState = {};\r\n\r\nexport default class ComponentRoot extends React.Component<Props, OwnState> {\r\n static contextType = AuthenticationContext;\r\n componentDidMount() {\r\n if (this.context.isUserAdmin === null || this.context.isUserAdmin === undefined) {\r\n this.context.authenticateUser();\r\n }\r\n this.props.setUserStatus(this.context.isUserAdmin);\r\n }\r\n\r\n returnProperIconType(icon: any) {\r\n return icon as IconProp;\r\n }\r\n\r\n render() {\r\n\r\n let mainComponent: any;\r\n let whyComponent: any;\r\n let noteComponent: any;\r\n let statsComponent: any;\r\n let patientEngagementComponent: any;\r\n let testimonialComponent: any;\r\n let faqComponent: any;\r\n\r\n let loadingComponent = (\r\n <div className='loader-wrapper'>\r\n <EupatiLoader />\r\n </div>\r\n );\r\n\r\n let PatientBtn = withRouter(({ history }) => (\r\n <Button\r\n variant='primary'\r\n type='submit'\r\n className='card-p-btn'\r\n id='pt-home-btn'\r\n onClick={() => {\r\n if (!this.props.isUserReal) {\r\n toast.error(FAIL_AUTH_MSG);\r\n return history.push('/');\r\n }\r\n\r\n switch (this.context.isUserAdmin) {\r\n case true:\r\n toast.error(ADMIN_ACCESS_DENIED_MSG);\r\n return history.push('/');\r\n case false:\r\n return history.push({ pathname: '/patient', state: { isUserPatient: (this.context.isUserAdmin !== undefined && this.context.isUserAdmin !== null), userId: this.context.userIdentity } });\r\n default:\r\n window.location.href = \"/validate\";\r\n break;\r\n }\r\n }}\r\n >\r\n View Your Profile\r\n </Button>\r\n ));\r\n\r\n let ResearcherBtn = withRouter(({ history }) => (\r\n <Button\r\n variant='primary'\r\n type='submit'\r\n className='card-r-btn'\r\n id='res-home-btn'\r\n onClick={() => {\r\n if (!this.props.isUserReal) {\r\n toast.error(FAIL_AUTH_MSG);\r\n return history.push('/');\r\n }\r\n\r\n history.push('/pricing');\r\n }}\r\n >\r\n Connect Now\r\n </Button>\r\n ));\r\n\r\n if (this.props.isLoading) {\r\n mainComponent = loadingComponent;\r\n whyComponent = null;\r\n noteComponent = null;\r\n statsComponent = null;\r\n patientEngagementComponent = null;\r\n testimonialComponent = null;\r\n }\r\n else {\r\n mainComponent = (\r\n <>\r\n <GoogleReCaptcha action='homePage' onVerify={token => this.props.setIsUserReal(token)} />\r\n\r\n <section className='upper-sec'>\r\n {/* <img className='upper-sec-img' src={upperSectionBg} /> */}\r\n <div className='upper-sec-txt'>\r\n <h5 className='upper-sec-txt-title mb-4'>EUPATIConnect</h5>\r\n <p className='upper-sec-txt-para'>\r\n Bringing EUPATI Patient Experts and researchers together\r\n </p>\r\n </div>\r\n\r\n </section>\r\n <section className='mid-sec'></section>\r\n <section className='lower-sec'>\r\n <div id='home-cards-container' className='row g-3 justify-content-center'>\r\n <Form.Group className='col-xs-auto mb-3'>\r\n <Card style={{ width: '20rem', boxShadow: 'rgb(0 0 0 / 20%) -4px 4px 8px 0px' }} className='left'>\r\n <div className='card-img'>\r\n <Card.Img variant=\"top\" src={researcher} />\r\n </div>\r\n <Card.Body>\r\n <Card.Title style={{ textAlign: 'center' }}>Researcher</Card.Title>\r\n <Card.Text className='mb-4'>\r\n Would you like to involve a EUPATI Patient Expert in your patient engagement initiative or opportunity?\r\n </Card.Text>\r\n <Form.Group style={{ textAlign: 'center', margin: '0' }}>\r\n <ResearcherBtn />\r\n </Form.Group>\r\n </Card.Body>\r\n </Card>\r\n </Form.Group>\r\n\r\n <Form.Group className='col-xs-auto mb-3'>\r\n <Card style={{ width: '20rem', boxShadow: 'rgb(0 0 0 / 20%) -4px 4px 8px 0px' }}>\r\n <div className='card-img'>\r\n <Card.Img variant=\"top\" src={patient} />\r\n </div>\r\n <Card.Body>\r\n <Card.Title style={{ textAlign: 'center' }}>EUPATI Patient Expert</Card.Title>\r\n <Card.Text className='mb-4'>\r\n Update your profile to share your knowledge and participate in patient engagement opportunities today.\r\n </Card.Text>\r\n <Form.Group style={{ textAlign: 'center', margin: '0 0 2px 0' }}>\r\n <PatientBtn />\r\n </Form.Group>\r\n </Card.Body>\r\n </Card>\r\n </Form.Group>\r\n </div>\r\n </section>\r\n\r\n </>\r\n )\r\n }\r\n\r\n if (!this.props.isLoading) {\r\n whyComponent = (\r\n <>\r\n <section className='why-title-sec'>\r\n <div className='why-title-sec-txt'>\r\n <h5 className='why-title-sec-txt-title mb-4'>Why EUPATIConnect?</h5>\r\n <p className='why-title-sec-txt-para'>\r\n EUPATIConnect is a place where both EUPATI Patient Experts and researchers can connect, to create mutually beneficial opportunities and to enhance the future of patient engagement.\r\n </p>\r\n </div>\r\n </section>\r\n <section className='why-content-sec'>\r\n <div className='why-content-sec-panel panel-right'>\r\n <div className='why-content-sec-panel-image'>\r\n <img className='why-image' src={imgWhy1} />\r\n </div>\r\n <div className='why-content-sec-panel-content'>\r\n <div className='why-content-sec-panel-content-title'>\r\n Large database of EUPATI Fellows\r\n </div>\r\n <div className='why-content-sec-panel-content-description'>\r\n We can connect you with 200+ EUPATI Patient Experts from over 100+ disease areas. We also have over 300+ EUPATI Open Classroom learners who have expertise in 1 or more EUPATI learning modules.\r\n </div>\r\n </div>\r\n </div>\r\n <div id='small-panel' className='why-content-sec-panel panel-left'>\r\n <div className='why-content-sec-panel-content'>\r\n <div className='why-content-sec-panel-content-title'>\r\n International Network <br />of EUPATI Fellows\r\n </div>\r\n <div className='why-content-sec-panel-content-description'>\r\n Our Patient Experts come from over <br />39 number of countries.\r\n </div>\r\n </div>\r\n <div className='why-content-sec-panel-image'>\r\n <img className='why-image' src={imgWhy2} />\r\n </div>\r\n </div>\r\n <div className='why-content-sec-panel panel-right'>\r\n <div className='why-content-sec-panel-image'>\r\n <img className='why-image' src={imgWhy3} />\r\n </div>\r\n <div className='why-content-sec-panel-content'>\r\n <div className='why-content-sec-panel-content-title'>\r\n Proficiency of Language\r\n </div>\r\n <div className='why-content-sec-panel-content-description'>\r\n Fluency in English is a requirement of the EUPATI training programme therefore our patients have a high degree of fluency in English. However, as our Patient Experts hail from all over the world many also have proficiency in a second or third language.\r\n </div>\r\n </div>\r\n </div>\r\n <div className='why-content-sec-panel panel-left'>\r\n <div className='why-content-sec-panel-content'>\r\n <div className='why-content-sec-panel-content-title'>\r\n Scientific and Health Literacy\r\n </div>\r\n <div className='why-content-sec-panel-content-description'>\r\n High level of knowledge of the medicines R&D process coupled with a high level of literacy in health and scientific terms. Our modules include Non-Clinical and Clinical Development, Health Technology Assessment, Regulatory Affairs.\r\n </div>\r\n </div>\r\n <div className='why-content-sec-panel-image'>\r\n <img className='why-image' src={imgWhy4} />\r\n </div>\r\n </div>\r\n <div className='why-content-sec-panel panel-right'>\r\n <div className='why-content-sec-panel-image'>\r\n <img className='why-image' src={imgWhy5} />\r\n </div>\r\n <div className='why-content-sec-panel-content'>\r\n <div className='why-content-sec-panel-content-title'>\r\n Strongly Motivated\r\n </div>\r\n <div className='why-content-sec-panel-content-description'>\r\n Patients Experts come to EUPATI driven internally by their desire to learn and change the future of patient engagement. As a result, they are strongly motivated to partner with researchers and to provide input, advice and feedback on all aspects of the medicines R&D process.\r\n </div>\r\n </div>\r\n </div>\r\n <div className='why-content-sec-panel panel-left'>\r\n <div className='why-content-sec-panel-content'>\r\n <div className='why-content-sec-panel-content-title'>\r\n Changing The Future Landscape of Patient Engagement\r\n </div>\r\n <div className='why-content-sec-panel-content-description'>\r\n Our partners and Patient Experts regularly share their experience of working together on research projects. In turn, these experiences often become case studies within our Patient Expert toolbox, thereby enhancing learning for future generations of Patient Experts to come.\r\n </div>\r\n </div>\r\n <div className='why-content-sec-panel-image'>\r\n <img className='why-image' src={imgWhy6} />\r\n </div>\r\n </div>\r\n <div className='why-content-sec-panel panel-right'>\r\n <div className='why-content-sec-panel-image'>\r\n <img className='why-image' src={imgWhy7} />\r\n </div>\r\n <div className='why-content-sec-panel-content'>\r\n <div className='why-content-sec-panel-content-title'>\r\n Quality of Training\r\n </div>\r\n <div className='why-content-sec-panel-content-description'>\r\n We pride ourselves on the thorough and rigorous training of the EUPATI Programme. All content has been created via a rigorous multistakeholder (patient, academic and industry) process to ensure the highest standard of patient engagement education.\r\n </div>\r\n </div>\r\n </div>\r\n <div className='why-content-sec-panel panel-left'>\r\n <div className='why-content-sec-panel-content'>\r\n <div className='why-content-sec-panel-content-title'>\r\n Opportunity to Share Knowledge\r\n </div>\r\n <div className='why-content-sec-panel-content-description'>\r\n EUPATIConnect provides a unique opportunity for EUPATI Fellows to share their knowledge, advance the patient engagement agenda and demonstrate their availability to be involved in future research opportunities and projects.\r\n </div>\r\n </div>\r\n <div className='why-content-sec-panel-image'>\r\n <img className='why-image' src={imgWhy8} />\r\n </div>\r\n </div>\r\n <div className='why-content-sec-panel panel-right'>\r\n <div className='why-content-sec-panel-image'>\r\n <img className='why-image' src={imgWhy9} />\r\n </div>\r\n <div className='why-content-sec-panel-content'>\r\n <div className='why-content-sec-panel-content-title'>\r\n Building New Connections\r\n </div>\r\n <div className='why-content-sec-panel-content-description'>\r\n EUPATIConnect provides EUPATI Fellows and Open Classroom learners the opportunity to build new connections as part of the large EUPATI Network.\r\n </div>\r\n </div>\r\n </div>\r\n </section>\r\n </>\r\n );\r\n\r\n noteComponent = (\r\n <>\r\n <section className='note-sec'>\r\n <div className='note-sec-txt'>\r\n <h5 className='note-sec-txt-title mb-4'>EUPATI National Platforms with Local Connections</h5>\r\n <p className='note-sec-txt-para'>\r\n EUPATI has National Platforms in over 23 countries a number of which are currently running their own local versions of the course (Ireland, Italy & The Netherlands). Therefore, if you require specific local expertise, we can also connect you with our local ENPs.\r\n </p>\r\n </div>\r\n <img src={imgNetBallPartial} className='net-ball-partial' />\r\n </section>\r\n </>\r\n );\r\n\r\n statsComponent = (\r\n <>\r\n <section className='stats-sec'>\r\n <div className='stats-sec-txt'>\r\n <h5 className='stats-sec-txt-title mb-5'>Statistics</h5>\r\n </div>\r\n <div className='stats-sec-content'>\r\n <div className='stats-sec-content-stat'>\r\n <div className='stats-sec-content-stat-title'>300</div>\r\n <div className='stats-sec-content-stat-content'>hours of online training</div>\r\n </div>\r\n <div className='stats-sec-content-stat'>\r\n <div className='stats-sec-content-stat-title'>8 days</div>\r\n <div className='stats-sec-content-stat-content'>of intensive classroom training</div>\r\n </div>\r\n <div className='stats-sec-content-stat'>\r\n <div className='stats-sec-content-stat-title'>200+</div>\r\n <div className='stats-sec-content-stat-content'>EUPATI Fellows</div>\r\n </div>\r\n <div className='stats-sec-content-stat'>\r\n <div className='stats-sec-content-stat-title'>300+</div>\r\n <div className='stats-sec-content-stat-content'>EUPATI Open Classroom Learners</div>\r\n </div>\r\n <div className='stats-sec-content-stat'>\r\n <div className='stats-sec-content-stat-title'>100+</div>\r\n <div className='stats-sec-content-stat-content'>disease areas</div>\r\n </div>\r\n <div className='stats-sec-content-stat'>\r\n <div className='stats-sec-content-stat-title'>39</div>\r\n <div className='stats-sec-content-stat-content'>number of countries</div>\r\n </div>\r\n <div className='stats-sec-content-stat'>\r\n <div className='stats-sec-content-stat-title'>35</div>\r\n <div className='stats-sec-content-stat-content'>of languages spoken</div>\r\n </div>\r\n </div>\r\n <img src={imgNetBallHalf} className='net-ball-stats-right' />\r\n </section>\r\n </>\r\n );\r\n\r\n patientEngagementComponent = (\r\n <>\r\n <section className='engagement-sec'>\r\n <div className='engagement-sec-separator'>\r\n <img src={imgEngagementSeparator} />\r\n </div>\r\n <div className='engagement-sec-txt'>\r\n <h5 className='engagement-sec-txt-title mb-4'>Patient Engagement Tools</h5>\r\n <p className='engagement-sec-txt-para'>\r\n Looking for further information on how to engage patients in your project? Check out our patient engagement tools below\r\n </p>\r\n </div>\r\n <div className='engagement-sec-content'>\r\n <a href='https://toolbox.eupati.eu/resources-guidance/patient-engagement-roadmap/' target='_blank'>\r\n <div className='engagement-sec-content-card'>\r\n <img src={imgRoadmap} />\r\n <div className='engagement-sec-content-card-name'>Patient Engagement Roadmap</div>\r\n </div>\r\n </a>\r\n {/* <a href='https://toolbox.eupati.eu/guidance/' target='_blank'> */}\r\n <div className='engagement-sec-content-double-card'>\r\n <div className='engagement-sec-content-double-card-title'><img src={imgGuidances} /> Guidances</div>\r\n <ul>\r\n <li><FontAwesomeIcon icon={this.returnProperIconType(faCheck)} /><div className='engagement-sec-content-double-card-item'><a href='https://toolbox.eupati.eu/guidance/' target='_blank'>EUPATI Patient Engagement Guidances</a></div></li>\r\n <li><FontAwesomeIcon icon={this.returnProperIconType(faCheck)} /><div className='engagement-sec-content-double-card-item'><a href='https://imi-paradigm.eu/petoolbox/' target='_blank'>PARADIGM Tools</a></div></li>\r\n <li><FontAwesomeIcon icon={this.returnProperIconType(faCheck)} /><div className='engagement-sec-content-double-card-item'><a href='https://pemsuite.org/legal-and-contractual-tools/' target='_blank'>PFMD Legal and Contracting Tools</a></div></li>\r\n <li><FontAwesomeIcon icon={this.returnProperIconType(faCheck)} /><div className='engagement-sec-content-double-card-item'><a href='https://pemsuite.org/fmv/' target='_blank'>PFMD Remuneration and Fair Market Value tools</a></div></li>\r\n </ul>\r\n </div>\r\n {/* </a> */}\r\n {/* <a href='https://imi-paradigm.eu/' target='_blank'>\r\n <div className='engagement-sec-content-card'>\r\n <img src={imgParadigmTools} />\r\n <div className='engagement-sec-content-card-name'>Paradigm Tools</div>\r\n </div>\r\n </a> */}\r\n </div>\r\n <img src={imgNetBallLight} className='net-ball-stats-left' />\r\n </section>\r\n </>\r\n );\r\n\r\n testimonialComponent = <Testimonials />;\r\n\r\n faqComponent = (\r\n <>\r\n <section className='faq-sec'>\r\n <div className='faq-sec-separator'>\r\n <img src={imgFaqSeparator} />\r\n </div>\r\n <div className='faq-sec-txt'>\r\n <h5 className='faq-sec-txt-title mb-4'>FAQ</h5>\r\n {/* <p className='faq-sec-txt-para'>\r\n Looking for further information on how to engage patients in your project? Check out our patient engagement tools below\r\n </p> */}\r\n </div>\r\n <div className='faq-sec-content'>\r\n {/* <a href='/faq'>\r\n <div className='faq-sec-content-card'>\r\n <img src={imgFaqWhatIsEupati} />\r\n <div className='faq-sec-content-card-name'>What is EUPATIConnect?</div>\r\n </div>\r\n </a> */}\r\n <a href='/faq'>\r\n <div className='faq-sec-content-card'>\r\n <img src={imgFaqHowDoesWork} />\r\n <div className='faq-sec-content-card-name'>\r\n <span className='faq-sec-content-card-text'>What is EUPATIConnect?<br />How does it work?</span>\r\n </div>\r\n </div>\r\n </a>\r\n </div>\r\n <div className='faq-sec-txt'>\r\n <p className='faq-sec-txt-link'>\r\n <a href='/faq'>Check our FAQ page</a>\r\n </p>\r\n </div>\r\n </section >\r\n </>\r\n );\r\n }\r\n\r\n return (\r\n <>\r\n {mainComponent}\r\n {whyComponent}\r\n {noteComponent}\r\n {statsComponent}\r\n {patientEngagementComponent}\r\n {testimonialComponent}\r\n {faqComponent}\r\n </>\r\n );\r\n }\r\n}","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","import { default as RootComponent, DispatchProps } from '../components/component-root';\r\nimport * as Constants from '../constants';\r\nimport * as Actions from '../actions';\r\nimport { State } from '../model';\r\nimport { connect } from 'react-redux';\r\n\r\nexport function mapStateToProps(globalState: any) {\r\n let name = Constants.NAME;\r\n let pageState = globalState[name] as State;\r\n return pageState;\r\n}\r\n\r\nexport function mapDispatchToProps(dispatch: any) {\r\n return {\r\n setIsUserReal: (token: string) => dispatch(Actions.verifyUserTokenAsync(token)),\r\n setUserStatus: (isAdmin: boolean) => dispatch(Actions.setUserStatusAsync(isAdmin))\r\n } as DispatchProps;\r\n}\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(RootComponent);","import { State } from './model';\r\nimport * as t from './actionType'\r\n\r\nconst initialState: State = {\r\n isLoading: false,\r\n isLoggedIn: false,\r\n isUserReal: true\r\n};\r\n\r\nexport default (state = initialState, action: any): State => {\r\n switch (action.type) {\r\n case t.SET_HOME_LOADING:\r\n return setHomeLoading(state, action.payload);\r\n case t.SET_HOME_LOGGED_IN:\r\n return setHomeLoggedInStatus(state, action.payload);\r\n case t.SET_IS_USER_REAL:\r\n return setIsUserReal(state, action.payload);\r\n default:\r\n return state;\r\n }\r\n};\r\n\r\nconst setHomeLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setHomeLoggedInStatus = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isLoggedIn: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setIsUserReal = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isUserReal: val\r\n } as State;\r\n\r\n return newState;\r\n}","import * as Actions from './actions';\r\nimport * as Components from './components/index';\r\nimport * as Containers from './containers/index';\r\nimport * as Constants from './constants';\r\nimport Reducer from './reducer';\r\n\r\nexport default {\r\n actions: Actions,\r\n components: Components,\r\n containers: Containers,\r\n constants: Constants,\r\n reducer: Reducer\r\n};\r\n\r\nexport const Root = Containers.ComponentRoot;","// constants.ts\r\n\r\nexport const NAME = 'allProjects';","import { NAME } from \"./constants\";\r\n\r\nexport const SET_LOOKUP_DATA = `${NAME}/SET_LOOKUP_DATA`;\r\n\r\nexport const SET_LOADING = `${NAME}/SET_LOADING`;\r\n\r\nexport const SET_PROJECTS = `${NAME}/SET_PROJECTS`;\r\n\r\nexport const SET_PROJECTS_LOADING = `${NAME}/SET_PROJECTS_LOADING`;\r\n\r\nexport const SET_PROJECTS_FILTER = `${NAME}/SET_PROJECTS_FILTER`;\r\n\r\nexport const SET_MATCHED_PATIENTS = `${NAME}/SET_MATCHED_PATIENTS`;\r\n\r\nexport const SET_MATCHED_PATIENTS_LOADING = `${NAME}/SET_MATCHED_PATIENTS_LOADING`;\r\n\r\nexport const SET_PROJECT_DATA = `${NAME}/SET_PROJECT_DATA`;\r\n\r\nexport const SET_PROJECT_LOADING = `${NAME}/SET_PROJECT_LOADING`;\r\n\r\nexport const SET_TEMPLATES_LOADING = `${NAME}/SET_TEMPLATES_LOADING`;\r\n\r\nexport const SET_EMAIL_TEMPLATES = `${NAME}/SET_EMAIL_TEMPLATES`;\r\n\r\nexport const SET_SINGLE_EMAIL_TEMPLATE = `${NAME}/SET_SINGLE_EMAIL_TEMPLATE`;","// model.js\r\n// This is the model of our module state (e.g. return type of the reducer)\r\n\r\nimport { EmailTemplateData, LookUpData } from \"../../../common/models/input-models\";\r\nimport { Patient, Project } from \"../../../common/models/main-models\";\r\n\r\nexport type State = {\r\n isLoading: boolean;\r\n lookUpData: LookUpData[];\r\n isProjectsLoading: boolean;\r\n projects: Project[];\r\n filter: number;\r\n matchedPatients: Patient[];\r\n isMatchedPatientsLoading: boolean;\r\n project: Project;\r\n isProjectLoading: boolean;\r\n emailTemplates: EmailTemplateData[];\r\n singleEmailTemplate: EmailTemplateData;\r\n emailTemplateLoading: boolean;\r\n};\r\n\r\nexport const defaultEmailTemplate = {\r\n id: '',\r\n name: '',\r\n subject: '',\r\n actions: [],\r\n htmlContent: ''\r\n} as EmailTemplateData;","import { ProjectStatus } from \"../../../common/helpers\";\r\nimport { EmailTemplateData, LookUpData, PatientSearchData, ProjectPatientData, ProjectStatusData, RequestData } from \"../../../common/models/input-models\";\r\nimport { Patient, Project } from \"../../../common/models/main-models\";\r\nimport DataSvc from \"../../../common/services/data-svc\";\r\nimport * as t from './actionTypes';\r\nimport { defaultEmailTemplate } from \"./model\";\r\n\r\nexport const setLoading = (isLoading: boolean) => ({\r\n type: t.SET_LOADING,\r\n payload: isLoading\r\n});\r\n\r\nexport const setLookUpData = (data: LookUpData[]) => ({\r\n type: t.SET_LOOKUP_DATA,\r\n payload: data\r\n});\r\n\r\nexport const setProjects = (projects: Project[]) => ({\r\n type: t.SET_PROJECTS,\r\n payload: [...projects]\r\n});\r\n\r\nexport const setIsProjectsLoading = (isProjectsLoading: boolean) => ({\r\n type: t.SET_PROJECTS_LOADING,\r\n payload: isProjectsLoading\r\n});\r\n\r\nexport const setProjectsFilter = (filter: number) => ({\r\n type: t.SET_PROJECTS_FILTER,\r\n payload: filter\r\n});\r\n\r\nexport const setMatchedPatients = (matchedPatients: Patient[]) => ({\r\n type: t.SET_MATCHED_PATIENTS,\r\n payload: [...matchedPatients]\r\n});\r\n\r\nexport const setMatchedPatientsLoading = (isMatchedPatientsLoading: boolean) => ({\r\n type: t.SET_MATCHED_PATIENTS_LOADING,\r\n payload: isMatchedPatientsLoading\r\n});\r\n\r\nexport const setProjectData = (project: Project) => ({\r\n type: t.SET_PROJECT_DATA,\r\n payload: project\r\n});\r\n\r\nexport const setProjectLoading = (isProjectsLoading: boolean) => ({\r\n type: t.SET_PROJECT_LOADING,\r\n payload: isProjectsLoading\r\n});\r\n\r\nexport const setEmailTemplates = (emailTemplates: EmailTemplateData[]) => ({\r\n type: t.SET_EMAIL_TEMPLATES,\r\n payload: [...emailTemplates]\r\n});\r\n\r\nexport const setSingleEmailTemplate = (singleEmailTemplate: EmailTemplateData) => ({\r\n type: t.SET_SINGLE_EMAIL_TEMPLATE,\r\n payload: { ...singleEmailTemplate }\r\n});\r\n\r\nexport const setEmailTemplateLoading = (emailTemplateLoading: boolean) => ({\r\n type: t.SET_TEMPLATES_LOADING,\r\n payload: emailTemplateLoading\r\n});\r\n\r\nexport const getLookUpDataAsync = () => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setLoading(true));\r\n DataSvc.utilsSvc.getLookUpData().then(\r\n (result: any) => {\r\n dispatch(setLookUpData(result));\r\n dispatch(setLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n );\r\n };\r\n};\r\n\r\nexport const getAllFilteredProjectsAsync = (condition: number) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setIsProjectsLoading(true));\r\n DataSvc.projectsSvc.getAllProjects().then(\r\n (result: any) => {\r\n var projects = [];\r\n if (condition > 0) {\r\n projects = [...result.filter((x: any) => {\r\n return x.projectStatusId == condition;\r\n })];\r\n } else {\r\n projects = result;\r\n }\r\n dispatch(setProjects(projects));\r\n dispatch(setIsProjectsLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const updateSearchPatients = (searchData?: PatientSearchData, projectName?: string) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setMatchedPatientsLoading(true));\r\n DataSvc.patientSvc.searchPatients(searchData).then(\r\n (result: any) => {\r\n if (typeof result !== 'undefined' && typeof projectName !== 'undefined') {\r\n dispatch(setMatchedPatients([...result.filter((pt: Patient) =>\r\n !pt.matchedProjects.some((x: any) => x.name.toLowerCase() === projectName.toLowerCase()) &&\r\n !pt.confirmedProjects.some((x: any) => x.name.toLowerCase() === projectName.toLowerCase()))])\r\n );\r\n }\r\n dispatch(setMatchedPatientsLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const getProjectDataByIdAsync = (projectId: string) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setProjectLoading(true));\r\n DataSvc.projectsSvc.getProjectById(projectId).then(\r\n (result: any) => {\r\n if (typeof result !== 'undefined') { dispatch(setProjectData(result)); }\r\n dispatch(setProjectLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const removePatientFromProjectAsync = (inputModel: ProjectPatientData) => {\r\n return (dispatch: any, getState: any) => {\r\n DataSvc.projectsSvc.removePatientFromProject(inputModel).then(\r\n () => {\r\n dispatch(getProjectDataByIdAsync(inputModel.projectId));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const addPatientToProjectAsync = (inputModel: ProjectPatientData, searchData?: PatientSearchData, projectName?: string) => {\r\n return (dispatch: any, getState: any) => {\r\n DataSvc.projectsSvc.assignPatientToProject(inputModel).then(\r\n () => {\r\n dispatch(updateSearchPatients(searchData, projectName));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const changePatientStatusToConfirmAsync = (inputModel: ProjectPatientData) => {\r\n return (dispatch: any, getState: any) => {\r\n DataSvc.projectsSvc.changePatientStatusToConfirm(inputModel).then(\r\n () => {\r\n dispatch(getProjectDataByIdAsync(inputModel.projectId));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const changeProjectStatusAsync = (id: string, filter: number) => {\r\n return (dispatch: any, getState: any) => {\r\n DataSvc.projectsSvc.getProjectById(id).then(\r\n (result: any) => {\r\n const inputModel = {\r\n projectId: result.id,\r\n statusId: filter //=== ProjectStatus.archivedStatusID ? ProjectStatus.inProgressStatusID.toString() : ProjectStatus.archivedStatusID\r\n } as ProjectStatusData;\r\n DataSvc.projectsSvc.changeProjectStatus(inputModel).then(\r\n () => {\r\n dispatch(getAllFilteredProjectsAsync(result.projectStatusId));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n },\r\n (error) => { console.error(error); }\r\n );\r\n }\r\n}\r\n\r\nexport const submitEmailDataAsync = (data: RequestData) => {\r\n return (dispatch: any, getState: any) => {\r\n DataSvc.utilsSvc.sendEmail(data).catch(error => console.error(error));\r\n }\r\n}\r\n\r\nexport const getAllEmailTemplatesAsync = () => {\r\n return (dispatch: any, getState: any) => {\r\n DataSvc.utilsSvc.getAllEmailTemplates().then(\r\n (result: any) => {\r\n dispatch(setEmailTemplates(result));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const getEmailTemplateByNameAsync = (name: string) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setEmailTemplateLoading(true));\r\n switch (name) {\r\n case 'empty':\r\n dispatch(setSingleEmailTemplate(defaultEmailTemplate));\r\n dispatch(setEmailTemplateLoading(false));\r\n break;\r\n default:\r\n DataSvc.utilsSvc.getEmailTemplateByName(name).then(\r\n (result: any) => {\r\n dispatch(setSingleEmailTemplate(result));\r\n dispatch(setEmailTemplateLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n );\r\n }\r\n }\r\n}","import React, { useState } from 'react';\r\nimport { Button, Form } from 'react-bootstrap';\r\nimport { IconProp } from '@fortawesome/fontawesome-svg-core';\r\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\r\nimport { faArrowLeft } from '@fortawesome/fontawesome-free-solid';\r\nimport './static.scss';\r\nimport { ProjectPatientData } from '../models/input-models';\r\nimport DataSvc from '../services/data-svc';\r\nimport { toast } from 'react-toastify';\r\nimport { DEL_PT_FROM_PROJ_MSG, ADD_PT_TO_PROJ_MSG } from '../helpers/messages';\r\n\r\ntype OwnProps = {\r\n leftArrowText: string,\r\n displayStylesProp: string,\r\n isForwardArrowAvail: boolean\r\n patientId?: string,\r\n projectId?: string,\r\n rightArrowText?: string,\r\n forwardBtnHandler?: Function,\r\n}\r\n\r\ntype DispatchProps = {\r\n backBtnHandler: () => void;\r\n}\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nexport default function EupatiArrowsMenu(props: Props) {\r\n\r\n const [isBtnDisabled, setIsBtnDisabled] = useState<boolean>(false);\r\n const [btnCursorProps, setBtnCursorProps] = useState<string>('');\r\n\r\n function returnProperIconType(icon: any) {\r\n return icon as IconProp;\r\n }\r\n\r\n function removePatientFromProject(inputModel: any) {\r\n DataSvc.projectsSvc.removePatientFromProject(inputModel).then(\r\n (result: any) => {\r\n setIsBtnDisabled(true);\r\n setBtnCursorProps('not-allowed');\r\n toast.success(DEL_PT_FROM_PROJ_MSG);\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n\r\n function assignPatientFromProject(inputModel: any) {\r\n DataSvc.projectsSvc.assignPatientToProject(inputModel).then(\r\n (result: any) => {\r\n setIsBtnDisabled(true);\r\n setBtnCursorProps('not-allowed');\r\n toast.success(ADD_PT_TO_PROJ_MSG);\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n\r\n function rightArrowBtn() {\r\n let inputModel = {\r\n projectId: props.projectId,\r\n patientId: props.patientId\r\n } as ProjectPatientData;\r\n\r\n if (typeof inputModel.projectId === 'undefined' &&\r\n typeof inputModel.patientId === 'undefined') {\r\n if (props.forwardBtnHandler) { props.forwardBtnHandler(); } // redirect to manual search\r\n }\r\n else {\r\n if (props?.rightArrowText?.toLowerCase().includes('remove')) {\r\n removePatientFromProject(inputModel);\r\n } else if (props?.rightArrowText?.toLowerCase().includes('assign')) {\r\n assignPatientFromProject(inputModel);\r\n } else if (props?.rightArrowText?.toLowerCase().includes('edit')) {\r\n //TODO: edit patient info...\r\n if (props.forwardBtnHandler) { props?.forwardBtnHandler(); }\r\n }\r\n }\r\n }\r\n\r\n return (\r\n <Form.Group className='arrows-menu' style={{ display: `${props.displayStylesProp}` }}>\r\n <Form.Group className='left-arrow-container' onClick={props.backBtnHandler}>\r\n <FontAwesomeIcon\r\n icon={returnProperIconType(faArrowLeft)}\r\n className='left-arrow-container-icon'\r\n />\r\n <span className='left-arrow-container-text'>{props.leftArrowText.toUpperCase()}</span>\r\n </Form.Group>\r\n <Form.Group className='right-arrow-container' style={!props.isForwardArrowAvail ? { visibility: 'hidden' } : { visibility: 'visible' }} onClick={rightArrowBtn}>\r\n <Button style={{ cursor: btnCursorProps }} disabled={isBtnDisabled} variant='warning' className='right-arrow-container-btn'>{props?.rightArrowText?.toUpperCase()}</Button>\r\n </Form.Group>\r\n </Form.Group>\r\n );\r\n}\r\n","import { IconProp } from '@fortawesome/fontawesome-svg-core';\r\nimport * as React from 'react';\r\nimport { Table } from 'react-bootstrap';\r\nimport { LookUpData } from '../models/input-models';\r\nimport { Patient } from '../models/main-models';\r\nimport EupatiArrowsMenu from './arrows-menu';\r\n\r\ntype OwnProps = {\r\n patientInfo: Patient;\r\n lookUpData: LookUpData[];\r\n leftArrowText: string;\r\n rightArrowText?: string;\r\n isForwardArrowAvail: boolean;\r\n searchData?: any;\r\n projectName?: string;\r\n projectId?: string;\r\n forwardBtnHandler?: Function;\r\n};\r\n\r\nexport type DispatchProps = {\r\n backBtnHandler: () => void;\r\n};\r\n\r\ntype OwnState = {\r\n backBtnClicked: boolean;\r\n};\r\n\r\ntype Props = DispatchProps & OwnProps;\r\n\r\nexport default class EupatiPatientDetails extends React.Component<Props, OwnState> {\r\n\r\n\r\n constructor(props: any) {\r\n super(props);\r\n\r\n this.state = {\r\n backBtnClicked: false\r\n }\r\n\r\n this.returnValueById = this.returnValueById.bind(this);\r\n this.returnJoinedArrayValues = this.returnJoinedArrayValues.bind(this);\r\n this.returnProperIconType = this.returnProperIconType.bind(this);\r\n this.toggleField = this.toggleField.bind(this);\r\n }\r\n\r\n returnValueById(propName: string, projectPropId: any) {\r\n let propType = this.props.lookUpData?.find(x => x.name == propName); // projectType\r\n\r\n let propValue = propType?.data.find(x => x.id == projectPropId);\r\n\r\n return propValue?.name;\r\n }\r\n\r\n returnJoinedArrayValues(fieldProps: any, lookUpDataType: any) {\r\n let arr = fieldProps?.map((x: any, i: any) => {\r\n return (\r\n this.returnValueById(lookUpDataType, x)\r\n )\r\n });\r\n\r\n return arr?.join(', ');\r\n }\r\n\r\n returnProperIconType(icon: any) {\r\n return icon as IconProp;\r\n }\r\n\r\n toggleField(val: string) {\r\n return val !== null && val !== '' ? true : false;\r\n }\r\n\r\n render() {\r\n\r\n let mainComponent = (\r\n <>\r\n <tbody>\r\n <tr>\r\n <th style={{ textAlign: 'center' }}>Patient information</th>\r\n </tr>\r\n <tr>\r\n <td>First name</td>\r\n <td>{this.props.patientInfo.firstName}</td>\r\n </tr>\r\n <tr>\r\n <td>Last name</td>\r\n <td>{this.props.patientInfo.lastName}</td>\r\n </tr>\r\n <tr>\r\n <td>Phone number</td>\r\n <td>{this.props.patientInfo.phoneNumber}</td>\r\n </tr>\r\n <tr>\r\n <td>Email</td>\r\n <td>{this.props.patientInfo.email}</td>\r\n </tr>\r\n <tr>\r\n <td>Birth year</td>\r\n <td>{this.props.patientInfo.birthYear}</td>\r\n </tr>\r\n <tr>\r\n <td>Gender</td>\r\n <td>{this.returnValueById('genderType', this.props.patientInfo.genderTypeId)}</td>\r\n </tr>\r\n {this.toggleField(this.props?.patientInfo?.genderTypeDescription) &&\r\n <tr>\r\n <td>Gender description</td>\r\n <td>{this.props?.patientInfo?.genderTypeDescription}</td>\r\n </tr>\r\n }\r\n <tr>\r\n <td>Country</td>\r\n <td>{this.returnValueById('country', this.props.patientInfo.countryId)}</td>\r\n </tr>\r\n <tr>\r\n <td>Languages</td>\r\n <td>{this.returnJoinedArrayValues(this.props.patientInfo?.languages, 'language')}</td>\r\n </tr>\r\n <tr>\r\n <td>Countries with experience</td>\r\n <td>{this.returnJoinedArrayValues(this.props.patientInfo?.countriesWithExperience, 'countryWithContinents')}</td>\r\n </tr>\r\n <tr>\r\n <td>Is patient org affiliated</td>\r\n <td>{this.props.patientInfo.isPOAffiliated ? \"Yes\" : \"No\"}</td>\r\n </tr>\r\n {this.props.patientInfo.isPOAffiliated &&\r\n <tr>\r\n <td>Patient organisation</td>\r\n <td>{this.props.patientInfo.patientOrganisation}</td>\r\n </tr>\r\n }\r\n <tr>\r\n <td>Disease experience</td>\r\n <td>{this.props.patientInfo.noDiseaseExpertise ? \"No specific disease experience\" : this.props.patientInfo.diseases.map(d => d.name).join(\", \")}</td>\r\n </tr>\r\n <tr>\r\n <td>Patient experience</td>\r\n <td>{this.returnValueById('patientExperiense', this.props.patientInfo?.patientExperienceId)}</td>\r\n </tr>\r\n <tr>\r\n <td>Patient expertise</td>\r\n <td>{this.returnJoinedArrayValues(this.props.patientInfo?.patientExpertises, 'expertise')}</td>\r\n </tr>\r\n {this.toggleField(this.props?.patientInfo?.patientExpertiseDescription) &&\r\n <tr>\r\n <td>Patient expertise description</td>\r\n <td>{this.props?.patientInfo?.patientExpertiseDescription}</td>\r\n </tr>\r\n }\r\n <tr>\r\n <td>Project type experiences</td>\r\n <td>{this.returnJoinedArrayValues(this.props.patientInfo?.projectTypeExperiences, 'projectType')}</td>\r\n </tr>\r\n {this.toggleField(this.props?.patientInfo?.projectTypeExperiencesDescription) &&\r\n <tr>\r\n <td>Project type experience description</td>\r\n <td>{this.props?.patientInfo?.projectTypeExperiencesDescription}</td>\r\n </tr>\r\n }\r\n <tr>\r\n <td>Is eligible for compensations</td>\r\n <td>{this.props.patientInfo.isEligibleForCompensation ? \"Yes\" : \"No\"}</td>\r\n </tr>\r\n <tr>\r\n <td>Is available for voluntary work</td>\r\n <td>{this.props.patientInfo.isAvailableForNoCompensation ? \"Yes\" : \"No\"}</td>\r\n </tr>\r\n <tr>\r\n <td>Project preferences</td>\r\n <td>{this.returnJoinedArrayValues(this.props.patientInfo?.projectPreferences, 'projectType')}</td>\r\n </tr>\r\n {this.toggleField(this.props?.patientInfo?.projectPreferenceDescription) &&\r\n <tr>\r\n <td>Project preferences description</td>\r\n <td>{this.props?.patientInfo?.projectPreferenceDescription}</td>\r\n </tr>\r\n }\r\n <tr>\r\n <td>Organisation preferences</td>\r\n <td>{this.returnJoinedArrayValues(this.props.patientInfo?.organisationPreferences, 'organisationType')}</td>\r\n </tr>\r\n {this.toggleField(this.props?.patientInfo?.organisationPreferenceDescription) &&\r\n <tr>\r\n <td>Organisation preference description</td>\r\n <td>{this.props?.patientInfo?.organisationPreferenceDescription}</td>\r\n </tr>\r\n }\r\n <tr>\r\n <td>Activity preference</td>\r\n <td>{this.returnValueById('activityType', this.props.patientInfo?.activityPreferenceId)}</td>\r\n </tr>\r\n <tr>\r\n <td>Other information</td>\r\n <td>{this.props.patientInfo.otherInformation}</td>\r\n </tr>\r\n {/* {this.props.patientInfo.matchedProjects.length > 0 &&\r\n <tr>\r\n <td>Matched projects</td>\r\n <td>{this.props.patientInfo.matchedProjects.map((x: any) => x.name).join(',')}</td>\r\n </tr>\r\n } */}\r\n <tr>\r\n <td>Is banned from search</td>\r\n <td>{this.props.patientInfo.isBannedFromSearch ? \"Yes\" : \"No\"}</td>\r\n </tr>\r\n </tbody>\r\n </>\r\n )\r\n\r\n return (\r\n <>\r\n <EupatiArrowsMenu\r\n {...{\r\n displayStylesProp: '',\r\n leftArrowText: this.props.leftArrowText,\r\n rightArrowText: this.props.rightArrowText,\r\n backBtnHandler: this.props.backBtnHandler,\r\n forwardBtnHandler: this.props.forwardBtnHandler,\r\n projectId: this.props.projectId,\r\n patientId: this.props.patientInfo.id,\r\n isForwardArrowAvail: this.props.isForwardArrowAvail\r\n }}\r\n />\r\n\r\n <Table striped bordered hover>\r\n {mainComponent}\r\n </Table>\r\n </>\r\n );\r\n }\r\n}","import React, { useEffect, useState } from 'react';\r\nimport Popup from 'reactjs-popup';\r\nimport { Form, Button } from 'react-bootstrap';\r\nimport { useForm, Controller } from \"react-hook-form\";\r\nimport EupatiTextbox from './textbox';\r\nimport EupatiTextarea from './textarea';\r\nimport { Rules } from '../helpers';\r\n//import { EditorState, ContentState } from 'draft-js';\r\n//import { Editor } from 'react-draft-wysiwyg';\r\nimport { toast } from 'react-toastify';\r\nimport './static.scss';\r\nimport 'reactjs-popup/dist/index.css';\r\n//import \"react-draft-wysiwyg/dist/react-draft-wysiwyg.css\";\r\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\r\nimport { faWindowClose, faWindowMinimize, faWindowMaximize } from '@fortawesome/fontawesome-free-regular';\r\nimport { IconProp } from '@fortawesome/fontawesome-svg-core';\r\nimport { EmailPatientDetails, LookUpOptions, RequestData } from '../models/input-models';\r\n//import { stateToHTML } from 'draft-js-export-html';\r\nimport { SEND_EMAILS_SUCC_MSG } from '../helpers/messages';\r\n//import htmlToDraft from 'html-to-draftjs';\r\nimport { Patient, Project } from '../models/main-models';\r\nimport { EmailTemplateData } from '../models/input-models';\r\nimport EupatiDropdown from './dropdown';\r\nimport EupatiLoader from './loading-animation/loader';\r\nimport { Editor } from '@tinymce/tinymce-react';\r\nconst escape_quotes = require('escape-quotes');\r\n\r\ntype OwnProps = {\r\n recipients: string;\r\n project: Project;\r\n btnText: string;\r\n emailTemplates: EmailTemplateData[];\r\n dropdownValues: LookUpOptions[];\r\n singleEmailTemplate: EmailTemplateData;\r\n emailTemplateLoading: boolean;\r\n matchedPatients: Patient[];\r\n};\r\n\r\ntype DispatchProps = {\r\n submitRequest: (reqData: RequestData) => void;\r\n resetValues: () => void;\r\n returnLookUpValueByTypeAndId: (propName: string, projectPropId: number) => string | undefined;\r\n getAllEmailTemplates: () => void;\r\n selectTemplateByIndex: (index: number) => void;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nexport default function EmailModalPopup(props: Props) {\r\n\r\n const { handleSubmit, reset, control, watch, formState: { errors } } = useForm();\r\n\r\n const [isMaxSize, setIsMaxSize] = useState<boolean>(false);\r\n const [singleTemplateData, setSingleTemplateData] = useState<EmailTemplateData>({ ...props.singleEmailTemplate });\r\n\r\n const onSubmit = (data: any) => {\r\n toast.success(SEND_EMAILS_SUCC_MSG);\r\n const targetedPeople = data.recipients.split('\\t');\r\n props.submitRequest({\r\n recipients: targetedPeople,\r\n subject: data.subject,\r\n content: escape_quotes(returnHtmlContent()),\r\n projectId: props.project.id,\r\n patients: props.matchedPatients.filter((x: Patient) => targetedPeople.some((tp: string) => tp === x.email)).map((x: Patient) => { return { id: x.id, email: x.email } as EmailPatientDetails })\r\n } as RequestData);\r\n }\r\n\r\n const handleTemplateOnChange = (e: any) => {\r\n if (e) {\r\n //e.target.value --> selected menu option index\r\n const index = parseInt(e.target.value);\r\n if (index !== undefined && index !== null) {\r\n props.selectTemplateByIndex(index);\r\n }\r\n }\r\n }\r\n\r\n const returnProperIconType = (icon: any) => {\r\n return icon as IconProp;\r\n }\r\n\r\n const returnHtmlContent = () => {\r\n let htmlContent = '';\r\n if (singleTemplateData.htmlContent !== '') {\r\n htmlContent = props.singleEmailTemplate.htmlContent === singleTemplateData.htmlContent ? props.singleEmailTemplate.htmlContent : singleTemplateData.htmlContent;\r\n }\r\n else {\r\n htmlContent = props.singleEmailTemplate.htmlContent;\r\n }\r\n\r\n return htmlContent;\r\n }\r\n\r\n // const returnSelectedDropdownOption = () => {\r\n // if (templateIndex !== undefined && templateIndex !== null) {\r\n // return props.dropdownValues.filter((x: LookUpOptions) => x.id === templateIndex);\r\n // }\r\n // }\r\n\r\n const handleEditorChange = (content: any) => {\r\n if (content) {\r\n const updatedHtmlContent = Object.assign(props.singleEmailTemplate, { htmlContent: escape_quotes(content) });\r\n setSingleTemplateData({ ...updatedHtmlContent });\r\n }\r\n }\r\n\r\n return (\r\n <Popup className={`${!isMaxSize ? 'modal' : 'modal max-size'}`} trigger={<Button className=\"button\"> {props.btnText} </Button>} modal>\r\n {(close: any) => (\r\n <Form onSubmit={handleSubmit(onSubmit)} onFocus={(e) => e.stopPropagation()} >\r\n <Form.Group className='modal-header'>\r\n <span className='modal-header-title'>New Message</span>\r\n <div className='modal-header-icons'>\r\n <div className='modal-header-icons-ext' onClick={() => { close(); reset(); props.selectTemplateByIndex(-1); }}>\r\n <FontAwesomeIcon icon={returnProperIconType(faWindowClose)} />\r\n </div>\r\n <div className='modal-header-icons-max'>\r\n <FontAwesomeIcon icon={returnProperIconType(faWindowMaximize)} onClick={() => setIsMaxSize(!isMaxSize)} />\r\n </div>\r\n <div className='modal-header-icons-min' onClick={close}>\r\n <FontAwesomeIcon icon={returnProperIconType(faWindowMinimize)} />\r\n </div>\r\n </div>\r\n </Form.Group>\r\n <div className='modal-content-wrapper'>\r\n <Form.Group className='modal-recipients'>\r\n <Form.Label className='modal-recipients-title'>Bcc recipients</Form.Label>\r\n <Controller\r\n name='recipients'\r\n control={control}\r\n defaultValue={props.recipients}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextarea\r\n {...{\r\n ...field,\r\n errorMsg: errors?.recipients?.message,\r\n rowsCount: 1,\r\n placeholderMsg: 'Please select recipient(s)',\r\n isDisabled: true\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group className='modal-subject'>\r\n <Form.Label className='modal-subject-title'>Subject</Form.Label>\r\n <Controller\r\n name='subject'\r\n control={control}\r\n defaultValue=''\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.subject?.message,\r\n placeholder: 'Please type subject'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group className='modal-templates'>\r\n <Form.Label className='modal-templates-title'>Choose template</Form.Label>\r\n <Controller\r\n name='templates'\r\n control={control}\r\n //defaultValue={returnSelectedDropdownOption()}\r\n rules={Rules.notRequired}\r\n render={({ field }) =>\r\n <EupatiDropdown\r\n {...{\r\n ...field,\r\n onChange: handleTemplateOnChange,\r\n errorMsg: errors?.templates?.message,\r\n fieldName: 'templates',\r\n values: props.dropdownValues,\r\n defaultOptionText: 'Select template...'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <div style={{ padding: '1rem 1rem' }}>\r\n {props.emailTemplateLoading ? (\r\n <>\r\n <EupatiLoader />\r\n </>\r\n ) : (\r\n <Form.Group id='content-editor' className='modal-content'>\r\n {/* <Controller\r\n name='content'\r\n control={control}\r\n defaultValue={props.singleEmailTemplate.htmlContent}\r\n rules={Rules.requiredMessage}\r\n render={({ field }) =>\r\n <EupatiContentEditor\r\n {...{\r\n ...field,\r\n errorMsg: errors?.content?.message,\r\n }}\r\n />\r\n }\r\n /> */}\r\n <Editor\r\n apiKey=\"gi5vdpb46pw329w18n94luc6ne2yimgpjks785wd387s2qvu\"\r\n value={escape_quotes(props.singleEmailTemplate.htmlContent)}\r\n init={{\r\n height: 500,\r\n menubar: false,\r\n convert_urls: true,\r\n relative_urls: false,\r\n remove_script_host: false,\r\n plugins: ['lists'],\r\n toolbar: 'undo redo | ' +\r\n 'bold italic | alignleft aligncenter ' +\r\n 'alignright alignjustify | bullist numlist outdent indent | ' +\r\n 'removeformat',\r\n content_style: 'body { font-family:Helvetica,Arial,sans-serif; font-size:18px }'\r\n }}\r\n onEditorChange={handleEditorChange}\r\n />\r\n </Form.Group>\r\n )}\r\n </div>\r\n\r\n </div>\r\n <Form.Group className='modal-btns'>\r\n <Button variant='primary' className='modal-btns-save' type='submit'>SEND</Button>\r\n </Form.Group>\r\n </Form>\r\n )\r\n }\r\n </Popup >\r\n )\r\n};","// Row Selection: https://react-table.tanstack.com/docs/examples/row-selection\r\nimport React from \"react\";\r\n\r\n// @ts-ignore\r\nexport const Check = React.forwardRef(({ indeterminate, ...rest }, ref) => {\r\n const defaultRef = React.useRef();\r\n const resolvedRef = ref || defaultRef;\r\n\r\n React.useEffect(() => {\r\n // @ts-ignore\r\n resolvedRef.current.indeterminate = indeterminate;\r\n }, [resolvedRef, indeterminate]);\r\n\r\n return (\r\n <>\r\n <input\r\n type=\"checkbox\"\r\n // @ts-ignore\r\n ref={resolvedRef}\r\n {...rest}\r\n />\r\n </>\r\n );\r\n});\r\n","import React, { useEffect, useMemo, useState } from 'react';\r\nimport { Button, Table } from 'react-bootstrap';\r\nimport { useRowSelect, useTable } from 'react-table';\r\nimport { EmailTemplateData, LookUpData, LookUpOptions, PatientSearchData, ProjectPatientData, RequestData } from '../models/input-models';\r\nimport { Patient, Project } from '../models/main-models';\r\nimport EupatiPatientDetails from './patient-details';\r\nimport { toast } from 'react-toastify';\r\nimport { ADD_PT_TO_PROJ_MSG, DEL_PT_FROM_PROJ_MSG, CONFIRM_PATIENT_MSG } from '../helpers/messages';\r\nimport EmailPopupModal from '../static/popup-modal';\r\nimport { Check } from './react-table-checkbox';\r\n\r\ntype OwnProps = {\r\n matchedPatients: Patient[],\r\n lookUpData: LookUpData[],\r\n isPatientProfileClicked: boolean,\r\n leftArrowText: string,\r\n rightArrowText: string\r\n isForwardArrowAvail: boolean,\r\n leftBtnText: string,\r\n rightBtnText: string,\r\n projectId: string,\r\n projectName: string,\r\n isManualSearchBtnClicked: boolean,\r\n patientSearchData?: any,\r\n project: Project,\r\n isConfirmed: boolean,\r\n emailTemplates: EmailTemplateData[],\r\n singleEmailTemplate: EmailTemplateData,\r\n emailTemplateLoading: boolean\r\n};\r\n\r\ntype DispatchProps = {\r\n patientProfileBtnHandler: () => void;\r\n backToProjectProfile: () => void;\r\n toggleComponents: (val: string) => void;\r\n removePatient: (inputModel: ProjectPatientData) => void;\r\n addPatient: (inputModel: ProjectPatientData, searchData: PatientSearchData, projectName: string) => void;\r\n updateSearchPatients?: (ptSrchData: any) => void;\r\n submitRequest?: (data: RequestData) => void;\r\n changePatientStatus: (inputModel: ProjectPatientData) => void;\r\n getAllEmailTemplates: () => void;\r\n getEmailTemplateByName: (name: string) => void;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nexport default function EupatiPatientsGrid(props: Props) {\r\n\r\n const [patientInfo, setPatientInfo] = useState<any>({});\r\n const [allTemplates, setAllTemplates] = useState<EmailTemplateData[]>(props.emailTemplates.length > 0 ? [...props.emailTemplates] : []);\r\n const [dropdownValues, setDropdownValue] = useState<LookUpOptions[]>([]);\r\n\r\n useEffect(() => {\r\n if (allTemplates.length > 0) {\r\n //sort by name alphabetically\r\n setAllTemplates([...allTemplates.sort((a, b) => a.name.localeCompare(b.name))]);\r\n //convert templates to dropdown menu options\r\n templatesToLookUpOptions();\r\n }\r\n }, []);\r\n\r\n let mainComponent: any;\r\n\r\n const returnLookUpValueByTypeAndId = (propName: string, projectPropId: number) => {\r\n const propType = props.lookUpData.find((x: any) => x.name == propName); // projectType\r\n const propValue = propType?.data.find((x: any) => x.id == projectPropId);\r\n return propValue?.name;\r\n }\r\n\r\n function profileBtnHandler(id: any) {\r\n setPatientInfo(props.matchedPatients.find((x: any) => x.id === id));\r\n props.patientProfileBtnHandler(); // isPatientProfileClicked:true\r\n props.toggleComponents('none');\r\n //window.scrollTo(0, 0);\r\n }\r\n\r\n function deleteProjectPatient(inputModel: ProjectPatientData) {\r\n toast.success(DEL_PT_FROM_PROJ_MSG);\r\n props.removePatient(inputModel);\r\n }\r\n\r\n function addProjectPatient(inputModel: ProjectPatientData) {\r\n toast.success(ADD_PT_TO_PROJ_MSG);\r\n props.addPatient(inputModel, props.patientSearchData, props.projectName);\r\n }\r\n\r\n function confirmPatient(inputModel: ProjectPatientData) {\r\n toast.success(CONFIRM_PATIENT_MSG);\r\n props.changePatientStatus(inputModel);\r\n }\r\n\r\n function resetTableSelectedState() {\r\n toggleAllRowsSelected(false); // reset tbl state\r\n }\r\n\r\n function rightBtnHandler(patientId: any) {\r\n let inputModel = {\r\n projectId: props.projectId,\r\n patientId: patientId\r\n } as ProjectPatientData;\r\n\r\n switch (props.rightBtnText.toLowerCase()) {\r\n case 'remove':\r\n deleteProjectPatient(inputModel);\r\n break;\r\n case 'assign':\r\n addProjectPatient(inputModel);\r\n break;\r\n }\r\n }\r\n\r\n function backBtnHandler() {\r\n setPatientInfo({});\r\n props.backToProjectProfile(); // isPatientProfileClicked:false\r\n props.toggleComponents('');\r\n if (typeof props.updateSearchPatients !== 'undefined') {\r\n props.updateSearchPatients(props.patientSearchData);\r\n }\r\n }\r\n\r\n function templatesToLookUpOptions() {\r\n const arr = allTemplates?.map((x: EmailTemplateData, i: number) => {\r\n return (\r\n {\r\n id: i,\r\n name: x.name\r\n } as LookUpOptions\r\n )\r\n });\r\n setDropdownValue([...arr]);\r\n }\r\n\r\n function selectTemplateByIndex(index: number) {\r\n const selectedTemplate = allTemplates[index];\r\n if (selectedTemplate !== undefined) {\r\n props.getEmailTemplateByName(selectedTemplate.name);\r\n }\r\n else {\r\n props.getEmailTemplateByName('empty');\r\n }\r\n }\r\n\r\n // function handleCopyOnClick(e: any) {\r\n // e.preventDefault();\r\n // const emails = selectedFlatRows.map((row: any) => row.original.email).join(';');\r\n // navigator.clipboard.writeText(emails.trim());\r\n // toast.success(EMAILS_COPIED_MSG);\r\n // }\r\n\r\n const data = useMemo(\r\n () => props?.matchedPatients.map((x: any, i: any) => {\r\n return {\r\n id: x.id,\r\n name: x.firstName.concat(' ', x.lastName),\r\n country: returnLookUpValueByTypeAndId('country', x.countryId),\r\n diseases: x.noDiseaseExpertise ? \"No specific disease experience\" : x.diseases?.map((d: any) => d.name).join(\", \"),\r\n email: x.email,\r\n expertises: x.patientExpertises.map((pe: number) => returnLookUpValueByTypeAndId('expertise', pe)).join(\", \")\r\n }\r\n }), [props.matchedPatients]\r\n )\r\n\r\n const columns = useMemo(\r\n () => [\r\n {\r\n Header: 'Name',\r\n accessor: 'name'\r\n },\r\n {\r\n Header: 'Country',\r\n accessor: 'country'\r\n },\r\n {\r\n Header: 'Diseases',\r\n accessor: 'diseases'\r\n },\r\n {\r\n Header: 'Email',\r\n accessor: 'email'\r\n },\r\n {\r\n Header: 'Expertises',\r\n accessor: 'expertises'\r\n }\r\n ], []\r\n )\r\n\r\n const {\r\n getTableProps,\r\n getTableBodyProps,\r\n headerGroups,\r\n rows,\r\n prepareRow,\r\n //@ts-ignore\r\n selectedFlatRows,\r\n //@ts-ignore\r\n toggleAllRowsSelected\r\n } = useTable({\r\n //@ts-ignore\r\n columns,\r\n data\r\n },\r\n useRowSelect,\r\n (hooks) => {\r\n {\r\n !props.isManualSearchBtnClicked &&\r\n hooks.visibleColumns.push((cols) => {\r\n return [\r\n {\r\n id: 'selection',\r\n //@ts-ignore\r\n Header: (({ getToggleAllRowsSelectedProps }) => (\r\n <Check {...getToggleAllRowsSelectedProps()} />\r\n )),\r\n //@ts-ignore\r\n Cell: ({ row }) => <Check {...row.getToggleRowSelectedProps()} />\r\n },\r\n ...cols\r\n ]\r\n })\r\n }\r\n }\r\n )\r\n\r\n mainComponent = (\r\n <Table {...getTableProps()} striped bordered hover>\r\n <thead>\r\n {headerGroups.map(headerGroup => (\r\n <tr {...headerGroup.getHeaderGroupProps()}>\r\n {headerGroup.headers.map(col => (\r\n <th {...col.getHeaderProps()}>\r\n {col.render('Header')}\r\n </th>\r\n ))}\r\n </tr>\r\n ))}\r\n </thead>\r\n <tbody {...getTableBodyProps()}>\r\n {rows.map(row => {\r\n prepareRow(row);\r\n return (\r\n <tr {...row.getRowProps()}>\r\n {row.cells.map(cell => {\r\n return (\r\n <td {...cell.getCellProps()}>\r\n {cell.render('Cell')}\r\n </td>\r\n )\r\n })}\r\n <>\r\n <td>\r\n <Button\r\n variant=\"info\"\r\n onClick={() => profileBtnHandler(row.original.id)}\r\n >\r\n {props.leftBtnText.toUpperCase()}\r\n </Button>\r\n </td>\r\n {props.isConfirmed === false &&\r\n <td>\r\n <Button\r\n variant=\"success\"\r\n onClick={() => confirmPatient({ patientId: row.original.id, projectId: props.projectId } as ProjectPatientData)}\r\n >\r\n CONFIRM\r\n </Button>\r\n </td>\r\n }\r\n <td>\r\n <Button\r\n variant='danger'\r\n onClick={() => rightBtnHandler(row.original.id)}\r\n >\r\n {props.rightBtnText.toUpperCase()}\r\n </Button>\r\n </td>\r\n </>\r\n </tr>\r\n )\r\n })}\r\n </tbody>\r\n {/* <pre>\r\n <code>\r\n {JSON.stringify(\r\n {\r\n selectedFlatRows: selectedFlatRows.map((row: any) => row.original.email),\r\n },\r\n null,\r\n 2\r\n )}\r\n </code>\r\n </pre> */}\r\n </Table >\r\n )\r\n\r\n return (\r\n <>\r\n {props.isPatientProfileClicked &&\r\n <EupatiPatientDetails\r\n {...{\r\n patientInfo,\r\n lookUpData: props.lookUpData,\r\n backBtnHandler,\r\n //forwardBtnHandler: props.rightArrowText.includes('remove') ? props.removePatient : props.addPatient,\r\n projectName: props.projectName,\r\n searchData: props.patientSearchData,\r\n leftArrowText: props.leftArrowText,\r\n rightArrowText: props.rightArrowText,\r\n isForwardArrowAvail: props.isForwardArrowAvail,\r\n projectId: props.projectId\r\n }}\r\n />\r\n }\r\n {!props.isPatientProfileClicked &&\r\n <>\r\n {!props.isManualSearchBtnClicked &&\r\n <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'flex-end', marginBottom: '10px' }}>\r\n {/* <Button\r\n id='copy-emails-btn'\r\n onClick={(e) => { handleCopyOnClick(e) }}\r\n disabled={selectedFlatRows.length === 0 ? true : false}\r\n style={selectedFlatRows.length === 0 ? { cursor: 'not-allowed', margin: '0 10px 0 0' } : { margin: '0 10px 0 0', cursor: 'pointer' }}\r\n >\r\n COPY SELECTED EMAILS\r\n </Button> */}\r\n <EmailPopupModal\r\n recipients={selectedFlatRows.map((row: any) => row.original.email).join('\\t')}\r\n submitRequest={props.submitRequest !== undefined ? props.submitRequest : () => { void 0; }}\r\n btnText='Email Patients'\r\n resetValues={() => { }}\r\n singleEmailTemplate={props.singleEmailTemplate}\r\n emailTemplateLoading={props.emailTemplateLoading}\r\n project={props.project}\r\n returnLookUpValueByTypeAndId={returnLookUpValueByTypeAndId}\r\n getAllEmailTemplates={props.getAllEmailTemplates}\r\n emailTemplates={props.emailTemplates}\r\n selectTemplateByIndex={selectTemplateByIndex}\r\n dropdownValues={dropdownValues}\r\n matchedPatients={props.matchedPatients}\r\n />\r\n </div>\r\n }\r\n {mainComponent}\r\n </>\r\n }\r\n </>\r\n );\r\n}\r\n","import React, { useState } from 'react';\r\nimport { Button, Form } from 'react-bootstrap';\r\nimport { Controller, useForm } from 'react-hook-form';\r\nimport EupatiTextbox from '../textbox';\r\nimport EupatiPatientsGrid from '../matched-patients-grid';\r\nimport EupatiArrowsMenu from '../arrows-menu';\r\nimport EupatiLoader from '../loading-animation/loader';\r\nimport { LookUpData, PatientSearchData, ProjectPatientData, EmailTemplateData } from '../../models/input-models';\r\nimport './manual-search.scss';\r\nimport EupatiEmailbox from '../emailbox';\r\nimport EupatiDropdown from '../dropdown';\r\nimport EupatiDiseaseAsyncSelect from '../async-select-menu';\r\nimport EupatiMultiselect from '../multiselect';\r\nimport { Patient, Project } from '../../models/main-models';\r\nimport { DiseaseInfo } from '../../models/main-models';\r\n\r\ntype OwnProps = {\r\n projectId: string,\r\n displayStylesProp: string,\r\n isPatientProfileClicked: boolean,\r\n lookUpData: LookUpData[],\r\n projectName: string,\r\n matchedPatients: Patient[],\r\n isMatchedPatientsLoading: boolean,\r\n project: Project,\r\n emailTemplates: EmailTemplateData[],\r\n singleEmailTemplate: EmailTemplateData;\r\n emailTemplateLoading: boolean;\r\n};\r\n\r\ntype DispatchProps = {\r\n toggleComponents: (val: string) => void;\r\n patientProfileBtnHandler: () => void;\r\n backToProjectProfile: () => void;\r\n setMatchedPatients: (searchData: PatientSearchData, projectName: string) => void;\r\n removePatient: (inputModel: ProjectPatientData) => void;\r\n addPatient: (inputModel: ProjectPatientData, searchData: PatientSearchData, projectName: string) => void;\r\n changePatientStatus: (inputModel: ProjectPatientData) => void;\r\n getAllEmailTemplates: () => void;\r\n getEmailTemplateByName: (name: string) => void;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\ntype SubmitData = {\r\n pocFirstName: string,\r\n pocLastName: string,\r\n email: string,\r\n country: number,\r\n diseases: DiseaseInfo[],\r\n patientExpertises: number[]\r\n};\r\n\r\nexport default function EupatiManualMatch(props: Props) {\r\n\r\n const { handleSubmit, control, watch, formState: { errors } } = useForm();\r\n\r\n const [isSubmitBtnClicked, setIsSubmitBtnClicked] = useState<boolean>(false);\r\n const [isPatientProfileClicked, setIsPatientProfileClicked] = useState<boolean>(false);\r\n const [ptSearchData, setPtSearchData] = useState({});\r\n\r\n const onSubmit = (data: SubmitData) => {\r\n setIsSubmitBtnClicked(true);\r\n\r\n const patientSearchData = {\r\n firstName: data.pocFirstName === undefined ? '' : data.pocFirstName,\r\n lastName: data.pocLastName === undefined ? '' : data.pocLastName,\r\n email: data.email === undefined ? '' : data.email,\r\n countryId: data.country === undefined ? null : data.country,\r\n diseases: data.diseases === undefined ? [] : data.diseases,\r\n patientExpertises: data.patientExpertises === undefined ? [] : data.patientExpertises\r\n } as PatientSearchData;\r\n\r\n setPtSearchData(patientSearchData);\r\n updateSearchPatients(patientSearchData);\r\n }\r\n\r\n function updateSearchPatients(patientSearchData: PatientSearchData) {\r\n props.setMatchedPatients(patientSearchData, props.projectName);\r\n }\r\n\r\n function findLookUpData(lookUpDataType?: string) {\r\n if (props.lookUpData &&\r\n props.lookUpData.length > 0) {\r\n return props.lookUpData?.filter((x: any) => x.name == lookUpDataType)[0]?.data;\r\n }\r\n\r\n return [];\r\n }\r\n\r\n function backToManualSearch() {\r\n setIsPatientProfileClicked(false);\r\n }\r\n\r\n function patientProfileBtnHandler() {\r\n setIsPatientProfileClicked(true);\r\n }\r\n\r\n let loadingComp = (\r\n <EupatiLoader />\r\n )\r\n\r\n let patientsGridComp = (\r\n <EupatiPatientsGrid\r\n {...{\r\n matchedPatients: props.matchedPatients,\r\n lookUpData: props.lookUpData,\r\n emailTemplates: props.emailTemplates,\r\n singleEmailTemplate: props.singleEmailTemplate,\r\n emailTemplateLoading: props.emailTemplateLoading,\r\n backToProjectProfile: backToManualSearch,\r\n isPatientProfileClicked: isPatientProfileClicked,\r\n patientProfileBtnHandler: patientProfileBtnHandler,\r\n toggleComponents: props.toggleComponents,\r\n leftArrowText: 'manual search',\r\n rightArrowText: 'assign to project',\r\n isForwardArrowAvail: true,\r\n leftBtnText: 'profile',\r\n rightBtnText: 'assign',\r\n projectId: props.projectId,\r\n updateSearchPatients,\r\n patientSearchData: ptSearchData,\r\n projectName: props.projectName,\r\n addPatient: props.addPatient,\r\n removePatient: props.removePatient,\r\n isManualSearchBtnClicked: true,\r\n project: props.project,\r\n changePatientStatus: props.changePatientStatus,\r\n isConfirmed: true,\r\n getAllEmailTemplates: props.getAllEmailTemplates,\r\n getEmailTemplateByName: props.getEmailTemplateByName\r\n }}\r\n />\r\n )\r\n\r\n if (props.isMatchedPatientsLoading) {\r\n patientsGridComp = loadingComp;\r\n }\r\n\r\n return (\r\n <>\r\n <Form className='manual' onSubmit={handleSubmit(onSubmit)} style={{ display: `${props.displayStylesProp}` }}>\r\n <EupatiArrowsMenu\r\n {...{\r\n displayStylesProp: props.displayStylesProp,\r\n leftArrowText: 'project details',\r\n rightArrowText: props.projectName,\r\n backBtnHandler: props.backToProjectProfile,\r\n //forwardBtnHandler: props.backToProjectProfile,\r\n isForwardArrowAvail: false\r\n }}\r\n />\r\n <Form.Group style={{ display: 'flex', justifyContent: 'center' }}>\r\n <h4 style={{ margin: 'auto auto 50px auto' }} >Current project - {props.projectName.toUpperCase()}</h4>\r\n </Form.Group>\r\n <Form.Group className='manual-info'>\r\n <Form.Group className='lcolumn'>\r\n <Form.Group className='manual-info-field'>\r\n <Form.Label>First name</Form.Label>\r\n <Controller\r\n control={control}\r\n name='pocFirstName'\r\n render={({ field }) =>\r\n <EupatiTextbox {...{ ...field, errorMsg: errors?.pocFirstName?.message, placeholder: 'Please type first name' }} />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group className='manual-info-field'>\r\n <Form.Label>Surname</Form.Label>\r\n <Controller\r\n control={control}\r\n name='pocLastName'\r\n render={({ field }) =>\r\n <EupatiTextbox {...{ ...field, errorMsg: errors?.pocLastName?.message, placeholder: 'Please type last name' }} />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group className='manual-info-field'>\r\n <Form.Label>Email</Form.Label>\r\n <Controller\r\n control={control}\r\n name='email'\r\n render={({ field }) =>\r\n <EupatiEmailbox {...{ ...field, errorMsg: errors?.email?.message }} />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group className='manual-info-field'>\r\n <Form.Label>Therapeutic Areas or Diseases</Form.Label>\r\n <Controller\r\n name='diseases'\r\n control={control}\r\n render={({ field }) =>\r\n <EupatiDiseaseAsyncSelect\r\n {...{\r\n ...field,\r\n errorMsg: errors?.diseases?.message\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n </Form.Group>\r\n\r\n <Form.Group className='rcolumn'>\r\n\r\n <Form.Group className='manual-info-field mb-4'>\r\n <Form.Label>Country</Form.Label>\r\n <Controller\r\n control={control}\r\n name='country'\r\n render={({ field }) =>\r\n <EupatiDropdown\r\n {...{\r\n ...field,\r\n errorMsg: errors?.country?.message,\r\n fieldName: 'countries',\r\n values: findLookUpData('country'),\r\n defaultOptionText: 'Please select country...'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group className='manual-info-field'>\r\n <Form.Label>Expertises (multiple answers possible)</Form.Label>\r\n <Controller\r\n control={control}\r\n name='patientExpertises'\r\n render={({ field }) =>\r\n <EupatiMultiselect\r\n {...{\r\n ...field,\r\n errorMsg: errors?.patientExpertises?.message,\r\n fieldName: 'patientExpertises',\r\n values: findLookUpData('expertise')\r\n }} />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n </Form.Group>\r\n </Form.Group>\r\n <Form.Group id='manual-btn' style={{ display: 'flex', alignItems: 'center', justifyContent: 'center' }}>\r\n <Button className='sbmt' variant=\"primary\" type='submit'>SEARCH</Button>\r\n </Form.Group>\r\n </Form>\r\n {isSubmitBtnClicked &&\r\n <>\r\n {patientsGridComp}\r\n </>\r\n }\r\n </>\r\n );\r\n}\r\n","import * as React from 'react';\r\nimport { Table, Form, Button } from 'react-bootstrap';\r\nimport { LookUpData, PatientSearchData, ProjectPatientData, RequestData, EmailTemplateData, LookUpOptions } from '../models/input-models';\r\nimport EupatiLoader from './loading-animation/loader';\r\nimport { IconProp } from '@fortawesome/fontawesome-svg-core';\r\nimport EupatiManualMatch from './manual-search/index';\r\nimport EupatiPatientsGrid from './matched-patients-grid';\r\nimport './static.scss';\r\nimport EupatiArrowsMenu from './arrows-menu';\r\nimport { Patient, Project } from '../models/main-models';\r\nimport EmailModalPopup from './popup-modal';\r\nimport { jsPDF } from \"jspdf\";\r\nimport html2canvas from 'html2canvas';\r\n\r\ntype OwnProps = {\r\n projectId: string;\r\n lookUpData: LookUpData[];\r\n patientSearchData?: any;\r\n matchedPatients: Patient[];\r\n isMatchedPatientsLoading: boolean;\r\n isProjectLoading: boolean;\r\n project: Project;\r\n emailTemplates: EmailTemplateData[];\r\n singleEmailTemplate: EmailTemplateData;\r\n emailTemplateLoading: boolean;\r\n};\r\n\r\ntype OwnState = {\r\n isManualSearchBtnClicked: boolean;\r\n isPatientProfileClicked: boolean;\r\n displayStylesProp: string;\r\n allTemplates: EmailTemplateData[];\r\n};\r\n\r\ntype DispatchProps = {\r\n updateSearchPatients?: (ptSrchData: any) => void;\r\n backToAllProjects: () => void;\r\n setMatchedPatients: (searchData: PatientSearchData, projectName: string) => void;\r\n setProjectById: (id: string) => void;\r\n removePatient: (inputModel: ProjectPatientData) => void;\r\n addPatient: (inputModel: ProjectPatientData, searchData: PatientSearchData, projectName: string) => void;\r\n submitRequest: (data: RequestData) => void;\r\n changePatientStatus: (inputModel: ProjectPatientData) => void;\r\n getAllEmailTemplates: () => void;\r\n getEmailTemplateByName: (name: string) => void;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nexport default class EupatiProjectDetails extends React.Component<Props, OwnState> {\r\n\r\n constructor(props: any) {\r\n super(props);\r\n\r\n this.state = {\r\n isManualSearchBtnClicked: false,\r\n isPatientProfileClicked: false,\r\n displayStylesProp: '',\r\n allTemplates: this.props.emailTemplates.length > 0 ? [...this.props.emailTemplates] : [],\r\n }\r\n\r\n this.returnValueById = this.returnValueById.bind(this);\r\n this.returnProperIconType = this.returnProperIconType.bind(this);\r\n this.returnJoinedArrayValues = this.returnJoinedArrayValues.bind(this);\r\n this.manualSearchBtnHandler = this.manualSearchBtnHandler.bind(this);\r\n this.backToProjectProfile = this.backToProjectProfile.bind(this);\r\n this.patientProfileBtnHandler = this.patientProfileBtnHandler.bind(this);\r\n this.toggleComponents = this.toggleComponents.bind(this);\r\n this.convertDate = this.convertDate.bind(this);\r\n this.toggleField = this.toggleField.bind(this);\r\n this.returnLookUpValueByTypeAndId = this.returnLookUpValueByTypeAndId.bind(this);\r\n this.templatesToLookUpOptions = this.templatesToLookUpOptions.bind(this);\r\n this.selectTemplateByIndex = this.selectTemplateByIndex.bind(this);\r\n }\r\n\r\n componentDidMount() {\r\n this.props.setProjectById(this.props?.projectId);\r\n if (this.state.allTemplates.length > 0) {\r\n //sort by name alphabetically\r\n this.setState(prevState => ({\r\n allTemplates: [...prevState.allTemplates.sort((a, b) => a.name.localeCompare(b.name))]\r\n }));\r\n }\r\n }\r\n\r\n returnValueById(propName: string, projectPropId: number) {\r\n let propType = this.props.lookUpData.find(x => x.name === propName); // projectType\r\n let propValue = propType?.data.find(x => x.id === projectPropId);\r\n return propValue?.name;\r\n }\r\n\r\n returnJoinedArrayValues(fieldProps: any, lookUpDataType: any) {\r\n let arr = fieldProps?.map((x: any, i: any) => {\r\n return (\r\n this.returnValueById(lookUpDataType, x)\r\n )\r\n });\r\n\r\n return arr?.join(', ');\r\n }\r\n\r\n templatesToLookUpOptions() {\r\n const arr = this.state.allTemplates?.map((x: EmailTemplateData, i: number) => {\r\n return (\r\n {\r\n id: i,\r\n name: x.name\r\n } as LookUpOptions\r\n )\r\n });\r\n\r\n return arr;\r\n }\r\n\r\n selectTemplateByIndex(index: number) {\r\n const selectedTemplate = this.state.allTemplates[index];\r\n if (selectedTemplate !== undefined) {\r\n this.props.getEmailTemplateByName(selectedTemplate.name);\r\n }\r\n else {\r\n this.props.getEmailTemplateByName('empty');\r\n }\r\n }\r\n\r\n returnProperIconType(icon: any) {\r\n return icon as IconProp;\r\n }\r\n\r\n manualSearchBtnHandler() {\r\n this.setState({\r\n isManualSearchBtnClicked: true\r\n });\r\n }\r\n\r\n backToProjectProfile() {\r\n this.props.setProjectById(this.props?.projectId);\r\n this.setState({\r\n isManualSearchBtnClicked: false,\r\n isPatientProfileClicked: false\r\n })\r\n }\r\n\r\n patientProfileBtnHandler() {\r\n this.setState({\r\n isPatientProfileClicked: true\r\n })\r\n }\r\n\r\n toggleComponents(val: string) {\r\n this.setState({\r\n displayStylesProp: val\r\n })\r\n }\r\n\r\n convertDate(date: any) {\r\n if (typeof date === 'undefined') { return }\r\n date = new Date(date);\r\n function pad(s: any) { return (s < 10) ? '0' + s : s; }\r\n return [pad(date.getDate()), pad(date.getMonth() + 1), date.getFullYear()].join('/')\r\n }\r\n\r\n toggleField(val: string) {\r\n return val !== null && val !== '' ? true : false;\r\n }\r\n\r\n returnLookUpValueByTypeAndId = (propName: string, projectPropId: number) => {\r\n const propType = this.props.lookUpData.find((x: any) => x.name == propName); // projectType\r\n const propValue = propType?.data.find((x: any) => x.id == projectPropId);\r\n return propValue?.name;\r\n }\r\n\r\n downloadPDF() {\r\n let page = document.getElementById('all-projects-tbl');\r\n if (page) {\r\n html2canvas(page)\r\n .then((canvas) => {\r\n const imgData = canvas.toDataURL('image/png');\r\n const pdf = new jsPDF();\r\n pdf.addImage(imgData, 'JPEG', 0, 0, canvas.width / 12, canvas.height / 14);\r\n window.open(pdf.output('bloburl'))\r\n //pdf.save(\"EUPATIProject.pdf\");\r\n })\r\n }\r\n }\r\n\r\n render() {\r\n\r\n let loadingComponent = (\r\n <div className='loader-wrapper'>\r\n <EupatiLoader />\r\n </div>\r\n );\r\n\r\n let mainComponent: any;\r\n\r\n if (this.props.project.name === '') {\r\n mainComponent = loadingComponent;\r\n } else {\r\n mainComponent = (\r\n <>\r\n <EupatiArrowsMenu\r\n {...{\r\n displayStylesProp: this.state.displayStylesProp,\r\n leftArrowText: 'all projects',\r\n rightArrowText: 'manual match',\r\n backBtnHandler: this.props.backToAllProjects,\r\n forwardBtnHandler: this.manualSearchBtnHandler,\r\n isForwardArrowAvail: true,\r\n }}\r\n />\r\n <Form.Group style={{ display: this.state.displayStylesProp === '' ? 'flex' : this.state.displayStylesProp, justifyContent: 'center' }}>\r\n <h5 style={{ color: '#F0B72F', fontWeight: 'bold', textDecoration: 'underline' }}>Projects information</h5>\r\n </Form.Group>\r\n <Table striped bordered hover style={{ display: `${this.state.displayStylesProp}` }}>\r\n <tbody>\r\n <tr>\r\n <td>Name</td>\r\n <td>{this.props?.project?.name}</td>\r\n </tr>\r\n <tr>\r\n <td>Overview</td>\r\n <td>{this.props?.project?.overview}</td>\r\n </tr>\r\n <tr>\r\n <td>Type</td>\r\n <td>{this.returnValueById('projectType', this.props?.project?.projectTypeId)}</td>\r\n </tr>\r\n {this.toggleField(this.props?.project?.projectTypeDescription) &&\r\n <tr>\r\n <td>Type description</td>\r\n <td>{this.props?.project?.projectTypeDescription}</td>\r\n </tr>\r\n }\r\n <tr>\r\n <td>Interaction</td>\r\n <td>{this.returnValueById('interactionType', this.props?.project?.interactionTypeId)}</td>\r\n </tr>\r\n <tr>\r\n <td>Activity</td>\r\n <td>{this.returnValueById('activityType', this.props?.project?.projectActivityId)}</td>\r\n </tr>\r\n <tr>\r\n <td>How many patients are you looking for?</td>\r\n <td>{(this.props?.project?.projectNumberOfPatientsNeeded == 0 || this.props?.project?.projectNumberOfPatientsNeeded == undefined) ? '' : this.props?.project?.projectNumberOfPatientsNeeded}</td>\r\n </tr>\r\n <tr>\r\n <td>Role and expectations</td>\r\n <td>{this.props?.project?.roleAndExpectations}</td>\r\n </tr>\r\n <tr>\r\n <td>Start date</td>\r\n <td>{this.convertDate(this.props?.project?.startDate)}</td>\r\n </tr>\r\n <tr>\r\n <td>End date</td>\r\n <td>{this.convertDate(this.props?.project?.endDate)}</td>\r\n </tr>\r\n <tr>\r\n <td>Time required</td>\r\n <td>{this.props?.project?.timeRequired}</td>\r\n </tr>\r\n <tr>\r\n <td>Is compensation provided </td>\r\n <td>{this.props?.project?.isCompensationProvided ? \"Yes\" : \"No\"}</td>\r\n </tr>\r\n {this.props?.project?.isCompensationProvided &&\r\n <tr>\r\n <td>Compensation amout</td>\r\n <td>{this.props?.project?.compensation}</td>\r\n </tr>\r\n }\r\n <tr>\r\n <td>Is ThereTravel Reimbursement</td>\r\n <td>{this.props?.project?.isThereTravelReimbursement ? \"Yes\" : \"No\"}</td>\r\n </tr>\r\n <tr>\r\n <td>Equipment requirements</td>\r\n <td>{this.props?.project?.equipmentRequirements}</td>\r\n </tr>\r\n <tr>\r\n <td>Response deadline</td>\r\n <td>{this.convertDate(this.props?.project?.responseDeadline)}</td>\r\n </tr>\r\n <tr>\r\n <td>Price</td>\r\n <td>{this.props.project.price}</td>\r\n </tr>\r\n <tr>\r\n <td>Plan</td>\r\n <td>{this.props.project.plan}</td>\r\n </tr>\r\n <tr>\r\n <td>Package</td>\r\n <td>{this.props.project.package}</td>\r\n </tr>\r\n <tr>\r\n <td>Payment method</td>\r\n <td>{this.props.project.paymentMethod}</td>\r\n </tr>\r\n <tr>\r\n <td>Disease Experience</td>\r\n <td>{this.props?.project?.noDiseaseExpertiseRequired ? \"No specific disease experience is required\" : this.props?.project?.diseases?.map((d: any) => d.name).join(\", \")}</td>\r\n </tr>\r\n <tr>\r\n <td>Disease Preference</td>\r\n <td>{this.props?.project?.searchDiseaseTherapeuticArea ? \"Match patients in the therapeutic area(s) as well\" : \"Match only from the selected disease(s)\"}</td>\r\n </tr>\r\n {/* <tr>\r\n <td>Disease area</td>\r\n <td>{this.props?.project?.diseaseTAName}</td>\r\n </tr> */}\r\n <tr>\r\n <td>Patient expertises</td>\r\n <td>{this.returnJoinedArrayValues(this.props?.project?.patientExpertises, 'expertise')}</td>\r\n </tr>\r\n {this.toggleField(this.props?.project?.patientExpertisesDescription) &&\r\n <tr>\r\n <td>Patient expertises description</td>\r\n <td>{this.props?.project?.patientExpertisesDescription}</td>\r\n </tr>\r\n }\r\n <tr>\r\n <td>Countries</td>\r\n <td>{this.returnJoinedArrayValues(this.props?.project?.countries, 'countryWithContinents')}</td>\r\n </tr>\r\n <tr>\r\n <td>Languages</td>\r\n <td>{this.returnJoinedArrayValues(this.props?.project?.languages, 'language')}</td>\r\n </tr>\r\n <tr>\r\n <td>Other information</td>\r\n <td>{this.props?.project?.otherInformation}</td>\r\n </tr>\r\n </tbody>\r\n </Table>\r\n\r\n <Form.Group style={{ display: this.state.displayStylesProp === '' ? 'flex' : this.state.displayStylesProp, justifyContent: 'center' }}>\r\n <h5 style={{ color: '#F0B72F', fontWeight: 'bold', textDecoration: 'underline' }}>Person of contact</h5>\r\n </Form.Group>\r\n <Form.Group style={{ display: 'flex', justifyContent: 'flex-end' }}>\r\n <EmailModalPopup\r\n recipients={this.props?.project?.pocEmail}\r\n project={this.props?.project}\r\n btnText='Email Researcher'\r\n submitRequest={this.props.submitRequest}\r\n resetValues={() => { }}\r\n singleEmailTemplate={this.props.singleEmailTemplate}\r\n emailTemplateLoading={this.props.emailTemplateLoading}\r\n returnLookUpValueByTypeAndId={this.returnLookUpValueByTypeAndId}\r\n getAllEmailTemplates={this.props.getAllEmailTemplates}\r\n emailTemplates={this.state.allTemplates}\r\n selectTemplateByIndex={this.selectTemplateByIndex}\r\n dropdownValues={this.templatesToLookUpOptions()}\r\n matchedPatients={this.props.matchedPatients}\r\n />\r\n </Form.Group>\r\n <Table striped bordered hover style={{ display: `${this.state.displayStylesProp}` }}>\r\n <tbody>\r\n <tr>\r\n <td>First name</td>\r\n <td>{this.props?.project?.pocFirstName}</td>\r\n </tr>\r\n <tr>\r\n <td>Last name</td>\r\n <td>{this.props?.project?.pocLastName}</td>\r\n </tr>\r\n <tr>\r\n <td>Organisation</td>\r\n <td>{this.props?.project?.pocOrganisation}</td>\r\n </tr>\r\n <tr>\r\n <td>Organisation type</td>\r\n <td>{this.returnValueById('organisationType', this.props?.project?.pocOrganisationTypeId)}</td>\r\n </tr>\r\n {this.toggleField(this.props?.project?.pocOrganisationTypeDescription) &&\r\n <tr>\r\n <td>Organisation type description</td>\r\n <td>{this.props?.project?.pocOrganisationTypeDescription}</td>\r\n </tr>\r\n }\r\n <tr>\r\n <td>Job title</td>\r\n <td>{this.props?.project?.pocJobTitle}</td>\r\n </tr>\r\n <tr>\r\n <td>Country of origin</td>\r\n <td>{this.returnValueById('country', this.props?.project?.pocCountryId)}</td>\r\n </tr>\r\n <tr>\r\n <td>Phone number</td>\r\n <td>{this.props?.project?.pocPhoneNumber}</td>\r\n </tr>\r\n <tr>\r\n <td>Email</td>\r\n <td>{this.props?.project?.pocEmail}</td>\r\n </tr>\r\n </tbody>\r\n </Table>\r\n <Form.Group onClick={this.downloadPDF}>\r\n <Button className='right-arrow-container-btn'>Download Project Information as PDF</Button>\r\n </Form.Group>\r\n </>\r\n );\r\n }\r\n\r\n return (\r\n <>\r\n {!this.state.isManualSearchBtnClicked ? (\r\n <>\r\n <>\r\n {mainComponent}\r\n </>\r\n {this.props?.project?.matchedPatients?.length > 0 &&\r\n <>\r\n <Form.Group style={{ display: this.state.displayStylesProp === '' ? 'flex' : this.state.displayStylesProp, justifyContent: 'center', margin: '0', padding: '0' }}>\r\n <h5 style={{ color: '#F0B72F', fontWeight: 'bold', textDecoration: 'underline' }}>Matched patients</h5>\r\n </Form.Group>\r\n <EupatiPatientsGrid\r\n {...{\r\n matchedPatients: [...this.props?.project?.matchedPatients],\r\n lookUpData: this.props.lookUpData,\r\n emailTemplates: this.props.emailTemplates,\r\n singleEmailTemplate: this.props.singleEmailTemplate,\r\n emailTemplateLoading: this.props.emailTemplateLoading,\r\n patientProfileBtnHandler: this.patientProfileBtnHandler,\r\n backToProjectProfile: this.backToProjectProfile,\r\n isPatientProfileClicked: this.state.isPatientProfileClicked,\r\n toggleComponents: this.toggleComponents,\r\n leftArrowText: 'projects details',\r\n rightArrowText: 'remove from project',\r\n isForwardArrowAvail: true,\r\n leftBtnText: 'profile',\r\n rightBtnText: 'remove',\r\n projectId: this.props?.projectId,\r\n updateSearchPatients: this.props.updateSearchPatients,\r\n patientSearchData: this.props.patientSearchData,\r\n projectName: this.props?.project?.name,\r\n addPatient: this.props.addPatient,\r\n removePatient: this.props.removePatient,\r\n isManualSearchBtnClicked: this.state.isManualSearchBtnClicked,\r\n submitRequest: this.props.submitRequest,\r\n project: this.props.project,\r\n changePatientStatus: this.props.changePatientStatus,\r\n isConfirmed: false,\r\n getAllEmailTemplates: this.props.getAllEmailTemplates,\r\n getEmailTemplateByName: this.props.getEmailTemplateByName\r\n }}\r\n />\r\n </>\r\n }\r\n {this.props?.project?.confirmedPatients?.length > 0 &&\r\n <>\r\n <Form.Group style={{ display: this.state.displayStylesProp === '' ? 'flex' : this.state.displayStylesProp, justifyContent: 'center', margin: '0', padding: '0' }}>\r\n <h5 style={{ color: '#F0B72F', fontWeight: 'bold', textDecoration: 'underline' }}>Confirmed patients</h5>\r\n </Form.Group>\r\n <EupatiPatientsGrid\r\n {...{\r\n matchedPatients: [...this.props?.project?.confirmedPatients],\r\n lookUpData: this.props.lookUpData,\r\n emailTemplates: this.props.emailTemplates,\r\n singleEmailTemplate: this.props.singleEmailTemplate,\r\n emailTemplateLoading: this.props.emailTemplateLoading,\r\n patientProfileBtnHandler: this.patientProfileBtnHandler,\r\n backToProjectProfile: this.backToProjectProfile,\r\n isPatientProfileClicked: this.state.isPatientProfileClicked,\r\n toggleComponents: this.toggleComponents,\r\n leftArrowText: 'projects details',\r\n rightArrowText: 'remove from project',\r\n isForwardArrowAvail: true,\r\n leftBtnText: 'profile',\r\n rightBtnText: 'remove',\r\n projectId: this.props?.projectId,\r\n updateSearchPatients: this.props.updateSearchPatients,\r\n patientSearchData: this.props.patientSearchData,\r\n projectName: this.props?.project?.name,\r\n addPatient: this.props.addPatient,\r\n removePatient: this.props.removePatient,\r\n isManualSearchBtnClicked: this.state.isManualSearchBtnClicked,\r\n submitRequest: this.props.submitRequest,\r\n project: this.props.project,\r\n changePatientStatus: this.props.changePatientStatus,\r\n isConfirmed: true,\r\n getAllEmailTemplates: this.props.getAllEmailTemplates,\r\n getEmailTemplateByName: this.props.getEmailTemplateByName\r\n }}\r\n />\r\n </>\r\n }\r\n </>\r\n ) : (\r\n <>\r\n <EupatiManualMatch\r\n {...{\r\n //matchedPatients: [...this.props?.project?.matchedPatients],\r\n projectName: this.props?.project?.name,\r\n backToProjectProfile: this.backToProjectProfile,//\r\n lookUpData: this.props.lookUpData,\r\n emailTemplates: this.props.emailTemplates,\r\n singleEmailTemplate: this.props.singleEmailTemplate,\r\n emailTemplateLoading: this.props.emailTemplateLoading,\r\n isPatientProfileClicked: this.state.isPatientProfileClicked,\r\n patientProfileBtnHandler: this.patientProfileBtnHandler,\r\n toggleComponents: this.toggleComponents,\r\n displayStylesProp: this.state.displayStylesProp,\r\n projectId: this.props?.projectId,\r\n setMatchedPatients: this.props.setMatchedPatients,\r\n matchedPatients: this.props.matchedPatients,\r\n isMatchedPatientsLoading: this.props.isMatchedPatientsLoading,\r\n addPatient: this.props.addPatient,\r\n removePatient: this.props.removePatient,\r\n project: this.props.project,\r\n changePatientStatus: this.props.changePatientStatus,\r\n getAllEmailTemplates: this.props.getAllEmailTemplates,\r\n getEmailTemplateByName: this.props.getEmailTemplateByName\r\n }}\r\n />\r\n </>\r\n )}\r\n </>\r\n );\r\n }\r\n}","import React from 'react';\r\n\r\nexport default function GlobalFilter(props: any) {\r\n return (\r\n <span>\r\n Search:{' '}\r\n <input\r\n value={props.filter || \"\"}\r\n onChange={e => props.setFilter(e.target.value)}\r\n placeholder='Filter the records...'\r\n style={{ fontSize: '1.1rem', border: '0' }}\r\n />\r\n </span>\r\n )\r\n}","import React, { useState } from 'react';\r\nimport { Table, Button, Form } from 'react-bootstrap';\r\nimport EupatiProjectDetails from './project-details';\r\nimport { useTable, useGlobalFilter, usePagination, useSortBy } from \"react-table\";\r\nimport { useMemo } from 'react';\r\nimport EupatiDropdown from './dropdown';\r\nimport { LookUpData, PatientSearchData, ProjectPatientData, RequestData, EmailTemplateData, LookUpOptions } from '../models/input-models';\r\nimport { ProjectStatus } from '../helpers';\r\nimport GlobalFilter from './global-filter';\r\nimport './static.scss';\r\nimport { Patient, Project } from '../models/main-models';\r\nimport EupatiLoader from './loading-animation/loader';\r\nimport { toast } from 'react-toastify';\r\nimport { ARCHIVE_PROJ_SUCC_MSG } from '../helpers/messages';\r\nimport { IconProp } from '@fortawesome/fontawesome-svg-core';\r\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\r\nimport { faSortAlphaDown, faSortAlphaUp, faFileExcel } from '@fortawesome/fontawesome-free-solid';\r\nimport { faWindowMinimize } from '@fortawesome/fontawesome-free-regular';\r\nimport { CSVLink } from \"react-csv\";\r\nimport uniqid from 'uniqid';\r\nimport { projectStatus } from '../helpers/status';\r\n\r\ntype OwnProps = {\r\n lookUpData: LookUpData[],\r\n projects: Project[],\r\n projectsFilter: number,\r\n matchedPatients: Patient[],\r\n isMatchedPatientsLoading: boolean,\r\n isProjectLoading: boolean,\r\n project: Project\r\n emailTemplates: EmailTemplateData[];\r\n singleEmailTemplate: EmailTemplateData;\r\n emailTemplateLoading: boolean;\r\n};\r\n\r\ntype DispatchProps = {\r\n setProjects: (condition: number) => void;\r\n setProjectsFilter: (filter: number) => void;\r\n setMatchedPatients: (searchData: PatientSearchData, projectName: string) => void;\r\n setProjectById: (id: string) => void;\r\n removePatient: (inputModel: ProjectPatientData) => void;\r\n addPatient: (inputModel: ProjectPatientData, searchData: PatientSearchData, projectName: string) => void;\r\n changeProjectStatus: (id: string, filter: number) => void;\r\n submitRequest: (data: RequestData) => void;\r\n changePatientStatus: (inputModel: ProjectPatientData) => void;\r\n getAllEmailTemplates: () => void;\r\n getEmailTemplateByName: (name: string) => void;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nconst OUTLINE_PADDING_STYLE = {\r\n paddingLeft: '1.2rem',\r\n paddingRight: '1.2rem'\r\n};\r\nconst PRIMARY_PADDING_STYLE = {\r\n paddingLeft: '1.7rem',\r\n paddingRight: '1.7rem'\r\n}\r\nexport default function EupatiAllProjectsGrid(props: Props) {\r\n\r\n const [isDetailsBtnClicked, setIsDetailsBtnClicked] = useState<boolean>(false);\r\n const [clickedProjectId, setClickedProjectId] = useState<string>('');\r\n\r\n const detailsBtnHandler = (id: any) => {\r\n setClickedProjectId(id);\r\n props.setProjectById(id);\r\n setIsDetailsBtnClicked(true);\r\n }\r\n\r\n const changeProjectStatusHandler = (id: any, filter: number) => {\r\n toast.success(ARCHIVE_PROJ_SUCC_MSG);\r\n props.changeProjectStatus(id, filter);\r\n }\r\n\r\n const backBtnHandler = () => {\r\n setClickedProjectId('');\r\n setIsDetailsBtnClicked(false);\r\n }\r\n\r\n const returnValueById = (propName: string, projectPropId: number) => {\r\n let propType = props.lookUpData.find((x: any) => x.name == propName); // projectType\r\n let propValue = propType?.data.find((x: any) => x.id == projectPropId);\r\n return propValue?.name;\r\n }\r\n\r\n function findLookUpData(lookUpDataType?: string) {\r\n if (props.lookUpData &&\r\n props.lookUpData.length > 0) {\r\n var data = props.lookUpData?.filter((x: any) => x.name == lookUpDataType)[0]?.data;\r\n if (lookUpDataType == \"projectStatus\" && data.findIndex(d => d.id == 0) == -1)//add \"All Statuses option in the filter dropdown\"\r\n {\r\n data.unshift({\r\n id: 0, name: \"Show All\"\r\n } as LookUpOptions)\r\n }\r\n\r\n return data;\r\n }\r\n\r\n return [];\r\n }\r\n\r\n const projectStatusHandler = (statusId: number) => {\r\n props.setProjectsFilter(statusId);\r\n props.setProjects(statusId);\r\n }\r\n\r\n function convertDate(date: any) {\r\n if (typeof date === 'undefined') { return }\r\n function pad(s: any) { return (s < 10) ? '0' + s : s; } // 9 --> 09 || 10 --> 10\r\n return [pad(date.getDate()), pad(date.getMonth() + 1), date.getFullYear()].join('/') // format date --> 09/12/2021 \r\n }\r\n\r\n function setValue(val: any) {\r\n if (isNaN(val)) {\r\n projectStatusHandler(ProjectStatus.inProgressStatusID);\r\n return ProjectStatus.inProgressStatusID;\r\n }\r\n\r\n return val;\r\n }\r\n\r\n function returnProperIconType(icon: any) {\r\n return icon as IconProp;\r\n }\r\n\r\n let projectsDetailsComp: any;\r\n let loadComp = (\r\n <div className='loader-wrapper'>\r\n <EupatiLoader />\r\n </div>\r\n )\r\n\r\n if (clickedProjectId === '') {\r\n projectsDetailsComp = loadComp;\r\n }\r\n else {\r\n projectsDetailsComp = (\r\n <EupatiProjectDetails\r\n {...{\r\n projectId: clickedProjectId,\r\n backToAllProjects: backBtnHandler,\r\n lookUpData: props.lookUpData,\r\n emailTemplates: props.emailTemplates,\r\n singleEmailTemplate: props.singleEmailTemplate,\r\n emailTemplateLoading: props.emailTemplateLoading,\r\n setMatchedPatients: props.setMatchedPatients,\r\n matchedPatients: props.matchedPatients,\r\n isMatchedPatientsLoading: props.isMatchedPatientsLoading,\r\n setProjectById: props.setProjectById,\r\n isProjectLoading: props.isProjectLoading,\r\n project: props.project,\r\n removePatient: props.removePatient,\r\n addPatient: props.addPatient,\r\n submitRequest: props.submitRequest,\r\n changePatientStatus: props.changePatientStatus,\r\n getAllEmailTemplates: props.getAllEmailTemplates,\r\n getEmailTemplateByName: props.getEmailTemplateByName\r\n }}\r\n />\r\n )\r\n }\r\n\r\n const headers = [\r\n { label: \"Name\", key: \"name\" },\r\n { label: \"Type\", key: \"type\" },\r\n { label: \"Start date\", key: \"date\" },\r\n { label: \"Disease(s) experience\", key: \"diseases\" },\r\n { label: \"Chosen plan\", key: \"plan\" },\r\n { label: \"Organisation\", key: \"org\" }\r\n ];\r\n\r\n const data = useMemo(\r\n () => props.projects?.map((x: any, i: any) => {\r\n let statuses = findLookUpData('projectStatus');\r\n\r\n return {\r\n id: x.id,\r\n name: x.name,\r\n type: returnValueById('projectType', x.projectTypeId),\r\n date: x.createdOn,\r\n diseases: x.noDiseaseExpertiseRequired ? \"No disease experience required\" : x.diseases?.map((d: any) => d.name).join(\", \"),\r\n plan: x.plan,\r\n org: x.pocOrganisation,\r\n status: x.projectStatusId,\r\n statusText: statuses.find(s => s.id == x.projectStatusId)?.name\r\n }\r\n }), [props.projects]\r\n )\r\n\r\n const columns = useMemo(\r\n () => [\r\n {\r\n Header: 'Name',\r\n accessor: 'name', // accessor is the \"key\" in the data\r\n },\r\n {\r\n Header: 'Type',\r\n accessor: 'type'\r\n },\r\n {\r\n Header: 'Date',\r\n accessor: 'date',\r\n Cell: (props: any) => {\r\n if (props.value != undefined && props.value != null) {\r\n return props.value.toString() == \"0001-01-01T00:00:00\" ? \"-\" : convertDate(new Date(props.value));\r\n } else {\r\n return '';\r\n }\r\n }\r\n },\r\n {\r\n Header: 'Diseases',\r\n accessor: 'diseases'\r\n },\r\n {\r\n Header: 'Plan',\r\n accessor: 'plan'\r\n },\r\n {\r\n Header: 'Organisation',\r\n accessor: 'org'\r\n },\r\n {\r\n Header: 'Status',\r\n accessor: 'statusText'\r\n }\r\n ], []\r\n )\r\n\r\n const {\r\n getTableProps,\r\n getTableBodyProps,\r\n headerGroups, // columns Header\r\n rows, // render data based on accessor\r\n // @ts-ignore\r\n page,\r\n // @ts-ignore\r\n nextPage,\r\n // @ts-ignore\r\n previousPage,\r\n // @ts-ignore\r\n canNextPage,\r\n // @ts-ignore\r\n canPreviousPage,\r\n prepareRow,\r\n // @ts-ignore\r\n visibleColumns,\r\n // @ts-ignore\r\n pageOptions,\r\n // @ts-ignore\r\n gotoPage,\r\n // @ts-ignore\r\n pageCount,\r\n // @ts-ignore\r\n setPageSize,\r\n // @ts-ignore\r\n state,\r\n // @ts-ignore\r\n setGlobalFilter,\r\n } = useTable({\r\n // @ts-ignore\r\n columns,\r\n data\r\n },\r\n useGlobalFilter,\r\n useSortBy,\r\n usePagination,\r\n )\r\n // @ts-ignore\r\n const { globalFilter, pageSize, pageIndex } = state;\r\n\r\n let mainComponent = (\r\n <>\r\n <Table {...getTableProps()} striped bordered hover>\r\n <thead>\r\n {headerGroups.map(headerGroup => (\r\n <tr {...headerGroup.getHeaderGroupProps()}>\r\n {headerGroup.headers.map(col => (\r\n //@ts-ignore\r\n <th {...col.getHeaderProps(col.getSortByToggleProps())}>\r\n {col.render('Header')}\r\n <span>\r\n {/* @ts-ignore */\r\n col.isSorted ? (col.isSortedDesc ? <FontAwesomeIcon icon={returnProperIconType(faSortAlphaDown)} /> : <FontAwesomeIcon icon={returnProperIconType(faSortAlphaUp)} />) : <FontAwesomeIcon id='line' icon={returnProperIconType(faWindowMinimize)} />\r\n }\r\n </span>\r\n </th>\r\n ))}\r\n </tr>\r\n ))}\r\n <tr>\r\n <th\r\n colSpan={visibleColumns.length}\r\n style={{ textAlign: 'left' }}\r\n >\r\n <GlobalFilter filter={globalFilter} setFilter={setGlobalFilter} />\r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody {...getTableBodyProps()}>\r\n {page.map((row: any) => {\r\n prepareRow(row)\r\n return (\r\n <tr {...row.getRowProps()}>\r\n {row.cells.map((cell: any) => {\r\n return (\r\n <td {...cell.getCellProps()}>\r\n {cell.render('Cell')}\r\n </td>\r\n )\r\n })}\r\n <>\r\n <td role='cell'>\r\n <Button\r\n variant=\"info\"\r\n onClick={() => detailsBtnHandler(row.original.id)}\r\n >\r\n DETAILS\r\n </Button>\r\n </td>\r\n {row.original.status === projectStatus.archivedStatusID ? (\r\n <td role='cell'>\r\n <Button\r\n variant='secondary'\r\n onClick={() => changeProjectStatusHandler(row.original.id, projectStatus.inProgressStatusID)}\r\n style={{ cursor: 'pointer' }}\r\n >\r\n REVIVE\r\n </Button>\r\n </td>\r\n ) : (\r\n <td role='cell'>\r\n <Button\r\n variant='danger'\r\n onClick={() => changeProjectStatusHandler(row.original.id, projectStatus.archivedStatusID)}\r\n style={{ cursor: 'pointer' }}\r\n >\r\n ARCHIVE\r\n </Button>\r\n </td>\r\n )}\r\n </>\r\n </tr>\r\n )\r\n })}\r\n </tbody>\r\n </Table>\r\n <Form.Group style={{ display: 'flex', justifyContent: 'space-between', alignItems: 'center' }}>\r\n <span>\r\n Page{' '}\r\n <strong>\r\n {pageIndex + 1} of {pageOptions.length}\r\n </strong>\r\n </span>\r\n <span>\r\n Go to page: {' '}\r\n <input\r\n type='number'\r\n defaultValue={pageIndex + 1}\r\n min='1'\r\n disabled={pageSize >= rows.length}\r\n onChange={(e) => {\r\n e.preventDefault();\r\n const pageNum = e.target.value ? Number(e.target.value) - 1 : 0;\r\n gotoPage(pageNum);\r\n }}\r\n />\r\n </span>\r\n <select value={pageSize} onChange={e => setPageSize(e.target.value)}>\r\n {\r\n [10, 25, 50, 100].map(pageSize => (\r\n <option key={pageSize} value={pageSize}>\r\n Show {pageSize}\r\n </option>\r\n ))\r\n }\r\n </select>\r\n <Button id='backToFirstPageBtn' onClick={() => gotoPage(0)} disabled={!canPreviousPage} style={canPreviousPage ? { cursor: 'pointer', ...OUTLINE_PADDING_STYLE } : { cursor: 'not-allowed', ...OUTLINE_PADDING_STYLE }} className='btn btn-outline-dark btn-sm' >{'<<'}</Button>\r\n <Button onClick={() => previousPage()} disabled={!canPreviousPage} style={canPreviousPage ? { cursor: 'pointer' } : { cursor: 'not-allowed' }} variant='secondary' >Previous</Button>\r\n <Button onClick={() => nextPage()} disabled={!canNextPage} style={canNextPage ? { cursor: 'pointer', ...PRIMARY_PADDING_STYLE } : { cursor: 'not-allowed', ...PRIMARY_PADDING_STYLE }} variant='primary'>Next</Button>\r\n <Button id='gotoLastPageBtn' onClick={() => gotoPage(pageCount - 1)} disabled={!canNextPage} style={canNextPage ? { cursor: 'pointer', ...OUTLINE_PADDING_STYLE } : { cursor: 'not-allowed', ...OUTLINE_PADDING_STYLE }} className='btn btn-outline-dark btn-sm' >{'>>'}</Button>\r\n </Form.Group>\r\n </>\r\n );\r\n\r\n return (\r\n <>\r\n {isDetailsBtnClicked &&\r\n <>\r\n {projectsDetailsComp}\r\n </>\r\n }\r\n {!isDetailsBtnClicked &&\r\n <>\r\n <h4 style={{ textAlign: 'center', textDecoration: 'underline' }}>PROJECTS</h4>\r\n <div className='table-btns'>\r\n <EupatiDropdown {...{\r\n fieldName: 'projectStatusId',\r\n errorMsg: '',\r\n values: findLookUpData('projectStatus'),\r\n onChange: (e: any) => projectStatusHandler(parseInt(e.target.value)),\r\n value: setValue(parseInt(props.projectsFilter.toString())),\r\n width: 'auto'\r\n }} />\r\n <span><strong>{props.projects?.length}</strong> projects.</span>\r\n <CSVLink\r\n data={data}\r\n headers={headers}\r\n id='csv-download-btn'\r\n filename={`${uniqid('projects-table-')}.csv`}\r\n className=\"btn btn-success\"\r\n >\r\n DOWNLOAD <FontAwesomeIcon icon={returnProperIconType(faFileExcel)} />\r\n </CSVLink>\r\n </div>\r\n {mainComponent}\r\n </>\r\n }\r\n </>\r\n );\r\n}","import * as React from 'react';\r\nimport { Form } from 'react-bootstrap';\r\nimport { EmailTemplateData, LookUpData, PatientSearchData, ProjectPatientData, RequestData } from '../../../../common/models/input-models';\r\nimport { Patient, Project } from '../../../../common/models/main-models';\r\nimport EupatiLoader from '../../../../common/static/loading-animation/loader';\r\nimport EupatiAllProjectsGrid from '../../../../common/static/projects-grid';\r\nimport { State } from '../model';\r\nimport '../style.scss';\r\n\r\ntype OwnProps = {\r\n isLoading: boolean;\r\n lookUpData: LookUpData[];\r\n isProjectsLoading: boolean;\r\n projects: Project[];\r\n filter: number;\r\n matchedPatients: Patient[];\r\n isMatchedPatientsLoading: boolean;\r\n project: Project;\r\n isProjectLoading: boolean;\r\n emailTemplates: EmailTemplateData[];\r\n singleEmailTemplate: EmailTemplateData;\r\n emailTemplateLoading: boolean;\r\n};\r\n\r\nexport type DispatchProps = {\r\n setLookUpData: () => void;\r\n setProjects: (condition: number) => void;\r\n setFilter: (filter: number) => void;\r\n setMatchedPatients: (searchData: PatientSearchData, projectName: string) => void;\r\n setProjectById: (id: string) => void;\r\n removePatient: (inputModel: ProjectPatientData) => void;\r\n addPatient: (inputModel: ProjectPatientData, searchData: PatientSearchData, projectName: string) => void;\r\n changeProjectStatus: (id: string, filter: number) => void;\r\n submitRequest: (data: RequestData) => void;\r\n changePatientStatus: (inputModel: ProjectPatientData) => void;\r\n getAllEmailTemplates: () => void;\r\n getEmailTemplateByName: (name: string) => void;\r\n};\r\n\r\ntype Props = State & DispatchProps & OwnProps;\r\n\r\ntype OwnState = {};\r\n\r\n//TODO: pass func to grid so it doesnt call services directly\r\nexport default class ComponentRoot extends React.Component<Props, OwnState> {\r\n\r\n componentDidMount() {\r\n this.props.setLookUpData();\r\n this.props.getAllEmailTemplates();\r\n this.props.setProjects(this.props.filter);\r\n }\r\n\r\n render() {\r\n\r\n let mainComponent: any;\r\n\r\n let loadingComponent = (\r\n <div className='loader-wrapper'>\r\n <EupatiLoader />\r\n </div>\r\n )\r\n\r\n if (this.props.isLoading ||\r\n this.props.isProjectsLoading) {\r\n mainComponent = loadingComponent;\r\n }\r\n else {\r\n mainComponent = (\r\n <Form.Group id='all-projects-tbl' className='all-projects-wrapper mb-5'>\r\n <EupatiAllProjectsGrid\r\n {...{\r\n lookUpData: this.props.lookUpData,\r\n projects: this.props.projects,\r\n setProjects: this.props.setProjects,\r\n setProjectsFilter: this.props.setFilter,\r\n projectsFilter: this.props.filter,\r\n emailTemplates: this.props.emailTemplates,\r\n singleEmailTemplate: this.props.singleEmailTemplate,\r\n emailTemplateLoading: this.props.emailTemplateLoading,\r\n setMatchedPatients: this.props.setMatchedPatients,\r\n matchedPatients: this.props.matchedPatients,\r\n isMatchedPatientsLoading: this.props.isMatchedPatientsLoading,\r\n setProjectById: this.props.setProjectById,\r\n isProjectLoading: this.props.isProjectLoading,\r\n project: this.props.project,\r\n removePatient: this.props.removePatient,\r\n addPatient: this.props.addPatient,\r\n changeProjectStatus: this.props.changeProjectStatus,\r\n submitRequest: this.props.submitRequest,\r\n changePatientStatus: this.props.changePatientStatus,\r\n getAllEmailTemplates: this.props.getAllEmailTemplates,\r\n getEmailTemplateByName: this.props.getEmailTemplateByName\r\n }}\r\n />\r\n </Form.Group>\r\n )\r\n }\r\n\r\n return (\r\n <>\r\n {mainComponent}\r\n </>\r\n );\r\n }\r\n}","import { default as RootComponent, DispatchProps } from '../components/component-root';\r\nimport * as Constants from '../constants';\r\nimport * as Actions from '../actions';\r\nimport { State } from '../model';\r\nimport { connect } from 'react-redux';\r\nimport { PatientSearchData, ProjectPatientData, RequestData } from '../../../../common/models/input-models';\r\n\r\nexport function mapStateToProps(globalState: any) {\r\n let name = Constants.NAME;\r\n let pageState = globalState[name] as State;\r\n return pageState;\r\n}\r\n\r\nexport function mapDispatchToProps(dispatch: any) {\r\n return {\r\n setLookUpData: () => dispatch(Actions.getLookUpDataAsync()),\r\n setProjects: (condition: number) => dispatch(Actions.getAllFilteredProjectsAsync(condition)),\r\n setFilter: (filter: number) => dispatch(Actions.setProjectsFilter(filter)),\r\n setMatchedPatients: (searchData: PatientSearchData, projectName: string) => dispatch(Actions.updateSearchPatients(searchData, projectName)),\r\n setProjectById: (id: string) => dispatch(Actions.getProjectDataByIdAsync(id)),\r\n removePatient: (inputModel: ProjectPatientData) => dispatch(Actions.removePatientFromProjectAsync(inputModel)),\r\n addPatient: (inputModel: ProjectPatientData, searchData: PatientSearchData, projectName: string) => dispatch(Actions.addPatientToProjectAsync(inputModel, searchData, projectName)),\r\n changeProjectStatus: (id: string, filter: number) => dispatch(Actions.changeProjectStatusAsync(id, filter)),\r\n submitRequest: (data: RequestData) => dispatch(Actions.submitEmailDataAsync(data)),\r\n changePatientStatus: (inputModel: ProjectPatientData) => dispatch(Actions.changePatientStatusToConfirmAsync(inputModel)),\r\n getAllEmailTemplates: () => dispatch(Actions.getAllEmailTemplatesAsync()),\r\n getEmailTemplateByName: (name: string) => dispatch(Actions.getEmailTemplateByNameAsync(name))\r\n } as DispatchProps;\r\n}\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(RootComponent);","import { CSVMappedField } from './csv-mapping-model';\r\n\r\nlet newMappedObj: any; // otherwise it gives an error\r\n\r\nexport const csvDataToJson = (data: any[], mapping: CSVMappedField[]) => {\r\n let mappedData = [];\r\n for (let i = 0; i < data.length; i++) {\r\n const patientInfo = data[i];\r\n newMappedObj = {};\r\n for (let j = 0; j < mapping.length; j++) {\r\n const mapItem = mapping[j];\r\n newMappedObj[mapItem.objectProperty] = patientInfo[mapItem.csvColumnName];\r\n }\r\n mappedData.push(newMappedObj);\r\n }\r\n\r\n return mappedData;\r\n};\r\n","import { defaultEmailTemplate, State } from './model';\r\nimport * as t from './actionTypes';\r\nimport { EmailTemplateData, LookUpData } from '../../../common/models/input-models';\r\nimport { Patient, Project } from '../../../common/models/main-models';\r\nimport { emptyProject } from '../../new-project/model';\r\n\r\nconst initialState: State = {\r\n projects: [],\r\n lookUpData: [],\r\n isLoading: false,\r\n isProjectsLoading: false,\r\n filter: 1,\r\n matchedPatients: [],\r\n isMatchedPatientsLoading: false,\r\n project: emptyProject,\r\n isProjectLoading: false,\r\n emailTemplates: [],\r\n singleEmailTemplate: defaultEmailTemplate,\r\n emailTemplateLoading: false\r\n};\r\n\r\nexport default (state = initialState, action: any): State => {\r\n switch (action.type) {\r\n case t.SET_LOADING:\r\n return setLoading(state, action.payload);\r\n case t.SET_LOOKUP_DATA:\r\n return setLookUpData(state, action.payload);\r\n case t.SET_PROJECTS_LOADING:\r\n return setProjectsLoading(state, action.payload);\r\n case t.SET_PROJECTS:\r\n return setProjects(state, action.payload);\r\n case t.SET_PROJECTS_FILTER:\r\n return setProjectsFilter(state, action.payload);\r\n case t.SET_MATCHED_PATIENTS:\r\n return setMatchedPatients(state, action.payload);\r\n case t.SET_MATCHED_PATIENTS_LOADING:\r\n return setMatchedPatientsLoading(state, action.payload);\r\n case t.SET_PROJECT_DATA:\r\n return setProjectData(state, action.payload);\r\n case t.SET_PROJECTS_LOADING:\r\n return setProjectLoading(state, action.payload);\r\n case t.SET_EMAIL_TEMPLATES:\r\n return setEmailTemplates(state, action.payload);\r\n case t.SET_SINGLE_EMAIL_TEMPLATE:\r\n return setSingleEmailTemplate(state, action.payload);\r\n case t.SET_TEMPLATES_LOADING:\r\n return setEmailTemplateLoading(state, action.payload);\r\n default:\r\n return state;\r\n }\r\n}\r\n\r\nconst setLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setLookUpData = (state: State, val: LookUpData[]): State => {\r\n let newState = {\r\n ...state,\r\n lookUpData: [...val]\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setProjectsLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isProjectsLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setProjects = (state: State, val: Project[]): State => {\r\n let newState = {\r\n ...state,\r\n projects: [...val]\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setProjectsFilter = (state: State, val: number): State => {\r\n let newState = {\r\n ...state,\r\n filter: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setMatchedPatients = (state: State, val: Patient[]): State => {\r\n let newState = {\r\n ...state,\r\n matchedPatients: [...val]\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setMatchedPatientsLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isMatchedPatientsLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setProjectData = (state: State, val: Project): State => {\r\n let newState = {\r\n ...state,\r\n project: { ...val }\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setProjectLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isProjectLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setEmailTemplates = (state: State, val: EmailTemplateData[]): State => {\r\n let newState = {\r\n ...state,\r\n emailTemplates: [...val]\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setSingleEmailTemplate = (state: State, val: EmailTemplateData): State => {\r\n let newState = {\r\n ...state,\r\n singleEmailTemplate: { ...val }\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setEmailTemplateLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n emailTemplateLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}","import * as Actions from './actions';\r\nimport * as Components from './components/index';\r\nimport * as Containers from './containers/index';\r\nimport * as Constants from './constants';\r\nimport Reducer from './reducer';\r\n\r\nexport default {\r\n actions: Actions,\r\n components: Components,\r\n containers: Containers,\r\n constants: Constants,\r\n reducer: Reducer\r\n};\r\n\r\nexport const Root = Containers.ComponentRoot;","// constants.ts\r\n\r\nexport const NAME = 'importPatients';","import { NAME } from \"./constants\";\r\n\r\nexport const SET_IS_DATA_SUBMITTED = `${NAME}/SET_IS_DATA_SUBMITTED`;\r\n\r\nexport const SET_LOOK_UP_DATA = `${NAME}/SET_LOOK_UP_DATA`;","import { LookUpData, PatientsImportData } from \"../../../common/models/input-models\";\r\nimport DataSvc from \"../../../common/services/data-svc\";\r\nimport * as t from './actionTypes';\r\n\r\nexport const setIsDataSubmitted = (isDataSubmitted: boolean) => ({\r\n type: t.SET_IS_DATA_SUBMITTED,\r\n payload: isDataSubmitted,\r\n});\r\n\r\nexport const setLookUpData = (lookUpData: LookUpData[]) => ({\r\n type: t.SET_LOOK_UP_DATA,\r\n payload: lookUpData\r\n});\r\n\r\nexport const submitMatchedDataAsync = (patientsData: PatientsImportData) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setIsDataSubmitted(false));\r\n DataSvc.patientSvc.importPatients(patientsData).then(\r\n (result: any) => {\r\n dispatch(setIsDataSubmitted(true));\r\n },\r\n (error) => {\r\n console.error(error);\r\n }\r\n )\r\n }\r\n}\r\n\r\nexport const getLookUpDataAsync = () => {\r\n return (dispatch: any, getState: any) => {\r\n DataSvc.utilsSvc.getLookUpData().then(\r\n (result: any) => {\r\n dispatch(setLookUpData(result));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}","import * as React from \"react\";\r\nimport { Button } from \"react-bootstrap\";\r\nimport { FormGroup } from \"reactstrap\";\r\nimport { CSVMappedField } from \"./csv-mapping-model\";\r\nimport { Rules } from '../../helpers';\r\nimport { toast } from 'react-toastify';\r\n\r\ntype OwnProps = {\r\n csvObject: any;\r\n objectProperties: string[];\r\n mapping: CSVMappedField[];\r\n isOptionSelected: boolean;\r\n}\r\n\r\nexport type DispatchProps = {\r\n finishMapping: (mapping: any) => void;\r\n}\r\n\r\ntype Props = DispatchProps & OwnProps;\r\n\r\ntype OwnState = {\r\n mapping: CSVMappedField[];\r\n}\r\n\r\nexport default class CSVMappingComponent extends React.Component<Props, OwnState> {\r\n constructor(props: any) {\r\n super(props);\r\n\r\n this.state = {\r\n mapping: []\r\n };\r\n\r\n this.selectMatchingCsvColumn = this.selectMatchingCsvColumn.bind(this);\r\n this.finishMapping = this.finishMapping.bind(this);\r\n }\r\n\r\n componentDidMount() {\r\n this.setState({ mapping: this.props.mapping });\r\n }\r\n\r\n selectMatchingCsvColumn(value: any, key: any) {\r\n let mapping = this.state.mapping;\r\n\r\n let mapItem = mapping.filter((m) => m.objectProperty === key)[0];\r\n if (mapItem) {\r\n mapItem.csvColumnName = value;\r\n } else {\r\n mapping.push({\r\n objectProperty: key,\r\n csvColumnName: value,\r\n } as CSVMappedField);\r\n }\r\n\r\n this.setState({ mapping: mapping });\r\n }\r\n\r\n finishMapping() {\r\n if (!this.props.isOptionSelected) {\r\n toast.error(Rules.selectOptionMessage.required);\r\n }\r\n else {\r\n this.props.finishMapping(this.state.mapping);\r\n }\r\n }\r\n\r\n render() {\r\n\r\n let objPropsOptions = Object.keys(this.props.csvObject[0]).map((k, i) => {\r\n return (\r\n <option key={i} value={k}>\r\n {k.toLowerCase()}\r\n </option>\r\n );\r\n });\r\n\r\n let mappingComponent = this.props.objectProperties.map((p, i) => {\r\n let mapItem = this.state.mapping.filter(\r\n (m) => m.objectProperty === p\r\n )[0];\r\n\r\n if (!mapItem) {\r\n mapItem = {\r\n objectProperty: '',\r\n csvColumnName: ''\r\n };\r\n }\r\n\r\n return (\r\n <FormGroup key={i} className=\"mapping-item-wrapper\">\r\n <FormGroup className=\"mapping-item-object-property\">{p.toUpperCase()}</FormGroup>\r\n <FormGroup className=\"mapping-item-csv-column\">\r\n <select\r\n onChange={(event) =>\r\n this.selectMatchingCsvColumn(\r\n event.target.value,\r\n p\r\n )\r\n }\r\n className=\"blue-dropdown\"\r\n value={mapItem.csvColumnName}\r\n >\r\n <option value=\"\">-</option>\r\n {objPropsOptions}\r\n </select>\r\n </FormGroup>\r\n </FormGroup>\r\n );\r\n });\r\n\r\n return (\r\n <FormGroup id=\"mapping-wrapper\">\r\n {mappingComponent}\r\n <FormGroup className='mapping-item-wrapper'>\r\n <Button\r\n id=\"mapping-button\"\r\n className=\"btn-fmp\"\r\n onClick={this.finishMapping}\r\n >\r\n Finish Mapping\r\n </Button>\r\n </FormGroup>\r\n </FormGroup>\r\n )\r\n }\r\n}","// model.js\r\n// This is the model of our module state (e.g. return type of the reducer)\r\n\r\nimport { LookUpData } from \"../../../common/models/input-models\";\r\n\r\nexport type State = {\r\n isDataSubmitted: boolean;\r\n lookUpData: LookUpData[];\r\n};\r\n\r\nexport const ImportProperties = [\r\n 'firstName',\r\n 'lastName',\r\n 'phoneNumber',\r\n 'email',\r\n 'country',\r\n //'countryCode',\r\n 'condition',\r\n 'gender'\r\n];","import React, { useMemo } from 'react';\r\nimport { Table } from 'react-bootstrap';\r\nimport { useTable } from 'react-table';\r\n\r\ntype OwnProps = {\r\n importPatients: any[]\r\n};\r\n\r\ntype DispatchProps = {\r\n\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nexport default function ImportPreviewGrid(props: Props) {\r\n const data = useMemo(\r\n () => props?.importPatients.map((x: any, i: any) => {\r\n return x\r\n }), [props?.importPatients]\r\n )\r\n\r\n const columns = useMemo(\r\n () => [\r\n {\r\n Header: 'First name',\r\n accessor: 'firstName'\r\n },\r\n {\r\n Header: 'Surname',\r\n accessor: 'lastName'\r\n },\r\n {\r\n Header: 'Phone number',\r\n accessor: 'phoneNumber'\r\n },\r\n {\r\n Header: 'Email',\r\n accessor: 'email'\r\n },\r\n {\r\n Header: 'Country',\r\n accessor: 'country'\r\n },\r\n // {\r\n // Header: 'Country code',\r\n // accessor: 'countryCode'\r\n // },\r\n {\r\n Header: 'Condition',\r\n accessor: 'condition'\r\n },\r\n {\r\n Header: 'Gender',\r\n accessor: 'gender'\r\n }\r\n ], []\r\n )\r\n\r\n const {\r\n getTableProps,\r\n getTableBodyProps,\r\n headerGroups,\r\n rows,\r\n prepareRow,\r\n } = useTable({ columns, data })\r\n\r\n return (\r\n <Table {...getTableProps()} striped bordered hover>\r\n <thead>\r\n {headerGroups.map(headerGroup => (\r\n <tr {...headerGroup.getHeaderGroupProps()}>\r\n {headerGroup.headers.map(col => (\r\n <th {...col.getHeaderProps()}>\r\n {col.render('Header')}\r\n </th>\r\n ))}\r\n </tr>\r\n ))}\r\n </thead>\r\n <tbody {...getTableBodyProps()}>\r\n {rows.map(row => {\r\n prepareRow(row);\r\n return (\r\n <tr {...row.getRowProps()}>\r\n {row.cells.map(cell => {\r\n return (\r\n <td {...cell.getCellProps()}>\r\n {cell.render('Cell')}\r\n </td>\r\n )\r\n })}\r\n </tr>\r\n )\r\n })}\r\n </tbody>\r\n </Table>\r\n )\r\n}\r\n","import * as React from 'react';\r\nimport { State } from '../model';\r\nimport CSVReader, { IFileInfo } from 'react-csv-reader';\r\nimport '../style.scss';\r\nimport EupatiDropdown from '../../../../common/static/dropdown';\r\nimport { FormGroup } from 'reactstrap';\r\nimport {\r\n LookUpOptions,\r\n PatientsImportData,\r\n} from '../../../../common/models/input-models';\r\nimport { Rules } from '../../../../common/helpers';\r\nimport { Button, FormLabel } from 'react-bootstrap';\r\nimport CSVMappingComponent from '../../../../common/static/csv-import/csv-mapping';\r\nimport { ImportProperties } from '../model';\r\nimport { csvDataToJson } from '../../../../common/static/csv-import/csv-mapping-helper';\r\nimport ImportPreviewGrid from '../../../../common/static/import-preview-grid';\r\nimport { CSVMappedField } from '../../../../common/static/csv-import/csv-mapping-model';\r\nimport EupatiConfirmPage from '../../../../common/static/confirm-page';\r\n\r\ntype OwnProps = {};\r\n\r\nexport type DispatchProps = {\r\n submitPatientsData: (patientsData: PatientsImportData) => void;\r\n //getLookUpDate: () => void;\r\n};\r\n\r\ntype Props = State & DispatchProps & OwnProps;\r\n\r\ntype OwnState = {\r\n errorMessage: string;\r\n lookUpValue: any;\r\n data: any[];\r\n mapping: CSVMappedField[];\r\n isMappingMode: boolean;\r\n isPreviewMode: boolean;\r\n isOptionSelected: boolean;\r\n isDataSubmitted: boolean;\r\n};\r\n\r\n// ids are based on enum PatientExpertises\r\nconst lookUpOptions = [\r\n { id: 1, name: 'EUPATI Fellow' } as LookUpOptions,\r\n { id: 3, name: 'EUPATI Open Classroom Learner' } as LookUpOptions,\r\n { id: 2, name: 'National EUPATI Fellow' } as LookUpOptions,\r\n];\r\nexport default class ComponentRoot extends React.Component<Props, OwnState> {\r\n constructor(props: any) {\r\n super(props);\r\n\r\n this.state = {\r\n errorMessage: Rules.selectOptionMessage.required,\r\n lookUpValue: { expertise: 0 },\r\n data: [],\r\n mapping: [],\r\n isMappingMode: true,\r\n isPreviewMode: false,\r\n isOptionSelected: false,\r\n isDataSubmitted: false,\r\n };\r\n\r\n this.csvImportTypeHandler = this.csvImportTypeHandler.bind(this);\r\n this.readCSVData = this.readCSVData.bind(this);\r\n this.handleReadingError = this.handleReadingError.bind(this);\r\n this.finishMapping = this.finishMapping.bind(this);\r\n this.activateMapping = this.activateMapping.bind(this);\r\n this.submitData = this.submitData.bind(this);\r\n }\r\n\r\n csvImportTypeHandler(e: any) {\r\n switch (e.target.value !== '') {\r\n case true:\r\n this.setState({\r\n errorMessage: '',\r\n lookUpValue: { expertise: parseInt(e.target.value) },\r\n isOptionSelected: true,\r\n });\r\n break;\r\n case false:\r\n this.setState({\r\n errorMessage: Rules.selectOptionMessage.required,\r\n lookUpValue: { expertise: 0 },\r\n isOptionSelected: false,\r\n data: [],\r\n });\r\n break;\r\n }\r\n }\r\n\r\n readCSVData(data: Array<any>, fileInfo: IFileInfo) {\r\n this.setState({ data: data });\r\n console.debug(fileInfo);\r\n }\r\n\r\n handleReadingError(err: any) {\r\n console.error(err);\r\n }\r\n\r\n finishMapping(mapping: any) {\r\n this.setState({\r\n mapping: mapping,\r\n isMappingMode: false,\r\n isPreviewMode: true,\r\n });\r\n }\r\n\r\n activateMapping() {\r\n this.setState({\r\n isMappingMode: true,\r\n isPreviewMode: false,\r\n });\r\n }\r\n\r\n submitData() {\r\n const mappedData = csvDataToJson(this.state.data, this.state.mapping);\r\n const patientExpertise = lookUpOptions.find(\r\n (l) => l.id === this.state.lookUpValue.expertise\r\n );\r\n mappedData.forEach((md: any) =>\r\n Object.assign(md, { expertise: patientExpertise })\r\n );\r\n this.props.submitPatientsData(mappedData as PatientsImportData);\r\n this.setState({\r\n isDataSubmitted: true,\r\n isMappingMode: false,\r\n isPreviewMode: false,\r\n isOptionSelected: false,\r\n });\r\n }\r\n\r\n render() {\r\n //Upload CSV UTF-8 (Comma delimited)\r\n let uploadCSVComponent: any;\r\n if (this.state.isOptionSelected) {\r\n let papaparseOptions = {\r\n header: true,\r\n dynamicTyping: true,\r\n skipEmptyLines: true,\r\n encoding: 'utf-8',\r\n transformHeader: (header: any) =>\r\n header.toLowerCase().replace(`/\\W/g`, '_'),\r\n };\r\n uploadCSVComponent = (\r\n <>\r\n <CSVReader\r\n cssClass=\"csv-reader-input\"\r\n label=\"Select CSV patients data\"\r\n onFileLoaded={(data, fileInfo) => this.readCSVData(data, fileInfo)}\r\n parserOptions={papaparseOptions}\r\n onError={this.handleReadingError}\r\n inputId=\"patients-csv-import\"\r\n inputName=\"patients-csv\"\r\n inputStyle={{ color: '#F0B72F', margin: 'auto' }}\r\n />\r\n <hr className=\"solid\" />\r\n </>\r\n );\r\n }\r\n\r\n //Column mapping\r\n let csvMappingComponent: any;\r\n if (this.state.data.length > 0 && this.state.isMappingMode) {\r\n let csvMappingProps = {\r\n csvObject: this.state.data,\r\n objectProperties: ImportProperties,\r\n mapping: this.state.mapping,\r\n finishMapping: (mapping: any) => this.finishMapping(mapping),\r\n isOptionSelected: this.state.isOptionSelected,\r\n };\r\n csvMappingComponent = <CSVMappingComponent {...csvMappingProps} />;\r\n }\r\n\r\n //Data preview\r\n let previewComponent: any;\r\n if (this.state.data.length > 0 && this.state.isPreviewMode) {\r\n let previewData;\r\n if (this.state.data.length > 10) {\r\n previewData = this.state.data.slice(0, 10);\r\n } else {\r\n previewData = this.state.data;\r\n }\r\n\r\n let mappedPreviewData = csvDataToJson(previewData, this.state.mapping);\r\n\r\n previewComponent = (\r\n <>\r\n <ImportPreviewGrid importPatients={mappedPreviewData} />\r\n <div className=\"d-flex\" id=\"importBtns\">\r\n <Button\r\n id=\"mapping-button\"\r\n className=\"btn-back\"\r\n onClick={this.activateMapping}\r\n >\r\n Go To Mapping\r\n </Button>\r\n <Button\r\n id=\"mapping-button\"\r\n className=\"btn\"\r\n onClick={this.submitData}\r\n >\r\n Upload Data\r\n </Button>\r\n </div>\r\n </>\r\n );\r\n }\r\n\r\n //Confirm page\r\n let confirmPage: any;\r\n if (this.state.isDataSubmitted) {\r\n confirmPage = (\r\n <>\r\n <EupatiConfirmPage />\r\n </>\r\n );\r\n }\r\n\r\n return (\r\n <FormGroup>\r\n {!this.state.isDataSubmitted && (\r\n <>\r\n <h4\r\n style={{\r\n textAlign: 'center',\r\n margin: '5rem auto auto auto',\r\n textDecoration: 'underline',\r\n fontWeight: 'bold',\r\n }}\r\n >\r\n IMPORT PATIENTS DATA\r\n </h4>\r\n <hr className=\"solid\" />\r\n <FormGroup className=\"import-pt-dropdown mb-5\">\r\n <FormLabel style={{ alignItems: 'center' }}>\r\n Select EUPATI Patient type\r\n </FormLabel>\r\n <EupatiDropdown\r\n {...{\r\n fieldName: 'csv-type',\r\n errorMsg: this.state.errorMessage,\r\n values: lookUpOptions,\r\n onChange: (e: any) => this.csvImportTypeHandler(e),\r\n defaultOptionText: '',\r\n width: 'auto',\r\n }}\r\n />\r\n </FormGroup>\r\n </>\r\n )}\r\n {uploadCSVComponent}\r\n {csvMappingComponent}\r\n {previewComponent}\r\n {confirmPage}\r\n </FormGroup>\r\n );\r\n }\r\n}\r\n","import { default as RootComponent, DispatchProps } from '../components/component-root';\r\nimport * as Constants from '../constants';\r\nimport * as Actions from '../actions';\r\nimport { State } from '../model';\r\nimport { connect } from 'react-redux';\r\nimport { PatientsImportData } from '../../../../common/models/input-models';\r\n\r\nexport function mapStateToProps(globalState: any) {\r\n let name = Constants.NAME;\r\n let pageState = globalState[name] as State;\r\n return pageState;\r\n}\r\n\r\nexport function mapDispatchToProps(dispatch: any) {\r\n return {\r\n submitPatientsData: (patientsData: PatientsImportData) => dispatch(Actions.submitMatchedDataAsync(patientsData)),\r\n getLookUpDate: () => dispatch(Actions.getLookUpDataAsync())\r\n } as DispatchProps;\r\n}\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(RootComponent);","import { State } from './model';\r\nimport * as t from './actionTypes';\r\nimport { LookUpData } from '../../../common/models/input-models';\r\n\r\nconst initialState: State = {\r\n isDataSubmitted: false,\r\n lookUpData: []\r\n};\r\n\r\nexport default (state = initialState, action: any): State => {\r\n switch (action.type) {\r\n case t.SET_IS_DATA_SUBMITTED:\r\n return setIsDataSubmitted(state, action.payload);\r\n case t.SET_LOOK_UP_DATA:\r\n return setLookUpData(state, action.payload);\r\n default:\r\n return state;\r\n }\r\n};\r\n\r\nconst setIsDataSubmitted = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isDataSubmitted: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setLookUpData = (state: State, val: LookUpData[]): State => {\r\n let newState = {\r\n ...state,\r\n lookUpData: [...val]\r\n } as State;\r\n\r\n return newState;\r\n}","import * as Actions from './actions';\r\nimport * as Components from './components/index';\r\nimport * as Containers from './containers/index';\r\nimport * as Constants from './constants';\r\nimport Reducer from './reducer';\r\n\r\nexport default {\r\n actions: Actions,\r\n components: Components,\r\n containers: Containers,\r\n constants: Constants,\r\n reducer: Reducer\r\n};\r\n\r\nexport const Root = Containers.ComponentRoot;","// constants.ts\r\n\r\nexport const NAME = 'allPatients';","import { NAME } from \"./constants\";\r\n\r\nexport const SET_LOOKUP_DATA = `${NAME}/SET_LOOKUP_DATA`;\r\n\r\nexport const SET_LOADING = `${NAME}/SET_LOADING`;\r\n\r\nexport const SET_PATIENTS = `${NAME}/SET_PATIENTS`;\r\n\r\nexport const SET_PATIENTS_LOADING = `${NAME}/SET_PATIENTS_LOADING`;\r\n\r\nexport const REMOVE_PATIENT = `${NAME}/REMOVE_PATIENT`;\r\n\r\nexport const SET_PATIENT_INFO = `allPatient/SET_PATIENT_INFO`;\r\n\r\nexport const SET_PATIENT_INFO_LOADING = `allPatient/SET_PATIENT_INFO_LOADING`;","import { LookUpData } from \"../../../common/models/input-models\";\r\nimport { Patient } from \"../../../common/models/main-models\";\r\nimport DataSvc from \"../../../common/services/data-svc\";\r\nimport * as t from './actionTypes';\r\n\r\nexport const setLoading = (isLoading: boolean) => ({\r\n type: t.SET_LOADING,\r\n payload: isLoading\r\n});\r\n\r\nexport const setLookUpData = (data: LookUpData[]) => ({\r\n type: t.SET_LOOKUP_DATA,\r\n payload: data\r\n});\r\n\r\nexport const setPatients = (patients: Patient[]) => ({\r\n type: t.SET_PATIENTS,\r\n payload: [...patients]\r\n});\r\n\r\nexport const setIsPatientsLoading = (isPatientsLoading: boolean) => ({\r\n type: t.SET_PATIENTS_LOADING,\r\n payload: isPatientsLoading\r\n});\r\n\r\nexport const setPatientInfo = (patient: Patient) => ({\r\n type: t.SET_PATIENT_INFO,\r\n payload: patient\r\n});\r\n\r\nexport const setPatientInfoLoading = (isPatientInfoLoading: boolean) => ({\r\n type: t.SET_PATIENT_INFO_LOADING,\r\n payload: isPatientInfoLoading\r\n});\r\n\r\nexport const getLookUpDataAsync = () => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setLoading(true));\r\n DataSvc.utilsSvc.getLookUpData().then(\r\n (result: any) => {\r\n dispatch(setLookUpData(result));\r\n dispatch(setLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n );\r\n };\r\n};\r\n\r\nexport const getAllPatientsAsync = () => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setIsPatientsLoading(true));\r\n DataSvc.patientSvc.getAllPatients().then(\r\n (result: any) => {\r\n dispatch(setPatients(result));\r\n dispatch(setIsPatientsLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const getPatientByIdAsync = (id: string) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setPatientInfoLoading(true));\r\n DataSvc.patientSvc.getPatientById(id).then(\r\n (result: any) => {\r\n dispatch(setPatientInfo(result));\r\n dispatch(setPatientInfoLoading(false));\r\n },\r\n (error) => { console.log(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const removePatientByIdAsync = (id: string) => {\r\n return (dispatch: any, getState: any) => {\r\n DataSvc.patientSvc.getPatientById(id).then(\r\n (result: any) => {\r\n DataSvc.patientSvc.removePatient(result).then(\r\n () => {\r\n dispatch(getAllPatientsAsync());\r\n },\r\n (error) => { console.log(error); }\r\n )\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}","import React from 'react';\r\nimport { Button, Form } from 'react-bootstrap';\r\nimport Popup from 'reactjs-popup';\r\nimport './static.scss';\r\n\r\ntype OwnProps = {\r\n target: string;\r\n params: string;\r\n targetId: string;\r\n};\r\n\r\ntype DispatchProps = {\r\n handleRemove: (id: string, e: any) => void;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nexport default function ConfirmDenyModal(props: Props) {\r\n return (\r\n <Popup\r\n className='modal'\r\n trigger={\r\n <Button variant='danger' className='modal-rm'>REMOVE</Button>\r\n }\r\n modal\r\n >\r\n {(close: any) => (\r\n <Form.Group>\r\n <button className='modal-close' onClick={close}>\r\n ×\r\n </button>\r\n <Form.Label className='modal-head'>Do you want to permanently delete this?</Form.Label>\r\n <Form.Group className='modal-core'>\r\n {' '}\r\n {`The following action will remove ${props.target.toLocaleUpperCase()} with ${props.params.toLocaleUpperCase()}`}\r\n </Form.Group>\r\n <Form.Group className='modal-actions'>\r\n <Button variant='success' onClick={(e: any) => props.handleRemove(props.targetId, e)} >CONFRIM</Button>\r\n <Button variant='secondary' onClick={close} >CANCEL</Button>\r\n </Form.Group>\r\n </Form.Group>\r\n )\r\n }\r\n </Popup >\r\n )\r\n}","import React, { useMemo, useState } from 'react';\r\nimport { Table } from 'react-bootstrap';\r\nimport {\r\n useTable,\r\n useGlobalFilter,\r\n usePagination,\r\n useSortBy,\r\n} from 'react-table';\r\nimport { Button, Form } from 'react-bootstrap';\r\nimport GlobalFilter from './global-filter';\r\nimport EupatiPatientDetails from './patient-details';\r\nimport './static.scss';\r\nimport EupatiLoader from './loading-animation/loader';\r\nimport { DiseaseInfo, Patient } from '../models/main-models';\r\nimport { LookUpData } from '../models/input-models';\r\nimport { useHistory } from 'react-router';\r\nimport { toast } from 'react-toastify';\r\nimport { REMOVE_PT_SUCC_MSG } from '../../common/helpers/messages';\r\nimport { IconProp } from '@fortawesome/fontawesome-svg-core';\r\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\r\nimport {\r\n faSortAlphaDown,\r\n faSortAlphaUp,\r\n faFileExcel,\r\n} from '@fortawesome/fontawesome-free-solid';\r\nimport { faWindowMinimize } from '@fortawesome/fontawesome-free-regular';\r\nimport { CSVLink } from 'react-csv';\r\nimport uniqid from 'uniqid';\r\nimport ConfirmDenyModal from './confirm-deny-modal';\r\n\r\ntype OwnProps = {\r\n lookUpData: LookUpData[];\r\n patients: Patient[];\r\n patientDetails: Patient;\r\n};\r\n\r\ntype DispatchProps = {\r\n removePatientById: (patientId: string) => void;\r\n showPatientDetails: (patientId: string) => void;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nconst OUTLINE_PADDING_STYLE = {\r\n paddingLeft: '1.2rem',\r\n paddingRight: '1.2rem',\r\n};\r\nconst PRIMARY_PADDING_STYLE = {\r\n paddingLeft: '1.7rem',\r\n paddingRight: '1.7rem',\r\n};\r\nexport default function EupatiAllPatients(props: Props) {\r\n const history = useHistory();\r\n\r\n const [isDetailsBtnClicked, setIsDetailsBtnClicked] =\r\n useState<boolean>(false);\r\n\r\n const handleRemovePatient = (id: string, e: any) => {\r\n e.preventDefault();\r\n props.removePatientById(id);\r\n toast.success(REMOVE_PT_SUCC_MSG);\r\n };\r\n\r\n const handlePatientDetails = (id: string, e: any) => {\r\n e.preventDefault();\r\n setIsDetailsBtnClicked(true);\r\n props.showPatientDetails(id);\r\n };\r\n\r\n const backBtnHandler = () => {\r\n setIsDetailsBtnClicked(false);\r\n };\r\n\r\n const addBtnHandler = () => {\r\n history.push({\r\n pathname: '/patient',\r\n state: { isNewPatient: true },\r\n });\r\n };\r\n\r\n const returnValueById = (propName: string, projectPropId: number) => {\r\n let propType = props.lookUpData.find((x: any) => x.name == propName); // projectType\r\n let propValue = propType?.data.find((x: any) => x.id == projectPropId);\r\n return propValue?.name;\r\n };\r\n\r\n const headers = [\r\n { label: 'First Name', key: 'firstName' },\r\n { label: 'Last Name', key: 'lastName' },\r\n { label: 'Country', key: 'country' },\r\n { label: 'Diseases', key: 'diseases' },\r\n { label: 'Email', key: 'email' },\r\n { label: 'Expertises', key: 'expertises' },\r\n { label: 'Phone number', key: 'phone' },\r\n { label: 'Other Information', key: 'otherInformation' },\r\n { label: 'Gender', key: 'gender' },\r\n { label: 'Patient Experience', key: 'patientExperience' },\r\n { label: 'Activity Preference', key: 'activityPreference' },\r\n { label: 'Is Affiliated With Patient Org', key: 'isPOAffiliated' },\r\n { label: 'Is Eligible For Compensation', key: 'isEligibleForCompensation' },\r\n {\r\n label: 'Is Available Without Compensation',\r\n key: 'isAvailableForNoCompensation',\r\n },\r\n { label: 'Languages', key: 'languages' },\r\n { label: 'Project Preferences', key: 'projectPreferences' },\r\n { label: 'Project Experiences', key: 'projectTypeExperiences' },\r\n { label: 'Organisation Preferences', key: 'organisationPreferences' },\r\n { label: 'Countries With Experience', key: 'countriesWithExperience' },\r\n ];\r\n\r\n const data = useMemo(\r\n () =>\r\n props.patients?.map((x: any, i: any) => {\r\n return {\r\n //default grid cols\r\n id: x.id,\r\n firstName: x.firstName,\r\n lastName: x.lastName,\r\n country: returnValueById('country', x.countryId),\r\n diseases: x.noDiseaseExpertise\r\n ? 'No specific disease experience'\r\n : x.diseases?.map((d: any) => d.name).join(', '),\r\n email: x.email,\r\n expertises: x.patientExpertises\r\n .map((pe: number) => returnValueById('expertise', pe))\r\n .join(', '),\r\n //additional csv cols\r\n //single fields\r\n phone: `${x.phoneNumber}`,\r\n otherInformation: x.otherInformation?.replace(/\\r?\\n/g, ''),\r\n gender: returnValueById('genderType', x.genderTypeId),\r\n patientExperience: returnValueById(\r\n 'patientExperiense',\r\n x.patientExperienceId\r\n ),\r\n activityPreference: returnValueById(\r\n 'activityType',\r\n x.activityPreferenceId\r\n ),\r\n isPOAffiliated: x.isPOAffiliated ? 'Yes' : 'No',\r\n isEligibleForCompensation: x.isEligibleForCompensation ? 'Yes' : 'No',\r\n isAvailableForNoCompensation: x.isAvailableForNoCompensation\r\n ? 'Yes'\r\n : 'No',\r\n //collections\r\n projectPreferences: x.projectPreferences\r\n .map((pp: number) => returnValueById('projectType', pp))\r\n .join(', '),\r\n projectTypeExperiences: x.projectTypeExperiences\r\n .map((pte: number) => returnValueById('projectType', pte))\r\n .join(', '),\r\n organisationPreferences: x.organisationPreferences\r\n .map((op: number) => returnValueById('organisationType', op))\r\n .join(', '),\r\n countriesWithExperience: x.countriesWithExperience\r\n .map((c: string) => returnValueById('country', parseInt(c)))\r\n .join(', '),\r\n languages: x.languages\r\n .map((l: string) => returnValueById('language', parseInt(l)))\r\n .join(', '),\r\n matchedProjects: x.matchedProjects.length,\r\n confirmedProjects: x.confirmedProjects.length,\r\n };\r\n }),\r\n [props.patients]\r\n );\r\n\r\n const columns = useMemo(\r\n () => [\r\n {\r\n Header: 'Name',\r\n accessor: 'name', // accessor is the \"key\" in the data\r\n },\r\n {\r\n Header: 'Country',\r\n accessor: 'country',\r\n },\r\n {\r\n Header: 'Disease',\r\n accessor: 'diseases',\r\n },\r\n {\r\n Header: 'Email',\r\n accessor: 'email',\r\n },\r\n {\r\n Header: 'Expertises',\r\n accessor: 'expertises',\r\n },\r\n ],\r\n []\r\n );\r\n\r\n const {\r\n getTableProps,\r\n getTableBodyProps,\r\n headerGroups,\r\n // @ts-ignore\r\n page,\r\n rows,\r\n // @ts-ignore\r\n nextPage,\r\n // @ts-ignore\r\n previousPage,\r\n // @ts-ignore\r\n canNextPage,\r\n // @ts-ignore\r\n canPreviousPage,\r\n prepareRow,\r\n visibleColumns,\r\n // @ts-ignore\r\n pageOptions,\r\n // @ts-ignore\r\n gotoPage,\r\n // @ts-ignore\r\n pageCount,\r\n // @ts-ignore\r\n setPageSize,\r\n state,\r\n // @ts-ignore\r\n setGlobalFilter,\r\n } = useTable(\r\n {\r\n // @ts-ignore\r\n columns,\r\n data,\r\n // @ts-ignore\r\n initialState: { pageIndex: 0 },\r\n },\r\n useGlobalFilter,\r\n useSortBy,\r\n usePagination\r\n );\r\n // @ts-ignore\r\n const { globalFilter, pageSize, pageIndex } = state;\r\n\r\n let patientsDetailsComp: any;\r\n let loadComp = (\r\n <div className=\"loader-wrapper\">\r\n <EupatiLoader />\r\n </div>\r\n );\r\n\r\n function redirectToPatientsPage() {\r\n history.push({\r\n pathname: '/patient',\r\n state: {\r\n patientId: props.patientDetails.id,\r\n isNewPatient: false,\r\n },\r\n });\r\n }\r\n\r\n function returnProperIconType(icon: any) {\r\n return icon as IconProp;\r\n }\r\n\r\n if (props.patientDetails.id === '') {\r\n patientsDetailsComp = loadComp;\r\n } else {\r\n patientsDetailsComp = (\r\n <EupatiPatientDetails\r\n {...{\r\n patientInfo: props.patientDetails,\r\n lookUpData: props.lookUpData,\r\n backBtnHandler: backBtnHandler,\r\n leftArrowText: 'all patients',\r\n rightArrowText: 'edit patient',\r\n forwardBtnHandler: redirectToPatientsPage,\r\n isForwardArrowAvail: true,\r\n }}\r\n />\r\n );\r\n }\r\n\r\n return (\r\n <>\r\n {isDetailsBtnClicked && <>{patientsDetailsComp}</>}\r\n {!isDetailsBtnClicked && (\r\n <>\r\n <h4 style={{ textAlign: 'center', textDecoration: 'underline' }}>\r\n PATIENTS\r\n </h4>\r\n <div className=\"table-btns\">\r\n <Button id=\"add-pt-btn\" onClick={addBtnHandler}>\r\n ADD PATIENT\r\n </Button>\r\n <span>\r\n <strong>{props.patients?.length}</strong> patients in total.\r\n </span>\r\n <CSVLink\r\n data={data}\r\n headers={headers}\r\n id=\"csv-download-btn\"\r\n filename={`${uniqid('patients-table-')}.csv`}\r\n className=\"btn btn-success\"\r\n >\r\n DOWNLOAD{' '}\r\n <FontAwesomeIcon icon={returnProperIconType(faFileExcel)} />\r\n </CSVLink>\r\n </div>\r\n <Table {...getTableProps()} striped bordered hover>\r\n <thead>\r\n {headerGroups.map((headerGroup) => (\r\n <tr {...headerGroup.getHeaderGroupProps()}>\r\n {headerGroup.headers.map((col) => (\r\n //@ts-ignore\r\n <th {...col.getHeaderProps(col.getSortByToggleProps())}>\r\n {col.render('Header')}\r\n <span>\r\n {\r\n /* @ts-ignore */\r\n col.isSorted ? (\r\n /* @ts-ignore */\r\n col.isSortedDesc ? (\r\n <FontAwesomeIcon\r\n icon={returnProperIconType(faSortAlphaDown)}\r\n />\r\n ) : (\r\n <FontAwesomeIcon\r\n icon={returnProperIconType(faSortAlphaUp)}\r\n />\r\n )\r\n ) : (\r\n <FontAwesomeIcon\r\n id=\"line\"\r\n icon={returnProperIconType(faWindowMinimize)}\r\n />\r\n )\r\n }\r\n </span>\r\n </th>\r\n ))}\r\n </tr>\r\n ))}\r\n <tr>\r\n <th\r\n colSpan={visibleColumns.length}\r\n style={{ textAlign: 'left' }}\r\n >\r\n <GlobalFilter\r\n filter={globalFilter}\r\n setFilter={setGlobalFilter}\r\n />\r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody {...getTableBodyProps()}>\r\n {page.map((row: any) => {\r\n prepareRow(row);\r\n return (\r\n <tr {...row.getRowProps()}>\r\n {row.cells.map((cell: any) => {\r\n return (\r\n <td {...cell.getCellProps()}>{cell.render('Cell')}</td>\r\n );\r\n })}\r\n <>\r\n <td>\r\n <Button\r\n variant=\"info\"\r\n onClick={(e: any) =>\r\n handlePatientDetails(row.original.id, e)\r\n }\r\n >\r\n DETAILS\r\n </Button>\r\n </td>\r\n <td>\r\n <ConfirmDenyModal\r\n {...{\r\n targetId: row.original.id,\r\n target: 'patient',\r\n params: `email address - ${\r\n props.patients.find(\r\n (pt: Patient) => pt.id === row.original.id\r\n )?.email\r\n }`,\r\n handleRemove: handleRemovePatient,\r\n }}\r\n />\r\n {/* <Button\r\n variant='danger'\r\n onClick={(e: any) => handleRemovePatient(row.original.id, e)}\r\n >\r\n REMOVE\r\n </Button> */}\r\n </td>\r\n </>\r\n </tr>\r\n );\r\n })}\r\n </tbody>\r\n </Table>\r\n <Form.Group\r\n style={{\r\n display: 'flex',\r\n justifyContent: 'space-between',\r\n alignItems: 'center',\r\n }}\r\n >\r\n <span>\r\n Page{' '}\r\n <strong>\r\n {pageIndex + 1} of {pageOptions.length}\r\n </strong>\r\n </span>\r\n <span>\r\n Go to page:{' '}\r\n <input\r\n type=\"number\"\r\n defaultValue={pageIndex + 1}\r\n min=\"1\"\r\n disabled={pageSize >= rows.length}\r\n onChange={(e) => {\r\n e.preventDefault();\r\n const pageNum = e.target.value\r\n ? Number(e.target.value) - 1\r\n : 0;\r\n gotoPage(pageNum);\r\n }}\r\n />\r\n </span>\r\n <select\r\n value={pageSize}\r\n onChange={(e) => setPageSize(e.target.value)}\r\n >\r\n {[10, 25, 50, 100].map((pageSize) => (\r\n <option key={pageSize} value={pageSize}>\r\n Show {pageSize}\r\n </option>\r\n ))}\r\n </select>\r\n <Button\r\n id=\"backToFirstPageBtn\"\r\n onClick={() => gotoPage(0)}\r\n disabled={!canPreviousPage}\r\n style={\r\n canPreviousPage\r\n ? { cursor: 'pointer', ...OUTLINE_PADDING_STYLE }\r\n : { cursor: 'not-allowed', ...OUTLINE_PADDING_STYLE }\r\n }\r\n className=\"btn btn-outline-dark btn-sm\"\r\n >\r\n {'<<'}\r\n </Button>\r\n <Button\r\n onClick={() => previousPage()}\r\n disabled={!canPreviousPage}\r\n style={\r\n canPreviousPage\r\n ? { cursor: 'pointer' }\r\n : { cursor: 'not-allowed' }\r\n }\r\n variant=\"secondary\"\r\n >\r\n Previous\r\n </Button>\r\n <Button\r\n onClick={() => nextPage()}\r\n disabled={!canNextPage}\r\n style={\r\n canNextPage\r\n ? { cursor: 'pointer', ...PRIMARY_PADDING_STYLE }\r\n : { cursor: 'not-allowed', ...PRIMARY_PADDING_STYLE }\r\n }\r\n variant=\"primary\"\r\n >\r\n Next\r\n </Button>\r\n <Button\r\n id=\"gotoLastPageBtn\"\r\n onClick={() => gotoPage(pageCount - 1)}\r\n disabled={!canNextPage}\r\n style={\r\n canNextPage\r\n ? { cursor: 'pointer', ...OUTLINE_PADDING_STYLE }\r\n : { cursor: 'not-allowed', ...OUTLINE_PADDING_STYLE }\r\n }\r\n className=\"btn btn-outline-dark btn-sm\"\r\n >\r\n {'>>'}\r\n </Button>\r\n </Form.Group>\r\n </>\r\n )}\r\n </>\r\n );\r\n}\r\n","import * as React from 'react';\r\nimport { Form } from 'react-bootstrap';\r\nimport EupatiLoader from '../../../../common/static/loading-animation/loader';\r\nimport EupatiAllPatients from '../../../../common/static/patients-grid';\r\nimport { State } from '../model';\r\nimport '../style.scss';\r\n\r\ntype OwnProps = {};\r\n\r\nexport type DispatchProps = {\r\n setLookUpData: () => void;\r\n setPatients: () => void;\r\n removePatientById: (patientId: string) => void;\r\n setPatientInfo: (patientId: string) => void;\r\n};\r\n\r\ntype Props = State & DispatchProps & OwnProps;\r\n\r\ntype OwnState = {};\r\n\r\nexport default class ComponentRoot extends React.Component<Props, OwnState> {\r\n\r\n componentDidMount() {\r\n this.props.setPatients();\r\n this.props.setLookUpData();\r\n }\r\n\r\n render() {\r\n\r\n let mainComponent: any;\r\n\r\n let loadingComponent = (\r\n <div className='loader-wrapper'>\r\n <EupatiLoader />\r\n </div>\r\n )\r\n\r\n if (this.props.isLoading ||\r\n this.props.isPatientsLoading) {\r\n mainComponent = loadingComponent;\r\n }\r\n else {\r\n mainComponent = (\r\n <Form.Group id='all-patients-tbl' className='all-patients-wrapper mb-5'>\r\n <EupatiAllPatients\r\n {...{\r\n lookUpData: this.props.lookUpData,\r\n patients: this.props.patients,\r\n removePatientById: this.props.removePatientById,\r\n showPatientDetails: this.props.setPatientInfo,\r\n patientDetails: this.props.patientInfo\r\n }}\r\n />\r\n </Form.Group>\r\n )\r\n }\r\n\r\n return (\r\n <>\r\n {mainComponent}\r\n </>\r\n );\r\n }\r\n}","import { default as RootComponent, DispatchProps } from '../components/component-root';\r\nimport * as Constants from '../constants';\r\nimport * as Actions from '../actions';\r\nimport { State } from '../model';\r\nimport { connect } from 'react-redux';\r\n\r\nexport function mapStateToProps(globalState: any) {\r\n let name = Constants.NAME;\r\n let pageState = globalState[name] as State;\r\n return pageState;\r\n}\r\n\r\nexport function mapDispatchToProps(dispatch: any) {\r\n return {\r\n setLookUpData: () => dispatch(Actions.getLookUpDataAsync()),\r\n setPatients: () => dispatch(Actions.getAllPatientsAsync()),\r\n removePatientById: (patientId: string) => dispatch(Actions.removePatientByIdAsync(patientId)),\r\n setPatientInfo: (patientId: string) => dispatch(Actions.getPatientByIdAsync(patientId))\r\n } as DispatchProps;\r\n}\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(RootComponent);","import { State } from './model';\r\nimport * as t from './actionTypes';\r\nimport { LookUpData } from '../../../common/models/input-models';\r\nimport { Patient } from '../../../common/models/main-models';\r\nimport { defaultPatientInfo } from '../../patient-profile/model';\r\n\r\nconst initialState: State = {\r\n patients: [],\r\n lookUpData: [],\r\n isLoading: false,\r\n isPatientsLoading: false,\r\n isPatientInfoLoading: false,\r\n patientInfo: defaultPatientInfo\r\n};\r\n\r\nexport default (state = initialState, action: any): State => {\r\n switch (action.type) {\r\n case t.SET_LOADING:\r\n return setLoading(state, action.payload);\r\n case t.SET_LOOKUP_DATA:\r\n return setLookUpData(state, action.payload);\r\n case t.SET_PATIENTS_LOADING:\r\n return setPatientsLoading(state, action.payload);\r\n case t.SET_PATIENTS:\r\n return setPatients(state, action.payload);\r\n case t.SET_PATIENT_INFO_LOADING:\r\n return setPatientInfoLoading(state, action.payload);\r\n case t.SET_PATIENT_INFO:\r\n return setPatientInfo(state, action.payload);\r\n default:\r\n return state;\r\n }\r\n}\r\n\r\nconst setLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setLookUpData = (state: State, val: LookUpData[]): State => {\r\n let newState = {\r\n ...state,\r\n lookUpData: [...val]\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setPatientsLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isPatientsLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setPatients = (state: State, val: Patient[]): State => {\r\n let newState = {\r\n ...state,\r\n patients: [...val]\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setPatientInfoLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isPatientInfoLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setPatientInfo = (state: State, val: Patient): State => {\r\n let newState = {\r\n ...state,\r\n patientInfo: { ...val }\r\n } as State;\r\n\r\n return newState;\r\n}\r\n","import * as Actions from './actions';\r\nimport * as Components from './components/index';\r\nimport * as Containers from './containers/index';\r\nimport * as Constants from './constants';\r\nimport Reducer from './reducer';\r\n\r\nexport default {\r\n actions: Actions,\r\n components: Components,\r\n containers: Containers,\r\n constants: Constants,\r\n reducer: Reducer\r\n};\r\n\r\nexport const Root = Containers.ComponentRoot;","// constants.ts\r\n\r\nexport const NAME = 'allAdmins';","import { NAME } from \"./constants\";\r\n\r\nexport const SET_ADMINS_LOADING = `${NAME}/SET_ADMINS_LOADING`;\r\n\r\nexport const SET_ADMINS = `${NAME}/SET_ADMINS`;","import { User } from '../../../common/models/main-models';\r\nimport DataSvc from '../../../common/services/data-svc';\r\nimport * as t from './actionTypes';\r\n\r\nexport const setIsAdminsLoading = (isAdminsLoading: boolean) => ({\r\n type: t.SET_ADMINS_LOADING,\r\n payload: isAdminsLoading,\r\n});\r\n\r\nexport const setAdmins = (admins: User[]) => ({\r\n type: t.SET_ADMINS,\r\n payload: [...admins],\r\n});\r\n\r\nexport const getAllAdminsAsync = () => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setIsAdminsLoading(true));\r\n DataSvc.usersSvc.getAllAdmins().then(\r\n (result: any) => {\r\n dispatch(setAdmins(result));\r\n dispatch(setIsAdminsLoading(false));\r\n },\r\n (error) => {\r\n console.error(error);\r\n }\r\n );\r\n };\r\n};\r\n\r\nexport const removeAdminAsync = (id: string, ownerId: string) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setIsAdminsLoading(true));\r\n DataSvc.usersSvc.getEupatiUserById(ownerId).then(\r\n (result: any) => {\r\n DataSvc.usersSvc.removeAdmin({ id: id, email: '' } as User).then(\r\n () => {\r\n dispatch(getAllAdminsAsync());\r\n dispatch(setIsAdminsLoading(false));\r\n },\r\n (error) => {\r\n console.error(error);\r\n }\r\n );\r\n },\r\n (error) => {\r\n console.error(error);\r\n }\r\n );\r\n };\r\n};\r\n\r\nexport const approveAdminAsync = (id: string, ownerId: string) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setIsAdminsLoading(true));\r\n DataSvc.usersSvc.getAdminById(ownerId).then(\r\n (result: any) => {\r\n DataSvc.usersSvc.approveAdmin({ id: id, email: '' } as User).then(\r\n () => {\r\n dispatch(getAllAdminsAsync());\r\n dispatch(setIsAdminsLoading(false));\r\n },\r\n (error) => {\r\n console.error(error);\r\n }\r\n );\r\n },\r\n (error) => {\r\n console.error(error);\r\n }\r\n );\r\n };\r\n};\r\n","import React, { useMemo, useContext } from 'react';\r\nimport { Button } from 'react-bootstrap';\r\nimport { useTable, useGlobalFilter, usePagination } from 'react-table';\r\nimport { Table } from 'reactstrap';\r\nimport { User } from '../models/main-models';\r\nimport GlobalFilter from './global-filter';\r\nimport { toast } from 'react-toastify';\r\nimport {\r\n REMOVE_ADMIN_SUCC_MSG,\r\n APPROVE_ADMIN_SUCC_MSG,\r\n} from '../../common/helpers/messages';\r\nimport AuthenticationContext from '../../common/static/auth-context';\r\nimport './static.scss';\r\nimport { Roles } from '../helpers';\r\nimport ConfirmDenyModal from './confirm-deny-modal';\r\n\r\ntype OwnProps = {\r\n admins: User[];\r\n};\r\n\r\ntype DispatchProps = {\r\n removeAdmin: (id: string, ownerId: string) => void;\r\n approveAdmin: (id: string, ownerId: string) => void;\r\n};\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nexport default function EupatiAllAdminsGrid(props: Props) {\r\n const contextData = useContext(AuthenticationContext);\r\n\r\n const handleOnRemove = (id: string, event: any) => {\r\n event.preventDefault();\r\n props.removeAdmin(id, contextData.userIdentity);\r\n toast.success(REMOVE_ADMIN_SUCC_MSG);\r\n };\r\n\r\n const handleOnApprove = (id: string, event: any) => {\r\n event.preventDefault();\r\n props.approveAdmin(id, contextData.userIdentity);\r\n toast.success(APPROVE_ADMIN_SUCC_MSG);\r\n };\r\n\r\n const data = useMemo(\r\n () =>\r\n props?.admins?.map((x: any, i: any) => {\r\n return {\r\n id: x.id,\r\n email: x.email,\r\n role: x.role,\r\n };\r\n }),\r\n [props?.admins]\r\n );\r\n\r\n const columns = useMemo(\r\n () => [\r\n {\r\n Header: 'Email',\r\n accessor: 'email',\r\n },\r\n ],\r\n []\r\n );\r\n\r\n const {\r\n getTableProps,\r\n getTableBodyProps,\r\n headerGroups, // columns Header\r\n rows, // render data based on accessor\r\n // @ts-ignore\r\n page,\r\n prepareRow,\r\n // @ts-ignore\r\n visibleColumns,\r\n // @ts-ignore\r\n state,\r\n // @ts-ignore\r\n setGlobalFilter,\r\n } = useTable(\r\n {\r\n // @ts-ignore\r\n columns,\r\n data,\r\n },\r\n useGlobalFilter,\r\n usePagination\r\n );\r\n // @ts-ignore\r\n const { globalFilter, pageSize, pageIndex } = state;\r\n\r\n return (\r\n <>\r\n <h4\r\n style={{\r\n textAlign: 'center',\r\n textDecoration: 'underline',\r\n margin: '5rem auto 2.5rem auto',\r\n }}\r\n >\r\n ADMINS\r\n </h4>\r\n <Table {...getTableProps()} striped bordered hover>\r\n <thead>\r\n {headerGroups.map((headerGroup) => (\r\n <tr {...headerGroup.getHeaderGroupProps()}>\r\n {headerGroup.headers.map((col) => (\r\n <th {...col.getHeaderProps()}>{col.render('Header')}</th>\r\n ))}\r\n </tr>\r\n ))}\r\n <tr>\r\n <th colSpan={visibleColumns.length} style={{ textAlign: 'left' }}>\r\n <GlobalFilter filter={globalFilter} setFilter={setGlobalFilter} />\r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody {...getTableBodyProps()}>\r\n {page.map((row: any) => {\r\n prepareRow(row);\r\n return (\r\n <tr {...row.getRowProps()}>\r\n {row.cells.map((cell: any) => {\r\n return (\r\n <td {...cell.getCellProps()}>{cell.render('Cell')}</td>\r\n );\r\n })}\r\n <>\r\n {props.admins\r\n .find((a) => a.id === row.original.id)\r\n ?.role.toUpperCase() === Roles.Member && (\r\n <td>\r\n <Button\r\n variant=\"success\"\r\n onClick={(e: any) =>\r\n handleOnApprove(row.original.id, e)\r\n }\r\n >\r\n APPROVE\r\n </Button>\r\n </td>\r\n )}\r\n <td>\r\n <ConfirmDenyModal\r\n {...{\r\n targetId: row.original.id,\r\n target: 'admin',\r\n params: `email - ${\r\n props.admins.find(\r\n (a: User) => a.id === row.original.id\r\n )?.email\r\n }`,\r\n handleRemove: handleOnRemove,\r\n }}\r\n />\r\n {/* <Button\r\n variant=\"danger\"\r\n onClick={(e: any) => handleOnRemove(row.original.id, e)}\r\n >\r\n REMOVE\r\n </Button> */}\r\n </td>\r\n </>\r\n </tr>\r\n );\r\n })}\r\n </tbody>\r\n </Table>\r\n </>\r\n );\r\n}\r\n","import React from 'react';\r\nimport { Form } from 'react-bootstrap';\r\nimport EupatiAllAdminsGrid from '../../../../common/static/admins-grid';\r\nimport EupatiLoader from '../../../../common/static/loading-animation/loader';\r\nimport { State } from '../model';\r\nimport '../style.scss';\r\n\r\ntype OwnProps = {};\r\n\r\nexport type DispatchProps = {\r\n setAdminsData: () => void;\r\n removeAdminData: (id: string, ownerId: string) => void;\r\n approveAdmin: (id: string, ownerId: string) => void;\r\n};\r\n\r\ntype Props = State & DispatchProps & OwnProps;\r\n\r\ntype OwnState = {};\r\n\r\nconst HtmlToReactParser = require('html-to-react').Parser;\r\nexport default class ComponentRoot extends React.Component<Props, OwnState> {\r\n componentDidMount() {\r\n this.props.setAdminsData();\r\n }\r\n\r\n render() {\r\n let mainComp: any;\r\n\r\n let loadComp = (\r\n <div className=\"loader-wrapper\">\r\n <EupatiLoader />\r\n </div>\r\n );\r\n\r\n if (this.props.isAdminsLoading) {\r\n mainComp = loadComp;\r\n } else {\r\n mainComp = (\r\n <Form.Group id=\"all-admins-tbl\" className=\"all-admins-wrapper mb-5\">\r\n <EupatiAllAdminsGrid\r\n {...{\r\n admins: this.props?.admins,\r\n removeAdmin: this.props?.removeAdminData,\r\n approveAdmin: this.props?.approveAdmin,\r\n }}\r\n />\r\n </Form.Group>\r\n );\r\n }\r\n\r\n return <>{mainComp}</>;\r\n }\r\n}\r\n","import {\r\n default as RootComponent,\r\n DispatchProps,\r\n} from '../components/component-root';\r\nimport * as Constants from '../constants';\r\nimport * as Actions from '../actions';\r\nimport { State } from '../model';\r\nimport { connect } from 'react-redux';\r\n\r\nexport function mapStateToProps(globalState: any) {\r\n let name = Constants.NAME;\r\n let pageState = globalState[name] as State;\r\n return pageState;\r\n}\r\n\r\nexport function mapDispatchToProps(dispatch: any) {\r\n return {\r\n setAdminsData: () => dispatch(Actions.getAllAdminsAsync()),\r\n removeAdminData: (id: string, ownerId: string) =>\r\n dispatch(Actions.removeAdminAsync(id, ownerId)),\r\n approveAdmin: (id: string, ownerId: string) =>\r\n dispatch(Actions.approveAdminAsync(id, ownerId)),\r\n } as DispatchProps;\r\n}\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(RootComponent);\r\n","import { User } from \"../../../common/models/main-models\";\r\nimport { State } from \"./model\";\r\nimport * as t from './actionTypes';\r\n\r\nconst initialState: State = {\r\n admins: [],\r\n isAdminsLoading: false\r\n}\r\n\r\nexport default (state = initialState, action: any): State => {\r\n switch (action.type) {\r\n case t.SET_ADMINS_LOADING:\r\n return setAdminsLoading(state, action.payload);\r\n case t.SET_ADMINS:\r\n return setAdmins(state, action.payload);\r\n default:\r\n return state;\r\n }\r\n}\r\n\r\nconst setAdminsLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isAdminsLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setAdmins = (state: State, val: User[]): State => {\r\n let newState = {\r\n ...state,\r\n admins: [...val]\r\n } as State;\r\n\r\n return newState;\r\n}","import * as Actions from './actions';\r\nimport * as Components from './components/index';\r\nimport * as Containers from './containers/index';\r\nimport * as Constants from './constants';\r\nimport Reducer from './reducer';\r\n\r\nexport default {\r\n actions: Actions,\r\n components: Components,\r\n containers: Containers,\r\n constants: Constants,\r\n reducer: Reducer\r\n};\r\n\r\nexport const Root = Containers.ComponentRoot;","// constants.ts\r\n\r\nexport const NAME = 'contentEditor';","import { NAME } from \"./constants\";\r\n\r\nexport const SET_CONTENT_LOADING = `${NAME}/SET_CONTENT_LOADING`;\r\n\r\nexport const SET_CONTENT_RESPONSE = `${NAME}/SET_CONTENT_RESPONSE`;","import { ContentData, ContentResponse } from '../../../common/models/input-models';\r\nimport DataSvc from '../../../common/services/data-svc';\r\nimport * as t from './actionTypes';\r\n\r\nexport const setContentLoading = (isContentLoading: boolean) => ({\r\n type: t.SET_CONTENT_LOADING,\r\n payload: isContentLoading\r\n});\r\n\r\nexport const setContentResponse = (contentResponse: ContentResponse) => ({\r\n type: t.SET_CONTENT_RESPONSE,\r\n payload: { ...contentResponse }\r\n});\r\n\r\nexport const getContentByNameAsync = (name: string) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setContentLoading(true));\r\n DataSvc.utilsSvc.getContent(name).then(\r\n (result: any) => {\r\n dispatch(setContentResponse(result));\r\n dispatch(setContentLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const updateContentAsync = (contentData: ContentData) => {\r\n return (dispatch: any, getState: any) => {\r\n try {\r\n DataSvc.utilsSvc.updateContent(contentData);\r\n }\r\n catch (error) {\r\n console.error(error);\r\n }\r\n }\r\n}","import React, { useRef } from 'react';\r\nimport { Editor } from '@tinymce/tinymce-react';\r\nimport { ContentData } from '../models/input-models';\r\nimport { useHistory } from 'react-router';\r\nimport { toast } from 'react-toastify';\r\nimport { Button } from 'react-bootstrap';\r\n\r\ntype OwnProps = {\r\n content: string; // default state\r\n pageName: string; // privacy or terms\r\n}\r\n\r\nexport type DispatchProps = {\r\n updateContent: (data: ContentData) => void;\r\n}\r\n\r\ntype Props = DispatchProps & OwnProps;\r\n\r\nexport default function TinyMCEditor(props: Props) {\r\n const history = useHistory();\r\n const editorRef = useRef(null);\r\n const submit = () => {\r\n if (editorRef.current) {\r\n props.updateContent({\r\n name: props.pageName,\r\n rawDraftContent: '',\r\n //@ts-ignore\r\n htmlContent: editorRef.current.getContent()\r\n } as ContentData);\r\n toast.success(`You have successfully updated the ${props.pageName.toUpperCase()} content.`);\r\n setTimeout(() => {\r\n history.push(`/${props.pageName.toLowerCase()}`);\r\n }, 200);\r\n }\r\n };\r\n return (\r\n <>\r\n <Editor\r\n //@ts-ignore\r\n onInit={(evt, editor) => (editorRef.current) = editor}\r\n initialValue={props.content}\r\n apiKey=\"gi5vdpb46pw329w18n94luc6ne2yimgpjks785wd387s2qvu\"\r\n init={{\r\n height: 500,\r\n convert_urls: true,\r\n relative_urls: false,\r\n remove_script_host: false,\r\n menubar: 'file edit view insert format tools table',\r\n plugins: [\r\n 'advlist autolink lists link image charmap print preview anchor',\r\n 'searchreplace visualblocks code fullscreen',\r\n 'insertdatetime media table paste code wordcount'\r\n ],\r\n toolbar: 'undo redo | formatselect | ' +\r\n 'bold italic backcolor | alignleft aligncenter ' +\r\n 'alignright alignjustify | bullist numlist outdent indent | accordion |' +\r\n 'removeformat',\r\n setup: function (editor) {\r\n editor.ui.registry.addButton('accordion', {\r\n text: 'Collapsible',\r\n onAction: function (_) {\r\n editor.insertContent(' <details> <summary>CHANGE THE TITLE</summary> <p>CHANGE THE CONTENT</p></details> ');\r\n }\r\n });\r\n },\r\n content_style: 'body {font-family:Helvetica,Arial,sans-serif; font-size:18px }'\r\n }}\r\n />\r\n <div id='editor-btns'>\r\n <Button variant='secondary' onClick={() => history.push(`/${props.pageName.toLowerCase()}`)} >{`BACK TO ${props.pageName.toUpperCase()}`}</Button>\r\n <Button variant='primary' onClick={submit}>SAVE</Button>\r\n </div>\r\n </>\r\n );\r\n}\r\n","import * as React from 'react';\r\nimport EupatiLoader from '../../../../common/static/loading-animation/loader';\r\nimport { State } from '../models';\r\nimport EupatiRichTextEditor from '../../../../common/static/text-editor';\r\nimport { ContentData, ContentResponse } from '../../../../common/models/input-models';\r\nimport { RouteComponentProps } from '@reach/router';\r\nimport { History } from 'history';\r\nimport \"react-draft-wysiwyg/dist/react-draft-wysiwyg.css\";\r\nimport TinyMCEditor from '../../../../common/static/tinymce-editor';\r\n\r\ntype OwnProps = {\r\n isContentLoading: boolean,\r\n contentResponse: ContentResponse,\r\n history: History\r\n};\r\n\r\nexport type DispatchProps = {\r\n getContent: (name: string) => void;\r\n updateContent: (data: ContentData) => void;\r\n};\r\n\r\ntype Props = State & DispatchProps & OwnProps & RouteComponentProps<{ location: { state: { pageName: string } } }>;\r\n\r\ntype OwnState = {};\r\n\r\n//raw draft content:\r\n//`{\"blocks\": [{\"key\": \"fl66k\",\"text\": \"asdasdasdasd\",\"type\": \"unstyled\",\"depth\": 0,\"inlineStyleRanges\": [],\"entityRanges\": [],\"data\": {}}],\"entityMap\": {}}`,\r\nexport default class ComponentRoot extends React.Component<Props, OwnState> {\r\n\r\n componentDidMount() {\r\n if (this.props.location?.state.pageName !== undefined) {\r\n this.props.getContent(this.props.location?.state.pageName);\r\n }\r\n }\r\n\r\n render() {\r\n\r\n let mainComp: any;\r\n\r\n let loadComp = (\r\n <div className='loader-wrapper'>\r\n <EupatiLoader />\r\n </div>\r\n )\r\n\r\n if (this.props.isContentLoading ||\r\n this.props.location?.state.pageName === undefined) {\r\n mainComp = loadComp;\r\n }\r\n else {\r\n mainComp = (\r\n // <EupatiRichTextEditor\r\n // {...{\r\n // pageName: this.props?.location?.state.pageName !== undefined ? this.props.location?.state.pageName : '',\r\n // content: this.props?.contentResponse?.rawDraftContent !== undefined ? this.props.contentResponse.rawDraftContent : '',\r\n // updateContent: this.props?.updateContent,\r\n // history: this.props.history\r\n // }}\r\n // />\r\n <TinyMCEditor\r\n {...{\r\n pageName: this.props?.location?.state.pageName !== undefined ? this.props.location?.state.pageName : '',\r\n content: this.props?.contentResponse?.htmlContent !== undefined ? this.props.contentResponse.htmlContent : '',\r\n updateContent: this.props?.updateContent\r\n }}\r\n />\r\n )\r\n }\r\n\r\n return (\r\n <>\r\n {mainComp}\r\n </>\r\n )\r\n }\r\n}","import { default as RootComponent, DispatchProps } from '../components/component-root';\r\nimport * as Constants from '../constants';\r\nimport { State } from '../models';\r\nimport * as Actions from '../actions';\r\nimport { ContentData } from '../../../../common/models/input-models';\r\nimport { connect } from 'react-redux';\r\n\r\nexport function mapStateToProps(globalState: any) {\r\n let name = Constants.NAME;\r\n let pageState = globalState[name] as State;\r\n return pageState;\r\n}\r\n\r\nexport function mapDispatchToProps(dispatch: any) {\r\n return {\r\n getContent: (name: string) => dispatch(Actions.getContentByNameAsync(name)),\r\n updateContent: (data: ContentData) => dispatch(Actions.updateContentAsync(data))\r\n } as DispatchProps;\r\n}\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(RootComponent);","import { blankResponse, State } from \"./models\";\r\nimport * as t from './actionTypes';\r\nimport { ContentResponse } from \"../../../common/models/input-models\";\r\n\r\nconst initialState: State = {\r\n isContentLoading: false,\r\n contentResponse: blankResponse\r\n}\r\n\r\nexport default (state = initialState, action: any): State => {\r\n switch (action.type) {\r\n case t.SET_CONTENT_LOADING:\r\n return setContentLoading(state, action.payload);\r\n case t.SET_CONTENT_RESPONSE:\r\n return setContentResponse(state, action.payload);\r\n default:\r\n return state;\r\n }\r\n}\r\n\r\nconst setContentLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isContentLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setContentResponse = (state: State, val: ContentResponse): State => {\r\n let newState = {\r\n ...state,\r\n contentResponse: { ...val }\r\n } as State;\r\n\r\n return newState;\r\n}","// model.js\r\n// This is the model of our module state (e.g. return type of the reducer)\r\n\r\nimport { ContentResponse } from \"../../../common/models/input-models\";\r\n\r\nexport type State = {\r\n isContentLoading: boolean;\r\n contentResponse: ContentResponse;\r\n}\r\n\r\nexport const blankResponse = {\r\n rawDraftContent: '',\r\n htmlContent: ''\r\n} as ContentResponse;","import * as Actions from './actions';\r\nimport * as Components from './components/index';\r\nimport * as Containers from './containers/index';\r\nimport * as Constants from './constants';\r\nimport Reducer from './reducer';\r\n\r\nexport default {\r\n actions: Actions,\r\n components: Components,\r\n containers: Containers,\r\n constants: Constants,\r\n reducer: Reducer\r\n};\r\n\r\nexport const Root = Containers.ComponentRoot;","// constants.ts\r\n\r\nexport const NAME = 'priceCatalog';","import { NAME } from './constants';\r\n\r\nexport const SET_IS_CATALOGS_LOADING = `${NAME}/SET_IS_CATALOGS_LOADING`;\r\n\r\nexport const SET_CATALOGS_DATA = `${NAME}/SET_CATALOGS_DATA`;","import { Messages } from '../../../common/helpers';\r\nimport { CatalogData } from '../../../common/models/input-models';\r\nimport DataSvc from '../../../common/services/data-svc';\r\nimport * as t from './actionTypes';\r\n\r\nexport const setIsCatalogsLoading = (isCatalogsLoading: boolean) => ({\r\n type: t.SET_IS_CATALOGS_LOADING,\r\n payload: isCatalogsLoading\r\n});\r\n\r\nexport const setCatalogsData = (catalogsData: CatalogData[]) => ({\r\n type: t.SET_CATALOGS_DATA,\r\n payload: catalogsData\r\n});\r\n\r\nexport const getCatalogsPricesAsync = () => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setIsCatalogsLoading(true));\r\n DataSvc.utilsSvc.getPriceCatalogs().then(\r\n (result: any) => {\r\n dispatch(setCatalogsData(result));\r\n dispatch(setIsCatalogsLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const updateCatalogsPricesAsync = (data: CatalogData[]) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setIsCatalogsLoading(true));\r\n DataSvc.utilsSvc.updatePriceCatalogs(data).then(\r\n (result: any) => {\r\n dispatch(getCatalogsPricesAsync());\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}","export const CATALOG_TYPES = {\r\n Basic: 'Basic',\r\n TailorMade: 'TailorMade'\r\n};\r\n\r\nexport const CATEGORY_NAMES = {\r\n Researcher: 'ExternalResearcher',\r\n Industry: 'IndustryPartner',\r\n Academia: 'AcademiaPartner'\r\n};\r\n\r\nexport const OPTION_NAMES = {\r\n Network: 'NetworkOption',\r\n Mentorship: 'MentorshipOption'\r\n};\r\n\r\nexport const CONVERTED_NAMES = {\r\n // based on pricing excel spreadsheet\r\n AcademiaPartner: 'EUPATI Partner - Academic',\r\n IndustryPartner: 'EUPATI Partner - Industry',\r\n ExternalResearcher: 'External Researcher',\r\n NetworkOption: 'External Networks Option',\r\n MentorshipOption: 'Mentorship Option',\r\n TailorMadeType: 'Tailor-Made'\r\n}","import * as React from 'react';\r\nimport { Button, Table } from 'react-bootstrap';\r\nimport { CatalogData, CategoryData, OptionData } from '../models/input-models';\r\nimport { CATALOG_TYPES, CATEGORY_NAMES, CONVERTED_NAMES, OPTION_NAMES } from '../../common/helpers/pricing-list';\r\nimport { toast } from 'react-toastify';\r\nimport { SAVED_NEW_PRICES_MSG, INVALID_NUMERIC_INPUT, CANCEL_PRICES_UPDATE } from '../helpers/messages';\r\n\r\ntype OwnProps = {\r\n catalogsData: CatalogData[]\r\n};\r\n\r\nexport type DispatchProps = {\r\n setCatalogsPrices: () => void\r\n updateCatalogsPrices: (data: CatalogData[]) => void;\r\n};\r\n\r\ntype Props = DispatchProps & OwnProps;\r\n\r\nexport default function EupatiPricesGrid(props: Props) {\r\n\r\n const [isEditBtnClicked, setIsEditBtnClicked] = React.useState<boolean>(false);\r\n const [tempData, setTempData] = React.useState<CatalogData[]>([...props.catalogsData]);\r\n\r\n function onEditRowHandler(e: any) {\r\n e.preventDefault();\r\n setIsEditBtnClicked(true);\r\n }\r\n\r\n function onCancelOperationHandler(e: any) {\r\n e.preventDefault();\r\n toast.info(CANCEL_PRICES_UPDATE);\r\n setTimeout(() => {\r\n setIsEditBtnClicked(false);\r\n props.setCatalogsPrices();\r\n }, 100);\r\n }\r\n\r\n function onChangeBasePriceHandler(e: any, val: any, categoryIndex: number, catalogIndex: number) {\r\n e.preventDefault();\r\n if (isNaN(val.basePrice)) { return toast.error(INVALID_NUMERIC_INPUT); }\r\n const updatedData = Object.assign(tempData[catalogIndex].categoryOptionsData[categoryIndex], val);\r\n Object.assign(tempData[catalogIndex].categoryOptionsData[categoryIndex], updatedData);\r\n setTempData([...tempData]);\r\n }\r\n\r\n function onChangeOptionsPriceHandler(e: any, val: any, catalogIndex: number, categoryIndex: number, optionIndex: number) {\r\n e.preventDefault();\r\n if (isNaN(val.price)) { return toast.error(INVALID_NUMERIC_INPUT); }\r\n const updatedData = Object.assign(tempData[catalogIndex].categoryOptionsData[categoryIndex].additionalOptionsData[optionIndex], val);\r\n Object.assign(tempData[catalogIndex].categoryOptionsData[categoryIndex].additionalOptionsData[optionIndex], updatedData);\r\n setTempData([...tempData]);\r\n }\r\n\r\n function onSaveStateHandler(e: any) {\r\n e.preventDefault();\r\n toast.success(SAVED_NEW_PRICES_MSG);\r\n props.updateCatalogsPrices(tempData);\r\n setIsEditBtnClicked(false);\r\n }\r\n\r\n function formatNumber(num: number) {\r\n return (Math.round(num * 100) / 100).toFixed(2);\r\n }\r\n\r\n function convertCategoriesNames(name: string) {\r\n switch (name) {\r\n case CATEGORY_NAMES.Academia:\r\n return `${CONVERTED_NAMES.AcademiaPartner}`\r\n case CATEGORY_NAMES.Industry:\r\n return `${CONVERTED_NAMES.IndustryPartner}`\r\n case CATEGORY_NAMES.Researcher:\r\n return `${CONVERTED_NAMES.ExternalResearcher}`\r\n default:\r\n return ''\r\n }\r\n }\r\n\r\n function convertOptionsNames(category: string, name: string) {\r\n switch (name) {\r\n case OPTION_NAMES.Network:\r\n return `${category.concat(` with ${CONVERTED_NAMES.NetworkOption}`)}`\r\n case OPTION_NAMES.Mentorship:\r\n return `${category.concat(` with ${CONVERTED_NAMES.MentorshipOption}`)}`\r\n default:\r\n return ''\r\n }\r\n }\r\n\r\n function convertCatalogTypesNames(name: string) {\r\n switch (name) {\r\n case CATALOG_TYPES.Basic:\r\n return `${CATALOG_TYPES.Basic}`\r\n case CATALOG_TYPES.TailorMade:\r\n return `${CONVERTED_NAMES.TailorMadeType}`\r\n default:\r\n return ''\r\n }\r\n }\r\n\r\n return (\r\n <>\r\n <h4 style={{ textAlign: 'center', textDecoration: 'underline', margin: '5rem auto auto auto' }} >PRICING DASHBOARD</h4>\r\n <div style={isEditBtnClicked === false ? { display: 'flex', justifyContent: 'center', alignItems: 'center' } : { display: 'flex', justifyContent: 'space-evenly', alignItems: 'center' }}>\r\n {isEditBtnClicked === true ? (\r\n <Button onClick={onCancelOperationHandler}>Exit</Button>\r\n ) : (\r\n <Button onClick={onEditRowHandler}>Edit</Button>\r\n )}\r\n <Button onClick={onSaveStateHandler} style={isEditBtnClicked === false ? { display: 'none' } : { display: 'block' }} >Save</Button>\r\n </div>\r\n <Table striped bordered hover>\r\n <thead>\r\n <tr>\r\n <th>Type</th>\r\n <th>Category</th>\r\n <th>Price</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n {tempData.map((data: CatalogData, catalogIndex: number) => {\r\n return (\r\n <React.Fragment key={catalogIndex + 'a'}>\r\n <tr style={{ fontWeight: 'bolder', textDecoration: 'underline', backgroundColor: '#113D7C', color: '#fff' }}>\r\n <td>\r\n {`${convertCatalogTypesNames(data.type)}`}\r\n </td>\r\n <td></td>\r\n <td></td>\r\n </tr>\r\n <React.Fragment key={catalogIndex + 'b'}>\r\n {data.categoryOptionsData.map((category: CategoryData, categoryIndex: number) => {\r\n return (\r\n <React.Fragment key={categoryIndex + 'c'}>\r\n <tr>\r\n <td></td>\r\n <td>\r\n {`${convertCategoriesNames(category.name)}`}\r\n </td>\r\n {isEditBtnClicked &&\r\n <td>\r\n <input type='text' value={category.basePrice} onChange={(e: any) => onChangeBasePriceHandler(e, { basePrice: parseFloat(e.target.value) }, categoryIndex, catalogIndex)} />\r\n </td>\r\n }\r\n {!isEditBtnClicked &&\r\n <td>\r\n {formatNumber(category.basePrice)}\r\n </td>\r\n }\r\n </tr>\r\n {\r\n category.additionalOptionsData.map((option: OptionData, optionIndex: number) => {\r\n return (\r\n <React.Fragment key={optionIndex + 'd'}>\r\n <tr>\r\n <td></td>\r\n <td>\r\n {convertOptionsNames(convertCategoriesNames(category.name), option.name)}\r\n </td>\r\n {isEditBtnClicked &&\r\n <td>\r\n <input type='text' value={option.price} onChange={(e: any) => onChangeOptionsPriceHandler(e, { price: parseFloat(e.target.value) }, catalogIndex, categoryIndex, optionIndex)} />\r\n </td>\r\n }\r\n {!isEditBtnClicked &&\r\n <td>\r\n {formatNumber(option.price)}\r\n </td>\r\n }\r\n </tr>\r\n </React.Fragment>\r\n )\r\n })\r\n }\r\n {category.additionalOptionsData.length > 0 &&\r\n <tr style={{ fontWeight: 'bold', backgroundColor: '#F0B72F' }}>\r\n <td></td>\r\n <td>\r\n {`${convertCategoriesNames(category.name)} ${(category.additionalOptionsData.map(x => convertOptionsNames('', x.name)).join(' and ')).trim()}`}\r\n </td>\r\n <td>\r\n {formatNumber(category.totalPrice)}\r\n </td>\r\n </tr>\r\n }\r\n </React.Fragment>\r\n )\r\n })}\r\n </React.Fragment>\r\n </React.Fragment>\r\n )\r\n })}\r\n </tbody>\r\n </Table>\r\n </>\r\n );\r\n}\r\n","import * as React from 'react';\r\nimport { Form } from 'react-bootstrap';\r\nimport { CatalogData } from '../../../../common/models/input-models';\r\nimport EupatiLoader from '../../../../common/static/loading-animation/loader';\r\nimport EupatiPricesGrid from '../../../../common/static/prices-grid';\r\nimport { State } from '../model';\r\nimport '../style.scss';\r\n\r\ntype OwnProps = {\r\n isCatalogsLoading: boolean;\r\n catalogsData: CatalogData[]\r\n};\r\n\r\nexport type DispatchProps = {\r\n setCatalogsPrices: () => void;\r\n updateCatalogsPrices: (data: CatalogData[]) => void;\r\n};\r\n\r\ntype Props = State & DispatchProps & OwnProps;\r\n\r\ntype OwnState = {};\r\n\r\nexport default class ComponentRoot extends React.Component<Props, OwnState> {\r\n\r\n componentDidMount() {\r\n this.props.setCatalogsPrices();\r\n }\r\n\r\n render() {\r\n\r\n let mainComp: any;\r\n\r\n let loadComp = (\r\n <div className='loader-wrapper'>\r\n <EupatiLoader />\r\n </div>\r\n )\r\n\r\n if (this.props.isCatalogsLoading) {\r\n mainComp = loadComp;\r\n }\r\n else {\r\n mainComp = (\r\n <Form.Group id='price-catalog-tbl' className='price-catalog-wrapper mb-5'>\r\n <EupatiPricesGrid\r\n {...{\r\n catalogsData: this.props.catalogsData,\r\n setCatalogsPrices: this.props.setCatalogsPrices,\r\n updateCatalogsPrices: this.props.updateCatalogsPrices\r\n }}\r\n />\r\n </Form.Group>\r\n )\r\n }\r\n\r\n return (\r\n <>\r\n {mainComp}\r\n </>\r\n )\r\n }\r\n}","import { default as RootComponent, DispatchProps } from '../components/component-root';\r\nimport * as Constants from '../constants';\r\nimport * as Actions from '../actions';\r\nimport { State } from '../model';\r\nimport { connect } from 'react-redux';\r\nimport { CatalogData } from '../../../../common/models/input-models';\r\n\r\nexport function mapStateToProps(globalState: any) {\r\n let name = Constants.NAME;\r\n let pageState = globalState[name] as State;\r\n return pageState;\r\n}\r\n\r\nexport function mapDispatchToProps(dispatch: any) {\r\n return {\r\n setCatalogsPrices: () => dispatch(Actions.getCatalogsPricesAsync()),\r\n updateCatalogsPrices: (data: CatalogData[]) => dispatch(Actions.updateCatalogsPricesAsync(data))\r\n } as DispatchProps;\r\n}\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(RootComponent);","import { State } from \"./model\";\r\nimport * as t from './actionTypes';\r\nimport { CatalogData } from \"../../../common/models/input-models\";\r\n\r\nconst initialState: State = {\r\n isCatalogsLoading: false,\r\n catalogsData: []\r\n}\r\n\r\nexport default (state = initialState, action: any): State => {\r\n switch (action.type) {\r\n case t.SET_IS_CATALOGS_LOADING:\r\n return setIsCatalogsLoading(state, action.payload);\r\n case t.SET_CATALOGS_DATA:\r\n return setCatalogsData(state, action.payload);\r\n default:\r\n return state;\r\n }\r\n}\r\n\r\nconst setIsCatalogsLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isCatalogsLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setCatalogsData = (state: State, val: CatalogData[]): State => {\r\n let newState = {\r\n ...state,\r\n catalogsData: [...val]\r\n } as State;\r\n\r\n return newState;\r\n}","import * as Actions from './actions';\r\nimport * as Components from './components/index';\r\nimport * as Containers from './containers/index';\r\nimport * as Constants from './constants';\r\nimport Reducer from './reducer';\r\n\r\nexport default {\r\n actions: Actions,\r\n components: Components,\r\n containers: Containers,\r\n constants: Constants,\r\n reducer: Reducer\r\n};\r\n\r\nexport const Root = Containers.ComponentRoot;","// constants.ts\r\n\r\nexport const NAME = 'pricingPage';","import { NAME } from \"./constants\";\r\n\r\nexport const SET_PRICING_LOADING = `${NAME}/SET_PRICING_LOADING`;\r\n\r\nexport const SET_PRICING_LOGGED_IN = `${NAME}/SET_PRICING_LOGGED_IN`;\r\n\r\nexport const SET_IS_USER_REAL = `${NAME}/SET_IS_USER_REAL`;\r\n\r\nexport const SET_IS_USER_ADMIN = `${NAME}/SET_IS_USER_ADMIN`;\r\n\r\nexport const SET_CATALOGS_DATA = `${NAME}/SET_CATALOGS_DATA`;","// matching/actions.js\r\n\r\nimport DataSvc from '../../common/services/data-svc';\r\nimport * as t from './actionType';\r\nimport { Res } from '../../common/helpers';\r\nimport { CatalogData } from '../../common/models/input-models';\r\n\r\nexport const setPricingLoading = (isLoading: boolean) => ({\r\n type: t.SET_PRICING_LOADING,\r\n payload: isLoading,\r\n});\r\n\r\nexport const setPricingLoggedInStatus = (isLoggedIn: boolean) => ({\r\n type: t.SET_PRICING_LOGGED_IN,\r\n payload: isLoggedIn\r\n});\r\n\r\nexport const setIsUserReal = (isUserReal: boolean) => ({\r\n type: t.SET_IS_USER_REAL,\r\n payload: isUserReal\r\n});\r\n\r\nexport const setIsUserAdmin = (isUserAdmin: boolean) => ({\r\n type: t.SET_IS_USER_ADMIN,\r\n payload: isUserAdmin\r\n});\r\n\r\nexport const setCatalogsData = (data: CatalogData[]) => ({\r\n type: t.SET_CATALOGS_DATA,\r\n payload: data\r\n});\r\n\r\nexport const verifyUserTokenAsync = (token: string) => {\r\n return (dispatch: any, getState: any) => {\r\n DataSvc.utilsSvc.verifyUserByRecaptchaToken({ recaptchaToken: token }).then(\r\n (result: any) => {\r\n if (result !== Res.success) {\r\n dispatch(setIsUserReal(false));\r\n }\r\n },\r\n (error) => { console.error(error); }\r\n );\r\n }\r\n}\r\n\r\nexport const getCatalogsPricesDataAsync = () => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setPricingLoading(true));\r\n DataSvc.utilsSvc.getPriceCatalogs().then(\r\n (result: any) => {\r\n dispatch(setCatalogsData(result));\r\n dispatch(setPricingLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}","export default \"\"","import React, { useEffect, useState } from 'react';\r\nimport { Accordion, Button, Card, Form } from 'react-bootstrap';\r\nimport astericsImg from '../../../../images/pricing/asterics.png';\r\nimport { CategoryData } from '../../../common/models/input-models';\r\nimport { faChevronDown, faChevronUp, faCheck } from '@fortawesome/fontawesome-free-solid';\r\nimport { IconProp } from '@fortawesome/fontawesome-svg-core';\r\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\r\nimport { useHistory } from 'react-router';\r\nimport { CATALOG_TYPES } from '../../../common/helpers/pricing-list';\r\nimport { INVALID_PRICING_DATA, INVALID_PAYMENT_METHOD } from '../../../common/helpers/messages';\r\nimport { toast } from 'react-toastify';\r\n\r\ntype OwnProps = {\r\n basicPlanCategories: CategoryData[],\r\n paymentMethods: string[]\r\n};\r\n\r\nexport type DispatchProps = {\r\n returnIcon: (icon: any) => IconProp;\r\n convertCategoriesNames: (name: string) => string;\r\n};\r\n\r\ntype Props = DispatchProps & OwnProps;\r\n\r\ntype SelectedOptionData = {\r\n price: number,\r\n plan: string,\r\n text: string,\r\n index: number,\r\n bgColor: string\r\n}\r\n\r\nconst DEFAULT_COLOR_SELECTED = '#00A4B6';\r\nexport default function BasicPlanComponent(props: Props) {\r\n const history = useHistory();\r\n\r\n const [selectedOption, setSelectedOption] = useState<SelectedOptionData>({ price: -1, plan: CATALOG_TYPES.Basic, text: '', index: -1, bgColor: DEFAULT_COLOR_SELECTED });\r\n const [icon, setIcon] = useState<IconProp>(faChevronDown as IconProp);\r\n const [paymentIcon, setPaymentIcon] = useState<IconProp>(faChevronUp as IconProp);\r\n const [selectedPaymentMethod, setSelectedPaymentMethod] = useState<string>('');\r\n const [defaultPaymentMethod, setDefaultPaymentMethod] = useState<string>('');\r\n\r\n useEffect(() => {\r\n setDefaultPaymentMethod(props.paymentMethods.find(pm => pm.toLowerCase().includes('invoice'))!);//component-root state\r\n }, []);\r\n\r\n function priceChanged(price: number, categoryName: string, categoryIndex: number) {\r\n const updatedState = Object.assign(selectedOption, { price: price, text: categoryName, index: categoryIndex });\r\n setSelectedOption({ ...updatedState });\r\n }\r\n\r\n function toggleIcons() {\r\n if (icon === props.returnIcon(faChevronDown)) {\r\n setIcon(props.returnIcon(faChevronUp));\r\n setPaymentIcon(props.returnIcon(faChevronDown));\r\n }\r\n else {\r\n setIcon(props.returnIcon(faChevronDown));\r\n setPaymentIcon(props.returnIcon(faChevronDown));\r\n }\r\n }\r\n\r\n function updatePaymentMethodOnClick(method: string) {\r\n if (selectedOption.price === -1) {\r\n toast.error(INVALID_PRICING_DATA);\r\n return;\r\n }\r\n setSelectedPaymentMethod(method);\r\n }\r\n\r\n function reverseToggleIcon() {\r\n if (paymentIcon === props.returnIcon(faChevronUp)) {\r\n setPaymentIcon(props.returnIcon(faChevronDown));\r\n setIcon(props.returnIcon(faChevronDown));\r\n }\r\n else {\r\n setPaymentIcon(props.returnIcon(faChevronUp));\r\n setIcon(props.returnIcon(faChevronDown));\r\n }\r\n }\r\n\r\n const selectedOptionStyle = {\r\n backgroundColor: selectedOption.bgColor,\r\n color: '#ffffff'\r\n };\r\n\r\n const submitBtn = (\r\n <div className='pricing-plan-card-submit-button'>\r\n <Button\r\n variant='primary'\r\n type='submit'\r\n className='submit-btn'\r\n onClick={() => {\r\n if (selectedOption.price < 0 || selectedOption.text === '') {\r\n return toast.error(INVALID_PRICING_DATA);\r\n }\r\n else if (selectedPaymentMethod === '') {\r\n return toast.error(INVALID_PAYMENT_METHOD);\r\n }\r\n history.push({\r\n pathname: '/new-project',\r\n state: {\r\n price: selectedOption.price,\r\n plan: selectedOption.plan,\r\n package: props.convertCategoriesNames(selectedOption.text),\r\n paymentMethod: selectedPaymentMethod\r\n }\r\n });\r\n //if they wanna pay via invoice\r\n //redirect directly to new project page\r\n //cos our stripe implementation works only with cards\r\n // switch (selectedPaymentMethod === defaultPaymentMethod) {\r\n // case true:\r\n // history.push({\r\n // pathname: '/new-project',\r\n // state: {\r\n // price: selectedOption.price,\r\n // plan: selectedOption.plan,\r\n // package: props.convertCategoriesNames(selectedOption.text),\r\n // paymentMethod: selectedPaymentMethod\r\n // }\r\n // });\r\n // break;\r\n // default:\r\n // history.push({\r\n // pathname: '/payment',\r\n // state: {\r\n // price: selectedOption.price,\r\n // plan: selectedOption.plan,\r\n // package: props.convertCategoriesNames(selectedOption.text),\r\n // paymentMethod: selectedPaymentMethod\r\n // }\r\n // });\r\n // break;\r\n // }\r\n }}\r\n >\r\n Submit Your Request\r\n </Button>\r\n </div >\r\n );\r\n\r\n const pricingCard = (\r\n <Card>\r\n <Card.Header style={{ marginBottom: '0.5rem', borderRadius: '4px' }}>\r\n <Accordion.Toggle as={Button} variant=\"link\" eventKey=\"0\" onClick={toggleIcons}>\r\n Pricing\r\n <FontAwesomeIcon icon={props.returnIcon(icon)} />\r\n </Accordion.Toggle>\r\n\r\n </Card.Header>\r\n <Accordion.Collapse eventKey=\"0\">\r\n <Card.Body>\r\n {props?.basicPlanCategories?.map((category: CategoryData, categoryIndex: number) => {\r\n return (\r\n <Form.Group\r\n key={categoryIndex + 'a'}\r\n style={selectedOption.index === categoryIndex ? { ...selectedOptionStyle } : {}}\r\n onClick={() => priceChanged(category.basePrice, category.name, categoryIndex)}\r\n >\r\n <Form.Label id='cat-price'>{`€\t${category.basePrice}`}</Form.Label>\r\n <Form.Label id='cat-name' >{props.convertCategoriesNames(category.name)}</Form.Label>\r\n </Form.Group>\r\n )\r\n })}\r\n </Card.Body>\r\n </Accordion.Collapse>\r\n </Card>\r\n );\r\n\r\n const paymentOptions = (\r\n <>\r\n {selectedOption.price === 0 ? (\r\n <Form.Group\r\n key={69420 + 'b'}\r\n >\r\n <div\r\n className='payments-wrapper'\r\n style={selectedPaymentMethod === defaultPaymentMethod ? { ...selectedOptionStyle } : {}}\r\n onClick={() => updatePaymentMethodOnClick(defaultPaymentMethod)}\r\n >\r\n <div className='payment-check'>\r\n <FontAwesomeIcon icon={props.returnIcon(faCheck)} style={selectedPaymentMethod === defaultPaymentMethod ? { position: 'relative', top: '0', left: '0', color: '#fff' } : { position: 'relative', top: '0', left: '0' }} />\r\n </div>\r\n <Form.Label id='cat-name'>{defaultPaymentMethod}</Form.Label>\r\n </div>\r\n </Form.Group>\r\n ) : (\r\n <>\r\n {props.paymentMethods.map((method: string, methodIndex: number) => {\r\n return (\r\n <Form.Group\r\n key={methodIndex + 'b'}\r\n //id={`${method.toLowerCase().includes('card') ? 'disabled-option-cursor' : ''}`}\r\n >\r\n <div\r\n className='payments-wrapper'\r\n //id={`${method.toLowerCase().includes('card') ? 'disabled-option-events' : ''}`}\r\n style={selectedPaymentMethod === method ? { ...selectedOptionStyle } : {}}\r\n onClick={() => updatePaymentMethodOnClick(method)}\r\n >\r\n <div className='payment-check'>\r\n <FontAwesomeIcon icon={props.returnIcon(faCheck)} style={selectedPaymentMethod === method ? { position: 'relative', top: '0', left: '0', color: '#fff' } : { position: 'relative', top: '0', left: '0' }} />\r\n </div>\r\n <Form.Label id='cat-name'>{method}</Form.Label>\r\n </div>\r\n </Form.Group>\r\n )\r\n })}\r\n </>\r\n )}\r\n </>\r\n )\r\n\r\n const paymentsCard = (\r\n <Card>\r\n <Card.Header id='payment-card-header' style={{ marginBottom: '0.5rem', borderRadius: '4px' }}>\r\n <Accordion.Toggle as={Button} variant=\"link\" eventKey=\"1\" onClick={reverseToggleIcon}>\r\n Payment method\r\n <FontAwesomeIcon icon={props.returnIcon(paymentIcon)} />\r\n </Accordion.Toggle>\r\n </Card.Header>\r\n <Accordion.Collapse eventKey=\"1\">\r\n <Card.Body style={{ border: '0' }}>\r\n {paymentOptions}\r\n </Card.Body>\r\n </Accordion.Collapse>\r\n </Card>\r\n );\r\n\r\n const submitBasic = (\r\n <>\r\n <Accordion defaultActiveKey=\"0\">\r\n {pricingCard}\r\n {paymentsCard}\r\n </Accordion>\r\n <div className='pricing-plan-card-submit'>\r\n {submitBtn}\r\n <div className='pricing-plan-card-submit-note'>\r\n <img src={astericsImg} className='pricing-plan-card-submit-note-asterics' />\r\n <strong>Over 90% of our requests have been successfully matched.</strong> However, please note that EUPATI cannot guarantee a successful matching result.\r\n </div>\r\n </div>\r\n </>\r\n );\r\n\r\n return <div className='pricing-plan'>\r\n <div className='pricing-plan-card pricing-plan-basic' style={{ paddingTop: '15px' }}>\r\n {selectedOption.text !== '' &&\r\n <div className='d-flex' style={{ minHeight: '1px' }}>\r\n <div className='pricing-plan-card-pricebox'>{'€ ' + selectedOption.price}</div>\r\n <div className='pricing-plan-card-pricetitle'>{props.convertCategoriesNames(selectedOption.text)}</div>\r\n </div>\r\n }\r\n {selectedOption.text === '' &&\r\n <div className='d-flex' style={{ minHeight: '1px' }}>\r\n <div className='pricing-plan-card-plantitle'>Basic Plan</div>\r\n </div>\r\n }\r\n <div className='pricing-plan-card-benefit'>\r\n <div className='pricing-plan-card-benefit-description'>\r\n Are you are looking for a EUPATI Patient Expert and happy to manage the process of selecting the right patient for your project among a pool of matched individuals? Select the basic plan - we can connect you with patient experts corresponding to the requested profile and you can take it from there.\r\n </div>\r\n </div>\r\n <div className='pricing-plan-card-benefit'>\r\n <div className='pricing-plan-card-benefit-title'>\r\n Search\r\n </div>\r\n <div className='pricing-plan-card-benefit-description'>\r\n We will search over 200+ EUPATI Fellows along with our EUPATI Open Classroom Learners to find the right Patient Expert for you.\r\n </div>\r\n </div>\r\n <div className='pricing-plan-card-benefit'>\r\n <div className='pricing-plan-card-benefit-title'>\r\n Match\r\n </div>\r\n <div className='pricing-plan-card-benefit-description'>\r\n We will share your request with our matched Patient Experts.\r\n </div>\r\n </div>\r\n <div className='pricing-plan-card-benefit'>\r\n <div className='pricing-plan-card-benefit-title'>\r\n Connect\r\n </div>\r\n <div className='pricing-plan-card-benefit-description'>\r\n Our interested Patient Experts will contact you directly.\r\n </div>\r\n </div>\r\n <div className='pricing-plan-card-benefit'>\r\n <div className='pricing-plan-card-benefit-title'>\r\n Co-Create!\r\n </div>\r\n <div className='pricing-plan-card-benefit-description'>\r\n You and your matched Patients Experts can start working together straight away.\r\n </div>\r\n </div>\r\n </div>\r\n <div className='pricing-plan-card pricing-plan-basic pricing-plan-card-2'>\r\n {submitBasic}\r\n </div>\r\n </div>;\r\n}","import React, { useEffect, useState } from 'react';\r\nimport { Accordion, Button, Card, Form } from 'react-bootstrap';\r\nimport { CategoryData, OptionData } from '../../../common/models/input-models';\r\nimport astericsImg from '../../../../images/pricing/asterics.png';\r\nimport { faCheck, faChevronDown, faChevronUp, faSquare } from '@fortawesome/fontawesome-free-solid';\r\nimport { IconProp } from '@fortawesome/fontawesome-svg-core';\r\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\r\nimport { CATALOG_TYPES, CATEGORY_NAMES } from '../../../common/helpers/pricing-list';\r\nimport { INVALID_PRICING_DATA, INVALID_PAYMENT_METHOD } from '../../../common/helpers/messages';\r\nimport { useHistory } from 'react-router';\r\nimport { toast } from 'react-toastify';\r\n\r\ntype OwnProps = {\r\n tailorMadePlanCategories: CategoryData[],\r\n paymentMethods: string[]\r\n};\r\n\r\nexport type DispatchProps = {\r\n returnIcon: (icon: any) => IconProp;\r\n convertCategoriesNames: (name: string) => string;\r\n convertOptionsNames: (name: string) => string;\r\n};\r\n\r\ntype Props = DispatchProps & OwnProps;\r\n\r\ntype SelectedOptionData = {\r\n price: number,\r\n text: string[],\r\n plan: string,\r\n index: number,\r\n bgColor: string,\r\n additionals: AdditionalsData[]\r\n}\r\n\r\ntype AdditionalsData = {\r\n name: string,\r\n price: number\r\n}\r\n\r\nconst DEFAULT_COLOR_SELECTED = '#00A4B6';\r\nconst DEFAULT_OPTIONS_MENU = ['Mentorship Option', 'External Networks Option']; // if these ever change blame Tech0\r\nconst SELECT_PRICING_WARNING = 'Please first select pricing option';\r\nexport default function TailorMadeComponent(props: Props) {\r\n const history = useHistory();\r\n\r\n const [selectedOption, setSelectedOption] = useState<SelectedOptionData>({ price: -1, text: [], plan: CATALOG_TYPES.TailorMade, index: -1, bgColor: DEFAULT_COLOR_SELECTED, additionals: [] });\r\n const [icon, setIcon] = useState<IconProp>(faChevronDown as IconProp);\r\n const [paymentIcon, setPaymentIcon] = useState<IconProp>(faChevronUp as IconProp);\r\n const [selectedPaymentMethod, setSelectedPaymentMethod] = useState<string>('');\r\n const [defaultPaymentMethod, setDefaultPaymentMethod] = useState<string>('');\r\n\r\n useEffect(() => {\r\n setDefaultPaymentMethod(props.paymentMethods.find(pm => pm.toLowerCase().includes('invoice'))!);//component-root state\r\n }, []);\r\n\r\n function updateStateOnClick(price: number, categoryName: string, categoryIndex: number) {\r\n // calls only when selecting category (ExternalResearcher, IndustryPartner, AcademiaPartner)\r\n const updatedText = [categoryName];\r\n setSelectedOption({ price: price, text: updatedText, plan: CATALOG_TYPES.TailorMade, index: categoryIndex, additionals: [], bgColor: DEFAULT_COLOR_SELECTED });\r\n }\r\n\r\n function removeItemFromAdditionals(option: AdditionalsData) {\r\n const updatedAdditionals = selectedOption.additionals.filter(x => x.name !== option.name);\r\n const updatedText = selectedOption.text.filter(x => x !== option.name);\r\n setSelectedOption({\r\n price: selectedOption.price -= option.price,\r\n text: updatedText,\r\n plan: CATALOG_TYPES.TailorMade,\r\n index: selectedOption.index,\r\n bgColor: selectedOption.bgColor,\r\n additionals: updatedAdditionals\r\n });\r\n }\r\n\r\n function addItemToAdditionals(option: AdditionalsData) {\r\n const updatedAdditionals = selectedOption.additionals.concat(option);\r\n const updatedText = selectedOption.text.concat(option.name);\r\n setSelectedOption({\r\n price: selectedOption.price += option.price,\r\n text: updatedText,\r\n plan: CATALOG_TYPES.TailorMade,\r\n index: selectedOption.index,\r\n bgColor: selectedOption.bgColor,\r\n additionals: updatedAdditionals\r\n });\r\n }\r\n\r\n function updateAdditionalOptionsOnClick(option: AdditionalsData) {\r\n selectedOption.additionals.some(x => x.name === option.name) ? removeItemFromAdditionals(option) : addItemToAdditionals(option);\r\n }\r\n\r\n function updatePaymentMethodOnClick(method: string) {\r\n if (selectedOption.price === -1) {\r\n toast.error(INVALID_PRICING_DATA);\r\n return;\r\n }\r\n setSelectedPaymentMethod(method);\r\n }\r\n\r\n function toggleIcons() {\r\n /*\r\n down --> open\r\n up --> close\r\n */\r\n if (icon === props.returnIcon(faChevronDown)) {\r\n setIcon(props.returnIcon(faChevronUp));\r\n setPaymentIcon(props.returnIcon(faChevronDown));\r\n }\r\n else {\r\n setIcon(props.returnIcon(faChevronDown));\r\n setPaymentIcon(props.returnIcon(faChevronDown));\r\n }\r\n }\r\n\r\n function reverseToggleIcon() {\r\n if (paymentIcon === props.returnIcon(faChevronUp)) {\r\n setPaymentIcon(props.returnIcon(faChevronDown));\r\n setIcon(props.returnIcon(faChevronDown));\r\n }\r\n else {\r\n setPaymentIcon(props.returnIcon(faChevronUp));\r\n setIcon(props.returnIcon(faChevronDown));\r\n }\r\n }\r\n\r\n function displayCategoryNameWithOptions() {\r\n let result = '';\r\n const categoryName = selectedOption.text.find(x => Object.values(CATEGORY_NAMES).some(name => name.toLowerCase() === x.toLowerCase()));\r\n if (categoryName) {\r\n // \"NetworkOption\"--> \"External Networks Option\" --> \"External Networks\" (convert names based on xlsx and extract 'Option' due to repetitiveness)\r\n const optionNames = selectedOption.text.filter(x => x !== categoryName).map(x => props.convertOptionsNames(x)).map(x => x.replace('Option', '').trim());\r\n // \"External Researcher\" --> \"External Researcher with\" (depends on whether optionNames.length > 0)\r\n result = optionNames.length > 0 ? `${props.convertCategoriesNames(categoryName)} with ` : `${props.convertCategoriesNames(categoryName)}`;\r\n // \"Mentorship\" --> \"Mentorship and External Networks\" (depends on whether optionNames.length > 1)\r\n optionNames.length > 1 ? result += `${optionNames.join(' and ')}` : optionNames.forEach(o => result += `${o}`);\r\n }\r\n\r\n return result.trim();\r\n }\r\n\r\n const selectedOptionStyle = {\r\n backgroundColor: selectedOption.bgColor,\r\n color: '#ffffff'\r\n };\r\n\r\n const submitBtn = (\r\n <div className='pricing-plan-card-submit-button'>\r\n <Button\r\n variant='primary'\r\n type='submit'\r\n className='submit-btn'\r\n onClick={() => {\r\n if (selectedOption.price < 0 || selectedOption.text.length === 0) {\r\n return toast.error(INVALID_PRICING_DATA);\r\n }\r\n else if (selectedPaymentMethod === '') {\r\n return toast.error(INVALID_PAYMENT_METHOD);\r\n }\r\n history.push({\r\n pathname: '/new-project',\r\n state: {\r\n price: selectedOption.price,\r\n plan: selectedOption.plan,\r\n package: displayCategoryNameWithOptions(),\r\n paymentMethod: selectedPaymentMethod\r\n }\r\n });\r\n //if they wanna pay via invoice\r\n //redirect directly to new project page\r\n //cos our stripe implementation works only with cards\r\n // switch (selectedPaymentMethod === defaultPaymentMethod) {\r\n // case true:\r\n // history.push({\r\n // pathname: '/new-project',\r\n // state: {\r\n // price: selectedOption.price,\r\n // plan: selectedOption.plan,\r\n // package: displayCategoryNameWithOptions(),\r\n // paymentMethod: selectedPaymentMethod\r\n // }\r\n // });\r\n // break;\r\n // default:\r\n // history.push({\r\n // pathname: '/payment',\r\n // state: {\r\n // price: selectedOption.price,\r\n // plan: selectedOption.plan,\r\n // package: displayCategoryNameWithOptions(),\r\n // paymentMethod: selectedPaymentMethod\r\n // }\r\n // });\r\n // break;\r\n // }\r\n }}\r\n >\r\n Submit Your Request\r\n </Button>\r\n </div>\r\n );\r\n\r\n const categoriesCard = (\r\n <Card style={{ padding: '34px 26px 0px 26px' }}>\r\n <Card.Header style={{ marginBottom: '0.5rem', borderRadius: '4px' }}>\r\n <Accordion.Toggle as={Button} variant=\"link\" eventKey=\"0\" onClick={toggleIcons}>\r\n Pricing\r\n <FontAwesomeIcon icon={props.returnIcon(icon)} />\r\n </Accordion.Toggle>\r\n\r\n </Card.Header>\r\n <Accordion.Collapse eventKey=\"0\">\r\n <Card.Body>\r\n {props?.tailorMadePlanCategories?.map((category: CategoryData, index: number) => {\r\n return (\r\n <Form.Group\r\n key={index + 'ge'}\r\n style={selectedOption.index === index ? { ...selectedOptionStyle } : {}}\r\n onClick={() => updateStateOnClick(category.basePrice, category.name, index)}\r\n >\r\n <Form.Label id='cat-price'>{`€\t${category.basePrice}`}</Form.Label>\r\n <Form.Label id='cat-name' >{props.convertCategoriesNames(category.name)}</Form.Label>\r\n </Form.Group>\r\n )\r\n })}\r\n </Card.Body>\r\n </Accordion.Collapse>\r\n </Card>\r\n );\r\n\r\n // const optionsCard = (\r\n // <Card>\r\n // <Card.Header style={{ marginBottom: '0.5rem', borderRadius: '4px' }}>\r\n // <Accordion.Toggle as={Button} variant=\"link\" eventKey=\"0\" onClick={toggleIcons}>\r\n // Options\r\n // <FontAwesomeIcon icon={props.returnIcon(icon)} />\r\n // </Accordion.Toggle>\r\n // </Card.Header>\r\n // <Accordion.Collapse eventKey=\"0\">\r\n // <Card.Body>\r\n // {props.tailorMadePlanCategories[selectedOption.index]?.additionalOptionsData.map((option: OptionData, optionIndex: number) => {\r\n // return (\r\n // <Form.Group\r\n // style={selectedOption.additionals.some(x => x.name === option.name) ? { ...selectedOptionStyle } : {}}\r\n // onClick={() => updateAdditionalOptionsOnClick({ name: option.name, price: option.price } as AdditionalsData)}\r\n // >\r\n // <Form.Label id='cat-price'>{`€\t${option.price}`}</Form.Label>\r\n // <Form.Label id='cat-name' >{props.convertOptionsNames(option.name)}</Form.Label>\r\n // </Form.Group>\r\n // )\r\n // })}\r\n // </Card.Body>\r\n // </Accordion.Collapse>\r\n // </Card>\r\n // );\r\n\r\n const optionsBlock = (\r\n <section className='options-section'>\r\n <div className='options-section-title'>\r\n <label>ADDITIONAL OPTIONS:</label>\r\n </div>\r\n <div className='options-section-menu'>\r\n {props.tailorMadePlanCategories[selectedOption.index] === undefined ? (\r\n <React.Fragment key={selectedOption.index + 'a'}>\r\n {DEFAULT_OPTIONS_MENU.map((optionName: string, index: number) => {\r\n return (\r\n <div\r\n key={index + 'ce'}\r\n className='options-section-menu-item'\r\n onClick={() => toast.error(SELECT_PRICING_WARNING)}>\r\n <FontAwesomeIcon icon={props.returnIcon(faSquare)} />\r\n <label>{optionName}</label>\r\n </div>\r\n )\r\n })}\r\n </React.Fragment>\r\n ) : (\r\n <React.Fragment key={selectedOption.index + 'be'}>\r\n {props.tailorMadePlanCategories[selectedOption.index]?.additionalOptionsData.map((option: OptionData, optionIndex: number) => {\r\n return (\r\n <div\r\n key={optionIndex + 'ef'}\r\n className='options-section-menu-item'\r\n onClick={() => updateAdditionalOptionsOnClick({ name: option.name, price: option.price } as AdditionalsData)}\r\n >\r\n <FontAwesomeIcon icon={props.returnIcon(faSquare)} style={selectedOption.additionals.some(x => x.name === option.name) ? { color: 'rgb(0, 164, 182)', backgroundColor: '#fff' } : {}} />\r\n <label>{`${props.convertOptionsNames(option.name)} - €\t${option.price}`}</label>\r\n </div>\r\n )\r\n })}\r\n </React.Fragment>\r\n )}\r\n </div>\r\n </section>\r\n );\r\n\r\n const paymentOptions = (\r\n <>\r\n {selectedOption.price === 0 ? (\r\n <Form.Group\r\n key={69420 + 'b'}\r\n >\r\n <div\r\n className='payments-wrapper'\r\n style={selectedPaymentMethod === defaultPaymentMethod ? { ...selectedOptionStyle } : {}}\r\n onClick={() => updatePaymentMethodOnClick(defaultPaymentMethod)}\r\n >\r\n <div className='payment-check'>\r\n <FontAwesomeIcon icon={props.returnIcon(faCheck)} style={selectedPaymentMethod === defaultPaymentMethod ? { position: 'relative', top: '0', left: '0', color: '#fff' } : { position: 'relative', top: '0', left: '0' }} />\r\n </div>\r\n <Form.Label id='cat-name'>{defaultPaymentMethod}</Form.Label>\r\n </div>\r\n </Form.Group>\r\n ) : (\r\n <>\r\n {props.paymentMethods.map((method: string, methodIndex: number) => {\r\n return (\r\n <Form.Group\r\n key={methodIndex + 'de'}\r\n //id={`${method.toLowerCase().includes('card') ? 'disabled-option-cursor' : ''}`}\r\n >\r\n <div\r\n className='payments-wrapper'\r\n //id={`${method.toLowerCase().includes('card') ? 'disabled-option-events' : ''}`}\r\n style={selectedPaymentMethod === method ? { ...selectedOptionStyle } : {}}\r\n onClick={() => updatePaymentMethodOnClick(method)}\r\n >\r\n <div className='payment-check'>\r\n <FontAwesomeIcon icon={props.returnIcon(faCheck)} style={selectedPaymentMethod === method ? { position: 'relative', top: '0', left: '0', color: '#fff' } : { position: 'relative', top: '0', left: '0' }} />\r\n </div>\r\n <Form.Label id='cat-name' >{method}</Form.Label>\r\n </div>\r\n </Form.Group>\r\n )\r\n })}\r\n </>\r\n )}\r\n </>\r\n )\r\n\r\n const paymentsCard = (\r\n <Card style={{ padding: '16px 26px 34px 26px' }}>\r\n <Card.Header id='payment-card-header' style={{ marginBottom: '0.5rem', borderRadius: '4px' }}>\r\n <Accordion.Toggle as={Button} variant=\"link\" eventKey=\"1\" onClick={reverseToggleIcon}>\r\n Payment method\r\n <FontAwesomeIcon icon={props.returnIcon(paymentIcon)} />\r\n </Accordion.Toggle>\r\n </Card.Header>\r\n <Accordion.Collapse eventKey=\"1\">\r\n <Card.Body style={{ border: '0' }}>\r\n {paymentOptions}\r\n </Card.Body>\r\n </Accordion.Collapse>\r\n </Card>\r\n )\r\n\r\n const submitTailorMade = (\r\n <>\r\n <Accordion id='tailor-made-accordion' defaultActiveKey=\"0\" style={{ height: '100%' }}>\r\n <section>\r\n {categoriesCard}\r\n {paymentsCard}\r\n </section>\r\n {optionsBlock}\r\n </Accordion>\r\n <div className='pricing-plan-card-submit' style={{ margin: '0.1px' }}>\r\n {submitBtn}\r\n <div className='pricing-plan-card-submit-note'>\r\n <img src={astericsImg} className='pricing-plan-card-submit-note-asterics' />\r\n <strong>Over 90% of our requests have been successfully matched.</strong> However, please note that EUPATI cannot guarantee a successful matching result. In the case of an unsuccessful match only the basic fee will be charged.\r\n </div>\r\n </div>\r\n </>\r\n );\r\n\r\n return (\r\n <div className='pricing-plan' key={selectedOption.text.length + 'eh'}>\r\n <div className='pricing-plan-card pricing-plan-tailor-made' style={{ paddingTop: '27px' }}>\r\n {selectedOption.text.length > 0 &&\r\n <div className='d-flex' style={{ minHeight: '1px' }}>\r\n <div className='pricing-plan-card-pricebox'>{'€ ' + selectedOption.price}</div>\r\n <div className='pricing-plan-card-pricetitle'>{displayCategoryNameWithOptions()}</div>\r\n </div>\r\n }\r\n {selectedOption.text.length === 0 &&\r\n <div className='d-flex' style={{ minHeight: '1px' }}>\r\n <div className='pricing-plan-card-plantitle'>Tailor-Made Plan</div>\r\n </div>\r\n }\r\n <div className='pricing-plan-card-benefit'>\r\n <div className='pricing-plan-card-benefit-description'>\r\n Need some extra help? Let us take the hassle out of finding the right patient for you! If you would like some additional help in finding the right Patient Expert for your project, select the Tailor-Made plan. Under this plan, we will use our expert knowledge of our patient database to find the most suitable Patient Expert for you, connecting you solely with the patients who are interested in your project. We can also reduce the burden on you by liaising on any follow up actions with our EUPATI Patient Experts where necessary.\r\n </div>\r\n </div>\r\n <div className='pricing-plan-card-benefit'>\r\n <div className='pricing-plan-card-benefit-title'>\r\n Search\r\n </div>\r\n <div className='pricing-plan-card-benefit-description'>\r\n We will search over 200+ EUPATI Fellows along with our EUPATI Open Classroom Learners to find the right Patient Expert for you.\r\n </div>\r\n </div>\r\n <div className='pricing-plan-card-benefit'>\r\n <div className='pricing-plan-card-benefit-title'>\r\n Match\r\n </div>\r\n <div className='pricing-plan-card-benefit-description'>\r\n We will share your request with our matched Patient Experts.\r\n </div>\r\n </div>\r\n <div className='pricing-plan-card-benefit'>\r\n <div className='pricing-plan-card-benefit-title'>\r\n Share & Connect\r\n </div>\r\n <div className='pricing-plan-card-benefit-description'>\r\n We will share the matched and interested Patient Experts with you.\r\n </div>\r\n </div>\r\n <div className='pricing-plan-card-benefit'>\r\n <div className='pricing-plan-card-benefit-title'>\r\n Co-Create!\r\n </div>\r\n <div className='pricing-plan-card-benefit-description'>\r\n You and your matched Patients Experts can start working together straight away.\r\n </div>\r\n </div>\r\n <div className='pricing-plan-card-benefit'>\r\n <div className='pricing-plan-card-benefit-title'>\r\n Follow Up\r\n </div>\r\n <div className='pricing-plan-card-benefit-description'>\r\n We liaise with you on any follow up where necessary.\r\n </div>\r\n </div>\r\n </div>\r\n <div className='pricing-plan-card pricing-plan-tailor-made pricing-plan-card-2' style={{ padding: '0px' }}>\r\n {submitTailorMade}\r\n </div>\r\n <div className='pricing-plan-card pricing-plan-tailor-made-options'>\r\n <div id='options-icon-plus'>+</div>\r\n <div id='options-title-box'>Additional Options:</div>\r\n <div className='pricing-plan-card-benefit'>\r\n <div className='pricing-plan-card-benefit-title'>\r\n Mentorship\r\n </div>\r\n <div className='pricing-plan-card-benefit-description'>\r\n If you desire, we can provide additional mentorship to your organisation or the Patient Expert where either party has minimal expertise in previous patient engagement projects.\r\n </div>\r\n </div>\r\n <div className='pricing-plan-card-benefit'>\r\n <div className='pricing-plan-card-benefit-title'>\r\n External Networks\r\n </div>\r\n <div className='pricing-plan-card-benefit-description'>\r\n Are you looking to reach beyond EUPATI Expert Patients? If necessary, we can reach out to our external networks, outside the EUPATI Patient Expert Pool, to find the right patient for you.\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n )\r\n}","import React, { Component } from 'react';\r\nimport { Button } from 'react-bootstrap';\r\nimport astericsImg from '../../../../images/pricing/asterics.png';\r\n\r\ntype OwnProps = {};\r\n\r\nexport type DispatchProps = {};\r\n\r\ntype Props = DispatchProps & OwnProps;\r\n\r\ntype OwnState = {};\r\n\r\nexport default class CustomPlanComponent extends Component<Props, OwnState> {\r\n\r\n constructor(props: any) {\r\n super(props);\r\n }\r\n\r\n render() {\r\n\r\n const contactUsBtn = (\r\n <div className='pricing-plan-card-submit-button'>\r\n <Button\r\n variant='primary'\r\n type='submit'\r\n className='submit-btn'\r\n onClick={(e) => {\r\n e.preventDefault();\r\n window.location.href = 'https://eupati.eu/contact/';\r\n }}\r\n >\r\n Contact Us\r\n </Button>\r\n </div>\r\n );\r\n\r\n return (\r\n <div className='pricing-plan' style={{ justifyContent: 'center', alignItems: 'center' }} >\r\n <div className='pricing-plan-card pricing-plan-custom' style={{ display: 'flex', flexDirection: 'column', justifyContent: 'space-between' }}>\r\n <div className='d-flex' style={{ minHeight: '1px' }}>\r\n <div className='pricing-plan-card-pricebox' style={{ flexDirection: 'column', paddingBottom: '10px' }}>20% <span className='discount'>discount</span></div>\r\n <div className='pricing-plan-card-pricetitle'>Based on the number of requests</div>\r\n </div>\r\n <div className='pricing-plan-card-benefit'>\r\n <div className='pricing-plan-card-benefit-title'>\r\n Customised Annual Subscription Plan\r\n </div>\r\n <div className='pricing-plan-card-benefit-description' style={{ lineHeight: '250%' }}>\r\n Would you like to sign up for an annual subscription plan for a certain number of matchmaking requests per year to streamline your internal approval and payments processes? Contact us and we will customise the right matchmaking plan for you.\r\n </div>\r\n </div>\r\n <div className='pricing-plan-card-submit' style={{ backgroundColor: '#fff', display: 'flex', flexDirection: 'column', justifyContent: 'center', padding: '0px', height: 'auto' }}>\r\n {contactUsBtn}\r\n <div className='pricing-plan-card-submit-note' style={{ display: 'none' }}>\r\n <img src={astericsImg} className='pricing-plan-card-submit-note-asterics' />\r\n <strong>Over 90% of our requests have been successfully matched.</strong> However, please note that EUPATI cannot guarantee a successful matching result. In the case of an unsuccessful match only the basic fee will be charged.\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n )\r\n }\r\n}","import * as React from 'react';\r\nimport { Nav, Tab } from 'react-bootstrap';\r\nimport EupatiLoader from '../../../common/static/loading-animation/loader';\r\nimport { State } from '../model';\r\nimport '../style.scss';\r\nimport { GoogleReCaptcha } from 'react-google-recaptcha-v3';\r\nimport BasicPlanComponent from './basic-plan';\r\nimport TailorMadeComponent from './tailor-made-plan';\r\nimport CustomPlanComponent from './custom-plan';\r\nimport { IconProp } from '@fortawesome/fontawesome-svg-core';\r\nimport { CATALOG_TYPES, CATEGORY_NAMES, CONVERTED_NAMES, OPTION_NAMES } from '../../../common/helpers/pricing-list';\r\n\r\ntype OwnProps = {};\r\n\r\nexport type DispatchProps = {\r\n setIsUserReal: (token: string) => void;\r\n setCatalogsPrices: () => void;\r\n};\r\n\r\ntype Props = State & DispatchProps & OwnProps;\r\n\r\ntype OwnState = {\r\n paymentMethods: string[]\r\n};\r\n\r\n//const EMPTY_SUBMIT_WARNING = 'You have to select a Pricing from the menu.';\r\n//const PAYMENT_METHOD_WARNING = 'Please select a Payment method';\r\nexport default class ComponentRoot extends React.Component<Props, OwnState> {\r\n constructor(props: any) {\r\n super(props);\r\n\r\n this.returnIcon = this.returnIcon.bind(this);\r\n this.convertOptionsNames = this.convertOptionsNames.bind(this);\r\n this.convertCategoriesNames = this.convertCategoriesNames.bind(this);\r\n this.returnCategoriesArrayByCatalogType = this.returnCategoriesArrayByCatalogType.bind(this);\r\n\r\n this.state = {\r\n //paymentMethods: ['Pay via Invoice', 'Pay by Credit Card']//'invoice' and 'card' are keywords\r\n paymentMethods: ['Pay via Invoice']\r\n }\r\n }\r\n\r\n componentDidMount() {\r\n this.props.setCatalogsPrices();\r\n }\r\n\r\n convertCategoriesNames(name: string) {\r\n switch (name) {\r\n case CATEGORY_NAMES.Researcher:\r\n return `${CONVERTED_NAMES.ExternalResearcher}`\r\n case CATEGORY_NAMES.Industry:\r\n return `${CONVERTED_NAMES.IndustryPartner}`\r\n case CATEGORY_NAMES.Academia:\r\n return `${CONVERTED_NAMES.AcademiaPartner}`\r\n default:\r\n return ''\r\n }\r\n }\r\n\r\n convertOptionsNames(name: string) {\r\n switch (name) {\r\n case OPTION_NAMES.Network:\r\n return `${CONVERTED_NAMES.NetworkOption}`\r\n case OPTION_NAMES.Mentorship:\r\n return `${CONVERTED_NAMES.MentorshipOption}`\r\n default:\r\n return ''\r\n }\r\n }\r\n\r\n returnIcon(icon: any) {\r\n return icon as IconProp;\r\n }\r\n\r\n returnCategoriesArrayByCatalogType(catalogType: string) {\r\n const priceCatalog = this.props.catalogData.find(x => x.type.toLowerCase() === catalogType);\r\n if (priceCatalog) {\r\n return priceCatalog.categoryOptionsData;\r\n }\r\n\r\n return [];\r\n }\r\n\r\n render() {\r\n\r\n let mainComponent: any;\r\n\r\n let loadingComponent = (\r\n <div className='loader-wrapper'>\r\n <EupatiLoader />\r\n </div>\r\n );\r\n\r\n if (this.props.isLoading) {\r\n mainComponent = loadingComponent;\r\n }\r\n else {\r\n const tabs = (\r\n <div className=\"tabs-nav-wrapper\">\r\n <Nav variant=\"tabs\" className=\"tabs\">\r\n <Nav.Item>\r\n <Nav.Link eventKey='basic'>\r\n Basic\r\n </Nav.Link>\r\n </Nav.Item>\r\n <Nav.Item>\r\n <Nav.Link eventKey='tailor'>\r\n Tailor-Made\r\n </Nav.Link>\r\n </Nav.Item>\r\n <Nav.Item>\r\n <Nav.Link eventKey='custom'>\r\n Custom\r\n </Nav.Link>\r\n </Nav.Item>\r\n </Nav>\r\n </div>\r\n );\r\n\r\n const tabContents = (\r\n <>\r\n <Tab.Pane eventKey='basic'>\r\n <BasicPlanComponent\r\n {...{\r\n returnIcon: this.returnIcon,\r\n paymentMethods: this.state.paymentMethods,\r\n basicPlanCategories: this.returnCategoriesArrayByCatalogType(CATALOG_TYPES.Basic.toLowerCase()),\r\n convertCategoriesNames: this.convertCategoriesNames\r\n }}\r\n />\r\n </Tab.Pane>\r\n\r\n <Tab.Pane eventKey='tailor'>\r\n <TailorMadeComponent\r\n {...{\r\n returnIcon: this.returnIcon,\r\n paymentMethods: this.state.paymentMethods,\r\n convertOptionsNames: this.convertOptionsNames,\r\n convertCategoriesNames: this.convertCategoriesNames,\r\n tailorMadePlanCategories: this.returnCategoriesArrayByCatalogType(CATALOG_TYPES.TailorMade.toLowerCase())\r\n }}\r\n />\r\n </Tab.Pane>\r\n\r\n <Tab.Pane eventKey='custom'>\r\n <CustomPlanComponent />\r\n </Tab.Pane>\r\n </>\r\n );\r\n\r\n mainComponent = (\r\n <>\r\n <GoogleReCaptcha action='homePage' onVerify={token => this.props.setIsUserReal(token)} />\r\n\r\n <section className='pricing-upper-sec'>\r\n <div className='pricing-upper-sec-txt'>\r\n <h5 className='pricing-upper-sec-txt-title mb-4'>Connect Now</h5>\r\n <h5 className='pricing-upper-sec-txt-sub-title'>Would you like to engage a EUPATI Patient Expert in your patient engagement opportunity?</h5>\r\n <p className='pricing-upper-sec-txt-para'>\r\n We have created 3 different packages to suit your needs.\r\n Select the right one for you and we can begin finding the right patient for your project today.\r\n </p>\r\n </div>\r\n </section>\r\n\r\n <section className='pricing-lower-sec'>\r\n <div id='pricing-tabs'>\r\n <Tab.Container\r\n id=\"tabs\"\r\n defaultActiveKey='basic'\r\n >\r\n {tabs}\r\n <Tab.Content>{tabContents}</Tab.Content>\r\n </Tab.Container>\r\n </div>\r\n </section>\r\n </>\r\n );\r\n }\r\n\r\n return (\r\n <>\r\n {mainComponent}\r\n </>\r\n );\r\n }\r\n}","import { default as RootComponent, DispatchProps } from '../components/component-root';\r\nimport * as Constants from '../constants';\r\nimport * as Actions from '../actions';\r\nimport { State } from '../model';\r\nimport { connect } from 'react-redux';\r\n\r\nexport function mapStateToProps(globalState: any) {\r\n let name = Constants.NAME;\r\n let pageState = globalState[name] as State;\r\n return pageState;\r\n}\r\n\r\nexport function mapDispatchToProps(dispatch: any) {\r\n return {\r\n setIsUserReal: (token: string) => dispatch(Actions.verifyUserTokenAsync(token)),\r\n setCatalogsPrices: () => dispatch(Actions.getCatalogsPricesDataAsync())\r\n } as DispatchProps;\r\n}\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(RootComponent);","import { State } from './model';\r\nimport * as t from './actionType'\r\nimport { CatalogData } from '../../common/models/input-models';\r\n\r\nconst initialState: State = {\r\n isLoading: false,\r\n isLoggedIn: false,\r\n isUserReal: true,\r\n catalogData: []\r\n};\r\n\r\nexport default (state = initialState, action: any): State => {\r\n switch (action.type) {\r\n case t.SET_PRICING_LOADING:\r\n return setPricingLoading(state, action.payload);\r\n case t.SET_PRICING_LOGGED_IN:\r\n return setPricingLoggedInStatus(state, action.payload);\r\n case t.SET_IS_USER_REAL:\r\n return setIsUserReal(state, action.payload);\r\n case t.SET_CATALOGS_DATA:\r\n return setCatalogsData(state, action.payload);\r\n default:\r\n return state;\r\n }\r\n};\r\n\r\nconst setPricingLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setPricingLoggedInStatus = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isLoggedIn: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setIsUserReal = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isUserReal: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setCatalogsData = (state: State, val: CatalogData[]): State => {\r\n let newState = {\r\n ...state,\r\n catalogData: [...val]\r\n } as State;\r\n\r\n return newState;\r\n}","import * as Actions from './actions';\r\nimport * as Components from './components/index';\r\nimport * as Containers from './containers/index';\r\nimport * as Constants from './constants';\r\nimport Reducer from './reducer';\r\n\r\nexport default {\r\n actions: Actions,\r\n components: Components,\r\n containers: Containers,\r\n constants: Constants,\r\n reducer: Reducer\r\n};\r\n\r\nexport const Root = Containers.ComponentRoot;","// constants.ts\r\n\r\nexport const NAME = 'contentManagement';","import { NAME } from \"./constants\";\r\n\r\nexport const SET_CONTENT_LOADING = `${NAME}/SET_CONTENT_LOADING`;\r\n\r\nexport const SET_CONTENT_RESPONSE = `${NAME}/SET_CONTENT_RESPONSE`;","import { ContentData, ContentResponse } from '../../../common/models/input-models';\r\nimport DataSvc from '../../../common/services/data-svc';\r\nimport * as t from './actionTypes';\r\n\r\nexport const setContentLoading = (isContentLoading: boolean) => ({\r\n type: t.SET_CONTENT_LOADING,\r\n payload: isContentLoading\r\n});\r\n\r\nexport const setContentResponse = (contentResponse: ContentResponse) => ({\r\n type: t.SET_CONTENT_RESPONSE,\r\n payload: { ...contentResponse }\r\n});\r\n\r\nexport const getContentByNameAsync = (name: string) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setContentLoading(true));\r\n DataSvc.utilsSvc.getContent(name).then(\r\n (result: any) => {\r\n dispatch(setContentResponse(result));\r\n dispatch(setContentLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const updateContentAsync = (contentData: ContentData) => {\r\n return (dispatch: any, getState: any) => {\r\n try {\r\n DataSvc.utilsSvc.updateContent(contentData);\r\n }\r\n catch (error) {\r\n console.error(error);\r\n }\r\n }\r\n}","import * as React from 'react';\r\nimport { Button, Form } from 'react-bootstrap';\r\nimport { RouteComponentProps } from '@reach/router';\r\nimport { ContentResponse } from '../../../../common/models/input-models';\r\nimport ReactDOMServer from 'react-dom/server';\r\nimport EupatiLoader from '../../../../common/static/loading-animation/loader';\r\nimport { useHistory } from 'react-router';\r\nimport '../style.scss';\r\n\r\ntype OwnProps = {\r\n content: ContentResponse,\r\n isContentLoading: boolean,\r\n contentName: string,\r\n isUserAdmin: boolean\r\n};\r\n\r\nexport type DispatchProps = {};\r\n\r\ntype Props = DispatchProps & OwnProps & RouteComponentProps<{ location: { state: { html: string } } }>;\r\n\r\nconst HtmlToReactParser = require('html-to-react').Parser;\r\nexport default function EupatiPrivacyPage(props: Props) {\r\n const history = useHistory();\r\n\r\n const htmlToReactParser = new HtmlToReactParser();\r\n const reactElement = htmlToReactParser.parse(props.content.htmlContent);\r\n const reactHtml = ReactDOMServer.renderToStaticMarkup(reactElement);\r\n\r\n const redirectToEditor = () => {\r\n history.push({\r\n pathname: '/admin/content-editor',\r\n state: { pageName: props.contentName }\r\n });\r\n }\r\n\r\n let mainComp: any;\r\n let loadComp = (\r\n <div className='loader-wrapper'>\r\n <EupatiLoader />\r\n </div>\r\n )\r\n\r\n if (props.isContentLoading) {\r\n mainComp = loadComp;\r\n }\r\n else {\r\n mainComp = (\r\n <div className={`${props.contentName}-content`} dangerouslySetInnerHTML={{ __html: reactHtml }}></div>\r\n );\r\n }\r\n\r\n return (\r\n <>\r\n <Form.Group id={`${props.contentName}`}>\r\n {props.isUserAdmin &&\r\n <div id={`${props.contentName}-btns`}>\r\n <Button variant='primary' onClick={redirectToEditor}>Edit page</Button>\r\n </div>\r\n }\r\n {mainComp}\r\n </Form.Group>\r\n </>\r\n );\r\n}\r\n","import React from \"react\"\r\nimport { ContentData, ContentResponse } from \"../../../../common/models/input-models\";\r\nimport { State } from \"../model\";\r\nimport EupatiContentPage from \"./content\";\r\nimport 'reactjs-popup/dist/index.css';\r\nimport '../style.scss';\r\nimport AuthenticationContext from \"../../../../common/static/auth-context\";\r\n\r\ntype OwnProps = {\r\n isContentLoading: boolean,\r\n contentResponse: ContentResponse\r\n};\r\n\r\nexport type DispatchProps = {\r\n getContent: (name: string) => void;\r\n updateContent: (data: ContentData) => void;\r\n};\r\n\r\ntype Props = State & DispatchProps & OwnProps;\r\n\r\ntype OwnState = {\r\n name: string;\r\n};\r\n\r\nconst CURRENT_PATH = window.location.pathname; // (e.g. \"/privacy\")\r\nexport default class ComponentRoot extends React.Component<Props, OwnState> {\r\n static contextType = AuthenticationContext;\r\n constructor(props: any) {\r\n super(props);\r\n\r\n this.state = {\r\n name: CURRENT_PATH.substring(1) // removes the slash from CURRENT_PATH\r\n }\r\n }\r\n\r\n componentDidMount() {\r\n this.props.getContent(this.state.name);\r\n if (this.context.isUserAdmin === null || this.context.isUserAdmin === undefined) {\r\n this.context.authenticateUser();\r\n }\r\n }\r\n\r\n render() {\r\n return (\r\n <>\r\n <EupatiContentPage\r\n {...{\r\n content: this.props.contentResponse,\r\n isContentLoading: this.props.isContentLoading,\r\n contentName: this.state.name,\r\n isUserAdmin: this.context.isUserAdmin\r\n }}\r\n />\r\n </>\r\n )\r\n }\r\n}","import { default as RootComponent, DispatchProps } from '../components/component-root';\r\nimport * as Constants from '../constants';\r\nimport { State } from '../model';\r\nimport * as Actions from '../actions';\r\nimport { ContentData } from '../../../../common/models/input-models';\r\nimport { connect } from 'react-redux';\r\n\r\nexport function mapStateToProps(globalState: any) {\r\n let name = Constants.NAME;\r\n let pageState = globalState[name] as State;\r\n return pageState;\r\n}\r\n\r\nexport function mapDispatchToProps(dispatch: any) {\r\n return {\r\n getContent: (name: string) => dispatch(Actions.getContentByNameAsync(name)),\r\n updateContent: (data: ContentData) => dispatch(Actions.updateContentAsync(data))\r\n } as DispatchProps;\r\n}\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(RootComponent);","import { blankResponse, State } from \"./model\";\r\nimport * as t from './actionTypes';\r\nimport { ContentResponse } from \"../../../common/models/input-models\";\r\n\r\nconst initialState: State = {\r\n isContentLoading: false,\r\n contentResponse: blankResponse\r\n}\r\n\r\nexport default (state = initialState, action: any): State => {\r\n switch (action.type) {\r\n case t.SET_CONTENT_LOADING:\r\n return setContentLoading(state, action.payload);\r\n case t.SET_CONTENT_RESPONSE:\r\n return setContentResponse(state, action.payload);\r\n default:\r\n return state;\r\n }\r\n}\r\n\r\nconst setContentLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isContentLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setContentResponse = (state: State, val: ContentResponse): State => {\r\n let newState = {\r\n ...state,\r\n contentResponse: { ...val }\r\n } as State;\r\n\r\n return newState;\r\n}","// model.js\r\n// This is the model of our module state (e.g. return type of the reducer)\r\n\r\nimport { ContentResponse } from \"../../../common/models/input-models\";\r\n\r\nexport type State = {\r\n isContentLoading: boolean;\r\n contentResponse: ContentResponse;\r\n}\r\n\r\nexport const blankResponse = {\r\n rawDraftContent: '',\r\n htmlContent: ''\r\n} as ContentResponse;","import * as Actions from './actions';\r\nimport * as Components from './components/index';\r\nimport * as Containers from './containers/index';\r\nimport * as Constants from './constants';\r\nimport Reducer from './reducer';\r\n\r\nexport default {\r\n actions: Actions,\r\n components: Components,\r\n containers: Containers,\r\n constants: Constants,\r\n reducer: Reducer\r\n};\r\n\r\nexport const Root = Containers.ComponentRoot;","export const NAME = 'emailTemplates';","import { NAME } from './constants';\r\n\r\nexport const SET_EMAIL_TEMPLATES_LOADING = `${NAME}/SET_EMAIL_TEMPLATES_LOADING`;\r\n\r\nexport const SET_EMAIL_TEMPLATE_DATA = `${NAME}/SET_EMAIL_TEMPLATE_DATA`;\r\n\r\nexport const SET_SINGLE_EMAIL_TEMPLATE_LOADING = `${NAME}/SET_SINGLE_EMAIL_TEMPLATE_LOADING`;\r\n\r\nexport const SET_SINGLE_EMAIL_TEMPLATE_DATA = `${NAME}/SET_SINGLE_EMAIL_TEMPLATE_DATA`;\r\n\r\nexport const SET_PROJECT_MODEL_PROPS_NAMES = `${NAME}/SET_PROJECT_MODEL_PROPS_NAMES`;\r\n\r\nexport const SET_PATIENT_MODEL_PROPS_NAMES = `${NAME}/SET_PATIENT_MODEL_PROPS_NAMES`;\r\n\r\nexport const SET_TRIGGERS_MENU_OPTIONS = `${NAME}/SET_TRIGGERS_MENU_OPTIONS`;\r\n\r\nexport const SET_TRIGGERS_MENU_OPTIONS_LOADING = `${NAME}/SET_TRIGGERS_MENU_OPTIONS_LOADING`;\r\n\r\nexport const SET_RECEIVERS_MENU_OPTIONS = `${NAME}/SET_RECEIVERS_MENU_OPTIONS`;\r\n\r\nexport const SET_CHOOSEN_RECEIVERS = `${NAME}/SET_CHOOSEN_RECEIVERS`;","import { EmailAutomationTriggersMenu, EmailTemplateData, LookUpOptions, ModelPropsNames } from \"../../../common/models/input-models\";\r\n\r\nexport type State = {\r\n isEmailTemplatesLoading: boolean;\r\n isSingleEmailTemplateLoading: boolean;\r\n emailTemplatesData: EmailTemplateData[];\r\n singleEmailTemplateData: EmailTemplateData;\r\n projectPropsNames: ModelPropsNames[];\r\n patientPropsNames: ModelPropsNames[];\r\n triggersMenuOptions: EmailAutomationTriggersMenu[];\r\n isTriggersMenuOptionsLoading: boolean;\r\n receiversMenuOptions: LookUpOptions[];\r\n choosenReceivers: number[];\r\n};\r\n\r\nexport const emptyTemplate = {\r\n id: '',\r\n name: '',\r\n htmlContent: ''\r\n} as EmailTemplateData;","import { ActionsTemplateData, EmailAutomationTriggersMenu, EmailTemplateData, LookUpOptions, ModelPropsNames } from '../../../common/models/input-models';\r\nimport DataSvc from '../../../common/services/data-svc';\r\nimport * as t from './actionTypes';\r\nimport { emptyTemplate } from './models';\r\n\r\nexport const setIsEmailTemplatesLoading = (isEmailTemplatesLoading: boolean) => ({\r\n type: t.SET_EMAIL_TEMPLATES_LOADING,\r\n payload: isEmailTemplatesLoading\r\n});\r\n\r\nexport const setEmailTemplatesData = (emailTemplatesData: EmailTemplateData[]) => ({\r\n type: t.SET_EMAIL_TEMPLATE_DATA,\r\n payload: [...emailTemplatesData]\r\n});\r\n\r\nexport const setIsSingleEmailTemplateLoading = (isSingleEmailTemplateLoading: boolean) => ({\r\n type: t.SET_SINGLE_EMAIL_TEMPLATE_LOADING,\r\n payload: isSingleEmailTemplateLoading\r\n});\r\n\r\nexport const setSingleEmailTemplateData = (emailTemplateData: EmailTemplateData) => ({\r\n type: t.SET_SINGLE_EMAIL_TEMPLATE_DATA,\r\n payload: { ...emailTemplateData }\r\n});\r\n\r\nexport const setProjectModelPropsNames = (projectModelPropsNames: ModelPropsNames[]) => ({\r\n type: t.SET_PROJECT_MODEL_PROPS_NAMES,\r\n payload: [...projectModelPropsNames]\r\n});\r\n\r\nexport const setPatientModelPropsNames = (patientModelPropsNames: ModelPropsNames[]) => ({\r\n type: t.SET_PATIENT_MODEL_PROPS_NAMES,\r\n payload: [...patientModelPropsNames]\r\n});\r\n\r\nexport const setTriggersMenuOptions = (emailAutomationTriggers: EmailAutomationTriggersMenu[]) => ({\r\n type: t.SET_TRIGGERS_MENU_OPTIONS,\r\n payload: [...emailAutomationTriggers]\r\n});\r\n\r\nexport const setTriggersMenuOptionsLoading = (isTriggersMenuOptionsLoading: boolean) => ({\r\n type: t.SET_TRIGGERS_MENU_OPTIONS_LOADING,\r\n payload: isTriggersMenuOptionsLoading\r\n});\r\n\r\nexport const setReceiversMenuOptions = (receiversMenuOptions: LookUpOptions[]) => ({\r\n type: t.SET_RECEIVERS_MENU_OPTIONS,\r\n payload: [...receiversMenuOptions]\r\n});\r\n\r\nexport const setChoosenReceivers = (choosenReceivers: number[]) => ({\r\n type: t.SET_CHOOSEN_RECEIVERS,\r\n payload: [...choosenReceivers]\r\n});\r\n\r\nexport const setAllEmailTemplatesAsync = () => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setIsEmailTemplatesLoading(true));\r\n DataSvc.utilsSvc.getAllEmailTemplates().then(\r\n (result: any) => {\r\n dispatch(setEmailTemplatesData(result));\r\n dispatch(setIsEmailTemplatesLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n );\r\n };\r\n};\r\n\r\nexport const setEmailTemplateByIdAsync = (id?: string) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setIsSingleEmailTemplateLoading(true));\r\n switch (id) {\r\n case undefined:\r\n dispatch(setSingleEmailTemplateData(emptyTemplate));\r\n dispatch(setIsSingleEmailTemplateLoading(false));\r\n break;\r\n default:\r\n DataSvc.utilsSvc.getEmailTemplate(id).then(\r\n (result: any) => {\r\n dispatch(setSingleEmailTemplateData(result));\r\n dispatch(setIsSingleEmailTemplateLoading(false));\r\n //dispatch(setEmailTriggerTemplateBeneficiariesAsync(id));\r\n },\r\n (error) => { console.error(error); }\r\n );\r\n break;\r\n }\r\n };\r\n};\r\n\r\nexport const createNewEmailTemplateAsync = (emailTemplateData: EmailTemplateData) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setIsSingleEmailTemplateLoading(true));\r\n DataSvc.utilsSvc.addEmailTemplate(emailTemplateData).then(\r\n (result: any) => {\r\n dispatch(setIsSingleEmailTemplateLoading(false));\r\n dispatch(setSingleEmailTemplateData(emptyTemplate));\r\n dispatch(setAllEmailTemplatesAsync());\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n };\r\n};\r\n\r\nexport const updateEmailTemplateDataAsync = (emailTemplateData: EmailTemplateData) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setIsSingleEmailTemplateLoading(true));\r\n DataSvc.utilsSvc.alterEmailTemplateData(emailTemplateData).then(\r\n (result: any) => {\r\n dispatch(setIsSingleEmailTemplateLoading(false));\r\n dispatch(setSingleEmailTemplateData(emptyTemplate));\r\n dispatch(setAllEmailTemplatesAsync());\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n };\r\n};\r\n\r\nexport const removeEmailTemplateDataAsync = (id: string) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setIsSingleEmailTemplateLoading(true));\r\n DataSvc.utilsSvc.getEmailTemplate(id).then(\r\n (result: any) => {\r\n DataSvc.utilsSvc.removeEmailTemplate(result).then(\r\n (result: any) => {\r\n dispatch(setAllEmailTemplatesAsync());\r\n dispatch(setIsSingleEmailTemplateLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n };\r\n};\r\n\r\nexport const setModelsPropsNamesAsync = (id: string) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setIsSingleEmailTemplateLoading(true));\r\n DataSvc.utilsSvc.getClassPropertiesNames({ id: id }).then(\r\n (result: any) => {\r\n const projectProps = result.find((x: any) => x.name === 'project');\r\n dispatch(setProjectModelPropsNames(projectProps.items));\r\n const patientsProps = result.find((x: any) => x.name === 'patient');\r\n dispatch(setPatientModelPropsNames(patientsProps.items));\r\n dispatch(setIsSingleEmailTemplateLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n };\r\n};\r\n\r\nexport const setTriggersMenuOptionsAsync = () => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setTriggersMenuOptionsLoading(true));\r\n DataSvc.utilsSvc.getEmailAutomationTriggers().then(\r\n (result: any) => {\r\n dispatch(setTriggersMenuOptions(result));\r\n dispatch(setTriggersMenuOptionsLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const assignActionsToEmailTemplateAsync = (data: ActionsTemplateData) => {\r\n return (dispatch: any, getState: any) => {\r\n DataSvc.utilsSvc.assignActionsToEmailTemplate(data).then(\r\n () => {\r\n dispatch(setAllEmailTemplatesAsync())\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const misallocateActionsFromEmailTemplateAsync = (data: ActionsTemplateData) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setIsSingleEmailTemplateLoading(true));\r\n DataSvc.utilsSvc.misallocateActionsFromEmailTemplate(data).then(\r\n (result: any) => {\r\n dispatch(setEmailTemplateByIdAsync(data.emailTemplateId));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const setReceiversMenuOptionsAsync = () => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setTriggersMenuOptionsLoading(true));\r\n DataSvc.utilsSvc.getLookUpData().then(\r\n (result: any) => {\r\n dispatch(setReceiversMenuOptions(result.find((x: any) => x.name === \"receiverType\").data));\r\n dispatch(setTriggersMenuOptionsLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const setEmailTriggerTemplateBeneficiariesAsync = (id: string) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setIsSingleEmailTemplateLoading(true));\r\n DataSvc.utilsSvc.getEmailTriggerTemplateBeneficiaries(id).then(\r\n (result: any) => {\r\n dispatch(setChoosenReceivers(result));\r\n dispatch(setIsSingleEmailTemplateLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}","import React, { useRef, useState } from \"react\";\r\nimport { Editor } from \"@tinymce/tinymce-react\";\r\nimport { EmailTemplateData, ModelPropsNames, OptionsData } from \"../models/input-models\";\r\nimport { Button, Form } from \"react-bootstrap\";\r\nimport { toast } from \"react-toastify\";\r\nimport { FILL_ALL_FIELD_ERR_MSG } from \"../helpers/messages\";\r\n\r\ntype OwnProps = {\r\n emailTemplateData: EmailTemplateData;\r\n projectPropsNames: ModelPropsNames[];\r\n patientPropsNames: ModelPropsNames[];\r\n options: OptionsData[];\r\n}\r\n\r\nexport type DispatchProps = {\r\n onBackToAllHandler: () => void;\r\n onSaveTemplateChangesHandler: (templateData: EmailTemplateData) => void;\r\n}\r\n\r\ntype Props = DispatchProps & OwnProps;\r\n\r\nconst randomstring = require(\"randomstring\");\r\nexport default function EmailTemplateEditor(props: Props) {\r\n const editorRef = useRef(null);\r\n const eupatiURL = \"https://connect.eupati.eu/\";\r\n\r\n const [emailTemplateName, setEmailTemplateName] = useState<string>(props.emailTemplateData.name);\r\n const [emailTemplateSubject, setEmailTemplateSubject] = useState<string>(props.emailTemplateData.subject);\r\n\r\n const onSubmit = (e: any) => {\r\n e.preventDefault();\r\n if (editorRef.current) {\r\n const updatedEmailTemplateData = Object.assign(props.emailTemplateData, {\r\n name: emailTemplateName, actions: [],\r\n subject: emailTemplateSubject,\r\n //@ts-ignore\r\n htmlContent: editorRef.current.getContent()\r\n });\r\n if (updatedEmailTemplateData.name === '' ||\r\n updatedEmailTemplateData.subject === '' ||\r\n updatedEmailTemplateData.htmlContent === '') {\r\n return toast.error(FILL_ALL_FIELD_ERR_MSG);\r\n }\r\n props.onSaveTemplateChangesHandler(updatedEmailTemplateData);\r\n }\r\n }\r\n\r\n const onEmailTemplateNameChangeHandler = (e: any) => {\r\n setEmailTemplateName(e.target.value);\r\n }\r\n\r\n const onEmailTemplateSubjectChangeHandler = (e: any) => {\r\n setEmailTemplateSubject(e.target.value);\r\n }\r\n\r\n return (\r\n <Form onSubmit={onSubmit} >\r\n <Form.Group id='email-template-editor-btns' className=\"mb-3\">\r\n <Button\r\n variant='secondary'\r\n id='back-btn'\r\n onClick={() => props.onBackToAllHandler()}\r\n >\r\n BACK\r\n </Button>\r\n <Button\r\n variant='primary'\r\n id='save-btn'\r\n type=\"submit\"\r\n >\r\n SAVE\r\n </Button>\r\n </Form.Group>\r\n <Form.Group className=\"mb-3\">\r\n <Form.Label>Name</Form.Label>\r\n <Form.Control type=\"text\" value={emailTemplateName} placeholder=\"Enter template name...\" onChange={onEmailTemplateNameChangeHandler} />\r\n </Form.Group>\r\n <Form.Group className=\"mb-3\">\r\n <Form.Label>Subject</Form.Label>\r\n <Form.Control type=\"text\" value={emailTemplateSubject} placeholder=\"Enter template subject...\" onChange={onEmailTemplateSubjectChangeHandler} />\r\n </Form.Group>\r\n <Form.Group className=\"mb-3\">\r\n <Form.Label>Content</Form.Label>\r\n <Editor\r\n //@ts-ignore\r\n onInit={(evt, editor) => (editorRef.current) = editor}\r\n initialValue={props.emailTemplateData.htmlContent}\r\n apiKey=\"gi5vdpb46pw329w18n94luc6ne2yimgpjks785wd387s2qvu\"\r\n init={{\r\n height: 500,\r\n convert_urls: true,\r\n relative_urls: false,\r\n remove_script_host: false,\r\n menubar: 'file edit view insert format tools table properties',\r\n plugins: [\r\n 'advlist autolink lists link image charmap print preview anchor',\r\n 'searchreplace visualblocks code fullscreen',\r\n 'insertdatetime media table paste code wordcount'\r\n ],\r\n toolbar: 'undo redo | formatselect | ' +\r\n 'bold italic backcolor | alignleft aligncenter ' +\r\n 'alignright alignjustify | bullist numlist outdent indent |' +\r\n 'removeformat | ptconfirmation | ptrejection | projconfirmation | projrejection',\r\n menu: {\r\n properties: { title: 'Fields', items: 'project patient' }\r\n },\r\n setup: function (editor) {\r\n //toolbar\r\n editor.ui.registry.addButton('ptconfirmation', {\r\n text: 'Patient Confirm',\r\n onAction: function () {\r\n const url = `${eupatiURL}letter-of-confirmation/?uid=##uid##+${randomstring.generate(128)}&pid=##pid##`;\r\n editor.insertContent(`<a href='${url}' target='_blank' style=\"color:#fff; border-radius:41px; border-color:transparent; background-color:#00749F; font-size: 18px; padding:12px 24px; cursor:pointer; margin-top:30px; text-decoration: none;\">Confirm</a>`);\r\n }\r\n });\r\n editor.ui.registry.addButton('ptrejection', {\r\n text: 'Patient Reject',\r\n onAction: function () {\r\n const url = `${eupatiURL}letter-of-rejection/?uid=##uid##+${randomstring.generate(128)}&pid=##pid##`;\r\n editor.insertContent(`<a href='${url}' target='_blank' style=\"color:#fff; border-radius:41px; border-color:transparent; background-color:#A7171A; font-size: 18px; padding:12px 24px; cursor:pointer; margin-top:30px; text-decoration: none;\">Not Interested</a>`);\r\n }\r\n });\r\n editor.ui.registry.addButton('projconfirmation', {\r\n text: 'Project Confirm',\r\n onAction: function () {\r\n const url = `${eupatiURL}letter-of-confirmation/?pid=##pid##+${randomstring.generate(128)}`;\r\n editor.insertContent(`<a href='${url}' target='_blank' style=\"color:#fff; border-radius:41px; border-color:transparent; background-color:#00749F; font-size: 18px; padding:12px 24px; cursor:pointer; margin-top:30px; text-decoration: none;\">Confirm</a>`);\r\n }\r\n });\r\n editor.ui.registry.addButton('projrejection', {\r\n text: 'Project Reject',\r\n onAction: function () {\r\n const url = `${eupatiURL}letter-of-rejection/?pid=##pid##+${randomstring.generate(128)}`;\r\n editor.insertContent(`<a href='${url}' target='_blank' style=\"color:#fff; border-radius:41px; border-color:transparent; background-color:#A7171A; font-size: 18px; padding:12px 24px; cursor:pointer; margin-top:30px; text-decoration: none;\">Not Interested</a>`);\r\n }\r\n });\r\n //menu\r\n editor.ui.registry.addNestedMenuItem('project', {\r\n text: 'Project',\r\n getSubmenuItems: () => {\r\n return props.projectPropsNames.map(x => {\r\n return {\r\n type: x.type,\r\n text: x.text,\r\n onAction: () => {\r\n editor.insertContent(`${x.value}`);\r\n }\r\n }\r\n }) as any;\r\n }\r\n });\r\n editor.ui.registry.addNestedMenuItem('patient', {\r\n text: 'Patient',\r\n getSubmenuItems: () => {\r\n return props.patientPropsNames.map(x => {\r\n return {\r\n type: x.type,\r\n text: x.text,\r\n onAction: () => {\r\n editor.insertContent(`${x.value}`);\r\n }\r\n }\r\n }) as any;\r\n }\r\n });\r\n },\r\n content_style: 'body {font - family:Helvetica,Arial,sans-serif; font-size:18px }'\r\n }}\r\n />\r\n </Form.Group>\r\n </Form>\r\n )\r\n}","import React, { useState } from \"react\";\r\nimport { Button, Form } from \"react-bootstrap\";\r\nimport { toast } from \"react-toastify\";\r\nimport { SUCC_ASSIGN_ACTIONS_TO_TEMPLATE } from \"../helpers/messages\";\r\nimport { ActionsTemplateData, EmailAutomationTriggersMenu, EmailTemplateData, LookUpOptions } from \"../models/input-models\";\r\nimport EupatiDropdown from \"./dropdown\";\r\n\r\ntype OwnProps = {\r\n emailTemplate: EmailTemplateData;\r\n triggersMenuOptions: EmailAutomationTriggersMenu[];\r\n filteredTriggersMenuOptions: EmailAutomationTriggersMenu[];\r\n receiversMenuOptions: LookUpOptions[];\r\n choosenReceivers: number[];\r\n};\r\n\r\nexport type DispatchProps = {\r\n onBackToAllHandler: () => void;\r\n assignActionsToTemplate: (data: ActionsTemplateData) => void;\r\n compare: (a: any, b: any) => number;\r\n misallocateActionsFromEmailTemplate: (data: ActionsTemplateData) => void;\r\n};\r\n\r\ntype Props = DispatchProps & OwnProps;\r\n\r\nexport default function ActionsTemplateMenu(props: Props) {\r\n\r\n const [templateTriggers, setTemplateTriggers] = useState<string[]>(props.emailTemplate?.actions?.length > 0 ? props.emailTemplate?.actions?.map((eta) => eta.name) : []);\r\n //const [currentTrigger, setCurrentTrigger] = useState<EmailAutomationTriggersMenu | undefined>(props.triggersMenuOptions.sort(props.compare).find((o: any) => templateTriggers.some(tt => tt === o.name)))\r\n\r\n const onSubmit = (e: any) => {\r\n e.preventDefault();\r\n toast.success(SUCC_ASSIGN_ACTIONS_TO_TEMPLATE);\r\n props.assignActionsToTemplate({\r\n emailTemplateId: props.emailTemplate.id,\r\n actions: templateTriggers,\r\n receivers: []\r\n } as ActionsTemplateData);\r\n props.onBackToAllHandler();\r\n }\r\n\r\n const onTemplateTriggersChangeHandler = (e: any) => {\r\n //if empty string, remove assigned actions\r\n const val = props.triggersMenuOptions[e.target.value].name;\r\n switch (val) {\r\n case undefined:\r\n setTemplateTriggers([]);\r\n break;\r\n default:\r\n setTemplateTriggers([val]);\r\n break;\r\n }\r\n }\r\n\r\n return (\r\n <Form onSubmit={onSubmit}>\r\n <Form.Group id='template-triggers-btns' className=\"mb-3\">\r\n <Button\r\n variant='secondary'\r\n id='back-btn'\r\n onClick={() => props.onBackToAllHandler()}\r\n >\r\n BACK\r\n </Button>\r\n <Button\r\n variant='primary'\r\n id='save-btn'\r\n type=\"submit\"\r\n >\r\n SAVE\r\n </Button>\r\n </Form.Group>\r\n <Form.Group className=\"mb-3\">\r\n <Form.Label>Email Template Name</Form.Label>\r\n <Form.Control type=\"text\" value={props.emailTemplate.name} placeholder=\"Enter template name...\" disabled={true} />\r\n </Form.Group>\r\n <Form.Group className=\"mb-3\" >\r\n <Form.Label>Available Triggers</Form.Label>\r\n <EupatiDropdown\r\n fieldName=\"actions\"\r\n values={props.triggersMenuOptions.sort(props.compare).map((x: EmailAutomationTriggersMenu, i: number) => { return { id: i, name: x.name } })}\r\n value={props.triggersMenuOptions.sort(props.compare).findIndex((o: any) => templateTriggers.some(tt => tt === o.name))}\r\n errorMsg=\"\"\r\n defaultOptionText=\"No action assigned...\"\r\n onChange={onTemplateTriggersChangeHandler}\r\n />\r\n </Form.Group>\r\n {/* <Form.Group className=\"mb-3\">\r\n <Form.Label>Choosen Receivers</Form.Label>\r\n <EupatiMultiselect\r\n fieldName=\"receivers\"\r\n values={props.receiversMenuOptions}\r\n value={receivers}\r\n errorMsg=''\r\n onChange={(e) => onReceiversChangeHandler(e)}\r\n />\r\n </Form.Group> */}\r\n </Form>\r\n )\r\n}","import React, { useContext, useEffect, useMemo, useState } from \"react\";\r\nimport { Button, Form, Table } from \"react-bootstrap\";\r\nimport { useTable } from \"react-table\";\r\nimport { toast } from \"react-toastify\";\r\nimport { EMAIL_TEMPLATE_CREATED, EMAIL_TEMPLATE_UPDATED } from \"../../../../common/helpers/messages\";\r\nimport { ActionsTemplateData, EmailAutomationTriggerData, EmailAutomationTriggersMenu, EmailTemplateData, LookUpOptions, ModelPropsNames, OptionsData } from \"../../../../common/models/input-models\";\r\nimport AuthenticationContext from \"../../../../common/static/auth-context\";\r\nimport EupatiLoader from \"../../../../common/static/loading-animation/loader\";\r\nimport EmailTemplateEditor from \"../../../../common/static/template-editor\";\r\nimport ActionsTemplateMenu from '../../../../common/static/actions-template-menu';\r\nimport { State } from \"../models\";\r\nimport '../style.scss';\r\nimport ConfirmDenyModal from \"../../../../common/static/confirm-deny-modal\";\r\n\r\ntype OwnProps = {\r\n isEmailTemplatesLoading: boolean;\r\n isSingleEmailTemplateLoading: boolean;\r\n emailTemplatesData: EmailTemplateData[];\r\n singleEmailTemplateData: EmailTemplateData;\r\n projectPropsNames: ModelPropsNames[];\r\n patientPropsNames: ModelPropsNames[];\r\n triggersMenuOptions: EmailAutomationTriggersMenu[];\r\n isTriggersMenuOptionsLoading: boolean;\r\n receiversMenuOptions: LookUpOptions[];\r\n choosenReceivers: number[];\r\n};\r\n\r\nexport type DispatchProps = {\r\n getAllTemplates: () => void;\r\n getSingleTemplate: (id?: string) => void;\r\n createEmailTemplate: (data: EmailTemplateData) => void;\r\n updateEmailTemplate: (data: EmailTemplateData) => void\r\n removeEmailTemplate: (id: string) => void;\r\n getModelsPropsName: (id: string) => void;\r\n getTriggersMenuOptions: () => void;\r\n assignActionsToEmailTemplate: (data: ActionsTemplateData) => void;\r\n getReceiversMenuOptions: () => void;\r\n getEmailTriggerTemplateBeneficiaries: (id: string) => void;\r\n misallocateActionsFromEmailTemplate: (data: ActionsTemplateData) => void;\r\n};\r\n\r\ntype Props = State & DispatchProps & OwnProps;\r\n\r\nconst options = [\r\n { value: 'toResearcher', label: \"Send to researcher\" },\r\n { value: 'toPatient', label: \"Send to patients\" }\r\n] as OptionsData[];\r\n\r\nexport default function EmailTemplates(props: Props) {\r\n const contextData = useContext(AuthenticationContext);\r\n\r\n const [isCreateTemplateClicked, setIsCreateTemplateClicked] = useState<boolean>(false);\r\n const [isEditTemplateClicked, setIsEditTemplateClicked] = useState<boolean>(false);\r\n const [isActionsBtnClicked, setIsActionsBtnClicked] = useState<boolean>(false);\r\n\r\n useEffect(() => {\r\n if (contextData.isUserAdmin === true) {\r\n props.getAllTemplates();\r\n props.getTriggersMenuOptions();\r\n props.getReceiversMenuOptions();\r\n props.getModelsPropsName(contextData.userIdentity);\r\n }\r\n }, []);\r\n\r\n const onCreateNewHandler = () => {\r\n props.getSingleTemplate();//reset to emptyTemplate\r\n setIsCreateTemplateClicked(true);\r\n }\r\n\r\n const onEditTemplateHandler = (id: string) => {\r\n setIsEditTemplateClicked(true);\r\n props.getSingleTemplate(id);\r\n }\r\n\r\n const onBackToAllHandler = () => {\r\n props.getSingleTemplate();//reset to emptyTemplate\r\n setIsCreateTemplateClicked(false);\r\n setIsEditTemplateClicked(false);\r\n setIsActionsBtnClicked(false);\r\n }\r\n\r\n const onAssignActionsHandler = (id: string) => {\r\n props.getSingleTemplate(id);\r\n setIsActionsBtnClicked(true);\r\n }\r\n\r\n const onRemoveTemplateHandler = (id: string) => {\r\n props.removeEmailTemplate(id);\r\n }\r\n\r\n const onSaveTemplateChangesHandler = (emailTemplateData: EmailTemplateData) => {\r\n switch (emailTemplateData.id !== '') {\r\n case true:\r\n toast.success(EMAIL_TEMPLATE_UPDATED);\r\n props.updateEmailTemplate(emailTemplateData);\r\n break;\r\n default:\r\n toast.success(EMAIL_TEMPLATE_CREATED);\r\n props.createEmailTemplate(emailTemplateData);\r\n break;\r\n }\r\n setIsCreateTemplateClicked(false);\r\n setIsEditTemplateClicked(false);\r\n }\r\n\r\n const compare = (a: any, b: any) => {\r\n if (a.name < b.name) {\r\n return -1;\r\n }\r\n if (a.name > b.name) {\r\n return 1;\r\n }\r\n return 0;\r\n }\r\n\r\n const data = useMemo(\r\n () => props.emailTemplatesData?.sort(compare).map((x: any, i: any) => {\r\n return {\r\n id: x.id,\r\n index: i + 1,\r\n name: x.name,\r\n //actions: options.filter((o: OptionsData) => x.actions.split(';').some((a: any) => a === o.value)).map((el: OptionsData) => el.label).join(', '),\r\n content: x.htmlContent,\r\n }\r\n }), [props.emailTemplatesData]\r\n )\r\n\r\n const columns = useMemo(\r\n () => [\r\n {\r\n Header: '#',\r\n accessor: 'index'\r\n },\r\n {\r\n Header: 'Name',\r\n accessor: 'name'\r\n },\r\n // {\r\n // Header: 'Actions',\r\n // accessor: 'actions'\r\n // }\r\n ], []\r\n )\r\n\r\n const {\r\n getTableProps,\r\n getTableBodyProps,\r\n headerGroups,\r\n rows,\r\n prepareRow\r\n } = useTable({\r\n // @ts-ignore\r\n columns,\r\n data,\r\n });\r\n\r\n const loadComp = (\r\n <div className='loader-wrapper'>\r\n <EupatiLoader />\r\n </div>\r\n );\r\n\r\n const emailTemplatesComp = (\r\n <>\r\n <h4 style={{ textAlign: 'center', textDecoration: 'underline' }}>EMAIL TEMPLATES</h4>\r\n <Button variant='primary' id='create-btn' onClick={onCreateNewHandler} >CREATE NEW</Button>\r\n <Table {...getTableProps()} striped bordered hover>\r\n <thead>\r\n {headerGroups.map(headerGroup => (\r\n <tr {...headerGroup.getHeaderGroupProps()}>\r\n {headerGroup.headers.map(col => (\r\n <th {...col.getHeaderProps()}>\r\n {col.render('Header')}\r\n </th>\r\n ))}\r\n </tr>\r\n ))}\r\n </thead>\r\n <tbody {...getTableBodyProps()}>\r\n {rows.map((row: any) => {\r\n prepareRow(row);\r\n return (\r\n <tr {...row.getRowProps()}>\r\n {row.cells.map((cell: any) => {\r\n return (\r\n <td {...cell.getCellProps()}>\r\n {cell.render('Cell')}\r\n </td>\r\n )\r\n })}\r\n <>\r\n <td>\r\n <Button\r\n variant='info'\r\n onClick={(e: any) => onAssignActionsHandler(row.original.id)}\r\n >\r\n ACTIONS\r\n </Button>\r\n </td>\r\n <td>\r\n <Button\r\n variant='warning'\r\n onClick={(e: any) => onEditTemplateHandler(row.original.id)}\r\n >\r\n EDIT\r\n </Button>\r\n </td>\r\n <td>\r\n <ConfirmDenyModal\r\n {...{\r\n targetId: row.original.id,\r\n target: 'email template',\r\n params: `name - ${props.emailTemplatesData.find((etd: EmailTemplateData) => etd.id === row.original.id)?.name}`,\r\n handleRemove: onRemoveTemplateHandler\r\n }}\r\n />\r\n {/* <Button\r\n variant='danger'\r\n onClick={(e: any) => onRemoveTemplateHandler(row.original.id)}\r\n >\r\n REMOVE\r\n </Button> */}\r\n </td>\r\n </>\r\n </tr>\r\n )\r\n })}\r\n </tbody>\r\n </Table>\r\n </>\r\n )\r\n\r\n const emailTemplateEditor = (\r\n <>\r\n <h4 style={{ textAlign: 'center', textDecoration: 'underline' }}>EMAIL TEMPLATE EDITOR</h4>\r\n <EmailTemplateEditor\r\n {...{\r\n emailTemplateData: props.singleEmailTemplateData,\r\n onBackToAllHandler: onBackToAllHandler,\r\n onSaveTemplateChangesHandler: onSaveTemplateChangesHandler,\r\n projectPropsNames: props.projectPropsNames,\r\n patientPropsNames: props.patientPropsNames,\r\n options: options\r\n }}\r\n />\r\n </>\r\n )\r\n\r\n const emailTemplatesActionsComp = (\r\n <>\r\n <h4 style={{ textAlign: 'center', textDecoration: 'underline' }}>ASSIGN TRIGGERS TO TEMPLATE</h4>\r\n <ActionsTemplateMenu\r\n {...{\r\n emailTemplate: props.singleEmailTemplateData,\r\n triggersMenuOptions: props.triggersMenuOptions,\r\n filteredTriggersMenuOptions: props.triggersMenuOptions.filter((tmo: EmailAutomationTriggersMenu) => !props.emailTemplatesData.map((etd: EmailTemplateData) => etd.actions).map((etda: EmailAutomationTriggerData[]) => etda.map((x: EmailAutomationTriggerData) => x.name)[0]).some((val: string) => val === tmo.name)),\r\n onBackToAllHandler: onBackToAllHandler,\r\n assignActionsToTemplate: props.assignActionsToEmailTemplate,\r\n receiversMenuOptions: props.receiversMenuOptions,\r\n choosenReceivers: props.choosenReceivers,\r\n compare: compare,\r\n misallocateActionsFromEmailTemplate: props.misallocateActionsFromEmailTemplate\r\n }}\r\n />\r\n </>\r\n )\r\n\r\n const pageSwitcher = () => {\r\n if (props.isEmailTemplatesLoading || props.isSingleEmailTemplateLoading || props.isTriggersMenuOptionsLoading) {\r\n return loadComp;\r\n }\r\n else if (!isCreateTemplateClicked && !isEditTemplateClicked && !isActionsBtnClicked) {\r\n return emailTemplatesComp//grid\r\n }\r\n else if (isActionsBtnClicked) {\r\n return emailTemplatesActionsComp\r\n }\r\n else {\r\n return emailTemplateEditor\r\n }\r\n }\r\n\r\n return (\r\n <Form.Group className='email-templates-wrapper'>\r\n {pageSwitcher()}\r\n </Form.Group>\r\n )\r\n}","import { default as RootComponent, DispatchProps } from '../components/component-root';\r\nimport * as Constants from '../constants';\r\nimport { State } from '../models';\r\nimport * as Actions from '../actions';\r\nimport { connect } from 'react-redux';\r\nimport { ActionsTemplateData, EmailTemplateData } from '../../../../common/models/input-models';\r\n\r\nexport function mapStateToProps(globalState: any) {\r\n let name = Constants.NAME;\r\n let pageState = globalState[name] as State;\r\n return pageState;\r\n}\r\n\r\nexport function mapDispatchToProps(dispatch: any) {\r\n return {\r\n getAllTemplates: () => dispatch(Actions.setAllEmailTemplatesAsync()),\r\n getSingleTemplate: (id: string) => dispatch(Actions.setEmailTemplateByIdAsync(id)),\r\n createEmailTemplate: (data: EmailTemplateData) => dispatch(Actions.createNewEmailTemplateAsync(data)),\r\n updateEmailTemplate: (data: EmailTemplateData) => dispatch(Actions.updateEmailTemplateDataAsync(data)),\r\n removeEmailTemplate: (id: string) => dispatch(Actions.removeEmailTemplateDataAsync(id)),\r\n getModelsPropsName: (id: string) => dispatch(Actions.setModelsPropsNamesAsync(id)),\r\n getTriggersMenuOptions: () => dispatch(Actions.setTriggersMenuOptionsAsync()),\r\n assignActionsToEmailTemplate: (data: ActionsTemplateData) => dispatch(Actions.assignActionsToEmailTemplateAsync(data)),\r\n getReceiversMenuOptions: () => dispatch(Actions.setReceiversMenuOptionsAsync()),\r\n getEmailTriggerTemplateBeneficiaries: (id: string) => dispatch(Actions.setEmailTriggerTemplateBeneficiariesAsync(id)),\r\n misallocateActionsFromEmailTemplate: (data: ActionsTemplateData) => dispatch(Actions.misallocateActionsFromEmailTemplateAsync(data))\r\n } as DispatchProps;\r\n}\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(RootComponent);","import { emptyTemplate, State } from \"./models\";\r\nimport * as t from './actionTypes';\r\nimport { EmailAutomationTriggersMenu, EmailTemplateData, LookUpOptions, ModelPropsNames } from \"../../../common/models/input-models\";\r\n\r\nconst initialState: State = {\r\n isEmailTemplatesLoading: false,\r\n isSingleEmailTemplateLoading: false,\r\n emailTemplatesData: [],\r\n singleEmailTemplateData: emptyTemplate,\r\n projectPropsNames: [],\r\n patientPropsNames: [],\r\n triggersMenuOptions: [],\r\n isTriggersMenuOptionsLoading: false,\r\n receiversMenuOptions: [],\r\n choosenReceivers: []\r\n};\r\n\r\nexport default (state = initialState, action: any): State => {\r\n switch (action.type) {\r\n case t.SET_EMAIL_TEMPLATES_LOADING:\r\n return setEmailTemplatesLoading(state, action.payload);\r\n case t.SET_EMAIL_TEMPLATE_DATA:\r\n return setEmailTemplatesData(state, action.payload);\r\n case t.SET_SINGLE_EMAIL_TEMPLATE_LOADING:\r\n return setSingleEmailTemplateLoading(state, action.payload);\r\n case t.SET_SINGLE_EMAIL_TEMPLATE_DATA:\r\n return setSingleEmailTemplateData(state, action.payload);\r\n case t.SET_PROJECT_MODEL_PROPS_NAMES:\r\n return setProjectModelPropsNames(state, action.payload);\r\n case t.SET_PATIENT_MODEL_PROPS_NAMES:\r\n return setPatientModelPropsNames(state, action.payload);\r\n case t.SET_TRIGGERS_MENU_OPTIONS:\r\n return setTriggersMenuOptions(state, action.payload);\r\n case t.SET_TRIGGERS_MENU_OPTIONS_LOADING:\r\n return setTriggersMenuOptionsLoading(state, action.payload);\r\n case t.SET_RECEIVERS_MENU_OPTIONS:\r\n return setReceiversMenuOptions(state, action.payload);\r\n case t.SET_CHOOSEN_RECEIVERS:\r\n return setChoosenReceivers(state, action.payload);\r\n default:\r\n return state;\r\n }\r\n};\r\n\r\nconst setEmailTemplatesLoading = (state: State, val: boolean): State => {\r\n const newState = {\r\n ...state,\r\n isEmailTemplatesLoading: val\r\n } as State;\r\n\r\n return newState;\r\n};\r\n\r\nconst setSingleEmailTemplateLoading = (state: State, val: boolean): State => {\r\n const newState = {\r\n ...state,\r\n isSingleEmailTemplateLoading: val\r\n } as State;\r\n\r\n return newState;\r\n};\r\n\r\nconst setEmailTemplatesData = (state: State, val: EmailTemplateData[]): State => {\r\n const newState = {\r\n ...state,\r\n emailTemplatesData: [...val]\r\n } as State;\r\n\r\n return newState;\r\n};\r\n\r\nconst setSingleEmailTemplateData = (state: State, val: EmailTemplateData): State => {\r\n const newState = {\r\n ...state,\r\n singleEmailTemplateData: { ...val }\r\n } as State;\r\n\r\n return newState;\r\n};\r\n\r\nconst setProjectModelPropsNames = (state: State, val: ModelPropsNames[]): State => {\r\n const newState = {\r\n ...state,\r\n projectPropsNames: [...val]\r\n } as State;\r\n\r\n return newState;\r\n};\r\n\r\nconst setPatientModelPropsNames = (state: State, val: ModelPropsNames[]): State => {\r\n const newState = {\r\n ...state,\r\n patientPropsNames: [...val]\r\n } as State;\r\n\r\n return newState;\r\n};\r\n\r\nconst setTriggersMenuOptions = (state: State, val: EmailAutomationTriggersMenu[]): State => {\r\n const newState = {\r\n ...state,\r\n triggersMenuOptions: [...val]\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setTriggersMenuOptionsLoading = (state: State, val: boolean): State => {\r\n const newState = {\r\n ...state,\r\n isTriggersMenuOptionsLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setReceiversMenuOptions = (state: State, val: LookUpOptions[]): State => {\r\n const newState = {\r\n ...state,\r\n receiversMenuOptions: [...val]\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setChoosenReceivers = (state: State, val: number[]): State => {\r\n const newState = {\r\n ...state,\r\n choosenReceivers: [...val]\r\n } as State;\r\n\r\n return newState;\r\n}","import * as Actions from './actions';\r\nimport * as Components from './components/index';\r\nimport * as Containers from './containers/index';\r\nimport * as Constants from './constants';\r\nimport Reducer from './reducer';\r\n\r\nexport default {\r\n actions: Actions,\r\n components: Components,\r\n containers: Containers,\r\n constants: Constants,\r\n reducer: Reducer\r\n};\r\n\r\nexport const Root = Containers.ComponentRoot;","export const NAME = 'emailResponse';","import { NAME } from \"./constants\";\r\n\r\nexport const SET_LOADING = `${NAME}/SET_LOADING`;","import DataSvc from '../../common/services/data-svc';\r\nimport { ChangePatientStatusData, ProjectFeedbackData, ProjectStatusData, SurveyAnswerData } from '../../common/models/input-models';\r\nimport * as t from './actionTypes';\r\n\r\nexport const setLoading = (isLoading: boolean) => ({\r\n type: t.SET_LOADING,\r\n payload: isLoading\r\n});\r\n\r\nexport const changePatientStatusAsync = (data: ChangePatientStatusData) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setLoading(true));\r\n DataSvc.patientSvc.changePatientStatus(data).then(\r\n (result: any) => {\r\n if (result === 'You got me on that one...') {\r\n dispatch(setLoading(false));\r\n }\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const addSurveyAnswerAsync = (data: SurveyAnswerData) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setLoading(true));\r\n DataSvc.patientSvc.addSurveyAnswer(data).then(\r\n (result: any) => {\r\n if (result === 'You are a wizard, Harry...') {\r\n dispatch(setLoading(false));\r\n }\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const changeProjectStatusAsync = (data: ProjectStatusData) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setLoading(true));\r\n DataSvc.projectsSvc.changeProjectStatus(data).then(\r\n (result: any) => {\r\n dispatch(setLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const addProjectFeedbackAsync = (data: ProjectFeedbackData) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setLoading(true));\r\n DataSvc.projectsSvc.addFeedback(data).then(\r\n (result: any) => {\r\n dispatch(setLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}","import React, { useEffect, useState } from \"react\";\r\nimport { ChangePatientStatusData, ProjectFeedbackData, ProjectStatusData, SurveyAnswerData } from \"../../../common/models/input-models\";\r\nimport { State } from \"../model\";\r\nimport confrimImg from '../../../../images/confirm-img.png';\r\nimport declineImg from '../../../../images/decline-img.png';\r\nimport { Button } from \"react-bootstrap\";\r\nimport '../style.scss';\r\nimport { useHistory } from \"react-router\";\r\nimport EupatiLoader from \"../../../common/static/loading-animation/loader\";\r\nimport { toast } from \"react-toastify\";\r\nimport { ANSWER_SUBMIT_SUCC } from \"../../../common/helpers/messages\";\r\nimport { projectStatus, patientStatus } from '../../../common/helpers/status';\r\n\r\ntype OwnProps = {\r\n isLoading: boolean;\r\n};\r\n\r\nexport type DispatchProps = {\r\n changePatientStatus: (data: ChangePatientStatusData) => void;\r\n addSurveyAnswer: (data: SurveyAnswerData) => void;\r\n changeProjectStatus: (data: ProjectStatusData) => void;\r\n addProjectFeedback: (data: ProjectFeedbackData) => void;\r\n};\r\n\r\ntype Props = State & DispatchProps & OwnProps;\r\n\r\nconst CONFRIM_PATH = 'letter-of-confirmation';\r\nconst REJECT_PATH = 'letter-of-rejection';\r\nconst url = window.location.href;\r\nconst regex = /(\\?|\\&)(uid|pid)\\=([a-zA-Z0-9-]+)/gm;\r\nconst DEFAULT_HTML = '<p>The page does not exist!</p>';\r\nexport default function EmailResponsePage(props: Props) {\r\n const history = useHistory();\r\n\r\n const [html, setHtml] = useState<string>(DEFAULT_HTML);\r\n const [text, setText] = useState<string>('');\r\n const [uid, setUID] = useState<string>('');\r\n const [pid, setPID] = useState<string>('');\r\n const [matches, setMatches] = useState<number>(0);\r\n\r\n useEffect(() => {\r\n //match 1: ?uid=e9d034f0-410d-4b52-b6df-d754c942c0ee match 2: &pid=df915d9a-06c8-4af3-981a-b668e2c11db7\r\n //group 1: ? group 1: &\r\n //group 2: uid group 2: pid\r\n //group 3: e9d034f0-410d-4b52-b6df-d754c942c0ee group 3: df915d9a-06c8-4af3-981a-b668e2c11db7\r\n const match = [...url.matchAll(regex)];\r\n setMatches(match.length);\r\n if (match !== null && match.length === 2) {\r\n try {\r\n const patientId = match[0][3];\r\n const projectId = match[1][3];\r\n setUID(patientId); setPID(projectId);\r\n if (url.includes(REJECT_PATH)) {\r\n const data = {\r\n uid: patientId,\r\n pid: projectId,\r\n sid: patientStatus.notInterestedStatusID\r\n } as ChangePatientStatusData;\r\n props.changePatientStatus(data);\r\n setHtml('<p>Thank you for the response.</br>We understand you are busy right now.</br>We will keep you informed on further opportunities.</p>');\r\n }\r\n else if (url.includes(CONFRIM_PATH)) {\r\n const data = {\r\n uid: patientId,\r\n pid: projectId,\r\n sid: patientStatus.confirmedStatusID\r\n } as ChangePatientStatusData;\r\n props.changePatientStatus(data);\r\n setHtml('<p>Thank you for confirming.</br>We will contact you shortly.</p>');\r\n }\r\n } catch (error) {\r\n console.error(error);\r\n }\r\n }\r\n else if (match !== null && match.length === 1) {\r\n try {\r\n if (url.includes(CONFRIM_PATH)) {\r\n const projectId = match[0][3];\r\n setPID(projectId);\r\n const data = {\r\n projectId: projectId,\r\n statusId: projectStatus.inProgressStatusID\r\n } as ProjectStatusData;\r\n props.changeProjectStatus(data);\r\n setHtml('<p>Thank you for confirming.</br>We will contact you shortly.</p>');\r\n }\r\n else if (url.includes(REJECT_PATH)) {\r\n const projectId = match[0][3];\r\n setPID(projectId);\r\n const data = {\r\n projectId: projectId,\r\n statusId: projectStatus.declinedStatusID\r\n } as ProjectStatusData;\r\n props.changeProjectStatus(data);\r\n setHtml('<p>Thank you for the response.</br>Please do not hesitate to contact us, if you need further assistance.</p>');\r\n }\r\n }\r\n catch (error) {\r\n console.error(error);\r\n }\r\n }\r\n }, []);\r\n //patient response\r\n function addPatientSurveyAnswerHandler() {\r\n props.addSurveyAnswer({\r\n uid: uid,\r\n pid: pid,\r\n txt: text\r\n } as SurveyAnswerData);\r\n toast.success(ANSWER_SUBMIT_SUCC);\r\n history.push('/');\r\n }\r\n //researcher response\r\n function addProjectFeedbackHandler() {\r\n props.addProjectFeedback({\r\n projectId: pid,\r\n feedback: text\r\n } as ProjectFeedbackData);\r\n toast.success(ANSWER_SUBMIT_SUCC);\r\n history.push('/');\r\n }\r\n\r\n let mainComp = null;\r\n let loadingComp = (\r\n <div className='loader-wrapper'>\r\n <EupatiLoader />\r\n </div>\r\n );\r\n\r\n if (props.isLoading) {\r\n mainComp = loadingComp;\r\n }\r\n else {\r\n mainComp = (\r\n <div className='mail-response'>\r\n {/* <img src={html === DEFAULT_HTML ? declineImg : confrimImg} alt='confrim' className=\"mail-response-img\" /> */}\r\n <div\r\n className=\"mail-response-text\"\r\n dangerouslySetInnerHTML={{ __html: html }}\r\n style={{ paddingTop: '40px', paddingBottom: '40px' }}\r\n >\r\n </div>\r\n {html !== DEFAULT_HTML &&\r\n <>\r\n <div>\r\n <textarea\r\n rows={10}\r\n cols={50}\r\n placeholder={html.includes('confirming') ?\r\n \"Please tell us why you are fit for this project...\" : \"To help us improve, please give us your feedback...\"\r\n }\r\n value={text}\r\n onChange={(e) => setText(e.target.value)}\r\n />\r\n </div>\r\n <div style={{ width: '100%' }}>\r\n {matches === 2 && (\r\n <Button\r\n className='mail-response-btn'\r\n onClick={addPatientSurveyAnswerHandler}\r\n >\r\n Submit\r\n </Button>\r\n )}\r\n {matches === 1 && (\r\n <Button\r\n className='mail-response-btn'\r\n onClick={addProjectFeedbackHandler}\r\n >\r\n Submit\r\n </Button>\r\n )}\r\n </div>\r\n </>\r\n }\r\n </div>\r\n )\r\n }\r\n\r\n return (\r\n <>\r\n {mainComp}\r\n </>\r\n )\r\n}","import { default as RootComponent, DispatchProps } from '../components/component-root';\r\nimport * as Constants from '../constants';\r\nimport * as Actions from '../actions';\r\nimport { State } from '../model';\r\nimport { connect } from 'react-redux';\r\nimport { ChangePatientStatusData, ProjectFeedbackData, ProjectStatusData, SurveyAnswerData } from '../../../common/models/input-models';\r\n\r\nexport function mapStateToProps(globalState: any) {\r\n let name = Constants.NAME;\r\n let pageState = globalState[name] as State;\r\n return pageState;\r\n}\r\n\r\nexport function mapDispatchToProps(dispatch: any) {\r\n return {\r\n changePatientStatus: (data: ChangePatientStatusData) => dispatch(Actions.changePatientStatusAsync(data)),\r\n addSurveyAnswer: (data: SurveyAnswerData) => dispatch(Actions.addSurveyAnswerAsync(data)),\r\n changeProjectStatus: (data: ProjectStatusData) => dispatch(Actions.changeProjectStatusAsync(data)),\r\n addProjectFeedback: (data: ProjectFeedbackData) => dispatch(Actions.addProjectFeedbackAsync(data))\r\n } as DispatchProps;\r\n}\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(RootComponent);","import { State } from \"./model\";\r\nimport * as t from './actionTypes';\r\n\r\nconst initialState: State = {\r\n isLoading: false\r\n};\r\n\r\nexport default (state = initialState, action: any): State => {\r\n switch (action.type) {\r\n case t.SET_LOADING:\r\n return setLoading(state, action.payload);\r\n default:\r\n return state;\r\n }\r\n};\r\n\r\nconst setLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}","import * as Actions from './actions';\r\nimport * as Components from './components/index';\r\nimport * as Containers from './containers/index';\r\nimport * as Constants from './constants';\r\nimport Reducer from './reducer';\r\n\r\nexport default {\r\n actions: Actions,\r\n components: Components,\r\n containers: Containers,\r\n constants: Constants,\r\n reducer: Reducer\r\n};\r\n\r\nexport const Root = Containers.ComponentRoot;","// constants.ts\r\n\r\nexport const NAME = 'paymentPage';","import { NAME } from \"./constants\";\r\n\r\nexport const SET_PAYMENT_LOADING = `${NAME}/SET_PAYMENT_LOADING`;\r\n\r\nexport const SET_LOOKUP_DATA_LOADING = `${NAME}/SET_LOOKUP_DATA_LOADING`;\r\n\r\nexport const SET_LOOKUP_DATA = `${NAME}/SET_LOOKUP_DATA`;\r\n\r\nexport const SET_PAYMENT_RESPONSE = `${NAME}/SET_PAYMENT_RESPONSE`;\r\n\r\nexport const SET_ALL_COUNTRIES_DATA = `${NAME}/SET_ALL_COUNTRIES_DATA`;\r\n\r\nexport const SET_ALL_COUNTRIES_LOADING = `${NAME}/SET_ALL_COUNTRIES_LOADING`;","// matching/actions.js\r\n\r\nimport { CountriesWithCodeModel, LookUpData, PaymentIntentCreateModel, PaymentIntentResponseModel } from '../../common/models/input-models.js';\r\nimport DataSvc from '../../common/services/data-svc';\r\nimport * as t from './actionType.js';\r\n\r\nexport const setPaymentLoading = (isLoading: boolean) => ({\r\n type: t.SET_PAYMENT_LOADING,\r\n payload: isLoading,\r\n});\r\n\r\nexport const setLookUpDataLoading = (isLoading: boolean) => ({\r\n type: t.SET_LOOKUP_DATA_LOADING,\r\n payload: isLoading\r\n});\r\n\r\nexport const setLookUpData = (data: LookUpData[]) => ({\r\n type: t.SET_LOOKUP_DATA,\r\n payload: [...data]\r\n});\r\n\r\nexport const setPaymentResponse = (model: PaymentIntentResponseModel) => ({\r\n type: t.SET_PAYMENT_RESPONSE,\r\n payload: { ...model }\r\n});\r\n\r\nexport const setAllCountriesData = (model: CountriesWithCodeModel[]) => ({\r\n type: t.SET_ALL_COUNTRIES_DATA,\r\n payload: [...model]\r\n});\r\n\r\nexport const setAllCountriesLoading = (isLoading: boolean) => ({\r\n type: t.SET_ALL_COUNTRIES_LOADING,\r\n payload: isLoading\r\n});\r\n\r\nexport const getLookUpDataAsync = () => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setLookUpDataLoading(true));\r\n DataSvc.utilsSvc.getLookUpData().then(\r\n (result: any) => {\r\n dispatch(setLookUpData(result));\r\n dispatch(setLookUpDataLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n );\r\n };\r\n};\r\n\r\nexport const getAllCountriesAsync = () => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setAllCountriesLoading(true));\r\n DataSvc.utilsSvc.getAllCountries().then(\r\n (result: any) => {\r\n dispatch(setAllCountriesData(result));\r\n dispatch(setAllCountriesLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n )\r\n }\r\n}\r\n\r\nexport const createPaymentIntentAsync = (data: PaymentIntentCreateModel) => {\r\n return (dispatch: any, getState: any) => {\r\n dispatch(setPaymentLoading(true));\r\n DataSvc.paymentSvc.createPaymentIntent(data).then(\r\n (result: any) => {\r\n //TODO: add error handler;\r\n //just to log the error is not enough in this case;\r\n //because we are chargin real money;\r\n //and if it fails for some reason;\r\n //we should be able to display the message to the user;\r\n //endless loading screen after you click \"Pay\" is a big no no imo.\r\n dispatch(setPaymentResponse(result));//clientSecret\r\n dispatch(setPaymentLoading(false));\r\n },\r\n (error) => { console.error(error); }\r\n );\r\n };\r\n};","import React from \"react\"\r\nimport { useHistory } from \"react-router\";\r\n\r\ntype OwnProps = {\r\n message: string;\r\n isFail: boolean;\r\n price?: number;\r\n plan?: string;\r\n package?: string;\r\n paymentMethod?: string;\r\n clientSecret?: string;\r\n}\r\n\r\ntype DispatchProps = {\r\n swapComponents: (shouldSwap: boolean) => void;\r\n startLoading: () => void;\r\n}\r\n\r\ntype Props = OwnProps & DispatchProps;\r\n\r\nexport default function CheckoutResult(props: Props) {\r\n const history = useHistory();\r\n\r\n function redirectTo(pathname: string) {\r\n history.push({\r\n pathname: pathname,\r\n state: {\r\n price: props.price === undefined ? -1 : props.price,\r\n plan: props.plan === undefined ? '' : props.plan,\r\n package: props.package === undefined ? '' : props.package,\r\n paymentMethod: props.paymentMethod === undefined ? '' : props.paymentMethod,\r\n clientSecret: props.clientSecret\r\n }\r\n });\r\n }\r\n\r\n return (\r\n <div style={{ display: 'flex', justifyContent: 'center', alignItems: 'center' }}>\r\n {props.isFail ? (\r\n <div>purchased failed - <span style={{ color: '#bb2124' }} >{props.message}</span>\r\n <button onClick={() => {\r\n props.startLoading();\r\n setTimeout(() => {\r\n props.swapComponents(false)\r\n }, 200);\r\n }}>\r\n Try again\r\n </button>\r\n </div>\r\n ) : (\r\n <div>thanks for the purchase - <span style={{ color: '#22bb33' }} >{props.message}</span>\r\n <button onClick={() => redirectTo('/new-project')}>Proceed</button>\r\n </div>\r\n )}\r\n </div>\r\n )\r\n}","import React, { useState } from 'react';\r\nimport { CardElement, useElements, useStripe } from '@stripe/react-stripe-js';\r\nimport { Button, Form } from 'react-bootstrap';\r\nimport { Controller, useForm } from 'react-hook-form';\r\nimport EupatiTextbox from './textbox';\r\nimport EupatiDropdown from './dropdown';\r\nimport { CountriesWithCodeModel, LookUpData } from '../models/input-models';\r\nimport { Rules } from '../helpers';\r\nimport CheckoutResult from './checkout-outcome';\r\nimport EupatiLoader from './loading-animation/loader';\r\nimport './static.scss';\r\n\r\ntype Props = {\r\n lookUpData: LookUpData[],\r\n clientSecret: string,\r\n countries: CountriesWithCodeModel[];\r\n price?: number;\r\n plan?: string;\r\n package?: string;\r\n paymentMethod?: string;\r\n};\r\n\r\ntype SubmitFormData = {\r\n name: string;\r\n phone: string;\r\n email: string;\r\n city: string;\r\n country: string;\r\n line1: string;\r\n line2: string;\r\n zip: string;//postal_code\r\n state: string;\r\n};\r\n\r\nexport default function StripeCard(props: Props) {\r\n const { handleSubmit, control, watch, formState: { errors } } = useForm();\r\n\r\n const elements = useElements();\r\n const stripe = useStripe();\r\n\r\n const [isLoading, setIsLoading] = useState<boolean>(false);\r\n const [message, setMessage] = useState<string>('');\r\n const [shouldRenderSubComp, setShouldRenderSubComp] = useState<boolean>(false);\r\n const [isPaymentFailed, setIsPaymentFailed] = useState<boolean>(false);\r\n\r\n const fieldsData = {\r\n name: watch(\"name\", '') as string,\r\n phone: watch(\"phone\", '') as string,\r\n email: watch(\"email\", '') as string,\r\n city: watch(\"city\", '') as string,\r\n country: watch(\"country\", '') as string,\r\n line1: watch(\"line1\", '') as string,\r\n line2: watch(\"line2\", '') as string,\r\n zip: watch(\"zip\", '') as string,\r\n state: watch(\"state\", '') as string,\r\n } as SubmitFormData;\r\n\r\n const onSubmit = async (data: SubmitFormData) => {\r\n if (!stripe || !elements) {\r\n return;\r\n }\r\n\r\n // confirm payment\r\n // TODO: add checkout outcome pages (success and fail)\r\n const cardElement = elements.getElement(CardElement);\r\n if (cardElement) {\r\n const { error: stripeError, paymentIntent } = await stripe.confirmCardPayment(\r\n //props.clientSecret, {\r\n \"pi_3Ktr2NAfbriVg9as0afScgCw_secret_RHZRBa3UvEqVqYrWXWVILMSj9\", {\r\n payment_method: {\r\n card: cardElement,\r\n billing_details: {\r\n address: {\r\n city: data.city,\r\n country: returnCountryCode(parseInt(data.country)),\r\n line1: data.line1,\r\n line2: data.line2,\r\n postal_code: data.zip,\r\n state: data.state\r\n },\r\n email: data.email,\r\n name: data.name,\r\n phone: data.phone\r\n }\r\n }\r\n });\r\n setIsLoading(true);\r\n if (stripeError) {\r\n //console.error(stripeError);\r\n setIsPaymentFailed(true);\r\n const message = stripeError.message;\r\n if (message) {\r\n setMessage(message);\r\n }\r\n else {\r\n setMessage('Something went wrong...');\r\n }\r\n swapComponents(true);\r\n return;\r\n }\r\n\r\n //console.log(paymentIntent);\r\n setIsPaymentFailed(false);\r\n setMessage('you can now create a project');\r\n swapComponents(true);\r\n }\r\n }\r\n\r\n function findLookUpData(lookUpDataType?: string) {\r\n if (props.lookUpData &&\r\n props.lookUpData.length > 0) {\r\n return props.lookUpData?.filter((x: any) => x.name == lookUpDataType)[0]?.data;\r\n }\r\n\r\n return [];\r\n }\r\n\r\n const returnCountryCode = (countryId: number) => {\r\n const country = props.countries.find(c => c.id === countryId);\r\n if (country) {\r\n return country.code;\r\n }\r\n\r\n return '';\r\n }\r\n\r\n const swapComponents = (shouldSwap: boolean) => {\r\n setIsLoading(true);\r\n setShouldRenderSubComp(shouldSwap);\r\n setTimeout(() => {\r\n setIsLoading(false);\r\n }, 300);\r\n }\r\n\r\n const cardElementOptions = {\r\n // a way to inject styles into stripe iframe\r\n hidePostalCode: true,\r\n }\r\n\r\n let loadComp = (\r\n <div className='loader-wrapper'>\r\n <EupatiLoader />\r\n </div>\r\n );\r\n\r\n let mainComp = null;\r\n let subComp = null;\r\n if (isLoading) {\r\n mainComp = loadComp;\r\n subComp = loadComp;\r\n }\r\n else {\r\n //#region MainComponent\r\n mainComp = (\r\n <div id='stripe-payment'>\r\n <h4>Checkout</h4>\r\n <Form id='stripe-payment-form' onSubmit={handleSubmit(onSubmit)}>\r\n {/* <Form.Group className='billing-info'>\r\n <h6 className='billing-info-text'>Billing details</h6>\r\n </Form.Group> */}\r\n\r\n <Form.Group id='row-wrapper'>\r\n <Form.Group className='stripe-payment-field' id='row'>\r\n <Form.Label>Name</Form.Label>\r\n <Controller\r\n control={control}\r\n name='name'\r\n rules={Rules.requiredMessage}\r\n defaultValue={fieldsData.name}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.name?.message,\r\n placeholder: 'John Doe'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group className='stripe-payment-field' id='row'>\r\n <Form.Label>Phone</Form.Label>\r\n <Controller\r\n control={control}\r\n name='phone'\r\n rules={Rules.requiredMessage}\r\n defaultValue={fieldsData.phone}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.phone?.message,\r\n placeholder: '+447975777666'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group className='stripe-payment-field' id='row'>\r\n <Form.Label>Email</Form.Label>\r\n <Controller\r\n control={control}\r\n name='email'\r\n rules={Rules.requiredMessage}\r\n defaultValue={fieldsData.email}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.email?.message,\r\n placeholder: 'john.doe@example.com'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group className='stripe-payment-field' id='row'>\r\n <Form.Label>City</Form.Label>\r\n <Controller\r\n control={control}\r\n name='city'\r\n rules={Rules.requiredMessage}\r\n defaultValue={fieldsData.city}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.city?.message,\r\n placeholder: 'Essex'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group className='stripe-payment-field' id='row'>\r\n <Form.Label>Ðddress Line 1</Form.Label>\r\n <Controller\r\n control={control}\r\n name='line1'\r\n rules={Rules.requiredMessage}\r\n defaultValue={fieldsData.line1}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.line1?.message,\r\n placeholder: 'Street address'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group className='stripe-payment-field' id='row'>\r\n <Form.Label>Address Line 2</Form.Label>\r\n <Controller\r\n control={control}\r\n name='line2'\r\n rules={Rules.notRequired}\r\n defaultValue={fieldsData.line2}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.line2?.message,\r\n placeholder: 'Apartment, building, floor'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group className='stripe-payment-field' id='row'>\r\n <Form.Label>Postal code</Form.Label>\r\n <Controller\r\n control={control}\r\n name='zip'\r\n rules={Rules.requiredMessage}\r\n defaultValue={fieldsData.zip}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.zip?.message,\r\n placeholder: 'CB1 6NU'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group className='stripe-payment-field' id='row'>\r\n <Form.Label>Province</Form.Label>\r\n <Controller\r\n control={control}\r\n name='state'\r\n rules={Rules.requiredMessage}\r\n defaultValue={fieldsData.state}\r\n render={({ field }) =>\r\n <EupatiTextbox\r\n {...{\r\n ...field,\r\n errorMsg: errors?.state?.message,\r\n placeholder: 'Greater London'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n </Form.Group>\r\n\r\n <Form.Group id='row-wrapper-2'>\r\n <Form.Group className='stripe-payment-field mb-4' id='row-2'>\r\n <Form.Label>Country</Form.Label>\r\n <Controller\r\n control={control}\r\n name='country'\r\n rules={Rules.selectOptionMessage}\r\n defaultValue={fieldsData.country}\r\n render={({ field }) =>\r\n <EupatiDropdown\r\n {...{\r\n ...field,\r\n errorMsg: errors?.country?.message,\r\n fieldName: 'countries',\r\n values: findLookUpData('country'),\r\n defaultOptionText: 'Please select country...'\r\n }}\r\n />\r\n }\r\n />\r\n </Form.Group>\r\n\r\n <Form.Group className='card-info' id='row-2'>\r\n <Form.Label htmlFor='stripe-card-element'>Card information</Form.Label>\r\n <Form.Group className=\"form-control\" style={{ height: '2.4rem', paddingTop: '.7em' }} >\r\n <CardElement\r\n id='stripe-card-element'\r\n options={cardElementOptions}\r\n />\r\n </Form.Group>\r\n </Form.Group>\r\n </Form.Group>\r\n <Button type='submit'>Pay</Button>\r\n </Form>\r\n </div>\r\n );\r\n //#endregion\r\n\r\n //#region SubComponent\r\n subComp = (\r\n <>\r\n <CheckoutResult\r\n {...{\r\n isFail: isPaymentFailed,\r\n message: message,\r\n plan: props.plan,\r\n package: props.package,\r\n paymentMethod: props.paymentMethod,\r\n price: props.price,\r\n clientSecret: props.clientSecret,\r\n swapComponents: swapComponents,\r\n startLoading: () => setIsLoading(true)\r\n }}\r\n />\r\n </>\r\n );\r\n //#endregion\r\n }\r\n\r\n return (\r\n <>\r\n {shouldRenderSubComp ? (\r\n <>\r\n {subComp}\r\n </>\r\n ) : (\r\n <>\r\n {mainComp}\r\n </>\r\n )}\r\n </>\r\n )\r\n}","import { RouteComponentProps } from \"@reach/router\";\r\nimport React from \"react\";\r\nimport { INVALID_PRICING_DATA } from \"../../../common/helpers/messages\";\r\nimport { State } from \"../model\";\r\nimport { toast } from 'react-toastify';\r\nimport { CountriesWithCodeModel, LookUpData, PaymentIntentCreateModel, PaymentIntentResponseModel } from \"../../../common/models/input-models\";\r\nimport EupatiLoader from \"../../../common/static/loading-animation/loader\";\r\nimport '../styles.scss';\r\nimport StripeCard from \"../../../common/static/stripe-card\";\r\n\r\ntype OwnProps = {\r\n isPaymentLoading: boolean;\r\n isLookUpDataLoading: boolean;\r\n isCountriesLoading: boolean;\r\n lookUpData: LookUpData[];\r\n countries: CountriesWithCodeModel[];\r\n paymentResponse: PaymentIntentResponseModel;\r\n};\r\n\r\nexport type DispatchProps = {\r\n getLookUpData: () => void;\r\n getAllCountries: () => void;\r\n createPaymentIntent: (data: PaymentIntentCreateModel) => void;\r\n};\r\n\r\ntype Props = State & DispatchProps & OwnProps & RouteComponentProps<{ location: { state: { price: number, plan: string, package: string, paymentMethod: string, clientSecret?: string } } }>;\r\n\r\ntype OwnState = {\r\n clientSecret: string;\r\n};\r\n\r\nexport default class ComponentRoot extends React.Component<Props, OwnState> {\r\n constructor(props: any) {\r\n super(props);\r\n\r\n this.state = {\r\n clientSecret: ''\r\n } as OwnState;\r\n }\r\n\r\n componentDidMount() {\r\n const historyState = this.props.location?.state;\r\n if (historyState === undefined || historyState.price <= 0 ||\r\n historyState.package === '' || historyState.paymentMethod === '') {\r\n toast.error(INVALID_PRICING_DATA);\r\n window.location.href = '/pricing';\r\n }\r\n else {\r\n if (historyState.clientSecret === undefined) {\r\n this.props.createPaymentIntent({ price: historyState.price });\r\n }\r\n else {\r\n this.setState({ clientSecret: historyState.clientSecret });\r\n }\r\n this.props.getLookUpData();\r\n this.props.getAllCountries();\r\n }\r\n }\r\n\r\n render() {\r\n let mainComp = null;\r\n let loadComp = (\r\n <div className='loader-wrapper'>\r\n <EupatiLoader />\r\n </div>\r\n );\r\n\r\n if (this.props.isLookUpDataLoading ||\r\n this.props.isPaymentLoading ||\r\n this.props.isCountriesLoading\r\n ) {\r\n mainComp = loadComp;\r\n }\r\n else {\r\n mainComp = (\r\n <>\r\n <StripeCard\r\n {...{\r\n lookUpData: this.props.lookUpData,\r\n countries: this.props.countries,\r\n clientSecret: this.state.clientSecret === '' ? this.props.paymentResponse.clientSecret : this.state.clientSecret,\r\n package: this.props.location?.state.package,\r\n plan: this.props.location?.state.plan,\r\n price: this.props.location?.state.price,\r\n paymentMethod: this.props.location?.state.paymentMethod\r\n }}\r\n />\r\n </>\r\n );\r\n }\r\n\r\n return (\r\n <React.Fragment>\r\n {mainComp}\r\n </React.Fragment>\r\n )\r\n }\r\n}","import { default as RootComponent, DispatchProps } from '../components/component-root';\r\nimport * as Constants from '../constants';\r\nimport * as Actions from '../actions';\r\nimport { State } from '../model';\r\nimport { connect } from 'react-redux';\r\nimport { PaymentIntentCreateModel } from '../../../common/models/input-models';\r\n\r\nexport function mapStateToProps(globalState: any) {\r\n let name = Constants.NAME;\r\n let pageState = globalState[name] as State;\r\n return pageState;\r\n}\r\n\r\nexport function mapDispatchToProps(dispatch: any) {\r\n return {\r\n getLookUpData: () => dispatch(Actions.getLookUpDataAsync()),\r\n createPaymentIntent: (data: PaymentIntentCreateModel) => dispatch(Actions.createPaymentIntentAsync(data)),\r\n getAllCountries: () => dispatch(Actions.getAllCountriesAsync())\r\n } as DispatchProps;\r\n}\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(RootComponent);","import { State } from './model';\r\nimport * as t from './actionType'\r\nimport { CountriesWithCodeModel, LookUpData, PaymentIntentResponseModel } from '../../common/models/input-models';\r\n\r\nconst initialState: State = {\r\n isPaymentLoading: false,\r\n isLookUpDataLoading: false,\r\n isCountriesLoading: false,\r\n lookUpData: [],\r\n countries: [],\r\n paymentResponse: {\r\n clientSecret: ''\r\n }\r\n};\r\n\r\nexport default (state = initialState, action: any): State => {\r\n switch (action.type) {\r\n case t.SET_PAYMENT_LOADING:\r\n return setPaymentLoading(state, action.payload);\r\n case t.SET_LOOKUP_DATA_LOADING:\r\n return setLookUpDataLoading(state, action.payload);\r\n case t.SET_LOOKUP_DATA:\r\n return setLookUpData(state, action.payload);\r\n case t.SET_PAYMENT_RESPONSE:\r\n return setPaymentResponse(state, action.payload);\r\n case t.SET_ALL_COUNTRIES_DATA:\r\n return setAllCountriesData(state, action.payload);\r\n case t.SET_ALL_COUNTRIES_LOADING:\r\n return setAllCountriesLoading(state, action.payload);\r\n default:\r\n return state;\r\n }\r\n};\r\n\r\nconst setPaymentLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isPaymentLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setLookUpDataLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isLookUpDataLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setLookUpData = (state: State, val: LookUpData[]): State => {\r\n let newState = {\r\n ...state,\r\n lookUpData: [...val]\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setPaymentResponse = (state: State, val: PaymentIntentResponseModel): State => {\r\n let newState = {\r\n ...state,\r\n paymentResponse: { ...val }\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setAllCountriesData = (state: State, val: CountriesWithCodeModel[]): State => {\r\n let newState = {\r\n ...state,\r\n countries: [...val]\r\n } as State;\r\n\r\n return newState;\r\n}\r\n\r\nconst setAllCountriesLoading = (state: State, val: boolean): State => {\r\n let newState = {\r\n ...state,\r\n isCountriesLoading: val\r\n } as State;\r\n\r\n return newState;\r\n}","import * as Actions from './actions';\r\nimport * as Components from './components/index';\r\nimport * as Containers from './containers/index';\r\nimport * as Constants from './constants';\r\nimport Reducer from './reducer';\r\n\r\nexport default {\r\n actions: Actions,\r\n components: Components,\r\n containers: Containers,\r\n constants: Constants,\r\n reducer: Reducer\r\n};\r\n\r\nexport const Root = Containers.ComponentRoot;","import newProject from '../components/modules/new-project';\r\nimport patientProfile from '../components/modules/patient-profile';\r\nimport homePage from '../components/modules/home';\r\nimport allProjects from '../components/modules/admin/all-projects';\r\nimport importPatients from '../components/modules/admin/import-patients';\r\nimport allPatients from '../components/modules/admin/all-patients';\r\nimport adminsLs from '../components/modules/admin/admins-ls';\r\nimport contentEditor from '../components/modules/admin/content-editor';\r\nimport priceCatalog from '../components/modules/admin/price-catalog';\r\nimport pricing from '../components/modules/pricing';\r\nimport contentManagement from '../components/modules/admin/content-management';\r\nimport emailTemplates from '../components/modules/admin/email-templates';\r\nimport emailResponse from '../components/modules/confirm';\r\nimport payment from '../components/modules/payment';\r\n\r\n// The top-level state object\r\nexport interface ApplicationState {\r\n\r\n}\r\n\r\n// Whenever an action is dispatched, Redux will update each top-level application state property using\r\n// the reducer with the matching name. It's important that the names match exactly, and that the reducer\r\n// acts on the corresponding ApplicationState property type.\r\nexport const reducers = {\r\n // guest\r\n contentManagement: contentManagement.reducer,\r\n homePage: homePage.reducer,\r\n newProject: newProject.reducer,\r\n paymentPage: payment.reducer,\r\n // users\r\n patientProfile: patientProfile.reducer,\r\n emailResponse: emailResponse.reducer,\r\n // admins\r\n allAdmins: adminsLs.reducer,\r\n allPatients: allPatients.reducer,\r\n allProjects: allProjects.reducer,\r\n contentEditor: contentEditor.reducer,\r\n emailTemplates: emailTemplates.reducer,\r\n importPatients: importPatients.reducer,\r\n priceCatalog: priceCatalog.reducer,\r\n pricingPage: pricing.reducer,\r\n};\r\n\r\n// This type can be used as a hint on action creators so that its 'dispatch' and 'getState' params are\r\n// correctly typed to match your store.\r\nexport interface AppThunkAction<TAction> {\r\n (dispatch: (action: TAction) => void, getState: () => ApplicationState): void;\r\n}\r\n","import React, { useContext, useEffect } from \"react\";\r\nimport { Redirect, Route } from \"react-router-dom\";\r\nimport AuthenticationContext from \"../auth-context\";\r\n\r\nexport default function AdminRoute({ component: Component, ...restOfProps }) {\r\n\r\n const contextData = useContext(AuthenticationContext);\r\n\r\n useEffect(() => {\r\n if (contextData.isUserAdmin === null || contextData.isUserAdmin === undefined) {\r\n contextData.authenticateUser();\r\n }\r\n });\r\n\r\n return (\r\n <Route\r\n {...restOfProps}\r\n render={(props) =>\r\n contextData.isUserAdmin ? <Component {...props} {...restOfProps} /> : <Redirect to=\"/\" />\r\n }\r\n />\r\n );\r\n}","import React, { useContext, useEffect } from \"react\";\r\nimport { Redirect, Route } from \"react-router-dom\";\r\nimport AuthenticationContext from \"../auth-context\";\r\n\r\nexport default function ProtectedRoute({ component: Component, ...restOfProps }) {\r\n\r\n const contextData = useContext(AuthenticationContext);\r\n\r\n useEffect(() => {\r\n if (contextData.isUserAdmin === null || contextData.isUserAdmin === undefined) {\r\n contextData.authenticateUser();\r\n }\r\n });\r\n\r\n function isUserLoggedIn() {\r\n if (contextData.isUserAdmin === null || contextData.isUserAdmin === undefined) {\r\n return false;\r\n }\r\n\r\n return true;\r\n }\r\n\r\n return (\r\n <Route\r\n {...restOfProps}\r\n render={(props) =>\r\n isUserLoggedIn() ? <Component {...props} {...restOfProps} /> : <Redirect to=\"/\" />\r\n }\r\n />\r\n );\r\n}","export default __webpack_public_path__ + \"static/media/logo.aa07d840.jpg\";","import React from 'react'\r\nimport { Component } from 'react';\r\nimport authService from './AuthorizeService';\r\nimport { AuthenticationResultStatus } from './AuthorizeService';\r\nimport { LoginActions, QueryParameterNames, ApplicationPaths } from './ApiAuthorizationConstants';\r\nimport EupatiLoader from '../common/static/loading-animation/loader';\r\n\r\n// The main responsibility of this component is to handle the user's login process.\r\n// This is the starting point for the login process. Any component that needs to authenticate\r\n// a user can simply perform a redirect to this component with a returnUrl query parameter and\r\n// let the component perform the login and return back to the return url.\r\nexport class LoginHelper {\r\n\r\n getReturnUrl(state) {\r\n const params = new URLSearchParams(window.location.search);\r\n const fromQuery = params.get(QueryParameterNames.ReturnUrl);\r\n if (fromQuery && !fromQuery.startsWith(`${window.location.origin}/`)) {\r\n // This is an extra check to prevent open redirects.\r\n throw new Error(\"Invalid return url. The return url needs to have the same origin as the current page.\")\r\n }\r\n return (state && state.returnUrl) || fromQuery || `${window.location.origin}/`;\r\n }\r\n}\r\nexport const loginHelper = new LoginHelper();\r\n\r\nexport class Login extends Component {\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n message: undefined\r\n };\r\n }\r\n\r\n componentDidMount() {\r\n const action = this.props.action;\r\n switch (action) {\r\n case LoginActions.Login:\r\n this.login(loginHelper.getReturnUrl());\r\n break;\r\n case LoginActions.LoginCallback:\r\n this.processLoginCallback();\r\n break;\r\n case LoginActions.LoginFailed:\r\n const params = new URLSearchParams(window.location.search);\r\n const error = params.get(QueryParameterNames.Message);\r\n this.setState({ message: error });\r\n break;\r\n case LoginActions.Profile:\r\n this.redirectToProfile();\r\n break;\r\n case LoginActions.Register:\r\n this.redirectToRegister();\r\n break;\r\n default:\r\n throw new Error(`Invalid action '${action}'`);\r\n }\r\n }\r\n\r\n render() {\r\n const action = this.props.action;\r\n const { message } = this.state;\r\n\r\n if (!!message) {\r\n return <div style={{ display: 'flex', justifyContent: 'center', alignItems: 'center' }}>{message}</div>\r\n } else {\r\n switch (action) {\r\n case LoginActions.Login:\r\n return (\r\n <div className='loader-wrapper'>\r\n <EupatiLoader />\r\n </div>\r\n );\r\n case LoginActions.LoginCallback:\r\n return (<div style={{ display: 'flex', justifyContent: 'center', alignItems: 'center' }}>Processing login callback</div>);\r\n case LoginActions.Profile:\r\n case LoginActions.Register:\r\n return (<div></div>);\r\n default:\r\n throw new Error(`Invalid action '${action}'`);\r\n }\r\n }\r\n }\r\n\r\n async login(returnUrl) {\r\n const state = { returnUrl };\r\n const result = await authService.signIn(state);\r\n\r\n switch (result.status) {\r\n case AuthenticationResultStatus.Redirect:\r\n break;\r\n case AuthenticationResultStatus.Success:\r\n await this.navigateToReturnUrl(returnUrl);\r\n break;\r\n case AuthenticationResultStatus.Fail:\r\n this.setState({ message: result.message });\r\n break;\r\n default:\r\n throw new Error(`Invalid status result ${result.status}.`);\r\n }\r\n }\r\n\r\n async processLoginCallback() {\r\n const url = window.location.href;\r\n const result = await authService.completeSignIn(url);\r\n switch (result.status) {\r\n case AuthenticationResultStatus.Redirect:\r\n // There should not be any redirects as the only time completeSignIn finishes\r\n // is when we are doing a redirect sign in flow.\r\n throw new Error('Should not redirect.');\r\n case AuthenticationResultStatus.Success:\r\n await this.navigateToReturnUrl(loginHelper.getReturnUrl(result.state));\r\n break;\r\n case AuthenticationResultStatus.Fail:\r\n this.setState({ message: result.message });\r\n break;\r\n default:\r\n throw new Error(`Invalid authentication result status '${result.status}'.`);\r\n }\r\n }\r\n\r\n redirectToRegister() {\r\n this.redirectToApiAuthorizationPath(`${ApplicationPaths.IdentityRegisterPath}?${QueryParameterNames.ReturnUrl}=${encodeURI(ApplicationPaths.Login)}`);\r\n }\r\n\r\n redirectToProfile() {\r\n this.redirectToApiAuthorizationPath(ApplicationPaths.IdentityManagePath);\r\n }\r\n\r\n redirectToApiAuthorizationPath(apiAuthorizationPath) {\r\n const redirectUrl = `${window.location.origin}/${apiAuthorizationPath}`;\r\n // It's important that we do a replace here so that when the user hits the back arrow on the\r\n // browser they get sent back to where it was on the app instead of to an endpoint on this\r\n // component.\r\n window.location.replace(redirectUrl);\r\n }\r\n\r\n navigateToReturnUrl(returnUrl) {\r\n // It's important that we do a replace here so that we remove the callback uri with the\r\n // fragment containing the tokens from the browser history.\r\n window.location.replace(returnUrl);\r\n }\r\n}\r\n","import React, { Component, Fragment } from 'react';\r\nimport { NavItem, NavLink } from 'reactstrap';\r\nimport { Link } from 'react-router-dom';\r\nimport authService from './AuthorizeService';\r\nimport { loginHelper } from './Login';\r\nimport { ApplicationPaths, LoginActions } from './ApiAuthorizationConstants';\r\n\r\nexport class LoginMenu extends Component {\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n isAuthenticated: false,\r\n userName: null\r\n };\r\n }\r\n\r\n componentDidMount() {\r\n this._subscription = authService.subscribe(() => this.populateState());\r\n this.populateState();\r\n\r\n authService.signInSilent();\r\n }\r\n\r\n componentWillUnmount() {\r\n authService.unsubscribe(this._subscription);\r\n }\r\n\r\n async populateState() {\r\n const [isAuthenticated, user] = await Promise.all([authService.isAuthenticated(), authService.getUser()])\r\n\r\n this.setState({\r\n isAuthenticated,\r\n userName: user && user.name\r\n });\r\n }\r\n\r\n render() {\r\n const { isAuthenticated, userName } = this.state;\r\n if (!isAuthenticated) {\r\n const registerPath = `${ApplicationPaths.Register}`;\r\n const loginPath = `${ApplicationPaths.Login}`;\r\n return this.anonymousView(registerPath, loginPath);\r\n } else {\r\n const profilePath = `${ApplicationPaths.Profile}`;\r\n const logoutPath = { pathname: `${ApplicationPaths.LogOut}`, state: { local: true } };\r\n return this.authenticatedView(userName, profilePath, logoutPath);\r\n }\r\n }\r\n\r\n authenticatedView(userName, profilePath, logoutPath) {\r\n return (<Fragment>\r\n {/* <NavItem>\r\n <NavLink tag={Link} className=\"text-dark\" to={profilePath}>{userName}</NavLink>\r\n </NavItem> */}\r\n <NavItem>\r\n {/* <a href={logoutPath.pathname}>Logout</a> */}\r\n <NavLink tag={Link} to={logoutPath} style={{ color: '#fff' }}>Logout</NavLink>\r\n </NavItem>\r\n </Fragment>);\r\n\r\n }\r\n\r\n anonymousView(registerPath, loginPath) {\r\n return (<Fragment>\r\n <NavItem>\r\n <a href={\"/faq\"} style={{ color: '#fff' }}>About</a>\r\n </NavItem>\r\n <NavItem>\r\n <a href={loginPath} style={{ color: '#fff' }}>Login</a>\r\n {/* <NavLink tag={Link} className=\"text-dark\" to={loginPath}>Login</NavLink> */}\r\n </NavItem>\r\n </Fragment>);\r\n }\r\n}\r\n","import * as React from 'react';\r\nimport { Image } from 'react-bootstrap';\r\nimport { withRouter, NavLink } from 'react-router-dom';\r\nimport logo from '../../../images/logo.jpg';\r\nimport { Navbar } from 'react-bootstrap';\r\nimport { Nav } from 'react-bootstrap';\r\nimport { LoginMenu } from '../../api-authorization/LoginMenu';\r\nimport { faHome } from '@fortawesome/fontawesome-free-solid';\r\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\r\nimport { IconProp } from '@fortawesome/fontawesome-svg-core';\r\n\r\ntype OwnProps = {\r\n isUserAdmin: boolean;\r\n authenticateUser: () => void;\r\n}\r\n\r\nexport default class NavBar extends React.PureComponent<OwnProps, {}> {\r\n\r\n componentDidMount() {\r\n if (this.props.isUserAdmin === null || this.props.isUserAdmin === undefined) {\r\n this.props.authenticateUser();\r\n this.forceUpdate();\r\n }\r\n }\r\n\r\n componentDidUpdate(prevProps: any) {\r\n if (prevProps.isUserAdmin === null || prevProps.isUserAdmin === undefined) {\r\n this.props.authenticateUser();\r\n }\r\n }\r\n\r\n returnProperIconType(icon: any) {\r\n return icon as IconProp;\r\n }\r\n\r\n public render() {\r\n\r\n const ImgCard = withRouter(({ history }) => (\r\n <Image\r\n src={logo}\r\n rounded\r\n className='navbar-top-brand-logo'\r\n onClick={() => history.push('/')}\r\n >\r\n </Image>\r\n ));\r\n\r\n return (\r\n <div className='navigation-bar'>\r\n <Navbar className='navbar-top'>\r\n <Navbar.Brand className='navbar-top-brand' style={{ cursor: 'pointer' }}>\r\n <ImgCard />\r\n </Navbar.Brand>\r\n <div className='navbar-top-btns'>\r\n <Nav>\r\n <Nav.Link id='homeLink' href='/' className='navbar-top-button'><FontAwesomeIcon className='navbar-top-home' icon={this.returnProperIconType(faHome)} />Home</Nav.Link>\r\n </Nav>\r\n <Nav>\r\n <Nav.Link id='eupatiLink' href='https://eupati.eu/' className='navbar-top-button' style={{ marginLeft: '1.5rem' }}>Back To EUPATI</Nav.Link>\r\n </Nav>\r\n </div>\r\n </Navbar>\r\n <Navbar className='navbar-bottom' expand='lg' collapseOnSelect style={{ display: 'flex', justifyContent: 'flex-end' }}>\r\n <Navbar.Toggle />\r\n <Navbar.Collapse className='navbar-bottom-menu'>\r\n <Nav className='navbar-bottom-menu-list' style={!this.props.isUserAdmin ? { justifyContent: 'flex-end' } : {}}>\r\n {this.props.isUserAdmin &&\r\n <div className='admin-nav-items'>\r\n <li className='nav-item'>\r\n <NavLink className='nav-link' to='/admin/prices' style={{ textDecoration: 'none', color: '#fff' }}>Pricing</NavLink>\r\n </li>\r\n <li className='nav-item'>\r\n <NavLink className='nav-link' to='/admin/all-admins' style={{ textDecoration: 'none', color: '#fff' }}>Admins</NavLink>\r\n </li>\r\n <li className='nav-item'>\r\n <NavLink className='nav-link' to='/admin/all-patients' style={{ textDecoration: 'none', color: '#fff' }}>Patients</NavLink>\r\n </li>\r\n\r\n <li className='nav-item'>\r\n <NavLink className='nav-link' to='/admin/projects' style={{ textDecoration: 'none', color: '#fff' }}>Projects</NavLink>\r\n </li>\r\n\r\n <li className='nav-item'>\r\n <NavLink className='nav-link' to='/admin/import-patients' style={{ textDecoration: 'none', color: '#fff' }}>Import</NavLink>\r\n </li>\r\n\r\n <li className='nav-item'>\r\n <NavLink className='nav-link' to='/admin/email-templates' style={{ textDecoration: 'none', color: '#fff' }}>Templates</NavLink>\r\n </li>\r\n </div>\r\n }\r\n </Nav>\r\n <Nav className='navbar-bottom-menu-list' style={!this.props.isUserAdmin ? { justifyContent: 'flex-end' } : {}}>\r\n <div className='auth-nav-items'>\r\n <LoginMenu />\r\n </div>\r\n </Nav>\r\n </Navbar.Collapse>\r\n </Navbar>\r\n <hr className='ribbon'></hr>\r\n </div>\r\n )\r\n }\r\n}\r\n","import React from \"react\";\r\nimport { Navbar, Nav } from \"react-bootstrap\";\r\nimport { NavLink } from \"reactstrap\";\r\n\r\ntype OwnProps = {};\r\n\r\ntype DispatchProps = {};\r\n\r\ntype Props = {} & DispatchProps & OwnProps;\r\n\r\ntype OwnState = {\r\n currentYear: number;\r\n};\r\n\r\nexport default class Footer extends React.PureComponent<Props, OwnState> {\r\n\r\n constructor(props: any) {\r\n super(props);\r\n\r\n this.state = {\r\n currentYear: new Date().getFullYear()\r\n }\r\n }\r\n\r\n render() {\r\n\r\n return (\r\n <div className='footer'>\r\n <div className='footer-top'>\r\n <div className='footer-top-txt'>\r\n <a target='_blank' href='https://eupati.eu/contact/'><h5 className='footer-top-txt-title'>Contact Us</h5></a>\r\n </div>\r\n {/* <Nav className='footer-top-menu'>\r\n <li className='nav-item'>\r\n <NavLink className='nav-link' target='_blank' href='https://eupati.eu/contact/'>Contact</NavLink>\r\n </li>\r\n <li className='nav-item'>\r\n <NavLink className='nav-link' target='_blank' href='https://eupati.eu/donate/'>Donate</NavLink>\r\n </li>\r\n <li className='nav-item'>\r\n <NavLink className='nav-link' target='_blank' href='https://collaborate.eupati.eu/'>Collaborate</NavLink>\r\n </li>\r\n </Nav> */}\r\n </div>\r\n <Navbar className='footer-bottom'>\r\n <span>{`\\u00A9 Copyright EUPATI ${this.state.currentYear}`}</span>\r\n <Nav className='footer-bottom-menu'>\r\n <li className='nav-item'>\r\n <NavLink className='nav-link' href='/terms'>Terms & Conditions</NavLink>\r\n </li>\r\n <li className='nav-item'>\r\n <NavLink className='nav-link' href='/privacy'>Privacy</NavLink>\r\n </li>\r\n <li className='nav-item'>\r\n <NavLink className='nav-link' href='/faq'>FAQ</NavLink>\r\n </li>\r\n {/* <li className='nav-item'>\r\n <NavLink className='nav-link' target='_blank' href='https://eupati.eu/cookies/'>Cookies</NavLink>\r\n </li> */}\r\n </Nav>\r\n </Navbar>\r\n </div>\r\n )\r\n }\r\n}","import * as React from 'react';\r\nimport { Container } from 'react-bootstrap';\r\nimport NavBar from './navbar';\r\nimport Footer from './footer';\r\nimport AuthenticationContext from './auth-context';\r\n\r\nexport default class Layout extends React.PureComponent<{}, { children?: React.ReactNode }> {\r\n static contextType = AuthenticationContext;\r\n public render() {\r\n return (\r\n <React.Fragment>\r\n <NavBar {...this.context} />\r\n <Container>\r\n {this.props.children}\r\n </Container>\r\n <Footer />\r\n </React.Fragment>\r\n );\r\n }\r\n}","import React from 'react'\r\nimport { Component } from 'react';\r\nimport authService from './AuthorizeService';\r\nimport { AuthenticationResultStatus } from './AuthorizeService';\r\nimport { QueryParameterNames, LogoutActions, ApplicationPaths } from './ApiAuthorizationConstants';\r\n\r\n// The main responsibility of this component is to handle the user's logout process.\r\n// This is the starting point for the logout process, which is usually initiated when a\r\n// user clicks on the logout button on the LoginMenu component.\r\nexport class Logout extends Component {\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n message: undefined,\r\n isReady: false,\r\n authenticated: false\r\n };\r\n }\r\n\r\n componentDidMount() {\r\n const action = this.props.action;\r\n switch (action) {\r\n case LogoutActions.Logout:\r\n if (!!window.history.state.state.local) {\r\n this.logout(this.getReturnUrl());\r\n } else {\r\n // This prevents regular links to <app>/authentication/logout from triggering a logout\r\n this.setState({ isReady: true, message: \"The logout was not initiated from within the page.\" });\r\n }\r\n break;\r\n case LogoutActions.LogoutCallback:\r\n this.processLogoutCallback();\r\n break;\r\n case LogoutActions.LoggedOut:\r\n this.navigateToReturnUrl('/');\r\n //this.setState({ isReady: true, message: \"You successfully logged out!\" });\r\n break;\r\n default:\r\n throw new Error(`Invalid action '${action}'`);\r\n }\r\n\r\n this.populateAuthenticationState();\r\n }\r\n\r\n render() {\r\n const { isReady, message } = this.state;\r\n if (!isReady) {\r\n return <div></div>\r\n }\r\n if (!!message) {\r\n return (<div style={{ display: 'flex', justifyContent: 'center', alignItems: 'center' }}>{message}</div>);\r\n } else {\r\n const action = this.props.action;\r\n switch (action) {\r\n case LogoutActions.Logout:\r\n return (<div style={{ display: 'flex', justifyContent: 'center', alignItems: 'center' }}>Processing logout</div>);\r\n case LogoutActions.LogoutCallback:\r\n return (<div style={{ display: 'flex', justifyContent: 'center', alignItems: 'center' }}>Processing logout callback</div>);\r\n case LogoutActions.LoggedOut:\r\n return (<div style={{ display: 'flex', justifyContent: 'center', alignItems: 'center' }}>{message}</div>);\r\n default:\r\n throw new Error(`Invalid action '${action}'`);\r\n }\r\n }\r\n }\r\n\r\n async logout(returnUrl) {\r\n const state = { returnUrl };\r\n const isauthenticated = await authService.isAuthenticated();\r\n if (isauthenticated) {\r\n const result = await authService.signOut(state);\r\n switch (result.status) {\r\n case AuthenticationResultStatus.Redirect:\r\n break;\r\n case AuthenticationResultStatus.Success:\r\n await this.navigateToReturnUrl(returnUrl);\r\n break;\r\n case AuthenticationResultStatus.Fail:\r\n this.setState({ message: result.message });\r\n break;\r\n default:\r\n throw new Error(\"Invalid authentication result status.\");\r\n }\r\n } else {\r\n this.setState({ message: \"You successfully logged out!\" });\r\n }\r\n }\r\n\r\n async processLogoutCallback() {\r\n const url = window.location.href;\r\n const result = await authService.completeSignOut(url);\r\n switch (result.status) {\r\n case AuthenticationResultStatus.Redirect:\r\n // There should not be any redirects as the only time completeAuthentication finishes\r\n // is when we are doing a redirect sign in flow.\r\n throw new Error('Should not redirect.');\r\n case AuthenticationResultStatus.Success:\r\n await this.navigateToReturnUrl(this.getReturnUrl(result.state));\r\n break;\r\n case AuthenticationResultStatus.Fail:\r\n this.setState({ message: result.message });\r\n break;\r\n default:\r\n throw new Error(\"Invalid authentication result status.\");\r\n }\r\n }\r\n\r\n async populateAuthenticationState() {\r\n const authenticated = await authService.isAuthenticated();\r\n this.setState({ isReady: true, authenticated });\r\n }\r\n\r\n getReturnUrl(state) {\r\n const params = new URLSearchParams(window.location.search);\r\n const fromQuery = params.get(QueryParameterNames.ReturnUrl);\r\n if (fromQuery && !fromQuery.startsWith(`${window.location.origin}/`)) {\r\n // This is an extra check to prevent open redirects.\r\n throw new Error(\"Invalid return url. The return url needs to have the same origin as the current page.\")\r\n }\r\n return (state && state.returnUrl) ||\r\n fromQuery ||\r\n `${window.location.origin}${ApplicationPaths.LoggedOut}`;\r\n }\r\n\r\n navigateToReturnUrl(returnUrl) {\r\n return window.location.replace(returnUrl);\r\n }\r\n}\r\n","import React, { Component, Fragment } from 'react';\r\nimport { Route } from 'react-router';\r\nimport { Login } from './Login'\r\nimport { Logout } from './Logout'\r\nimport { ApplicationPaths, LoginActions, LogoutActions } from './ApiAuthorizationConstants';\r\n\r\nexport default class ApiAuthorizationRoutes extends Component {\r\n\r\n render () {\r\n return(\r\n <Fragment>\r\n <Route path={ApplicationPaths.Login} render={() => loginAction(LoginActions.Login)} />\r\n <Route path={ApplicationPaths.LoginFailed} render={() => loginAction(LoginActions.LoginFailed)} />\r\n <Route path={ApplicationPaths.LoginCallback} render={() => loginAction(LoginActions.LoginCallback)} />\r\n <Route path={ApplicationPaths.Profile} render={() => loginAction(LoginActions.Profile)} />\r\n <Route path={ApplicationPaths.Register} render={() => loginAction(LoginActions.Register)} />\r\n <Route path={ApplicationPaths.LogOut} render={() => logoutAction(LogoutActions.Logout)} />\r\n <Route path={ApplicationPaths.LogOutCallback} render={() => logoutAction(LogoutActions.LogoutCallback)} />\r\n <Route path={ApplicationPaths.LoggedOut} render={() => logoutAction(LogoutActions.LoggedOut)} />\r\n </Fragment>);\r\n }\r\n}\r\n\r\nfunction loginAction(name){\r\n return (<Login action={name}></Login>);\r\n}\r\n\r\nfunction logoutAction(name) {\r\n return (<Logout action={name}></Logout>);\r\n}\r\n","import React, { useEffect, useState } from 'react';\r\nimport { Route, useHistory } from 'react-router';\r\nimport AdminRoute from './components/common/static/routes/admin-routes';\r\nimport ProtectedRoute from './components/common/static/routes/protected-route';\r\nimport Layout from './components/common/static/Layout';\r\nimport { Root as NewProjectPage } from './components/modules/new-project';\r\nimport { Root as PatientInfoPage } from './components/modules/patient-profile';\r\nimport { Root as HomePage } from './components/modules/home';\r\nimport { Root as PricingPage } from './components/modules/pricing';\r\nimport { Root as AdminProjectsPage } from './components/modules/admin/all-projects';\r\nimport { Root as AdminImportPatients } from './components/modules/admin/import-patients';\r\nimport { Root as AdminPatientsPage } from './components/modules/admin/all-patients';\r\nimport { Root as AdminLsPage } from './components/modules/admin/admins-ls';\r\nimport { Root as ContentEditor } from './components/modules/admin/content-editor';\r\nimport { Root as PriceCatalog } from './components/modules/admin/price-catalog';\r\nimport { Root as ContentManagement } from './components/modules/admin/content-management';\r\nimport { Root as EmailTemplates } from './components/modules/admin/email-templates';\r\nimport { Root as EmailResponsePage } from './components/modules/confirm';\r\nimport { Root as PaymentPage } from './components/modules/payment';\r\n//import AuthorizeRoute from './components/api-authorization/AuthorizeRoute';\r\nimport ApiAuthorizationRoutes from './components/api-authorization/ApiAuthorizationRoutes';\r\nimport { ApplicationPaths } from './components/api-authorization/ApiAuthorizationConstants';\r\nimport './App.scss';\r\nimport { AuthenticationProvider } from './components/common/static/auth-context';\r\nimport { ToastContainer, Slide } from 'react-toastify';\r\nimport 'react-toastify/dist/ReactToastify.css';\r\nimport CookieConsent, { Cookies } from 'react-cookie-consent';\r\nimport { Elements } from '@stripe/react-stripe-js';\r\nimport { loadStripe } from '@stripe/stripe-js';\r\n\r\nexport default function App() {\r\n const history = useHistory();\r\n\r\n useEffect(() => {\r\n const handler = (e: any) => {\r\n if (\r\n e.target.closest(\r\n '.tox-tinymce-aux, .moxman-window, .tam-assetmanager-root'\r\n ) !== null\r\n ) {\r\n e.stopImmediatePropagation();\r\n }\r\n };\r\n document.addEventListener('focusin', handler);\r\n return () => document.removeEventListener('focusin', handler);\r\n }, []);\r\n\r\n // const getPublishableKey = async () => {\r\n // const { publishableKey } = await fetch('/api/payments/getstripeconfig').then(res => res.json());\r\n // const stripePromise = loadStripe(publishableKey);\r\n // return stripePromise;\r\n // }\r\n\r\n return (\r\n //<Elements stripe={getPublishableKey()}>\r\n <AuthenticationProvider>\r\n <ToastContainer\r\n autoClose={4000}\r\n transition={Slide}\r\n position={'top-center'}\r\n style={{ width: '33%' }}\r\n hideProgressBar={true}\r\n />\r\n <CookieConsent\r\n location=\"bottom\"\r\n style={{ background: '#113D7C' }}\r\n buttonStyle={{ color: '#secondaryColor', fontSize: '13px' }}\r\n buttonClasses=\"cookieConsentBtn\"\r\n expires={150}\r\n >\r\n This website uses cookies to enhance the user experience.{' '}\r\n <span style={{ fontSize: '13px' }}>\r\n Please refer to our <a href=\"/privacy\">Privacy policy</a> page for\r\n more details.\r\n </span>\r\n </CookieConsent>\r\n <Layout>\r\n <Route exact path=\"/\" component={HomePage} />\r\n <Route exact path=\"/pricing\" component={PricingPage} />\r\n <Route exact path=\"/new-project\" component={NewProjectPage} />\r\n {/* <Route exact path='/payment' component={PaymentPage} /> */}\r\n <Route exact path=\"/privacy\" component={ContentManagement} />\r\n <Route exact path=\"/faq\" component={ContentManagement} />\r\n <Route exact path=\"/terms\" component={ContentManagement} />\r\n <Route path=\"/letter-of-confirmation\" component={EmailResponsePage} />\r\n <Route path=\"/letter-of-rejection\" component={EmailResponsePage} />\r\n <ProtectedRoute exact path=\"/patient\" component={PatientInfoPage} />\r\n <AdminRoute\r\n exact\r\n path=\"/admin/projects\"\r\n component={AdminProjectsPage}\r\n />\r\n <AdminRoute\r\n exact\r\n path=\"/admin/import-patients\"\r\n component={AdminImportPatients}\r\n />\r\n <AdminRoute\r\n exact\r\n path=\"/admin/all-patients\"\r\n component={AdminPatientsPage}\r\n />\r\n <AdminRoute exact path=\"/admin/all-admins\" component={AdminLsPage} />\r\n <AdminRoute\r\n exact\r\n path=\"/admin/content-editor\"\r\n history={history}\r\n component={ContentEditor}\r\n />\r\n <AdminRoute exact path=\"/admin/prices\" component={PriceCatalog} />\r\n <AdminRoute\r\n exact\r\n path=\"/admin/email-templates\"\r\n component={EmailTemplates}\r\n />\r\n <Route\r\n path={ApplicationPaths.ApiAuthorizationPrefix}\r\n component={ApiAuthorizationRoutes}\r\n />\r\n </Layout>\r\n </AuthenticationProvider>\r\n //</Elements>\r\n );\r\n}\r\n","// In production, we register a service worker to serve assets from local cache.\r\n\r\n// This lets the app load faster on subsequent visits in production, and gives\r\n// it offline capabilities. However, it also means that developers (and users)\r\n// will only see deployed updates on the \"N+1\" visit to a page, since previously\r\n// cached resources are updated in the background.\r\n\r\n// To learn more about the benefits of this model, read https://goo.gl/KwvDNy.\r\n// This link also includes instructions on opting out of this behavior.\r\n\r\nconst isLocalhost = Boolean(\r\n window.location.hostname === 'localhost' ||\r\n // [::1] is the IPv6 localhost address.\r\n window.location.hostname === '[::1]' ||\r\n // 127.0.0.1/8 is considered localhost for IPv4.\r\n window.location.hostname.match(\r\n /^127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/\r\n )\r\n);\r\n\r\nexport default function register() {\r\n if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {\r\n // The URL constructor is available in all browsers that support SW.\r\n const url = process.env.PUBLIC_URL as string;\r\n const publicUrl = new URL(url, window.location.toString());\r\n if (publicUrl.origin !== window.location.origin) {\r\n // Our service worker won't work if PUBLIC_URL is on a different origin\r\n // from what our page is served on. This might happen if a CDN is used to\r\n // serve assets; see https://github.com/facebookincubator/create-react-app/issues/2374\r\n return;\r\n }\r\n\r\n window.addEventListener('load', () => {\r\n const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;\r\n\r\n if (isLocalhost) {\r\n // This is running on localhost. Lets check if a service worker still exists or not.\r\n checkValidServiceWorker(swUrl);\r\n } else {\r\n // Is not local host. Just register service worker\r\n registerValidSW(swUrl);\r\n }\r\n });\r\n }\r\n}\r\n\r\nfunction registerValidSW(swUrl: string) {\r\n navigator.serviceWorker\r\n .register(swUrl)\r\n .then(registration => {\r\n registration.onupdatefound = () => {\r\n const installingWorker = registration.installing as ServiceWorker;\r\n installingWorker.onstatechange = () => {\r\n if (installingWorker.state === 'installed') {\r\n if (navigator.serviceWorker.controller) {\r\n // At this point, the old content will have been purged and\r\n // the fresh content will have been added to the cache.\r\n // It's the perfect time to display a \"New content is\r\n // available; please refresh.\" message in your web app.\r\n console.log('New content is available; please refresh.');\r\n } else {\r\n // At this point, everything has been precached.\r\n // It's the perfect time to display a\r\n // \"Content is cached for offline use.\" message.\r\n console.log('Content is cached for offline use.');\r\n }\r\n }\r\n };\r\n };\r\n })\r\n .catch(error => {\r\n console.error('Error during service worker registration:', error);\r\n });\r\n}\r\n\r\nfunction checkValidServiceWorker(swUrl: string) {\r\n // Check if the service worker can be found. If it can't reload the page.\r\n fetch(swUrl)\r\n .then(response => {\r\n // Ensure service worker exists, and that we really are getting a JS file.\r\n const contentType = response.headers.get('content-type');\r\n if (response.status === 404 || (contentType && contentType.indexOf('javascript') === -1)) {\r\n // No service worker found. Probably a different app. Reload the page.\r\n navigator.serviceWorker.ready.then(registration => {\r\n registration.unregister().then(() => {\r\n window.location.reload();\r\n });\r\n });\r\n } else {\r\n // Service worker found. Proceed as normal.\r\n registerValidSW(swUrl);\r\n }\r\n })\r\n .catch(() => {\r\n console.log('No internet connection found. App is running in offline mode.');\r\n });\r\n}\r\n\r\nexport function unregister() {\r\n if ('serviceWorker' in navigator) {\r\n navigator.serviceWorker.ready.then(registration => {\r\n registration.unregister();\r\n });\r\n }\r\n}\r\n","import 'bootstrap/dist/css/bootstrap.css';\r\n\r\nimport * as React from 'react';\r\nimport * as ReactDOM from 'react-dom';\r\nimport { Provider } from 'react-redux';\r\nimport { ConnectedRouter } from 'connected-react-router';\r\nimport { createBrowserHistory } from 'history';\r\nimport configureStore from './store/configureStore';\r\nimport App from './App';\r\nimport registerServiceWorker from './registerServiceWorker';\r\n\r\n// Create browser history to use in the Redux store\r\nconst baseUrl = document.getElementsByTagName('base')[0].getAttribute('href') as string;\r\nconst history = createBrowserHistory({ basename: baseUrl });\r\n\r\n// Get the application-wide store instance, prepopulating with state from the server where available.\r\nconst store = configureStore(history);\r\n\r\nconst SITE_KEY = '6LdxnJMcAAAAAFdlE2cY43syjTlKK_qAMAKZRocG';\r\n\r\nimport { GoogleReCaptchaProvider } from 'react-google-recaptcha-v3';\r\n\r\nReactDOM.render(\r\n <Provider store={store}>\r\n <ConnectedRouter history={history}>\r\n <GoogleReCaptchaProvider reCaptchaKey={SITE_KEY}>\r\n <App />\r\n </GoogleReCaptchaProvider>\r\n </ConnectedRouter>\r\n </Provider>,\r\n document.getElementById('root')\r\n);\r\n\r\nregisterServiceWorker();","import { applyMiddleware, combineReducers, compose, createStore } from 'redux';\r\nimport thunk from 'redux-thunk';\r\nimport { connectRouter, routerMiddleware } from 'connected-react-router';\r\nimport { History } from 'history';\r\nimport { ApplicationState, reducers } from './';\r\n\r\nexport default function configureStore(history: History, initialState?: ApplicationState) {\r\n \r\n let middleware = [\r\n thunk,\r\n routerMiddleware(history)\r\n ];\r\n\r\n if (process.env.NODE_ENV === 'development') {\r\n middleware = [...middleware, require('redux-logger').default];\r\n }\r\n\r\n const rootReducer = combineReducers({\r\n ...reducers,\r\n router: connectRouter(history)\r\n });\r\n\r\n const enhancers = [];\r\n const windowIfDefined = typeof window === 'undefined' ? null : window as any; // eslint-disable-line @typescript-eslint/no-explicit-any\r\n if (windowIfDefined && windowIfDefined.__REDUX_DEVTOOLS_EXTENSION__) {\r\n enhancers.push(windowIfDefined.__REDUX_DEVTOOLS_EXTENSION__());\r\n }\r\n\r\n return createStore(\r\n rootReducer,\r\n initialState,\r\n compose(applyMiddleware(...middleware), ...enhancers)\r\n );\r\n}\r\n"],"sourceRoot":""}