{"version":3,"sources":["modules/App/components/AppBoundary.js","modules/App/components/Overlay.js","modules/App/components/Spinner.js","utils/arrayHelpers.js","utils/objectHelpers.js","utils/queryHelpers.js","utils/dateHelpers.js","utils/deviceHelper.js","utils/domHelpers.js","modules/App/components/Notification.js","utils/csvHelpers.js","modules/App/actions/types.js","modules/App/actions/index.js","modules/ClientPortal/constants/stepKeys.js","modules/ClientPortal/constants/themeColor.js","modules/ClientPortal/constants/formKeys.js","modules/ClientPortal/constants/pageKeys.js","modules/ClientPortal/constants/index.js","modules/App/index.js","modules/ClientPortal/hooks/useHover.js","modules/ClientPortal/hooks/useCheckMobile.js","modules/ClientPortal/Common/Icon/index.js","modules/ClientPortal/Common/PageHeader/PageLogo.js","modules/ClientPortal/context/DrawerContext.js","modules/ClientPortal/Common/PageHeader/PageHeaderMobile.js","modules/ClientPortal/Common/PageHeader/PageHeaderDesktop.js","modules/ClientPortal/Common/PageHeader/PageHeader.js","assets/images/28989_logo_main - horizontal.png","modules/ClientPortal/Common/PoweredBy/PoweredBy.js","assets/images/coreplus-logo-small.png","modules/ClientPortal/styles/index.js","modules/ClientPortal/Common/ProgressStep/ProgressStep.js","modules/ClientPortal/Common/Select/Select.js","modules/ClientPortal/Common/TextButton/TextButton.js","modules/ClientPortal/Common/SideDrawer/SideDrawer.js","modules/ClientPortal/Common/Button/FullWidthButton.js","modules/ClientPortal/Common/Button/TransparentButton.js","modules/ClientPortal/Common/Button/ThemeColorButton.js","api/config.js","modules/ClientPortal/Common/Button/BackTopButton.js","utils/matomoHelpers.js","assets/images/google-map-marker.png","modules/ClientPortal/Common/GoogleMap/GoogleMap.js","modules/ClientPortal/Common/GoogleMap/LocationNotFound.js","assets/images/sad_face.png","modules/ClientPortal/Common/StepText/StepText.js","modules/ClientPortal/Common/Calendar/CalendarDay.js","modules/ClientPortal/helpers/filterHelper.js","modules/ClientPortal/helpers/bookingPortalHelper.js","modules/ClientPortal/helpers/dateTimeHelper.js","modules/ClientPortal/helpers/FormValidationHelper.js","modules/ClientPortal/helpers/medicareHelpers.js","modules/ClientPortal/helpers/appointmentSummaryHelper.js","modules/ClientPortal/helpers/appointmentCancellationHelper.js","modules/ClientPortal/helpers/fileHelper.js","modules/ClientPortal/helpers/creditCardHelper.js","modules/ClientPortal/Common/Calendar/Calendar.js","modules/ClientPortal/Common/Calendar/DateOfBirthCalendar.js","modules/ClientPortal/Common/InputBox/InputBox.js","modules/ClientPortal/Common/AutocompleteBox/AutocompleteBox.js","modules/ClientPortal/Common/AutocompleteBox/ComboBox.js","modules/ClientPortal/Common/Modal/Modal.js","modules/ClientPortal/Common/MonthYearPicker/MonthYearPickerPanel.js","modules/ClientPortal/Common/MonthYearPicker/ExpiryMonth.js","modules/ClientPortal/BookingPortal/components/Steps/StepItem.js","modules/ClientPortal/BookingPortal/components/Steps/SpecialtyTypeSelect.js","modules/ClientPortal/helpers/dataMappingHelper.js","modules/ClientPortal/BookingPortal/components/Steps/AppointmentTypeSelect.js","modules/ClientPortal/BookingPortal/components/Steps/LocationSelect.js","modules/ClientPortal/BookingPortal/components/Steps/PractitionerSelect.js","modules/ClientPortal/BookingPortal/components/Steps/TimeZoneSelect.js","modules/ClientPortal/BookingPortal/components/Steps/ScheduleSelect.js","modules/ClientPortal/BookingPortal/components/Drawer/DrawerCardContainer.js","modules/ClientPortal/BookingPortal/components/Drawer/LocationListCard.js","modules/ClientPortal/BookingPortal/components/Drawer/LocationDrawer.js","modules/ClientPortal/BookingPortal/components/Drawer/PractitionerAvatar.js","modules/ClientPortal/BookingPortal/components/Drawer/EllipsisButton.js","modules/ClientPortal/BookingPortal/components/Drawer/PractitionerListCard.js","modules/ClientPortal/BookingPortal/components/Drawer/PractitionerDrawer.js","modules/ClientPortal/BookingPortal/components/Drawer/WaitingListButton.js","modules/ClientPortal/BookingPortal/components/Drawer/TimeSlotList.js","modules/ClientPortal/BookingPortal/components/Drawer/CalendarLoader.js","modules/ClientPortal/BookingPortal/components/Drawer/ScheduleDrawer.js","modules/ClientPortal/BookingPortal/components/Alert.js","modules/ClientPortal/BookingPortal/components/WelcomeMessage.js","modules/ClientPortal/BookingPortal/components/ContinueButton.js","modules/ClientPortal/AnimationWrapper/MountedAnimationWrapper.js","modules/ClientPortal/AnimationWrapper/useMountAndUnmount.js","modules/ClientPortal/actions/types.js","modules/ClientPortal/actions/appointmentAction.js","api/httpClient.js","requests/index.js","services/portalService.js","modules/ClientPortal/actions/configAction.js","modules/ClientPortal/actions/datasourceAction.js","modules/ClientPortal/helpers/PreviewLoadingTemplate.js","modules/ClientPortal/actions/formAction.js","modules/ClientPortal/actions/bookingAction.js","modules/ClientPortal/helpers/stepHelper.js","modules/ClientPortal/BookingPortal/hooks/useGetData.js","modules/ClientPortal/BookingPortal/index.js","modules/ClientPortal/actions/waitingListAction.js","modules/ClientPortal/BookingPortal/hooks/useSelectData.js","modules/ClientPortal/ContactForm/components/VerificationDrawer.js","modules/ClientPortal/ContactForm/components/Form/FormInput.js","modules/ClientPortal/ContactForm/components/Form/DateOfBirth.js","modules/ClientPortal/ContactForm/components/Form/Comments.js","modules/ClientPortal/ContactForm/components/Form/HealthFund.js","modules/ClientPortal/ContactForm/components/Form/MedibankCustomFields.js","modules/ClientPortal/ContactForm/components/Form/MedibankFields.js","modules/ClientPortal/helpers/index.js","modules/ClientPortal/ContactForm/components/Form/ClientAddress.js","modules/ClientPortal/ContactForm/components/Form/ClientSuburb.js","modules/ClientPortal/ContactForm/components/Form/ClientPostcode.js","modules/ClientPortal/ContactForm/components/Form/FileUploader.js","modules/ClientPortal/ContactForm/components/Form/UploadDocument.js","modules/ClientPortal/ContactForm/components/Form/IntakeForm.js","modules/ClientPortal/ContactForm/components/Form/ConfirmationPolicy.js","modules/ClientPortal/ContactForm/components/Form/MedicareInformation.js","modules/ClientPortal/ContactForm/components/Form/CreditCard.js","modules/ClientPortal/ContactForm/components/Form/PersonalDetailsForm.js","modules/ClientPortal/ContactForm/components/Summary/SummaryListItem.js","modules/ClientPortal/ContactForm/components/Summary/SummaryDesktop.js","modules/ClientPortal/ContactForm/components/Summary/SummaryMobile.js","modules/ClientPortal/ContactForm/components/Summary/AppointmentSummary.js","modules/ClientPortal/ContactForm/consts/index.js","modules/ClientPortal/ContactForm/index.js","modules/ClientPortal/Confirm/components/BookingDetailsItem.js","modules/ClientPortal/Confirm/helperFunctions.js","modules/ClientPortal/Confirm/components/AddToCalendar.js","modules/ClientPortal/Confirm/index.js","modules/ClientPortal/Cancellation/components/CancellationReasons.js","modules/ClientPortal/Cancellation/index.js","modules/ClientPortal/index.js","utils/googleAnalyticsHelper.js","routes.js","modules/App/reducers/index.js","modules/ClientPortal/reducers/appointmentReducer.js","modules/ClientPortal/reducers/configReducer.js","modules/ClientPortal/reducers/datasourceReducer.js","jsonData/HealthFunds.js","jsonData/CustomFields.js","modules/ClientPortal/reducers/bookingReducer.js","modules/ClientPortal/reducers/formReducer.js","modules/ClientPortal/reducers/waitingListReducer.js","store/rootReducer.js","store/configureStore.js","index.js"],"names":["AppBoundary","componentDidCatch","componentDidUpdate","props","redirect","error","success","history","push","this","children","Component","styles","overlayStyle","width","height","zIndex","position","left","top","background","Overlay","style","spinnerStyle","marginLeft","marginTop","Spinner","spinning","CircularProgress","size","thickness","deleteElementByIndex","arr","index","length","slice","deepGet","obj","defaultValue","undefined","foundSoFar","remainingProps","deepAssign","initial","value","keys","key","reduce","current","currentIndex","remainingKeys","currentKey","parentKey","parentProp","currentVal","firstKey","reverse","getByKeys","currentValue","getParameterByName","name","url","window","location","href","replace","results","RegExp","toLowerCase","exec","decodeURIComponent","isSameDay","day1","day2","getDate","getMonth","getFullYear","getYearMonthPart","day","Date","isIOSDevice","test","navigator","userAgent","MSStream","blurInputWhenTypeEnter","e","which","document","activeElement","target","blur","darken","color","amount","indexOf","substring","parseInt","subtractLight","colorHex","colorResult","toString","requestAnimationFrame","mozRequestAnimationFrame","webkitRequestAnimationFrame","msRequestAnimationFrame","setTimeout","scrollTo","element","to","duration","scrollHeight","clientHeight","scrollTop","perTick","isLightColor","hexcolor","split","map","hex","join","substr","Notification","objectToCSVRow","dataObject","dataArray","o","result","search","memo","clear","isError","message","messageInUI","useMemo","text","canDismiss","Dialog","classes","root","paperScrollPaper","open","className","onClick","APP_ACTION","SHOW_ERROR","SHOW_SUCCESS","CLEAR","LOADING","REDIRECT","loading","type","payload","showError","STEP_KEYS","themeString","sessionStorage","getItem","themeColor","headerTheme","themeJson","JSON","parse","THEME_COLOR","THEME_COLOR_HOVER","hexCode","amt","col","darkenColor","THEME_COLOR_HEADER","IS_LIGHT_HEADER","FORM_KEYS","FIRST_NAME","MIDDLE_NAME","PREFERRED_NAME","LAST_NAME","DATE_OF_BIRTH","EMAIL","MOBILE","COMMENTS","CLIENT_ADDRESS","CLIENT_SUBURB","CLIENT_POSTCODE","HEALTH_FUND","CARD_NUMBER","CARD_POSITION","CUSTOM_FIELDS","FILES","MEDICARE_NUMBER","MEDICARE_EXPIRY","CREDIT_CARD_NUMBER","CREDIT_CARD_EXPIRY","CREDIT_CARD_NAME","CREDIT_CARD_SECURITY_CODE","PAGE_KEYS","ANY_SELECTION","CANCELLATION_OTHER_REASON_ID","VALID_FILE_EXTENSION","SUPPORTED_FILE_TEXT","extension","toUpperCase","ONLINE_PAYMENT_KEY_NAME","ONLINE_PAYMENT_IS_TEST","connect","state","app","outerTheme","createMuiTheme","palette","primary","main","ThemeProvider","theme","useHover","useState","setValue","ref","useRef","handleMouseEnter","useCallback","handleMouseLeave","useEffect","node","addEventListener","removeEventListener","useCheckMobile","innerWidth","isMobile","setIsMobile","onWindowSizeChange","ListIcon","MaterialUIIcon","iconKey","ArrowDownIcon","DoneIcon","CloseIcon","PhoneIcon","EditIcon","CalendarIcon","CreditCardIcon","HelpIcon","restProps","Icon","PageLogo","setError","tenant","src","alt","onError","DrawerContext","createContext","DrawerContextProvider","drawerOpen","setDrawerOpen","Provider","headerBgColor","contrastColor","fontColor","infoIconStyle","borderColor","infoIconStyleOpen","phoneIconStyle","PageHeaderMobile","menuRef","scrollRecordRef","scrollY","openSubMenu","setOpenSubMenu","useContext","displayPhoneNumber","customerTermsUrl","customerPrivacyPolicyUrl","businessName","isLogoOrBusinessName","handleClick","event","targetDom","contains","handleScroll","windowScrollY","Math","abs","businessNameFontStyle","fontSize","stopPropagation","prevOpen","rel","xmlns","viewBox","points","fill","bgColor","PageHeaderDesktop","PageHeader","PoweredBy","logo","coreplusLogo","colorStyle","backgroundStyle","borderColorStyle","backgroundStyleHover","borderColorStyleHover","ProgressStep","page","appointment","setHeight","timmer","heightValue","diffHeight","nodeList","querySelectorAll","dom","offsetTop","getLineHeight","clearTimeout","stepTwo","Select","anchorEl","setAnchorEl","placeholder","onToggle","onSelect","options","noOptionText","noOptionDataSource","preventDefault","handleSelect","valueText","foundItem","find","item","label","renderText","renderMenu","Menu","onClose","PaperProps","maxHeight","minWidth","MenuItem","span","TextButton","SideDrawer","closeCallback","showCloseBtn","maskClosable","handleClose","object","Drawer","paper","anchor","hoverStyle","FullWidthButton","disabled","hoverRef","isHovered","defaultColorTheme","defaultColor","TransparentButton","isTheme","forceDisabled","normalStyle","defaultProps","ThemeColorButton","RECAPTCHA_KEY","API_CONFIG","BUSINESS_NAME","GOOGLE_MAP_KEY","BackTopButton","iconDirection","pathname","process","antiForgeryTokenDom","querySelector","CSRF_TOKEN","origin","protocol","hostname","port","script","createElement","innerHTML","head","appendChild","createMatomoScriptTag","rootUrl","headers","CsrfAngular","preventTouchStyle","pointerEvents","GoogleMap","zoom","preventTouch","bootstrapURLKeys","defaultCenter","defaultZoom","GoogleMapMarker","lat","lng","LocationNotFound","StepText","step","total","hoverContainerStyle","hoverTextStyle","CalendarDay","dateKey","today","amEnabled","pmEnabled","selected","enabled","containerStyle","dateTextStyle","amEnabledStyle","pmEnabledStyle","filterPractitionersBySpecialty","practitioners","specialtyType","filter","p","specialties","s","specialtyTypeId","includes","filterSchedulesByPractitioner","schedules","practitioner","practitionerId","filterSchedulesByLocation","Sessions","locationId","filterLocationsBySchedules","locations","locationIdsInSchedule","next","sessions","l","filterPractitionersBySchedules","practitionerIdsInSchedule","checkIsPhoneConsult","siteConsultTypes","some","siteId","consultType","isCurrentStep","steps","mapDateTimeStringToText","dateTimeString","moment","parseZone","format","mapDateTimeToTimeText","datetime","getUniqueTimeSlots","timeslots","startDateTime","endDateTime","mapMomentjsToDateTimeString","momentJsDateTime","AUS_DATE_REGEX","mapAusDateStrToDate","ausDate","dateArr","momentJsDate","isValid","isBefore","toDate","isDateBirthWithInRange","date","isAfter","isFutureDate","mapDateToICalDatetimeFormat","isValidName","isPostcode","mandatoryObject","errorMessage","required","trim","isEmpty","validators","valid","isEmail","getCommentsFieldsValidator","isCommentMandatory","getAddressFieldsValidator","addressValue","isAddressMandatory","getMedicareValidator","numberValue","expiryValue","numberValid","val","num","irn","cardNumber","validated","enteredMedicareCardNumber","enteredMedicareCardNumberLength","totalValue","i","parseFloat","validateMedicareCard","expiryValid","getCreditCardValidator","mandatory","cardValid","validator","isCreditCard","nameValid","Boolean","codeValid","validate","rules","Object","getSpecialtyTypeAppointmentType","specialtyTypes","specialtyTypeValue","appointmentTypeValue","specialtyTypeText","appointmentTypeText","isTelehealthAppointment","foundSpecialtyType","foundAppointmentType","appointmentTypes","a","appointmentTypeId","description","isTeleHealthEnabled","getLocationTextAndPosition","positions","locationValue","locationText","locationDetail","suburb","getPractitionerText","practitionerValue","practitionerDetail","firstName","lastName","getPractitionerFirstName","getPractitionerLastName","getAppointmentDateTimeText","appointmentDateTime","waitingListRequired","waitingListPreferredTime","getFullAddress","streetAddress","postcode","country","timezoneTextAndTzIdMap","adelaide","brisbane","currie","darwin","eucla","hobart","lindeman","melbourne","perth","sydney","getAppointmentIdFromUrl","mappingContentTypeWithFileName","fileName","getFileNameWithExtension","base64ToArrayBuffer","base64","binaryString","atob","binaryLen","bytes","Uint8Array","ascii","charCodeAt","splitedFileNameArray","fetchForCardTokenPromise","publishKey","card","isTest","pinApi","mode","Pin","Api","getPinApiInstanceFactory","Promise","resolve","reject","createCardToken","then","done","canSaveCreditCard","isCreditCardEnabled","config","onlinePaymentToken","datasource","createPinPaymentsScript","getElementsByTagName","areNotAllCreditCardFieldsFilled","number","expiryDate","securityCode","hasValueFieldsNumber","Calendar","month","fromMonth","timeSlots","onDayClick","onMonthChange","selectedDay","renderDay","mapJsDateToYearMonthDayString","timeSlot","am","pm","firstYear","fromDate","DateOfBirthCalendar","monthDate","setMonthDate","dateString","jsDate","DayComponent","handleYearMonthChange","handleDayClick","dateStr","disabledDays","after","captionElement","localeUtils","YearMonthForm","onChange","toMonth","months","getMonths","years","handleChange","form","year","InputBox","errorText","onBlur","errorTextComponent","InputBoxError","TextField","helperText","AutocompleteBox","inputText","setInputText","onSearch","option","handleSearch","Autocomplete","disableClearable","getOptionLabel","renderInput","params","fullWidth","inputProps","autoComplete","ComboBox","freeSolo","filterSelectedOptions","noOptionsText","inputValue","autoHighlight","Modal","title","onConfirm","currentMoment","currentYear","currentMonth","monthArr","MonthYearPickerPanel","minYear","maxYear","previousNotAllow","yearValue","setYearValue","yearInNumber","monthValue","getStyle","isPrevious","monthVal","handleClickMonth","ExpiryMonth","showCalendar","setShowCalendar","floatingLabel","InputLabelProps","shrink","CalendarPanel","splitArr","StepItem","hint","SpecialtyTypeSelect","hideStep","mapSpecialtyTypesToOptions","handleToggle","AppointmentTypeSelect","appointmentType","mapAppointmentTypesToOptions","LocationSelect","getPositions","PractitionerSelect","preSelectPractitioner","TimeZoneSelect","timeZones","hintText","isTimezoneEnabled","locationTimeZones","timeZone","timezoneUID","ScheduleSelect","noSlotsPlaceholder","placeholderText","DrawerCardContainer","LocationListCard","addressText","LocationDrawer","setSearch","showAnyLocationButton","timezoneId","isTimeZoneUnique","locationList","mapLocationsToDataInLocationDrawer","handleSelectAny","firstLocation","newSearch","filterLocations","filterBy","renderLocations","filteredLocations","Alert","PractitionerAvatar","useInitial","handleError","Avatar","EllipsisButton","tooltipContent","Tooltip","maxHeightStyle","PractitionerListCard","descriptionRef","isHigher","setIsHigher","expanded","setExpanded","imageId","imageSrc","getFirstLetterUpperCase","str","charAt","initialNameText","property","getComputedStyle","getPropertyValue","showButton","descriptionDomStyle","PractitionerDrawer","expandedCard","setExpandedCard","isAnyPractitionerEnabled","showAnyPractitionerButton","photoImageRootUrl","practitionerList","mapPractitionersToDataInPractitionerDrawer","renderPractitionerList","WaitingListButton","TimeSlotList","isAM","TimeSlot","CalendarLoader","LinearProgress","drawerDomIdentifier","ScheduleDrawer","headingRef","drawerRef","headingFloat","setHeadingFloat","setSelectedDay","selectedMonth","setSelectedMonth","nextTimeSlotText","setNextTimeSlotText","loadingTimeSlots","getTimeSlots","availableLocations","earliestBookingTime","appointmentDateTimeValue","waitingListEnabled","waitingList","setRequireWaitingList","selectPreferredTime","timezone","preferredTime","headerTopHeight","startTimeMomentJs","add","endTimeMomentJs","endOf","headingDom","headingTop","drawerTop","timer","identifier","renderDateTitle","initialMonth","timeSlotList","res","timeslot","startTime","momentJsTime","recordInRes","timeslotWithCurrentKey","timeslotInDatasource","newTimeslot","hour","createTimeSlotObjectForScheduleDrawer","displayTimeSlots","selectedTimeSlot","destination","adjustment","elementScrollTop","handleMonthClick","ditinctMonths","accumulator","monthKey","startOf","startOfMonth","startTimemomentJs","endTimemomentJs","diff","handleClickTimeSlot","handleClickNextTimeSlot","firstSlot","id","FloatHeading","WelcomeMessage","ContinueButton","MountedAnimationWrapper","mounted","setMounted","useMountAndUnmount","animationClassName","CSSTransition","in","classNames","timeout","enter","exit","APPOINTMENT_ACTION","DATASOURCE_ACTION","CONFIG_ACTION","BOOKING_ACTION","WAITING_LIST_ACTION","FORM_ACTION","selectAppointmentType","setAppointmentValue","selectLocation","timeZoneId","selectPractitioner","selectAppointmentDateTime","source","axios","CancelToken","isCancel","requests","getSuburbList","httpClient","baseUrl","setUrl","get","requestUrl","getUrl","query","newTab","tokenQuery","post","cancelToken","stringify","postAll","all","postFormData","file","formData","FormData","append","forEach","onUploadProgress","remove","delete","uploadFileToS3","presignedUrl","put","portalService","locationGroupId","queryString","locationIds","specialtyId","start","end","phoneConsult","token","locationStr","smsModel","address","isNewClient","appointmentId","paramsObj","qs","clientId","fileSize","attributeNames","consumerId","geolocationService","setConfig","setLoadedData","loaded","setSpecialtyTypes","filtedSpecialtyTypes","f","setDatasourceValue","setPractitioners","setLocations","setTimeZones","setSchedules","toggleLoadingTimeSlots","setTimeSlots","concat","setPosition","dispatch","getState","data","getIntakeFormFileList","isDownloadDocumentAllowed","previewInIOS","windowOpener","write","fileByte","blob","Blob","fileUrl","URL","createObjectURL","getTimeslotsByPractitionersAndLocations","practitionerIds","ts","getOnlinePaymentToken","applicationAttributes","attributeName","attributeValue","onlinePaymentIsTest","setVerifyDrawerOpen","sendingVerificationCode","mobile","mobileNumber","getCreditCardToken","creditCardNumber","creditCardExpiry","creditCardName","creditCardSecurityCode","expiry_month","expiry_year","cvc","address_line1","address_city","address_country","response","console","submitBookingWithoutFiles","verificationCode","recaptchaToken","creditCardToken","createBookingModel","goToPage","updateAppointmentId","updateAppointmentCancelled","getResponseErrorMessage","submitBookingWithFiles","fileIdList","clientObj","clients","getClientResponse","isNewClientFlag","client","createClientResponse","newPassingClientObject","uploadFiles","files","appointmentResponse","createFileAssociations","createFileResponse","fileId","Item1","Item2","association","associatedEntity","associatedPrimaryDomainKey","associationType","timeZoneOfLocation","middleName","preferredName","email","dateOfBirth","comments","healthFund","cardPosition","customFields","clientAddress","clientSuburb","clientPostcode","medicareNumber","medicareExpiry","confirmationText","reCaptchaEnabled","isHidingLocationEnabled","isPhoneConsult","locationTextAndPosition","practitionerText","appointmentDateTimeText","enteredComments","timezoneText","timezoneList","getTimezoneText","timezoneIdentifier","appointmentParams","notes","smsVerifyCode","bookingDetails","createBookingDetailsText","coordinate","appointmentTypeName","serviceName","locationAddress","waitingListProps","addToWaitingList","clientParams","phoneNumberMobile","healthFundProviderId","healthFundMembershipNumber","healthFundCardPosition","homePostcode","cf","cardToken","medicareCardNumber","medicareCardIRN","getMedicareNumberAndIRNFromString","medicareCardExpireDate","expiry","getMedicareExpiryDateFromString","appointmentTimeText","modelState","goToNextStep","currentStep","practitionerFirst","showTimeZone","extraConfig","booking","foundIndex","nextStep","findNextStep","remainingStep","newSteps","stepsToBeClear","clearSteps","toggleVisibility","visiable","cancelled","getSuburbs","searchText","pageNumber","pageSize","useGetTimeSlotList","filterTimeSlotsByLocationAndPractitioner","selectSpecialtyType","selectTimeZone","initLoad","cancel","timezoneValue","filteredTimeSlots","time","welcomeMessage","preSelectSpecialtyType","specialtyHintText","appointmentTypeHintText","practitionerHintText","locationHintText","timezoneHintText","appointmentDateTimeHintText","visibilityKey","specialtyTypeList","useGetSpecialtyTypeList","appointmentTypeList","selectedSpecialtyType","specialty","sort","b","nameA","nameB","useGetAppointmentTypeList","schedulesCopy","locationCopy","useGetLocationList","practitionersCopy","schedulesFilteredByLocation","useGetPractitionerList","timeSlotsList","useGetAvailableLocations","availablePractitioners","practitionersFilteredBySpecialty","useGetAvailablePractitioners","handleGetPositions","useGetPositions","handleSelectSpecialtyType","useSelectSpecialtyType","handleSelectAppointmentType","useSelectAppointmentType","handleSelectLocation","foundedTimeZone","timeZoneIdOfLocation","useSelectLocation","handleSelectPractitioner","useSelectPractitioner","handleSelectTimeZone","useSelectTimeZone","handleSelectAppointmentDateTime","anyPractitioner","anyLocation","matchedTimeSlots","firstMatch","useSelectAppointmentDateTime","handleSelectWaitingListPreferredTime","useSelectWaitingListPreferredTime","handleContinueButtonClick","finished","renderSteps","stepKey","VerificationDrawer","recaptchaRef","verificationCount","setVerificationCount","verificationError","setVerificationError","recaptchaValid","setRecaptchaValid","setRecaptchaToken","submitBooking","verifyCode","useRecaptcha","handleInputChange","handleCancel","handleResend","handleConfirm","verified","count","handleVerifyRecaptcha","sitekey","render","FormInput","formKey","onValidate","maxLength","regexRule","handleBlur","DateOfBirth","dobRef","focused","setFocused","handleDocumentClick","handleFocus","handleCalendarIconClick","prevState","InputProps","inputComponent","DOBMaskedInput","onFocus","show","inputRef","inputElement","mask","Fade","Comments","HealthFund","healthFunds","MedibankCustomFields","handleCustomFieldChange","checked","Grid","container","md","xs","Checkbox","MedibankFields","MedibankFundId","healthFundValue","cardNumberValue","cardPositionValue","customFieldsValue","isMedibank","spacing","sm","ClientAddress","ClientSuburb","setData","setLoading","dataSource","geoLocationId","SuburbId","PostCode","suburbName","SuburbName","State","log","selectedLocation","ClientPostcode","FileUploader","setFiles","hideFileUploader","useDropzone","onDrop","acceptedFiles","getRootProps","getInputProps","UploadDocument","removeIndex","setRemoveIndex","setErrorText","removeFile","instruction","resetRemoveIndex","proptypes","Proptypes","array","isRequired","func","string","boolean","IntakeForm","downloadDocumentInstruction","downloadFile","DownloadFileItem","ConfirmationPolicy","customerConfirmationPolicy","MedicareInformation","numberError","expiryDateError","handleNumberChange","handleExpiryChange","handleCloseExpiry","MedicareMaskedInput","CreditCard","nameError","securityCodeError","placement","PersonalDetailsForm","firstNameValue","middleNameValue","preferredNameValue","lastNameValue","birthdayValue","mobileValue","emailValue","commentsValue","clientAddressValue","clientSuburbValue","clientPostcodeValue","errors","mobileHintDescription","isCommentsEnabled","isCommentsMandatory","isClientAddressMandatory","isClientAddressEnabled","isMedicareEnabled","isUploadDocumentEnabled","isUploadDocumentMandatory","uploadDocumentInstruction","isCreditCardMandatory","intakeFormFiles","showCreditCard","handleValidation","handleAddressFieldsValidation","addressKey","primaryKey","secondaryKey","primaryValue","secondaryValue","primaryError","secondError","currentError","SummaryListItem","notClickable","renderIcon","SummaryDesktop","links","onClickLink","onClickButton","hidingLocationEnabled","link","hidden","marginBottom","SummaryMobile","AppointmentSummary","onClickAppointmentLink","onClickAppointmentButton","hideSpecialty","getHideSpecialty","hidePractitioner","getHidePractitioner","MANDATORY_LIST","setFormValueByKey","setFormErrorTextByKey","code","onClickPlaceBooking","filesInStore","filesInStoreNames","d","fileIndex","msSaveOrOpenBlob","body","download","click","parentNode","removeChild","revokeObjectURL","medicareNumberValue","medicareExpiryValue","shouldFillingMedicareInfo","showFillingCreditCardInfo","customMandatoryList","mandatoryList","btnDisabled","errorList","mandatoryListCheck","customMandatoryListCheck","handleClickAppointmentLink","prevStep","handleClickBack","handleClickBooking","isVerifyDrawerOpen","BookingDetailsItem","getYahooCalendarUrl","yahooCalendarUrl","encodeURI","getGoogleCalendarUrl","googleCalendarUrl","printConfirmation","printContents","getElementById","popupWin","close","AddToCalendar","containerRef","setOpen","calendarAppointment","handleCalendarClick","fileDownload","prev","SpanTagItem","AtagItem","defaultStyle","makeNewBooking","waitingListConfirmationText","headerText","specialtyTypeAppointmentTypeText","appointmentStartTime","appointmentEndTime","handleClickCancel","cursor","textDecoration","CancellationReasons","reasonId","setReasonId","setReasonText","setNotes","cancelReasonList","RadioGroup","aria-label","x","focus","reason","FormControlLabel","control","Radio","multiline","rowsMax","rows","variant","HAS_APPOINTMENT_ID_IN_URL","showSuccess","reasonText","setCancelReasonList","getCancellationReasons","getConfig","getAppointmentDetails","getSpecialties","isCancelled","configResponse","specialtiesResponse","getErrorMessage","pracDictionary","locDictionary","status","reasonListInUI","reasons","DisplayOrder","Name","Id","displayOrder","handleCancelAppointment","cancellationReasonId","cancellationNotes","appointmentStartDateTime","appointmentEndDateTime","initialLoad","getPractitioners","getLocations","getTimezones","getSchedules","spread","configRes","specialtiesRes","practitionersRes","locationsRes","timezonesRes","timezones","locationTimezones","catch","hasLocationGroup","locationsFilteredBySchedules","loadedData","googleAnalyticsCode","trackingId","script1","async","script2","createGoogleAnalyticsScriptTag","renderPage","showLeftPanel","Routes","INITIAL_STATE","clearAppointmentByKeys","action","clearAppointmentObj","setLocationAndItsTimeZone","timeZoneOfLocationData","confirmationSmsText","hideSpecialties","logoFileName","isTimezoneMandatory","isMedicareMandatory","appointmentNotWithinHrs","appointmentNotAfterDays","appointmentMinCancelHrs","isNotifyPractitionerEmails","notifyPractitionerEmails","updateDataSource","updateTimeSlots","handlePositionLoad","handleSetError","newError","handleToggleVerificationDrawer","handleMakeNewBookingForForms","remainingObj","handleSetFiles","newFiles","handleRemoveFile","handleRequireWaitingList","preferredTimeObj","rootReducer","combineReducers","path","composeEnhancers","compose","store","createStore","applyMiddleware","thunk","ReactDOM"],"mappings":"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AM,2BAER,CACE3F,MAAO,uCACP2F,KAAM,0BAER,CACE3F,MAAO,uCACP2F,KAAM,cAER,CACE3F,MAAO,uCACP2F,KAAM,aAER,CACE3F,MAAO,uCACP2F,KAAM,kCAER,CACE3F,MAAO,uCACP2F,KAAM,aAER,CACE3F,MAAO,uCACP2F,KAAM,OAER,CACE3F,MAAO,uCACP2F,KAAM,wBAER,CAAE3F,MAAO,uCAAwC2F,KAAM,OACvD,CACE3F,MAAO,uCACP2F,KAAM,yBAER,CACE3F,MAAO,uCACP2F,KAAM,8CAER,CACE3F,MAAO,uCACP2F,KAAM,mBAER,CACE3F,MAAO,uCACP2F,KAAM,iBAER,CACE3F,MAAO,uCACP2F,KAAM,sDAER,CACE3F,MAAO,uCACP2F,KAAM,eAER,CACE3F,MAAO,uCACP2F,KAAM,+BAER,CACE3F,MAAO,uCACP2F,KAAM,8BAER,CACE3F,MAAO,uCACP2F,KAAM,qBAER,CACE3F,MAAO,uCACP2F,KAAM,sBAER,CACE3F,MAAO,uCACP2F,KAAM,wBAER,CACE3F,MAAO,uCACP2F,KAAM,sCAER,CACE3F,MAAO,uCACP2F,KAAM,oBAER,CACE3F,MAAO,uCACP2F,KAAM,eAER,CACE3F,MAAO,uCACP2F,KAAM,wBAER,CACE3F,MAAO,uCACP2F,KAAM,eAER,CACE3F,MAAO,uCACP2F,KAAM,+BAER,CACE3F,MAAO,uCACP2F,KAAM,2BAER,CACE3F,MAAO,uCACP2F,KAAM,iBAER,CACE3F,MAAO,uCACP2F,KAAM,iCAER,CACE3F,MAAO,uCACP2F,KAAM,4BAER,CACE3F,MAAO,uCACP2F,KAAM,sBAER,CACE3F,MAAO,uCACP2F,KAAM,kBAER,CACE3F,MAAO,uCACP2F,KAAM,oCAER,CACE3F,MAAO,uCACP2F,KAAM,yBAER,CACE3F,MAAO,uCACP2F,KAAM,+BAER,CACE3F,MAAO,uCACP2F,KAAM,8BAER,CACE3F,MAAO,uCACP2F,KAAM,wBAER,CACE3F,MAAO,uCACP2F,KAAM,YAER,CACE3F,MAAO,uCACP2F,KAAM,UD7JewhC,YACzBhL,aErCmB,CA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","file":"static/js/main.chunk.js","sourcesContent":["import { Component } from \"react\";\r\n//import { withRouter } from \"react-router-dom\";\r\n\r\nclass AppBoundary extends Component {\r\n componentDidCatch = () => {\r\n //error\r\n };\r\n static getDerivedStateFromError(error) {}\r\n\r\n componentDidUpdate = () => {\r\n const { error, success, redirect, history } = this.props;\r\n if (error) {\r\n //error\r\n }\r\n if (success) {\r\n //success\r\n }\r\n if (redirect) {\r\n history.push(redirect);\r\n }\r\n if (error || success || redirect) {\r\n //clear();\r\n }\r\n };\r\n\r\n render() {\r\n return this.props.children;\r\n }\r\n}\r\n\r\nexport default AppBoundary;\r\n","import React from \"react\";\r\n\r\nconst styles = {\r\n overlayStyle: {\r\n width: \"100%\",\r\n height: \"100%\",\r\n zIndex: \"9999\",\r\n position: \"fixed\",\r\n left: \"0\",\r\n top: \"0\",\r\n background: \"rgba(0,0,0,0.3)\"\r\n }\r\n};\r\n\r\nconst Overlay = props => {\r\n return <div style={styles.overlayStyle}>{props.children}</div>;\r\n};\r\n\r\nexport { Overlay };\r\n","import React from \"react\";\r\nimport CircularProgress from \"@material-ui/core/CircularProgress\";\r\nimport { Overlay } from \"./Overlay\";\r\nconst styles = {\r\n spinnerStyle: {\r\n position: \"fixed\",\r\n left: \"50%\",\r\n top: \"50%\",\r\n marginLeft: \"-25px\",\r\n marginTop: \"-25px\"\r\n }\r\n};\r\n\r\nconst Spinner = props => {\r\n return props.spinning ? (\r\n <Overlay>\r\n <CircularProgress size={50} thickness={4} style={styles.spinnerStyle} />\r\n </Overlay>\r\n ) : null;\r\n};\r\n\r\nexport { Spinner };\r\n","export const replaceElementByIndex = (arr, index, newElement) => {\r\n if (index >= arr.length || index < 0) return [...arr];\r\n return [...arr.slice(0, index), newElement, ...arr.slice(index + 1)];\r\n};\r\n\r\nexport const deleteElementByIndex = (arr, index) => {\r\n if (index >= arr.length || index < 0) return [...arr];\r\n return [...arr.slice(0, index), ...arr.slice(index + 1)];\r\n};\r\n\r\nexport const removeElement = (array, element) => {\r\n const index = array.indexOf(element);\r\n return deleteElementByIndex(array, index);\r\n};\r\n\r\nexport const removeElements = (array, elements) => {\r\n return elements.reduce((prev, curr) => {\r\n return removeElement(prev, curr);\r\n }, array);\r\n};\r\n\r\nexport const swapItems = (items, firstIndex, secondIndex) => {\r\n // Constant reference - we can still modify the array itself\r\n const results = items.slice();\r\n const firstItem = items[firstIndex];\r\n results[firstIndex] = items[secondIndex];\r\n results[secondIndex] = firstItem;\r\n\r\n return results;\r\n};\r\n","export const getKey = obj => {\r\n return Object.keys(obj)[0];\r\n};\r\n\r\nexport const deepGet = (obj, props, defaultValue = \"\") => {\r\n // If we have reached an undefined/null property\r\n // then stop executing and return the default value.\r\n // If no default was provided it will be undefined.\r\n if (obj === undefined || obj === null) {\r\n return defaultValue;\r\n }\r\n\r\n // If the path array has no more elements, we've reached\r\n // the intended property and return its value\r\n if (props.length === 0) {\r\n return obj;\r\n }\r\n\r\n // Prepare our found property and path array for recursion\r\n const foundSoFar = obj[props[0]];\r\n const remainingProps = props.slice(1);\r\n\r\n return deepGet(foundSoFar, remainingProps, defaultValue);\r\n};\r\nexport const isGuid = value => {\r\n var regex = /[a-f0-9]{8}(?:-[a-f0-9]{4}){3}-[a-f0-9]{12}/i;\r\n var match = regex.exec(value);\r\n return match != null;\r\n};\r\n\r\nexport const getValueOrDefault = (obj, key, defaultVal = \"\") => {\r\n if (obj === null || typeof obj === \"undefined\") return defaultVal;\r\n\r\n let returnVal = obj[key];\r\n\r\n if (\r\n typeof returnVal === \"undefined\" ||\r\n returnVal === null ||\r\n returnVal === \"\"\r\n ) {\r\n return defaultVal;\r\n }\r\n return obj[key];\r\n};\r\n\r\nexport const deepAssign = (initial, value, keys) => {\r\n if (keys.length === 1) {\r\n const key = keys[0];\r\n return { ...initial, [key]: value };\r\n }\r\n\r\n const getByKeys = (keys, initial) => {\r\n const currentVal = keys.reduce((current, key) => {\r\n return current[key];\r\n }, initial);\r\n const firstKey = keys.reverse()[0];\r\n return { [firstKey]: currentVal };\r\n };\r\n\r\n let index = 0;\r\n return keys.reduce((current, key) => {\r\n const currentIndex = keys.length - index - 1;\r\n const remainingKeys = keys.slice(0, currentIndex);\r\n const currentKey = keys[currentIndex];\r\n\r\n if (currentIndex - 1 >= 0) {\r\n const parentKey = keys[currentIndex - 1];\r\n let parentProp = getByKeys(remainingKeys, initial);\r\n const currentValue = index === 0 ? value : current[currentKey];\r\n const props = { ...parentProp[parentKey], [currentKey]: currentValue };\r\n index++;\r\n return { [parentKey]: props };\r\n } else {\r\n return { ...initial, ...current };\r\n }\r\n }, {});\r\n};\r\n","export const arrayToQueryString = (array, key) => {\r\n return array.map(a => `${key}=${a}`).join(\"&\");\r\n};\r\n\r\nexport const toQueryString = paramsObject => {\r\n return Object.keys(paramsObject)\r\n .filter(key => paramsObject[key] != null)\r\n .map(\r\n key =>\r\n `${encodeURIComponent(key)}=${encodeURIComponent(paramsObject[key])}`\r\n )\r\n .join(\"&\");\r\n};\r\n\r\nexport const getParameterByName = (name, url) => {\r\n if (!url) url = window.location.href;\r\n name = name.replace(/[[\\]]/g, \"\\\\$&\");\r\n var regex = new RegExp(\"[?&]\" + name.toLowerCase() + \"(=([^&#]*)|&|#|$)\"),\r\n results = regex.exec(url.toLowerCase());\r\n if (!results) return null;\r\n if (!results[2]) return \"\";\r\n return decodeURIComponent(results[2].replace(/\\+/g, \" \"));\r\n};\r\n","const checkZero = data => {\r\n if (data.toString().length === 1) {\r\n data = \"0\" + data;\r\n }\r\n return data;\r\n};\r\n\r\nexport const isSameDay = (day1, day2) => {\r\n if (!day1 || !day2) return false;\r\n return (\r\n day1.getDate() === day2.getDate() &&\r\n day1.getMonth() === day2.getMonth() &&\r\n day1.getFullYear() === day2.getFullYear()\r\n );\r\n};\r\n\r\nexport const isSameMonth = (day1, day2) => {\r\n return (\r\n day1.getMonth() === day2.getMonth() &&\r\n day1.getFullYear() === day2.getFullYear()\r\n );\r\n};\r\n\r\nexport const isDayIncluded = (day, days) => {\r\n return days.some(d => isSameDay(d, day));\r\n};\r\n\r\nexport const getDatePart = day => {\r\n return new Date(day.getFullYear(), day.getMonth(), day.getDate());\r\n};\r\n\r\nexport const getYearMonthPart = day => {\r\n return new Date(day.getFullYear(), day.getMonth());\r\n};\r\n\r\nexport const formatDate = day => {\r\n return (\r\n checkZero(day.getDate()) +\r\n \"/\" +\r\n checkZero(day.getMonth() + 1) +\r\n \"/\" +\r\n day.getFullYear()\r\n );\r\n};\r\n\r\nexport const formatMoment = moment => {\r\n return moment.format(\"YYYY-MM-DDTHH:mm:ss\");\r\n};\r\n\r\nexport const getDistinctDateFormats = (moments, format) => {\r\n return moments\r\n .map(moment => moment.format(format))\r\n .reduce((current, next) => {\r\n if (!current.includes(next)) {\r\n current.push(next);\r\n }\r\n return current;\r\n }, []);\r\n};\r\n","export const isMobileDevice = () => {\r\n if (\r\n /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(\r\n navigator.userAgent\r\n )\r\n ) {\r\n return true;\r\n }\r\n return false;\r\n};\r\n\r\nexport const isIOSDevice =\r\n /iPad|iPhone|iPod/.test(navigator.userAgent) && !window.MSStream;\r\n\r\nexport const detectIE = () => {\r\n var ua = window.navigator.userAgent;\r\n\r\n // Test values; Uncomment to check result …\r\n\r\n // IE 10\r\n // ua = 'Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; Trident/6.0)';\r\n\r\n // IE 11\r\n // ua = 'Mozilla/5.0 (Windows NT 6.3; Trident/7.0; rv:11.0) like Gecko';\r\n\r\n // Edge 12 (Spartan)\r\n // ua = 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/39.0.2171.71 Safari/537.36 Edge/12.0';\r\n\r\n // Edge 13\r\n // ua = 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/46.0.2486.0 Safari/537.36 Edge/13.10586';\r\n\r\n var msie = ua.indexOf(\"MSIE \");\r\n if (msie > 0) {\r\n // IE 10 or older => return version number\r\n return true;\r\n }\r\n\r\n var trident = ua.indexOf(\"Trident/\");\r\n if (trident > 0) {\r\n // IE 11 => return version number\r\n return true;\r\n }\r\n\r\n var edge = ua.indexOf(\"Edge/\");\r\n if (edge > 0) {\r\n // Edge (IE 12+) => return version number\r\n return true;\r\n }\r\n\r\n // other browser\r\n return false;\r\n};\r\n","export const blurInputWhenTypeEnter = e => {\r\n if (e.which === 13 && document.activeElement === e.target) {\r\n e.target.blur();\r\n }\r\n};\r\n\r\n// copy text to Clipboard\r\nexport function copyTextToClipboard(text, cb = () => {}) {\r\n if (!navigator.clipboard) {\r\n fallbackCopyTextToClipboard(text, cb);\r\n return;\r\n }\r\n navigator.clipboard.writeText(text).then(\r\n function() {\r\n //console.log(\"Async: Copying to clipboard was successful!\");\r\n cb();\r\n },\r\n function(err) {\r\n console.error(\"Async: Could not copy text: \", err);\r\n }\r\n );\r\n}\r\n\r\n// for browsers which does not support navigator.clipboard\r\nfunction fallbackCopyTextToClipboard(text, cb = () => {}) {\r\n var textArea = document.createElement(\"textarea\");\r\n textArea.value = text;\r\n document.body.appendChild(textArea);\r\n textArea.focus();\r\n textArea.select();\r\n try {\r\n document.execCommand(\"copy\");\r\n //var msg = successful ? \"successful\" : \"unsuccessful\";\r\n //console.log(\"Fallback: Copying text command was \" + msg);\r\n cb();\r\n } catch (err) {\r\n console.error(\"Fallback: Oops, unable to copy\", err);\r\n }\r\n document.body.removeChild(textArea);\r\n}\r\n\r\nexport function insertAtCursor(input, textToInsert, currentValue) {\r\n let value = currentValue == null ? input.value : currentValue;\r\n\r\n const start = input.selectionStart;\r\n const end = input.selectionEnd;\r\n\r\n value = value.slice(0, start) + textToInsert + value.slice(end);\r\n if (currentValue == null) {\r\n input.value = value;\r\n }\r\n input.selectionStart = input.selectionEnd = start + textToInsert.length;\r\n return value;\r\n}\r\n\r\nexport function darkenColor(hexCode, amt = 10) {\r\n if (hexCode[0] !== \"#\") {\r\n return hexCode;\r\n }\r\n var col = hexCode.slice(1);\r\n if (col.length === 3) {\r\n col = col\r\n .split(\"\")\r\n .map(function(hex) {\r\n return hex + hex;\r\n })\r\n .join(\"\");\r\n }\r\n return darken(col, amt);\r\n}\r\n\r\nfunction darken(color, amount) {\r\n color = color.indexOf(\"#\") >= 0 ? color.substring(1, color.length) : color;\r\n amount = parseInt((255 * amount) / 100);\r\n return (color =\r\n \"#\" +\r\n subtractLight(color.substring(0, 2), amount) +\r\n subtractLight(color.substring(2, 4), amount) +\r\n subtractLight(color.substring(4, 6), amount));\r\n}\r\n\r\nfunction subtractLight(color, amount) {\r\n var colorHex = parseInt(color, 16) - amount;\r\n var colorResult = colorHex < 0 ? 0 : colorHex;\r\n colorResult =\r\n colorResult.toString(16).length > 1\r\n ? colorResult.toString(16)\r\n : \"0\" + colorResult.toString(16);\r\n return colorResult;\r\n}\r\n\r\nexport function lightenColor(color, amount = 20) {\r\n color = color.indexOf(\"#\") >= 0 ? color.substring(1, color.length) : color;\r\n amount = parseInt((255 * amount) / 100);\r\n return (color = `#${addLight(color.substring(0, 2), amount)}${addLight(\r\n color.substring(2, 4),\r\n amount\r\n )}${addLight(color.substring(4, 6), amount)}`);\r\n}\r\n\r\nfunction addLight(color, amount) {\r\n let cc = parseInt(color, 16) + amount;\r\n let c = cc > 255 ? 255 : cc;\r\n c = c.toString(16).length > 1 ? c.toString(16) : `0${c.toString(16)}`;\r\n return c;\r\n}\r\n\r\nlet requestAnimationFrame =\r\n window.requestAnimationFrame ||\r\n window.mozRequestAnimationFrame ||\r\n window.webkitRequestAnimationFrame ||\r\n window.msRequestAnimationFrame;\r\nif (!requestAnimationFrame) {\r\n requestAnimationFrame = window.setTimeout;\r\n}\r\nrequestAnimationFrame = window.setTimeout;\r\nwindow.requestAnimationFrame = requestAnimationFrame;\r\n\r\nexport const elementScrollTop = (identifier, destination, adjustment = 0) => {\r\n scrollTo(\r\n document.querySelector(identifier),\r\n document.querySelector(destination).offsetTop + adjustment,\r\n 30\r\n );\r\n};\r\n\r\nconst scrollTo = (element, to, duration) => {\r\n if (\r\n duration <= 0 ||\r\n (element.scrollHeight - element.clientHeight > 0 &&\r\n element.scrollTop === element.scrollHeight - element.clientHeight)\r\n ) {\r\n return;\r\n }\r\n\r\n var difference = to - element.scrollTop;\r\n var perTick = (difference / duration) * 1;\r\n\r\n requestAnimationFrame(() => {\r\n element.scrollTop += perTick;\r\n scrollTo(element, to, duration - 1);\r\n });\r\n};\r\n\r\nexport const getDomStyleProperty = (dom, property) => {\r\n return window.getComputedStyle(dom, null).getPropertyValue(property);\r\n};\r\n\r\nexport const getDocumentDom = identifier => {\r\n return document.querySelector(identifier);\r\n};\r\n\r\nexport const isLightColor = hexcolor => {\r\n // If a leading # is provided, remove it\r\n if (hexcolor.slice(0, 1) === \"#\") {\r\n hexcolor = hexcolor.slice(1);\r\n }\r\n\r\n // If a three-character hexcode, make six-character\r\n if (hexcolor.length === 3) {\r\n hexcolor = hexcolor\r\n .split(\"\")\r\n .map(function(hex) {\r\n return hex + hex;\r\n })\r\n .join(\"\");\r\n }\r\n\r\n // Convert to RGB value\r\n var r = parseInt(hexcolor.substr(0, 2), 16);\r\n var g = parseInt(hexcolor.substr(2, 2), 16);\r\n var b = parseInt(hexcolor.substr(4, 2), 16);\r\n\r\n // Get YIQ ratio\r\n var yiq = (r * 299 + g * 587 + b * 114) / 1000;\r\n\r\n // Check contrast\r\n return yiq >= 180;\r\n};\r\n","import React, { memo, useMemo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport Dialog from \"@material-ui/core/Dialog\";\r\nimport { deepGet } from \"../../../utils\";\r\nimport \"./Notification.less\";\r\n\r\nexport const Notification = memo(props => {\r\n const { error, success, clear } = props;\r\n const isError = !!error && !success;\r\n const message = isError ? error : success;\r\n\r\n const messageInUI = useMemo(\r\n () => (typeof message === \"string\" ? { text: message } : message),\r\n [message]\r\n );\r\n const canDismiss = deepGet(messageInUI, [\"canDismiss\"], false);\r\n return (\r\n <Dialog\r\n classes={{\r\n root: \"zindex-message\",\r\n paperScrollPaper: \"notification-container\"\r\n }}\r\n open={!!message}\r\n >\r\n <div className=\"notification-content\">\r\n {!!message && (\r\n <div className=\"notification-content-text\">\r\n <i\r\n className={`material-icons ${\r\n isError ? \"red-color\" : \"green-color\"\r\n }`}\r\n >\r\n {isError ? \"close\" : \"done\"}\r\n </i>\r\n {deepGet(messageInUI, [\"text\"])}\r\n </div>\r\n )}\r\n\r\n {canDismiss && (\r\n <div className=\"notification-content-button\">\r\n <button\r\n className={`${isError ? \"red-button\" : \"green-button\"}`}\r\n onClick={clear}\r\n >\r\n Ok\r\n </button>\r\n </div>\r\n )}\r\n </div>\r\n </Dialog>\r\n );\r\n});\r\n\r\nNotification.propTypes = {\r\n error: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),\r\n success: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),\r\n clear: PropTypes.func\r\n};\r\n","export const csvManager = (function() {\r\n var objectToCSVRow = function(dataObject) {\r\n var dataArray = [];\r\n for (var o in dataObject) {\r\n var innerValue = dataObject[o] === null ? \"\" : dataObject[o].toString();\r\n var result = innerValue.replace(/\"/g, '\"\"').replace(/(<([^>]+)>)/gi, \" \");\r\n if (result.search(/(\"|,|\\n)/g) >= 0) result = '\"' + result + '\"';\r\n dataArray.push(result);\r\n }\r\n\r\n return dataArray.join(\",\") + \"\\r\\n\";\r\n };\r\n\r\n var exportToCSV = function(arrayOfObjects) {\r\n if (!arrayOfObjects.length) {\r\n return;\r\n }\r\n\r\n var csvContent = \"data:text/csv;charset=utf-8,\";\r\n\r\n // headers\r\n csvContent += objectToCSVRow(Object.keys(arrayOfObjects[0]));\r\n\r\n arrayOfObjects.forEach(function(item) {\r\n csvContent += objectToCSVRow(item);\r\n });\r\n\r\n var encodedUri = encodeURI(csvContent);\r\n\r\n var link = document.createElement(\"a\");\r\n link.setAttribute(\"href\", encodedUri);\r\n link.setAttribute(\"download\", \"waitinglist.csv\");\r\n document.body.appendChild(link); // Required for FF\r\n link.click();\r\n document.body.removeChild(link);\r\n };\r\n\r\n return {\r\n exportToCSV\r\n };\r\n})();\r\n","export const APP_ACTION = {\r\n SHOW_ERROR: \"app_action_show_error\",\r\n SHOW_SUCCESS: \"app_action_show_success\",\r\n CLEAR: \"app_action_clear\",\r\n LOADING: \"app_action_loading\",\r\n REDIRECT: \"app_action_redirect\"\r\n};\r\n","import { APP_ACTION } from './types';\r\n\r\nexport const updatePageHeader = pageHeader => {\r\n return {\r\n type: APP_ACTION.UPDATE_PAGE_HEADER,\r\n payload: { pageHeader }\r\n };\r\n};\r\n\r\nexport const loading = (loading = true) => {\r\n return { type: APP_ACTION.LOADING, payload: { loading } };\r\n};\r\n\r\nexport const showError = error => {\r\n return { type: APP_ACTION.SHOW_ERROR, payload: { error } };\r\n};\r\n\r\nexport const showSuccess = success => {\r\n return { type: APP_ACTION.SHOW_SUCCESS, payload: { success } };\r\n};\r\n\r\nexport const redirect = path => {\r\n return {\r\n type: APP_ACTION.REDIRECT,\r\n payload: { path }\r\n };\r\n};\r\n\r\nexport const clear = () => {\r\n return { type: APP_ACTION.CLEAR };\r\n};\r\n\r\nexport * from './types';\r\n","export const STEP_KEYS = {\r\n SPECIALTY_TYPE: \"specialtyType\",\r\n APPOINTMENT_TYPE: \"appointmentType\",\r\n PRACTITIONER: \"practitioner\",\r\n LOCATION: \"location\",\r\n TIMEZONE: \"timezone\",\r\n APPOINTMENT_DATE_TIME: \"appointmentDateTime\"\r\n};\r\n","import {\r\n darkenColor,\r\n isLightColor\r\n //lightenColor\r\n} from \"../../../utils\";\r\n\r\nconst themeString = sessionStorage.getItem(\"clientPortalTheme\");\r\nlet themeColor = \"#ed135d\";\r\nlet headerTheme = \"#ffffff\";\r\nif (themeString) {\r\n try {\r\n const themeJson = JSON.parse(themeString);\r\n themeColor = themeJson[\"themeColor\"];\r\n headerTheme = themeJson[\"headerTheme\"];\r\n } catch (e) {}\r\n}\r\nconst THEME_COLOR = themeColor;\r\nconst THEME_COLOR_HOVER = darkenColor(THEME_COLOR);\r\nconst THEME_COLOR_HEADER = headerTheme;\r\n\r\nconst IS_LIGHT_THEME = isLightColor(THEME_COLOR);\r\nconst IS_LIGHT_HEADER = isLightColor(THEME_COLOR_HEADER);\r\n\r\nexport {\r\n THEME_COLOR,\r\n THEME_COLOR_HOVER,\r\n THEME_COLOR_HEADER,\r\n IS_LIGHT_THEME,\r\n IS_LIGHT_HEADER\r\n};\r\n","export const FORM_KEYS = {\r\n FIRST_NAME: 'firstName',\r\n MIDDLE_NAME: 'middleName',\r\n PREFERRED_NAME: 'preferredName',\r\n LAST_NAME: 'lastName',\r\n DATE_OF_BIRTH: 'dateOfBirth',\r\n EMAIL: 'email',\r\n MOBILE: 'mobile',\r\n COMMENTS: 'comments',\r\n CLIENT_ADDRESS: 'clientAddress',\r\n CLIENT_SUBURB: 'clientSuburb',\r\n CLIENT_POSTCODE: 'clientPostcode',\r\n HEALTH_FUND: 'healthFund',\r\n CARD_NUMBER: 'cardNumber',\r\n CARD_POSITION: 'cardPosition',\r\n CUSTOM_FIELDS: 'customFields',\r\n FILES: 'files',\r\n MEDICARE_NUMBER: 'medicareNumber',\r\n MEDICARE_EXPIRY: 'medicareExpiry',\r\n CREDIT_CARD_NUMBER: 'creditCardNumber',\r\n CREDIT_CARD_EXPIRY: 'creditCardExpiry',\r\n CREDIT_CARD_NAME: 'creditCardName',\r\n CREDIT_CARD_SECURITY_CODE: 'creditCardSecurityCode'\r\n};\r\n","export const PAGE_KEYS = {\r\n BOOKING: \"booking\",\r\n CONTACT: \"contact\",\r\n CONFIRM: \"confirm\",\r\n CANCELLATION: \"cancellation\"\r\n};\r\n","export * from './stepKeys';\r\nexport * from './themeColor';\r\nexport * from './formKeys';\r\nexport * from './pageKeys';\r\n\r\nexport const ANY_SELECTION = 'ANY';\r\n\r\nexport const CANCELLATION_OTHER_REASON_ID =\r\n '00000000-0000-0000-0000-000000000000';\r\n\r\nexport const MAX_FILE_SIZE = 10 * 1024 * 1024;\r\nexport const MAX_FILE_NUMBER = 5;\r\n\r\nexport const VALID_FILE_EXTENSION = [\r\n 'pdf',\r\n 'jpg',\r\n 'jpeg',\r\n 'png',\r\n 'gif',\r\n 'doc',\r\n 'docx',\r\n 'rtf',\r\n 'html',\r\n 'txt',\r\n 'msg',\r\n 'pages'\r\n];\r\nexport const SUPPORTED_FILE_TEXT = VALID_FILE_EXTENSION.map(extension =>\r\n extension.toUpperCase()\r\n).join(', ');\r\n\r\nexport const DETECT_DUPLICATE_FILE_NAME_NUMBER = /.?\\(\\d+\\)$/g; // 123(10)\r\n\r\nexport const DEFAULT_FILE_ASSOCIATION_TYPE =\r\n '2fc3c52d-752b-4ace-8418-9ecdd9f298d0';\r\nexport const DEFAULT_FILE_ASSOCIATION_ENTITY = 'Appointment';\r\n\r\nexport const ONLINE_PAYMENT_KEY_NAME = 'PublishableApiKey';\r\nexport const ONLINE_PAYMENT_IS_TEST = 'IsTest';\r\n","import React from \"react\";\r\nimport { connect } from \"react-redux\";\r\nimport { ThemeProvider, createMuiTheme } from \"@material-ui/core/styles\";\r\nimport AppBoundary from \"./components/AppBoundary\";\r\nimport { Spinner } from \"./components/Spinner\";\r\nimport { Notification } from \"./components/Notification\";\r\nimport { clear } from \"./actions\";\r\nimport { THEME_COLOR } from \"../ClientPortal/constants\";\r\n\r\nconst App = props => {\r\n const { error, success, loading, redirect, clear, children } = props;\r\n\r\n const outerTheme = createMuiTheme({\r\n palette: {\r\n primary: {\r\n main: THEME_COLOR\r\n }\r\n }\r\n });\r\n return (\r\n <ThemeProvider theme={outerTheme}>\r\n <div>\r\n <Notification error={error} success={success} clear={clear} />\r\n <Spinner spinning={loading} />\r\n <AppBoundary\r\n error={error}\r\n success={success}\r\n redirect={redirect}\r\n clear={clear}\r\n >\r\n {children}\r\n </AppBoundary>\r\n </div>\r\n </ThemeProvider>\r\n );\r\n};\r\n\r\nexport default connect(\r\n state => {\r\n return { ...state.app };\r\n },\r\n { clear }\r\n)(App);\r\n","import { useState, useCallback, useRef, useEffect } from \"react\";\r\n// Hook\r\n// Hook\r\nexport function useHover() {\r\n const [value, setValue] = useState(false);\r\n\r\n const ref = useRef(null);\r\n\r\n const handleMouseEnter = useCallback(() => {\r\n !value && setValue(true);\r\n }, [value]);\r\n const handleMouseLeave = useCallback(() => value && setValue(false), [value]);\r\n\r\n useEffect(\r\n () => {\r\n const node = ref.current;\r\n if (node) {\r\n node.addEventListener(\"mouseenter\", handleMouseEnter);\r\n node.addEventListener(\"mouseleave\", handleMouseLeave);\r\n\r\n return () => {\r\n node.removeEventListener(\"mouseenter\", handleMouseEnter);\r\n node.removeEventListener(\"mouseleave\", handleMouseLeave);\r\n };\r\n }\r\n },\r\n [handleMouseEnter, handleMouseLeave] // Recall only if ref changes\r\n );\r\n\r\n return [ref, value];\r\n}\r\n","import { useEffect, useState } from \"react\";\r\n\r\nconst MobileMaxWidth = 767;\r\n\r\nexport function useCheckMobile() {\r\n const [isMobile, setIsMobile] = useState(\r\n () => window.innerWidth <= MobileMaxWidth\r\n );\r\n\r\n const onWindowSizeChange = () => {\r\n const width = window.innerWidth;\r\n setIsMobile(width <= MobileMaxWidth);\r\n };\r\n\r\n useEffect(() => {\r\n window.addEventListener(\"resize\", onWindowSizeChange);\r\n return () => window.removeEventListener(\"resize\", onWindowSizeChange);\r\n }, []);\r\n\r\n return isMobile;\r\n}\r\n","import React, { memo } from 'react';\r\nimport Icon from '@material-ui/core/Icon';\r\n\r\nexport const ListIcon = memo(props => {\r\n return <MaterialUIIcon iconKey=\"list\" {...props} />;\r\n});\r\n\r\nexport const ArrowDownIcon = memo(props => {\r\n return <MaterialUIIcon iconKey=\"keyboard_arrow_down\" {...props} />;\r\n});\r\n\r\nexport const ArrowTopIcon = memo(props => {\r\n return <MaterialUIIcon iconKey=\"keyboard_arrow_up\" {...props} />;\r\n});\r\n\r\nexport const DoneIcon = memo(props => {\r\n return <MaterialUIIcon iconKey=\"done\" {...props} />;\r\n});\r\n\r\nexport const CloseIcon = memo(props => {\r\n return <MaterialUIIcon iconKey=\"close\" {...props} />;\r\n});\r\n\r\nexport const InfoIcon = memo(props => {\r\n return <MaterialUIIcon iconKey=\"info\" {...props} />;\r\n});\r\n\r\nexport const PhoneIcon = memo(props => {\r\n return <MaterialUIIcon iconKey=\"phone\" {...props} />;\r\n});\r\n\r\nexport const EditIcon = memo(props => {\r\n return <MaterialUIIcon iconKey=\"mode_edit\" {...props} />;\r\n});\r\n\r\nexport const CalendarIcon = memo(props => {\r\n return <MaterialUIIcon iconKey=\"date_range\" {...props} />;\r\n});\r\n\r\nexport const CreditCardIcon = memo(props => {\r\n return <MaterialUIIcon iconKey=\"credit_card\" {...props} />;\r\n});\r\n\r\nexport const HelpIcon = memo(props => {\r\n return <MaterialUIIcon iconKey=\"help\" {...props} />;\r\n});\r\n\r\nexport const MaterialUIIcon = memo(({ iconKey, ...restProps }) => {\r\n return <Icon {...restProps}>{iconKey}</Icon>;\r\n});\r\n","import React, { memo, useState } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\n\r\nexport const PageLogo = memo(props => {\r\n const [error, setError] = useState(\"\");\r\n const { tenant } = props;\r\n if (!tenant || error) return null;\r\n return (\r\n <img\r\n src={`/${tenant}/api/portalsettings/LogoImage`}\r\n alt=\"logo\"\r\n onError={() => setError(\"load logo failed\")}\r\n />\r\n );\r\n});\r\n\r\nPageLogo.propTypes = {\r\n tenant: PropTypes.string\r\n};\r\n","import React, { createContext, memo, useState } from \"react\";\r\n\r\nexport const DrawerContext = createContext();\r\n\r\nexport const DrawerContextProvider = memo(({ children }) => {\r\n const [drawerOpen, setDrawerOpen] = useState(false);\r\n return (\r\n <DrawerContext.Provider value={{ drawerOpen, setDrawerOpen }}>\r\n {children}\r\n </DrawerContext.Provider>\r\n );\r\n});\r\n","import React, {\r\n memo,\r\n useState,\r\n useCallback,\r\n useEffect,\r\n useRef,\r\n useContext\r\n} from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport Headroom from \"react-headroom\";\r\nimport { PhoneIcon } from \"../Icon\";\r\nimport { PageLogo } from \"./PageLogo\";\r\nimport { DrawerContext } from \"../../context/DrawerContext\";\r\nimport { THEME_COLOR_HEADER, IS_LIGHT_HEADER } from \"../../constants\";\r\n\r\nconst headerBgColor = { background: THEME_COLOR_HEADER };\r\nconst contrastColor = IS_LIGHT_HEADER ? \"#333\" : \"#fafafa\";\r\nconst fontColor = { color: contrastColor };\r\nconst infoIconStyle = { color: contrastColor, borderColor: contrastColor };\r\nconst infoIconStyleOpen = {\r\n color: THEME_COLOR_HEADER,\r\n borderColor: contrastColor,\r\n background: contrastColor\r\n};\r\nconst phoneIconStyle = { color: contrastColor };\r\n\r\nexport const PageHeaderMobile = memo(props => {\r\n const menuRef = useRef();\r\n const scrollRecordRef = useRef(window.scrollY);\r\n const [openSubMenu, setOpenSubMenu] = useState(false);\r\n const { drawerOpen } = useContext(DrawerContext);\r\n const {\r\n tenant,\r\n displayPhoneNumber,\r\n customerTermsUrl,\r\n customerPrivacyPolicyUrl,\r\n businessName,\r\n isLogoOrBusinessName\r\n } = props;\r\n\r\n const handleClick = useCallback(\r\n event => {\r\n if (!openSubMenu) return;\r\n const targetDom = event.target;\r\n if (menuRef.current.contains(targetDom)) {\r\n return;\r\n }\r\n\r\n setOpenSubMenu(false);\r\n },\r\n [openSubMenu]\r\n );\r\n\r\n const handleScroll = useCallback(\r\n e => {\r\n if (!openSubMenu) return;\r\n const windowScrollY = window.scrollY;\r\n const diff = Math.abs(windowScrollY - scrollRecordRef.current);\r\n if (diff > 20) {\r\n setOpenSubMenu(false);\r\n }\r\n },\r\n [openSubMenu]\r\n );\r\n useEffect(() => {\r\n document.addEventListener(\"click\", handleClick, false);\r\n document.addEventListener(\"scroll\", handleScroll, false);\r\n return () => {\r\n document.removeEventListener(\"click\", handleClick, false);\r\n document.removeEventListener(\"scroll\", handleScroll, false);\r\n };\r\n }, [handleClick, handleScroll]);\r\n\r\n const businessNameFontStyle =\r\n businessName && businessName.length > 40\r\n ? {\r\n fontSize: \"1em\"\r\n }\r\n : {};\r\n\r\n return (\r\n <Headroom\r\n className={`client-portal-headroom ${drawerOpen ? \"fixed-headroom\" : \"\"}`}\r\n >\r\n <div className=\"page-header-small\" style={headerBgColor}>\r\n <div className=\"page-header-small-left\">\r\n {!isLogoOrBusinessName ? (\r\n <PageLogo tenant={tenant} />\r\n ) : (\r\n <span\r\n className=\"page-header-small-left-title\"\r\n style={{ ...fontColor, ...businessNameFontStyle }}\r\n >\r\n {businessName}\r\n </span>\r\n )}\r\n </div>\r\n <div className=\"page-header-small-right\">\r\n <div className=\"page-header-small-right-icons\">\r\n <span\r\n className=\"page-header-small-right-icons-info\"\r\n onClick={(e) => {\r\n e.stopPropagation();\r\n setOpenSubMenu(prevOpen => !prevOpen);\r\n }}\r\n style={openSubMenu ? infoIconStyleOpen : infoIconStyle}\r\n >\r\n i\r\n </span>\r\n {displayPhoneNumber && (\r\n <a\r\n className=\"page-header-small-right-icons-phone-tag\"\r\n href={`tel:${displayPhoneNumber}`}\r\n style={phoneIconStyle}\r\n >\r\n <PhoneIcon className=\"page-header-small-right-icons-phone\" />\r\n </a>\r\n )}\r\n </div>\r\n </div>\r\n <div\r\n className={`page-header-small-submenu ${openSubMenu ? \"open\" : \"\"}`}\r\n ref={menuRef}\r\n >\r\n <h2 className=\"page-header-small-submenu-top\">\r\n <span className=\"page-header-small-submenu-top-text\">\r\n Can't find the time you want?\r\n </span>\r\n <span className=\"page-header-small-submenu-top-phone\">\r\n {displayPhoneNumber}\r\n </span>\r\n </h2>\r\n <ul className=\"page-header-small-submenu-bottom\">\r\n {customerTermsUrl && (\r\n <li>\r\n <a\r\n href={customerTermsUrl}\r\n target=\"_blank\"\r\n rel=\"noopener noreferrer\"\r\n >\r\n Terms & Conditions\r\n </a>\r\n </li>\r\n )}\r\n {customerPrivacyPolicyUrl && (\r\n <li>\r\n <span className=\"page-header-small-submenu-bottom-divider\"></span>\r\n <a\r\n href={customerPrivacyPolicyUrl}\r\n target=\"_blank\"\r\n rel=\"noopener noreferrer\"\r\n >\r\n Privacy Policy\r\n </a>\r\n </li>\r\n )}\r\n </ul>\r\n <svg\r\n className=\"page-header-small-submenu-icon\"\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n viewBox=\"0 0 10 10\"\r\n width={15}\r\n height={15}\r\n >\r\n <polygon points=\"0,0 5,10 10,0\" fill={THEME_COLOR_HEADER} />\r\n </svg>\r\n </div>\r\n </div>\r\n </Headroom>\r\n );\r\n});\r\n\r\nPageHeaderMobile.propTypes = {\r\n logo: PropTypes.string,\r\n displayPhoneNumber: PropTypes.string,\r\n customerTermsUrl: PropTypes.string,\r\n customerPrivacyPolicyUrl: PropTypes.string,\r\n businessName: PropTypes.string,\r\n isLogoOrBusinessName: PropTypes.number\r\n};\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { PageLogo } from \"./PageLogo\";\r\nimport { THEME_COLOR_HEADER, IS_LIGHT_HEADER } from \"../../constants\";\r\n\r\nconst headerBgColor = { background: THEME_COLOR_HEADER };\r\nconst contrastColor = IS_LIGHT_HEADER ? \"#333\" : \"#fafafa\";\r\nconst fontColor = { color: contrastColor };\r\nconst bgColor = { background: contrastColor };\r\n\r\nexport const PageHeaderDesktop = memo(props => {\r\n const {\r\n tenant,\r\n displayPhoneNumber,\r\n customerTermsUrl,\r\n customerPrivacyPolicyUrl,\r\n businessName,\r\n isLogoOrBusinessName\r\n } = props;\r\n\r\n const businessNameFontStyle =\r\n businessName && businessName.length > 40\r\n ? {\r\n fontSize: \"1.2em\"\r\n }\r\n : {};\r\n\r\n return (\r\n <div className=\"head-wrapper\">\r\n <div className=\"page-header postion-fixed\" style={headerBgColor}>\r\n <div className=\"page-header-left\">\r\n {!isLogoOrBusinessName ? (\r\n <PageLogo tenant={tenant} />\r\n ) : (\r\n <span\r\n className=\"page-header-left-title\"\r\n style={{ ...fontColor, ...businessNameFontStyle }}\r\n >\r\n {businessName}\r\n </span>\r\n )}\r\n </div>\r\n <div className=\"page-header-right\">\r\n <h2 className=\"page-header-right-top\" style={fontColor}>\r\n <span className=\"page-header-right-top-text\">\r\n Can't find the time you want?\r\n </span>\r\n <span className=\"page-header-right-top-phone\">\r\n {displayPhoneNumber}\r\n </span>\r\n </h2>\r\n <ul className=\"page-header-right-bottom\">\r\n {customerTermsUrl && (\r\n <li>\r\n <a\r\n href={customerTermsUrl}\r\n target=\"_blank\"\r\n rel=\"noopener noreferrer\"\r\n style={fontColor}\r\n >\r\n Terms & Conditions\r\n </a>\r\n </li>\r\n )}\r\n {customerPrivacyPolicyUrl && (\r\n <li>\r\n <span\r\n className=\"page-header-right-bottom-divider\"\r\n style={bgColor}\r\n ></span>\r\n <a\r\n href={customerPrivacyPolicyUrl}\r\n target=\"_blank\"\r\n rel=\"noopener noreferrer\"\r\n style={fontColor}\r\n >\r\n Privacy Policy\r\n </a>\r\n </li>\r\n )}\r\n </ul>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n});\r\n\r\nPageHeaderDesktop.propTypes = {\r\n logo: PropTypes.string,\r\n displayPhoneNumber: PropTypes.string,\r\n customerTermsUrl: PropTypes.string,\r\n customerPrivacyPolicyUrl: PropTypes.string,\r\n businessName: PropTypes.string,\r\n isLogoOrBusinessName: PropTypes.number\r\n};\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { useCheckMobile } from \"../../hooks\";\r\nimport { PageHeaderMobile } from \"./PageHeaderMobile\";\r\nimport { PageHeaderDesktop } from \"./PageHeaderDesktop\";\r\nimport \"./pageHeader.less\";\r\n\r\nexport const PageHeader = memo(props => {\r\n const isMobile = useCheckMobile();\r\n\r\n return isMobile ? (\r\n <PageHeaderMobile {...props} />\r\n ) : (\r\n <PageHeaderDesktop {...props} />\r\n );\r\n});\r\n\r\nPageHeader.propTypes = {\r\n tenant: PropTypes.string,\r\n displayPhoneNumber: PropTypes.string,\r\n customerTermsUrl: PropTypes.string,\r\n customerPrivacyPolicyUrl: PropTypes.string,\r\n businessName: PropTypes.string,\r\n isLogoOrBusinessName: PropTypes.number\r\n};\r\n","export default __webpack_public_path__ + \"static/media/28989_logo_main - horizontal.png\";","import React, { memo, useMemo } from \"react\";\r\nimport { useCheckMobile } from \"../../hooks\";\r\nimport coreplusLogo from \"../../../../assets/images/28989_logo_main - horizontal.png\";\r\nimport coreplusLogoSmall from \"../../../../assets/images/coreplus-logo-small.png\";\r\nimport \"./poweredBy.less\";\r\n\r\nexport const PoweredBy = memo(() => {\r\n const isMobile = useCheckMobile();\r\n const logo = useMemo(() => {\r\n return isMobile ? coreplusLogoSmall : coreplusLogo;\r\n }, [isMobile]);\r\n return (\r\n <div className=\"coreplus-logo\">\r\n Powered by{\" \"}\r\n <a\r\n href=\"https://coreplus.com.au/\"\r\n alt=\"coreplus website\"\r\n target=\"_blank\"\r\n rel=\"noopener noreferrer\"\r\n >\r\n <img src={logo} alt=\"coreplus logo\" />\r\n </a>\r\n </div>\r\n );\r\n});\r\n","export default \"\"","import { THEME_COLOR, THEME_COLOR_HOVER } from \"../constants\";\r\n\r\nexport const colorStyle = {\r\n color: THEME_COLOR\r\n};\r\n\r\nexport const backgroundStyle = {\r\n background: THEME_COLOR\r\n};\r\n\r\nexport const borderColorStyle = {\r\n borderColor: THEME_COLOR\r\n};\r\n\r\nexport const colorStyleHover = {\r\n color: THEME_COLOR_HOVER\r\n};\r\n\r\nexport const backgroundStyleHover = {\r\n background: THEME_COLOR_HOVER\r\n};\r\n\r\nexport const borderColorStyleHover = {\r\n borderColor: THEME_COLOR_HOVER\r\n};\r\n","import React, { memo, useEffect, useState } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { ListIcon } from \"../Icon\";\r\nimport { backgroundStyle } from \"../../styles\";\r\nimport { STEP_KEYS, PAGE_KEYS } from \"../../constants\";\r\nimport \"./progressStep.less\";\r\n\r\nconst getLineHeight = (diffHeight = 100 + 72) => {\r\n const nodeList = document.querySelectorAll(\".booking-step-item\");\r\n const dom = nodeList[nodeList.length - 1];\r\n let height = 0;\r\n if (dom) {\r\n const offsetTop = dom.offsetTop;\r\n //const offsetHeight = dom.offsetHeight;\r\n height = offsetTop - diffHeight;\r\n }\r\n return height > 0 ? height : 0;\r\n};\r\n\r\nexport const ProgressStep = memo(props => {\r\n const { page, appointment } = props;\r\n const [height, setHeight] = useState(\"\");\r\n useEffect(() => {\r\n const timmer = setTimeout(() => {\r\n const finished = !!appointment[STEP_KEYS.APPOINTMENT_DATE_TIME];\r\n const heightValue = finished ? \"100%\" : getLineHeight() + \"px\";\r\n setHeight(heightValue);\r\n }, 0);\r\n return () => {\r\n clearTimeout(timmer);\r\n };\r\n }, [appointment]);\r\n const stepTwo = page === PAGE_KEYS.CONTACT;\r\n\r\n const style = {\r\n ...backgroundStyle,\r\n height\r\n };\r\n\r\n return (\r\n <div className={`progress-container ${stepTwo ? \"step-two\" : \"\"}`}>\r\n <span className=\"progress-line top-line\" style={backgroundStyle}></span>\r\n <span className=\"progress-circle\" style={backgroundStyle}>\r\n <ListIcon className=\"progress-circle-icon\" />\r\n </span>\r\n <span className=\"progress-line bottom-line\">\r\n <span className=\"bottom-line-content\" style={style}></span>\r\n </span>\r\n </div>\r\n );\r\n});\r\n\r\nProgressStep.propTypes = {\r\n page: PropTypes.string.isRequired,\r\n appointment: PropTypes.object.isRequired\r\n};\r\n\r\n//const lengthPercentage = [\"0\", \"15%\", \"35%\", \"55%\", \"75%\", \"90%\", \"100%\"];\r\n","import React, { memo, useMemo, useCallback, useState } from \"react\";\r\nimport Menu from \"@material-ui/core/Menu\";\r\nimport MenuItem from \"@material-ui/core/MenuItem\";\r\nimport { ArrowDownIcon, DoneIcon } from \"../Icon\";\r\nimport { colorStyle } from \"../../styles\";\r\nimport \"./select.less\";\r\n\r\nexport const Select = memo(props => {\r\n // replaced useRef for the issue when click back from contact form to booking page\r\n // => anchorEl = useRef() can be null and causing issues\r\n const [anchorEl, setAnchorEl] = useState(null);\r\n const {\r\n open,\r\n value,\r\n placeholder,\r\n onToggle,\r\n onSelect,\r\n options,\r\n noOptionText = \"no data\",\r\n ...restProps\r\n } = props;\r\n\r\n // options is null or no data inside\r\n const noOptionDataSource = useMemo(() => {\r\n return !options || options.length === 0;\r\n }, [options]);\r\n\r\n const handleClick = useCallback(\r\n e => {\r\n // This prevents ghost click.\r\n e.preventDefault();\r\n !noOptionDataSource && onToggle(true);\r\n },\r\n [onToggle, noOptionDataSource]\r\n );\r\n\r\n const handleSelect = useCallback(\r\n value => {\r\n onSelect(value);\r\n onToggle(false);\r\n },\r\n [onSelect, onToggle]\r\n );\r\n\r\n const handleRef = span => {\r\n if (span) {\r\n setAnchorEl(span);\r\n }\r\n };\r\n\r\n const valueText = useMemo(() => {\r\n const foundItem = options.find(item => item.value === value);\r\n return foundItem ? foundItem.label : \"\";\r\n }, [value, options]);\r\n\r\n const renderText = useMemo(() => {\r\n return !value ? (\r\n <span className=\"select-placeholder\">\r\n {placeholder}\r\n <ArrowDownIcon className=\"select-placeholder-icon\" />\r\n </span>\r\n ) : (\r\n <span className=\"select-value-text\" style={colorStyle}>\r\n {valueText}\r\n </span>\r\n );\r\n }, [value, placeholder, valueText]);\r\n\r\n const renderMenu = useMemo(() => {\r\n if (!anchorEl) return null;\r\n if (noOptionDataSource) return null;\r\n return (\r\n <Menu\r\n open={open}\r\n onClose={() => {\r\n onToggle(false);\r\n }}\r\n anchorEl={anchorEl}\r\n PaperProps={{\r\n style: {\r\n maxHeight: 300,\r\n minWidth: 200\r\n }\r\n }}\r\n className=\"select-menu-option\"\r\n {...restProps}\r\n >\r\n {options.map(item => {\r\n return (\r\n <MenuItem\r\n className=\"select-option-item\"\r\n key={item.value}\r\n onClick={() => handleSelect(item.value)}\r\n style={colorStyle}\r\n >\r\n {item.label}\r\n {item.value === value && (\r\n <DoneIcon className=\"select-option-item-selected-icon\" />\r\n )}\r\n </MenuItem>\r\n );\r\n })}\r\n </Menu>\r\n );\r\n }, [\r\n anchorEl,\r\n open,\r\n value,\r\n options,\r\n restProps,\r\n onToggle,\r\n handleSelect,\r\n noOptionDataSource\r\n ]);\r\n\r\n return (\r\n <>\r\n <span className=\"select-container\" onClick={handleClick} ref={handleRef}>\r\n {noOptionDataSource ? (\r\n <span className=\"select-value-text\">{noOptionText}</span>\r\n ) : (\r\n renderText\r\n )}\r\n <span className=\"select-bottom-line\" />\r\n </span>\r\n {renderMenu}\r\n </>\r\n );\r\n});\r\n","import React, { memo, useMemo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { colorStyle } from \"../../styles\";\r\nimport \"./textButton.less\";\r\n\r\nexport const TextButton = memo(props => {\r\n const { text, placeholder, onClick } = props;\r\n\r\n const renderText = useMemo(() => {\r\n return !text ? (\r\n <span className=\"text-button-hint-text\">{placeholder}</span>\r\n ) : (\r\n <span className=\"text-button-text\" style={colorStyle}>\r\n {text}\r\n </span>\r\n );\r\n }, [placeholder, text]);\r\n return (\r\n <span className=\"text-button-container\" onClick={onClick}>\r\n {renderText}\r\n <span className=\"text-button-bottom-line\" />\r\n </span>\r\n );\r\n});\r\n\r\nTextButton.propTypes = {\r\n text: PropTypes.string,\r\n placeholder: PropTypes.string,\r\n onClick: PropTypes.func\r\n};\r\n","import React, { memo, useCallback, useEffect, useContext } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport Drawer from \"@material-ui/core/Drawer\";\r\nimport { DrawerContext } from \"../../context/DrawerContext\";\r\nimport { CloseIcon } from \"../\";\r\nimport { colorStyle } from \"../../styles\";\r\n\r\nimport \"./sideDrawer.less\";\r\n\r\nconst BACKDROP_CLICK_KEY = \"backdropClick\";\r\n\r\nexport const SideDrawer = memo(props => {\r\n const {\r\n open,\r\n onToggle,\r\n closeCallback,\r\n showCloseBtn = true,\r\n maskClosable = true,\r\n children,\r\n ...restProps\r\n } = props;\r\n const { drawerOpen, setDrawerOpen } = useContext(DrawerContext);\r\n\r\n useEffect(() => {\r\n if (drawerOpen !== open) {\r\n setDrawerOpen(open);\r\n }\r\n // eslint-disable-next-line react-hooks/exhaustive-deps\r\n }, [open]);\r\n const handleClose = useCallback(\r\n (e, object) => {\r\n if (!maskClosable && object === BACKDROP_CLICK_KEY) {\r\n return false;\r\n }\r\n onToggle(false);\r\n closeCallback && closeCallback();\r\n },\r\n [onToggle, closeCallback, maskClosable]\r\n );\r\n return (\r\n <Drawer\r\n classes={{ paper: \"client-portal-drawer\" }}\r\n anchor=\"right\"\r\n open={open}\r\n onClose={handleClose}\r\n {...restProps}\r\n >\r\n {showCloseBtn && (\r\n <div className=\"client-portal-drawer-close-btn-container\">\r\n <span\r\n onClick={handleClose}\r\n className=\"client-portal-drawer-close-btn\"\r\n style={colorStyle}\r\n >\r\n Close <CloseIcon className=\"client-portal-drawer-close-btn-icon\" />\r\n </span>\r\n </div>\r\n )}\r\n {children}\r\n </Drawer>\r\n );\r\n});\r\n\r\nSideDrawer.propTypes = {\r\n open: PropTypes.bool.isRequired,\r\n onToggle: PropTypes.func.isRequired,\r\n closeCallback: PropTypes.func,\r\n showCloseBtn: PropTypes.bool,\r\n maskClosable: PropTypes.bool,\r\n children: PropTypes.oneOfType([\r\n PropTypes.arrayOf(PropTypes.node),\r\n PropTypes.node\r\n ])\r\n};\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { useHover } from \"../../hooks\";\r\nimport {\r\n borderColorStyle,\r\n colorStyle,\r\n borderColorStyleHover\r\n} from \"../../styles\";\r\nimport \"./fullWidthButton.less\";\r\n\r\nconst style = { ...borderColorStyle, ...colorStyle };\r\nconst hoverStyle = { ...borderColorStyleHover, color: \"#333\" };\r\n\r\nexport const FullWidthButton = memo(\r\n ({\r\n label,\r\n children,\r\n disabled = false,\r\n onClick,\r\n className = \"\",\r\n ...restProps\r\n }) => {\r\n const [hoverRef, isHovered] = useHover();\r\n return (\r\n <button\r\n ref={hoverRef}\r\n className={`full-width-btn ${className}`}\r\n onClick={onClick}\r\n disabled={disabled}\r\n style={isHovered ? hoverStyle : style}\r\n {...restProps}\r\n >\r\n {label || children}\r\n </button>\r\n );\r\n }\r\n);\r\n\r\nFullWidthButton.propTypes = {\r\n label: PropTypes.string,\r\n children: PropTypes.oneOfType([\r\n PropTypes.arrayOf(PropTypes.node),\r\n PropTypes.node\r\n ]),\r\n disabled: PropTypes.bool,\r\n onClick: PropTypes.func.isRequired,\r\n className: PropTypes.string\r\n};\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { backgroundStyle, borderColorStyle, colorStyle } from \"../../styles\";\r\nimport { useHover } from \"../../hooks\";\r\nimport \"./transparentButton.less\";\r\n\r\nconst hoverStyle = {\r\n color: \"#fff\",\r\n ...backgroundStyle,\r\n ...borderColorStyle\r\n};\r\n\r\nconst defaultColorTheme = {\r\n ...colorStyle,\r\n ...borderColorStyle\r\n};\r\nconst defaultColor = {\r\n borderColor: \"#333\",\r\n color: \"#333\"\r\n};\r\nexport const TransparentButton = memo(props => {\r\n const [hoverRef, isHovered] = useHover();\r\n const { isTheme, label, onClick, disabled, className, forceDisabled } = props;\r\n const normalStyle = isTheme ? defaultColorTheme : defaultColor;\r\n return (\r\n <button\r\n className={`transparent-btn ${disabled ? \"disabled\" : \"\"} ${className}`}\r\n onClick={onClick}\r\n ref={hoverRef}\r\n style={isHovered ? hoverStyle : normalStyle}\r\n disabled={forceDisabled}\r\n >\r\n {label}\r\n </button>\r\n );\r\n});\r\n\r\nTransparentButton.defaultProps = {\r\n className: \"\",\r\n forceDisabled: false,\r\n isTheme: false\r\n};\r\n\r\nTransparentButton.propTypes = {\r\n label: PropTypes.oneOfType([\r\n PropTypes.string,\r\n PropTypes.arrayOf(PropTypes.node),\r\n PropTypes.node\r\n ]).isRequired,\r\n onClick: PropTypes.func.isRequired,\r\n disabled: PropTypes.bool,\r\n className: PropTypes.string,\r\n forceDisabled: PropTypes.bool,\r\n isTheme: PropTypes.bool\r\n};\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport {\r\n backgroundStyle,\r\n borderColorStyle,\r\n backgroundStyleHover,\r\n borderColorStyleHover\r\n} from \"../../styles\";\r\nimport { useHover } from \"../../hooks\";\r\nimport \"./transparentButton.less\";\r\n\r\nconst hoverStyle = {\r\n color: \"#fff\",\r\n ...backgroundStyleHover,\r\n ...borderColorStyleHover\r\n};\r\n\r\nconst defaultColor = {\r\n color: \"#fff\",\r\n ...backgroundStyle,\r\n ...borderColorStyle\r\n};\r\nexport const ThemeColorButton = memo(props => {\r\n const [hoverRef, isHovered] = useHover();\r\n const { label, onClick, disabled, className } = props;\r\n return (\r\n <button\r\n className={`transparent-btn ${className}`}\r\n onClick={onClick}\r\n ref={hoverRef}\r\n style={isHovered ? hoverStyle : defaultColor}\r\n disabled={disabled}\r\n >\r\n {label}\r\n </button>\r\n );\r\n});\r\n\r\nThemeColorButton.defaultProps = {\r\n className: \"\",\r\n disabled: false\r\n};\r\n\r\nThemeColorButton.propTypes = {\r\n label: PropTypes.oneOfType([\r\n PropTypes.string,\r\n PropTypes.arrayOf(PropTypes.node),\r\n PropTypes.node\r\n ]).isRequired,\r\n onClick: PropTypes.func.isRequired,\r\n disabled: PropTypes.bool,\r\n className: PropTypes.string\r\n};\r\n","import { createMatomoScriptTag } from \"../utils\";\r\nlet RECAPTCHA_KEY,\r\n CSRF_TOKEN,\r\n API_CONFIG,\r\n DOMAIN_NAME,\r\n BUSINESS_NAME,\r\n GOOGLE_MAP_KEY;\r\n\r\nBUSINESS_NAME = window.location.pathname.replace(/\\//g, \"\");\r\nif (process.env.NODE_ENV !== \"production\") {\r\n API_CONFIG = {\r\n rootUrl: `${process.env.ROOT_URL}`,\r\n headers: {\r\n CsrfAngular: \"TEST\",\r\n \"content-type\": \"application/json\"\r\n }\r\n };\r\n RECAPTCHA_KEY = \"\";\r\n CSRF_TOKEN = \"\";\r\n DOMAIN_NAME = \"https://portal-qa.coreplus.com.au\";\r\n GOOGLE_MAP_KEY = \"\";\r\n} else {\r\n //prod config\r\n const prodDomainRegex = /^portal\\.coreplus\\.com\\.au/gi;\r\n RECAPTCHA_KEY = process.env.RECAPTCHA_KEY;\r\n const antiForgeryTokenDom = document.querySelector(\r\n 'input[name=\"__RequestVerificationToken\"]'\r\n );\r\n const CSRF_TOKEN = antiForgeryTokenDom ? antiForgeryTokenDom.value : \"\";\r\n if (!window.location.origin) {\r\n window.location.origin =\r\n window.location.protocol +\r\n \"//\" +\r\n window.location.hostname +\r\n (window.location.port ? \":\" + window.location.port : \"\");\r\n }\r\n DOMAIN_NAME = window.location.origin;\r\n GOOGLE_MAP_KEY = \"AIzaSyAAjhDgObWd9E0g4dCJHKMOhqFWFFwt89U\";\r\n if (prodDomainRegex.test(window.location.hostname)) {\r\n createMatomoScriptTag();\r\n GOOGLE_MAP_KEY = \"AIzaSyBO-zbHUAaPTTg5LzwrHIQlmh267AfeXQw\";\r\n }\r\n\r\n const rootUrl = `${window.location.origin}`;\r\n API_CONFIG = {\r\n rootUrl,\r\n headers: {\r\n CsrfAngular: CSRF_TOKEN || \"TEST\",\r\n \"content-type\": \"application/json\"\r\n }\r\n };\r\n}\r\n\r\nexport {\r\n CSRF_TOKEN,\r\n RECAPTCHA_KEY,\r\n API_CONFIG,\r\n DOMAIN_NAME,\r\n BUSINESS_NAME,\r\n GOOGLE_MAP_KEY\r\n};\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { MaterialUIIcon } from \"..\";\r\nimport { colorStyle } from \"../../styles\";\r\nimport \"./backTopButton.less\";\r\n\r\nexport const BackTopButton = memo(props => {\r\n //iconDirection = up down left righr\r\n const { onClick, iconDirection = \"up\" } = props;\r\n const iconKey = `keyboard_arrow_${iconDirection}\"`;\r\n return (\r\n <span className=\"back-top-button\" onClick={onClick} style={colorStyle}>\r\n <MaterialUIIcon iconKey={iconKey} className=\"back-top-button-icon\" />\r\n Back\r\n </span>\r\n );\r\n});\r\n\r\nBackTopButton.propTypes = {\r\n onClick: PropTypes.func.isRequired,\r\n iconDirection: PropTypes.string\r\n};\r\n","export const createMatomoScriptTag = () => {\r\n const script = document.createElement('script');\r\n script.innerHTML = `var _paq = window._paq || [];\r\n /* tracker methods like \"setCustomDimension\" should be called before \"trackPageView\" */\r\n _paq.push(['trackPageView']);\r\n _paq.push(['enableLinkTracking']);\r\n (function() {\r\n var u=\"//analyticsadmin.coreplus.com.au/analytics/\";\r\n _paq.push(['setTrackerUrl', u+'matomo.php']);\r\n _paq.push(['setSiteId', '2']);\r\n _paq.push(['setSecureCookie', true]);\r\n var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0];\r\n g.type='text/javascript'; g.async=true; g.defer=true; g.src=u+'matomo.js'; s.parentNode.insertBefore(g,s);\r\n })();`;\r\n document.head.appendChild(script);\r\n};\r\n","export default \"\"","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport GoogleMapReact from \"google-map-react\";\r\nimport { GOOGLE_MAP_KEY } from \"../../../../api/config\";\r\nimport googleMapMarker from \"../../../../assets/images/google-map-marker.png\";\r\nimport \"./googleMap.less\";\r\n\r\nconst preventTouchStyle = {\r\n pointerEvents: \"none\"\r\n};\r\n\r\nexport const GoogleMap = memo(props => {\r\n const { position, zoom = 15, preventTouch = false } = props;\r\n return (\r\n <div\r\n className=\"google-map-container\"\r\n style={preventTouch ? preventTouchStyle : null}\r\n >\r\n {position && (\r\n <GoogleMapReact\r\n bootstrapURLKeys={{ key: GOOGLE_MAP_KEY }}\r\n defaultCenter={position}\r\n defaultZoom={zoom}\r\n >\r\n <GoogleMapMarker lat={position.lat} lng={position.lng} />\r\n </GoogleMapReact>\r\n )}\r\n </div>\r\n );\r\n});\r\n\r\nGoogleMap.propTypes = {\r\n position: PropTypes.shape({\r\n lat: PropTypes.number.isRequired,\r\n lng: PropTypes.number.isRequired\r\n }),\r\n zoom: PropTypes.number,\r\n preventTouch: PropTypes.bool\r\n};\r\n\r\nconst GoogleMapMarker = memo(props => {\r\n return (\r\n <div className=\"google-map-marker-container\">\r\n <img src={googleMapMarker} alt=\"marker\" />\r\n </div>\r\n );\r\n});\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport NoLocationFound from \"../../../../assets/images/sad_face.png\";\r\n\r\nexport const LocationNotFound = memo(props => {\r\n const { name = \"no position\" } = props;\r\n return <img src={NoLocationFound} alt={name} />;\r\n});\r\n\r\nLocationNotFound.propTypes = {\r\n name: PropTypes.string\r\n};\r\n","export default \"\"","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { colorStyle } from \"../../styles\";\r\nimport \"./stepText.less\";\r\n\r\nexport const StepText = memo(props => {\r\n const { step, total = 2 } = props;\r\n\r\n return (\r\n <div className=\"step-text\" style={colorStyle}>\r\n Step {step} of {total}\r\n </div>\r\n );\r\n});\r\n\r\nStepText.propTypes = {\r\n step: PropTypes.number.isRequired,\r\n total: PropTypes.number\r\n};\r\n","import React, { memo, useMemo, useCallback } from \"react\";\r\nimport { useHover } from \"../../hooks\";\r\nimport { colorStyle, borderColorStyle, backgroundStyle } from \"../../styles\";\r\n\r\nconst hoverContainerStyle = {\r\n ...borderColorStyle,\r\n ...backgroundStyle,\r\n color: \"#fff\"\r\n};\r\n\r\nconst hoverTextStyle = {\r\n color: \"#fff\"\r\n};\r\n\r\nexport const CalendarDay = memo(props => {\r\n const [hoverRef, isHovered] = useHover();\r\n const {\r\n dateKey,\r\n day,\r\n onClick,\r\n today,\r\n amEnabled = false,\r\n pmEnabled = false,\r\n selected\r\n } = props;\r\n const enabled = useMemo(() => {\r\n return amEnabled || pmEnabled;\r\n }, [amEnabled, pmEnabled]);\r\n\r\n const containerStyle = useMemo(() => {\r\n if (enabled) {\r\n return isHovered || selected ? hoverContainerStyle : borderColorStyle;\r\n } else {\r\n return null;\r\n }\r\n }, [enabled, isHovered, selected]);\r\n\r\n const dateTextStyle = useMemo(() => {\r\n let style;\r\n if (today) {\r\n style = colorStyle;\r\n }\r\n if (enabled) {\r\n if (isHovered || selected) {\r\n style = hoverTextStyle;\r\n }\r\n }\r\n return style;\r\n }, [isHovered, selected, enabled, today]);\r\n\r\n const amEnabledStyle = useMemo(() => {\r\n if (amEnabled) {\r\n return isHovered || selected ? hoverTextStyle : colorStyle;\r\n } else {\r\n return isHovered || selected ? colorStyle : null;\r\n }\r\n }, [amEnabled, isHovered, selected]);\r\n\r\n const pmEnabledStyle = useMemo(() => {\r\n if (pmEnabled) {\r\n return isHovered || selected ? hoverTextStyle : colorStyle;\r\n } else {\r\n return isHovered || selected ? colorStyle : null;\r\n }\r\n }, [pmEnabled, isHovered, selected]);\r\n const handleClick = useCallback(() => {\r\n if (enabled) {\r\n onClick(dateKey);\r\n }\r\n }, [enabled, onClick, dateKey]);\r\n return (\r\n <div\r\n ref={hoverRef}\r\n className={`calendar-day-container calendar-day-date ${\r\n enabled ? \"enabled\" : \"\"\r\n }`}\r\n style={containerStyle}\r\n onClick={handleClick}\r\n >\r\n <div className=\"calendar-day-text\" style={dateTextStyle}>\r\n {day}\r\n </div>\r\n <div className=\"calendar-day-bottom\">\r\n <span style={amEnabledStyle}>am</span>\r\n <span style={pmEnabledStyle}>pm</span>\r\n </div>\r\n </div>\r\n );\r\n});\r\n","import moment from \"moment\";\r\nimport { ANY_SELECTION } from \"../constants\";\r\n\r\nexport const filterSpecialtiesHavingAppointmentTypes = specialties => {\r\n return specialties.filter(f => f.appointmentTypes.length > 0);\r\n};\r\n\r\nexport const filterPractitionersBySpecialty = (\r\n practitioners,\r\n specialtyType\r\n) => {\r\n if (!practitioners) return [];\r\n return practitioners.filter(p =>\r\n p.specialties.map(s => s.specialtyTypeId).includes(specialtyType)\r\n );\r\n};\r\n\r\nexport const filterSchedulesByPractitioner = (schedules, practitioner) => {\r\n if (practitioner && practitioner !== ANY_SELECTION) {\r\n return schedules.filter(s => s.practitionerId === practitioner);\r\n }\r\n return schedules;\r\n};\r\n\r\nexport const filterSchedulesByLocation = (schedules, location = \"\") => {\r\n if (!location || location === ANY_SELECTION) return schedules;\r\n return schedules.filter(\r\n s =>\r\n s.Sessions[0].locationId === location ||\r\n s.Sessions[1].locationId === location\r\n );\r\n};\r\n\r\nexport const filterLocationsBySchedules = (locations, schedules) => {\r\n const locationIdsInSchedule = schedules.reduce((current, next) => {\r\n const sessions = next.Sessions;\r\n if (!current.includes(sessions[0].locationId)) {\r\n current.push(sessions[0].locationId);\r\n }\r\n if (!current.includes(sessions[1].locationId)) {\r\n current.push(sessions[1].locationId);\r\n }\r\n return current;\r\n }, []);\r\n return locations.filter(l => {\r\n return locationIdsInSchedule.includes(l.locationId);\r\n });\r\n};\r\n\r\nexport const filterPractitionersBySchedules = (practitioners, schedules) => {\r\n if (!practitioners || !schedules) return [];\r\n const practitionerIdsInSchedule = schedules.map(s => s.practitionerId);\r\n\r\n return practitioners.filter(p =>\r\n practitionerIdsInSchedule.includes(p.practitionerId)\r\n );\r\n};\r\n\r\nexport const filterTimeSlotsByLocationAndPractitioner = (\r\n timeslots,\r\n location,\r\n practitioner\r\n) => {\r\n return timeslots.filter(\r\n ts =>\r\n moment(ts.startDateTime).isAfter(moment().add(30, \"minutes\")) &&\r\n (ts.locationId === location || location === \"ANY\" || !location) &&\r\n (ts.practitioner.practitionerId === practitioner ||\r\n practitioner === \"ANY\" ||\r\n !practitioner)\r\n );\r\n};\r\n\r\nexport const isTimeZoneUnique = locations => {\r\n const timeZones = locations\r\n .filter(l => l.timeZone !== null)\r\n .reduce((current, next) => {\r\n if (!current.includes(next.timeZone.timezoneId))\r\n current.push(next.timeZone.timezoneId);\r\n\r\n return current;\r\n }, []);\r\n\r\n return timeZones.length <= 1;\r\n};\r\n","export function checkIsPhoneConsult(siteConsultTypes, location) {\r\n return siteConsultTypes.some(\r\n type => type.siteId === location && type.consultType === 1\r\n );\r\n}\r\n\r\nexport const isCurrentStep = (steps, key) => {\r\n return steps[steps.length - 1] === key;\r\n};\r\n","import moment from \"moment\";\r\n\r\n// 2019-12-03T07:00:00+11:00 => 07:00am, 3rd Dec 2019\r\nexport const mapDateTimeStringToText = dateTimeString => {\r\n return moment(dateTimeString)\r\n .parseZone(dateTimeString)\r\n .format(\"hh:mma, Do MMM YYYY\");\r\n};\r\n\r\n// 2019-11-24 => Sunday, Nov 24th 2019\r\nexport const mapDateToTitle = date => {\r\n return moment(date).format(\"dddd, MMM Do YYYY\");\r\n};\r\n\r\n//2019-12-03T07:00:00+11:00 => 7:00 AM\r\nexport const mapDateTimeToTimeText = datetime => {\r\n return moment(datetime)\r\n .parseZone(datetime)\r\n .format(\"hh:mm a\");\r\n};\r\n\r\nexport const mapJsDateToYearMonthDayString = date => {\r\n return moment(date).format(\"YYYY-MM-DD\");\r\n};\r\n\r\nexport const createTimeSlotObjectForScheduleDrawer = (\r\n timeslotWithCurrentKey,\r\n momentJsTime,\r\n timeslotInDatasource\r\n) => {\r\n let newTimeslot = timeslotWithCurrentKey\r\n ? { ...timeslotWithCurrentKey }\r\n : { am: [], pm: [] };\r\n const amPmKey = ~~(momentJsTime.hour() / 12) ? \"pm\" : \"am\";\r\n newTimeslot[amPmKey].push(timeslotInDatasource);\r\n return newTimeslot;\r\n};\r\n\r\nexport const getUniqueTimeSlots = timeslots => {\r\n return timeslots\r\n .reduce((current, next) => {\r\n if (\r\n !current.some(\r\n s =>\r\n s.startDateTime === next.startDateTime &&\r\n s.endDateTime === next.endDateTime\r\n )\r\n ) {\r\n current.push(next);\r\n }\r\n return current;\r\n }, [])\r\n .map(({ startDateTime, endDateTime }) => {\r\n return { startDateTime, endDateTime };\r\n });\r\n};\r\n\r\nexport const mapMomentjsToDateTimeString = momentJsDateTime => {\r\n if (momentJsDateTime instanceof Date) {\r\n momentJsDateTime = moment(momentJsDateTime);\r\n }\r\n return momentJsDateTime.format(\"YYYY-MM-DDTHH:mm:ss\");\r\n};\r\n\r\nexport const isFutureDate = date => {\r\n return moment(date).isAfter(moment());\r\n};\r\n\r\n//dd/mm/yyyy\r\nconst AUS_DATE_REGEX = new RegExp(/^([0-3][0-9])\\/([0-1][0-9])\\/[1-2]\\d{3}$/);\r\n// map dd/mm/yyyy => JS Date\r\nexport const mapAusDateStrToDate = ausDate => {\r\n if (!AUS_DATE_REGEX.test(ausDate)) return null;\r\n // dd/mm/yyyy => [dd,mm,yyyy]\r\n\r\n const dateArr = ausDate.split(\"/\");\r\n const momentJsDate = moment(`${dateArr[2]}-${dateArr[1]}-${dateArr[0]}`);\r\n\r\n if (!momentJsDate.isValid()) return null;\r\n if (momentJsDate.isBefore(moment(\"1900-01-01\"))) return null;\r\n\r\n return momentJsDate.toDate();\r\n};\r\n\r\nexport const isDateBirthWithInRange = date => {\r\n if (!(date instanceof Date)) return false;\r\n return !isFutureDate(date);\r\n};\r\n\r\n// map js date => dd/mm/yyyy\r\nexport const mapDateToAusDateStr = date => {\r\n return moment(date).format(\"DD/MM/YYYY\");\r\n};\r\n\r\nexport const mapDateToICalDatetimeFormat = date => {\r\n return moment(date)\r\n .parseZone(date)\r\n .format(\"YYYYMMDDTHHmmss\");\r\n};\r\n","import validator from 'validator';\r\nimport { FORM_KEYS } from '../constants';\r\nimport { mapAusDateStrToDate, isDateBirthWithInRange } from './dateTimeHelper';\r\nimport { validateMedicareCard } from './medicareHelpers';\r\n\r\nconst isEmpty = value => {\r\n if (value && value.trim()) {\r\n return false;\r\n } else {\r\n return true;\r\n }\r\n};\r\n\r\nconst isValidName = value => {\r\n if (value) return /^[- a-zA-Z0-9'_]+$/.test(value);\r\n return true;\r\n};\r\n\r\nconst isMobile = value => {\r\n if (value.indexOf('04') === 0 && value.length === 10) {\r\n return true;\r\n }\r\n return false;\r\n};\r\n\r\nconst isEmail = value => {\r\n if (/^\\b[A-Z0-9._%+-]+@[A-Z0-9.-]+\\.[A-Z]{2,25}\\b$/i.test(value)) {\r\n return true;\r\n }\r\n return false;\r\n};\r\n\r\nexport const isPostcode = value => {\r\n if (/^[0-9]{4}$/i.test(value)) {\r\n return true;\r\n }\r\n return false;\r\n};\r\n\r\nconst mandatoryObject = errorMessage => {\r\n return {\r\n required: value => {\r\n if (isEmpty(value)) {\r\n return errorMessage;\r\n } else {\r\n return '';\r\n }\r\n }\r\n };\r\n};\r\n\r\nexport const validators = {\r\n [FORM_KEYS.FIRST_NAME]: {\r\n ...mandatoryObject('Firstname is required'),\r\n valid: value => {\r\n return !isValidName(value) ? 'Invalid firstname' : '';\r\n }\r\n },\r\n [FORM_KEYS.MIDDLE_NAME]: {\r\n valid: value => {\r\n return !isValidName(value) ? 'Invalid middle name' : '';\r\n }\r\n },\r\n [FORM_KEYS.LAST_NAME]: {\r\n ...mandatoryObject('Last name is required'),\r\n valid: value => {\r\n return !isValidName(value) ? 'Invalid last name' : '';\r\n }\r\n },\r\n [FORM_KEYS.PREFERRED_NAME]: {\r\n valid: value => {\r\n return value && !isValidName(value) ? 'Invalid preferred name' : '';\r\n }\r\n },\r\n [FORM_KEYS.DATE_OF_BIRTH]: {\r\n ...mandatoryObject('Date of birth is required'),\r\n valid: value => {\r\n const date = mapAusDateStrToDate(value);\r\n if (!date) {\r\n return 'Valid date format is dd/mm/yyyy';\r\n }\r\n if (!isDateBirthWithInRange(date)) {\r\n return 'Date of birth cannot be in future';\r\n }\r\n return '';\r\n }\r\n },\r\n [FORM_KEYS.MOBILE]: {\r\n ...mandatoryObject('Mobile number is required'),\r\n valid: value => {\r\n if (!isMobile(value)) {\r\n return 'Mobile number needs to be 10 digit numbers starting with 04';\r\n } else {\r\n return '';\r\n }\r\n }\r\n },\r\n [FORM_KEYS.EMAIL]: {\r\n ...mandatoryObject('Email is required'),\r\n valid: value => {\r\n if (!isEmail(value)) {\r\n return 'Invalid email. Please use letters, numbers, underscores and periods.';\r\n } else {\r\n return '';\r\n }\r\n }\r\n }\r\n};\r\n\r\nexport const getCommentsFieldsValidator = (isCommentMandatory = false) => {\r\n return isCommentMandatory\r\n ? {\r\n ...mandatoryObject('Comment is required')\r\n }\r\n : null;\r\n};\r\n\r\nexport const getAddressFieldsValidator = (\r\n key,\r\n addressValue,\r\n isAddressMandatory = false\r\n) => {\r\n switch (key) {\r\n case FORM_KEYS.CLIENT_ADDRESS:\r\n return isAddressMandatory\r\n ? {\r\n ...mandatoryObject('Your address is required')\r\n }\r\n : null;\r\n case FORM_KEYS.CLIENT_SUBURB:\r\n return isAddressMandatory || addressValue\r\n ? {\r\n ...mandatoryObject(\r\n !isAddressMandatory && addressValue\r\n ? 'Please fill in your suburb for your address'\r\n : 'Suburb is required'\r\n )\r\n }\r\n : null;\r\n case FORM_KEYS.CLIENT_POSTCODE:\r\n return isAddressMandatory || addressValue\r\n ? {\r\n ...mandatoryObject(\r\n !isAddressMandatory && addressValue\r\n ? 'Please fill in your postcode for your address'\r\n : 'Postcode is required'\r\n ),\r\n valid: value => {\r\n return !isPostcode(value) ? 'Please enter a valid Australian Postcode' : '';\r\n }\r\n }\r\n : {\r\n valid: value => {\r\n return value && !isPostcode(value) ? 'Please enter a valid Australian Postcode' : '';\r\n }\r\n };\r\n default:\r\n return null;\r\n }\r\n};\r\n\r\nexport const getMedicareValidator = (\r\n key,\r\n {\r\n [FORM_KEYS.MEDICARE_NUMBER]: numberValue,\r\n [FORM_KEYS.MEDICARE_EXPIRY]: expiryValue\r\n }\r\n) => {\r\n switch (key) {\r\n case FORM_KEYS.MEDICARE_NUMBER:\r\n const numberValid = val => {\r\n if (!val) {\r\n return !expiryValue ? null : 'Please fill in medicare card number';\r\n }\r\n const [num, irn] = val.split('/').map(item => item.replace(/_/g, ''));\r\n if (!validateMedicareCard(num)) return 'Invalid medicare card number';\r\n if (!irn) return 'The medicare IRN is required';\r\n return null;\r\n };\r\n return { numberValid };\r\n case FORM_KEYS.MEDICARE_EXPIRY:\r\n const expiryValid = val => {\r\n if (!val) {\r\n return !numberValue ? null : 'Please select medicare expiry';\r\n }\r\n return null;\r\n };\r\n return { expiryValid };\r\n default:\r\n return null;\r\n }\r\n};\r\n\r\nexport const getCreditCardValidator = (key, mandatory) => {\r\n switch (key) {\r\n case FORM_KEYS.CREDIT_CARD_NUMBER:\r\n const cardValid = val => {\r\n if (!val) return null;\r\n const isValid = validator.isCreditCard(val);\r\n return isValid ? null : 'Invalid card number';\r\n };\r\n return mandatory\r\n ? { ...mandatoryObject('Please fill in card number'), cardValid }\r\n : { cardValid };\r\n case FORM_KEYS.CREDIT_CARD_EXPIRY:\r\n return mandatory\r\n ? mandatoryObject('Please select the card expiry')\r\n : null;\r\n case FORM_KEYS.CREDIT_CARD_NAME:\r\n const nameValid = val => {\r\n if (!val) return null;\r\n const isValid = val.split(' ').filter(Boolean).length >= 2;\r\n return isValid ? null : 'Invalid cardholder name';\r\n };\r\n return mandatory\r\n ? { ...mandatoryObject('Please fill in cardholder name'), nameValid }\r\n : { nameValid };\r\n case FORM_KEYS.CREDIT_CARD_SECURITY_CODE:\r\n const codeValid = val => {\r\n if (!val) return null;\r\n const isValid = /^\\d{3,4}$/.test(val);\r\n return isValid ? null : 'Invalid security code';\r\n };\r\n return mandatory\r\n ? { ...mandatoryObject('Please fill in security code'), codeValid }\r\n : { codeValid };\r\n default:\r\n return null;\r\n }\r\n};\r\n\r\nexport const validate = (rules, value, ...args) => {\r\n if (!rules) return '';\r\n let errorMessage = '';\r\n const keys = Object.keys(rules);\r\n for (let key of keys) {\r\n errorMessage = rules[key](value, args[0]);\r\n if (errorMessage) {\r\n break;\r\n }\r\n }\r\n return errorMessage;\r\n};\r\n\r\n// medicare number and expiry should be:\r\n// 1. both have values\r\n// 2. both leave empty\r\nexport const areMedicareInfoValid = (number, expiry) => {\r\n // true ^ true or false ^ false = 0 ||||| false ^ true or true ^ false = 1\r\n return !(!!number ^ !!expiry);\r\n};\r\n","import moment from 'moment';\r\n\r\n// copy this validation from our ASP project => includes/validateMedicareCard.js\r\nexport const validateMedicareCard = cardNumber => {\r\n let validated = false;\r\n const enteredMedicareCardNumber = cardNumber;\r\n const enteredMedicareCardNumberLength = enteredMedicareCardNumber.length;\r\n let totalValue = 0;\r\n if (enteredMedicareCardNumberLength === 10) {\r\n for (let i = 0; i <= enteredMedicareCardNumberLength; i++) {\r\n if (enteredMedicareCardNumber.substring(i, i + 1) !== '') {\r\n switch (i) {\r\n case 1:\r\n totalValue += parseFloat(enteredMedicareCardNumber.substring(0, i));\r\n break;\r\n case 2:\r\n totalValue += parseFloat(\r\n enteredMedicareCardNumber.substring(1, i) * 3\r\n );\r\n break;\r\n case 3:\r\n totalValue += parseFloat(\r\n enteredMedicareCardNumber.substring(2, i) * 7\r\n );\r\n break;\r\n case 4:\r\n totalValue += parseFloat(\r\n enteredMedicareCardNumber.substring(3, i) * 9\r\n );\r\n break;\r\n case 5:\r\n totalValue += parseFloat(enteredMedicareCardNumber.substring(4, i));\r\n break;\r\n case 6:\r\n totalValue += parseFloat(\r\n enteredMedicareCardNumber.substring(5, i) * 3\r\n );\r\n break;\r\n case 7:\r\n totalValue += parseFloat(\r\n enteredMedicareCardNumber.substring(6, i) * 7\r\n );\r\n break;\r\n case 8:\r\n totalValue += parseFloat(\r\n enteredMedicareCardNumber.substring(7, i) * 9\r\n );\r\n break;\r\n default:\r\n break;\r\n }\r\n }\r\n }\r\n const verifiedInteger = totalValue % 10;\r\n if (\r\n verifiedInteger === parseInt(enteredMedicareCardNumber.substring(8, 9))\r\n ) {\r\n validated = true;\r\n } else {\r\n validated = false;\r\n }\r\n } else {\r\n validated = false;\r\n }\r\n return validated;\r\n};\r\n\r\nexport const getMedicareNumberAndIRNFromString = number => {\r\n if (!number) {\r\n return { medicareCardNumber: null, medicareCardIRN: null };\r\n }\r\n const [medicareCardNumber, medicareCardIRN] = number.split('/');\r\n return { medicareCardNumber, medicareCardIRN };\r\n};\r\n\r\nexport const getMedicareExpiryDateFromString = expiry => {\r\n // expiry = \"\" or \"01/2021\"\r\n const momentJsDate = moment(expiry, 'MM/YYYY');\r\n if (momentJsDate.isValid()) {\r\n return momentJsDate.format();\r\n }\r\n return null;\r\n};\r\n","import { ANY_SELECTION } from '../constants';\r\nimport { mapDateTimeStringToText } from './';\r\n\r\n// {specialtyTypeText,appointmentTypeText, isTelehealthAppointment}\r\nexport const getSpecialtyTypeAppointmentType = (\r\n specialtyTypes,\r\n specialtyTypeValue,\r\n appointmentTypeValue\r\n) => {\r\n let result = {\r\n specialtyTypeText: '',\r\n appointmentTypeText: '',\r\n isTelehealthAppointment: false\r\n };\r\n if (!!specialtyTypeValue && !!appointmentTypeValue) {\r\n const foundSpecialtyType = specialtyTypes.find(\r\n s => s.specialtyTypeId === specialtyTypeValue\r\n );\r\n if (foundSpecialtyType) {\r\n result.specialtyTypeText = foundSpecialtyType.name;\r\n const foundAppointmentType = foundSpecialtyType.appointmentTypes.find(\r\n a => a.appointmentTypeId === appointmentTypeValue\r\n );\r\n if (!!foundAppointmentType) {\r\n result.appointmentTypeText = foundAppointmentType.description;\r\n result.isTelehealthAppointment =\r\n !!foundAppointmentType.isTeleHealthEnabled;\r\n }\r\n }\r\n } else if (!!appointmentTypeValue) {\r\n for (var i = 0; i < specialtyTypes.length; i++) {\r\n const foundAppointmentType = specialtyTypes[i].appointmentTypes.find(\r\n a => a.appointmentTypeId === appointmentTypeValue\r\n );\r\n if (!!foundAppointmentType) {\r\n result.appointmentTypeText = foundAppointmentType.description;\r\n result.isTelehealthAppointment =\r\n !!foundAppointmentType.isTeleHealthEnabled;\r\n break;\r\n }\r\n }\r\n }\r\n return result;\r\n};\r\n\r\n// {locationText, position}\r\nexport const getLocationTextAndPosition = (\r\n locations,\r\n positions,\r\n locationValue\r\n) => {\r\n if (locationValue === ANY_SELECTION || !locationValue)\r\n return { locationText: 'ANY Location', position: null };\r\n\r\n const locationDetail = locations.find(l => l.locationId === locationValue);\r\n let result = {\r\n locationText: '',\r\n position: null\r\n };\r\n if (locationDetail) {\r\n result = {\r\n locationText: `${locationDetail.name}, ${locationDetail.suburb}`,\r\n position: positions[locationDetail.locationId]\r\n };\r\n }\r\n return result;\r\n};\r\n\r\nexport const getPractitionerText = (practitioners, practitionerValue) => {\r\n if (practitionerValue === ANY_SELECTION || !practitionerValue)\r\n return 'ANY Practitioner';\r\n\r\n const practitionerDetail = practitioners.find(\r\n p => p.practitionerId === practitionerValue\r\n );\r\n return practitionerDetail\r\n ? `${practitionerDetail.firstName} ${practitionerDetail.lastName}`\r\n : '';\r\n};\r\n\r\nexport const getPractitionerFirstName = (practitioners, practitionerValue) => {\r\n if (practitionerValue === ANY_SELECTION || !practitionerValue)\r\n return 'Unknown';\r\n\r\n const practitionerDetail = practitioners.find(\r\n p => p.practitionerId === practitionerValue\r\n );\r\n return practitionerDetail ? `${practitionerDetail.firstName}` : '';\r\n};\r\n\r\nexport const getPractitionerLastName = (practitioners, practitionerValue) => {\r\n if (practitionerValue === ANY_SELECTION || !practitionerValue)\r\n return 'Unknown';\r\n\r\n const practitionerDetail = practitioners.find(\r\n p => p.practitionerId === practitionerValue\r\n );\r\n return practitionerDetail ? `${practitionerDetail.lastName}` : '';\r\n};\r\n\r\nexport const getAppointmentDateTimeText = (\r\n appointmentDateTime,\r\n waitingListRequired = false,\r\n waitingListPreferredTime = ''\r\n) => {\r\n return waitingListRequired\r\n ? `${waitingListPreferredTime} preferred`\r\n : appointmentDateTime\r\n ? mapDateTimeStringToText(appointmentDateTime.startDateTime)\r\n : '';\r\n};\r\n\r\nexport const getHideSpecialty = config => {\r\n return config.preSelectSpecialtyType && config.preSelectSpecialtyType !== '';\r\n};\r\n\r\nexport const getHidePractitioner = config => {\r\n return config.preSelectPractitioner && config.preSelectPractitioner !== '';\r\n};\r\n\r\nexport const getFullAddress = location => {\r\n if (!location) return '';\r\n const { streetAddress, suburb, postcode, country } = location;\r\n return `${streetAddress}, ${suburb} ${postcode}, ${country}`;\r\n};\r\n\r\nexport const getTimezoneText = (timezoneId, timezoneList) => {\r\n return (\r\n timezoneList.find(timezone => timezone.timezoneUID === timezoneId)\r\n ?.description || ''\r\n );\r\n};\r\n\r\nexport const timezoneTextAndTzIdMap = {\r\n adelaide: 'Australia/Adelaide',\r\n brisbane: 'Australia/Brisbane',\r\n 'broken hill': 'Australia/Broken_Hill',\r\n 'cocos islands': 'Indian/Cocos',\r\n currie: 'Australia/Currie',\r\n darwin: 'Australia/Darwin',\r\n eucla: 'Australia/Eucla',\r\n hobart: 'Australia/Hobart',\r\n lindeman: 'Australia/Lindeman',\r\n 'lord howe': 'Australia/Lord_Howe',\r\n melbourne: 'Australia/Melbourne',\r\n perth: 'Australia/Perth',\r\n sydney: 'Australia/Sydney'\r\n};\r\n","import { getParameterByName } from \"../../../utils\";\r\n\r\nexport const getAppointmentIdFromUrl = () => {\r\n const appointmentId = getParameterByName(\"appointmentId\");\r\n return appointmentId;\r\n};\r\n","export const mappingContentTypeWithFileName = fileName => {\r\n const { extension } = getFileNameWithExtension(fileName);\r\n switch (extension) {\r\n case \"pdf\":\r\n return \"application/pdf\";\r\n case \"jpg\":\r\n case \"jpeg\":\r\n return \"image/jpeg\";\r\n case \"png\":\r\n return \"image/png\";\r\n case \"gif\":\r\n return \"image/gif\";\r\n case \"doc\":\r\n return \"application/msword\";\r\n case \"docx\":\r\n return \"application/vnd.openxmlformats-officedocument.wordprocessingml.document\";\r\n case \"rtf\":\r\n return \"application/rtf\";\r\n case \"html\":\r\n return \"text/html\";\r\n case \"txt\":\r\n return \"text/plain\";\r\n case \"msg\":\r\n return \"text/plain\";\r\n case \"pages\":\r\n return \"text/plain\";\r\n default:\r\n return \"application/octet-stream\";\r\n }\r\n};\r\n\r\nexport const base64ToArrayBuffer = base64 => {\r\n var binaryString = window.atob(base64);\r\n var binaryLen = binaryString.length;\r\n var bytes = new Uint8Array(binaryLen);\r\n for (var i = 0; i < binaryLen; i++) {\r\n var ascii = binaryString.charCodeAt(i);\r\n bytes[i] = ascii;\r\n }\r\n return bytes;\r\n};\r\n\r\nexport const getFileNameWithExtension = (fileName = \"\") => {\r\n //return {name, extension};\r\n let name = fileName,\r\n extension = \"\";\r\n const splitedFileNameArray = fileName.split(\".\");\r\n if (splitedFileNameArray.length > 1) {\r\n extension = splitedFileNameArray[\r\n splitedFileNameArray.length - 1\r\n ].toLowerCase();\r\n name = splitedFileNameArray\r\n .slice(0, splitedFileNameArray.length - 1)\r\n .join(\".\");\r\n }\r\n return {\r\n name,\r\n extension\r\n };\r\n};\r\n","const getPinApiInstanceFactory = (publishKey, isTest = true) => {\r\n const mode = isTest ? 'test' : 'live';\r\n if (!window.Pin) return null;\r\n return new window.Pin.Api(publishKey, mode);\r\n};\r\n\r\n// const card = {\r\n// number,\r\n// name,\r\n// expiry_month,\r\n// expiry_year,\r\n// cvc,\r\n// };\r\n\r\n// error: \"invalid_resource\"\r\n// error_description: \"One or more parameters were missing or invalid\"\r\n// messages: [{param: \"number\", code: \"number_invalid\", message: \"Number can't be blank\"},…]\r\n// 0: {param: \"number\", code: \"number_invalid\", message: \"Number can't be blank\"}\r\n// 1: {param: \"expiry_month\", code: \"expiry_month_invalid\", message: \"Expiry month can't be blank\"}\r\n// 2: {param: \"expiry_year\", code: \"expiry_year_invalid\", message: \"Expiry year can't be blank\"}\r\n// 3: {param: \"name\", code: \"name_invalid\", message: \"Name can't be blank\"}\r\n// 4: {param: \"cvc\", code: \"cvc_invalid\", message: \"Cvc can't be blank\"}\r\n\r\n// card.token\r\n\r\nexport const fetchForCardTokenPromise = (publishKey, card, isTest) => {\r\n const pinApi = getPinApiInstanceFactory(publishKey, isTest);\r\n if (!pinApi) return null;\r\n return new Promise((resolve, reject) => {\r\n pinApi.createCardToken(card).then(resolve, reject).done();\r\n });\r\n};\r\n\r\nexport const canSaveCreditCard = state => {\r\n const { isCreditCardEnabled } = state.config;\r\n const { onlinePaymentToken } = state.datasource;\r\n return isCreditCardEnabled && onlinePaymentToken;\r\n};\r\n\r\nexport const createPinPaymentsScript = () => {\r\n const script = document.createElement('script');\r\n script.src = 'https://cdn.pinpayments.com/pin.v2.js';\r\n document.getElementsByTagName('head')[0].appendChild(script);\r\n};\r\n\r\nexport const areNotAllCreditCardFieldsFilled = (\r\n name,\r\n number,\r\n expiryDate,\r\n securityCode\r\n) => {\r\n const hasValueFieldsNumber = [name, number, expiryDate, securityCode].filter(\r\n Boolean\r\n ).length;\r\n return hasValueFieldsNumber > 0 && hasValueFieldsNumber < 4;\r\n};\r\n","import React, { memo } from \"react\";\r\nimport DayPicker from \"react-day-picker\";\r\nimport { CalendarDay } from \"./CalendarDay\";\r\nimport { mapJsDateToYearMonthDayString } from \"../../helpers\";\r\nimport \"react-day-picker/lib/style.css\";\r\nimport \"./calendar.less\";\r\n\r\nexport const Calendar = memo(props => {\r\n const {\r\n month,\r\n fromMonth,\r\n timeSlots,\r\n onDayClick,\r\n onMonthChange,\r\n selectedDay\r\n } = props;\r\n const renderDay = (day, { today }) => {\r\n const dateKey = mapJsDateToYearMonthDayString(day);\r\n const timeSlot = timeSlots[dateKey];\r\n let amEnabled = false;\r\n let pmEnabled = false;\r\n if (timeSlot) {\r\n amEnabled = timeSlot.am && timeSlot.am.length > 0;\r\n pmEnabled = timeSlot.pm && timeSlot.pm.length > 0;\r\n }\r\n const selected = !!selectedDay && dateKey === selectedDay;\r\n const date = day.getDate();\r\n return (\r\n <CalendarDay\r\n dateKey={dateKey}\r\n day={date}\r\n today={today}\r\n amEnabled={amEnabled}\r\n pmEnabled={pmEnabled}\r\n selected={selected}\r\n onClick={onDayClick}\r\n />\r\n );\r\n };\r\n return (\r\n <DayPicker\r\n month={month}\r\n fromMonth={fromMonth}\r\n className=\"client-portal-calendar\"\r\n renderDay={renderDay}\r\n onMonthChange={onMonthChange}\r\n />\r\n );\r\n});\r\n","import React, { memo, useEffect, useState, useCallback, useMemo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport DayPicker from \"react-day-picker\";\r\nimport { backgroundStyle } from \"../../styles\";\r\nimport { useHover } from \"../../hooks\";\r\nimport {\r\n mapAusDateStrToDate,\r\n mapDateToAusDateStr,\r\n isDateBirthWithInRange\r\n} from \"../../helpers\";\r\nimport { isSameDay } from \"../../../../utils\";\r\nimport \"react-day-picker/lib/style.css\";\r\nimport \"./dateOfBirthCalendar.less\";\r\n\r\nconst firstYear = new Date(1900);\r\nconst fromDate = new Date(firstYear, 0);\r\nconst toDate = new Date();\r\n\r\nexport const DateOfBirthCalendar = memo(props => {\r\n const [monthDate, setMonthDate] = useState(null);\r\n const { dateString, onSelect } = props;\r\n\r\n const jsDate = useMemo(() => {\r\n const date = mapAusDateStrToDate(dateString);\r\n return isDateBirthWithInRange(date) ? date : null;\r\n }, [dateString]);\r\n\r\n useEffect(() => {\r\n if (jsDate) {\r\n setMonthDate(jsDate);\r\n }\r\n }, [jsDate]);\r\n\r\n const renderDay = useCallback(\r\n day => {\r\n const date = day.getDate();\r\n const selected = jsDate && isSameDay(day, jsDate);\r\n return <DayComponent date={date} selected={selected} />;\r\n },\r\n [jsDate]\r\n );\r\n\r\n const handleYearMonthChange = useCallback(month => {\r\n setMonthDate(month);\r\n }, []);\r\n\r\n const handleDayClick = useCallback(\r\n (day, { selected }) => {\r\n const dateStr = mapDateToAusDateStr(day);\r\n onSelect(dateStr);\r\n },\r\n [onSelect]\r\n );\r\n\r\n const disabledDays = useMemo(() => [{ after: toDate }], []);\r\n\r\n const captionElement = useCallback(\r\n ({ date, localeUtils }) => {\r\n return (\r\n <YearMonthForm\r\n date={date}\r\n localeUtils={localeUtils}\r\n onChange={handleYearMonthChange}\r\n />\r\n );\r\n },\r\n [handleYearMonthChange]\r\n );\r\n return (\r\n <DayPicker\r\n className=\"birthday-calendar\"\r\n onDayClick={handleDayClick}\r\n month={monthDate}\r\n fromMonth={fromDate}\r\n toMonth={toDate}\r\n renderDay={renderDay}\r\n disabledDays={disabledDays}\r\n captionElement={captionElement}\r\n />\r\n );\r\n});\r\n\r\nDateOfBirthCalendar.propTypes = {\r\n dateString: PropTypes.string,\r\n valid: PropTypes.bool,\r\n onSelect: PropTypes.func.isRequired\r\n};\r\n\r\n// year month selection in the calendar header\r\nconst YearMonthForm = memo(({ date, localeUtils, onChange }) => {\r\n const months = localeUtils.getMonths();\r\n\r\n const years = [];\r\n for (let i = fromDate.getFullYear(); i <= toDate.getFullYear(); i++) {\r\n years.push(i);\r\n }\r\n\r\n const handleChange = function handleChange(e) {\r\n const { year, month } = e.target.form;\r\n onChange(new Date(year.value, month.value));\r\n };\r\n\r\n return (\r\n <form className=\"DayPicker-Caption\" style={backgroundStyle}>\r\n <select name=\"month\" onChange={handleChange} value={date.getMonth()}>\r\n {months.map((month, i) => (\r\n <option key={month} value={i}>\r\n {month}\r\n </option>\r\n ))}\r\n </select>\r\n <select name=\"year\" onChange={handleChange} value={date.getFullYear()}>\r\n {years.map(year => (\r\n <option key={year} value={year}>\r\n {year}\r\n </option>\r\n ))}\r\n </select>\r\n </form>\r\n );\r\n});\r\n\r\nconst hoverStyle = {\r\n color: \"#fff\",\r\n ...backgroundStyle\r\n};\r\nconst DayComponent = memo(props => {\r\n const [hoverRef, isHovered] = useHover();\r\n const { date, selected } = props;\r\n return (\r\n <div\r\n ref={hoverRef}\r\n className=\"birthday-calendar-day\"\r\n style={isHovered || selected ? hoverStyle : null}\r\n >\r\n {date}\r\n </div>\r\n );\r\n});\r\n","import React, { memo, useMemo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport TextField from \"@material-ui/core/TextField\";\r\nimport { CloseIcon } from \"../Icon\";\r\nimport \"./inputBox.less\";\r\n\r\nexport const InputBox = memo(props => {\r\n const {\r\n label,\r\n value,\r\n errorText,\r\n onBlur,\r\n onChange,\r\n className = \"\",\r\n ...restProps\r\n } = props;\r\n const errorTextComponent = useMemo(() => {\r\n return <InputBoxError errorText={errorText} />;\r\n }, [errorText]);\r\n return (\r\n <TextField\r\n {...restProps}\r\n error={!!errorText}\r\n label={label}\r\n value={value}\r\n helperText={errorTextComponent}\r\n onChange={e => onChange(e.target.value)}\r\n onBlur={onBlur}\r\n className={`client-portal-input-box ${className}`}\r\n />\r\n );\r\n});\r\n\r\nInputBox.propTypes = {\r\n label: PropTypes.string.isRequired,\r\n value: PropTypes.string,\r\n errorText: PropTypes.string,\r\n onBlur: PropTypes.func,\r\n onChange: PropTypes.func.isRequired,\r\n className: PropTypes.string\r\n};\r\n\r\nconst InputBoxError = memo(props => {\r\n const { errorText } = props;\r\n if (!errorText) return null;\r\n return (\r\n <span className=\"input-error-text\">\r\n <CloseIcon />\r\n {errorText}\r\n </span>\r\n );\r\n});\r\n\r\nInputBoxError.propTypes = {\r\n errorText: PropTypes.string\r\n};\r\n","import React, { memo, useState, useCallback } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport Autocomplete from \"@material-ui/lab/Autocomplete\";\r\nimport { InputBox } from \"../InputBox/InputBox\";\r\nimport \"./autocompleteBox.less\";\r\n\r\nexport const AutocompleteBox = memo(props => {\r\n const [inputText, setInputText] = useState(\"\");\r\n const { label, options, onChange, onSearch, ...restProps } = props;\r\n const handleChange = useCallback(\r\n (e, option) => {\r\n if (!option) setInputText(\"\");\r\n\r\n onChange(option.value);\r\n setInputText(option.text);\r\n },\r\n [onChange]\r\n );\r\n\r\n const handleSearch = value => {\r\n setInputText(value);\r\n onSearch && onSearch(value);\r\n };\r\n return (\r\n <Autocomplete\r\n {...restProps}\r\n className=\"client-portal-autocomplete\"\r\n disableClearable\r\n options={options}\r\n onChange={handleChange}\r\n getOptionLabel={option => option.text}\r\n renderInput={params => {\r\n return (\r\n <InputBox\r\n {...params}\r\n label={label}\r\n fullWidth\r\n value={inputText}\r\n onChange={handleSearch}\r\n inputProps={{\r\n ...params.inputProps,\r\n autoComplete: \"none\"\r\n }}\r\n />\r\n );\r\n }}\r\n />\r\n );\r\n});\r\n\r\nAutocompleteBox.propTypes = {\r\n label: PropTypes.string.isRequired,\r\n options: PropTypes.array,\r\n onChange: PropTypes.func.isRequired\r\n};\r\n","import React, { memo, useCallback, useEffect } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport Autocomplete from \"@material-ui/lab/Autocomplete\";\r\nimport CircularProgress from \"@material-ui/core/CircularProgress\";\r\nimport { InputBox } from \"../InputBox/InputBox\";\r\nimport { blurInputWhenTypeEnter } from \"../../../../utils\";\r\nimport \"./autocompleteBox.less\";\r\n\r\nexport const ComboBox = memo(props => {\r\n const {\r\n label,\r\n value,\r\n errorText,\r\n options,\r\n onChange,\r\n onSearch,\r\n onBlur,\r\n loading,\r\n ...restProps\r\n } = props;\r\n\r\n useEffect(() => {\r\n document.addEventListener(\"keyup\", blurInputWhenTypeEnter, false);\r\n return () => {\r\n document.removeEventListener(\"keyup\", blurInputWhenTypeEnter, false);\r\n };\r\n }, []);\r\n const handleChange = useCallback(\r\n (e, option) => {\r\n onChange(option.value, option);\r\n\r\n setTimeout(() => {\r\n // blur the input box\r\n document.activeElement && document.activeElement.blur();\r\n }, 0);\r\n },\r\n [onChange]\r\n );\r\n\r\n const handleSearch = value => {\r\n onSearch(value);\r\n };\r\n return (\r\n <div className=\"client-portal-autocomplete-container\">\r\n <Autocomplete\r\n {...restProps}\r\n freeSolo\r\n className=\"client-portal-autocomplete\"\r\n disableClearable\r\n options={options}\r\n onChange={handleChange}\r\n getOptionLabel={option => {\r\n return option.text || option;\r\n }}\r\n filterSelectedOptions={true}\r\n noOptionsText={\"\"}\r\n inputValue={value || \"\"}\r\n autoHighlight={true}\r\n renderInput={params => {\r\n return (\r\n <InputBox\r\n {...params}\r\n label={label}\r\n fullWidth\r\n value={value}\r\n onChange={handleSearch}\r\n onBlur={onBlur}\r\n errorText={errorText}\r\n inputProps={{\r\n ...params.inputProps,\r\n autoComplete: \"none\"\r\n }}\r\n />\r\n );\r\n }}\r\n />\r\n {loading && (\r\n <CircularProgress\r\n size={16}\r\n className=\"client-portal-autocomplete-spinner\"\r\n />\r\n )}\r\n </div>\r\n );\r\n});\r\n\r\nComboBox.propTypes = {\r\n label: PropTypes.string.isRequired,\r\n value: PropTypes.string,\r\n errorText: PropTypes.string,\r\n options: PropTypes.array,\r\n onChange: PropTypes.func.isRequired,\r\n onSearch: PropTypes.func.isRequired,\r\n onBlur: PropTypes.func,\r\n loading: PropTypes.bool\r\n};\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport Dialog from \"@material-ui/core/Dialog\";\r\nimport { CloseIcon, ThemeColorButton } from \"../\";\r\nimport \"./modal.less\";\r\n\r\nexport const Modal = memo(props => {\r\n const { open, title, message, onClose, onConfirm } = props;\r\n\r\n return (\r\n <Dialog\r\n classes={{\r\n root: \"zindex-message\",\r\n paperScrollPaper: \"modal-container\"\r\n }}\r\n open={open}\r\n >\r\n {open && (\r\n <div className=\"modal-content\">\r\n <div className=\"modal-content-header\">\r\n <h2 className=\"modal-content-title\">{title}</h2>\r\n <CloseIcon className=\"modal-close-btn\" onClick={onClose} />\r\n </div>\r\n <div className=\"modal-content-body\">{message}</div>\r\n <div className=\"modal-content-button\">\r\n <ThemeColorButton label=\"Confirm\" onClick={onConfirm} />\r\n </div>\r\n </div>\r\n )}\r\n </Dialog>\r\n );\r\n});\r\n\r\nModal.propTypes = {\r\n open: PropTypes.bool.isRequired,\r\n title: PropTypes.string,\r\n message: PropTypes.oneOfType([\r\n PropTypes.arrayOf(PropTypes.node),\r\n PropTypes.node,\r\n PropTypes.string\r\n ]).isRequired,\r\n onClose: PropTypes.func.isRequired,\r\n onConfirm: PropTypes.func.isRequired\r\n};\r\n","import React, { memo, useMemo, useState, useCallback } from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport moment from 'moment';\r\nimport { MaterialUIIcon } from '../Icon';\r\nimport { backgroundStyle } from '../../styles';\r\n\r\nconst currentMoment = moment();\r\nconst currentYear = currentMoment.format('YYYY');\r\nconst currentMonth = currentMoment.format('M');\r\n\r\nconst monthArr = [\r\n { label: 'Jan', value: 1 },\r\n { label: 'Feb', value: 2 },\r\n { label: 'Mar', value: 3 },\r\n { label: 'Apr', value: 4 },\r\n { label: 'May', value: 5 },\r\n { label: 'Jun', value: 6 },\r\n { label: 'Jul', value: 7 },\r\n { label: 'Aug', value: 8 },\r\n { label: 'Sep', value: 9 },\r\n { label: 'Oct', value: 10 },\r\n { label: 'Nov', value: 11 },\r\n { label: 'Dec', value: 12 }\r\n];\r\n\r\nconst MonthYearPickerPanel = memo(\r\n ({ year, month, minYear, maxYear, onSelect, previousNotAllow }) => {\r\n const [yearValue, setYearValue] = useState(() => {\r\n return year ? parseInt(year, 10) : parseInt(currentYear, 10);\r\n });\r\n\r\n const yearInNumber = useMemo(() => {\r\n return year ? parseInt(year, 10) : parseInt(currentYear, 10);\r\n }, [year]);\r\n\r\n const monthValue = useMemo(() => {\r\n return month ? parseInt(month, 10) : null;\r\n }, [month]);\r\n\r\n const renderTitle = () => {\r\n return (\r\n <>\r\n {yearValue > minYear ? (\r\n <MaterialUIIcon\r\n iconKey=\"arrow_back_ios\"\r\n onClick={() => {\r\n setYearValue(yearValue - 1);\r\n }}\r\n />\r\n ) : (\r\n <span style={{ width: '1.5rem', height: '1.5rem' }} />\r\n )}\r\n <span>{yearValue}</span>\r\n {yearValue < maxYear ? (\r\n <MaterialUIIcon\r\n iconKey=\"arrow_forward_ios\"\r\n onClick={() => {\r\n setYearValue(yearValue + 1);\r\n }}\r\n />\r\n ) : (\r\n <span style={{ width: '1.5rem', height: '1.5rem' }} />\r\n )}\r\n </>\r\n );\r\n };\r\n\r\n const handleClickMonth = (val, disabled) => {\r\n if (disabled) return false;\r\n onSelect({ year: yearValue, month: val });\r\n };\r\n\r\n const getStyle = value => {\r\n return monthValue === value && yearValue === yearInNumber\r\n ? { ...backgroundStyle, color: '#fff' }\r\n : null;\r\n };\r\n\r\n const isPrevious = useCallback(\r\n monthVal => {\r\n if (!previousNotAllow) return false;\r\n return (\r\n yearValue <= parseInt(currentYear, 10) &&\r\n monthVal < parseInt(currentMonth, 10)\r\n );\r\n },\r\n [yearValue, previousNotAllow]\r\n );\r\n\r\n return (\r\n <div className=\"month-year-picker\">\r\n <div\r\n className=\"month-year-picker__title\"\r\n style={{ ...backgroundStyle }}\r\n >\r\n {renderTitle()}\r\n </div>\r\n <div className=\"month-year-picker__body\">\r\n {monthArr.map(({ label, value }) => {\r\n const disabled = isPrevious(value);\r\n return (\r\n <div\r\n key={value}\r\n onClick={() => {\r\n handleClickMonth(value, disabled);\r\n }}\r\n style={getStyle(value)}\r\n className={disabled ? 'disabled' : ''}\r\n >\r\n {label}\r\n </div>\r\n );\r\n })}\r\n </div>\r\n </div>\r\n );\r\n }\r\n);\r\n\r\nMonthYearPickerPanel.defaultProps = {\r\n minYear: parseInt(currentYear, 10),\r\n maxYear: parseInt(currentYear, 10) + 10,\r\n previousNotAllow: true\r\n};\r\n\r\nMonthYearPickerPanel.propTypes = {\r\n year: PropTypes.string,\r\n month: PropTypes.string,\r\n minYear: PropTypes.number,\r\n maxYear: PropTypes.number,\r\n onSelect: PropTypes.func.isRequired,\r\n previousNotAllow: PropTypes.bool\r\n};\r\n\r\nexport default MonthYearPickerPanel;\r\n","import React, { memo, useMemo, useState } from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport Dialog from '@material-ui/core/Dialog';\r\nimport { InputBox } from '../InputBox/InputBox';\r\nimport { MaterialUIIcon } from '../Icon';\r\nimport MonthYearPickerPanel from './MonthYearPickerPanel';\r\nimport './monthYearPicker.less';\r\n\r\nconst pad = val => {\r\n return val < 10 ? `0${val}` : val.toString();\r\n};\r\n\r\nexport const ExpiryMonth = memo(props => {\r\n const { label, value, errorText, onChange, onClose } = props;\r\n const [showCalendar, setShowCalendar] = useState(false);\r\n\r\n const handleSelectMonth = val => {\r\n onChange(val);\r\n setShowCalendar(false);\r\n };\r\n\r\n const floatingLabel = useMemo(() => {\r\n return showCalendar || !!value;\r\n }, [showCalendar, value]);\r\n\r\n const handleClear = () => {\r\n onChange('');\r\n };\r\n\r\n const handleClose = () => {\r\n setShowCalendar(false);\r\n onClose();\r\n };\r\n\r\n return (\r\n <div>\r\n <InputBox\r\n label={label}\r\n errorText={errorText}\r\n InputLabelProps={{\r\n shrink: floatingLabel\r\n }}\r\n placeholder={value}\r\n className=\"expiry-input\"\r\n disabled={true}\r\n onChange={() => {}}\r\n onClick={() => {\r\n setShowCalendar(true);\r\n }}\r\n />\r\n <CalendarPanel\r\n value={value}\r\n open={showCalendar}\r\n onClose={handleClose}\r\n onSelect={handleSelectMonth}\r\n />\r\n {value ? (\r\n <MaterialUIIcon\r\n onClick={handleClear}\r\n iconKey=\"cancel\"\r\n className=\"expiry-icon expiry-clear-icon\"\r\n />\r\n ) : (\r\n <MaterialUIIcon\r\n onClick={() => {\r\n setShowCalendar(true);\r\n }}\r\n iconKey=\"date_range\"\r\n className=\"expiry-icon expiry-calendar-icon\"\r\n />\r\n )}\r\n </div>\r\n );\r\n});\r\n\r\nExpiryMonth.propTypes = {\r\n label: PropTypes.string.isRequired,\r\n value: PropTypes.string,\r\n errorText: PropTypes.string,\r\n onChange: PropTypes.func.isRequired,\r\n onClose: PropTypes.func.isRequired\r\n};\r\n\r\nconst CalendarPanel = memo(props => {\r\n const { open, onClose, value, onSelect } = props;\r\n\r\n const { month, year } = useMemo(() => {\r\n if (!value) return { month: null, year: null };\r\n const splitArr = value.split('/');\r\n if (splitArr.length < 2) return { month: null, year: null };\r\n return { month: splitArr[0], year: splitArr[1] };\r\n }, [value]);\r\n\r\n const handleSelect = ({ year, month }) => {\r\n const value = `${pad(month)}/${year}`;\r\n onSelect(value);\r\n };\r\n\r\n return (\r\n <Dialog open={open} onClose={onClose} className=\"expiry-popup\">\r\n <MonthYearPickerPanel month={month} year={year} onSelect={handleSelect} />\r\n </Dialog>\r\n );\r\n});\r\n\r\nCalendarPanel.propTypes = {\r\n open: PropTypes.bool.isRequired,\r\n onClose: PropTypes.func.isRequired,\r\n value: PropTypes.string,\r\n onSelect: PropTypes.func.isRequired\r\n};\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\n\r\nexport const StepItem = memo(props => {\r\n const { hint, children } = props;\r\n return (\r\n <div className=\"booking-step-item\">\r\n {hint}\r\n {children}\r\n </div>\r\n );\r\n});\r\n\r\nStepItem.propTypes = {\r\n hint: PropTypes.string,\r\n children: PropTypes.oneOfType([\r\n PropTypes.arrayOf(PropTypes.node),\r\n PropTypes.node\r\n ])\r\n};\r\n","import React, { memo, Fragment, useMemo, useCallback, useEffect } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { StepItem } from \"./StepItem\";\r\nimport { Select } from \"../../../Common\";\r\nimport { mapSpecialtyTypesToOptions } from \"../../../helpers\";\r\nimport { STEP_KEYS } from \"../../../constants\";\r\n\r\nexport const SpecialtyTypeSelect = memo(props => {\r\n const {\r\n hint,\r\n open,\r\n value,\r\n onToggle,\r\n onSelect,\r\n specialtyTypes,\r\n hideStep\r\n } = props;\r\n\r\n const options = useMemo(() => mapSpecialtyTypesToOptions(specialtyTypes), [\r\n specialtyTypes\r\n ]);\r\n useEffect(() => {\r\n if (options.length === 1) {\r\n onSelect(options[0].value);\r\n }\r\n }, [onSelect, options]);\r\n\r\n const handleToggle = useCallback(\r\n open => {\r\n onToggle(STEP_KEYS.SPECIALTY_TYPE, open);\r\n },\r\n [onToggle]\r\n );\r\n\r\n return (\r\n <Fragment>\r\n {!hideStep && (\r\n <StepItem hint={hint}>\r\n <Select\r\n open={open}\r\n onToggle={handleToggle}\r\n value={value}\r\n placeholder=\"[select service]\"\r\n onSelect={onSelect}\r\n options={options}\r\n noOptionText=\"No service available\"\r\n />\r\n </StepItem>\r\n )}\r\n </Fragment>\r\n );\r\n});\r\n\r\nSpecialtyTypeSelect.propTypes = {\r\n hint: PropTypes.string.isRequired,\r\n open: PropTypes.bool.isRequired,\r\n value: PropTypes.string,\r\n onToggle: PropTypes.func.isRequired,\r\n onSelect: PropTypes.func.isRequired,\r\n specialtyTypes: PropTypes.array,\r\n hideStep: PropTypes.bool\r\n};\r\n","import { CSRF_TOKEN } from \"../../../api/config\";\r\n// specialty list in datasourece => options using in specialty types select\r\nexport const mapSpecialtyTypesToOptions = specialtyTypes => {\r\n if (!specialtyTypes) return [];\r\n return specialtyTypes.map(specialtyType => {\r\n return {\r\n label: specialtyType.name,\r\n value: specialtyType.specialtyTypeId\r\n };\r\n });\r\n};\r\n\r\n// appointment types in datasourece => options using in appointment types select\r\nexport const mapAppointmentTypesToOptions = appointmentTypes => {\r\n if (!appointmentTypes) return [];\r\n return appointmentTypes.map(appointmentType => {\r\n return {\r\n label: appointmentType.description,\r\n value: appointmentType.appointmentTypeId\r\n };\r\n });\r\n};\r\n\r\n// locations in datasourece => options using in location drawer\r\nexport const mapLocationsToDataInLocationDrawer = (locations, positions) => {\r\n if (!locations) return [];\r\n return locations.map(location => {\r\n const position = positions[location.locationId];\r\n return {\r\n locationId: location.locationId,\r\n name: location.name,\r\n position: position,\r\n streetAddress: location.streetAddress,\r\n suburb: location.suburb,\r\n state: location.state,\r\n country: location.country,\r\n postcode: location.postcode,\r\n timeZone: location.timeZone\r\n };\r\n });\r\n};\r\n\r\n// practitioner in datasourece => options using in practitioner drawer\r\nexport const mapPractitionersToDataInPractitionerDrawer = (\r\n practitioners,\r\n rootUrl\r\n) => {\r\n if (!practitioners) return [];\r\n return practitioners.map(practitioner => {\r\n return {\r\n practitionerId: practitioner.practitionerId,\r\n imageId: practitioner.imageId,\r\n firstName: practitioner.firstName,\r\n lastName: practitioner.lastName,\r\n description: practitioner.description,\r\n imageSrc: `${rootUrl}?imageId=${practitioner.imageId}&token=${CSRF_TOKEN}`\r\n };\r\n });\r\n};\r\n\r\n// time zone in datasourece => options using in time zone select\r\nexport const mapTimeZonesToOptions = locationTimeZones => {\r\n if (!locationTimeZones) return [];\r\n return locationTimeZones.map(timeZone => {\r\n return {\r\n label: timeZone.description,\r\n value: timeZone.timezoneUID\r\n };\r\n });\r\n};\r\n","import React, { memo, Fragment, useMemo, useCallback, useEffect } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { StepItem } from \"./StepItem\";\r\nimport { Select } from \"../../../Common\";\r\nimport { mapAppointmentTypesToOptions } from \"../../../helpers\";\r\nimport { STEP_KEYS } from \"../../../constants\";\r\n\r\nexport const AppointmentTypeSelect = memo(props => {\r\n const { hint, open, value, onToggle, onSelect, appointmentTypes } = props;\r\n const options = useMemo(\r\n () => mapAppointmentTypesToOptions(appointmentTypes),\r\n [appointmentTypes]\r\n );\r\n\r\n useEffect(() => {\r\n if (options.length === 1) {\r\n onSelect(options[0].value);\r\n }\r\n }, [onSelect, options]);\r\n\r\n const handleToggle = useCallback(\r\n open => {\r\n onToggle(STEP_KEYS.APPOINTMENT_TYPE, open);\r\n },\r\n [onToggle]\r\n );\r\n return (\r\n <Fragment>\r\n <StepItem hint={hint}>\r\n <Select\r\n open={open}\r\n onToggle={handleToggle}\r\n value={value}\r\n placeholder=\"[select type]\"\r\n onSelect={onSelect}\r\n options={options}\r\n noOptionText=\"No appointment type available\"\r\n />\r\n </StepItem>\r\n </Fragment>\r\n );\r\n});\r\n\r\nAppointmentTypeSelect.propTypes = {\r\n hint: PropTypes.string.isRequired,\r\n open: PropTypes.bool.isRequired,\r\n value: PropTypes.string,\r\n onToggle: PropTypes.func.isRequired,\r\n onSelect: PropTypes.func.isRequired,\r\n appointmentTypes: PropTypes.array\r\n};\r\n","import React, { memo, Fragment, useMemo, useCallback, useEffect } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { StepItem } from \"./StepItem\";\r\nimport { TextButton } from \"../../../Common\";\r\nimport { STEP_KEYS, ANY_SELECTION } from \"../../../constants\";\r\n\r\nexport const LocationSelect = memo(props => {\r\n const {\r\n hint,\r\n value,\r\n onToggle,\r\n onSelect,\r\n locations,\r\n getPositions,\r\n isCurrentStep\r\n } = props;\r\n\r\n useEffect(() => {\r\n if (isCurrentStep) {\r\n if (locations.length === 1) {\r\n onSelect(locations[0]);\r\n }\r\n getPositions();\r\n }\r\n\r\n // eslint-disable-next-line react-hooks/exhaustive-deps\r\n }, [isCurrentStep]);\r\n\r\n const text = useMemo(() => {\r\n if (value === ANY_SELECTION) {\r\n return \"Any location\";\r\n }\r\n const location = locations.find(location => location.locationId === value);\r\n if (location) {\r\n return `${location.name}, ${location.suburb}`;\r\n } else {\r\n return \"\";\r\n }\r\n }, [value, locations]);\r\n\r\n const handleClick = useCallback(() => {\r\n onToggle(STEP_KEYS.LOCATION, true);\r\n }, [onToggle]);\r\n\r\n return (\r\n <Fragment>\r\n <StepItem hint={hint}>\r\n <TextButton\r\n text={text}\r\n placeholder=\"[select location]\"\r\n onClick={handleClick}\r\n />\r\n </StepItem>\r\n </Fragment>\r\n );\r\n});\r\n\r\nLocationSelect.propTypes = {\r\n hint: PropTypes.string.isRequired,\r\n value: PropTypes.string,\r\n onToggle: PropTypes.func.isRequired,\r\n onSelect: PropTypes.func.isRequired,\r\n locations: PropTypes.array,\r\n getPositions: PropTypes.func.isRequired,\r\n isCurrentStep: PropTypes.bool.isRequired\r\n};\r\n","import React, { memo, useMemo, useCallback, useEffect } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { StepItem } from \"./StepItem\";\r\nimport { TextButton } from \"../../../Common\";\r\nimport { STEP_KEYS, ANY_SELECTION } from \"../../../constants\";\r\n\r\nexport const PractitionerSelect = memo(props => {\r\n const {\r\n hint,\r\n value,\r\n onToggle,\r\n onSelect,\r\n practitioners,\r\n preSelectPractitioner,\r\n isCurrentStep\r\n } = props;\r\n\r\n useEffect(() => {\r\n if (isCurrentStep) {\r\n if (preSelectPractitioner === ANY_SELECTION) {\r\n const anyPractitioner = {\r\n practitionerId: ANY_SELECTION\r\n };\r\n onSelect(anyPractitioner);\r\n } else if (practitioners.length === 1) {\r\n onSelect(practitioners[0]);\r\n }\r\n }\r\n // eslint-disable-next-line react-hooks/exhaustive-deps\r\n }, [isCurrentStep]);\r\n\r\n const text = useMemo(() => {\r\n if (value === ANY_SELECTION) {\r\n return \"Any practitioner\";\r\n }\r\n const practitioner = practitioners.find(\r\n practitioner => practitioner.practitionerId === value\r\n );\r\n if (practitioner) {\r\n return `${practitioner.firstName} ${practitioner.lastName}`;\r\n } else {\r\n return \"\";\r\n }\r\n }, [value, practitioners]);\r\n\r\n const handleClick = useCallback(() => {\r\n onToggle(STEP_KEYS.PRACTITIONER, true);\r\n }, [onToggle]);\r\n\r\n if (preSelectPractitioner === ANY_SELECTION) return null;\r\n\r\n return (\r\n <StepItem hint={hint}>\r\n <TextButton\r\n text={text}\r\n placeholder=\"[select practitioner]\"\r\n onClick={handleClick}\r\n />\r\n </StepItem>\r\n );\r\n});\r\n\r\nPractitionerSelect.propTypes = {\r\n hint: PropTypes.string.isRequired,\r\n value: PropTypes.string,\r\n onToggle: PropTypes.func.isRequired,\r\n onSelect: PropTypes.func.isRequired,\r\n practitioners: PropTypes.array,\r\n preSelectPractitioner: PropTypes.string,\r\n isCurrentStep: PropTypes.bool.isRequired\r\n};\r\n","import React, { memo, Fragment, useMemo, useCallback, useEffect } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { StepItem } from \"./StepItem\";\r\nimport { Select } from \"../../../Common\";\r\nimport { mapTimeZonesToOptions } from \"../../../helpers\";\r\nimport { STEP_KEYS } from \"../../../constants\";\r\n\r\nexport const TimeZoneSelect = memo(props => {\r\n const {\r\n hint,\r\n open,\r\n value,\r\n onToggle,\r\n onSelect,\r\n timeZones,\r\n hideStep,\r\n isTimezoneEnabled\r\n } = props;\r\n\r\n const hintText = isTimezoneEnabled ? \"in the same time zone as\" : hint;\r\n\r\n const options = useMemo(() => mapTimeZonesToOptions(timeZones), [timeZones]);\r\n\r\n useEffect(() => {\r\n if (options.length === 1) {\r\n onSelect(options[0].value);\r\n }\r\n }, [onSelect, options]);\r\n\r\n const handleToggle = useCallback(\r\n open => {\r\n onToggle(STEP_KEYS.TIMEZONE, open);\r\n },\r\n [onToggle]\r\n );\r\n\r\n return (\r\n <Fragment>\r\n {!hideStep && (\r\n <StepItem hint={hintText}>\r\n <Select\r\n open={open}\r\n onToggle={handleToggle}\r\n value={value}\r\n placeholder=\"[select timezone]\"\r\n onSelect={onSelect}\r\n options={options}\r\n />\r\n </StepItem>\r\n )}\r\n </Fragment>\r\n );\r\n});\r\n\r\nTimeZoneSelect.propTypes = {\r\n hint: PropTypes.string.isRequired,\r\n open: PropTypes.bool.isRequired,\r\n value: PropTypes.string,\r\n onToggle: PropTypes.func.isRequired,\r\n onSelect: PropTypes.func.isRequired,\r\n timeZones: PropTypes.array,\r\n hideStep: PropTypes.bool,\r\n isTimezoneEnabled: PropTypes.bool\r\n};\r\n","import React, { memo, Fragment, useMemo, useCallback } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { StepItem } from \"./StepItem\";\r\nimport { TextButton } from \"../../../Common\";\r\nimport { STEP_KEYS } from \"../../../constants\";\r\nimport { mapDateTimeStringToText } from \"../../../helpers\";\r\n\r\nexport const ScheduleSelect = memo(props => {\r\n const {\r\n hint,\r\n appointmentDateTime,\r\n noSlotsPlaceholder,\r\n loading,\r\n onToggle,\r\n timeSlots\r\n } = props;\r\n\r\n const text = useMemo(() => {\r\n let text = \"\";\r\n const startDateTime = appointmentDateTime\r\n ? appointmentDateTime.startDateTime\r\n : null;\r\n if (startDateTime) {\r\n text = mapDateTimeStringToText(startDateTime);\r\n }\r\n return text;\r\n }, [appointmentDateTime]);\r\n\r\n const placeholderText = useMemo(() => {\r\n return (timeSlots && timeSlots.length > 0) || loading\r\n ? \"[select date & time]\"\r\n : noSlotsPlaceholder || \"[No Slots Available]\";\r\n }, [timeSlots, loading, noSlotsPlaceholder]);\r\n\r\n const handleClick = useCallback(() => {\r\n onToggle(STEP_KEYS.APPOINTMENT_DATE_TIME, true);\r\n }, [onToggle]);\r\n\r\n return (\r\n <Fragment>\r\n <StepItem hint={hint}>\r\n <TextButton\r\n text={text}\r\n placeholder={placeholderText}\r\n onClick={handleClick}\r\n />\r\n </StepItem>\r\n </Fragment>\r\n );\r\n});\r\n\r\nScheduleSelect.propTypes = {\r\n hint: PropTypes.string.isRequired,\r\n appointmentDateTime: PropTypes.object,\r\n noSlotsPlaceholder: PropTypes.string,\r\n loading: PropTypes.bool.isRequired,\r\n onToggle: PropTypes.func.isRequired,\r\n timeSlots: PropTypes.array\r\n};\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { DoneIcon } from \"../../../Common\";\r\nimport { useHover } from \"../../../hooks\";\r\nimport { borderColorStyle, backgroundStyle } from \"../../../styles\";\r\n\r\nexport const DrawerCardContainer = memo(props => {\r\n const [hoverRef, isHovered] = useHover();\r\n const { onClick, selected, children } = props;\r\n\r\n return (\r\n <div\r\n ref={hoverRef}\r\n onClick={onClick}\r\n className=\"drawer-card\"\r\n style={selected || isHovered ? borderColorStyle : null}\r\n >\r\n {children}\r\n {selected && (\r\n <DoneIcon className=\"selected-icon\" style={backgroundStyle} />\r\n )}\r\n </div>\r\n );\r\n});\r\n\r\nDrawerCardContainer.propTypes = {\r\n onClick: PropTypes.func.isRequired,\r\n selected: PropTypes.bool,\r\n children: PropTypes.oneOfType([\r\n PropTypes.arrayOf(PropTypes.node),\r\n PropTypes.node\r\n ])\r\n};\r\n","import React, { memo, useMemo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { GoogleMap, LocationNotFound } from \"../../../Common\";\r\nimport { DrawerCardContainer } from \"./DrawerCardContainer\";\r\nimport { getFullAddress } from \"../../../helpers\";\r\n\r\nexport const LocationListCard = memo(props => {\r\n const { location, onClick, selected } = props;\r\n\r\n const { position, name } = location;\r\n\r\n const addressText = useMemo(() => {\r\n return getFullAddress(location);\r\n }, [location]);\r\n return (\r\n <DrawerCardContainer onClick={() => onClick(location)} selected={selected}>\r\n <div className=\"location-card\">\r\n <div className=\"media\">\r\n <div className=\"google-map-overlay\" />\r\n {position ? (\r\n <GoogleMap zoom={15} position={position} />\r\n ) : (\r\n <LocationNotFound name={name} />\r\n )}\r\n </div>\r\n <div className=\"information-panel\">\r\n <span className=\"info-title\">{name}</span>\r\n <span className=\"info-desc\">{addressText}</span>\r\n </div>\r\n </div>\r\n </DrawerCardContainer>\r\n );\r\n});\r\n\r\nLocationListCard.propTypes = {\r\n selected: PropTypes.bool.isRequired,\r\n location: PropTypes.shape({\r\n locationId: PropTypes.string.isRequired,\r\n position: PropTypes.shape({\r\n lat: PropTypes.number,\r\n lng: PropTypes.number\r\n }),\r\n name: PropTypes.string,\r\n streetAddress: PropTypes.string,\r\n suburb: PropTypes.string,\r\n state: PropTypes.string,\r\n postcode: PropTypes.string\r\n }),\r\n onClick: PropTypes.func.isRequired\r\n};\r\n","import React, { memo, useCallback, useMemo, useState } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { SideDrawer, FullWidthButton } from \"../../../Common\";\r\nimport TextField from \"@material-ui/core/TextField\";\r\nimport { LocationListCard } from \"./LocationListCard\";\r\nimport { STEP_KEYS, ANY_SELECTION } from \"../../../constants\";\r\nimport {\r\n mapLocationsToDataInLocationDrawer,\r\n isTimeZoneUnique\r\n} from \"../../../helpers\";\r\nimport { Alert } from \"../\";\r\n\r\nexport const LocationDrawer = memo(props => {\r\n const [search, setSearch] = useState(\"\");\r\n const { open, onToggle, onSelect, value, locations, positions } = props;\r\n\r\n const showAnyLocationButton = useMemo(() => {\r\n return locations.length > 1 && isTimeZoneUnique(locations);\r\n }, [locations]);\r\n\r\n const locationList = useMemo(\r\n () => mapLocationsToDataInLocationDrawer(locations, positions),\r\n [locations, positions]\r\n );\r\n\r\n const handleToggle = useCallback(\r\n open => {\r\n onToggle(STEP_KEYS.LOCATION, open);\r\n },\r\n [onToggle]\r\n );\r\n\r\n const handleSelect = useCallback(\r\n location => {\r\n handleToggle(false);\r\n onSelect(location);\r\n },\r\n [handleToggle, onSelect]\r\n );\r\n\r\n const handleSelectAny = useCallback(() => {\r\n const firstLocation = locationList[0];\r\n const location = {\r\n ...firstLocation,\r\n locationId: ANY_SELECTION\r\n };\r\n handleSelect(location);\r\n }, [handleSelect, locationList]);\r\n\r\n const handleSearch = useCallback(e => {\r\n const newSearch = e.target.value;\r\n setSearch(newSearch);\r\n }, []);\r\n\r\n const filterLocations = useCallback(\r\n locations => {\r\n const filterBy = search.toLowerCase();\r\n if (!filterBy) return locations;\r\n\r\n return locations.filter(location => {\r\n const { name, streetAddress, postcode, suburb, country } = location;\r\n return (\r\n name.toLowerCase().includes(filterBy) ||\r\n streetAddress.toLowerCase().includes(filterBy) ||\r\n postcode.toLowerCase().includes(filterBy) ||\r\n suburb.toLowerCase().includes(filterBy) ||\r\n country.toLowerCase().includes(filterBy)\r\n );\r\n });\r\n },\r\n [search]\r\n );\r\n\r\n const renderLocations = useMemo(() => {\r\n if (!open) return null;\r\n const filteredLocations = filterLocations(locationList);\r\n if (filteredLocations.length === 0)\r\n return <Alert message=\"No location available\" />;\r\n\r\n return filteredLocations.map(location => (\r\n <LocationListCard\r\n key={location.locationId}\r\n onClick={handleSelect}\r\n location={location}\r\n selected={value === location.locationId}\r\n />\r\n ));\r\n }, [locationList, handleSelect, value, open, filterLocations]);\r\n\r\n return (\r\n <SideDrawer open={open} onToggle={handleToggle}>\r\n <span className=\"drawer-title\">Select preferred location</span>\r\n {showAnyLocationButton && (\r\n <FullWidthButton\r\n label=\"Any available location\"\r\n className=\"drawer-top-full-button\"\r\n onClick={handleSelectAny}\r\n />\r\n )}\r\n <TextField\r\n className=\"drawer-search-input\"\r\n value={search}\r\n onChange={handleSearch}\r\n />\r\n <div className=\"drawer-list\">{renderLocations}</div>\r\n </SideDrawer>\r\n );\r\n});\r\n\r\nLocationDrawer.propTypes = {\r\n open: PropTypes.bool.isRequired,\r\n onToggle: PropTypes.func.isRequired,\r\n onSelect: PropTypes.func.isRequired,\r\n value: PropTypes.string,\r\n locations: PropTypes.array,\r\n positions: PropTypes.object\r\n};\r\n","import React, { memo, useState, useCallback } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { Avatar } from \"@material-ui/core\";\r\n\r\nexport const PractitionerAvatar = memo(props => {\r\n const [error, setError] = useState(false);\r\n\r\n const { useInitial, src, initial } = props;\r\n\r\n const handleError = useCallback(() => {\r\n setError(true);\r\n }, []);\r\n\r\n return !error && !useInitial ? (\r\n <img\r\n src={src}\r\n alt={initial}\r\n onError={handleError}\r\n className=\"practitioner-avatar-image\"\r\n />\r\n ) : (\r\n <Avatar className=\"practitioner-avatar-icon\">{initial}</Avatar>\r\n );\r\n});\r\n\r\nPractitionerAvatar.propTypes = {\r\n useInitial: PropTypes.bool.isRequired,\r\n src: PropTypes.string,\r\n initial: PropTypes.string.isRequired\r\n};\r\n","import React, { memo, useCallback } from \"react\";\r\nimport Tooltip from \"@material-ui/core/Tooltip\";\r\nimport { colorStyle } from \"../../../styles\";\r\nimport { useHover } from \"../../../hooks\";\r\n\r\nexport const EllipsisButton = memo(props => {\r\n const { onClick, tooltipContent = \"expand\" } = props;\r\n const [hoverRef, isHovered] = useHover();\r\n\r\n const handleClick = useCallback(\r\n e => {\r\n e.preventDefault();\r\n e.stopPropagation();\r\n onClick();\r\n },\r\n [onClick]\r\n );\r\n return (\r\n <Tooltip title={tooltipContent}>\r\n <button ref={hoverRef} onClick={handleClick} className=\"ellipsis-btn\">\r\n <span className=\"ellipsis-btn-left\"></span>\r\n <span\r\n className=\"ellipsis-btn-right\"\r\n style={isHovered ? colorStyle : null}\r\n >\r\n (...)\r\n </span>\r\n </button>\r\n </Tooltip>\r\n );\r\n});\r\n","import React, {\r\n memo,\r\n useRef,\r\n useCallback,\r\n useMemo,\r\n useEffect,\r\n useState\r\n} from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { PractitionerAvatar } from \"./PractitionerAvatar\";\r\nimport { DrawerCardContainer } from \"./DrawerCardContainer\";\r\nimport { EllipsisButton } from \"./EllipsisButton\";\r\nimport { getDomStyleProperty } from \"../../../../../utils\";\r\n\r\nconst maxHeight = 44;\r\nconst maxHeightStyle = { maxHeight: \"44px\" };\r\n\r\nexport const PractitionerListCard = memo(props => {\r\n const descriptionRef = useRef();\r\n const [isHigher, setIsHigher] = useState(false);\r\n const { selected, practitioner, onClick, expanded, setExpanded } = props;\r\n const {\r\n practitionerId,\r\n imageId,\r\n imageSrc,\r\n firstName,\r\n lastName,\r\n description\r\n } = practitioner;\r\n\r\n const getFirstLetterUpperCase = useCallback(str => {\r\n if (!str) return \"\";\r\n return str.charAt(0).toUpperCase();\r\n }, []);\r\n const initialNameText = useMemo(() => {\r\n return `${getFirstLetterUpperCase(firstName)}${getFirstLetterUpperCase(\r\n lastName\r\n )}`;\r\n }, [firstName, lastName, getFirstLetterUpperCase]);\r\n\r\n useEffect(() => {\r\n let currentHeight = 0;\r\n if (descriptionRef.current) {\r\n currentHeight = getDomStyleProperty(\r\n descriptionRef.current,\r\n \"height\"\r\n ).replace(\"px\", \"\");\r\n if (currentHeight > maxHeight) {\r\n !isHigher && setIsHigher(true);\r\n } else {\r\n isHigher && setIsHigher(false);\r\n }\r\n }\r\n // eslint-disable-next-line react-hooks/exhaustive-deps\r\n }, []);\r\n\r\n const showButton = useMemo(() => isHigher && !expanded, [isHigher, expanded]);\r\n const descriptionDomStyle = useMemo(\r\n () => (showButton ? maxHeightStyle : null),\r\n [showButton]\r\n );\r\n return (\r\n <DrawerCardContainer\r\n onClick={() => onClick(practitioner)}\r\n selected={selected}\r\n >\r\n <div className=\"practitioner-card\">\r\n <div className=\"media\">\r\n <PractitionerAvatar\r\n useInitial={!imageId}\r\n src={imageSrc}\r\n initial={initialNameText}\r\n />\r\n </div>\r\n <div className=\"information-panel\">\r\n <span className=\"info-title\">{`${firstName} ${lastName}`}</span>\r\n <span\r\n className={\"info-desc\"}\r\n ref={descriptionRef}\r\n style={descriptionDomStyle}\r\n >\r\n {/* <Collapse\r\n isOpened={expanded}\r\n initialStyle={{ height: \"44px\", overflow: \"hidden\" }}\r\n > */}\r\n {description}\r\n {/* </Collapse> */}\r\n </span>\r\n {showButton && (\r\n <EllipsisButton onClick={() => setExpanded(practitionerId)} />\r\n )}\r\n </div>\r\n </div>\r\n </DrawerCardContainer>\r\n );\r\n});\r\n\r\nPractitionerListCard.propTypes = {\r\n selected: PropTypes.bool.isRequired,\r\n practitioner: PropTypes.shape({\r\n practitionerId: PropTypes.string.isRequired,\r\n imageId: PropTypes.string,\r\n firstName: PropTypes.string.isRequired,\r\n lastName: PropTypes.string.isRequired,\r\n description: PropTypes.string,\r\n imageSrc: PropTypes.string\r\n }),\r\n onClick: PropTypes.func.isRequired\r\n};\r\n","import React, { memo, useCallback, useMemo, useState } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { SideDrawer, FullWidthButton } from \"../../../Common\";\r\nimport { PractitionerListCard } from \"./PractitionerListCard\";\r\nimport { Alert } from \"../\";\r\nimport { STEP_KEYS, ANY_SELECTION } from \"../../../constants\";\r\nimport { mapPractitionersToDataInPractitionerDrawer } from \"../../../helpers\";\r\n\r\nexport const PractitionerDrawer = memo(props => {\r\n const [expandedCard, setExpandedCard] = useState(null);\r\n const { open, onToggle, onSelect, value, practitioners, tenant, isAnyPractitionerEnabled } = props;\r\n\r\n const showAnyPractitionerButton = useMemo(() => {\r\n return practitioners.length > 1 && isAnyPractitionerEnabled;\r\n }, [practitioners]);\r\n\r\n const handleToggle = useCallback(\r\n open => {\r\n onToggle(STEP_KEYS.PRACTITIONER, open);\r\n setExpandedCard(null);\r\n },\r\n [onToggle]\r\n );\r\n\r\n const photoImageRootUrl = useMemo(\r\n () => `/${tenant}/api/appointmentbooking/Image`,\r\n [tenant]\r\n );\r\n\r\n const practitionerList = useMemo(\r\n () =>\r\n mapPractitionersToDataInPractitionerDrawer(\r\n practitioners,\r\n photoImageRootUrl\r\n ),\r\n [practitioners, photoImageRootUrl]\r\n );\r\n\r\n const handleSelect = useCallback(\r\n practitionerId => {\r\n handleToggle(false);\r\n onSelect(practitionerId);\r\n },\r\n [handleToggle, onSelect]\r\n );\r\n\r\n const handleSelectAny = useCallback(() => {\r\n const anyPractitioner = {\r\n practitionerId: ANY_SELECTION\r\n };\r\n handleSelect(anyPractitioner);\r\n }, [handleSelect]);\r\n\r\n const renderPractitionerList = useMemo(() => {\r\n if (practitionerList.length === 0)\r\n return <Alert message=\"No practitioner available\" />;\r\n return practitionerList.map(practitioner => (\r\n <PractitionerListCard\r\n key={practitioner.practitionerId}\r\n selected={value === practitioner.practitionerId}\r\n practitioner={practitioner}\r\n onClick={handleSelect}\r\n expanded={expandedCard === practitioner.practitionerId}\r\n setExpanded={setExpandedCard}\r\n />\r\n ));\r\n }, [practitionerList, value, handleSelect, expandedCard]);\r\n\r\n return ( \r\n <SideDrawer open={open} onToggle={handleToggle}>\r\n <span className=\"drawer-title\">Select preferred practitioner</span>\r\n {showAnyPractitionerButton && (\r\n <FullWidthButton\r\n label=\"Any available practitioner\"\r\n className=\"drawer-top-full-button\"\r\n onClick={handleSelectAny}\r\n />\r\n )}\r\n <div className=\"drawer-list\">{renderPractitionerList}</div>\r\n </SideDrawer>\r\n );\r\n});\r\n\r\nPractitionerDrawer.propTypes = {\r\n open: PropTypes.bool.isRequired,\r\n onToggle: PropTypes.func.isRequired,\r\n onSelect: PropTypes.func.isRequired,\r\n value: PropTypes.string,\r\n practitioners: PropTypes.array,\r\n tenant: PropTypes.string\r\n};\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { ThemeColorButton } from \"../../../Common\";\r\nimport { DoneIcon } from \"../../../Common\";\r\n\r\nexport const WaitingListButton = memo(props => {\r\n const { onClick, selected, label, className = \"\" } = props;\r\n return (\r\n <ThemeColorButton\r\n label={\r\n <>\r\n {selected && <DoneIcon />}\r\n {label}\r\n </>\r\n }\r\n onClick={onClick}\r\n className={className}\r\n />\r\n );\r\n});\r\n\r\nWaitingListButton.propTypes = {\r\n onClick: PropTypes.func.isRequired,\r\n selected: PropTypes.bool.isRequired,\r\n label: PropTypes.string.isRequired,\r\n className: PropTypes.string\r\n};\r\n","import React, { memo, useMemo } from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport { mapDateTimeToTimeText } from '../../../helpers';\r\nimport { backgroundStyle } from '../../../styles';\r\n\r\nconst TimeSlotList = memo(props => {\r\n const { isAM, timeSlots, onClick } = props;\r\n\r\n const title = useMemo(() => {\r\n const text = isAM ? 'AM' : 'PM';\r\n return `${text} Appointments`;\r\n }, [isAM]);\r\n\r\n if (!timeSlots || timeSlots.length === 0) return null;\r\n\r\n return (\r\n <div className=\"schedule-drawer-timeslot-container\">\r\n <h2 className=\"schedule-drawer-timeslot-title\">{title}</h2>\r\n <div className=\"schedule-drawer-timeslot-list\">\r\n {timeSlots.map((timeSlot, index) => (\r\n <TimeSlot key={index} timeSlot={timeSlot} onClick={onClick} />\r\n ))}\r\n </div>\r\n </div>\r\n );\r\n});\r\n\r\nTimeSlotList.propTypes = {\r\n isAM: PropTypes.bool,\r\n timeSlots: PropTypes.array,\r\n onClick: PropTypes.func\r\n};\r\n\r\nconst TimeSlot = memo(props => {\r\n const { timeSlot, onClick } = props;\r\n const { startDateTime, endDateTime } = timeSlot;\r\n const text = useMemo(() => {\r\n return `${mapDateTimeToTimeText(startDateTime)} - ${mapDateTimeToTimeText(\r\n endDateTime\r\n )}`;\r\n }, [startDateTime, endDateTime]);\r\n return (\r\n <div\r\n className=\"schedule-drawer-timeslot-item\"\r\n onClick={() => onClick(timeSlot)}\r\n style={backgroundStyle}\r\n >\r\n {text}\r\n </div>\r\n );\r\n});\r\n\r\nTimeSlot.propTypes = {\r\n timeSlot: PropTypes.object,\r\n onClick: PropTypes.func\r\n};\r\n\r\nexport default TimeSlotList;\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport LinearProgress from \"@material-ui/core/LinearProgress\";\r\n\r\nconst CalendarLoader = memo(props => {\r\n const { loading } = props;\r\n if (!loading) return null;\r\n return <LinearProgress mode=\"indeterminate\" color=\"primary\" />;\r\n});\r\n\r\nCalendarLoader.propTypes = {\r\n loading: PropTypes.bool\r\n};\r\n\r\nexport default CalendarLoader;\r\n","import React, {\r\n memo,\r\n useCallback,\r\n useMemo,\r\n useState,\r\n useEffect,\r\n useRef,\r\n Fragment\r\n} from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport moment from \"moment\";\r\nimport { SideDrawer, FullWidthButton, Calendar } from \"../../../Common\";\r\nimport { WaitingListButton } from \"./WaitingListButton\";\r\nimport TimeSlotList from \"./TimeSlotList\";\r\nimport CalendarLoader from \"./CalendarLoader\";\r\nimport { STEP_KEYS } from \"../../../constants\";\r\nimport {\r\n mapDateToTitle,\r\n createTimeSlotObjectForScheduleDrawer,\r\n getUniqueTimeSlots\r\n} from \"../../../helpers\";\r\nimport {\r\n getYearMonthPart,\r\n elementScrollTop,\r\n getDocumentDom\r\n} from \"../../../../../utils\";\r\nimport { useCheckMobile } from \"../../../hooks\";\r\n\r\nconst drawerDomIdentifier = \"#schedule-drawer .client-portal-drawer\";\r\n\r\nexport const ScheduleDrawer = memo(props => {\r\n const headingRef = useRef();\r\n const drawerRef = useRef();\r\n const [headingFloat, setHeadingFloat] = useState(false);\r\n const [selectedDay, setSelectedDay] = useState(null);\r\n const [selectedMonth, setSelectedMonth] = useState(null);\r\n const [nextTimeSlotText, setNextTimeSlotText] = useState(\"Next Available timeslot within 6 months\");\r\n const isMobile = useCheckMobile();\r\n const {\r\n open,\r\n onToggle,\r\n timeSlots,\r\n onSelect,\r\n loadingTimeSlots,\r\n getTimeSlots,\r\n isCurrentStep,\r\n availableLocations,\r\n earliestBookingTime,\r\n practitionerValue,\r\n appointmentDateTimeValue,\r\n waitingListEnabled,\r\n waitingList,\r\n setRequireWaitingList,\r\n selectPreferredTime,\r\n timezone\r\n } = props;\r\n\r\n const { required, preferredTime } = waitingList;\r\n\r\n const headerTopHeight = useMemo(() => (isMobile ? 70 : 85) + 40, [isMobile]);\r\n\r\n useEffect(() => {\r\n if (isCurrentStep && !appointmentDateTimeValue) {\r\n setSelectedDay(null);\r\n setSelectedMonth(null);\r\n const startTimeMomentJs = moment().add(earliestBookingTime, \"days\");\r\n const endTimeMomentJs = moment()\r\n .add(earliestBookingTime, \"days\")\r\n .endOf(\"month\");\r\n getTimeSlots(\r\n startTimeMomentJs,\r\n endTimeMomentJs,\r\n availableLocations,\r\n true\r\n );\r\n }\r\n // eslint-disable-next-line react-hooks/exhaustive-deps\r\n }, [isCurrentStep, practitionerValue, availableLocations, timezone]);\r\n\r\n const handleScroll = useCallback(() => {\r\n const headingDom = headingRef.current;\r\n if (headingDom) {\r\n const headingTop = headingDom.offsetTop;\r\n const drawerTop = drawerRef.current.scrollTop;\r\n setHeadingFloat(headingTop - headerTopHeight < drawerTop);\r\n }\r\n }, [headerTopHeight]);\r\n useEffect(() => {\r\n if (open) {\r\n const timer = setTimeout(() => {\r\n drawerRef.current = getDocumentDom(drawerDomIdentifier);\r\n drawerRef.current.addEventListener(\"scroll\", handleScroll);\r\n }, 0);\r\n return () => {\r\n clearTimeout(timer);\r\n drawerRef.current.removeEventListener(\"scroll\", handleScroll);\r\n };\r\n }\r\n }, [open, handleScroll]);\r\n\r\n const handleToggle = useCallback(\r\n open => {\r\n onToggle(STEP_KEYS.APPOINTMENT_DATE_TIME, open);\r\n setHeadingFloat(false);\r\n },\r\n [onToggle]\r\n );\r\n\r\n const renderDateTitle = useMemo(() => {\r\n return mapDateToTitle(selectedDay);\r\n }, [selectedDay]);\r\n\r\n const renderWaitingListContent = () => {\r\n return (\r\n <div>\r\n <span className=\"drawer-title\">\r\n I would prefer to be contacted during\r\n </span>\r\n\r\n <WaitingListButton\r\n label=\"AM\"\r\n selected={preferredTime === \"AM\"}\r\n onClick={() => selectPreferredTime(\"AM\")}\r\n className=\"waiting-list-time-btn\"\r\n />\r\n\r\n <WaitingListButton\r\n label=\"PM\"\r\n selected={preferredTime === \"PM\"}\r\n onClick={() => selectPreferredTime(\"PM\")}\r\n className=\"waiting-list-time-btn waiting-list-pm-btn\"\r\n />\r\n\r\n <FullWidthButton\r\n label=\"Go back to select a timeslot\"\r\n onClick={() => {\r\n setRequireWaitingList(false);\r\n }}\r\n />\r\n </div>\r\n );\r\n };\r\n\r\n const renderScheduleContent = () => {\r\n return (\r\n <Fragment>\r\n <span className=\"drawer-title\">SELECT A PREFERRED DATE AND TIME</span>\r\n <FullWidthButton\r\n label= {nextTimeSlotText}\r\n className=\"drawer-top-full-button\"\r\n onClick={handleClickNextTimeSlot}\r\n disabled={timeSlots.length === 0}\r\n />\r\n {waitingListEnabled && (\r\n <FullWidthButton\r\n label=\"No suitable timeslot available\"\r\n className=\"drawer-top-full-button waiting-list-full-button\"\r\n onClick={() => setRequireWaitingList()}\r\n />\r\n )}\r\n {open && (\r\n <div className=\"schedule-drawer-list\">\r\n <div className=\"schedule-drawer-calendar\">\r\n <Calendar\r\n month={month}\r\n fromMonth={initialMonth}\r\n timeSlots={timeSlotList}\r\n onDayClick={handleDayClick}\r\n selectedDay={selectedDay}\r\n onMonthChange={handleMonthClick}\r\n />\r\n </div>\r\n <CalendarLoader loading={loadingTimeSlots} />\r\n <div>\r\n {selectedDay && (\r\n <div className=\"schedule-drawer-timeslot\">\r\n <h1\r\n id=\"fixed-heading\"\r\n className=\"schedule-drawer-timeslot-heading\"\r\n ref={headingRef}\r\n >\r\n {renderDateTitle}\r\n </h1>\r\n <FloatHeading\r\n headingFloat={headingFloat}\r\n renderDateTitle={renderDateTitle}\r\n headerTopHeight={headerTopHeight}\r\n />\r\n <TimeSlotList\r\n isAM={true}\r\n timeSlots={displayTimeSlots.am}\r\n onClick={handleClickTimeSlot}\r\n />\r\n <TimeSlotList\r\n isAM={false}\r\n timeSlots={displayTimeSlots.pm}\r\n onClick={handleClickTimeSlot}\r\n />\r\n </div>\r\n )}\r\n </div>\r\n </div>\r\n )}\r\n </Fragment>\r\n );\r\n };\r\n\r\n const initialMonth = useMemo(() => {\r\n return timeSlots.length > 0\r\n ? getYearMonthPart(new Date(timeSlots[0].startDateTime))\r\n : getYearMonthPart(new Date());\r\n }, [timeSlots]);\r\n\r\n const month = useMemo(() => {\r\n return selectedMonth && selectedMonth > initialMonth\r\n ? selectedMonth\r\n : initialMonth;\r\n }, [selectedMonth, initialMonth]);\r\n\r\n const timeSlotList = useMemo(() => {\r\n return timeSlots.reduce((res, timeslot) => {\r\n const startTime = timeslot.startDateTime;\r\n const momentJsTime = moment(startTime).parseZone(startTime);\r\n const date = momentJsTime.format(\"YYYY-MM-DD\");\r\n const recordInRes = createTimeSlotObjectForScheduleDrawer(\r\n res[date],\r\n momentJsTime,\r\n timeslot\r\n );\r\n return { ...res, [date]: recordInRes };\r\n }, {});\r\n }, [timeSlots]);\r\n\r\n const displayTimeSlots = useMemo(() => {\r\n const selectedTimeSlot = timeSlotList[selectedDay];\r\n\r\n return {\r\n am: selectedTimeSlot ? getUniqueTimeSlots(selectedTimeSlot.am) : [],\r\n pm: selectedTimeSlot ? getUniqueTimeSlots(selectedTimeSlot.pm) : []\r\n };\r\n }, [timeSlotList, selectedDay]);\r\n\r\n const handleDayClick = useCallback(day => {\r\n setSelectedDay(day);\r\n elementScrollTop(drawerDomIdentifier, \".schedule-drawer-calendar\", 40);\r\n }, []);\r\n\r\n const handleMonthClick = useCallback(\r\n month => {\r\n setSelectedDay(null);\r\n setSelectedMonth(month);\r\n const ditinctMonths = Object.keys(timeSlotList).reduce(\r\n (accumulator, current) => {\r\n const monthKey = moment(current).format(\"YYYY-MM\");\r\n if (!accumulator.includes(monthKey)) {\r\n accumulator = [...accumulator, monthKey];\r\n }\r\n return accumulator;\r\n },\r\n []\r\n );\r\n\r\n const today = moment();\r\n const currentMonth = moment().startOf(\"month\");\r\n const startOfMonth = moment(month).startOf(\"month\");\r\n const startTimemomentJs = today > startOfMonth ? today : startOfMonth;\r\n const endTimemomentJs = moment(month).endOf(\"month\");\r\n\r\n if(currentMonth.diff(startOfMonth) === 0)\r\n setNextTimeSlotText(\"Next Available timeslot within 6 months\");\r\n else\r\n setNextTimeSlotText(\"Next Available timeslot\");\r\n\r\n if (ditinctMonths.includes(moment(month).format(\"YYYY-MM\"))) {\r\n return;\r\n } \r\n \r\n getTimeSlots(startTimemomentJs, endTimemomentJs, availableLocations);\r\n },\r\n [availableLocations, timeSlotList, getTimeSlots]\r\n );\r\n\r\n const handleClickTimeSlot = useCallback(\r\n timeSlot => {\r\n const { startDateTime, endDateTime } = timeSlot;\r\n handleToggle(false);\r\n onSelect({\r\n startDateTime,\r\n endDateTime\r\n });\r\n },\r\n [handleToggle, onSelect]\r\n );\r\n\r\n const handleClickNextTimeSlot = useCallback(() => {\r\n const firstSlot = timeSlots[0];\r\n handleClickTimeSlot(firstSlot);\r\n }, [timeSlots, handleClickTimeSlot]);\r\n\r\n return (\r\n <SideDrawer id=\"schedule-drawer\" open={open} onToggle={handleToggle}>\r\n {required ? renderWaitingListContent() : renderScheduleContent()}\r\n </SideDrawer>\r\n );\r\n});\r\n\r\nScheduleDrawer.propTypes = {\r\n open: PropTypes.bool.isRequired,\r\n onToggle: PropTypes.func.isRequired,\r\n timeSlots: PropTypes.array,\r\n onSelect: PropTypes.func.isRequired,\r\n loadingTimeSlots: PropTypes.bool.isRequired,\r\n getTimeSlots: PropTypes.func.isRequired,\r\n isCurrentStep: PropTypes.bool.isRequired,\r\n availableLocations: PropTypes.array,\r\n earliestBookingTime: PropTypes.number.isRequired,\r\n waitingListEnabled: PropTypes.bool.isRequired,\r\n waitingList: PropTypes.object,\r\n setRequireWaitingList: PropTypes.func.isRequired,\r\n selectPreferredTime: PropTypes.func.isRequired,\r\n timezone: PropTypes.string\r\n};\r\n\r\nconst FloatHeading = memo(props => {\r\n const { headingFloat, renderDateTitle, headerTopHeight } = props;\r\n if (!headingFloat) return null;\r\n return (\r\n <h1\r\n className=\"schedule-drawer-timeslot-heading-float\"\r\n style={{ top: `${headerTopHeight - 2}px` }}\r\n >\r\n {renderDateTitle}\r\n </h1>\r\n );\r\n});\r\nFloatHeading.propTypes = {\r\n headingFloat: PropTypes.bool.isRequired,\r\n renderDateTitle: PropTypes.string,\r\n headerTopHeight: PropTypes.number.isRequired\r\n};\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { backgroundStyle } from \"../../styles\";\r\n\r\nexport const Alert = memo(props => {\r\n const { message } = props;\r\n return (\r\n <div className=\"alert-block\" style={backgroundStyle}>\r\n {message}\r\n </div>\r\n );\r\n});\r\n\r\nAlert.propTypes = {\r\n message: PropTypes.string.isRequired\r\n};\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\n\r\nexport const WelcomeMessage = memo(props => {\r\n const { title } = props;\r\n return <div className=\"booking-page-title\">{title}</div>;\r\n});\r\n\r\nWelcomeMessage.propTypes = {\r\n title: PropTypes.string\r\n};\r\n","import React, { memo } from \"react\";\r\nimport { ThemeColorButton } from \"../../Common\";\r\nimport { DoneIcon } from \"../../Common\";\r\n\r\nexport const ContinueButton = memo(props => {\r\n const { onClick } = props;\r\n return (\r\n <ThemeColorButton\r\n label={\r\n <>\r\n <DoneIcon />\r\n Continue\r\n </>\r\n }\r\n onClick={onClick}\r\n className=\"continue-btn animated zoomIn\"\r\n />\r\n );\r\n});\r\n","import React, { memo } from \"react\";\r\nimport { CSSTransition } from \"react-transition-group\";\r\nimport { useMountAndUnmount } from \"./useMountAndUnmount\";\r\n\r\nexport const MountedAnimationWrapper = memo(props => {\r\n const mounted = useMountAndUnmount();\r\n const { children, animationClassName, duration = 500 } = props;\r\n return (\r\n <CSSTransition\r\n in={mounted}\r\n classNames={animationClassName}\r\n timeout={{ enter: duration, exit: duration }}\r\n >\r\n {children}\r\n </CSSTransition>\r\n );\r\n});\r\n","import { useState, useEffect } from \"react\";\r\n\r\nexport function useMountAndUnmount() {\r\n const [mounted, setMounted] = useState(false);\r\n useEffect(() => {\r\n setMounted(true);\r\n return () => {\r\n setMounted(false);\r\n };\r\n }, []);\r\n\r\n return mounted;\r\n}\r\n","export const APPOINTMENT_ACTION = {\r\n SET_VALUE: \"appointment_action_set_value\",\r\n SET_LOCATION: \"appointment_action_set_location\"\r\n};\r\n\r\nexport const DATASOURCE_ACTION = {\r\n SET_VALUE: \"datasource_action_set_value\",\r\n SET_TIME_SLOTS: \"datasource_action_set_time_slots\",\r\n SET_POSITION: \"datasource_action_set_position\"\r\n};\r\n\r\nexport const CONFIG_ACTION = {\r\n SET_CONFIG: \"config_action_set_config\",\r\n SET_LOADED_DATA: \"config_action_set_loaded_data\"\r\n};\r\n\r\nexport const BOOKING_ACTION = {\r\n SET_VALUE: \"booking_action_set_value\",\r\n SET_STEP: \"booking_action_set_step\",\r\n GO_BACK_STEP: \"booking_action_go_back_step\",\r\n TOGGLE_VISIBILITY: \"booking_action_toggle_visibility\",\r\n GO_TO_PAGE: \"booking_action_go_to_page\",\r\n MAKE_NEW_BOOKING: \"booking_action_make_new_booking\"\r\n};\r\n\r\nexport const WAITING_LIST_ACTION = {\r\n REQUIRE_WAITING_LIST: \"waiting_list_action_require_waiting_list\",\r\n UPDATE_PREFERRED_TIME: \"waiting_list_action_update_preferred_time\"\r\n};\r\n\r\nexport const FORM_ACTION = {\r\n SET_VALUE: \"form_action_set_value\",\r\n SET_ERROR: \"form_action_set_error\",\r\n TOGGLE_VERIFICATION_DRAWER: \"form_action_toggle_verification_drawer\",\r\n SET_FILES: \"form_action_set_files\",\r\n REMOVE_FILE: \"form_action_remove_file\"\r\n};\r\n","import { APPOINTMENT_ACTION } from \"./\";\r\nimport { STEP_KEYS } from \"../constants\";\r\n\r\nexport const selectSpecialtyType = value => {\r\n return setAppointmentValue(STEP_KEYS.SPECIALTY_TYPE, value);\r\n};\r\n\r\nexport const selectAppointmentType = value => {\r\n return setAppointmentValue(STEP_KEYS.APPOINTMENT_TYPE, value);\r\n};\r\n\r\nexport const selectLocation = (locationId, timeZoneId) => {\r\n return {\r\n type: APPOINTMENT_ACTION.SET_LOCATION,\r\n payload: {\r\n locationId,\r\n timeZoneId\r\n }\r\n };\r\n};\r\n\r\nexport const selectPractitioner = value => {\r\n return setAppointmentValue(STEP_KEYS.PRACTITIONER, value);\r\n};\r\n\r\nexport const selectTimeZone = value => {\r\n return setAppointmentValue(STEP_KEYS.TIMEZONE, value);\r\n};\r\n\r\nexport const selectAppointmentDateTime = appointmentDateTime => {\r\n return setAppointmentValue(\r\n STEP_KEYS.APPOINTMENT_DATE_TIME,\r\n appointmentDateTime\r\n );\r\n};\r\n\r\nexport const setAppointmentValue = (key, value) => {\r\n return {\r\n type: APPOINTMENT_ACTION.SET_VALUE,\r\n payload: {\r\n key,\r\n value\r\n }\r\n };\r\n};\r\n\r\n// [STEP_KEYS.SPECIALTY_TYPE]: null,\r\n// [STEP_KEYS.APPOINTMENT_TYPE]: null,\r\n// [STEP_KEYS.PRACTITIONER]: null,\r\n// [STEP_KEYS.LOCATION]: null,\r\n// [STEP_KEYS.TIMEZONE]: null,\r\n// [STEP_KEYS.APPOINTMENT_DATE_TIME]: null\r\n","import axios from \"axios\";\r\nimport { API_CONFIG } from \"./config\";\r\n// import store from \"../store/configureStore\";\r\n// import { showError } from \"../modules/App/actions\";\r\n// import { deepGet } from \"../utils\";\r\n\r\nconst { headers } = API_CONFIG;\r\n\r\nexport const source = () => {\r\n return axios.CancelToken.source();\r\n};\r\n\r\nexport const isCancel = e => {\r\n return axios.isCancel(e);\r\n};\r\n\r\nclass HttpClient {\r\n constructor(baseUrl) {\r\n this.baseUrl = baseUrl;\r\n }\r\n\r\n setUrl = baseUrl => {\r\n this.baseUrl = baseUrl;\r\n };\r\n\r\n get = (url, config) => {\r\n const requestUrl = `${this.baseUrl}api/${url}`;\r\n return axios.get(requestUrl, { headers, ...config });\r\n };\r\n\r\n getUrl = (url, query, newTab) => {\r\n let tokenQuery;\r\n\r\n if (process.env.NODE_ENV !== \"production\") {\r\n tokenQuery = `sessionId=${API_CONFIG.headers[\"X-SessionId\"]}`;\r\n } else {\r\n tokenQuery = `token=${API_CONFIG.headers[\"X-Token\"]}`;\r\n }\r\n\r\n const requestUrl = `${this.baseUrl}/${url}?${tokenQuery}&${query}`;\r\n if (newTab) {\r\n window.open(requestUrl, \"_blank\");\r\n } else {\r\n window.location.href = requestUrl;\r\n }\r\n };\r\n\r\n post = (url, payload = null, cancelToken = null) => {\r\n const requestUrl = `${this.baseUrl}api/${url}`;\r\n return axios.post(\r\n requestUrl,\r\n payload === null ? null : JSON.stringify(payload),\r\n { headers, cancelToken }\r\n );\r\n };\r\n\r\n postAll = requests => {\r\n return axios.all(requests);\r\n };\r\n\r\n postFormData = (url, payload = null, file = null) => {\r\n const requestUrl = `${this.baseUrl}api/${url}`;\r\n\r\n const formData = new FormData();\r\n if (file !== null) {\r\n formData.append(\"file-0\", file);\r\n }\r\n if (payload !== null) {\r\n Object.keys(payload).forEach(key => {\r\n formData.append(key, JSON.stringify(payload[key]));\r\n });\r\n }\r\n\r\n return axios.post(requestUrl, formData, {\r\n headers: {\r\n ...headers,\r\n \"content-type\": \"multipart/form-data\"\r\n },\r\n onUploadProgress: e => {}\r\n });\r\n };\r\n\r\n remove = url => {\r\n const requestUrl = `${this.baseUrl}api/${url}`;\r\n return axios.delete(requestUrl, { headers });\r\n };\r\n\r\n uploadFileToS3 = (presignedUrl, file) => {\r\n const options = {\r\n headers: {\r\n \"Content-Type\": file.type\r\n }\r\n };\r\n return axios.put(presignedUrl, file, options);\r\n };\r\n}\r\n\r\n// axios.interceptors.response.use(\r\n// response => {\r\n// return response;\r\n// },\r\n// error => {\r\n// if (!isCancel(error)) {\r\n// const errorMessage = deepGet(\r\n// error,\r\n// [\"response\", \"data\", \"Message\"],\r\n// \"Error occurred during processing your request.\"\r\n// );\r\n// store.dispatch(showError(errorMessage));\r\n// }\r\n// return Promise.reject(error);\r\n// }\r\n// );\r\n\r\nexport { HttpClient };\r\n","export const requests = { getTimeSlots: null, getSuburbList: null };\r\n","import qs from 'qs';\r\nimport { HttpClient, API_CONFIG, BUSINESS_NAME } from '../api';\r\nimport { requests } from '../requests';\r\nimport { getParameterByName } from '../utils';\r\nimport { getFullAddress } from '../modules/ClientPortal/helpers';\r\nimport {\r\n ONLINE_PAYMENT_KEY_NAME,\r\n ONLINE_PAYMENT_IS_TEST\r\n} from '../modules/ClientPortal/constants';\r\n\r\nconst httpClient = new HttpClient(`${API_CONFIG.rootUrl}/${BUSINESS_NAME}/`);\r\n\r\nconst get = httpClient.get;\r\nconst post = httpClient.post;\r\n\r\nexport const portalService = {\r\n getConfig: () => {\r\n const locationGroupId = getParameterByName('lg');\r\n let queryString = '';\r\n if (locationGroupId != null) {\r\n queryString = '?locationGroupId=' + locationGroupId;\r\n }\r\n const url = `portalsettings/ExtendedConfigDetails${queryString}`;\r\n return get(url);\r\n },\r\n getSpecialties: () => {\r\n const url = 'appointmentbooking/specialties?getAppointmentTypes=true';\r\n return get(url);\r\n },\r\n getPractitioners: () => {\r\n const url = 'appointmentbooking/practitioners?getSpecialties=true';\r\n return get(url);\r\n },\r\n getLocations: () => {\r\n const locationGroupId = getParameterByName('lg');\r\n let queryString = '';\r\n if (locationGroupId != null) {\r\n queryString = '?locationGroupId=' + locationGroupId;\r\n }\r\n const url = `appointmentbooking/locations${queryString}`;\r\n return get(url);\r\n },\r\n getTimezones: () => {\r\n const url = 'appointmentbooking/locationTimezones';\r\n return get(url);\r\n },\r\n getSchedules: (locationIds = null) => {\r\n const queryString = locationIds\r\n ? locationIds.map(locationId => `locationId=${locationId}`).join('&')\r\n : '';\r\n const url = `appointmentbooking/practitionerschedules?${queryString}`;\r\n return get(url);\r\n },\r\n getTimeSlots: (\r\n specialtyId,\r\n appointmentTypeId,\r\n locationIds,\r\n practitionerId,\r\n timeZoneId,\r\n start,\r\n end,\r\n phoneConsult = false\r\n ) => {\r\n const { token } = requests.getTimeSlots;\r\n\r\n let url = `appointmentbooking/timeslots?appointmentTypeId=${appointmentTypeId}&specialtyId=${specialtyId}&timezoneId=${timeZoneId}&phoneConsult=${phoneConsult}&start=${start}&end=${end}`;\r\n\r\n if (practitionerId !== '') {\r\n url += `&practitionerId=${practitionerId}`;\r\n }\r\n\r\n const locationStr = locationIds\r\n .map(locationId => `locationId=${locationId}`)\r\n .join('&');\r\n\r\n url += `&${locationStr}`;\r\n return get(url, { cancelToken: token });\r\n },\r\n requestVerificationCode: smsModel => {\r\n const url = 'appointmentbooking/requestverificationcode';\r\n return post(url, smsModel);\r\n },\r\n verifyCode: smsModel => {\r\n const url = 'appointmentbooking/verifycode';\r\n return post(url, smsModel);\r\n },\r\n getLocationPosition: location => {\r\n if (location.position) return;\r\n\r\n const address = getFullAddress(location);\r\n\r\n const url = `appointmentbooking/getlocationposition?address=${address}`;\r\n return get(url);\r\n },\r\n submitBooking: (params, isNewClient) => {\r\n const queryString =\r\n isNewClient != null ? `?isNewClient=${isNewClient}` : '';\r\n const url = `appointmentbooking/submitbooking${queryString}`;\r\n return post(url, params);\r\n },\r\n getCancelReasons: () => {\r\n const url = 'appointmentbooking/cancellationreason';\r\n return get(url);\r\n },\r\n getAppointmentById: appointmentId => {\r\n const url = `appointmentbooking/getappointmentbyid/?appointmentId=${appointmentId}`;\r\n return get(url);\r\n },\r\n cancelAppointment: params => {\r\n const url = 'appointmentbooking/cancelappointmentbyid';\r\n return post(url, params);\r\n },\r\n getClient: paramsObj => {\r\n const query = qs.stringify({ ...paramsObj });\r\n const url = `client/client?${query}`;\r\n return get(url);\r\n },\r\n createClient: params => {\r\n const url = 'client/client';\r\n return post(url, params);\r\n },\r\n createFileNode: (clientId, fileName, fileSize) => {\r\n const url = `file/GetPresignedUrl?clientId=${clientId}&fileName=${fileName}&fileSize=${fileSize}`;\r\n return post(url);\r\n },\r\n createFileAssociation: params => {\r\n const url = 'file/association';\r\n return post(url, params);\r\n },\r\n uploadFileToS3: (presignedUrl, file) => {\r\n return httpClient.uploadFileToS3(presignedUrl, file);\r\n },\r\n getDownloadFileList: () => {\r\n const url = 'file/files';\r\n return get(url);\r\n },\r\n getFileDetails: fileName => {\r\n const queryString = qs.stringify({ fileName });\r\n const url = `file/file?${queryString}`;\r\n return get(url);\r\n },\r\n // getOnlinePaymentToken: () => {\r\n // const attributeName = ONLINE_PAYMENT_KEY_NAME;\r\n // const consumerId = '8b2fef4c-f4b6-4eab-9f9b-fb529d62e4b6';\r\n // return get(\r\n // `Application/applicationAttribute?attributeName=${attributeName}&consumerId=${consumerId}`\r\n // );\r\n // },\r\n getOnlinePaymentTokenAndIsTestFlag: () => {\r\n const attributeNames = [ONLINE_PAYMENT_KEY_NAME, ONLINE_PAYMENT_IS_TEST];\r\n const consumerId = '8b2fef4c-f4b6-4eab-9f9b-fb529d62e4b6';\r\n const query = qs.stringify({ attributeNames, consumerId });\r\n return get(`Application/applicationAttributes?${query}`);\r\n }\r\n};\r\n\r\nexport const geolocationService = {\r\n getSuburbs: paramsObj => {\r\n const query = qs.stringify({ ...paramsObj });\r\n const url = `appointmentbooking/GetSuburbs?${query}`;\r\n return get(url)\r\n }\r\n};\r\n","import axios from 'axios';\r\nimport { portalService } from '../../../services';\r\nimport {\r\n setSpecialtyTypes,\r\n setPractitioners,\r\n setLocations,\r\n setTimeZones,\r\n setSchedules,\r\n CONFIG_ACTION,\r\n getIntakeFormFileList,\r\n getOnlinePaymentToken\r\n} from './';\r\nimport { BUSINESS_NAME } from '../../../api';\r\nimport { loading, showError } from '../../App/actions';\r\nimport { getParameterByName, deepGet } from '../../../utils';\r\nimport { filterLocationsBySchedules } from '../helpers';\r\n\r\nexport const setConfig = config => {\r\n return {\r\n type: CONFIG_ACTION.SET_CONFIG,\r\n payload: config\r\n };\r\n};\r\n\r\nconst setLoadedData = loaded => {\r\n return {\r\n type: CONFIG_ACTION.SET_LOADED_DATA,\r\n payload: loaded\r\n };\r\n};\r\n\r\nexport const initialLoad = () => async dispatch => {\r\n dispatch(loading(true));\r\n dispatch(setLoadedData(false));\r\n if (!BUSINESS_NAME) {\r\n dispatch(\r\n showError({\r\n text: 'Missing Tenant Id in URL',\r\n canDismiss: false\r\n })\r\n );\r\n return false;\r\n }\r\n const {\r\n getConfig,\r\n getSpecialties,\r\n getPractitioners,\r\n getLocations,\r\n getTimezones,\r\n getSchedules\r\n } = portalService;\r\n\r\n let locations;\r\n await axios\r\n .all([\r\n getConfig(),\r\n getSpecialties(),\r\n getPractitioners(),\r\n getLocations(),\r\n getTimezones()\r\n ])\r\n .then(\r\n axios.spread(\r\n (\r\n configRes,\r\n specialtiesRes,\r\n practitionersRes,\r\n locationsRes,\r\n timezonesRes\r\n ) => {\r\n const config = configRes.data;\r\n dispatch(setConfig(config));\r\n if (config.isCreditCardEnabled) {\r\n dispatch(getOnlinePaymentToken());\r\n }\r\n\r\n const specialtyTypes = specialtiesRes.data.specialtyTypes;\r\n dispatch(setSpecialtyTypes(specialtyTypes));\r\n\r\n const practitioners = practitionersRes.data.practitioners;\r\n dispatch(setPractitioners(practitioners));\r\n\r\n locations = locationsRes.data.locations;\r\n const timezones = timezonesRes.data.locationTimezones;\r\n\r\n dispatch(setTimeZones(timezones));\r\n }\r\n )\r\n )\r\n .catch(error => {\r\n const errorText = deepGet(\r\n error,\r\n ['response', 'data', 'Message'],\r\n 'Error occurred during processing your request.'\r\n );\r\n dispatch(\r\n showError({\r\n text: errorText,\r\n canDismiss: false\r\n })\r\n );\r\n dispatch(loading(false));\r\n });\r\n const hasLocationGroup = getParameterByName('lg');\r\n\r\n try {\r\n const { data } = await getSchedules(\r\n hasLocationGroup ? locations.map(l => l.locationId) : null\r\n );\r\n const { schedules } = data;\r\n dispatch(setSchedules(schedules));\r\n const locationsFilteredBySchedules = filterLocationsBySchedules(\r\n locations,\r\n schedules\r\n );\r\n\r\n dispatch(setLocations(locationsFilteredBySchedules));\r\n // this one has been removed because we will to get geolocations during location step\r\n // locationsFilteredBySchedules.forEach(location => {\r\n // portalService.getLocationPosition(location).then(({ data }) => {\r\n // if (data != null) {\r\n // const { lat, lng } = data;\r\n // dispatch(\r\n // updateLocationPosition(location.locationId, {\r\n // lat,\r\n // lng\r\n // })\r\n // );\r\n // }\r\n // });\r\n // });\r\n } catch (error) {\r\n const errorText = deepGet(\r\n error,\r\n ['response', 'data', 'Message'],\r\n 'Error occurred during processing your request.'\r\n );\r\n dispatch(\r\n showError({\r\n text: errorText,\r\n canDismiss: false\r\n })\r\n );\r\n } finally {\r\n dispatch(loading(false));\r\n dispatch(setLoadedData(true));\r\n }\r\n dispatch(getIntakeFormFileList());\r\n};\r\n","import { DATASOURCE_ACTION } from './';\r\nimport { portalService } from '../../../services';\r\nimport { requests } from '../../../requests';\r\nimport { source, isCancel } from '../../../api';\r\nimport {\r\n filterSpecialtiesHavingAppointmentTypes,\r\n mapMomentjsToDateTimeString,\r\n filterPractitionersBySpecialty,\r\n checkIsPhoneConsult,\r\n base64ToArrayBuffer,\r\n mappingContentTypeWithFileName\r\n} from '../helpers';\r\nimport { loading } from '../../App/actions';\r\nimport { isIOSDevice } from '../../../utils';\r\nimport { createPinPaymentsScript } from '../helpers';\r\nimport PreviewLoadingTemplateHtml from '../helpers/PreviewLoadingTemplate';\r\nimport { ONLINE_PAYMENT_KEY_NAME, ONLINE_PAYMENT_IS_TEST } from '../constants';\r\n\r\nexport const setSpecialtyTypes = specialtyTypes => {\r\n const filtedSpecialtyTypes = filterSpecialtiesHavingAppointmentTypes(\r\n specialtyTypes\r\n );\r\n return setDatasourceValue('specialtyTypes', filtedSpecialtyTypes);\r\n};\r\n\r\nexport const setPractitioners = practitioners => {\r\n return setDatasourceValue('practitioners', practitioners);\r\n};\r\nexport const setLocations = locations => {\r\n return setDatasourceValue('locations', locations);\r\n};\r\n\r\nexport const setTimeZones = timeZones => {\r\n return setDatasourceValue('timeZones', timeZones);\r\n};\r\n\r\nexport const setSchedules = schedules => {\r\n return setDatasourceValue('schedules', schedules);\r\n};\r\n\r\nexport const toggleLoadingTimeSlots = (loading = true) => {\r\n return setDatasourceValue('loadingTimeSlots', loading);\r\n};\r\n\r\nexport const setTimeSlots = (timeSlots, concat = false) => {\r\n return {\r\n type: DATASOURCE_ACTION.SET_TIME_SLOTS,\r\n payload: {\r\n timeSlots,\r\n concat\r\n }\r\n };\r\n};\r\n\r\nexport const setPosition = (locationId, position) => {\r\n return {\r\n type: DATASOURCE_ACTION.SET_POSITION,\r\n payload: {\r\n locationId,\r\n position\r\n }\r\n };\r\n};\r\n\r\nexport const getPositions = locationList => async (dispatch, getState) => {\r\n const { positions } = getState().datasource;\r\n locationList.forEach(location => {\r\n const locationId = location.locationId;\r\n if (positions[locationId]) return;\r\n portalService.getLocationPosition(location).then(({ data }) => {\r\n if (data) {\r\n const { lat, lng } = data;\r\n dispatch(\r\n setPosition(locationId, {\r\n lat,\r\n lng\r\n })\r\n );\r\n }\r\n });\r\n });\r\n};\r\n\r\nexport const getIntakeFormFileList = () => async (dispatch, getState) => {\r\n const { isDownloadDocumentAllowed } = getState().config;\r\n if (!isDownloadDocumentAllowed) return;\r\n const { data } = await portalService.getDownloadFileList();\r\n dispatch(setDatasourceValue('intakeFormFiles', data));\r\n};\r\n\r\nexport const previewInIOS = async fileName => {\r\n const windowOpener = window.open('', '_blank');\r\n windowOpener.document.write(PreviewLoadingTemplateHtml);\r\n\r\n const { data } = await portalService.getFileDetails(fileName);\r\n const file = base64ToArrayBuffer(data.fileByte);\r\n const blob = new Blob([file], {\r\n type: mappingContentTypeWithFileName(fileName)\r\n });\r\n const fileUrl = URL.createObjectURL(blob);\r\n windowOpener.location.href = fileUrl;\r\n};\r\n\r\nexport const downloadFile = fileName => async (dispatch, getState) => {\r\n if (isIOSDevice) {\r\n await previewInIOS(fileName);\r\n return;\r\n }\r\n\r\n dispatch(loading(true));\r\n try {\r\n const { data } = await portalService.getFileDetails(fileName);\r\n\r\n const file = base64ToArrayBuffer(data.fileByte);\r\n\r\n const blob = new Blob([file], {\r\n type: mappingContentTypeWithFileName(fileName)\r\n });\r\n\r\n if (window.navigator && window.navigator.msSaveOrOpenBlob) {\r\n window.navigator.msSaveOrOpenBlob(blob, fileName);\r\n return;\r\n }\r\n\r\n const fileUrl = URL.createObjectURL(blob);\r\n const a = document.createElement('a');\r\n document.body.appendChild(a);\r\n a.style = 'display:none';\r\n a.href = fileUrl;\r\n a.download = fileName;\r\n a.click();\r\n a.parentNode.removeChild(a);\r\n window.URL.revokeObjectURL(fileUrl);\r\n } catch (error) {\r\n } finally {\r\n dispatch(loading(false));\r\n }\r\n};\r\n\r\nexport const getTimeSlots = (\r\n startTimeMomentJs,\r\n endTimeMomentJs,\r\n locations,\r\n initLoad = false\r\n) => async (dispatch, getState) => {\r\n if (requests.getTimeSlots !== null) {\r\n requests.getTimeSlots.cancel();\r\n }\r\n\r\n requests.getTimeSlots = source();\r\n\r\n const { config, appointment, datasource } = getState();\r\n const {\r\n specialtyType,\r\n appointmentType,\r\n practitioner,\r\n location,\r\n timezone,\r\n timeZoneOfLocation\r\n } = appointment;\r\n\r\n const phoneConsult = checkIsPhoneConsult(config.siteConsultTypes, location);\r\n const timezoneValue = timezone || timeZoneOfLocation;\r\n let response;\r\n try {\r\n dispatch(toggleLoadingTimeSlots());\r\n\r\n response = await portalService.getTimeSlots(\r\n specialtyType,\r\n appointmentType,\r\n locations,\r\n practitioner === 'ANY' ? '' : practitioner,\r\n timezoneValue,\r\n mapMomentjsToDateTimeString(startTimeMomentJs),\r\n mapMomentjsToDateTimeString(endTimeMomentJs),\r\n phoneConsult\r\n );\r\n\r\n // for initial load, check for the further 2 months if no time slots in current month\r\n if (initLoad && response.data.timeslots.length === 0) {\r\n response = await portalService.getTimeSlots(\r\n specialtyType,\r\n appointmentType,\r\n locations,\r\n practitioner === 'ANY' ? '' : practitioner,\r\n timezoneValue,\r\n mapMomentjsToDateTimeString(\r\n startTimeMomentJs.add(1, 'month').startOf('month')\r\n ),\r\n mapMomentjsToDateTimeString(\r\n endTimeMomentJs.add(1, 'month').endOf('month')\r\n ),\r\n phoneConsult\r\n );\r\n\r\n // Fetching next available appointment for next six months.\r\n for(let i=0;i<5;i++){\r\n if (response.data.timeslots.length === 0) {\r\n response = await portalService.getTimeSlots(\r\n specialtyType,\r\n appointmentType,\r\n locations,\r\n practitioner === 'ANY' ? '' : practitioner,\r\n timezoneValue,\r\n mapMomentjsToDateTimeString(\r\n startTimeMomentJs.add(1, 'month').startOf('month')\r\n ),\r\n mapMomentjsToDateTimeString(\r\n endTimeMomentJs.add(1, 'month').endOf('month')\r\n ),\r\n phoneConsult\r\n );\r\n }\r\n else{\r\n break;\r\n }\r\n }\r\n }\r\n const { data } = response;\r\n const timeslots = data === null ? [] : data.timeslots || [];\r\n\r\n const filteredTimeSlots = getTimeslotsByPractitionersAndLocations(\r\n timeslots,\r\n datasource.practitioners,\r\n datasource.locations,\r\n specialtyType\r\n );\r\n dispatch(setTimeSlots(filteredTimeSlots, !initLoad));\r\n } catch (e) {\r\n if (!isCancel(e)) {\r\n //error handling\r\n }\r\n }\r\n dispatch(toggleLoadingTimeSlots(false));\r\n requests.getTimeSlots = null;\r\n};\r\n\r\nconst setDatasourceValue = (key, value) => {\r\n return {\r\n type: DATASOURCE_ACTION.SET_VALUE,\r\n payload: {\r\n key,\r\n value\r\n }\r\n };\r\n};\r\n\r\nconst getTimeslotsByPractitionersAndLocations = (\r\n timeslots,\r\n practitioners,\r\n locations,\r\n specialtyType\r\n) => {\r\n if (!timeslots || timeslots.length === 0) return [];\r\n const practitionerIds = filterPractitionersBySpecialty(\r\n practitioners,\r\n specialtyType\r\n ).map(p => p.practitionerId);\r\n const locationIds = locations.map(l => l.locationId);\r\n\r\n return timeslots.filter(ts => {\r\n const practitionerId = ts.practitioner.practitionerId;\r\n const locationId = ts.locationId;\r\n\r\n return (\r\n practitionerIds.includes(practitionerId) &&\r\n locationIds.includes(locationId)\r\n );\r\n });\r\n};\r\n\r\nexport const getOnlinePaymentToken = () => async dispatch => {\r\n try {\r\n const { data } = await portalService.getOnlinePaymentTokenAndIsTestFlag();\r\n const onlinePaymentToken =\r\n data?.applicationAttributes?.find(\r\n item => item.attributeName === ONLINE_PAYMENT_KEY_NAME\r\n )?.attributeValue ?? null;\r\n let onlinePaymentIsTest =\r\n data?.applicationAttributes?.find(\r\n item => item.attributeName === ONLINE_PAYMENT_IS_TEST\r\n )?.attributeValue ?? false;\r\n if (onlinePaymentIsTest) {\r\n onlinePaymentIsTest = onlinePaymentIsTest === 'true' ? true : false;\r\n }\r\n dispatch(setDatasourceValue('onlinePaymentToken', onlinePaymentToken));\r\n dispatch(setDatasourceValue('onlinePaymentIsTest', onlinePaymentIsTest));\r\n if (onlinePaymentToken) {\r\n createPinPaymentsScript();\r\n }\r\n } catch (error) {}\r\n};\r\n","const PreviewLoadingTemplateHtml = `\r\n<style>\r\n.preview-loading .loading-animation-container {\r\n position: fixed;\r\n height: 100%;\r\n width: 100%;\r\n z-index: 1019;\r\n -webkit-backdrop-filter: blur(5px);\r\n backdrop-filter: blur(5px);\r\n font-family: Helvetica, sans-serif;\r\n}\r\n\r\n.preview-loading .loader {\r\n height: 20px;\r\n width: 250px;\r\n position: absolute;\r\n top: 50%;\r\n left: 50%;\r\n transform: translate(-50%, -50%);\r\n}\r\n\r\n.preview-loading .loader--dot {\r\n animation: loader ease-in-out 3s infinite;\r\n height: 20px;\r\n width: 20px;\r\n border-radius: 100%;\r\n background-color: black;\r\n position: absolute;\r\n border: 2px solid white;\r\n}\r\n\r\n.preview-loading .loader--dot:first-child {\r\n background-color: #60c5ba;\r\n animation-delay: 0.5s;\r\n}\r\n.preview-loading .loader--dot:nth-child(2) {\r\n background-color: #e4018b;\r\n animation-delay: 0.4s;\r\n}\r\n.preview-loading .loader--dot:nth-child(3) {\r\n background-color: #ffcb3b;\r\n animation-delay: 0.3s;\r\n}\r\n.preview-loading .loader--dot:nth-child(4) {\r\n background-color: #f68a33;\r\n animation-delay: 0.2s;\r\n}\r\n\r\n.preview-loading .loader--text {\r\n position: absolute;\r\n top: 200%;\r\n left: 0;\r\n right: 0;\r\n width: 16rem;\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n margin: auto;\r\n}\r\n\r\n.preview-loading .loader--text--top {\r\n display: flex;\r\n}\r\n\r\n.preview-loading .loader--text--top--ellipsis:after {\r\n content: \"\";\r\n font-weight: bold;\r\n animation: loading-text 3s infinite;\r\n}\r\n\r\n@keyframes loader {\r\n 15% {\r\n transform: translateX(0);\r\n }\r\n 45% {\r\n transform: translateX(230px);\r\n }\r\n 65% {\r\n transform: translateX(230px);\r\n }\r\n 95% {\r\n transform: translateX(0);\r\n }\r\n}\r\n\r\n@keyframes loading-text {\r\n 0% {\r\n content: \"\";\r\n }\r\n 25% {\r\n content: \".\";\r\n }\r\n 50% {\r\n content: \"..\";\r\n }\r\n 75% {\r\n content: \"...\";\r\n }\r\n}\r\n</style>\r\n<div class=\"preview-loading loading-animation-container\">\r\n<div class=\"loader\">\r\n <div class=\"loader--dot\"></div>\r\n <div class=\"loader--dot\"></div>\r\n <div class=\"loader--dot\"></div>\r\n <div class=\"loader--dot\"></div>\r\n <div class=\"loader--text\">\r\n <div class=\"loader--text--top\">\r\n <div class=\"loader--text--top--heading\">Preview Loading</div>\r\n <div class=\"loader--text--top--ellipsis\"></div>\r\n </div>\r\n </div>\r\n</div>\r\n</div>\r\n`;\r\n\r\nexport default PreviewLoadingTemplateHtml;\r\n","import { FORM_ACTION } from './';\r\nimport { deepGet } from '../../../utils';\r\nimport { loading, showError } from '../../App/actions';\r\nimport { goToPage, updateAppointmentId, updateAppointmentCancelled } from './';\r\nimport { portalService } from '../../../services';\r\nimport {\r\n getSpecialtyTypeAppointmentType,\r\n getPractitionerText,\r\n getPractitionerFirstName,\r\n getPractitionerLastName,\r\n getLocationTextAndPosition,\r\n getAppointmentDateTimeText,\r\n mapAusDateStrToDate,\r\n mapMomentjsToDateTimeString,\r\n checkIsPhoneConsult,\r\n getFileNameWithExtension,\r\n getMedicareNumberAndIRNFromString,\r\n getMedicareExpiryDateFromString,\r\n fetchForCardTokenPromise,\r\n canSaveCreditCard,\r\n getTimezoneText,\r\n timezoneTextAndTzIdMap\r\n} from '../helpers';\r\nimport {\r\n PAGE_KEYS,\r\n FORM_KEYS,\r\n MAX_FILE_SIZE,\r\n MAX_FILE_NUMBER,\r\n VALID_FILE_EXTENSION,\r\n SUPPORTED_FILE_TEXT,\r\n DEFAULT_FILE_ASSOCIATION_ENTITY,\r\n DEFAULT_FILE_ASSOCIATION_TYPE\r\n} from '../constants';\r\n\r\nexport const setFormValueByKey = (key, value) => {\r\n return {\r\n type: FORM_ACTION.SET_VALUE,\r\n payload: {\r\n key,\r\n value\r\n }\r\n };\r\n};\r\nexport const setFormErrorTextByKey = (key, errorText) => {\r\n return {\r\n type: FORM_ACTION.SET_ERROR,\r\n payload: {\r\n key,\r\n errorText\r\n }\r\n };\r\n};\r\n\r\nexport const setVerifyDrawerOpen = open => {\r\n return {\r\n type: FORM_ACTION.TOGGLE_VERIFICATION_DRAWER,\r\n payload: open\r\n };\r\n};\r\n\r\nexport const onClickPlaceBooking = () => async (dispatch, getState) => {\r\n const { reCaptchaEnabled } = getState().config;\r\n if (reCaptchaEnabled) {\r\n dispatch(setVerifyDrawerOpen(true));\r\n } else {\r\n try {\r\n await dispatch(sendingVerificationCode());\r\n dispatch(setVerifyDrawerOpen(true));\r\n } catch (error) {\r\n dispatch(\r\n showError({\r\n text: 'Sending sms verification failed',\r\n canDismiss: true\r\n })\r\n );\r\n }\r\n }\r\n};\r\n\r\nexport const sendingVerificationCode = () => async (dispatch, getState) => {\r\n const { mobile } = getState().form;\r\n dispatch(loading(true));\r\n try {\r\n await portalService.requestVerificationCode({\r\n mobileNumber: mobile\r\n });\r\n } catch (error) {\r\n throw error;\r\n } finally {\r\n dispatch(loading(false));\r\n }\r\n};\r\n\r\nexport const verifyCode = code => async (dispatch, getState) => {\r\n dispatch(loading(true));\r\n try {\r\n await portalService.verifyCode({ verificationCode: code });\r\n } catch (error) {\r\n throw error;\r\n } finally {\r\n dispatch(loading(false));\r\n }\r\n};\r\n\r\nexport const setFiles = files => (dispatch, getState) => {\r\n const { [FORM_KEYS.FILES]: filesInStore } = getState().form;\r\n // check file extensions\r\n const invalidExtensionFiles = files.filter(\r\n file =>\r\n !VALID_FILE_EXTENSION.includes(\r\n getFileNameWithExtension(file.name).extension\r\n )\r\n );\r\n if (invalidExtensionFiles.length > 0) {\r\n dispatch(\r\n showError({\r\n text: `Only ${SUPPORTED_FILE_TEXT} are supported, Please try again.`,\r\n canDismiss: true\r\n })\r\n );\r\n return false;\r\n }\r\n\r\n // check file size.\r\n const overSizeFiles = files.filter(f => f.size > MAX_FILE_SIZE);\r\n if (overSizeFiles.length > 0) {\r\n dispatch(\r\n showError({\r\n text: 'The maximum size of each file is 10mb, please reduce the size and try again',\r\n canDismiss: true\r\n })\r\n );\r\n return false;\r\n }\r\n\r\n // check file name\r\n const filesInStoreNames = filesInStore.map(d => d.name);\r\n const duplicateNameFiles = files.filter(f =>\r\n filesInStoreNames.includes(f.name)\r\n );\r\n if (duplicateNameFiles.length) {\r\n dispatch(\r\n showError({\r\n text: 'Files with same name exist, please rename the file and try again',\r\n canDismiss: true\r\n })\r\n );\r\n return false;\r\n }\r\n\r\n // total file number\r\n const total = filesInStore.length + files.length;\r\n if (total > MAX_FILE_NUMBER) {\r\n dispatch(\r\n showError({\r\n text: `Only ${MAX_FILE_NUMBER} files can be uploaded for each appointment and please try again`,\r\n canDismiss: true\r\n })\r\n );\r\n return false;\r\n }\r\n\r\n dispatch({\r\n type: FORM_ACTION.SET_FILES,\r\n payload: { files: files }\r\n });\r\n};\r\n\r\nexport const removeFile = fileIndex => {\r\n return {\r\n type: FORM_ACTION.REMOVE_FILE,\r\n payload: fileIndex\r\n };\r\n};\r\n\r\nexport const submitBooking =\r\n (verificationCode = '', recaptchaToken = '') =>\r\n async (dispatch, getState) => {\r\n let creditCardToken = '';\r\n if (canSaveCreditCard(getState())) {\r\n creditCardToken = await dispatch(getCreditCardToken());\r\n const { isCreditCardMandatory } = getState().config;\r\n if (isCreditCardMandatory && !creditCardToken) {\r\n return false;\r\n }\r\n }\r\n const { files } = getState().form;\r\n try {\r\n if (files && files.length > 0) {\r\n await dispatch(\r\n submitBookingWithFiles(\r\n verificationCode,\r\n recaptchaToken,\r\n creditCardToken\r\n )\r\n );\r\n } else {\r\n await dispatch(\r\n submitBookingWithoutFiles(\r\n verificationCode,\r\n recaptchaToken,\r\n creditCardToken\r\n )\r\n );\r\n }\r\n } catch (error) {\r\n throw error;\r\n }\r\n };\r\n\r\nconst getCreditCardToken = () => async (dispatch, getState) => {\r\n const { onlinePaymentToken, onlinePaymentIsTest } = getState().datasource;\r\n const {\r\n creditCardNumber,\r\n creditCardExpiry,\r\n creditCardName,\r\n creditCardSecurityCode\r\n } = getState().form;\r\n if (\r\n !creditCardNumber ||\r\n !creditCardExpiry ||\r\n !creditCardName ||\r\n !creditCardSecurityCode\r\n ) {\r\n return '';\r\n }\r\n const [month, year] = creditCardExpiry.split('/');\r\n\r\n // need to provide address_line1, address_city and address_country\r\n // set them as not provided which is the same as Coreplus payment project\r\n const card = {\r\n number: creditCardNumber,\r\n name: creditCardName,\r\n expiry_month: month,\r\n expiry_year: year,\r\n cvc: creditCardSecurityCode,\r\n address_line1: 'address',\r\n address_city: 'not',\r\n address_country: 'provided'\r\n };\r\n try {\r\n dispatch(loading(true));\r\n const response = await fetchForCardTokenPromise(\r\n onlinePaymentToken,\r\n card,\r\n onlinePaymentIsTest\r\n );\r\n dispatch(loading(false));\r\n return response?.token;\r\n } catch (error) {\r\n console.error('Saving credit card failed with error', error);\r\n dispatch(\r\n showError({\r\n text: 'Saving credit card details failed.',\r\n canDismiss: true\r\n })\r\n );\r\n dispatch(loading(false));\r\n return '';\r\n }\r\n};\r\n\r\n/**\r\n * call submitbooking api endpoint directly.\r\n */\r\nconst submitBookingWithoutFiles =\r\n (verificationCode, recaptchaToken, creditCardToken) =>\r\n async (dispatch, getState) => {\r\n const { appointment, form, config, datasource, waitingList } = getState();\r\n const params = createBookingModel(\r\n appointment,\r\n form,\r\n config,\r\n datasource,\r\n waitingList,\r\n verificationCode,\r\n recaptchaToken,\r\n creditCardToken\r\n );\r\n\r\n dispatch(loading(true));\r\n try {\r\n const { data } = await portalService.submitBooking(params);\r\n dispatch(loading(false));\r\n dispatch(goToPage(PAGE_KEYS.CONFIRM));\r\n const appointmentId = data.appointmentId;\r\n dispatch(updateAppointmentId(appointmentId));\r\n dispatch(updateAppointmentCancelled(false));\r\n } catch (error) {\r\n dispatch(\r\n showError({\r\n text: getResponseErrorMessage(error),\r\n canDismiss: true\r\n })\r\n );\r\n dispatch(loading(false));\r\n throw error;\r\n }\r\n };\r\n\r\n/**\r\n * new process with file uploading\r\n * 1. detect client existing(used for checking new or existing client)\r\n * 2. call create client\r\n * 3 upload files\r\n * 4. create appointment\r\n * 5. link association\r\n */\r\nconst submitBookingWithFiles =\r\n (verificationCode, recaptchaToken, creditCardToken) =>\r\n async (dispatch, getState) => {\r\n const { appointment, form, config, datasource, waitingList } = getState();\r\n let params = createBookingModel(\r\n appointment,\r\n form,\r\n config,\r\n datasource,\r\n waitingList,\r\n verificationCode,\r\n recaptchaToken,\r\n creditCardToken\r\n );\r\n dispatch(loading(true));\r\n let appointmentId;\r\n let fileIdList = [];\r\n let isNewClientFlag;\r\n try {\r\n const clientObj = params.clients[0];\r\n const { data: getClientResponse } = await portalService.getClient(\r\n clientObj\r\n );\r\n isNewClientFlag = !getClientResponse.client;\r\n const { data: createClientResponse } = await portalService.createClient(\r\n params\r\n );\r\n const clientId = createClientResponse.client.clientId;\r\n\r\n const newPassingClientObject = { ...params.clients[0], clientId };\r\n params = {\r\n ...params,\r\n clients: [{ ...newPassingClientObject }]\r\n };\r\n fileIdList = await uploadFiles(clientId, form.files);\r\n } catch (ex) {\r\n dispatch(\r\n showError({\r\n text: 'Uploading files failed, please try again.',\r\n canDismiss: true\r\n })\r\n );\r\n dispatch(loading(false));\r\n throw ex;\r\n }\r\n try {\r\n const { data: appointmentResponse } = await portalService.submitBooking(\r\n params,\r\n isNewClientFlag\r\n );\r\n appointmentId = appointmentResponse.appointmentId;\r\n } catch (ex) {\r\n dispatch(\r\n showError({\r\n text: getResponseErrorMessage(ex),\r\n canDismiss: true\r\n })\r\n );\r\n dispatch(loading(false));\r\n throw ex;\r\n }\r\n try {\r\n await createFileAssociations(appointmentId, fileIdList);\r\n dispatch(loading(false));\r\n } catch (ex) {\r\n dispatch(\r\n showError({\r\n text: 'Sorry error occurred during processing your request. Failed to attach files to the appointment.',\r\n canDismiss: true\r\n })\r\n );\r\n dispatch(loading(false));\r\n throw ex;\r\n }\r\n dispatch(goToPage(PAGE_KEYS.CONFIRM));\r\n dispatch(updateAppointmentId(appointmentId));\r\n dispatch(updateAppointmentCancelled(false));\r\n };\r\n\r\nconst uploadFiles = async (clientId, files) => {\r\n let fileIdList = [];\r\n try {\r\n for (const file of files) {\r\n const { data: createFileResponse } = await portalService.createFileNode(\r\n clientId,\r\n file.name,\r\n file.size\r\n );\r\n const { Item1: fileId, Item2: presignedUrl } = createFileResponse;\r\n fileIdList.push(fileId);\r\n\r\n await portalService.uploadFileToS3(presignedUrl, file);\r\n }\r\n return fileIdList;\r\n } catch (error) {\r\n throw error;\r\n }\r\n};\r\n\r\nconst createFileAssociations = async (appointmentId, fileIdList) => {\r\n try {\r\n for (const fileId of fileIdList) {\r\n const association = {\r\n associatedEntity: DEFAULT_FILE_ASSOCIATION_ENTITY,\r\n associatedPrimaryDomainKey: appointmentId,\r\n associationType: DEFAULT_FILE_ASSOCIATION_TYPE,\r\n fileId: fileId\r\n };\r\n await portalService.createFileAssociation(association);\r\n }\r\n } catch (error) {\r\n throw error;\r\n }\r\n};\r\n\r\nconst createBookingModel = (\r\n appointment,\r\n form,\r\n config,\r\n datasource,\r\n waitingList,\r\n verificationCode,\r\n recaptchaToken,\r\n creditCardToken\r\n) => {\r\n const {\r\n specialtyType,\r\n appointmentType,\r\n practitioner,\r\n location,\r\n timezone,\r\n appointmentDateTime,\r\n timeZoneOfLocation\r\n } = appointment;\r\n\r\n const {\r\n firstName,\r\n middleName,\r\n lastName,\r\n preferredName,\r\n email,\r\n mobile,\r\n dateOfBirth,\r\n comments,\r\n healthFund,\r\n cardNumber,\r\n cardPosition,\r\n customFields,\r\n clientAddress,\r\n clientSuburb,\r\n clientPostcode,\r\n medicareNumber,\r\n medicareExpiry\r\n } = form;\r\n const { specialtyTypes, practitioners, locations, positions } = datasource;\r\n const {\r\n siteConsultTypes,\r\n confirmationText,\r\n businessName,\r\n reCaptchaEnabled,\r\n isHidingLocationEnabled\r\n } = config;\r\n\r\n const isPhoneConsult = checkIsPhoneConsult(siteConsultTypes, location);\r\n\r\n const locationTextAndPosition = getLocationTextAndPosition(\r\n locations,\r\n positions,\r\n location\r\n );\r\n\r\n const { specialtyTypeText, appointmentTypeText, isTelehealthAppointment } =\r\n getSpecialtyTypeAppointmentType(\r\n specialtyTypes,\r\n specialtyType,\r\n appointmentType\r\n );\r\n const practitionerText = getPractitionerText(practitioners, practitioner);\r\n const appointmentDateTimeText = getAppointmentDateTimeText(\r\n appointmentDateTime,\r\n waitingList.required,\r\n waitingList.preferredTime\r\n );\r\n\r\n const enteredComments = comments ? `Client comment: ${comments}` : '';\r\n\r\n const timezoneId = timezone || timeZoneOfLocation;\r\n const timezoneText = getTimezoneText(timezoneId, datasource.timeZones);\r\n const timezoneIdentifier =\r\n timezoneTextAndTzIdMap[timezoneText.toLowerCase()] || '';\r\n\r\n const appointmentParams = {\r\n startDateTime: deepGet(appointmentDateTime, ['startDateTime']),\r\n endDateTime: deepGet(appointmentDateTime, ['endDateTime']),\r\n practitioner: {\r\n practitionerId: practitioner === 'ANY' ? '' : practitioner,\r\n firstName: getPractitionerFirstName(practitioners, practitioner),\r\n lastName: getPractitionerLastName(practitioners, practitioner)\r\n },\r\n locationId: location === 'ANY' ? '' : location,\r\n timezoneId: timezoneId,\r\n timezoneText,\r\n timezoneIdentifier,\r\n appointmentTypeId: appointmentType,\r\n notes: `${enteredComments} ${\r\n isPhoneConsult ? '*This appointment is a phone consultation*' : ''\r\n }`,\r\n smsVerifyCode: verificationCode,\r\n bookingDetails: createBookingDetailsText(\r\n confirmationText,\r\n specialtyTypeText,\r\n practitionerText,\r\n locationTextAndPosition.locationText,\r\n appointmentDateTimeText,\r\n timezoneText,\r\n isHidingLocationEnabled\r\n ),\r\n coordinate: locationTextAndPosition.position,\r\n appointmentTypeName: appointmentTypeText,\r\n serviceName: specialtyTypeText,\r\n locationAddress: locationTextAndPosition.locationText,\r\n businessName: businessName\r\n ? businessName\r\n : locationTextAndPosition.locationText,\r\n reCaptchaEnabled,\r\n recaptchaToken,\r\n isTelehealthAppointment\r\n };\r\n\r\n const waitingListProps = {\r\n addToWaitingList: waitingList.required,\r\n preferredTime: waitingList.preferredTime\r\n };\r\n\r\n const clientParams = {\r\n firstName,\r\n middleName,\r\n lastName,\r\n preferredName,\r\n dateOfBirth: mapMomentjsToDateTimeString(mapAusDateStrToDate(dateOfBirth)),\r\n phoneNumberMobile: mobile,\r\n email,\r\n healthFundProviderId: healthFund,\r\n healthFundMembershipNumber: cardNumber,\r\n healthFundCardPosition: cardPosition,\r\n homePostcode: clientPostcode ? clientPostcode : null,\r\n clientAddress: clientAddress ? clientAddress : null,\r\n clientSuburb: clientSuburb ? clientSuburb : null,\r\n customFields:\r\n Object.keys(customFields).length === 0\r\n ? null\r\n : datasource.customFields.map(cf => {\r\n return {\r\n id: cf.id,\r\n value: customFields[cf.id] || false,\r\n name: cf.name\r\n };\r\n }),\r\n cardToken: creditCardToken ? creditCardToken : null\r\n };\r\n\r\n const { medicareCardNumber, medicareCardIRN } =\r\n getMedicareNumberAndIRNFromString(medicareNumber);\r\n if (medicareCardNumber && medicareCardIRN) {\r\n clientParams.medicareCardNumber = medicareCardNumber;\r\n clientParams.medicareCardIRN = medicareCardIRN;\r\n }\r\n\r\n clientParams.medicareCardExpireDate =\r\n getMedicareExpiryDateFromString(medicareExpiry);\r\n\r\n return {\r\n ...appointmentParams,\r\n ...waitingListProps,\r\n clients: [{ ...clientParams }]\r\n };\r\n};\r\n\r\nconst createBookingDetailsText = (\r\n confirmationText,\r\n specialtyTypeText,\r\n practitionerText,\r\n locationText,\r\n appointmentDateTimeText,\r\n timezoneText,\r\n isHidingLocationEnabled\r\n) => {\r\n const appointmentTimeText = timezoneText\r\n ? `${appointmentDateTimeText} (${timezoneText} Time)`\r\n : appointmentDateTimeText;\r\n return confirmationText\r\n .replace(/#SpecialtyName#/g, specialtyTypeText)\r\n .replace(/#Specialist#/g, practitionerText)\r\n .replace(/#location#/g, isHidingLocationEnabled ? '' : locationText)\r\n .replace(/#Appointment_Start_Time#/g, appointmentTimeText);\r\n};\r\n\r\nconst getResponseErrorMessage = error => {\r\n const modelState = deepGet(error, ['response', 'data', 'ModelState']);\r\n if (modelState) {\r\n return Object.keys(modelState)\r\n .map(key => modelState[key])\r\n .join(', ');\r\n }\r\n\r\n return deepGet(\r\n error,\r\n ['response', 'data', 'Message'],\r\n 'Error occurred during processing your request.'\r\n );\r\n};\r\n","import { BOOKING_ACTION } from '.';\r\nimport { findNextStep, checkIsPhoneConsult } from '../helpers';\r\nimport { STEP_KEYS } from '../constants';\r\nimport { geolocationService } from '../../../services/portalService';\r\n\r\nexport const goToNextStep = currentStep => (dispatch, getState) => {\r\n const {\r\n preSelectPractitioner,\r\n practitionerFirst,\r\n siteConsultTypes,\r\n isTimezoneEnabled\r\n } = getState().config;\r\n const { [STEP_KEYS.LOCATION]: locationValue } = getState().appointment;\r\n let showTimeZone = false;\r\n if (\r\n currentStep === STEP_KEYS.PRACTITIONER ||\r\n currentStep === STEP_KEYS.LOCATION\r\n ) {\r\n showTimeZone =\r\n checkIsPhoneConsult(siteConsultTypes, locationValue) || isTimezoneEnabled;\r\n }\r\n const extraConfig = {\r\n preSelectPractitioner,\r\n practitionerFirst,\r\n showTimeZone\r\n };\r\n const { steps } = getState().booking;\r\n const foundIndex = steps.indexOf(currentStep);\r\n const nextStep = findNextStep(currentStep, extraConfig);\r\n const remainingStep = [...steps].slice(0, foundIndex + 1);\r\n\r\n const newSteps = nextStep ? [...remainingStep, nextStep] : remainingStep;\r\n\r\n if (foundIndex + 1 === steps.length) {\r\n dispatch({\r\n type: BOOKING_ACTION.SET_STEP,\r\n payload: { steps: newSteps }\r\n });\r\n } else {\r\n const stepsToBeClear = [...steps].slice(foundIndex + 1);\r\n dispatch({\r\n type: BOOKING_ACTION.GO_BACK_STEP,\r\n payload: { steps: newSteps, clearSteps: stepsToBeClear }\r\n });\r\n }\r\n};\r\n\r\nexport const toggleVisibility = (key, visiable) => {\r\n const visiableKey = visiable ? key : null;\r\n return {\r\n type: BOOKING_ACTION.TOGGLE_VISIBILITY,\r\n payload: visiableKey\r\n };\r\n};\r\n\r\nexport const goToPage = page => {\r\n return {\r\n type: BOOKING_ACTION.GO_TO_PAGE,\r\n payload: page\r\n };\r\n};\r\n\r\nexport const makeNewBooking = () => {\r\n return { type: BOOKING_ACTION.MAKE_NEW_BOOKING };\r\n};\r\n\r\nexport const updateAppointmentId = appointmentId => {\r\n return {\r\n type: BOOKING_ACTION.SET_VALUE,\r\n payload: {\r\n key: 'appointmentId',\r\n value: appointmentId\r\n }\r\n };\r\n};\r\n\r\nexport const updateAppointmentCancelled = cancelled => {\r\n return {\r\n type: BOOKING_ACTION.SET_VALUE,\r\n payload: {\r\n key: 'isCancelled',\r\n value: cancelled\r\n }\r\n };\r\n};\r\n\r\nexport const getSuburbs = async (searchText) => {\r\n const paramsObj = {\r\n search: searchText == null || searchText === \"\" ? null : searchText,\r\n pageNumber: 1,\r\n pageSize: 30,\r\n };\r\n return await geolocationService.getSuburbs(paramsObj);\r\n};\r\n","import { STEP_KEYS } from \"../constants\";\r\nexport const findNextStep = (step, config) => {\r\n const { practitionerFirst, showTimeZone } = config;\r\n let nextStep = \"\";\r\n switch (step) {\r\n case STEP_KEYS.SPECIALTY_TYPE:\r\n return STEP_KEYS.APPOINTMENT_TYPE;\r\n\r\n case STEP_KEYS.APPOINTMENT_TYPE:\r\n nextStep = !practitionerFirst\r\n ? STEP_KEYS.LOCATION\r\n : STEP_KEYS.PRACTITIONER;\r\n return nextStep;\r\n\r\n case STEP_KEYS.LOCATION:\r\n nextStep = STEP_KEYS.APPOINTMENT_DATE_TIME;\r\n\r\n if (!practitionerFirst) nextStep = STEP_KEYS.PRACTITIONER;\r\n else if (showTimeZone) nextStep = STEP_KEYS.TIMEZONE;\r\n\r\n return nextStep;\r\n\r\n case STEP_KEYS.PRACTITIONER:\r\n nextStep = STEP_KEYS.LOCATION;\r\n\r\n if (!practitionerFirst) {\r\n nextStep = showTimeZone\r\n ? STEP_KEYS.TIMEZONE\r\n : STEP_KEYS.APPOINTMENT_DATE_TIME;\r\n }\r\n return nextStep;\r\n\r\n case STEP_KEYS.TIMEZONE:\r\n return STEP_KEYS.APPOINTMENT_DATE_TIME;\r\n\r\n case STEP_KEYS.APPOINTMENT_DATE_TIME:\r\n return null;\r\n\r\n default:\r\n return STEP_KEYS.SPECIALTY_TYPE;\r\n }\r\n};\r\n","import { useMemo, useCallback } from \"react\";\r\nimport { ANY_SELECTION } from \"../../constants\";\r\nimport {\r\n filterSchedulesByPractitioner,\r\n filterLocationsBySchedules,\r\n filterPractitionersBySpecialty,\r\n filterSchedulesByLocation,\r\n filterPractitionersBySchedules,\r\n filterTimeSlotsByLocationAndPractitioner\r\n} from \"../../helpers\";\r\n\r\nexport const useGetSpecialtyTypeList = (\r\n specialtyTypes,\r\n preSelectSpecialtyType\r\n) => {\r\n return useMemo(() => {\r\n if (!specialtyTypes) return [];\r\n return specialtyTypes.filter(\r\n specialtyType =>\r\n !preSelectSpecialtyType ||\r\n specialtyType.specialtyTypeId === preSelectSpecialtyType\r\n );\r\n }, [specialtyTypes, preSelectSpecialtyType]);\r\n};\r\n\r\nexport const useGetAppointmentTypeList = (\r\n specialtyTypeList,\r\n specialtyTypeValue\r\n) => {\r\n return useMemo(() => {\r\n if (!specialtyTypeList) return [];\r\n const selectedSpecialtyType = specialtyTypeList.find(\r\n specialty => specialty.specialtyTypeId === specialtyTypeValue\r\n );\r\n return selectedSpecialtyType\r\n ? selectedSpecialtyType.appointmentTypes.sort((a, b) => {\r\n var nameA = a.description.toUpperCase(); // ignore upper and lowercase\r\n var nameB = b.description.toUpperCase(); // ignore upper and lowercase\r\n if (nameA < nameB) {\r\n return -1;\r\n }\r\n if (nameA > nameB) {\r\n return 1;\r\n }\r\n return 0;\r\n })\r\n : null;\r\n }, [specialtyTypeList, specialtyTypeValue]);\r\n};\r\n\r\nexport const useGetLocationList = (\r\n locations,\r\n schedules,\r\n practitionerValue,\r\n practitionerFirst,\r\n preSelectPractitioner\r\n) => {\r\n return useMemo(() => {\r\n if (!schedules || !locations) return [];\r\n let schedulesCopy = schedules;\r\n let locationCopy = locations;\r\n if (practitionerFirst && preSelectPractitioner !== ANY_SELECTION) {\r\n schedulesCopy = filterSchedulesByPractitioner(\r\n schedulesCopy,\r\n practitionerValue\r\n );\r\n }\r\n locationCopy = filterLocationsBySchedules(locationCopy, schedulesCopy);\r\n return locationCopy;\r\n }, [\r\n locations,\r\n schedules,\r\n practitionerValue,\r\n practitionerFirst,\r\n preSelectPractitioner\r\n ]);\r\n};\r\n\r\nexport const useGetPractitionerList = (\r\n practitioners,\r\n schedules,\r\n specialtyTypeValue,\r\n locationValue\r\n) => {\r\n return useMemo(() => {\r\n let practitionersCopy = practitioners;\r\n practitionersCopy = filterPractitionersBySpecialty(\r\n practitionersCopy,\r\n specialtyTypeValue\r\n );\r\n\r\n const schedulesFilteredByLocation = filterSchedulesByLocation(\r\n schedules,\r\n locationValue\r\n );\r\n practitionersCopy = filterPractitionersBySchedules(\r\n practitionersCopy,\r\n schedulesFilteredByLocation\r\n );\r\n return practitionersCopy;\r\n }, [practitioners, schedules, specialtyTypeValue, locationValue]);\r\n};\r\n\r\nexport const useGetAvailableLocations = (\r\n locations,\r\n schedules,\r\n locationValue,\r\n practitionerValue\r\n) => {\r\n return useMemo(() => {\r\n let availableLocations = [locationValue];\r\n\r\n if (locationValue === ANY_SELECTION) {\r\n availableLocations = filterLocationsBySchedules(\r\n locations,\r\n filterSchedulesByPractitioner(schedules, practitionerValue)\r\n ).map(l => l.locationId);\r\n }\r\n return availableLocations;\r\n }, [locations, schedules, locationValue, practitionerValue]);\r\n};\r\n\r\nexport const useGetAvailablePractitioners = (\r\n practitioners,\r\n schedules,\r\n specialtyTypeValue,\r\n locationValue,\r\n practitionerValue\r\n) => {\r\n return useMemo(() => {\r\n let availablePractitioners = [practitionerValue];\r\n\r\n if (practitionerValue === ANY_SELECTION) {\r\n const practitionersFilteredBySpecialty = filterPractitionersBySpecialty(\r\n practitioners,\r\n specialtyTypeValue\r\n );\r\n\r\n availablePractitioners = filterPractitionersBySchedules(\r\n practitionersFilteredBySpecialty,\r\n filterSchedulesByLocation(schedules, locationValue)\r\n ).map(p => p.practitionerId);\r\n }\r\n return availablePractitioners;\r\n }, [\r\n practitioners,\r\n schedules,\r\n specialtyTypeValue,\r\n locationValue,\r\n practitionerValue\r\n ]);\r\n};\r\n\r\nexport const useGetTimeSlotList = (\r\n timeslots,\r\n practitionerValue,\r\n locationValue\r\n) => {\r\n return useMemo(() => {\r\n return filterTimeSlotsByLocationAndPractitioner(\r\n timeslots,\r\n locationValue,\r\n practitionerValue\r\n );\r\n }, [timeslots, practitionerValue, locationValue]);\r\n};\r\n\r\nexport const useGetPositions = (locationList, getPositions) => {\r\n return useCallback(() => {\r\n getPositions(locationList);\r\n }, [locationList, getPositions]);\r\n};\r\n","import React, { useCallback, useMemo, Fragment } from \"react\";\r\nimport { connect } from \"react-redux\";\r\nimport {\r\n WelcomeMessage,\r\n SpecialtyTypeSelect,\r\n AppointmentTypeSelect,\r\n LocationSelect,\r\n PractitionerSelect,\r\n TimeZoneSelect,\r\n ScheduleSelect,\r\n LocationDrawer,\r\n PractitionerDrawer,\r\n ScheduleDrawer,\r\n ContinueButton\r\n} from \"./components\";\r\nimport { MountedAnimationWrapper } from \"../AnimationWrapper\";\r\nimport { StepText } from \"../Common\";\r\nimport { STEP_KEYS, PAGE_KEYS } from \"../constants\";\r\nimport {\r\n toggleVisibility,\r\n selectSpecialtyType,\r\n selectAppointmentType,\r\n selectLocation,\r\n selectPractitioner,\r\n selectTimeZone,\r\n selectAppointmentDateTime,\r\n getPositions,\r\n getTimeSlots,\r\n goToNextStep,\r\n goToPage,\r\n setRequireWaitingList,\r\n selectPreferredTime\r\n} from \"../actions\";\r\nimport { isCurrentStep } from \"../helpers\";\r\nimport {\r\n useGetSpecialtyTypeList,\r\n useGetAppointmentTypeList,\r\n useGetLocationList,\r\n useGetPractitionerList,\r\n useGetAvailableLocations,\r\n useGetAvailablePractitioners,\r\n useGetTimeSlotList,\r\n useGetPositions,\r\n useSelectSpecialtyType,\r\n useSelectAppointmentType,\r\n useSelectLocation,\r\n useSelectPractitioner,\r\n useSelectTimeZone,\r\n useSelectAppointmentDateTime,\r\n useSelectWaitingListPreferredTime\r\n} from \"./hooks\";\r\nimport \"./bookingPortal.less\";\r\n\r\nexport const BookingPortal = props => {\r\n const {\r\n config,\r\n datasource,\r\n appointment,\r\n booking,\r\n waitingList,\r\n toggleVisibility,\r\n goToNextStep,\r\n selectSpecialtyType,\r\n selectAppointmentType,\r\n selectLocation,\r\n selectPractitioner,\r\n selectTimeZone,\r\n getPositions,\r\n selectAppointmentDateTime,\r\n getTimeSlots,\r\n goToPage,\r\n setRequireWaitingList,\r\n selectPreferredTime\r\n } = props;\r\n\r\n const {\r\n welcomeMessage,\r\n preSelectSpecialtyType,\r\n practitionerFirst,\r\n preSelectPractitioner,\r\n tenant,\r\n specialtyHintText,\r\n appointmentTypeHintText,\r\n practitionerHintText,\r\n locationHintText,\r\n timezoneHintText,\r\n appointmentDateTimeHintText,\r\n noSlotsPlaceholder,\r\n earliestBookingTime,\r\n waitingListEnabled,\r\n isTimezoneEnabled,\r\n isAnyPractitionerEnabled\r\n } = config;\r\n const {\r\n specialtyTypes,\r\n locations,\r\n practitioners,\r\n schedules,\r\n timeZones,\r\n positions,\r\n timeSlots,\r\n loadingTimeSlots\r\n } = datasource;\r\n const { steps, visibilityKey } = booking;\r\n\r\n const {\r\n [STEP_KEYS.SPECIALTY_TYPE]: specialtyTypeValue,\r\n [STEP_KEYS.APPOINTMENT_TYPE]: appointmentTypeValue,\r\n [STEP_KEYS.PRACTITIONER]: practitionerValue,\r\n [STEP_KEYS.LOCATION]: locationValue,\r\n [STEP_KEYS.TIMEZONE]: timezoneValue,\r\n [STEP_KEYS.APPOINTMENT_DATE_TIME]: appointmentDateTimeValue,\r\n timeZoneOfLocation\r\n } = appointment;\r\n\r\n const specialtyTypeList = useGetSpecialtyTypeList(\r\n specialtyTypes,\r\n preSelectSpecialtyType\r\n );\r\n\r\n const appointmentTypeList = useGetAppointmentTypeList(\r\n specialtyTypeList,\r\n specialtyTypeValue\r\n );\r\n\r\n const locationList = useGetLocationList(\r\n locations,\r\n schedules,\r\n practitionerValue,\r\n practitionerFirst,\r\n preSelectPractitioner\r\n );\r\n\r\n const practitionerList = useGetPractitionerList(\r\n practitioners,\r\n schedules,\r\n specialtyTypeValue,\r\n locationValue\r\n );\r\n\r\n const timeSlotsList = useGetTimeSlotList(\r\n timeSlots,\r\n practitionerValue,\r\n locationValue\r\n );\r\n\r\n const availableLocations = useGetAvailableLocations(\r\n locations,\r\n schedules,\r\n locationValue,\r\n practitionerValue\r\n );\r\n\r\n const availablePractitioners = useGetAvailablePractitioners(\r\n practitioners,\r\n schedules,\r\n specialtyTypeValue,\r\n locationValue,\r\n practitionerValue\r\n );\r\n\r\n const handleGetPositions = useGetPositions(locationList, getPositions);\r\n\r\n const handleSelectSpecialtyType = useSelectSpecialtyType(\r\n selectSpecialtyType,\r\n goToNextStep,\r\n specialtyTypeValue\r\n );\r\n\r\n const handleSelectAppointmentType = useSelectAppointmentType(\r\n selectAppointmentType,\r\n goToNextStep,\r\n appointmentTypeValue\r\n );\r\n\r\n const handleSelectLocation = useSelectLocation(\r\n selectLocation,\r\n goToNextStep,\r\n locationValue,\r\n timeZones\r\n );\r\n\r\n const handleSelectPractitioner = useSelectPractitioner(\r\n practitionerValue,\r\n selectPractitioner,\r\n goToNextStep\r\n );\r\n\r\n const handleSelectTimeZone = useSelectTimeZone(\r\n timezoneValue,\r\n selectTimeZone,\r\n goToNextStep\r\n );\r\n\r\n const handleSelectAppointmentDateTime = useSelectAppointmentDateTime(\r\n selectAppointmentDateTime,\r\n practitionerValue,\r\n locationValue,\r\n timeSlots,\r\n selectPractitioner,\r\n selectLocation,\r\n timeZones\r\n );\r\n\r\n const handleSelectWaitingListPreferredTime = useSelectWaitingListPreferredTime(\r\n selectPreferredTime,\r\n selectLocation,\r\n selectPractitioner,\r\n practitionerValue,\r\n locationValue,\r\n availableLocations,\r\n availablePractitioners,\r\n selectAppointmentDateTime,\r\n toggleVisibility,\r\n goToPage\r\n );\r\n\r\n const handleContinueButtonClick = useCallback(() => {\r\n goToPage(PAGE_KEYS.CONTACT);\r\n }, [goToPage]);\r\n\r\n const finished = useMemo(() => {\r\n return (\r\n steps.includes(STEP_KEYS.APPOINTMENT_DATE_TIME) &&\r\n appointmentDateTimeValue\r\n );\r\n }, [steps, appointmentDateTimeValue]);\r\n\r\n const renderSteps = stepKey => {\r\n switch (stepKey) {\r\n case STEP_KEYS.SPECIALTY_TYPE:\r\n return (\r\n <SpecialtyTypeSelect\r\n hint={specialtyHintText}\r\n open={visibilityKey === STEP_KEYS.SPECIALTY_TYPE}\r\n onToggle={toggleVisibility}\r\n value={specialtyTypeValue}\r\n onSelect={handleSelectSpecialtyType}\r\n specialtyTypes={specialtyTypeList}\r\n hideStep={!!preSelectSpecialtyType}\r\n />\r\n );\r\n case STEP_KEYS.APPOINTMENT_TYPE:\r\n return (\r\n <AppointmentTypeSelect\r\n hint={appointmentTypeHintText}\r\n open={visibilityKey === STEP_KEYS.APPOINTMENT_TYPE}\r\n onToggle={toggleVisibility}\r\n value={appointmentTypeValue}\r\n onSelect={handleSelectAppointmentType}\r\n appointmentTypes={appointmentTypeList}\r\n />\r\n );\r\n case STEP_KEYS.LOCATION:\r\n return (\r\n <LocationSelect\r\n hint={locationHintText}\r\n value={locationValue}\r\n onToggle={toggleVisibility}\r\n onSelect={handleSelectLocation}\r\n locations={locationList}\r\n getPositions={handleGetPositions}\r\n isCurrentStep={isCurrentStep(steps, STEP_KEYS.LOCATION)}\r\n />\r\n );\r\n case STEP_KEYS.PRACTITIONER:\r\n return (\r\n <PractitionerSelect\r\n hint={practitionerHintText}\r\n value={practitionerValue}\r\n onToggle={toggleVisibility}\r\n onSelect={handleSelectPractitioner}\r\n practitioners={practitionerList}\r\n preSelectPractitioner={preSelectPractitioner}\r\n isCurrentStep={isCurrentStep(steps, STEP_KEYS.PRACTITIONER)}\r\n />\r\n );\r\n case STEP_KEYS.TIMEZONE:\r\n return (\r\n <TimeZoneSelect\r\n hint={timezoneHintText}\r\n open={visibilityKey === STEP_KEYS.TIMEZONE}\r\n onToggle={toggleVisibility}\r\n value={timezoneValue}\r\n onSelect={handleSelectTimeZone}\r\n timeZones={timeZones}\r\n isTimezoneEnabled={isTimezoneEnabled}\r\n />\r\n );\r\n case STEP_KEYS.APPOINTMENT_DATE_TIME:\r\n return (\r\n <ScheduleSelect\r\n hint={appointmentDateTimeHintText}\r\n onToggle={toggleVisibility}\r\n appointmentDateTime={appointmentDateTimeValue}\r\n noSlotsPlaceholder={noSlotsPlaceholder}\r\n loading={loadingTimeSlots}\r\n timeSlots={timeSlotsList}\r\n />\r\n );\r\n default:\r\n return null;\r\n }\r\n };\r\n\r\n return (\r\n <MountedAnimationWrapper animationClassName=\"booking-portal-animation\">\r\n <div className=\"booking-portal-container\">\r\n {welcomeMessage && <WelcomeMessage title={welcomeMessage} />}\r\n <div className=\"booking-portal-step-text-container\">\r\n <StepText step={1} />\r\n </div>\r\n {steps.map(stepKey => (\r\n <Fragment key={stepKey}>{renderSteps(stepKey)}</Fragment>\r\n ))}\r\n {finished && <ContinueButton onClick={handleContinueButtonClick} />}\r\n <LocationDrawer\r\n open={visibilityKey === STEP_KEYS.LOCATION}\r\n onToggle={toggleVisibility}\r\n onSelect={handleSelectLocation}\r\n value={locationValue}\r\n locations={locationList}\r\n positions={positions}\r\n />\r\n <PractitionerDrawer\r\n open={visibilityKey === STEP_KEYS.PRACTITIONER}\r\n onToggle={toggleVisibility}\r\n onSelect={handleSelectPractitioner}\r\n value={practitionerValue}\r\n practitioners={practitionerList}\r\n tenant={tenant}\r\n isAnyPractitionerEnabled={isAnyPractitionerEnabled}\r\n />\r\n <ScheduleDrawer\r\n open={visibilityKey === STEP_KEYS.APPOINTMENT_DATE_TIME}\r\n onToggle={toggleVisibility}\r\n timeSlots={timeSlotsList}\r\n onSelect={handleSelectAppointmentDateTime}\r\n loadingTimeSlots={loadingTimeSlots}\r\n getTimeSlots={getTimeSlots}\r\n isCurrentStep={isCurrentStep(steps, STEP_KEYS.APPOINTMENT_DATE_TIME)}\r\n availableLocations={availableLocations}\r\n practitionerValue={practitionerValue}\r\n appointmentDateTimeValue={appointmentDateTimeValue}\r\n earliestBookingTime={earliestBookingTime}\r\n waitingListEnabled={waitingListEnabled}\r\n waitingList={waitingList}\r\n setRequireWaitingList={setRequireWaitingList}\r\n selectPreferredTime={handleSelectWaitingListPreferredTime}\r\n timezone={timezoneValue || timeZoneOfLocation}\r\n />\r\n </div>\r\n </MountedAnimationWrapper>\r\n );\r\n};\r\n\r\nexport default connect(\r\n state => {\r\n return {\r\n config: state.config,\r\n datasource: state.datasource,\r\n booking: state.booking,\r\n appointment: state.appointment,\r\n waitingList: state.waitingList\r\n };\r\n },\r\n {\r\n toggleVisibility,\r\n selectSpecialtyType,\r\n selectAppointmentType,\r\n selectLocation,\r\n selectPractitioner,\r\n selectTimeZone,\r\n selectAppointmentDateTime,\r\n getTimeSlots,\r\n getPositions,\r\n goToNextStep,\r\n goToPage,\r\n setRequireWaitingList,\r\n selectPreferredTime\r\n }\r\n)(BookingPortal);\r\n","import { WAITING_LIST_ACTION } from \"./types\";\r\n\r\nexport const setRequireWaitingList = (required = true) => {\r\n return {\r\n type: WAITING_LIST_ACTION.REQUIRE_WAITING_LIST,\r\n payload: required\r\n };\r\n};\r\n\r\nexport const selectPreferredTime = (time = \"\") => {\r\n return {\r\n type: WAITING_LIST_ACTION.UPDATE_PREFERRED_TIME,\r\n payload: time\r\n };\r\n};\r\n","import { useCallback } from \"react\";\r\nimport { STEP_KEYS, ANY_SELECTION, PAGE_KEYS } from \"../../constants\";\r\n\r\nexport const useSelectSpecialtyType = (\r\n selectSpecialtyType,\r\n goToNextStep,\r\n specialtyTypeValue\r\n) => {\r\n return useCallback(\r\n specialtyTypeId => {\r\n if (specialtyTypeId === specialtyTypeValue) return;\r\n selectSpecialtyType(specialtyTypeId);\r\n goToNextStep(STEP_KEYS.SPECIALTY_TYPE);\r\n },\r\n [selectSpecialtyType, goToNextStep, specialtyTypeValue]\r\n );\r\n};\r\n\r\nexport const useSelectAppointmentType = (\r\n selectAppointmentType,\r\n goToNextStep,\r\n appointmentTypeValue\r\n) => {\r\n return useCallback(\r\n appointmentTypeId => {\r\n if (appointmentTypeId === appointmentTypeValue) return;\r\n selectAppointmentType(appointmentTypeId);\r\n goToNextStep(STEP_KEYS.APPOINTMENT_TYPE);\r\n },\r\n [selectAppointmentType, goToNextStep, appointmentTypeValue]\r\n );\r\n};\r\n\r\nexport const useSelectLocation = (\r\n selectLocation,\r\n goToNextStep,\r\n locationValue,\r\n timeZones\r\n) => {\r\n return useCallback(\r\n location => {\r\n const { locationId, timeZone } = location;\r\n if (locationId === locationValue) return;\r\n const timeZoneId = timeZone ? timeZone.timezoneId || \"\" : \"\";\r\n const foundedTimeZone = timeZones.find(\r\n timezone =>\r\n timezone.timezoneUID.toLowerCase() === timeZoneId.toLowerCase()\r\n );\r\n\r\n const timeZoneIdOfLocation = foundedTimeZone\r\n ? foundedTimeZone.timezoneUID\r\n : timeZoneId;\r\n\r\n selectLocation(locationId, timeZoneIdOfLocation);\r\n\r\n goToNextStep(STEP_KEYS.LOCATION);\r\n },\r\n [selectLocation, goToNextStep, locationValue, timeZones]\r\n );\r\n};\r\n\r\nexport const useSelectPractitioner = (\r\n practitionerValue,\r\n selectPractitioner,\r\n goToNextStep\r\n) => {\r\n return useCallback(\r\n practitioner => {\r\n const { practitionerId } = practitioner;\r\n if (practitionerId === practitionerValue) return;\r\n selectPractitioner(practitionerId);\r\n goToNextStep(STEP_KEYS.PRACTITIONER);\r\n },\r\n [practitionerValue, selectPractitioner, goToNextStep]\r\n );\r\n};\r\n\r\nexport const useSelectTimeZone = (\r\n timezoneValue,\r\n selectTimeZone,\r\n goToNextStep\r\n) => {\r\n return useCallback(\r\n timezoneId => {\r\n if (timezoneId === timezoneValue) return;\r\n selectTimeZone(timezoneId);\r\n goToNextStep(STEP_KEYS.TIMEZONE);\r\n },\r\n [timezoneValue, selectTimeZone, goToNextStep]\r\n );\r\n};\r\n\r\nexport const useSelectAppointmentDateTime = (\r\n selectAppointmentDateTime,\r\n practitionerValue,\r\n locationValue,\r\n timeSlots,\r\n selectPractitioner,\r\n selectLocation\r\n) => {\r\n return useCallback(\r\n timeslot => {\r\n const { startDateTime, endDateTime } = timeslot;\r\n selectAppointmentDateTime(timeslot);\r\n const anyPractitioner = practitionerValue === ANY_SELECTION;\r\n const anyLocation = locationValue === ANY_SELECTION;\r\n if (anyPractitioner || anyLocation) {\r\n let matchedTimeSlots = timeSlots.filter(\r\n ts =>\r\n ts.startDateTime === startDateTime && ts.endDateTime === endDateTime\r\n );\r\n if (!anyPractitioner) {\r\n matchedTimeSlots = matchedTimeSlots.filter(\r\n ts => ts.practitioner.practitionerId === practitionerValue\r\n );\r\n }\r\n if (!anyLocation) {\r\n matchedTimeSlots = matchedTimeSlots.filter(\r\n ts => ts.locationId === locationValue\r\n );\r\n }\r\n const firstMatch = matchedTimeSlots[0];\r\n if (anyPractitioner) {\r\n selectPractitioner(firstMatch.practitioner.practitionerId);\r\n }\r\n if (anyLocation) {\r\n selectLocation(firstMatch.locationId);\r\n }\r\n }\r\n },\r\n [\r\n selectAppointmentDateTime,\r\n practitionerValue,\r\n locationValue,\r\n timeSlots,\r\n selectPractitioner,\r\n selectLocation\r\n ]\r\n );\r\n};\r\n\r\nexport const useSelectWaitingListPreferredTime = (\r\n selectPreferredTime,\r\n selectLocation,\r\n selectPractitioner,\r\n practitionerValue,\r\n locationValue,\r\n availableLocations,\r\n availablePractitioners,\r\n selectAppointmentDateTime,\r\n toggleVisibility,\r\n goToPage\r\n) => {\r\n return useCallback(\r\n time => {\r\n selectPreferredTime(time);\r\n selectAppointmentDateTime(null);\r\n\r\n if (\r\n practitionerValue === ANY_SELECTION &&\r\n availablePractitioners.length > 0\r\n ) {\r\n selectPractitioner(availablePractitioners[0]);\r\n }\r\n if (locationValue === ANY_SELECTION && availableLocations.length > 0) {\r\n selectLocation(availableLocations[0]);\r\n }\r\n toggleVisibility(STEP_KEYS.APPOINTMENT_DATE_TIME, false);\r\n goToPage(PAGE_KEYS.CONTACT);\r\n },\r\n [\r\n selectPreferredTime,\r\n selectLocation,\r\n selectPractitioner,\r\n practitionerValue,\r\n locationValue,\r\n availableLocations,\r\n availablePractitioners,\r\n selectAppointmentDateTime,\r\n toggleVisibility,\r\n goToPage\r\n ]\r\n );\r\n};\r\n","import React, { memo, useState, useCallback, useRef } from \"react\";\r\nimport ReCAPTCHA from \"react-google-recaptcha\";\r\nimport { SideDrawer, InputBox, TransparentButton } from \"../../Common\";\r\nimport { RECAPTCHA_KEY } from \"../../../../api/config\";\r\n\r\nconst MAX_COUNT_NUMBER = 5;\r\n\r\nexport const VerificationDrawer = memo(props => {\r\n const recaptchaRef = useRef();\r\n const [value, setValue] = useState(\"\");\r\n const [verificationCount, setVerificationCount] = useState(0);\r\n const [verificationError, setVerificationError] = useState(\"\");\r\n const [recaptchaValid, setRecaptchaValid] = useState(false);\r\n const [recaptchaToken, setRecaptchaToken] = useState(\"\");\r\n\r\n const {\r\n open,\r\n onToggle,\r\n submitBooking,\r\n sendingVerificationCode,\r\n verifyCode,\r\n useRecaptcha\r\n } = props;\r\n const handleInputChange = useCallback(\r\n value => {\r\n setValue(value);\r\n verificationError && setVerificationError(\"\");\r\n },\r\n [verificationError]\r\n );\r\n\r\n const handleCancel = useCallback(() => {\r\n onToggle(false);\r\n setValue(\"\");\r\n setVerificationCount(0);\r\n setVerificationError(\"\");\r\n }, [onToggle]);\r\n\r\n const handleResend = useCallback(async () => {\r\n try {\r\n await sendingVerificationCode();\r\n setValue(\"\");\r\n setVerificationCount(0);\r\n setVerificationError(\"\");\r\n } catch (e) {\r\n setVerificationError(\r\n \"Resend sms verification failed, could you please try it again.\"\r\n );\r\n }\r\n }, [sendingVerificationCode]);\r\n\r\n const handleConfirm = useCallback(async () => {\r\n if (!useRecaptcha) {\r\n let verified = false;\r\n const count = verificationCount + 1;\r\n setVerificationCount(count);\r\n try {\r\n await verifyCode(value);\r\n verified = true;\r\n } catch (e) {\r\n const errorMessage = `Incorrect confirmation code${\r\n count === MAX_COUNT_NUMBER\r\n ? \", please press Resend and enter again\"\r\n : \"\"\r\n }`;\r\n setVerificationError(errorMessage);\r\n }\r\n if (verified) {\r\n setVerificationCount(0);\r\n try {\r\n await submitBooking(value);\r\n } catch (e) {\r\n handleCancel();\r\n }\r\n }\r\n } else {\r\n try {\r\n await submitBooking(value, recaptchaToken);\r\n } catch (e) {\r\n handleCancel();\r\n }\r\n }\r\n }, [\r\n value,\r\n verificationCount,\r\n verifyCode,\r\n submitBooking,\r\n useRecaptcha,\r\n recaptchaToken,\r\n handleCancel\r\n ]);\r\n\r\n const handleVerifyRecaptcha = useCallback(value => {\r\n setRecaptchaValid(true);\r\n setRecaptchaToken(value);\r\n }, []);\r\n\r\n const renderVerificationMethod = () => {\r\n if (useRecaptcha) {\r\n return (\r\n <ReCAPTCHA\r\n ref={recaptchaRef}\r\n sitekey={RECAPTCHA_KEY}\r\n render=\"explicit\"\r\n onChange={handleVerifyRecaptcha}\r\n />\r\n );\r\n }\r\n return (\r\n <InputBox\r\n label=\"Verification Code\"\r\n value={value}\r\n errorText={verificationError}\r\n onChange={handleInputChange}\r\n />\r\n );\r\n };\r\n\r\n const buttonDisabled = () => {\r\n if (useRecaptcha) {\r\n return !recaptchaValid;\r\n } else {\r\n return (\r\n !value || verificationCount === MAX_COUNT_NUMBER || !!verificationError\r\n );\r\n }\r\n };\r\n\r\n return (\r\n <SideDrawer open={open} onToggle={onToggle} maskClosable={false}>\r\n <span className=\"drawer-title drawer-title-small\">\r\n A confirmation code was sent to your mobile device\r\n </span>\r\n <div>\r\n {renderVerificationMethod()}\r\n <div className=\"verification-sms-btn-container\">\r\n <div className=\"verification-sms-btn-container-save\">\r\n {!useRecaptcha && (\r\n <TransparentButton\r\n isTheme={true}\r\n label=\"Resend\"\r\n className=\"verification-sms-btn-resend\"\r\n onClick={handleResend}\r\n />\r\n )}\r\n <TransparentButton\r\n isTheme={true}\r\n label=\"Confirm\"\r\n className=\"verification-sms-btn-confirm\"\r\n forceDisabled={buttonDisabled()}\r\n onClick={handleConfirm}\r\n />\r\n </div>\r\n <div className=\"verification-sms-btn-container-back\">\r\n <TransparentButton\r\n label=\"Cancel\"\r\n className=\"verification-sms-btn-cancel\"\r\n onClick={handleCancel}\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n </SideDrawer>\r\n );\r\n});\r\n","import React, { memo, useCallback } from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport { InputBox } from '../../../Common';\r\nconst FormInput = memo(props => {\r\n const {\r\n formKey,\r\n label,\r\n value,\r\n errorText,\r\n onChange,\r\n onValidate,\r\n maxLength,\r\n disabled,\r\n regexRule\r\n } = props;\r\n\r\n const handleChange = useCallback(\r\n value => {\r\n if (value && regexRule && !regexRule.test(value)) return;\r\n if (maxLength && value.length > maxLength) return;\r\n onChange(formKey, value);\r\n onValidate && onValidate(formKey, value);\r\n },\r\n [formKey, onChange, onValidate, maxLength, regexRule]\r\n );\r\n\r\n const handleBlur = useCallback(() => {\r\n onValidate && onValidate(formKey, value);\r\n }, [formKey, onValidate, value]);\r\n return (\r\n <InputBox\r\n label={label}\r\n value={value || ''}\r\n errorText={errorText}\r\n onChange={handleChange}\r\n onBlur={handleBlur}\r\n inputProps={{\r\n autoComplete: 'none'\r\n }}\r\n disabled={disabled}\r\n />\r\n );\r\n});\r\n\r\nFormInput.propTypes = {\r\n formKey: PropTypes.string.isRequired,\r\n label: PropTypes.string.isRequired,\r\n value: PropTypes.string,\r\n errorText: PropTypes.string,\r\n onValidate: PropTypes.func,\r\n onChange: PropTypes.func.isRequired,\r\n maxLength: PropTypes.number,\r\n disabled: PropTypes.bool,\r\n regexRule: PropTypes.instanceOf(RegExp)\r\n};\r\n\r\nexport default FormInput;\r\n","import React, {\r\n memo,\r\n useEffect,\r\n useCallback,\r\n useMemo,\r\n useState,\r\n useRef\r\n} from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport MaskedInput from \"react-text-mask\";\r\nimport Fade from \"@material-ui/core/Fade\";\r\nimport { DateOfBirthCalendar, InputBox, CalendarIcon } from \"../../../Common\";\r\nimport { useCheckMobile } from \"../../../hooks\";\r\n\r\nconst DateOfBirth = memo(props => {\r\n const isMobile = useCheckMobile();\r\n const dobRef = useRef();\r\n const [focused, setFocused] = useState(false);\r\n const [showCalendar, setShowCalendar] = useState(false);\r\n const { formKey, value, errorText, onChange, onValidate } = props;\r\n\r\n useEffect(() => {\r\n document.addEventListener(\"click\", handleDocumentClick);\r\n return () => {\r\n document.removeEventListener(\"click\", handleDocumentClick);\r\n };\r\n }, []);\r\n\r\n const handleDocumentClick = e => {\r\n const targetDom = e.target;\r\n if (dobRef.current && dobRef.current.contains(targetDom)) {\r\n return;\r\n }\r\n setShowCalendar(false);\r\n };\r\n\r\n const handleChange = useCallback(\r\n value => {\r\n onChange(formKey, value);\r\n onValidate(formKey, value);\r\n },\r\n [formKey, onChange, onValidate]\r\n );\r\n\r\n const handleSelect = useCallback(\r\n value => {\r\n handleChange(value);\r\n setShowCalendar(false);\r\n },\r\n [handleChange]\r\n );\r\n\r\n const handleBlur = useCallback(() => {\r\n setFocused(false);\r\n }, []);\r\n\r\n const handleFocus = useCallback(() => {\r\n setShowCalendar(!isMobile);\r\n setFocused(true);\r\n }, [isMobile]);\r\n\r\n const handleCalendarIconClick = useCallback(() => {\r\n setShowCalendar(prevState => !prevState);\r\n }, []);\r\n\r\n const floatingLabel = useMemo(() => {\r\n if (isMobile) {\r\n return focused || !!value;\r\n } else {\r\n return showCalendar || focused || !!value;\r\n }\r\n }, [showCalendar, focused, value, isMobile]);\r\n\r\n return (\r\n <div ref={dobRef}>\r\n <InputBox\r\n label=\"Date of birth(dd/mm/yyyy) *\"\r\n placeholder=\"__/__/____\"\r\n errorText={errorText}\r\n value={value || \"\"}\r\n onBlur={handleBlur}\r\n onChange={handleChange}\r\n InputLabelProps={{\r\n shrink: floatingLabel\r\n }}\r\n InputProps={{\r\n inputComponent: DOBMaskedInput\r\n }}\r\n onFocus={handleFocus}\r\n type=\"tel\"\r\n className=\"date-of-birth-input\"\r\n />\r\n <CalendarPanel\r\n show={showCalendar}\r\n date={value}\r\n error={!!errorText}\r\n onSelect={handleSelect}\r\n />\r\n <div className=\"dob-mobile-icon\" onClick={handleCalendarIconClick}>\r\n <CalendarIcon />\r\n </div>\r\n </div>\r\n );\r\n});\r\n\r\nDateOfBirth.propTypes = {\r\n formKey: PropTypes.string.isRequired,\r\n value: PropTypes.string,\r\n errorText: PropTypes.string,\r\n onValidate: PropTypes.func,\r\n onChange: PropTypes.func.isRequired\r\n};\r\n\r\nconst DOBMaskedInput = memo(props => {\r\n const { inputRef, ...restProps } = props;\r\n return (\r\n <MaskedInput\r\n {...restProps}\r\n ref={ref => {\r\n inputRef(ref ? ref.inputElement : null);\r\n }}\r\n mask={[/\\d/, /\\d/, \"/\", /\\d/, /\\d/, \"/\", /\\d/, /\\d/, /\\d/, /\\d/]}\r\n />\r\n );\r\n});\r\n\r\nDOBMaskedInput.propTypes = {\r\n inputRef: PropTypes.func.isRequired\r\n};\r\n\r\nconst CalendarPanel = memo(props => {\r\n const { show, date, error, onSelect } = props;\r\n\r\n const dateString = useMemo(() => {\r\n return !error ? date : null;\r\n }, [error, date]);\r\n return (\r\n <Fade in={show}>\r\n <div className={`dob-calendar-container ${error ? \"hasError\" : \"\"}`}>\r\n <DateOfBirthCalendar dateString={dateString} onSelect={onSelect} />\r\n </div>\r\n </Fade>\r\n );\r\n});\r\n\r\nCalendarPanel.propTypes = {\r\n show: PropTypes.bool.isRequired,\r\n date: PropTypes.string,\r\n error: PropTypes.bool.isRequired,\r\n onSelect: PropTypes.func.isRequired\r\n};\r\n\r\nexport default DateOfBirth;\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport FormInput from \"./FormInput\";\r\nimport { colorStyle } from \"../../../styles\";\r\nimport { FORM_KEYS } from \"../../../constants\";\r\n\r\nconst Comments = memo(props => {\r\n const { value, errorText, onChange, onValidate, mandatory } = props;\r\n\r\n return (\r\n <div className=\"details-form-item\">\r\n <FormInput\r\n formKey={FORM_KEYS.COMMENTS}\r\n label={`Comments${mandatory ? \" *\" : \"(optional)\"}`}\r\n value={value}\r\n errorText={errorText}\r\n onChange={onChange}\r\n onValidate={onValidate}\r\n maxLength={200}\r\n />\r\n {value && (\r\n <span className=\"comments-letter-counter\" style={colorStyle}>\r\n {value.length} / 200\r\n </span>\r\n )}\r\n </div>\r\n );\r\n});\r\n\r\nComments.propTypes = {\r\n value: PropTypes.string,\r\n errorText: PropTypes.string,\r\n onChange: PropTypes.func.isRequired,\r\n onValidate: PropTypes.func\r\n};\r\n\r\nexport default Comments;\r\n","import React, { memo, useCallback } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { AutocompleteBox } from \"../../../Common\";\r\nimport { FORM_KEYS } from \"../../../constants\";\r\n\r\nconst HealthFund = memo(props => {\r\n const { healthFunds, onChange } = props;\r\n\r\n const handleChange = useCallback(\r\n value => {\r\n onChange(FORM_KEYS.HEALTH_FUND, value);\r\n },\r\n [onChange]\r\n );\r\n\r\n return (\r\n <AutocompleteBox\r\n label=\"Select your current health fund\"\r\n options={healthFunds}\r\n onChange={handleChange}\r\n />\r\n );\r\n});\r\n\r\nHealthFund.propTypes = {\r\n healthFunds: PropTypes.array.isRequired,\r\n onChange: PropTypes.func.isRequired\r\n};\r\n\r\nexport default HealthFund;\r\n","import React, { memo, useCallback } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport Checkbox from \"@material-ui/core/Checkbox\";\r\nimport Grid from \"@material-ui/core/Grid\";\r\n\r\nconst MedibankCustomFields = memo(props => {\r\n const { value, formKey, customFields, onChange } = props;\r\n const handleCustomFieldChange = useCallback(\r\n (id, checked) => {\r\n onChange(formKey, {\r\n ...value,\r\n [id]: checked\r\n });\r\n },\r\n [onChange, value, formKey]\r\n );\r\n\r\n const renderCustomField = () => {\r\n return customFields.map(cf => {\r\n return (\r\n <Grid item md={6} xs={12} className=\"custom-fields-item\" key={cf.id}>\r\n <Checkbox\r\n color=\"primary\"\r\n checked={value[cf.id] || false}\r\n onChange={e => handleCustomFieldChange(cf.id, e.target.checked)}\r\n />\r\n <span className=\"custom-fields-item-desc\">{cf.name}</span>\r\n </Grid>\r\n );\r\n });\r\n };\r\n return (\r\n <div className=\"custom-fields-container\">\r\n <p className=\"custom-fields-description\">\r\n I am interested in learning about Medibank's other insurance products as\r\n indicated below :\r\n </p>\r\n <Grid container>{renderCustomField()}</Grid>\r\n </div>\r\n );\r\n});\r\n\r\nMedibankCustomFields.propTypes = {\r\n value: PropTypes.object.isRequired,\r\n formKey: PropTypes.string.isRequired,\r\n customFields: PropTypes.array.isRequired,\r\n onChange: PropTypes.func.isRequired\r\n};\r\n\r\nexport default MedibankCustomFields;\r\n","import React, { memo } from 'react';\r\nimport Grid from '@material-ui/core/Grid';\r\nimport PropTypes from 'prop-types';\r\nimport FormInput from './FormInput';\r\nimport { isMedibank } from '../../../helpers';\r\nimport { FORM_KEYS } from '../../../constants';\r\nimport HealthFund from './HealthFund';\r\nimport MedibankCustomFields from './MedibankCustomFields';\r\n\r\nconst MedibankFields = memo(\r\n ({\r\n tenant,\r\n MedibankFundId,\r\n healthFundValue,\r\n healthFunds,\r\n cardNumberValue,\r\n cardPositionValue,\r\n customFieldsValue,\r\n customFields,\r\n setValue,\r\n onValidate\r\n }) => {\r\n const isMedibankPortal = isMedibank(tenant);\r\n\r\n if (!isMedibankPortal) return null;\r\n const renderHealthFund = () => {\r\n return (\r\n <div className=\"details-form-item\">\r\n <HealthFund healthFunds={healthFunds} onChange={setValue} />\r\n </div>\r\n );\r\n };\r\n\r\n const renderMembershipCard = () => {\r\n if (healthFundValue !== MedibankFundId) return null;\r\n return (\r\n <Grid container spacing={1}>\r\n <Grid item sm={6} xs={12} className=\"details-form-item\">\r\n <FormInput\r\n formKey={FORM_KEYS.CARD_NUMBER}\r\n label=\"Membership number\"\r\n value={cardNumberValue}\r\n onChange={setValue}\r\n onValidate={onValidate}\r\n />\r\n </Grid>\r\n <Grid item sm={6} xs={12} className=\"details-form-item\">\r\n <FormInput\r\n formKey={FORM_KEYS.CARD_POSITION}\r\n label=\"Card position number\"\r\n value={cardPositionValue}\r\n onChange={setValue}\r\n onValidate={onValidate}\r\n />\r\n </Grid>\r\n </Grid>\r\n );\r\n };\r\n\r\n const renderCustomFields = () => {\r\n return (\r\n <MedibankCustomFields\r\n value={customFieldsValue}\r\n formKey={FORM_KEYS.CUSTOM_FIELDS}\r\n customFields={customFields}\r\n onChange={setValue}\r\n />\r\n );\r\n };\r\n\r\n return (\r\n <>\r\n {renderHealthFund()}\r\n {renderMembershipCard()}\r\n {renderCustomFields()}\r\n </>\r\n );\r\n }\r\n);\r\n\r\nMedibankFields.propTypes = {\r\n tenant: PropTypes.string,\r\n MedibankFundId: PropTypes.string,\r\n healthFundValue: PropTypes.string,\r\n healthFunds: PropTypes.instanceOf(Array),\r\n cardNumberValue: PropTypes.string,\r\n cardPositionValue: PropTypes.string,\r\n customFieldsValue: PropTypes.instanceOf(Object),\r\n customFields: PropTypes.instanceOf(Array),\r\n setValue: PropTypes.func.isRequired,\r\n onValidate: PropTypes.func.isRequired\r\n};\r\n\r\nMedibankFields.defaultProps = {\r\n healthFunds: [],\r\n customFields: []\r\n};\r\n\r\nexport default MedibankFields;\r\n","export * from './dataMappingHelper';\r\nexport * from './stepHelper';\r\nexport * from './filterHelper';\r\nexport * from './bookingPortalHelper';\r\nexport * from './dateTimeHelper';\r\nexport * from './medicareHelpers';\r\nexport * from './FormValidationHelper';\r\nexport * from './appointmentSummaryHelper';\r\nexport * from './appointmentCancellationHelper';\r\nexport * from './fileHelper';\r\nexport * from './creditCardHelper';\r\n\r\nexport const isMedibank = (tenant = '') => tenant.toLowerCase() === 'medibank';\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport FormInput from \"./FormInput\";\r\nimport { FORM_KEYS } from \"../../../constants\";\r\n\r\nconst ClientAddress = memo(props => {\r\n const { value, mandatory, errorText, onChange, onValidate } = props;\r\n\r\n return (\r\n <FormInput\r\n formKey={FORM_KEYS.CLIENT_ADDRESS}\r\n label={`Your address${mandatory ? \" *\" : \"(optional)\"}`}\r\n value={value}\r\n errorText={errorText}\r\n onChange={onChange}\r\n onValidate={onValidate}\r\n maxLength={150}\r\n />\r\n );\r\n});\r\n\r\nClientAddress.propTypes = {\r\n value: PropTypes.string,\r\n errorText: PropTypes.string,\r\n onChange: PropTypes.func.isRequired,\r\n onValidate: PropTypes.func,\r\n mandatory: PropTypes.bool\r\n};\r\n\r\nexport default ClientAddress;\r\n","import React, { memo, useState, useMemo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { ComboBox } from \"../../../Common\";\r\nimport { FORM_KEYS } from \"../../../constants\";\r\nimport { getSuburbs } from \"../../../actions\";\r\n\r\nconst ClientSuburb = memo((props) => {\r\n const { value, errorText, onChange, onValidate, disabled, mandatory } = props;\r\n const [data, setData] = useState([]);\r\n const [loading, setLoading] = useState(false);\r\n const search = async (value) => {\r\n if (value.length === 0) {\r\n if (data.length > 0) {\r\n setData([]);\r\n }\r\n } else {\r\n setLoading(true);\r\n\r\n let response, dataSource;\r\n try {\r\n response = await getSuburbs(value);\r\n\r\n dataSource = response.data.map((suburb) => {\r\n return {\r\n geoLocationId: suburb.SuburbId,\r\n postcode: suburb.PostCode,\r\n suburbName: suburb.SuburbName,\r\n state: suburb.State,\r\n };\r\n });\r\n } catch (err) {\r\n // not doing anything here\r\n console.log(\"Failed to load suburb list\");\r\n } finally {\r\n if (dataSource === undefined) dataSource = [];\r\n }\r\n setData(dataSource);\r\n setLoading(false);\r\n }\r\n };\r\n\r\n const handleSearch = (value) => {\r\n onChange(FORM_KEYS.CLIENT_SUBURB, value);\r\n onValidate(FORM_KEYS.CLIENT_SUBURB, value);\r\n search(value);\r\n };\r\n\r\n const handleSelect = (locationId, option) => {\r\n const selectedLocation = data.find((location) => {\r\n return location.geoLocationId + \"\" === locationId + \"\";\r\n });\r\n\r\n if (selectedLocation != null) {\r\n const postcode = selectedLocation.postcode;\r\n onChange(FORM_KEYS.CLIENT_SUBURB, option.text);\r\n onValidate(FORM_KEYS.CLIENT_SUBURB, value);\r\n onChange(FORM_KEYS.CLIENT_POSTCODE, postcode);\r\n onValidate(FORM_KEYS.CLIENT_POSTCODE, postcode);\r\n }\r\n };\r\n\r\n const handleBlur = () => {\r\n onValidate(FORM_KEYS.CLIENT_SUBURB, value);\r\n };\r\n\r\n const options = useMemo(\r\n () =>\r\n data.map((suburb) => {\r\n return {\r\n value: suburb.geoLocationId,\r\n text: `${suburb.suburbName} ${suburb.state}`.trim(),\r\n };\r\n }),\r\n [data]\r\n );\r\n\r\n return (\r\n <ComboBox\r\n label={`Suburb${mandatory ? \" *\" : \"\"}`}\r\n options={options}\r\n onChange={handleSelect}\r\n onSearch={handleSearch}\r\n onBlur={handleBlur}\r\n value={value}\r\n disabled={disabled}\r\n loading={loading}\r\n errorText={errorText}\r\n />\r\n );\r\n});\r\n\r\nClientSuburb.propTypes = {\r\n value: PropTypes.string,\r\n errorText: PropTypes.string,\r\n onChange: PropTypes.func.isRequired,\r\n onValidate: PropTypes.func,\r\n mandatory: PropTypes.bool,\r\n disabled: PropTypes.bool,\r\n};\r\n\r\nexport default ClientSuburb;\r\n","import React, { memo, useState, useMemo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { ComboBox } from \"../../../Common\";\r\nimport { FORM_KEYS } from \"../../../constants\";\r\nimport { getSuburbs } from \"../../../actions\";\r\n\r\nconst ClientPostcode = memo((props) => {\r\n const { value, errorText, onChange, onValidate, disabled, mandatory } = props;\r\n const [data, setData] = useState([]);\r\n const [loading, setLoading] = useState(false);\r\n\r\n const search = async (value) => {\r\n if (value.length === 0) {\r\n if (data.length > 0) {\r\n setData([]);\r\n }\r\n } else {\r\n setLoading(true);\r\n\r\n let response, dataSource;\r\n try {\r\n response = await getSuburbs(value);\r\n\r\n dataSource = response.data.map((suburb) => {\r\n return {\r\n geoLocationId: suburb.SuburbId,\r\n postcode: suburb.PostCode,\r\n suburbName: suburb.SuburbName,\r\n state: suburb.State,\r\n };\r\n });\r\n } catch (err) {\r\n // not doing anything here\r\n console.log(\"Failed to load suburb list\");\r\n } finally {\r\n if (dataSource === undefined) dataSource = [];\r\n }\r\n\r\n setData(dataSource);\r\n setLoading(false);\r\n }\r\n };\r\n\r\n const options = useMemo(\r\n () =>\r\n data.map((suburb) => {\r\n return {\r\n value: suburb.geoLocationId,\r\n text: `${suburb.postcode}`.trim(),\r\n };\r\n }),\r\n [data]\r\n );\r\n\r\n const handleSearch = (value) => {\r\n onChange(FORM_KEYS.CLIENT_POSTCODE, value);\r\n onValidate(FORM_KEYS.CLIENT_POSTCODE, value);\r\n search(value);\r\n };\r\n\r\n const handleSelect = (locationId, option) => {\r\n const selectedLocation = data.find((location) => {\r\n return location.geoLocationId + \"\" === locationId + \"\";\r\n });\r\n if (selectedLocation != null) {\r\n const suburb =\r\n `${selectedLocation.suburbName} ${selectedLocation.state}`.trim();\r\n onChange(FORM_KEYS.CLIENT_POSTCODE, option.text);\r\n onValidate(FORM_KEYS.CLIENT_POSTCODE, value);\r\n onChange(FORM_KEYS.CLIENT_SUBURB, suburb);\r\n onValidate(FORM_KEYS.CLIENT_SUBURB, suburb);\r\n }\r\n };\r\n\r\n const handleBlur = () => {\r\n onValidate(FORM_KEYS.CLIENT_POSTCODE, value);\r\n };\r\n\r\n return (\r\n <ComboBox\r\n label={`Postcode${mandatory ? \" *\" : \"\"}`}\r\n options={options}\r\n onChange={handleSelect}\r\n onSearch={handleSearch}\r\n onBlur={handleBlur}\r\n value={value}\r\n disabled={disabled}\r\n loading={loading}\r\n errorText={errorText}\r\n />\r\n );\r\n});\r\n\r\nClientPostcode.propTypes = {\r\n value: PropTypes.string,\r\n errorText: PropTypes.string,\r\n onChange: PropTypes.func.isRequired,\r\n onValidate: PropTypes.func,\r\n mandatory: PropTypes.bool,\r\n disabled: PropTypes.bool,\r\n};\r\n\r\nexport default ClientPostcode;\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { useDropzone } from \"react-dropzone\";\r\nimport \"./fileUploader.less\";\r\n\r\nconst FileUploader = memo(props => {\r\n const { setFiles, hideFileUploader = false } = props;\r\n const onDrop = acceptedFiles => {\r\n setFiles(acceptedFiles);\r\n };\r\n const { getRootProps, getInputProps } = useDropzone({ onDrop });\r\n\r\n if (hideFileUploader) return null;\r\n\r\n return (\r\n <div className=\"file-upload\" {...getRootProps()}>\r\n <input {...getInputProps()} />\r\n <div className=\"file-upload-content\">\r\n Click or drag files here to upload\r\n <span>(limit of 10MB per file)</span>\r\n </div>\r\n </div>\r\n );\r\n});\r\n\r\nFileUploader.propTypes = {\r\n setFiles: PropTypes.func.isRequired,\r\n hideFileUploader: PropTypes.bool\r\n};\r\n\r\nexport default FileUploader;\r\n","import React, { memo, useState, useEffect } from 'react';\r\nimport Proptypes from 'prop-types';\r\nimport FileUploader from './FileUploader';\r\nimport { CloseIcon, Modal } from '../../../Common';\r\nimport { FORM_KEYS, MAX_FILE_NUMBER } from '../../../constants';\r\n\r\nconst NON_REMOVE_FILE_INDEX = -1;\r\n\r\nconst UploadDocument = memo(props => {\r\n const [removeIndex, setRemoveIndex] = useState(NON_REMOVE_FILE_INDEX);\r\n const [errorText, setErrorText] = useState(undefined);\r\n const { files, setFiles, removeFile, instruction, mandatory, onValidate } =\r\n props;\r\n const hideFileUploader = files.length >= MAX_FILE_NUMBER;\r\n\r\n const resetRemoveIndex = () => {\r\n setRemoveIndex(NON_REMOVE_FILE_INDEX);\r\n if (mandatory && files.length === 1) {\r\n setErrorText(`Please upload a file!`);\r\n }\r\n };\r\n\r\n // eslint-disable-next-line\r\n useEffect(() => {\r\n if (mandatory && files.length < 1) {\r\n onValidate(FORM_KEYS.FILES, `Please upload a file!`);\r\n } else if (!mandatory || files.length > 0) {\r\n onValidate(FORM_KEYS.FILES, ``);\r\n setErrorText(undefined);\r\n }\r\n });\r\n\r\n return (\r\n <div className=\"upload-document-container\">\r\n <h2 className=\"upload-document-title\">\r\n {instruction}\r\n {mandatory ? ' *' : ''}\r\n </h2>\r\n <FileUploader setFiles={setFiles} hideFileUploader={hideFileUploader} />\r\n <ul className=\"upload-file-list\">\r\n {files.map((file, index) => (\r\n <li key={index}>\r\n {file.name}\r\n <CloseIcon\r\n className=\"remove-file-icon\"\r\n onClick={() => setRemoveIndex(index)}\r\n />\r\n </li>\r\n ))}\r\n </ul>\r\n <Modal\r\n open={removeIndex > -1}\r\n message={\r\n <>\r\n <span className=\"remove-file-message-bold-text\">\r\n Are you sure you want to remove{' '}\r\n </span>\r\n {files[removeIndex] ? files[removeIndex].name : ''}\r\n </>\r\n }\r\n onConfirm={() => {\r\n removeFile(removeIndex);\r\n resetRemoveIndex();\r\n }}\r\n onClose={() => {\r\n resetRemoveIndex();\r\n }}\r\n />\r\n {errorText ? (\r\n <div className=\"file-upload-error\">\r\n <CloseIcon /> {errorText}\r\n </div>\r\n ) : (\r\n ``\r\n )}\r\n {mandatory ? (\r\n <div className=\"details-form-item-hint-text\">\r\n * File upload is mandatory\r\n </div>\r\n ) : (\r\n ``\r\n )}\r\n </div>\r\n );\r\n});\r\n\r\nUploadDocument.proptypes = {\r\n files: Proptypes.array.isRequired,\r\n setFiles: Proptypes.func.isRequired,\r\n removeFile: Proptypes.func.isRequired,\r\n instruction: Proptypes.string,\r\n mandatory: Proptypes.boolean,\r\n onValidate: Proptypes.func.isRequired\r\n};\r\n\r\nexport default UploadDocument;\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { useHover } from \"../../../hooks\";\r\nimport { colorStyle } from \"../../../styles\";\r\n\r\nconst IntakeForm = memo(props => {\r\n const { downloadDocumentInstruction, files, downloadFile } = props;\r\n return (\r\n <div className=\"details-form-item\">\r\n <h2 className=\"details-form-item-title\">Download Forms</h2>\r\n <span className=\"details-form-item-text\">\r\n {downloadDocumentInstruction}\r\n </span>\r\n <div className=\"intake-form-list\">\r\n {files.map((file, index) => (\r\n <DownloadFileItem\r\n key={index}\r\n onClick={() => {\r\n downloadFile(file.fileName);\r\n }}\r\n fileName={file.fileName}\r\n />\r\n ))}\r\n </div>\r\n </div>\r\n );\r\n});\r\n\r\nconst DownloadFileItem = memo(props => {\r\n const [hoverRef, isHovered] = useHover();\r\n const { onClick, fileName } = props;\r\n return (\r\n <div\r\n ref={hoverRef}\r\n className=\"intake-form-list-item\"\r\n onClick={onClick}\r\n style={isHovered ? colorStyle : null}\r\n >\r\n {fileName}\r\n </div>\r\n );\r\n});\r\n\r\nDownloadFileItem.propTypes = {\r\n fileName: PropTypes.string.isRequired,\r\n onClick: PropTypes.func\r\n};\r\n\r\nIntakeForm.propTypes = {\r\n downloadDocumentInstruction: PropTypes.string,\r\n files: PropTypes.array\r\n};\r\n\r\nexport default IntakeForm;\r\n","import React, { memo } from 'react';\r\nimport PropTypes from 'prop-types';\r\n\r\nconst ConfirmationPolicy = memo(({ customerConfirmationPolicy }) => {\r\n return (\r\n <div className=\"details-form-item\">\r\n <h2 className=\"details-form-item-title\">Confirmation Policy</h2>\r\n <span className=\"details-form-item-text\">\r\n {customerConfirmationPolicy}\r\n </span>\r\n </div>\r\n );\r\n});\r\n\r\nConfirmationPolicy.propTypes = {\r\n customerConfirmationPolicy: PropTypes.string\r\n};\r\n\r\nConfirmationPolicy.defaultProps = {\r\n customerConfirmationPolicy: ''\r\n};\r\n\r\nexport default ConfirmationPolicy;\r\n","import React, { memo, useCallback } from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport Grid from '@material-ui/core/Grid';\r\nimport MaskedInput from 'react-text-mask';\r\nimport { InputBox, ExpiryMonth } from '../../../Common';\r\nimport { FORM_KEYS } from '../../../constants';\r\n\r\nconst MedicareInformation = memo(props => {\r\n const {\r\n number,\r\n numberError,\r\n expiryDate,\r\n expiryDateError,\r\n onChange,\r\n onValidate\r\n } = props;\r\n\r\n const handleNumberChange = useCallback(\r\n val => {\r\n onChange(FORM_KEYS.MEDICARE_NUMBER, val);\r\n onValidate(FORM_KEYS.MEDICARE_NUMBER, val);\r\n },\r\n [onChange, onValidate]\r\n );\r\n\r\n const handleExpiryChange = useCallback(\r\n val => {\r\n onChange(FORM_KEYS.MEDICARE_EXPIRY, val);\r\n onValidate(FORM_KEYS.MEDICARE_EXPIRY, val);\r\n },\r\n [onChange, onValidate]\r\n );\r\n\r\n const handleBlur = useCallback(() => {\r\n onValidate(FORM_KEYS.MEDICARE_NUMBER, number);\r\n }, [onValidate, number]);\r\n\r\n const handleCloseExpiry = useCallback(() => {\r\n onValidate(FORM_KEYS.MEDICARE_EXPIRY, expiryDate);\r\n }, [onValidate, expiryDate]);\r\n\r\n return (\r\n <div className=\"contact-form-additional narrow-row\">\r\n <h1 className=\"contact-form-additional__title\">Medicare Information</h1>\r\n <Grid container spacing={2} className=\"details-form-item\">\r\n <Grid item xs={8}>\r\n <InputBox\r\n label=\"Medicare Card No\"\r\n errorText={numberError}\r\n value={number || ''}\r\n onChange={handleNumberChange}\r\n onBlur={handleBlur}\r\n InputProps={{\r\n inputComponent: MedicareMaskedInput,\r\n autoComplete: 'new-password'\r\n }}\r\n className=\"medicare-number-input\"\r\n />\r\n </Grid>\r\n <Grid item xs={4}>\r\n <ExpiryMonth\r\n label=\"Expiry\"\r\n value={expiryDate}\r\n errorText={expiryDateError}\r\n onChange={handleExpiryChange}\r\n onClose={handleCloseExpiry}\r\n />\r\n </Grid>\r\n </Grid>\r\n </div>\r\n );\r\n});\r\n\r\nMedicareInformation.propTypes = {\r\n number: PropTypes.string,\r\n numberError: PropTypes.string,\r\n expiryDate: PropTypes.string,\r\n expiryDateError: PropTypes.string,\r\n onChange: PropTypes.func.isRequired,\r\n onValidate: PropTypes.func.isRequired\r\n};\r\n\r\nconst MedicareMaskedInput = memo(props => {\r\n const { inputRef, ...restProps } = props;\r\n return (\r\n <MaskedInput\r\n {...restProps}\r\n ref={ref => {\r\n inputRef(ref ? ref.inputElement : null);\r\n }}\r\n mask={[\r\n /\\d/,\r\n /\\d/,\r\n /\\d/,\r\n /\\d/,\r\n /\\d/,\r\n /\\d/,\r\n /\\d/,\r\n /\\d/,\r\n /\\d/,\r\n /\\d/,\r\n '/',\r\n /\\d/\r\n ]}\r\n />\r\n );\r\n});\r\n\r\nMedicareMaskedInput.propTypes = {\r\n inputRef: PropTypes.func.isRequired\r\n};\r\n\r\nexport default MedicareInformation;\r\n","import React, { memo, useCallback, useMemo } from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport Grid from '@material-ui/core/Grid';\r\nimport Tooltip from '@material-ui/core/Tooltip';\r\nimport { ExpiryMonth, CreditCardIcon, HelpIcon } from '../../../Common';\r\nimport FormInput from './FormInput';\r\nimport { FORM_KEYS } from '../../../constants';\r\nimport { areNotAllCreditCardFieldsFilled } from '../../../helpers';\r\n\r\nconst CreditCard = memo(\r\n ({\r\n name,\r\n number,\r\n expiryDate,\r\n securityCode,\r\n nameError,\r\n numberError,\r\n expiryDateError,\r\n securityCodeError,\r\n onChange,\r\n onValidate,\r\n mandatory\r\n }) => {\r\n const handleExpiryChange = useCallback(\r\n val => {\r\n onChange(FORM_KEYS.CREDIT_CARD_EXPIRY, val);\r\n onValidate(FORM_KEYS.CREDIT_CARD_EXPIRY, val);\r\n },\r\n [onChange, onValidate]\r\n );\r\n\r\n const handleCloseExpiry = useCallback(() => {\r\n onValidate(FORM_KEYS.CREDIT_CARD_EXPIRY, expiryDate);\r\n }, [onValidate, expiryDate]);\r\n\r\n const showError = useMemo(() => {\r\n return areNotAllCreditCardFieldsFilled(\r\n name,\r\n number,\r\n expiryDate,\r\n securityCode\r\n );\r\n }, [name, number, expiryDate, securityCode]);\r\n\r\n return (\r\n <div className=\"contact-form-additional narrow-row\">\r\n <h1 className=\"contact-form-additional__title\">\r\n Credit/Debit Card Details\r\n </h1>\r\n <Grid container spacing={2} className=\"details-form-item\">\r\n <Grid item xs={8}>\r\n <FormInput\r\n formKey={FORM_KEYS.CREDIT_CARD_NUMBER}\r\n label={`Credit/Debit Card No${mandatory ? ' *' : ''}`}\r\n errorText={numberError}\r\n value={number}\r\n onChange={onChange}\r\n onValidate={onValidate}\r\n maxLength={16}\r\n regexRule={/^\\d*$/}\r\n />\r\n <CreditCardIcon className=\"form-input-icon\" />\r\n </Grid>\r\n <Grid item xs={4}>\r\n <ExpiryMonth\r\n label={`Expiry${mandatory ? ' *' : ''}`}\r\n value={expiryDate}\r\n errorText={expiryDateError}\r\n onChange={handleExpiryChange}\r\n onClose={handleCloseExpiry}\r\n />\r\n </Grid>\r\n </Grid>\r\n <Grid container spacing={2} className=\"details-form-item\">\r\n <Grid item xs={8}>\r\n <FormInput\r\n formKey={FORM_KEYS.CREDIT_CARD_NAME}\r\n label={`Cardholder Name${mandatory ? ' *' : ''}`}\r\n errorText={nameError}\r\n value={name}\r\n onChange={onChange}\r\n onValidate={onValidate}\r\n maxLength={100}\r\n />\r\n </Grid>\r\n <Grid item xs={4} className=\"credit-card-security-code\">\r\n <FormInput\r\n formKey={FORM_KEYS.CREDIT_CARD_SECURITY_CODE}\r\n label={`Security Code${mandatory ? ' *' : ''}`}\r\n errorText={securityCodeError}\r\n value={securityCode}\r\n onChange={onChange}\r\n onValidate={onValidate}\r\n regexRule={/^\\d*$/}\r\n maxLength={4}\r\n />\r\n <Tooltip\r\n title=\"Mastercard or Visa: 3 digits on back of your card.\"\r\n placement=\"right-end\"\r\n >\r\n <span>\r\n <HelpIcon className=\"form-input-icon\" />\r\n </span>\r\n </Tooltip>\r\n </Grid>\r\n </Grid>\r\n {showError && !mandatory && (\r\n <div className=\"credit-card-error\">\r\n * Please fill in all fields of the card details\r\n </div>\r\n )}\r\n </div>\r\n );\r\n }\r\n);\r\n\r\nCreditCard.propTypes = {\r\n name: PropTypes.string,\r\n number: PropTypes.string,\r\n expiryDate: PropTypes.string,\r\n securityCode: PropTypes.string,\r\n nameError: PropTypes.string,\r\n numberError: PropTypes.string,\r\n expiryDateError: PropTypes.string,\r\n securityCodeError: PropTypes.string,\r\n onChange: PropTypes.func.isRequired,\r\n onValidate: PropTypes.func.isRequired,\r\n mandatory: PropTypes.bool.isRequired\r\n};\r\n\r\nexport default CreditCard;\r\n","import React, { memo, useCallback } from \"react\";\r\nimport Grid from \"@material-ui/core/Grid\";\r\nimport PropTypes from \"prop-types\";\r\nimport FormInput from \"./FormInput\";\r\nimport DateOfBirth from \"./DateOfBirth\";\r\nimport Comments from \"./Comments\";\r\nimport MedibankFields from \"./MedibankFields\";\r\nimport ClientAddress from \"./ClientAddress\";\r\nimport ClientSuburb from \"./ClientSuburb\";\r\nimport ClientPostcode from \"./ClientPostcode\";\r\nimport UploadDocument from \"./UploadDocument\";\r\nimport IntakeForm from \"./IntakeForm\";\r\nimport ConfirmationPolicy from \"./ConfirmationPolicy\";\r\nimport MedicareInformation from \"./MedicareInformation\";\r\nimport CreditCard from \"./CreditCard\";\r\nimport { FORM_KEYS } from \"../../../constants\";\r\nimport {\r\n validate,\r\n validators,\r\n getCommentsFieldsValidator,\r\n getAddressFieldsValidator,\r\n getMedicareValidator,\r\n getCreditCardValidator,\r\n canSaveCreditCard,\r\n} from \"../../../helpers\";\r\n\r\nexport const PersonalDetailsForm = memo((props) => {\r\n const {\r\n setValue,\r\n setError,\r\n form,\r\n datasource,\r\n config,\r\n setFiles,\r\n removeFile,\r\n downloadFile,\r\n } = props;\r\n\r\n const {\r\n [FORM_KEYS.FIRST_NAME]: firstNameValue,\r\n [FORM_KEYS.MIDDLE_NAME]: middleNameValue,\r\n [FORM_KEYS.PREFERRED_NAME]: preferredNameValue,\r\n [FORM_KEYS.LAST_NAME]: lastNameValue,\r\n [FORM_KEYS.DATE_OF_BIRTH]: birthdayValue,\r\n [FORM_KEYS.MOBILE]: mobileValue,\r\n [FORM_KEYS.EMAIL]: emailValue,\r\n [FORM_KEYS.COMMENTS]: commentsValue,\r\n [FORM_KEYS.CLIENT_ADDRESS]: clientAddressValue,\r\n [FORM_KEYS.CLIENT_SUBURB]: clientSuburbValue,\r\n [FORM_KEYS.CLIENT_POSTCODE]: clientPostcodeValue,\r\n [FORM_KEYS.MEDICARE_NUMBER]: medicareNumber,\r\n [FORM_KEYS.MEDICARE_EXPIRY]: medicareExpiry,\r\n [FORM_KEYS.CREDIT_CARD_NUMBER]: creditCardNumber,\r\n [FORM_KEYS.CREDIT_CARD_EXPIRY]: creditCardExpiry,\r\n [FORM_KEYS.CREDIT_CARD_NAME]: creditCardName,\r\n [FORM_KEYS.CREDIT_CARD_SECURITY_CODE]: creditCardSecurityCode,\r\n [FORM_KEYS.HEALTH_FUND]: healthFundValue,\r\n [FORM_KEYS.CARD_NUMBER]: cardNumberValue,\r\n [FORM_KEYS.CARD_POSITION]: cardPositionValue,\r\n [FORM_KEYS.CUSTOM_FIELDS]: customFieldsValue,\r\n [FORM_KEYS.FILES]: files,\r\n errors,\r\n } = form;\r\n const {\r\n mobileHintDescription,\r\n customerConfirmationPolicy,\r\n tenant,\r\n MedibankFundId,\r\n isCommentsEnabled,\r\n isCommentsMandatory,\r\n isClientAddressMandatory,\r\n isClientAddressEnabled,\r\n isMedicareEnabled,\r\n isUploadDocumentEnabled,\r\n isUploadDocumentMandatory,\r\n uploadDocumentInstruction,\r\n isDownloadDocumentAllowed,\r\n downloadDocumentInstruction,\r\n isCreditCardMandatory,\r\n } = config;\r\n const { healthFunds, customFields, intakeFormFiles } = datasource;\r\n\r\n const showCreditCard = canSaveCreditCard({ config, datasource });\r\n\r\n const handleValidation = useCallback(\r\n (key, value) => {\r\n const errorText = validate(validators[key], value);\r\n const currentError = errors[key];\r\n if (errorText !== currentError) {\r\n setError(key, errorText);\r\n }\r\n },\r\n [setError, errors]\r\n );\r\n\r\n const handleSetAddressValue = (addressKey, value) => {\r\n // clientAddress\r\n setValue(addressKey, value);\r\n if (!value) {\r\n setValue(FORM_KEYS.CLIENT_SUBURB, \"\");\r\n setValue(FORM_KEYS.CLIENT_POSTCODE, \"\");\r\n errors[FORM_KEYS.CLIENT_SUBURB] && setError(FORM_KEYS.CLIENT_SUBURB, \"\");\r\n errors[FORM_KEYS.CLIENT_POSTCODE] &&\r\n setError(FORM_KEYS.CLIENT_POSTCODE, \"\");\r\n }\r\n };\r\n\r\n const handleCommentsFieldsValidation = (key, value) => {\r\n const errorText = validate(\r\n getCommentsFieldsValidator(isCommentsMandatory),\r\n value\r\n );\r\n const currentError = errors[key];\r\n if (errorText !== currentError) {\r\n setError(key, errorText);\r\n }\r\n };\r\n\r\n const handleAddressFieldsValidation = (key, value) => {\r\n const errorText = validate(\r\n getAddressFieldsValidator(\r\n key,\r\n clientAddressValue,\r\n isClientAddressMandatory\r\n ),\r\n value\r\n );\r\n const currentError = errors[key];\r\n if (errorText !== currentError) {\r\n setError(key, errorText);\r\n }\r\n };\r\n\r\n const handleMedicareValidation = (key, value) => {\r\n const primaryKey = key;\r\n const secondaryKey =\r\n key === FORM_KEYS.MEDICARE_NUMBER\r\n ? FORM_KEYS.MEDICARE_EXPIRY\r\n : FORM_KEYS.MEDICARE_NUMBER;\r\n const primaryValue = value;\r\n const secondaryValue = form[secondaryKey];\r\n\r\n const primaryError = validate(\r\n getMedicareValidator(primaryKey, {\r\n [primaryKey]: primaryValue,\r\n [secondaryKey]: secondaryValue,\r\n }),\r\n primaryValue\r\n );\r\n const currentPrimaryError = errors[primaryKey];\r\n if (primaryError !== currentPrimaryError) {\r\n setError(primaryKey, primaryError);\r\n }\r\n\r\n if (!primaryError) {\r\n const secondError = validate(\r\n getMedicareValidator(secondaryKey, {\r\n [primaryKey]: primaryValue,\r\n [secondaryKey]: secondaryValue,\r\n }),\r\n secondaryValue\r\n );\r\n\r\n const currentSecondaryError = errors[secondaryKey];\r\n if (secondError !== currentSecondaryError) {\r\n setError(secondaryKey, secondError);\r\n }\r\n }\r\n };\r\n\r\n const handleCreditCardValidation = (key, value) => {\r\n const errorText = validate(\r\n getCreditCardValidator(key, isCreditCardMandatory),\r\n value\r\n );\r\n const currentError = errors[key];\r\n if (errorText !== currentError) {\r\n setError(key, errorText);\r\n }\r\n };\r\n\r\n const handleMandatoryDocumentValidation = (key, value) => {\r\n const currentError = errors[key];\r\n const errorText =\r\n isUploadDocumentEnabled && isUploadDocumentMandatory ? value : \"\";\r\n\r\n if (errorText !== currentError) {\r\n setError(key, errorText);\r\n }\r\n };\r\n\r\n return (\r\n <div className=\"details-form-container\">\r\n <div className=\"details-form-item\">\r\n <FormInput\r\n formKey={FORM_KEYS.FIRST_NAME}\r\n label=\"First Name *\"\r\n value={firstNameValue}\r\n errorText={errors[FORM_KEYS.FIRST_NAME]}\r\n onChange={setValue}\r\n onValidate={handleValidation}\r\n maxLength={50}\r\n />\r\n </div>\r\n <div className=\"details-form-item\">\r\n <FormInput\r\n formKey={FORM_KEYS.MIDDLE_NAME}\r\n label=\"Middle Name\"\r\n value={middleNameValue}\r\n errorText={errors[FORM_KEYS.MIDDLE_NAME]}\r\n onChange={setValue}\r\n onValidate={handleValidation}\r\n maxLength={50}\r\n />\r\n </div>\r\n <div className=\"details-form-item\">\r\n <FormInput\r\n formKey={FORM_KEYS.LAST_NAME}\r\n label=\"Last Name *\"\r\n value={lastNameValue}\r\n errorText={errors[FORM_KEYS.LAST_NAME]}\r\n onChange={setValue}\r\n onValidate={handleValidation}\r\n maxLength={50}\r\n />\r\n </div>\r\n <div className=\"details-form-item\">\r\n <FormInput\r\n formKey={FORM_KEYS.PREFERRED_NAME}\r\n label=\"Preferred Name\"\r\n value={preferredNameValue}\r\n errorText={errors[FORM_KEYS.PREFERRED_NAME]}\r\n onChange={setValue}\r\n onValidate={handleValidation}\r\n maxLength={50}\r\n />\r\n </div>\r\n <div className=\"details-form-item date-of-birth\">\r\n <DateOfBirth\r\n formKey={FORM_KEYS.DATE_OF_BIRTH}\r\n value={birthdayValue}\r\n errorText={errors[FORM_KEYS.DATE_OF_BIRTH]}\r\n onChange={setValue}\r\n onValidate={handleValidation}\r\n />\r\n </div>\r\n <div className=\"details-form-item\">\r\n <FormInput\r\n formKey={FORM_KEYS.EMAIL}\r\n label=\"Your email *\"\r\n value={emailValue}\r\n errorText={errors[FORM_KEYS.EMAIL]}\r\n onChange={setValue}\r\n onValidate={handleValidation}\r\n />\r\n <span\r\n className={`details-form-item-hint-text ${\r\n errors[FORM_KEYS.EMAIL] ? \"hasError\" : \"\"\r\n }`}\r\n >\r\n * we will send you a booking confirmation to your email address\r\n provided\r\n </span>\r\n </div>\r\n <div className=\"details-form-item\">\r\n <FormInput\r\n formKey={FORM_KEYS.MOBILE}\r\n label=\"Your mobile number *\"\r\n value={mobileValue}\r\n errorText={errors[FORM_KEYS.MOBILE]}\r\n onChange={setValue}\r\n onValidate={handleValidation}\r\n />\r\n <span\r\n className={`details-form-item-hint-text ${\r\n errors[FORM_KEYS.MOBILE] ? \"hasError\" : \"\"\r\n }`}\r\n >\r\n {mobileHintDescription}\r\n </span>\r\n </div>\r\n\r\n <MedibankFields\r\n tenant={tenant}\r\n MedibankFundId={MedibankFundId}\r\n healthFundValue={healthFundValue}\r\n healthFunds={healthFunds}\r\n cardNumberValue={cardNumberValue}\r\n cardPositionValue={cardPositionValue}\r\n customFieldsValue={customFieldsValue}\r\n customFields={customFields}\r\n setValue={setValue}\r\n onValidate={handleValidation}\r\n />\r\n\r\n {isClientAddressEnabled && (\r\n <Grid container spacing={2} className=\"details-form-item\">\r\n <Grid item xs={12}>\r\n <ClientAddress\r\n value={clientAddressValue}\r\n errorText={errors[FORM_KEYS.CLIENT_ADDRESS]}\r\n onChange={handleSetAddressValue}\r\n onValidate={handleAddressFieldsValidation}\r\n mandatory={isClientAddressMandatory}\r\n />\r\n </Grid>\r\n <Grid item xs={8}>\r\n <ClientSuburb\r\n value={clientSuburbValue}\r\n onChange={setValue}\r\n onValidate={handleAddressFieldsValidation}\r\n mandatory={isClientAddressMandatory || !!clientAddressValue}\r\n disabled={!clientAddressValue}\r\n errorText={errors[FORM_KEYS.CLIENT_SUBURB]}\r\n />\r\n </Grid>\r\n <Grid item xs={4}>\r\n <ClientPostcode\r\n value={clientPostcodeValue}\r\n onChange={setValue}\r\n onValidate={handleAddressFieldsValidation}\r\n mandatory={isClientAddressMandatory || !!clientAddressValue}\r\n disabled={!clientAddressValue}\r\n errorText={errors[FORM_KEYS.CLIENT_POSTCODE]}\r\n />\r\n </Grid>\r\n </Grid>\r\n )}\r\n\r\n {isCommentsEnabled && (\r\n <Comments\r\n value={commentsValue}\r\n errorText={errors[FORM_KEYS.COMMENTS]}\r\n onChange={setValue}\r\n onValidate={handleCommentsFieldsValidation}\r\n mandatory={isCommentsMandatory}\r\n />\r\n )}\r\n\r\n {isMedicareEnabled && (\r\n <MedicareInformation\r\n number={medicareNumber}\r\n numberError={errors[FORM_KEYS.MEDICARE_NUMBER]}\r\n expiryDate={medicareExpiry}\r\n expiryDateError={errors[FORM_KEYS.MEDICARE_EXPIRY]}\r\n onChange={setValue}\r\n onValidate={handleMedicareValidation}\r\n />\r\n )}\r\n\r\n {showCreditCard && (\r\n <CreditCard\r\n name={creditCardName}\r\n number={creditCardNumber}\r\n expiryDate={creditCardExpiry}\r\n securityCode={creditCardSecurityCode}\r\n nameError={errors[FORM_KEYS.CREDIT_CARD_NAME]}\r\n numberError={errors[FORM_KEYS.CREDIT_CARD_NUMBER]}\r\n expiryDateError={errors[FORM_KEYS.CREDIT_CARD_EXPIRY]}\r\n securityCodeError={errors[FORM_KEYS.CREDIT_CARD_SECURITY_CODE]}\r\n onChange={setValue}\r\n onValidate={handleCreditCardValidation}\r\n mandatory={isCreditCardMandatory}\r\n />\r\n )}\r\n\r\n {isUploadDocumentEnabled && (\r\n <UploadDocument\r\n files={files}\r\n instruction={uploadDocumentInstruction}\r\n setFiles={setFiles}\r\n removeFile={removeFile}\r\n mandatory={isUploadDocumentMandatory}\r\n onValidate={handleMandatoryDocumentValidation}\r\n />\r\n )}\r\n\r\n {isDownloadDocumentAllowed && (\r\n <IntakeForm\r\n downloadDocumentInstruction={downloadDocumentInstruction}\r\n files={intakeFormFiles}\r\n downloadFile={downloadFile}\r\n />\r\n )}\r\n\r\n <ConfirmationPolicy\r\n customerConfirmationPolicy={customerConfirmationPolicy}\r\n />\r\n </div>\r\n );\r\n});\r\n\r\nPersonalDetailsForm.propTypes = {\r\n setValue: PropTypes.func.isRequired,\r\n setError: PropTypes.func.isRequired,\r\n form: PropTypes.object.isRequired,\r\n config: PropTypes.object.isRequired,\r\n datasource: PropTypes.object.isRequired,\r\n};\r\n","import React, { memo, useMemo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { MaterialUIIcon, EditIcon } from \"../../../Common/Icon\";\r\nimport { colorStyle } from \"../../../styles\";\r\nimport { useHover } from \"../../../hooks\";\r\n\r\nexport const SummaryListItem = memo(props => {\r\n const [hoverRef, isHovered] = useHover();\r\n const { text, iconKey, stepKey, onClick, notClickable } = props;\r\n const renderIcon = useMemo(() => {\r\n return !notClickable && isHovered ? (\r\n <EditIcon style={colorStyle} />\r\n ) : (\r\n <MaterialUIIcon iconKey={iconKey} style={colorStyle} />\r\n );\r\n }, [isHovered, iconKey, notClickable]);\r\n\r\n const color = useMemo(() => {\r\n return !notClickable && isHovered ? colorStyle : null;\r\n }, [isHovered, notClickable]);\r\n return (\r\n <span\r\n className=\"summary-list-item\"\r\n ref={hoverRef}\r\n style={color}\r\n onClick={() => onClick(stepKey)}\r\n >\r\n {renderIcon}\r\n {text}\r\n </span>\r\n );\r\n});\r\n\r\nSummaryListItem.propTypes = {\r\n text: PropTypes.string,\r\n iconKey: PropTypes.string,\r\n stepKey: PropTypes.string.isRequired,\r\n onClick: PropTypes.func.isRequired,\r\n notClickable: PropTypes.bool\r\n};\r\n","import React, { memo } from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport { FullWidthButton, GoogleMap } from '../../../Common';\r\nimport { SummaryListItem } from './SummaryListItem';\r\n\r\nexport const SummaryDesktop = memo(props => {\r\n const {\r\n links,\r\n position,\r\n onClickLink,\r\n onClickButton,\r\n notClickable,\r\n hidingLocationEnabled\r\n } = props;\r\n return (\r\n <div className=\"appointment-summary-desktop\">\r\n <h1 className=\"appointment-summary-desktop-title\">My appointment</h1>\r\n <ul className=\"appointment-summary-desktop-list\">\r\n {links.map(link => {\r\n const { hidden, stepKey, text, iconKey } = link;\r\n if (hidden) return null;\r\n return (\r\n <li key={stepKey}>\r\n <SummaryListItem\r\n stepKey={stepKey}\r\n text={text}\r\n iconKey={iconKey}\r\n onClick={onClickLink}\r\n notClickable={notClickable}\r\n />\r\n </li>\r\n );\r\n })}\r\n </ul>\r\n {hidingLocationEnabled ? (\r\n <div style={{ marginBottom: '30px' }} />\r\n ) : (\r\n <div\r\n className=\"appointment-summary-desktop-map\"\r\n style={notClickable ? { marginBottom: 0 } : null}\r\n >\r\n <GoogleMap zoom={15} position={position} preventTouch={true} />\r\n </div>\r\n )}\r\n {!notClickable && (\r\n <FullWidthButton\r\n className=\"appointment-summary-desktop-button\"\r\n label=\"Edit my appointment\"\r\n onClick={onClickButton}\r\n />\r\n )}\r\n </div>\r\n );\r\n});\r\n\r\nSummaryDesktop.propTypes = {\r\n links: PropTypes.array.isRequired,\r\n position: PropTypes.shape({\r\n lat: PropTypes.number.isRequired,\r\n lng: PropTypes.number.isRequired\r\n }),\r\n onClickLink: PropTypes.func.isRequired,\r\n onClickButton: PropTypes.func.isRequired,\r\n notClickable: PropTypes.bool,\r\n hidingLocationEnabled: PropTypes.bool\r\n};\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { SummaryListItem } from \"./SummaryListItem\";\r\n\r\nexport const SummaryMobile = memo(props => {\r\n const { links, onClickLink, notClickable } = props;\r\n return (\r\n <div className=\"appointment-summary-mobile\">\r\n <h1 className=\"appointment-summary-mobile-title\">My appointment</h1>\r\n <ul className=\"appointment-summary-mobile-list\">\r\n {links.map(link => {\r\n const { hidden, stepKey, text, iconKey } = link;\r\n if (hidden) return null;\r\n return (\r\n <li key={stepKey}>\r\n <SummaryListItem\r\n stepKey={stepKey}\r\n text={text}\r\n iconKey={iconKey}\r\n onClick={onClickLink}\r\n notClickable={notClickable}\r\n />\r\n </li>\r\n );\r\n })}\r\n </ul>\r\n </div>\r\n );\r\n});\r\n\r\nSummaryMobile.propTypes = {\r\n links: PropTypes.array.isRequired,\r\n onClickLink: PropTypes.func.isRequired,\r\n notClickable: PropTypes.bool\r\n};\r\n","import React, { memo, useMemo, useCallback } from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport { SummaryDesktop } from './SummaryDesktop';\r\nimport { SummaryMobile } from './SummaryMobile';\r\nimport {\r\n getSpecialtyTypeAppointmentType,\r\n getLocationTextAndPosition,\r\n getPractitionerText,\r\n getAppointmentDateTimeText,\r\n getHidePractitioner,\r\n getHideSpecialty\r\n} from '../../../helpers';\r\nimport { STEP_KEYS } from '../../../constants';\r\nimport { useCheckMobile } from '../../../hooks';\r\n\r\nexport const AppointmentSummary = memo(props => {\r\n const isMobile = useCheckMobile();\r\n const {\r\n appointment,\r\n config,\r\n datasource,\r\n waitingList,\r\n onClickAppointmentLink,\r\n onClickAppointmentButton,\r\n notClickable = false\r\n } = props;\r\n\r\n const {\r\n [STEP_KEYS.SPECIALTY_TYPE]: specialtyTypeValue,\r\n [STEP_KEYS.APPOINTMENT_TYPE]: appointmentTypeValue,\r\n [STEP_KEYS.PRACTITIONER]: practitionerValue,\r\n [STEP_KEYS.LOCATION]: locationValue,\r\n [STEP_KEYS.APPOINTMENT_DATE_TIME]: appointmentDateTimeValue\r\n } = appointment;\r\n const { locations, practitioners, specialtyTypes, positions } = datasource;\r\n const { specialtyTypeText, appointmentTypeText } = useMemo(\r\n () =>\r\n getSpecialtyTypeAppointmentType(\r\n specialtyTypes,\r\n specialtyTypeValue,\r\n appointmentTypeValue\r\n ),\r\n [specialtyTypes, specialtyTypeValue, appointmentTypeValue]\r\n );\r\n const practitionerText = useMemo(\r\n () => getPractitionerText(practitioners, practitionerValue),\r\n [practitioners, practitionerValue]\r\n );\r\n const { locationText, position } = useMemo(\r\n () => getLocationTextAndPosition(locations, positions, locationValue),\r\n [locations, positions, locationValue]\r\n );\r\n const appointmentDateTimeText = useMemo(\r\n () =>\r\n getAppointmentDateTimeText(\r\n appointmentDateTimeValue,\r\n waitingList.required,\r\n waitingList.preferredTime\r\n ),\r\n [appointmentDateTimeValue, waitingList]\r\n );\r\n const hideSpecialty = useMemo(() => getHideSpecialty(config), [config]);\r\n const hidePractitioner = useMemo(() => getHidePractitioner(config), [config]);\r\n const links = [\r\n {\r\n stepKey: STEP_KEYS.SPECIALTY_TYPE,\r\n text: specialtyTypeText\r\n ? `${specialtyTypeText} ${appointmentTypeText}`\r\n : appointmentTypeText,\r\n iconKey: 'local_hospital',\r\n hidden: hideSpecialty\r\n },\r\n {\r\n stepKey: STEP_KEYS.PRACTITIONER,\r\n text: practitionerText,\r\n iconKey: 'account_box',\r\n hidden: hidePractitioner\r\n },\r\n {\r\n stepKey: STEP_KEYS.LOCATION,\r\n text: locationText,\r\n iconKey: 'room',\r\n hidden: config.isHidingLocationEnabled\r\n },\r\n {\r\n stepKey: STEP_KEYS.APPOINTMENT_DATE_TIME,\r\n text: appointmentDateTimeText,\r\n iconKey: 'date_range',\r\n hidden: false\r\n }\r\n ];\r\n\r\n const onClickLink = useCallback(\r\n stepKey => {\r\n !notClickable && onClickAppointmentLink(stepKey);\r\n },\r\n [onClickAppointmentLink, notClickable]\r\n );\r\n\r\n if (isMobile) {\r\n return (\r\n <SummaryMobile\r\n links={links}\r\n onClickLink={onClickLink}\r\n notClickable={notClickable}\r\n />\r\n );\r\n }\r\n return (\r\n <SummaryDesktop\r\n links={links}\r\n position={position}\r\n onClickLink={onClickLink}\r\n onClickButton={onClickAppointmentButton}\r\n notClickable={notClickable}\r\n hidingLocationEnabled={config.isHidingLocationEnabled}\r\n />\r\n );\r\n});\r\n\r\nAppointmentSummary.propTypes = {\r\n appointment: PropTypes.object.isRequired,\r\n config: PropTypes.object.isRequired,\r\n datasource: PropTypes.object.isRequired,\r\n onClickAppointmentLink: PropTypes.func.isRequired,\r\n onClickAppointmentButton: PropTypes.func.isRequired,\r\n notClickable: PropTypes.bool\r\n};\r\n","import { FORM_KEYS } from \"../../constants\";\r\nexport const MANDATORY_LIST = [\r\n FORM_KEYS.FIRST_NAME,\r\n FORM_KEYS.LAST_NAME,\r\n FORM_KEYS.DATE_OF_BIRTH,\r\n FORM_KEYS.MOBILE,\r\n FORM_KEYS.EMAIL\r\n];\r\n","import React, { useMemo, useCallback } from 'react';\r\nimport { connect } from 'react-redux';\r\nimport {\r\n PersonalDetailsForm,\r\n AppointmentSummary,\r\n VerificationDrawer\r\n} from './components';\r\nimport { MountedAnimationWrapper } from '../AnimationWrapper';\r\nimport { StepText, TransparentButton, BackTopButton } from '../Common';\r\nimport {\r\n setFormValueByKey,\r\n setFormErrorTextByKey,\r\n setVerifyDrawerOpen,\r\n submitBooking,\r\n sendingVerificationCode,\r\n verifyCode,\r\n onClickPlaceBooking,\r\n goToPage,\r\n goToNextStep,\r\n toggleVisibility,\r\n setFiles,\r\n removeFile,\r\n downloadFile\r\n} from '../actions';\r\nimport { PAGE_KEYS, FORM_KEYS } from '../constants';\r\nimport { MANDATORY_LIST } from './consts';\r\nimport {\r\n validate,\r\n validators,\r\n getCommentsFieldsValidator,\r\n getAddressFieldsValidator,\r\n getCreditCardValidator,\r\n canSaveCreditCard,\r\n getMedicareValidator,\r\n areMedicareInfoValid,\r\n areNotAllCreditCardFieldsFilled\r\n} from '../helpers';\r\nimport './contactForm.less';\r\n\r\nexport const ContactForm = props => {\r\n const {\r\n form,\r\n config,\r\n appointment,\r\n datasource,\r\n waitingList,\r\n steps,\r\n setFormValueByKey,\r\n setFormErrorTextByKey,\r\n setVerifyDrawerOpen,\r\n submitBooking,\r\n sendingVerificationCode,\r\n verifyCode,\r\n onClickPlaceBooking,\r\n goToPage,\r\n goToNextStep,\r\n toggleVisibility,\r\n setFiles,\r\n removeFile,\r\n downloadFile\r\n } = props;\r\n\r\n const {\r\n isCommentsEnabled,\r\n isCommentsMandatory,\r\n isClientAddressEnabled,\r\n isClientAddressMandatory,\r\n isMedicareEnabled,\r\n isCreditCardMandatory\r\n } = config;\r\n\r\n const {\r\n [FORM_KEYS.CLIENT_ADDRESS]: clientAddressValue,\r\n [FORM_KEYS.MEDICARE_NUMBER]: medicareNumberValue,\r\n [FORM_KEYS.MEDICARE_EXPIRY]: medicareExpiryValue,\r\n [FORM_KEYS.CREDIT_CARD_NUMBER]: creditCardNumber,\r\n [FORM_KEYS.CREDIT_CARD_EXPIRY]: creditCardExpiry,\r\n [FORM_KEYS.CREDIT_CARD_NAME]: creditCardName,\r\n [FORM_KEYS.CREDIT_CARD_SECURITY_CODE]: creditCardSecurityCode\r\n } = form;\r\n\r\n const shouldFillingMedicareInfo = useMemo(() => {\r\n return (\r\n isMedicareEnabled &&\r\n !areMedicareInfoValid(medicareNumberValue, medicareExpiryValue)\r\n );\r\n }, [medicareNumberValue, medicareExpiryValue, isMedicareEnabled]);\r\n\r\n const showCreditCard = canSaveCreditCard({ config, datasource });\r\n\r\n const showFillingCreditCardInfo = useMemo(() => {\r\n return (\r\n showCreditCard &&\r\n areNotAllCreditCardFieldsFilled(\r\n creditCardNumber,\r\n creditCardExpiry,\r\n creditCardName,\r\n creditCardSecurityCode\r\n )\r\n );\r\n }, [\r\n creditCardNumber,\r\n creditCardExpiry,\r\n creditCardName,\r\n creditCardSecurityCode,\r\n showCreditCard\r\n ]);\r\n\r\n const customMandatoryList = useMemo(() => {\r\n let mandatoryList = [];\r\n if (isCommentsEnabled && isCommentsMandatory) {\r\n mandatoryList = [...mandatoryList, FORM_KEYS.COMMENTS];\r\n }\r\n if (isClientAddressEnabled) {\r\n if (isClientAddressMandatory) {\r\n mandatoryList = [\r\n ...mandatoryList,\r\n FORM_KEYS.CLIENT_ADDRESS,\r\n FORM_KEYS.CLIENT_SUBURB,\r\n FORM_KEYS.CLIENT_POSTCODE\r\n ];\r\n } else {\r\n mandatoryList = clientAddressValue\r\n ? [\r\n ...mandatoryList,\r\n FORM_KEYS.CLIENT_SUBURB,\r\n FORM_KEYS.CLIENT_POSTCODE\r\n ]\r\n : [...mandatoryList];\r\n }\r\n }\r\n if (shouldFillingMedicareInfo) {\r\n mandatoryList = [\r\n ...mandatoryList,\r\n FORM_KEYS.MEDICARE_NUMBER,\r\n FORM_KEYS.MEDICARE_EXPIRY\r\n ];\r\n }\r\n if (\r\n showCreditCard &&\r\n (isCreditCardMandatory || showFillingCreditCardInfo)\r\n ) {\r\n mandatoryList = [\r\n ...mandatoryList,\r\n FORM_KEYS.CREDIT_CARD_NUMBER,\r\n FORM_KEYS.CREDIT_CARD_EXPIRY,\r\n FORM_KEYS.CREDIT_CARD_NAME,\r\n FORM_KEYS.CREDIT_CARD_SECURITY_CODE\r\n ];\r\n }\r\n return mandatoryList;\r\n }, [\r\n isCommentsEnabled,\r\n isCommentsMandatory,\r\n isClientAddressMandatory,\r\n isClientAddressEnabled,\r\n clientAddressValue,\r\n shouldFillingMedicareInfo,\r\n showCreditCard,\r\n isCreditCardMandatory,\r\n showFillingCreditCardInfo\r\n ]);\r\n\r\n const btnDisabled = useMemo(() => {\r\n const errors = form.errors;\r\n const errorList = Object.keys(errors).filter(key => {\r\n return errors[key];\r\n });\r\n const mandatoryListCheck = MANDATORY_LIST.filter(formKey => !form[formKey]);\r\n const customMandatoryListCheck = customMandatoryList.filter(\r\n formKey => !form[formKey]\r\n );\r\n return (\r\n errorList.length > 0 ||\r\n mandatoryListCheck.length > 0 ||\r\n customMandatoryListCheck.length > 0\r\n );\r\n }, [form, customMandatoryList]);\r\n\r\n const handleClickAppointmentLink = useCallback(\r\n stepKey => {\r\n const index = steps.indexOf(stepKey);\r\n const prevStep = index > 0 ? steps[index - 1] : null;\r\n goToNextStep(prevStep);\r\n setTimeout(() => toggleVisibility(stepKey, true), 500);\r\n goToPage(PAGE_KEYS.BOOKING);\r\n },\r\n [goToPage, goToNextStep, toggleVisibility, steps]\r\n );\r\n\r\n const handleClickBack = useCallback(() => {\r\n goToPage(PAGE_KEYS.BOOKING);\r\n }, [goToPage]);\r\n\r\n const handleClickBooking = useCallback(() => {\r\n if (btnDisabled) {\r\n const { errors } = form;\r\n MANDATORY_LIST.forEach(formKey => {\r\n const errorText = validate(validators[formKey], form[formKey]);\r\n const currentError = errors[formKey];\r\n if (errorText !== currentError) {\r\n setFormErrorTextByKey(formKey, errorText);\r\n }\r\n });\r\n customMandatoryList.forEach(formKey => {\r\n let errorText = '';\r\n if (formKey === FORM_KEYS.COMMENTS) {\r\n errorText = validate(\r\n getCommentsFieldsValidator(isCommentsMandatory),\r\n form[formKey]\r\n );\r\n } else if (\r\n [\r\n FORM_KEYS.CLIENT_ADDRESS,\r\n FORM_KEYS.CLIENT_SUBURB,\r\n FORM_KEYS.CLIENT_POSTCODE\r\n ].includes(formKey)\r\n ) {\r\n errorText = validate(\r\n getAddressFieldsValidator(\r\n formKey,\r\n form[FORM_KEYS.CLIENT_ADDRESS],\r\n isClientAddressMandatory\r\n ),\r\n form[formKey]\r\n );\r\n } else if (\r\n [\r\n FORM_KEYS.CREDIT_CARD_NUMBER,\r\n FORM_KEYS.CREDIT_CARD_EXPIRY,\r\n FORM_KEYS.CREDIT_CARD_NAME,\r\n FORM_KEYS.CREDIT_CARD_SECURITY_CODE\r\n ].includes(formKey)\r\n ) {\r\n errorText = validate(\r\n getCreditCardValidator(formKey, isCreditCardMandatory),\r\n form[formKey]\r\n );\r\n } else if (\r\n [FORM_KEYS.MEDICARE_NUMBER, FORM_KEYS.MEDICARE_EXPIRY].includes(\r\n formKey\r\n )\r\n ) {\r\n errorText = validate(\r\n getMedicareValidator(formKey, {\r\n [FORM_KEYS.MEDICARE_NUMBER]: form[FORM_KEYS.MEDICARE_NUMBER],\r\n [FORM_KEYS.MEDICARE_EXPIRY]: form[FORM_KEYS.MEDICARE_EXPIRY]\r\n }),\r\n form[formKey]\r\n );\r\n }\r\n\r\n const currentError = errors[formKey];\r\n if (errorText !== currentError) {\r\n setFormErrorTextByKey(formKey, errorText);\r\n }\r\n });\r\n } else {\r\n onClickPlaceBooking();\r\n }\r\n }, [\r\n btnDisabled,\r\n form,\r\n setFormErrorTextByKey,\r\n onClickPlaceBooking,\r\n isCommentsMandatory,\r\n isClientAddressMandatory,\r\n customMandatoryList,\r\n isCreditCardMandatory\r\n ]);\r\n\r\n return (\r\n <MountedAnimationWrapper animationClassName=\"contact-form-animation\">\r\n <div className=\"contact-form-container\">\r\n <div className=\"contact-form-summary\">\r\n <AppointmentSummary\r\n config={config}\r\n appointment={appointment}\r\n datasource={datasource}\r\n waitingList={waitingList}\r\n onClickAppointmentLink={handleClickAppointmentLink}\r\n onClickAppointmentButton={handleClickBack}\r\n />\r\n </div>\r\n\r\n <div className=\"contact-form-details\">\r\n <BackTopButton onClick={handleClickBack} />\r\n <h1 className=\"contact-form-title\">Personal Details</h1>\r\n <div className=\"contact-form-step-text\">\r\n <StepText step={2} />\r\n </div>\r\n <PersonalDetailsForm\r\n form={form}\r\n config={config}\r\n datasource={datasource}\r\n setValue={setFormValueByKey}\r\n setError={setFormErrorTextByKey}\r\n setFiles={setFiles}\r\n removeFile={removeFile}\r\n downloadFile={downloadFile}\r\n />\r\n <div className=\"contact-form-btn-container\">\r\n <TransparentButton\r\n isTheme={true}\r\n label={waitingList.required ? 'Confirm' : 'Place booking'} // waiting list\r\n disabled={btnDisabled}\r\n className=\"booking-btn\"\r\n onClick={handleClickBooking}\r\n />\r\n <TransparentButton\r\n className=\"back-btn\"\r\n onClick={handleClickBack}\r\n label=\"Back\"\r\n />\r\n </div>\r\n </div>\r\n <VerificationDrawer\r\n open={form.isVerifyDrawerOpen}\r\n onToggle={setVerifyDrawerOpen}\r\n submitBooking={submitBooking}\r\n sendingVerificationCode={sendingVerificationCode}\r\n verifyCode={verifyCode}\r\n useRecaptcha={config.reCaptchaEnabled}\r\n />\r\n </div>\r\n </MountedAnimationWrapper>\r\n );\r\n};\r\n\r\nexport default connect(\r\n state => {\r\n return {\r\n config: state.config,\r\n appointment: state.appointment,\r\n datasource: state.datasource,\r\n form: state.form,\r\n waitingList: state.waitingList,\r\n steps: state.booking.steps\r\n };\r\n },\r\n {\r\n setFormValueByKey,\r\n setFormErrorTextByKey,\r\n setVerifyDrawerOpen,\r\n submitBooking,\r\n sendingVerificationCode,\r\n verifyCode,\r\n onClickPlaceBooking,\r\n goToPage,\r\n goToNextStep,\r\n toggleVisibility,\r\n setFiles,\r\n removeFile,\r\n downloadFile\r\n }\r\n)(ContactForm);\r\n","import React, { memo } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\n\r\nexport const BookingDetailsItem = memo(props => {\r\n const { name, text } = props;\r\n return (\r\n <div className=\"booking-confirmation-detail\">\r\n <p className=\"booking-confirmation-detail-name\">{name}</p>\r\n <p className=\"booking-confirmation-detail-text\">{text}</p>\r\n </div>\r\n );\r\n});\r\n\r\nBookingDetailsItem.propTypes = {\r\n name: PropTypes.string.isRequired,\r\n text: PropTypes.string\r\n};\r\n","export const getIcsCalendar = appointment => {\r\n const elements = [\r\n ...[\r\n 'BEGIN:VCALENDAR',\r\n 'VERSION:2.0',\r\n 'BEGIN:VEVENT',\r\n 'CLASS:PUBLIC',\r\n 'DESCRIPTION:' + appointment.description,\r\n 'DTSTART;VALUE=DATE:' + appointment.startDateTime,\r\n 'DTEND;VALUE=DATE:' + appointment.endDateTime\r\n ],\r\n appointment.location ? 'LOCATION:' + appointment.location : '',\r\n ...[\r\n 'SUMMARY;LANGUAGE=en-us:' + appointment.title,\r\n 'TRANSP:TRANSPARENT',\r\n 'END:VEVENT',\r\n 'END:VCALENDAR'\r\n ]\r\n ];\r\n\r\n return elements.join('\\n');\r\n};\r\n\r\nexport const getYahooCalendarUrl = appointment => {\r\n let yahooCalendarUrl = 'http://calendar.yahoo.com/?v=60&view=d&type=20';\r\n yahooCalendarUrl += '&title=' + encodeURI(appointment.title);\r\n yahooCalendarUrl +=\r\n '&st=' +\r\n encodeURI(appointment.startDateTime) +\r\n '&et=' +\r\n encodeURI(appointment.endDateTime);\r\n yahooCalendarUrl += '&desc=' + encodeURI(appointment.description);\r\n if (appointment.location) {\r\n yahooCalendarUrl += '&in_loc=' + encodeURI(appointment.location);\r\n }\r\n\r\n return yahooCalendarUrl;\r\n};\r\n\r\nexport const getGoogleCalendarUrl = appointment => {\r\n let googleCalendarUrl =\r\n 'https://www.google.com/calendar/render?action=TEMPLATE';\r\n googleCalendarUrl += '&text=' + encodeURI(appointment.title);\r\n googleCalendarUrl +=\r\n '&dates=' +\r\n encodeURI(appointment.startDateTime) +\r\n '/' +\r\n encodeURI(appointment.endDateTime);\r\n googleCalendarUrl += '&details=' + encodeURI(appointment.description);\r\n if (appointment.location) {\r\n googleCalendarUrl += '&location=' + encodeURI(appointment.location);\r\n }\r\n\r\n return googleCalendarUrl;\r\n};\r\n\r\n// this link is not working.\r\n// export const getMicrosoftCalendarUrl = appointment => {\r\n// var microsoftCalendarUrl =\r\n// \"http://calendar.live.com/calendar/calendar.aspx?rru=addevent\";\r\n// microsoftCalendarUrl += \"&summary=\" + encodeURI(appointment.title);\r\n// microsoftCalendarUrl +=\r\n// \"&dtstart=\" +\r\n// encodeURI(appointment.startDateTime) +\r\n// \"&dtend=\" +\r\n// encodeURI(appointment.endDateTime);\r\n// microsoftCalendarUrl += \"&description=\" + encodeURI(appointment.description);\r\n// microsoftCalendarUrl += \"&location=\" + encodeURI(appointment.location);\r\n\r\n// return microsoftCalendarUrl;\r\n// };\r\n\r\nexport const printConfirmation = () => {\r\n var printContents = document.getElementById('printable').innerHTML;\r\n var popupWin = window.open('', '_blank', 'width=790,height=770');\r\n popupWin.document.open();\r\n popupWin.document.write(\r\n `<head>\r\n <link href=\"https://fonts.googleapis.com/css?family=Roboto:300,400,500,700\" rel=\"stylesheet\" type=\"text/css\">\r\n <style type=\"text/css\">\r\n .booking-confirmation-container {\r\n padding: 100px 15px;\r\n font-size: 14px;\r\n }\r\n .booking-confirmation-title {\r\n font-weight: 400;\r\n font-size: 1.8em;\r\n margin: 0 0 4em;\r\n text-transform: uppercase;\r\n line-height: 1.5em;\r\n text-align: center;\r\n }\r\n .booking-confirmation-content {\r\n display: flex;\r\n justify-content: space-between;\r\n width: 100%;\r\n }\r\n .booking-confirmation-content-item {\r\n width: 50%;\r\n padding: 0 15px;\r\n }\r\n .booking-confirmation-detail {\r\n margin-bottom: 10px;\r\n }\r\n .booking-confirmation-detail-name {\r\n font-size: 1em;\r\n font-weight: 300;\r\n color: #555;\r\n line-height: 1.2em;\r\n }\r\n .booking-confirmation-detail-text {\r\n font-weight: 400;\r\n font-size: 1em;\r\n color: #333;\r\n line-height: 1.5em;\r\n min-height: 1.5em;\r\n }\r\n .gm-bundled-control,\r\n .gm-fullscreen-control {\r\n display: none !important;\r\n }\r\n .google-map-marker-container {\r\n width: 27px;\r\n height: 43px;\r\n overflow: hidden;\r\n position: absolute;\r\n left: -14px;\r\n top: -43px;\r\n z-index: 0;\r\n }\r\n .google-map-marker-container img {\r\n position: absolute;\r\n left: 0px;\r\n top: 0px;\r\n width: 27px;\r\n height: 43px;\r\n user-select: none;\r\n border: 0px;\r\n padding: 0px;\r\n margin: 0px;\r\n max-width: none;\r\n }\r\n .booking-confirmation-map-container {\r\n padding: 15px;\r\n background: #fff;\r\n\r\n }\r\n .google-map-container {\r\n width: 100%;\r\n height: 320px;\r\n background: #aeaeae;\r\n }\r\n </style>\r\n </head>\r\n <body style=\"overflow-x:hidden;\" onload=\"setTimeout(function() {window.print();}, 500);\">\r\n <div class=\"booking-confirmation-container\">\r\n ${printContents}\r\n </div>\r\n </body>\r\n `\r\n );\r\n popupWin.document.close();\r\n};\r\n","import React, { memo, useState, useEffect, useRef } from 'react';\r\nimport fileDownload from 'js-file-download';\r\nimport PropTypes from 'prop-types';\r\nimport Fade from '@material-ui/core/Fade';\r\nimport { useHover } from '../../hooks';\r\nimport { backgroundStyle } from '../../styles';\r\nimport { ThemeColorButton, ArrowDownIcon } from '../../Common';\r\nimport {\r\n getIcsCalendar,\r\n getGoogleCalendarUrl,\r\n getYahooCalendarUrl\r\n} from '../helperFunctions';\r\n\r\nexport const AddToCalendar = memo(props => {\r\n const containerRef = useRef();\r\n const [open, setOpen] = useState(false);\r\n\r\n useEffect(() => {\r\n document.addEventListener('click', handleDocumentClick);\r\n return () => {\r\n document.removeEventListener('click', handleDocumentClick);\r\n };\r\n }, []);\r\n\r\n const handleDocumentClick = e => {\r\n const targetDom = e.target;\r\n if (containerRef.current.contains(targetDom)) {\r\n return;\r\n }\r\n setOpen(false);\r\n };\r\n\r\n const {\r\n title,\r\n description,\r\n location,\r\n startDateTime,\r\n endDateTime,\r\n isHidingLocationEnabled\r\n } = props;\r\n\r\n const calendarAppointment = {\r\n title,\r\n description,\r\n location: isHidingLocationEnabled ? '' : location,\r\n startDateTime,\r\n endDateTime\r\n };\r\n\r\n const handleClick = () => {\r\n setOpen(prev => !prev);\r\n };\r\n\r\n const handleCalendarClick = () => {\r\n const fileName = title.replace(/[^\\w ]+/g, '') + '.ics';\r\n fileDownload(\r\n getIcsCalendar(calendarAppointment),\r\n fileName,\r\n 'application/octet-stream'\r\n );\r\n };\r\n\r\n const renderList = () => {\r\n return (\r\n <ul className=\"add-to-calendar-list\">\r\n <li>\r\n <SpanTagItem onClick={handleCalendarClick} label=\"iCalendar\" />\r\n </li>\r\n <li>\r\n <AtagItem\r\n href={getGoogleCalendarUrl(calendarAppointment)}\r\n label=\"Google Calendar\"\r\n />\r\n </li>\r\n <li>\r\n <SpanTagItem onClick={handleCalendarClick} label=\"Outlook\" />\r\n </li>\r\n <li>\r\n <AtagItem\r\n href={getYahooCalendarUrl(calendarAppointment)}\r\n label=\"Yahoo! Calendar\"\r\n />\r\n </li>\r\n </ul>\r\n );\r\n };\r\n\r\n return (\r\n <div className=\"add-to-calendar\" ref={containerRef}>\r\n <ThemeColorButton\r\n label={\r\n <>\r\n Add to calendar\r\n <ArrowDownIcon\r\n className={`add-to-calendar-btn-icon ${open ? 'open' : ''}`}\r\n />\r\n </>\r\n }\r\n onClick={handleClick}\r\n className=\"add-to-calendar-btn\"\r\n />\r\n <Fade in={open}>{renderList()}</Fade>\r\n </div>\r\n );\r\n});\r\n\r\nAddToCalendar.propTypes = {\r\n title: PropTypes.string.isRequired,\r\n description: PropTypes.string.isRequired,\r\n location: PropTypes.string.isRequired,\r\n startDateTime: PropTypes.string.isRequired,\r\n endDateTime: PropTypes.string.isRequired,\r\n isHidingLocationEnabled: PropTypes.bool.isRequired\r\n};\r\n\r\nconst defaultStyle = {\r\n color: '#333'\r\n};\r\nconst hoverStyle = {\r\n color: '#fff',\r\n ...backgroundStyle\r\n};\r\n\r\nconst AtagItem = memo(props => {\r\n const [hoverRef, isHovered] = useHover();\r\n const { label, href } = props;\r\n return (\r\n <a\r\n ref={hoverRef}\r\n href={href}\r\n target=\"_blank\"\r\n rel=\"noopener noreferrer\"\r\n style={isHovered ? hoverStyle : defaultStyle}\r\n >\r\n {label}\r\n </a>\r\n );\r\n});\r\n\r\nAtagItem.propTypes = {\r\n label: PropTypes.string.isRequired,\r\n href: PropTypes.string.isRequired\r\n};\r\n\r\nconst SpanTagItem = memo(props => {\r\n const [hoverRef, isHovered] = useHover();\r\n const { label, onClick } = props;\r\n return (\r\n <span\r\n ref={hoverRef}\r\n onClick={onClick}\r\n style={isHovered ? hoverStyle : defaultStyle}\r\n >\r\n {label}\r\n </span>\r\n );\r\n});\r\nSpanTagItem.propTypes = {\r\n label: PropTypes.string.isRequired,\r\n onClick: PropTypes.func.isRequired\r\n};\r\n","import React, { useCallback } from 'react';\r\nimport { connect } from 'react-redux';\r\nimport { GoogleMap, TransparentButton } from '../Common';\r\nimport { MountedAnimationWrapper } from '../AnimationWrapper';\r\nimport { BookingDetailsItem, AddToCalendar } from './components';\r\nimport {\r\n getSpecialtyTypeAppointmentType,\r\n getPractitionerText,\r\n getLocationTextAndPosition,\r\n getAppointmentDateTimeText\r\n} from '../helpers';\r\nimport { makeNewBooking, goToPage } from '../actions';\r\nimport { PAGE_KEYS } from '../constants';\r\nimport { printConfirmation } from './helperFunctions';\r\nimport { mapDateToICalDatetimeFormat } from '../helpers';\r\nimport './confirm.less';\r\n\r\nexport const Confirm = props => {\r\n const {\r\n config,\r\n appointment,\r\n datasource,\r\n waitingList,\r\n makeNewBooking,\r\n goToPage\r\n } = props;\r\n const { required, preferredTime } = waitingList;\r\n const { waitingListConfirmationText, isHidingLocationEnabled } = config;\r\n const {\r\n specialtyType,\r\n appointmentType,\r\n practitioner,\r\n location,\r\n appointmentDateTime\r\n } = appointment;\r\n const { specialtyTypes, practitioners, locations, positions } = datasource;\r\n\r\n const headerText = required\r\n ? waitingListConfirmationText\r\n : 'Your appointment has been booked';\r\n\r\n const specialtyTypeAppointmentTypeText = getSpecialtyTypeAppointmentType(\r\n specialtyTypes,\r\n specialtyType,\r\n appointmentType\r\n );\r\n\r\n const { specialtyTypeText, appointmentTypeText } =\r\n specialtyTypeAppointmentTypeText;\r\n\r\n const practitionerText = getPractitionerText(practitioners, practitioner);\r\n\r\n const locationTextAndPosition = getLocationTextAndPosition(\r\n locations,\r\n positions,\r\n location\r\n );\r\n\r\n const { locationText, position } = locationTextAndPosition;\r\n\r\n const appointmentDateTimeText = getAppointmentDateTimeText(\r\n appointmentDateTime,\r\n required,\r\n preferredTime\r\n );\r\n\r\n const appointmentStartTime = appointmentDateTime\r\n ? mapDateToICalDatetimeFormat(appointmentDateTime.startDateTime)\r\n : '';\r\n const appointmentEndTime = appointmentDateTime\r\n ? mapDateToICalDatetimeFormat(appointmentDateTime.endDateTime)\r\n : '';\r\n\r\n const handleClickCancel = useCallback(() => {\r\n goToPage(PAGE_KEYS.CANCELLATION);\r\n }, [goToPage]);\r\n\r\n return (\r\n <MountedAnimationWrapper animationClassName=\"confirm-animation\">\r\n <div className=\"booking-confirmation-container\">\r\n <div id=\"printable\">\r\n <h2 className=\"booking-confirmation-title\">{headerText}</h2>\r\n\r\n <div className=\"booking-confirmation-content\">\r\n {!isHidingLocationEnabled && (\r\n <div className=\"booking-confirmation-content-item\">\r\n <div className=\"booking-confirmation-map-container\">\r\n <GoogleMap position={position} preventTouch={true} />\r\n </div>\r\n </div>\r\n )}\r\n <div className=\"booking-confirmation-content-item\">\r\n <BookingDetailsItem name=\"Service\" text={specialtyTypeText} />\r\n <BookingDetailsItem\r\n name=\"Appointment Type\"\r\n text={appointmentTypeText}\r\n />\r\n <BookingDetailsItem name=\"with\" text={practitionerText} />\r\n {!isHidingLocationEnabled && (\r\n <BookingDetailsItem name=\"Location\" text={locationText} />\r\n )}\r\n <BookingDetailsItem\r\n name=\"Appointment Time\"\r\n text={appointmentDateTimeText}\r\n />\r\n <div style={{ marginTop: 80 }}>\r\n <span\r\n style={{ cursor: 'pointer', textDecoration: 'underline' }}\r\n onClick={handleClickCancel}\r\n >\r\n Cancel my appointment\r\n </span>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div className=\"booking-confirmation-content\">\r\n <div className=\"booking-confirmation-content-item booking-confirmation-calendar\">\r\n <AddToCalendar\r\n title=\"appointment confirmation\"\r\n description=\"appointment confirmation\"\r\n location={locationText}\r\n startDateTime={appointmentStartTime}\r\n endDateTime={appointmentEndTime}\r\n isHidingLocationEnabled={isHidingLocationEnabled}\r\n />\r\n </div>\r\n <div className=\"booking-confirmation-content-item booking-confirmation-buttons\">\r\n <TransparentButton\r\n label=\"Make another booking\"\r\n onClick={makeNewBooking}\r\n />\r\n <TransparentButton label=\"Print\" onClick={printConfirmation} />\r\n </div>\r\n </div>\r\n </div>\r\n </MountedAnimationWrapper>\r\n );\r\n};\r\n\r\nexport default connect(\r\n state => {\r\n return {\r\n config: state.config,\r\n appointment: state.appointment,\r\n waitingList: state.waitingList,\r\n datasource: state.datasource\r\n };\r\n },\r\n { makeNewBooking, goToPage }\r\n)(Confirm);\r\n","import React, { memo, useRef } from \"react\";\r\nimport Radio from \"@material-ui/core/Radio\";\r\nimport RadioGroup from \"@material-ui/core/RadioGroup\";\r\nimport FormControlLabel from \"@material-ui/core/FormControlLabel\";\r\nimport TextField from \"@material-ui/core/TextField\";\r\nimport { CANCELLATION_OTHER_REASON_ID } from \"../../constants\";\r\n\r\nexport const CancellationReasons = memo(props => {\r\n const inputRef = useRef();\r\n const {\r\n reasonId,\r\n setReasonId,\r\n setReasonText,\r\n notes,\r\n setNotes,\r\n cancelReasonList\r\n } = props;\r\n\r\n const handleSelect = e => {\r\n const value = e.target.value;\r\n setReasonId(value);\r\n setReasonText(cancelReasonList.find(x => x.id === value).name);\r\n\r\n if (value === CANCELLATION_OTHER_REASON_ID) {\r\n inputRef.current.focus();\r\n }\r\n };\r\n\r\n const handleCommentsChange = e => {\r\n const value = e.target.value;\r\n setNotes(value);\r\n };\r\n\r\n return (\r\n <div className=\"cancellation-reasons\">\r\n <RadioGroup\r\n aria-label=\"gender\"\r\n name=\"cancellationReason\"\r\n value={reasonId}\r\n onChange={handleSelect}\r\n className=\"cancellation-reasons-radio-group\"\r\n >\r\n {cancelReasonList.map(reason => (\r\n <FormControlLabel\r\n key={reason.id}\r\n value={reason.id}\r\n control={\r\n <Radio color=\"primary\" className=\"cancellation-reasons-radio\" />\r\n }\r\n label={reason.name}\r\n className=\"cancellation-reasons-radio-label\"\r\n />\r\n ))}\r\n </RadioGroup>\r\n <div className=\"cancellation-other-reason\">\r\n <p className=\"cancellation-other-reason-text\">Additional comments</p>\r\n <TextField\r\n inputRef={inputRef}\r\n multiline={true}\r\n rowsMax={4}\r\n rows={4}\r\n inputProps={{ maxLength: 150 }}\r\n value={notes}\r\n onChange={handleCommentsChange}\r\n variant=\"outlined\"\r\n className=\"cancellation-other-reason-input\"\r\n />\r\n </div>\r\n </div>\r\n );\r\n});\r\n","import React, { useState, useEffect } from \"react\";\r\nimport { connect } from \"react-redux\";\r\nimport moment from \"moment\";\r\nimport { MountedAnimationWrapper } from \"../AnimationWrapper\";\r\nimport { BackTopButton, ThemeColorButton } from \"../Common\";\r\nimport { AppointmentSummary } from \"../ContactForm/components/Summary/AppointmentSummary\";\r\nimport { CancellationReasons } from \"./components\";\r\nimport { PAGE_KEYS, CANCELLATION_OTHER_REASON_ID } from \"../constants\";\r\nimport {\r\n setConfig,\r\n selectAppointmentDateTime,\r\n setPractitioners,\r\n selectPractitioner,\r\n setLocations,\r\n selectLocation,\r\n getPositions,\r\n setSpecialtyTypes,\r\n selectAppointmentType,\r\n updateAppointmentCancelled,\r\n goToPage\r\n} from \"../actions\";\r\nimport { loading, showError, showSuccess } from \"../../App/actions\";\r\nimport { portalService } from \"../../../services\";\r\nimport { getAppointmentIdFromUrl } from \"../helpers\";\r\nimport { deepGet } from \"../../../utils\";\r\nimport \"./cancellation.less\";\r\n\r\nconst HAS_APPOINTMENT_ID_IN_URL = getAppointmentIdFromUrl();\r\n\r\nexport const Cancellation = props => {\r\n const [reasonId, setReasonId] = useState(\"\");\r\n const [reasonText, setReasonText] = useState(\"\");\r\n const [notes, setNotes] = useState(\"\");\r\n const [cancelReasonList, setCancelReasonList] = useState([]);\r\n\r\n useEffect(() => {\r\n getCancellationReasons();\r\n if (!!HAS_APPOINTMENT_ID_IN_URL) {\r\n getConfig();\r\n getAppointmentDetails(HAS_APPOINTMENT_ID_IN_URL);\r\n getSpecialties();\r\n }\r\n if (booking.isCancelled) {\r\n showError({\r\n text: \"This appointment has been already cancelled.\",\r\n canDismiss: true\r\n });\r\n }\r\n // eslint-disable-next-line react-hooks/exhaustive-deps\r\n }, []);\r\n\r\n const {\r\n config,\r\n appointment,\r\n datasource,\r\n waitingList,\r\n booking,\r\n goToPage,\r\n loading,\r\n showError,\r\n showSuccess,\r\n setConfig,\r\n selectAppointmentDateTime,\r\n setPractitioners,\r\n selectPractitioner,\r\n setLocations,\r\n selectLocation,\r\n getPositions,\r\n setSpecialtyTypes,\r\n selectAppointmentType,\r\n updateAppointmentCancelled\r\n } = props;\r\n\r\n const getConfig = async () => {\r\n const configResponse = await portalService.getConfig();\r\n const config = configResponse.data;\r\n setConfig(config);\r\n };\r\n\r\n const getSpecialties = async () => {\r\n try {\r\n //loading(true);\r\n const specialtiesResponse = await portalService.getSpecialties();\r\n const { specialtyTypes } = specialtiesResponse.data;\r\n setSpecialtyTypes(specialtyTypes);\r\n } catch (error) {\r\n showError({\r\n text:\r\n \"Failed while getting appointment details. \" + getErrorMessage(error),\r\n canDismiss: true\r\n });\r\n } finally {\r\n //loading(false);\r\n }\r\n };\r\n\r\n const getAppointmentDetails = async () => {\r\n try {\r\n loading(true);\r\n const appointmentResponse = await portalService.getAppointmentById(\r\n HAS_APPOINTMENT_ID_IN_URL\r\n );\r\n const {\r\n appointment,\r\n appointmentType,\r\n location\r\n } = appointmentResponse.data;\r\n const { practitioner } = appointment;\r\n\r\n const startDateTime = moment(\r\n appointment.startDateTime,\r\n \"YYYY-MM-DDTHH:mm:ssZ\"\r\n );\r\n const endDateTime = moment(\r\n appointment.endDateTime,\r\n \"YYYY-MM-DDTHH:mm:ssZ\"\r\n );\r\n\r\n const timeslot = { startDateTime, endDateTime };\r\n selectAppointmentDateTime(timeslot);\r\n\r\n const pracDictionary = [\r\n {\r\n practitionerId: practitioner.practitionerId,\r\n firstName: practitioner.firstName,\r\n lastName: practitioner.lastName\r\n }\r\n ];\r\n setPractitioners(pracDictionary);\r\n selectPractitioner(practitioner.practitionerId);\r\n\r\n getPositions([location]);\r\n\r\n const locDictionary = [\r\n {\r\n locationId: location.locationId,\r\n name: location.name,\r\n streetAddress: location.streetAddress,\r\n suburb: location.suburb\r\n }\r\n ];\r\n setLocations(locDictionary);\r\n selectLocation(location.locationId);\r\n\r\n if (appointmentType) {\r\n selectAppointmentType(appointmentType.appointmentTypeId);\r\n updateAppointmentCancelled(false);\r\n }\r\n\r\n if (appointment.status === \"Cancelled\") {\r\n updateAppointmentCancelled(true);\r\n showError({\r\n text: \"This appointment is already cancelled.\",\r\n canDismiss: true\r\n });\r\n }\r\n } catch (error) {\r\n updateAppointmentCancelled(true);\r\n showError({\r\n text:\r\n \"Failed while getting appointment details. \" + getErrorMessage(error),\r\n canDismiss: true\r\n });\r\n } finally {\r\n loading(false);\r\n }\r\n };\r\n\r\n const getCancellationReasons = async () => {\r\n try {\r\n //loading(true);\r\n const { data } = await portalService.getCancelReasons();\r\n\r\n const reasonListInUI = data.reasons\r\n .sort((a, b) => (a.DisplayOrder > b.DisplayOrder ? 1 : -1))\r\n .filter(reason => reason.Name !== \"Practitioner cancelled\")\r\n .map(reason => {\r\n return reason.Id === CANCELLATION_OTHER_REASON_ID\r\n ? {\r\n id: reason.Id,\r\n name: \"Other (please specify)\",\r\n displayOrder: reason.DisplayOrder\r\n }\r\n : {\r\n id: reason.Id,\r\n name: reason.Name,\r\n displayOrder: reason.DisplayOrder\r\n };\r\n });\r\n\r\n setCancelReasonList(reasonListInUI);\r\n } catch (error) {\r\n showError({\r\n text: \"Failed to load cancellation reasons\",\r\n canDismiss: true\r\n });\r\n } finally {\r\n //loading(false);\r\n }\r\n };\r\n\r\n const getErrorMessage = error => {\r\n return deepGet(\r\n error,\r\n [\"response\", \"data\", \"Message\"],\r\n \"Error occurred during processing your request.\"\r\n );\r\n };\r\n\r\n const handleCancelAppointment = async () => {\r\n if (!booking.appointmentId) return false;\r\n try {\r\n loading(true);\r\n const cancellationReasonId =\r\n !reasonId || reasonId === CANCELLATION_OTHER_REASON_ID\r\n ? CANCELLATION_OTHER_REASON_ID\r\n : reasonId;\r\n const cancellationNotes =\r\n \"Client portal Cancellation | reason: \" +\r\n reasonText +\r\n \" | Additional comments: \" +\r\n notes;\r\n const { data } = await portalService.cancelAppointment({\r\n appointmentId: booking.appointmentId,\r\n cancellationReasonId,\r\n appointmentStartDateTime: appointment.appointmentDateTime.startDateTime,\r\n appointmentEndDateTime: appointment.appointmentDateTime.endDateTime,\r\n notes: cancellationNotes\r\n });\r\n\r\n if (data.status === \"Cancelled\") {\r\n updateAppointmentCancelled(true);\r\n showSuccess({\r\n text: \"Your appointment has been cancelled successfully.\",\r\n canDismiss: true\r\n });\r\n }\r\n } catch (error) {\r\n showError({\r\n text: \"Failed to cancel appointment. \" + getErrorMessage(error),\r\n canDismiss: true\r\n });\r\n } finally {\r\n loading(false);\r\n }\r\n };\r\n\r\n const handleBack = () => {\r\n goToPage(PAGE_KEYS.CONFIRM);\r\n };\r\n\r\n const btnDisabled =\r\n !reasonId ||\r\n (!appointment && !appointment.appointmentDateTime) ||\r\n booking.isCancelled;\r\n\r\n return (\r\n <MountedAnimationWrapper animationClassName=\"cancellation-animation\">\r\n <div className=\"cancellation-container\">\r\n <div className=\"cancellation-content\">\r\n <div className=\"cancellation-content-item summary-item\">\r\n <AppointmentSummary\r\n config={config}\r\n appointment={appointment}\r\n datasource={datasource}\r\n waitingList={waitingList}\r\n onClickAppointmentLink={() => {}}\r\n onClickAppointmentButton={() => {}}\r\n notClickable={true}\r\n />\r\n </div>\r\n <div className=\"cancellation-content-item reason-item\">\r\n <div className=\"cancellation-top-button\">\r\n {!HAS_APPOINTMENT_ID_IN_URL && (\r\n <BackTopButton onClick={handleBack} iconDirection=\"left\" />\r\n )}\r\n </div>\r\n <h2 className=\"cancellation-title\">Cancel my appointment</h2>\r\n <div className=\"cancellation-reasons-container\">\r\n <p className=\"cancellation-reasons-title\">\r\n Why do you want to cancel your appointment?\r\n </p>\r\n <CancellationReasons\r\n reasonId={reasonId}\r\n setReasonId={setReasonId}\r\n setReasonText={setReasonText}\r\n notes={notes}\r\n setNotes={setNotes}\r\n cancelReasonList={cancelReasonList}\r\n />\r\n </div>\r\n <ThemeColorButton\r\n label=\"Cancel appointment\"\r\n onClick={handleCancelAppointment}\r\n disabled={btnDisabled}\r\n className=\"cancel-appointment-btn\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n </MountedAnimationWrapper>\r\n );\r\n};\r\n\r\nexport default connect(\r\n state => {\r\n return {\r\n config: state.config,\r\n appointment: state.appointment,\r\n datasource: state.datasource,\r\n booking: state.booking,\r\n waitingList: state.waitingList\r\n };\r\n },\r\n {\r\n loading,\r\n setConfig,\r\n selectAppointmentDateTime,\r\n setPractitioners,\r\n selectPractitioner,\r\n setLocations,\r\n selectLocation,\r\n getPositions,\r\n setSpecialtyTypes,\r\n selectAppointmentType,\r\n updateAppointmentCancelled,\r\n goToPage,\r\n showError,\r\n showSuccess\r\n }\r\n)(Cancellation);\r\n","import React, { useEffect, useMemo } from 'react';\r\nimport { connect } from 'react-redux';\r\nimport { PageHeader, PoweredBy, ProgressStep } from './Common';\r\nimport BookingPortal from './BookingPortal';\r\nimport ContactForm from './ContactForm';\r\nimport Confirm from './Confirm';\r\nimport Cancellation from './Cancellation';\r\nimport { initialLoad, goToPage, updateAppointmentId } from './actions';\r\nimport { DrawerContextProvider } from './context/DrawerContext';\r\nimport { PAGE_KEYS } from './constants';\r\nimport { createGoogleAnalyticsScriptTag } from '../../utils/googleAnalyticsHelper';\r\nimport { getAppointmentIdFromUrl } from './helpers';\r\n\r\nconst ClientPortal = props => {\r\n const {\r\n config,\r\n booking,\r\n appointment,\r\n initialLoad,\r\n goToPage,\r\n updateAppointmentId\r\n } = props;\r\n const { loadedData } = config;\r\n const { page } = booking;\r\n\r\n useEffect(() => {\r\n const appointmentId = getAppointmentIdFromUrl();\r\n if (appointmentId) {\r\n goToPage(PAGE_KEYS.CANCELLATION);\r\n updateAppointmentId(appointmentId);\r\n } else {\r\n initialLoad();\r\n }\r\n // eslint-disable-next-line react-hooks/exhaustive-deps\r\n }, []);\r\n\r\n useEffect(() => {\r\n if (config.googleAnalyticsCode) {\r\n createGoogleAnalyticsScriptTag(config.googleAnalyticsCode);\r\n }\r\n }, [config.googleAnalyticsCode]);\r\n\r\n const renderPage = useMemo(() => {\r\n switch (page) {\r\n case PAGE_KEYS.BOOKING:\r\n return <BookingPortal />;\r\n\r\n case PAGE_KEYS.CONTACT:\r\n return <ContactForm />;\r\n\r\n case PAGE_KEYS.CONFIRM:\r\n return <Confirm />;\r\n\r\n case PAGE_KEYS.CANCELLATION:\r\n return <Cancellation />;\r\n\r\n default:\r\n return <BookingPortal />;\r\n }\r\n }, [page]);\r\n\r\n const showLeftPanel =\r\n page === PAGE_KEYS.BOOKING || page === PAGE_KEYS.CONTACT;\r\n\r\n return (\r\n <DrawerContextProvider>\r\n <div className=\"client-portal-main\">\r\n <PageHeader\r\n tenant={config.tenant}\r\n displayPhoneNumber={config.displayPhoneNumber}\r\n customerTermsUrl={config.customerTermsUrl}\r\n customerPrivacyPolicyUrl={config.customerPrivacyPolicyUrl}\r\n isLogoOrBusinessName={config.isLogoOrBusinessName}\r\n businessName={config.businessName}\r\n />\r\n <div className=\"container client-portal-content\">\r\n {loadedData && showLeftPanel && (\r\n <div className=\"left-panel\">\r\n <ProgressStep page={page} appointment={appointment} />\r\n </div>\r\n )}\r\n <div\r\n className={`right-panel ${\r\n !showLeftPanel ? 'content-full-width' : ''\r\n }`}\r\n >\r\n {loadedData && renderPage}\r\n </div>\r\n </div>\r\n <PoweredBy />\r\n </div>\r\n </DrawerContextProvider>\r\n );\r\n};\r\n\r\nexport default connect(\r\n state => {\r\n return {\r\n config: state.config,\r\n booking: state.booking,\r\n appointment: state.appointment\r\n };\r\n },\r\n { initialLoad, goToPage, updateAppointmentId }\r\n)(ClientPortal);\r\n","\r\nexport const createGoogleAnalyticsScriptTag = (trackingId) => {\r\n const script1 = document.createElement(\"script\");\r\n \r\n script1.src = \"https://www.googletagmanager.com/gtag/js?id=\" + trackingId;\r\n script1.async = true;\r\n document.head.appendChild(script1);\r\n\r\n const script2 = document.createElement(\"script\"); \r\n script2.innerHTML = `window.dataLayer = window.dataLayer || [];\r\n function gtag(){dataLayer.push(arguments);}\r\n gtag('js', new Date());\r\n \r\n gtag('config', '` + trackingId + `'); \r\n `;\r\n document.head.appendChild(script2);\r\n };\r\n ","import React from \"react\";\r\n//import { HashRouter as Router, Route, Switch } from \"react-router-dom\";\r\nimport App from \"./modules/App\";\r\nimport ClientPortal from \"./modules/ClientPortal\";\r\n\r\nconst Routes = props => {\r\n return (\r\n <App>\r\n <ClientPortal />\r\n </App>\r\n );\r\n};\r\n\r\nexport default Routes;\r\n","import { APP_ACTION } from \"../actions/types\";\r\nconst INITIAL_STATE = {\r\n loading: false,\r\n error: null, //{text: \"error message\", canDismiss: true/false}\r\n success: null,\r\n redirect: \"\"\r\n};\r\n\r\nexport const appReducer = (state = INITIAL_STATE, action) => {\r\n switch (action.type) {\r\n case APP_ACTION.LOADING:\r\n return { ...state, loading: action.payload.loading };\r\n\r\n case APP_ACTION.SHOW_ERROR:\r\n return { ...state, error: action.payload.error, loading: false };\r\n\r\n case APP_ACTION.SHOW_SUCCESS:\r\n return { ...state, success: action.payload.success, loading: false };\r\n\r\n case APP_ACTION.REDIRECT:\r\n return { ...state, redirect: action.payload.path };\r\n\r\n case APP_ACTION.CLEAR:\r\n return { ...state, success: \"\", error: \"\", redirect: \"\" };\r\n\r\n default:\r\n return state;\r\n }\r\n};\r\n","import { APPOINTMENT_ACTION, BOOKING_ACTION } from \"../actions\";\r\nimport { STEP_KEYS } from \"../constants\";\r\n// specialtyTypeId,appointmentTypeId,locationId, timezone, appointmenttime etc...\r\nconst INITIAL_STATE = {\r\n [STEP_KEYS.SPECIALTY_TYPE]: null,\r\n [STEP_KEYS.APPOINTMENT_TYPE]: null,\r\n [STEP_KEYS.PRACTITIONER]: null,\r\n [STEP_KEYS.LOCATION]: null,\r\n [STEP_KEYS.TIMEZONE]: null,\r\n [STEP_KEYS.APPOINTMENT_DATE_TIME]: null,\r\n timeZoneOfLocation: null\r\n};\r\n/** \r\n timeZoneOfLocation is the selected location's time zone Id, we put it as sperate to simplify the logic with selected time zone(phone consult)\r\n*/\r\n\r\nconst clearAppointmentByKeys = (state, action) => {\r\n const { clearSteps } = action.payload;\r\n const clearAppointmentObj = clearSteps.reduce((total, current) => {\r\n return {\r\n ...total,\r\n [current]: null\r\n };\r\n }, {});\r\n\r\n return { ...state, ...clearAppointmentObj };\r\n};\r\n\r\nconst setLocationAndItsTimeZone = (state, action) => {\r\n const { locationId, timeZoneId } = action.payload;\r\n const timeZoneOfLocationData = timeZoneId\r\n ? { timeZoneOfLocation: timeZoneId }\r\n : {};\r\n return {\r\n ...state,\r\n [STEP_KEYS.LOCATION]: locationId,\r\n ...timeZoneOfLocationData\r\n };\r\n};\r\n\r\nexport const appointmentReducer = (state = INITIAL_STATE, action) => {\r\n switch (action.type) {\r\n case APPOINTMENT_ACTION.SET_VALUE:\r\n return { ...state, [action.payload.key]: action.payload.value };\r\n case BOOKING_ACTION.GO_BACK_STEP:\r\n return clearAppointmentByKeys(state, action);\r\n case APPOINTMENT_ACTION.SET_LOCATION:\r\n return setLocationAndItsTimeZone(state, action);\r\n case BOOKING_ACTION.MAKE_NEW_BOOKING:\r\n return INITIAL_STATE;\r\n default:\r\n return state;\r\n }\r\n};\r\n","import { CONFIG_ACTION } from \"../actions\";\r\nconst INITIAL_STATE = {\r\n loadedData: true,\r\n welcomeMessage: \"\",\r\n siteConsultTypes: [],\r\n specialtyHintText: \"I would like to make an appointment for\",\r\n appointmentTypeHintText: \"and this will be\",\r\n practitionerHintText: \"with\",\r\n locationHintText: \"at\",\r\n timezoneHintText: \"during the call I will be in the same time zone as\",\r\n appointmentDateTimeHintText: \"on\",\r\n practitionerFirst: false,\r\n preSelectPractitioner: \"\",\r\n confirmationSmsText: null,\r\n confirmationText: \"\",\r\n customerConfirmationPolicy: \"\",\r\n customerPrivacyPolicyUrl: \"\",\r\n customerTermsUrl: \"\",\r\n displayPhoneNumber: \"\",\r\n earliestBookingTime: 0,\r\n hideSpecialties: false,\r\n logo: null,\r\n logoFileName: null,\r\n mobileHintDescription:\r\n \"* Mobile number required to confirm appointment and inform of any changes to appointment\",\r\n noSlotsPlaceholder: \"[No Slots Available]\",\r\n preSelectSpecialtyType: \"\",\r\n reCaptchaEnabled: false,\r\n tenant: \"\",\r\n waitingListConfirmationText:\r\n \"A member of our team will be in touch with you to follow up your request\",\r\n waitingListEnabled: false,\r\n isLogoOrBusinessName: 0,\r\n businessName: null,\r\n isTimezoneEnabled: false,\r\n isTimezoneMandatory: false,\r\n isClientAddressEnabled: false,\r\n isClientAddressMandatory: false,\r\n isMedicareEnabled: false,\r\n isMedicareMandatory: false,\r\n isCreditCardEnabled: false,\r\n isCreditCardMandatory: false,\r\n isCommentsEnabled: false,\r\n isCommentsMandatory: false,\r\n isHidingLocationEnabled: false,\r\n isUploadDocumentEnabled: false,\r\n isUploadDocumentMandatory: false,\r\n uploadDocumentInstruction: null,\r\n appointmentNotWithinHrs: null,\r\n appointmentNotAfterDays: null,\r\n appointmentMinCancelHrs: null,\r\n isNotifyPractitionerEmails: null,\r\n notifyPractitionerEmails: null,\r\n googleAnalyticsCode: null,\r\n isDownloadDocumentAllowed: false,\r\n downloadDocumentInstruction: null,\r\n};\r\n\r\nexport const configReducer = (state = INITIAL_STATE, action) => {\r\n switch (action.type) {\r\n case CONFIG_ACTION.SET_CONFIG:\r\n return { ...state, ...action.payload };\r\n case CONFIG_ACTION.SET_LOADED_DATA:\r\n return { ...state, loadedData: action.payload };\r\n default:\r\n return state;\r\n }\r\n};\r\n","import { DATASOURCE_ACTION, BOOKING_ACTION } from '../actions';\r\nimport { deepAssign } from '../../../utils';\r\nimport HealthFunds from '../../../jsonData/HealthFunds';\r\nimport CustomFields from '../../../jsonData/CustomFields';\r\n\r\n// import { filterSpecialtiesHavingAppointmentTypes } from \"../helpers\";\r\n// import Specialties from \"../../../jsonData/Specialties\";\r\n// import Practitioners from \"../../../jsonData/Practitioners\";\r\n// import Locations from \"../../../jsonData/Locations\";\r\n// import TimeZones from \"../../../jsonData/LocationTimeZones\";\r\n// import Schedules from \"../../../jsonData/Schedules\";\r\n// import TimeSlots from \"../../../jsonData/TimeSlots\";\r\n\r\n// const INITIAL_STATE = {\r\n// specialtyTypes: filterSpecialtiesHavingAppointmentTypes(\r\n// Specialties.specialtyTypes\r\n// ),\r\n// practitioners: Practitioners.practitioners,\r\n// locations: Locations.locations,\r\n// timeSlots: TimeSlots.timeslots,\r\n// timeZones: TimeZones.locationTimezones,\r\n// schedules: Schedules.schedules,\r\n// positions: {},\r\n// healthFunds: HealthFunds.healthFunds,\r\n// customFields: CustomFields.customFields,\r\n// loadingTimeSlots: false\r\n// };\r\n\r\nconst INITIAL_STATE = {\r\n specialtyTypes: [],\r\n practitioners: [],\r\n locations: [],\r\n timeSlots: [],\r\n timeZones: [],\r\n schedules: [],\r\n positions: {},\r\n healthFunds: HealthFunds.healthFunds,\r\n customFields: CustomFields.customFields,\r\n loadingTimeSlots: false,\r\n intakeFormFiles: [], // intake form files\r\n onlinePaymentToken: null, // pin payment publishable key\r\n onlinePaymentIsTest: true // pin payment test account or not\r\n};\r\n\r\nconst updateDataSource = (state, action) => {\r\n const { key, value } = action.payload;\r\n return { ...state, [key]: value };\r\n};\r\n\r\nconst updateTimeSlots = (state, action) => {\r\n const { timeSlots, concat } = action.payload;\r\n\r\n return {\r\n ...state,\r\n timeSlots: concat ? [...state.timeSlots, ...timeSlots] : timeSlots\r\n };\r\n};\r\n\r\nconst handlePositionLoad = (state, action) => {\r\n const { locationId, position } = action.payload;\r\n return deepAssign(state, position, ['positions', locationId]);\r\n};\r\n\r\nexport const datasourceReducer = (state = INITIAL_STATE, action) => {\r\n switch (action.type) {\r\n case DATASOURCE_ACTION.SET_VALUE:\r\n return updateDataSource(state, action);\r\n case DATASOURCE_ACTION.SET_TIME_SLOTS:\r\n return updateTimeSlots(state, action);\r\n case DATASOURCE_ACTION.SET_POSITION:\r\n return handlePositionLoad(state, action);\r\n case BOOKING_ACTION.MAKE_NEW_BOOKING:\r\n return { ...state, timeSlots: [] };\r\n default:\r\n return state;\r\n }\r\n};\r\n","const healthFunds = {\r\n healthFunds: [\r\n {\r\n value: 'AC4B49B0-FA1E-4B46-BCF8-71459CF7DD9F',\r\n text: 'ACA Health Benefits Fund'\r\n },\r\n {\r\n value: '285B3AD2-28A9-4366-AF89-5ECF2BE6F7F6',\r\n text: 'Australian Health Management Group'\r\n },\r\n {\r\n value: 'F6EE2CEA-F6CE-4834-9DA6-9CE028815943',\r\n text: 'Australian Unity Health Ltd'\r\n },\r\n {\r\n value: 'FC59E503-9599-4677-B0FB-73AAFAAED046',\r\n text: 'BUPA Australia Health'\r\n },\r\n {\r\n value: '27C38FE3-7C32-436F-B735-ADA8C5D9E6B0',\r\n text: 'CBHS Friendly Society'\r\n },\r\n {\r\n value: 'B063881B-6D7F-454D-872F-465CCE644558',\r\n text: 'Central West Health Cover'\r\n },\r\n {\r\n value: 'C93F9080-417A-4859-9288-88AE3FC8E13D',\r\n text: 'Cessnock District Health Benefits Fund Ltd'\r\n },\r\n {\r\n value: '04C105CE-7A0D-4143-B74C-1DADAC83605D',\r\n text: 'CUA Health Limited'\r\n },\r\n {\r\n value: 'A830ABD6-18F2-4AE9-B468-601E2C073CC0',\r\n text: 'Defence Health'\r\n },\r\n {\r\n value: '7EC06B56-F13B-406B-B2BC-61D2A6582045',\r\n text: 'Doctors Health Fund'\r\n },\r\n {\r\n value: 'EB535EA4-CFEF-47A7-B4EC-E8515937F182',\r\n text: 'Druids Friendly Society'\r\n },\r\n {\r\n value: '269E0719-DB74-4166-BA37-DF140B996D31',\r\n text: 'Frank Health Insurance'\r\n },\r\n {\r\n value: '225CCFF8-9099-48FA-A621-DE7C87B95E48',\r\n text: 'GMF Health'\r\n },\r\n {\r\n value: 'F067E86E-9EE9-41D2-878D-68393D04CBDB',\r\n text: 'GMHBA Ltd'\r\n },\r\n {\r\n value: 'E4A5B1A8-9FF2-434E-A1B8-DD89890365B3',\r\n text: 'Grand United Corporate Society'\r\n },\r\n {\r\n value: '8BECBCB0-73AF-423D-86F7-7E8BB222370E',\r\n text: 'GU Health'\r\n },\r\n {\r\n value: 'DFDBFBF1-0EA9-4A3C-A0DA-7031A83D94B6',\r\n text: 'HBA'\r\n },\r\n {\r\n value: 'B287860D-4ECC-4B69-BD4E-BBA0D5B5B155',\r\n text: 'HBF Health Funds Inc'\r\n },\r\n { value: '420DC008-4D88-4E06-A6CB-42F874B04B71', text: 'HCF' },\r\n {\r\n value: '6393CC89-9FB2-4299-AB18-14D89B24BE58',\r\n text: 'Health Care Insurance'\r\n },\r\n {\r\n value: 'CB8E7D47-7A2E-4F30-97DC-E6DBEACCC04E',\r\n text: 'Health Insurance Fund of Australia Limited'\r\n },\r\n {\r\n value: '68E0CC1E-11C1-4950-AC33-6D97F794C545',\r\n text: 'Health Partners'\r\n },\r\n {\r\n value: 'CABB0014-D3BD-4057-97ED-7B7E232177A9',\r\n text: 'health.com.au'\r\n },\r\n {\r\n value: 'FB6388A8-FE43-400A-B5F5-98C02FC8A42C',\r\n text: 'Healthguard Health Benefits (including GMF Health)'\r\n },\r\n {\r\n value: '0BDA8E16-F856-41E9-9A2B-4E23AAF39E45',\r\n text: 'IOOF Health'\r\n },\r\n {\r\n value: '33FC5271-DEF7-44A2-B6B3-57B719F2316A',\r\n text: 'Latrobe Health Services Inc'\r\n },\r\n {\r\n value: '00CB85DA-5223-4CE3-BFEC-BDC9EE2FC482',\r\n text: 'Manchester Unity Australia'\r\n },\r\n {\r\n value: '9C2EC124-8BC0-454E-AF6E-41E3B2ECB47D',\r\n text: 'MBF Australia Ltd'\r\n },\r\n {\r\n value: 'EC9603BF-3AD8-4053-BC62-BF15E78EDE6E',\r\n text: 'MBF Health Pty Ltd'\r\n },\r\n {\r\n value: 'BA5313A2-531B-48D0-A300-8129CAAEB9DE',\r\n text: 'Medibank Private Ltd'\r\n },\r\n {\r\n value: '11E76E9F-0DBD-47A9-B868-7B73DF68E865',\r\n text: 'Mildura District Hospital Fund Ltd'\r\n },\r\n {\r\n value: 'AB464F53-96F1-4FB9-9714-0CC150BAF0E6',\r\n text: 'Mutual Community'\r\n },\r\n {\r\n value: 'F4DDC043-2D97-4210-8A8A-87CFF644B040',\r\n text: 'Navy Health'\r\n },\r\n {\r\n value: 'D1E64F26-8C7E-4240-A43C-65A519C7E956',\r\n text: 'NIB Health Funds Ltd'\r\n },\r\n {\r\n value: 'ED43D492-E46C-4228-9CD3-716FC6075201',\r\n text: 'Onemedifund'\r\n },\r\n {\r\n value: '18564887-E4F0-4FEA-A98E-9805E61B4B6F',\r\n text: 'Peoplecare Health Insurance'\r\n },\r\n {\r\n value: '1FD1F222-0B83-495B-A426-3ADDAF976641',\r\n text: 'Phoenix Health Fund Ltd'\r\n },\r\n {\r\n value: 'D38C0D48-6389-45EC-8A20-8833F5B411F7',\r\n text: 'Police Health'\r\n },\r\n {\r\n value: '51B8008C-36D9-4D24-B2DD-3F93216D0D6F',\r\n text: 'Queensland Country Health Ltd'\r\n },\r\n {\r\n value: 'FF2EC1B6-9590-4EBD-A383-8717DA8C1D1C',\r\n text: 'Reserve Bank Health Fund'\r\n },\r\n {\r\n value: '4BEB4B68-E4B8-4299-9AF4-F318467A9514',\r\n text: 'RT Health Fund Ltd'\r\n },\r\n {\r\n value: '9C161B81-4C6D-4FA9-9EFD-3CE5315A1C60',\r\n text: 'St.LukesHealth'\r\n },\r\n {\r\n value: 'FCF80D55-A3E5-4EFB-9BD5-50FF3DB5FDC1',\r\n text: 'Teachers Federation Health (NSW)'\r\n },\r\n {\r\n value: '2ED3F9B2-845B-42F4-BBBB-93BC8DC47826',\r\n text: 'Teachers Union Health'\r\n },\r\n {\r\n value: '047F4DE7-33D0-4354-9BBB-421E943B4016',\r\n text: 'The Doctors Health Fund Ltd'\r\n },\r\n {\r\n value: '3BAC80E8-D2A4-4A72-A092-1141F8B252D2',\r\n text: 'Transport Friendly Society'\r\n },\r\n {\r\n value: 'A6D398BC-C294-43A3-8929-CA318AB65292',\r\n text: 'Union Shopper Health'\r\n },\r\n {\r\n value: '9E36ECC6-8ABB-4615-B081-8EC34A3FE45D',\r\n text: 'Westfund'\r\n },\r\n {\r\n value: '00000000-0000-0000-0000-000000000000',\r\n text: 'None'\r\n }\r\n ]\r\n};\r\n\r\nexport default healthFunds;\r\n","const customFields = {\r\n customFields: [\r\n {\r\n id: '8CD008AB-0145-45D8-967C-8C0B3627463F',\r\n name: '01. Income Insurance'\r\n },\r\n {\r\n id: 'F28860AC-F58A-4AE8-9F22-66745130D19B',\r\n name: '02. Life Insurance'\r\n },\r\n {\r\n id: '21BFF459-35A0-4E40-86FA-6BD398FDF2D2',\r\n name: '03. Pet Insurance'\r\n },\r\n {\r\n id: '32C7B947-D061-43BC-9122-FC01CA192F47',\r\n name: '04. Travel Insurance'\r\n }\r\n ]\r\n};\r\n\r\nexport default customFields;\r\n","import { BOOKING_ACTION } from '../actions';\r\nimport { STEP_KEYS, PAGE_KEYS } from '../constants';\r\nconst INITIAL_STATE = {\r\n steps: [STEP_KEYS.SPECIALTY_TYPE],\r\n visibilityKey: null,\r\n page: PAGE_KEYS.BOOKING,\r\n appointmentId: null,\r\n isCancelled: false\r\n};\r\n\r\nexport const bookingReducer = (state = INITIAL_STATE, action) => {\r\n switch (action.type) {\r\n case BOOKING_ACTION.SET_VALUE:\r\n return { ...state, [action.payload.key]: action.payload.value };\r\n case BOOKING_ACTION.TOGGLE_VISIBILITY:\r\n return { ...state, visibilityKey: action.payload };\r\n case BOOKING_ACTION.SET_STEP:\r\n case BOOKING_ACTION.GO_BACK_STEP:\r\n return {\r\n ...state,\r\n steps: action.payload.steps\r\n };\r\n case BOOKING_ACTION.GO_TO_PAGE:\r\n return { ...state, page: action.payload };\r\n case BOOKING_ACTION.MAKE_NEW_BOOKING:\r\n return INITIAL_STATE;\r\n default:\r\n return state;\r\n }\r\n};\r\n","import { FORM_ACTION, BOOKING_ACTION } from '../actions';\r\nimport { FORM_KEYS } from '../constants';\r\nimport { deleteElementByIndex } from '../../../utils';\r\n\r\nconst INITIAL_STATE = {\r\n [FORM_KEYS.FIRST_NAME]: '',\r\n [FORM_KEYS.MIDDLE_NAME]: '',\r\n [FORM_KEYS.PREFERRED_NAME]: '',\r\n [FORM_KEYS.LAST_NAME]: '',\r\n [FORM_KEYS.MOBILE]: '',\r\n [FORM_KEYS.EMAIL]: '',\r\n [FORM_KEYS.DATE_OF_BIRTH]: '',\r\n [FORM_KEYS.COMMENTS]: '',\r\n [FORM_KEYS.CLIENT_ADDRESS]: '',\r\n [FORM_KEYS.CLIENT_SUBURB]: '',\r\n [FORM_KEYS.CLIENT_POSTCODE]: '',\r\n [FORM_KEYS.MEDICARE_NUMBER]: '',\r\n [FORM_KEYS.MEDICARE_EXPIRY]: '',\r\n [FORM_KEYS.CREDIT_CARD_NUMBER]: '',\r\n [FORM_KEYS.CREDIT_CARD_EXPIRY]: '',\r\n [FORM_KEYS.CREDIT_CARD_NAME]: '',\r\n [FORM_KEYS.CREDIT_CARD_SECURITY_CODE]: '',\r\n errors: {\r\n [FORM_KEYS.FIRST_NAME]: '',\r\n [FORM_KEYS.MIDDLE_NAME]: '',\r\n [FORM_KEYS.PREFERRED_NAME]: '',\r\n [FORM_KEYS.LAST_NAME]: '',\r\n [FORM_KEYS.MOBILE]: '',\r\n [FORM_KEYS.EMAIL]: '',\r\n [FORM_KEYS.DATE_OF_BIRTH]: '',\r\n [FORM_KEYS.COMMENTS]: '',\r\n [FORM_KEYS.CLIENT_ADDRESS]: '',\r\n [FORM_KEYS.CLIENT_SUBURB]: '',\r\n [FORM_KEYS.CLIENT_POSTCODE]: '',\r\n [FORM_KEYS.MEDICARE_NUMBER]: '',\r\n [FORM_KEYS.MEDICARE_EXPIRY]: '',\r\n [FORM_KEYS.CREDIT_CARD_NUMBER]: '',\r\n [FORM_KEYS.CREDIT_CARD_EXPIRY]: '',\r\n [FORM_KEYS.CREDIT_CARD_NAME]: '',\r\n [FORM_KEYS.CREDIT_CARD_SECURITY_CODE]: ''\r\n },\r\n isVerifyDrawerOpen: false,\r\n [FORM_KEYS.HEALTH_FUND]: null,\r\n [FORM_KEYS.CARD_NUMBER]: null,\r\n [FORM_KEYS.CARD_POSITION]: null,\r\n [FORM_KEYS.CUSTOM_FIELDS]: {},\r\n [FORM_KEYS.FILES]: []\r\n};\r\n\r\n// for testing:\r\nexport const formReducerInitState = INITIAL_STATE;\r\n\r\nconst handleSetError = (state, action) => {\r\n const { key, errorText } = action.payload;\r\n const newError = { ...state.errors, [key]: errorText };\r\n return { ...state, errors: newError };\r\n};\r\n\r\nconst handleToggleVerificationDrawer = (state, action) => {\r\n const open = action.payload;\r\n return {\r\n ...state,\r\n isVerifyDrawerOpen: open\r\n };\r\n};\r\n\r\nconst handleMakeNewBookingForForms = (state, action) => {\r\n const remainingKeys = [\r\n FORM_KEYS.FIRST_NAME,\r\n FORM_KEYS.PREFERRED_NAME,\r\n FORM_KEYS.LAST_NAME,\r\n FORM_KEYS.DATE_OF_BIRTH\r\n ];\r\n const remainingObj = remainingKeys.reduce((total, current) => {\r\n return { ...total, [current]: state[current] };\r\n }, {});\r\n return { ...INITIAL_STATE, ...remainingObj };\r\n};\r\n\r\nconst handleSetFiles = (state, action) => {\r\n const { files } = action.payload;\r\n const newFiles = [...state.files, ...files];\r\n return { ...state, files: newFiles };\r\n};\r\n\r\nconst handleRemoveFile = (state, action) => {\r\n const fileIndex = action.payload;\r\n const filesInStore = [...state.files];\r\n const newFiles = deleteElementByIndex(filesInStore, fileIndex);\r\n return { ...state, files: newFiles };\r\n};\r\n\r\nexport const formReducer = (state = INITIAL_STATE, action) => {\r\n switch (action.type) {\r\n case FORM_ACTION.SET_VALUE:\r\n return { ...state, [action.payload.key]: action.payload.value };\r\n case FORM_ACTION.SET_ERROR:\r\n return handleSetError(state, action);\r\n case FORM_ACTION.TOGGLE_VERIFICATION_DRAWER:\r\n return handleToggleVerificationDrawer(state, action);\r\n case FORM_ACTION.SET_FILES:\r\n return handleSetFiles(state, action);\r\n case FORM_ACTION.REMOVE_FILE:\r\n return handleRemoveFile(state, action);\r\n case BOOKING_ACTION.MAKE_NEW_BOOKING:\r\n return handleMakeNewBookingForForms(state, action);\r\n default:\r\n return state;\r\n }\r\n};\r\n","import { WAITING_LIST_ACTION, BOOKING_ACTION } from \"../actions\";\r\n\r\nconst INITIAL_STATE = {\r\n required: false,\r\n preferredTime: \"\"\r\n};\r\n\r\nconst handleRequireWaitingList = (state, action) => {\r\n const isRequired = action.payload;\r\n let preferredTimeObj = {};\r\n if (isRequired) {\r\n preferredTimeObj = { preferredTime: \"\" };\r\n }\r\n return { ...state, required: isRequired, ...preferredTimeObj };\r\n};\r\n\r\nexport const waitingListReducer = (state = INITIAL_STATE, action) => {\r\n switch (action.type) {\r\n case WAITING_LIST_ACTION.REQUIRE_WAITING_LIST:\r\n return handleRequireWaitingList(state, action);\r\n\r\n case WAITING_LIST_ACTION.UPDATE_PREFERRED_TIME:\r\n return { ...state, preferredTime: action.payload };\r\n\r\n case BOOKING_ACTION.GO_BACK_STEP:\r\n return INITIAL_STATE;\r\n\r\n case BOOKING_ACTION.MAKE_NEW_BOOKING:\r\n return INITIAL_STATE;\r\n\r\n default:\r\n return state;\r\n }\r\n};\r\n","import { combineReducers } from \"redux\";\r\nimport { appReducer } from \"../modules/App/reducers\";\r\nimport {\r\n appointmentReducer,\r\n configReducer,\r\n datasourceReducer,\r\n formReducer,\r\n bookingReducer,\r\n waitingListReducer\r\n} from \"../modules/ClientPortal/reducers\";\r\n\r\nconst rootReducer = combineReducers({\r\n app: appReducer,\r\n appointment: appointmentReducer,\r\n config: configReducer,\r\n datasource: datasourceReducer,\r\n booking: bookingReducer,\r\n waitingList: waitingListReducer,\r\n form: formReducer\r\n});\r\n\r\nexport default rootReducer;\r\n","import { createStore, compose, applyMiddleware } from \"redux\";\r\nimport thunk from \"redux-thunk\";\r\nimport rootReducer from \"./rootReducer\";\r\n\r\nconst composeEnhancers =\r\n process.env.NODE_ENV !== \"production\"\r\n ? window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ || compose\r\n : compose;\r\nconst store = createStore(\r\n rootReducer,\r\n composeEnhancers(applyMiddleware(thunk))\r\n);\r\n\r\nexport default store;\r\n","import React from \"react\";\r\nimport ReactDOM from \"react-dom\";\r\nimport \"core-js/stable\";\r\nimport \"regenerator-runtime/runtime\";\r\nimport { Provider } from \"react-redux\";\r\nimport Routes from \"./routes\";\r\nimport store from \"./store/configureStore\";\r\n\r\nimport \"./assets/app.less\";\r\n\r\nReactDOM.render(\r\n <Provider store={store}>\r\n <Routes></Routes>\r\n </Provider>,\r\n document.getElementById(\"root\")\r\n);\r\n\r\nexport default store;\r\n"],"sourceRoot":""}