{"version":3,"file":"chunk.0e91c1db37dca5b86fa4.js","mappings":"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","sources":["webpack:///./scripts/@practicegenius/react-final-form/effects/handlesInitialErrors.tsx","webpack:///./scripts/@practicegenius/react-final-form/Form.tsx","webpack:///./scripts/@practicegenius/react-final-form/Field.tsx","webpack:///./scripts/apps/earn-points/data/checkIn.ts","webpack:///../../../packages/domain/src/data/serviceBrand.ts","webpack:///./scripts/components/TextHr.tsx","webpack:///./scripts/shared/utils/sharedStyledElements.tsx","webpack:///./scripts/apps/home/screens/SociallyRegisteredModal.tsx","webpack:///./scripts/apps/home/screens/UnregisteredAccountModal.tsx","webpack:///./scripts/apps/home/screens/OrphanedAccountModal.tsx","webpack:///./scripts/apps/home/screens/DeletedPracticeAccountModal.tsx","webpack:///./scripts/apps/home/screens/UnregisteredSocialAccountModal.tsx","webpack:///../../../packages/pg-ui/src/hooks/useCountDown.ts","webpack:///./scripts/apps/home/screens/UserRateLimitedModal.tsx","webpack:///./scripts/apps/home/screens/GenericErrorModal.tsx","webpack:///./scripts/apps/home/screens/RecaptchaFailedModal.tsx","webpack:///../../../packages/pg-ui/src/hooks/makeUseRecaptcha.tsx","webpack:///./scripts/shared/queries/global.ts","webpack:///./scripts/shared/hooks/useRecaptcha.ts","webpack:///./scripts/apps/home/components/VerifyHumanCheckbox.tsx","webpack:///./scripts/apps/home/screens/Login.tsx","webpack:///./scripts/utils/php-js/withSessionErrors.tsx","webpack:///./assets/svg/logos/prh/logo-shimmer.svg","webpack:///./assets/svg/logos/hubbux/logo.svg","webpack:///./assets/svg/logos/culturello/logo.svg","webpack:///./scripts/apps/home/screens/Home.tsx","webpack:///./scripts/apps/home/screens/Home.module.css?752d","webpack:///./assets/BundledImageAsset.ts","webpack:///./scripts/components/screens/FormScreen.tsx","webpack:///./scripts/apps/home/layout.tsx","webpack:///./scripts/apps/home/screens/InvalidResetTokenModal.tsx","webpack:///./scripts/apps/home/screens/ForgotPassword.tsx","webpack:///./scripts/apps/home/screens/PasswordEmailSent.tsx","webpack:///./scripts/apps/home/screens/ForgotPasswordReset.tsx","webpack:///./scripts/apps/home/screens/PasswordResetSuccess.tsx","webpack:///./scripts/apps/home/screens/ForgotUsername.tsx","webpack:///./scripts/apps/home/screens/UsernameEmailSent.tsx","webpack:///./scripts/apps/home/screens/LegacyContactVerificationLanding.tsx","webpack:///../../../packages/pg-ui/src/base/Material/components/MemorableDateInput.tsx","webpack:///./scripts/apps/home/screens/UnauthenticatedCheckIn.tsx","webpack:///./scripts/apps/home/App.tsx","webpack:///./scripts/components/Modal/Modal.tsx","webpack:///./scripts/components/Modal/layout.ts","webpack:///./scripts/components/Modal/ui.tsx","webpack:///./scripts/components/PracticeLogo.tsx","webpack:///./scripts/http/httpClientsJs.ts","webpack:///./scripts/screens/social-auth/lang.ts","webpack:///./scripts/shared/hooks/useActivePractice.ts","webpack:///./scripts/shared/utils/queryParams.tsx","webpack:///../../../packages/domain/src/data/practice.ts","webpack:///../../../packages/domain/src/hooks/usePgForm.tsx","webpack:///../../../packages/pg-animation/src/Template.tsx","webpack:///../../../packages/pg-ui/src/base/Material/components/StyleableBaseComponents.tsx","webpack:///../../../packages/pg-ui/src/hooks/useAppDebugInfo.tsx","webpack:///../../../packages/pg-ui/src/hooks/useSecretMobileUtilityMenu.tsx","webpack:///../../../packages/domain/src/hooks/useTickerAction.ts"],"sourcesContent":["import * as React from 'react';\nimport {Mutator, MutableState} from 'final-form';\nimport {FormSpy} from 'react-final-form';\n\nexport type ErrorList = {\n [x: string]: string;\n};\n\nexport const setSessionErrors: Mutator = (\n [errors]: any,\n state: MutableState\n) => {\n state.formState.submitErrors = errors;\n state.formState.submitFailed = true;\n state.formState.lastSubmittedValues = state.formState.values;\n};\n\nclass InitializeInitialErrors extends React.Component<{\n initialErrors?: ErrorList;\n form: {\n mutators: {\n [x: string]: Function;\n };\n };\n}> {\n componentDidMount() {\n const {\n initialErrors,\n form: {mutators},\n } = this.props;\n\n if (\n initialErrors &&\n Object.keys(initialErrors).length &&\n mutators.setSessionErrors\n ) {\n mutators.setSessionErrors(initialErrors);\n }\n }\n\n render() {\n return null;\n }\n}\n\nexport default (props: {initialErrors?: ErrorList}) => (\n // @ts-ignore\n \n);\n","import * as React from 'react';\nimport {\n Config,\n Decorator,\n Mutator,\n FormState,\n FormSubscription,\n} from 'final-form';\nimport {\n FormRenderProps as FinalFormFormRenderProps,\n Form as FinalFormForm,\n} from 'react-final-form';\nimport {ValidationError} from '../../http/exceptions';\nimport InitializeInitialErrors, {\n setSessionErrors,\n ErrorList,\n} from './effects/handlesInitialErrors';\n\nexport type FormRenderProps = FinalFormFormRenderProps & {\n submitDisabled: boolean;\n combinedErrors: any;\n initialErrors: string[] | undefined | null;\n};\n\ntype FormProps = Config & {\n initialValues?: Record;\n subscription?: FormSubscription;\n decorators?: Decorator[];\n mutators?: {\n [x: string]: Mutator;\n };\n initialErrors?: ErrorList;\n children: React.ReactNode | ((a: FormRenderProps) => React.ReactNode);\n};\n\n/**\n * Given FormRenderProps should we disable submit?\n */\nfunction formRPToDisableSubmit({\n pristine,\n invalid,\n dirtySinceLastSubmit,\n submitting,\n}: {\n pristine?: boolean;\n invalid?: boolean;\n submitting?: boolean;\n dirtySinceLastSubmit?: boolean;\n}): boolean {\n return Boolean(\n (pristine && invalid) || submitting || (invalid && !dirtySinceLastSubmit)\n );\n}\n\n/**\n * Produce relevant form errors considering formState\n */\nfunction formStateToCombinedErrors(formState: FormState): {\n [name: string]: string;\n} {\n return (\n Object.keys({\n ...formState.errors,\n ...formState.submitErrors,\n })\n .map(name => ({\n name,\n message:\n // Give precedence to client-side errors.\n (formState.errors && formState.errors[name]) ||\n // Display server-side errors only when appropriate.\n (!formState.dirtySinceLastSubmit &&\n !formState.submitting &&\n formState.submitErrors &&\n formState.submitErrors[name]),\n }))\n .filter(({message}) => Boolean(message))\n // Turn it into our \"errors, keyed by field name\" object\n .reduce((acc, {name, message}) => ({...acc, [name]: message}), {})\n );\n}\n\n/**\n * Our own, slightly enhanced Form component\n */\nexport function Form({\n children,\n onSubmit,\n initialErrors,\n mutators = {},\n ...otherProps\n}: FormProps) {\n const handleSubmit: typeof onSubmit = React.useCallback(\n async (...args) => {\n try {\n // @ts-ignore\n await onSubmit(...args);\n // Ensure that submitErrors are not accidentally set by a request resolving with an object such as an updated entity\n // submitErrors must be set via throwing ValidationError\n return {};\n } catch (error) {\n // props.onSubmit may throw ValidationError\n // Pipe this through to react-final-form submitErrors\n if (error instanceof ValidationError) {\n return error.errors;\n }\n throw error;\n }\n },\n [onSubmit]\n );\n\n return (\n \n {formRP => (\n
\n {typeof children === 'function'\n ? children({\n ...formRP,\n submitDisabled: formRPToDisableSubmit(formRP),\n combinedErrors: formStateToCombinedErrors(\n formRP.form.getState()\n ),\n // @ts-ignore\n initialErrors: initialErrors\n ? Object.keys(initialErrors || {}).reduce(\n // @ts-ignore\n (acc, key) => [...acc, initialErrors[key]],\n []\n )\n : null,\n })\n : children}\n \n \n )}\n \n );\n}\n","import * as React from 'react';\nimport {\n FieldProps,\n FieldRenderProps as FinalFormFieldRenderProps,\n Field as FinalFormField,\n} from 'react-final-form';\n\ntype FieldError = string;\n\n// same as lib\nexport type FieldRenderProps = {\n input: FinalFormFieldRenderProps['input'];\n meta: {\n /**\n * The relevant field error to display considering formState\n */\n displayError?: FieldError | undefined | null;\n } & FinalFormFieldRenderProps['meta'];\n};\n\n/**\n * Given FieldRenderProps which, if any, error should we display inline?\n */\nfunction fieldRPToError({\n meta: {touched, error, submitError, submitFailed, dirtySinceLastSubmit},\n}: FinalFormFieldRenderProps): FieldError | undefined | null {\n if ((touched || submitFailed) && error) {\n return error;\n }\n\n if (submitFailed && !dirtySinceLastSubmit && submitError) {\n return submitError;\n }\n}\n\ninterface PgFieldProps extends FieldProps {\n children: (rp: FieldRenderProps) => React.ReactNode;\n}\n\n/**\n * Our own, slightly enhanced Field component\n * Use in place of react-final-form Field for consistent behavior\n */\nexport function Field({children, ...otherProps}: PgFieldProps) {\n return (\n \n {fieldRP => {\n const displayError = fieldRPToError(fieldRP);\n return children({\n input: fieldRP.input,\n meta: {\n ...fieldRP.meta,\n displayError,\n },\n });\n }}\n \n );\n}\n\nField.defaultProps = {\n /**\n * Prevent form from deleting values on backspace to empty.\n * Related discussion: https://github.com/final-form/react-final-form/issues/342\n *\n * This prevents the following scenario:\n * 1. Backspace field `some_field` to \"empty\"\n * 2. The `Form.values.some_field` effectively gets deleted\n * 3. Submit form attempting to send `some_field` either as `\"\"` or `null`\n * 4. `some_field` is just not present in the form submission values\n * With this in place, the above scenario would result in `values.some_field * === ''` upon submission.\n */\n parse(value: any) {\n return value || '';\n },\n};\n","import qs from 'qs';\n\nexport type CheckInType = 'qr_code';\n\nexport const parseCheckInType = (str: string): CheckInType | null => {\n switch (str) {\n case 'qr_code':\n return 'qr_code';\n default:\n return null;\n }\n};\n\nexport const parseCheckInDataFromQueryString = (\n queryString: string\n): {\n type: CheckInType;\n id: number;\n} | null => {\n const {checkin: checkinData} = qs.parse(queryString, {\n ignoreQueryPrefix: true,\n });\n\n if (\n !checkinData ||\n Array.isArray(checkinData) ||\n typeof checkinData !== 'object'\n )\n return null;\n\n if (!('type' in checkinData) || !('id' in checkinData)) return null;\n if (\n typeof checkinData.type !== 'string' ||\n typeof checkinData.id !== 'string'\n )\n return null;\n\n const type = parseCheckInType(checkinData.type);\n const id = parseInt(checkinData.id, 10);\n\n if (!type || Number.isNaN(id)) return null;\n\n return {\n type,\n id,\n };\n};\n","export const serviceBrands = [\n 'patientrewardshub',\n 'hubbux',\n 'culturello',\n] as const;\nexport type ServiceBrand = typeof serviceBrands[number];\n\n/**\n * Given a hostname from a URL, get the corresponding ServiceBrand.\n * Fallback to `patientrewardshub` for unknown hosts.\n */\nexport const resolveServiceBrandFromHostname = (\n hostname: string\n): ServiceBrand => {\n const host = hostname.replace(/.*?\\.(.*?)\\..*/, '$1') as\n | 'patientrewardshub'\n | 'hubbux'\n | 'culturello';\n const hostToServiceBrand = {\n patientrewardshub: 'patientrewardshub',\n hubbux: 'hubbux',\n culturello: 'culturello',\n } as const;\n\n return hostToServiceBrand[host] || 'patientrewardshub';\n};\n\n/**\n * If window exists, resolves the ServiceBrand from the hostname given by window.location.hostname\n * Otherwise, falls back to `ServiceBrand.patientrewardshub`.\n */\nexport const inferServiceBrandFromWindow = () =>\n typeof window === 'undefined'\n ? 'patientrewardshub'\n : resolveServiceBrandFromHostname(window.location.hostname);\n","/* eslint-disable @typescript-eslint/no-use-before-define */\nimport {styled} from '@mui/material/styles';\nimport * as React from 'react';\n\nconst Wrapper = styled('div')({\n height: '50px',\n flexDirection: 'row',\n alignItems: 'center',\n flex: 1,\n display: 'flex',\n});\n\nconst Divider = styled('div')({\n height: '1px',\n flex: 1,\n backgroundColor: 'grey',\n});\n\nconst Text = styled('span')({\n margin: '0 15px',\n});\n\nexport function TextHr({children}: {children: React.ReactNode}) {\n return (\n \n \n {children}\n \n \n );\n}\n","import {styled} from '@mui/material/styles';\n\nexport const Title = styled('h3')({\n textAlign: 'center',\n color: '#1e98d9',\n});\n\nexport const Content = styled('p')({\n textAlign: 'center',\n});\n","/* eslint-disable @typescript-eslint/no-use-before-define */\nimport * as React from 'react';\nimport {SocialAuthIntegration} from '@practicegenius/domain/src/data/integrations';\nimport {Modal} from '../../../components/Modal/Modal';\nimport {Content, Title} from '../../../shared/utils/sharedStyledElements';\nimport {SocialLoginButtons} from '../../../components/SitesDotSocialLoginButtons';\n\ntype Props = {\n isOpen: boolean;\n close: () => void;\n message: string;\n socialAccounts: ReadonlyArray;\n onLoginError: React.ComponentProps['onLoginError'];\n};\n\nexport function SociallyRegisteredModal({\n isOpen,\n close,\n message,\n socialAccounts,\n onLoginError,\n}: Props) {\n return (\n \n Social Login\n \n {message}\n
\n
\n To log in with your email or username, add a password to your profile.\n
\n \n
\n );\n}\n","/* eslint-disable @typescript-eslint/no-use-before-define */\nimport * as React from 'react';\nimport {\n Button,\n ButtonWidth,\n} from '@practicegenius/pg-ui/src/base/Material/components/Button';\nimport {Field} from '../../../@practicegenius/react-final-form';\nimport {Modal} from '../../../components/Modal/Modal';\nimport {ModalButtons} from '../../../components/Modal/layout';\nimport {Content, Title} from '../../../shared/utils/sharedStyledElements';\n\nexport const unregisteredAccountMethods = Object.freeze({\n REWARDS_NUMBER: 'rewards_number',\n TEMP_REG_CODE: 'temp_reg_code',\n});\n\nconst unregisteredAccountMethodDescriptions = {\n [unregisteredAccountMethods.REWARDS_NUMBER]: 'Rewards Number',\n [unregisteredAccountMethods.TEMP_REG_CODE]: 'Temporary Registration Code',\n};\n\ntype Props = {\n isOpen: boolean;\n close: () => void;\n methodUsed: typeof unregisteredAccountMethods[keyof typeof unregisteredAccountMethods];\n redirectTo: (loginValue: string) => string;\n};\n\nexport function UnregisteredAccountModal({\n isOpen,\n close,\n methodUsed,\n redirectTo,\n}: Props) {\n return (\n \n Let's finish registering your account\n \n The account associated with this{' '}\n {unregisteredAccountMethodDescriptions[methodUsed]} is not set up.\n
\n Let's finish registering so you can start earning rewards.\n
\n \n \n {/* When this modal is showing, the login value is the rewards card number */}\n \n {({input: {value: data}}) => (\n \n Finish Registering\n \n )}\n \n \n
\n );\n}\n","import * as React from 'react';\nimport {\n Button,\n ButtonWidth,\n} from '@practicegenius/pg-ui/src/base/Material/components/Button';\nimport {Field} from '../../../@practicegenius/react-final-form';\nimport {Modal} from '../../../components/Modal/Modal';\nimport {ModalButtons} from '../../../components/Modal/layout';\nimport {Content, Title} from '../../../shared/utils/sharedStyledElements';\nimport {Link} from '../../../components/Link';\n\ntype Props = {\n isOpen: boolean;\n close: () => void;\n redirectTo: string;\n};\n\nexport function OrphanedAccountModal({isOpen, close, redirectTo}: Props) {\n return (\n \n Account Setup Incomplete\n \n Your account registration is not complete. Please finish the\n registration by inputting your rewards number on the next screen or\n contact us at (800) 560-1469.\n \n \n \n \n {() => (\n \n Finish with rewards number\n \n )}\n \n \n \n );\n}\n","import * as React from 'react';\nimport {\n Button,\n ButtonWidth,\n} from '@practicegenius/pg-ui/src/base/Material/components/Button';\nimport {Modal} from '../../../components/Modal/Modal';\nimport {ModalButtons} from '../../../components/Modal/layout';\nimport {Content, Title} from '../../../shared/utils/sharedStyledElements';\n\ntype Props = {\n isOpen: boolean;\n close: () => void;\n};\n\nexport function DeletedPracticeAccountModal({isOpen, close}: Props) {\n return (\n \n Account not found\n \n We couldn't locate your account in our system. It seems the business\n accidentally deleted your profile. Please get in touch with the business\n to restore your account and regain access to the rewards program.\n \n \n \n \n \n );\n}\n","/* eslint-disable @typescript-eslint/no-use-before-define */\nimport * as React from 'react';\nimport {\n Button,\n ButtonVariant,\n ButtonWidth,\n} from '@practicegenius/pg-ui/src/base/Material/components/Button';\nimport {SocialAuthIntegration} from '@practicegenius/domain/src/data/integrations';\nimport {Modal} from '../../../components/Modal/Modal';\nimport {ModalButtons} from '../../../components/Modal/layout';\nimport {platformLabels} from '../../../screens/social-auth/lang';\nimport ServiceBrand from '../../../utils/ServiceBrand';\nimport {Content, Title} from '../../../shared/utils/sharedStyledElements';\n\ntype Props = {\n isOpen: boolean;\n close: () => void;\n provider: SocialAuthIntegration;\n};\n\nexport function UnregisteredSocialAccountModal({\n isOpen,\n close,\n provider,\n}: Props) {\n return (\n \n {platformLabels[provider]} account not connected\n \n Your {platformLabels[provider]} account is not connected to your{' '}\n {ServiceBrand.lang.hubProduct} account. Log in with your username and\n password. You can connect your {platformLabels[provider]} account in\n your profile settings.\n \n \n \n Log In With Username\n \n \n \n );\n}\n","import React from 'react';\n\n/** Starts a count-down timer from the given number and returns the current time left */\nexport const useCountDown = (\n /** Length of the countdown */\n timeMs: number,\n /** Time between steps */\n tickMs = 1000\n): number => {\n const [timeRemaining, setTimeRemaining] = React.useState(timeMs);\n\n React.useEffect(() => {\n const intervalId = setInterval(() => {\n setTimeRemaining(prevTime => {\n if (prevTime - tickMs <= 0) {\n clearInterval(intervalId);\n return 0;\n }\n\n return prevTime - tickMs;\n });\n }, tickMs);\n }, [tickMs, setTimeRemaining]);\n\n return timeRemaining;\n};\n\nexport const useCountDownSeconds = (\n /** Length of the countdown in seconds */\n timeSeconds: number,\n /** Time between steps in seconds */\n tickSeconds = 1\n): number => {\n const timeMs = useCountDown(timeSeconds * 1000, tickSeconds * 1000);\n return Math.ceil(timeMs / 1000);\n};\n","import * as React from 'react';\nimport pluralize from 'pluralize';\nimport {\n Box,\n Typography,\n Dialog,\n DialogTitle,\n DialogContent,\n DialogActions,\n} from '@mui/material';\nimport {Link} from 'react-router-dom';\nimport {\n Button,\n ButtonVariant,\n ButtonWidth,\n} from '@practicegenius/pg-ui/src/base/Material/components/Button';\nimport {useCountDownSeconds} from '@practicegenius/pg-ui/src/hooks/useCountDown';\nimport {routes} from '../routes';\n\ntype ResponseAction = 'account_paused' | 'help' | 'pause_warning';\n\nconst titles = {\n account_paused: 'Whoops!',\n help: 'Hey There!',\n pause_warning: 'Hold On!',\n};\n\ntype Props = {\n isOpen: boolean;\n close: () => unknown;\n formValues: any;\n responseAction: ResponseAction;\n availableIn: number;\n nextBlockDuration: number;\n};\n\nconst humanizeMinutes = (seconds: number) => {\n const minutes = Math.floor(seconds / 60);\n\n return `${minutes} ${pluralize('minute', minutes)}`;\n};\n\nconst humanizeSeconds = (seconds: number) => {\n if (seconds < 60) {\n return `${seconds} ${pluralize('second', seconds)}`;\n }\n\n if (seconds < 180) {\n return `${humanizeMinutes(seconds)} and ${seconds % 60} ${pluralize(\n 'second',\n seconds\n )}`;\n }\n\n return humanizeMinutes(seconds);\n};\n\nconst HelpContent = (props: Props) => (\n <>\n It looks like you are having trouble logging in. Can we help you out? Use a\n link to recover your username or password.\n \n);\n\nconst PauseWarningContent = (props: Props) => (\n <>\n Something's not quite right. To keep your account safe it will be paused for{' '}\n {humanizeSeconds(props.nextBlockDuration)} after the next\n failed login.\n
\n
\n Don't worry. We can help you recover your username or password. Click a link\n below.\n \n);\n\nconst AccountPausedContent = ({availableIn, close}: Props) => {\n const displaySeconds = useCountDownSeconds(availableIn);\n\n React.useEffect(() => {\n if (displaySeconds <= 0) {\n close();\n }\n }, [displaySeconds, close]);\n\n return (\n <>\n Let's take a step back. To make sure your information is safe, your\n account has been paused for{' '}\n {humanizeSeconds(displaySeconds)}.\n
\n
\n You can try logging in again soon. We can still help you recover your\n username or password. Click a link below.\n \n );\n};\n\nconst messages = {\n help: HelpContent,\n pause_warning: PauseWarningContent,\n account_paused: AccountPausedContent,\n};\n\nexport function UserRateLimitedModal(props: Props) {\n const {isOpen, close, responseAction, formValues} = props;\n\n // eslint-disable-next-line no-prototype-builtins\n const title = titles.hasOwnProperty(responseAction)\n ? titles[responseAction]\n : null;\n // eslint-disable-next-line no-prototype-builtins\n const message = messages.hasOwnProperty(responseAction)\n ? messages[responseAction](props)\n : null;\n\n return (\n \n {title}\n \n {message}\n \n \n \n \n Try Again\n \n \n \n Forgot Username\n \n \n Forgot Password\n \n \n \n );\n}\n","import React from 'react';\nimport DialogTitle from '@mui/material/DialogTitle';\nimport DialogContent from '@mui/material/DialogContent';\nimport DialogActions from '@mui/material/DialogActions';\nimport Dialog from '@mui/material/Dialog';\nimport {\n Button,\n ButtonWidth,\n} from '@practicegenius/pg-ui/src/base/Material/components/Button';\nimport {Link} from '../../../components/Link';\n\nexport function GenericErrorModal({\n open,\n close,\n}: {\n open: boolean;\n close: () => unknown;\n}) {\n return (\n \n It's not you - it's us!\n \n Please give us a call at{' '}\n (800) 560-1469 and we'll help fix\n this unexpected error as soon as possible.\n \n \n \n \n \n );\n}\n","import React from 'react';\nimport {\n Button,\n ButtonWidth,\n} from '@practicegenius/pg-ui/src/base/Material/components/Button';\nimport {Modal} from '../../../components/Modal/Modal';\nimport {ModalButtons} from '../../../components/Modal/layout';\nimport {Content, Title} from '../../../shared/utils/sharedStyledElements';\n\ntype Props = {\n isOpen: boolean;\n close: () => void;\n};\n\nexport function RecaptchaFailedModal({isOpen, close}: Props) {\n return (\n \n Verification Failed\n Refresh the page and try again or use another browser.\n \n \n \n \n );\n}\n","import {Logger} from '@practicegenius/domain/src/common/logger';\nimport {z} from 'zod';\nimport React from 'react';\nimport ReCAPTCHA from 'react-google-recaptcha';\nimport {makeChannelUpdateMessage} from '@practicegenius/domain/src/sites-mobile-app/messages';\nimport {UseMutationResult} from '@tanstack/react-query';\nimport {\n inMobileApp,\n parseAppToSitesMessage,\n postMessageToMobileApp,\n} from '../utils/MobileApp';\nimport {isClient} from '../utils/environment';\nimport {CatastrophicErrorBoundary} from '../components/CatastrophicErrorBoundary';\n\nif (isClient)\n // @ts-expect-error This global is the only way to opt in to enterprise recaptcha 🤦\n window.recaptchaOptions = {\n useRecaptchaNet: true,\n enterprise: true,\n };\n\nexport const recaptchaPlatformSchema = z.enum([\n 'web',\n 'ios',\n 'android',\n 'mobile',\n]);\nexport type RecaptchaPlatform = z.infer;\n\nexport const recaptchaActionSchema = z.enum(['LOGIN']);\nexport type RecaptchaAction = z.infer;\n\ntype RecaptchaHookConfig = {\n logger: Logger;\n /**\n * This mutation is used to setup the session to bypass recaptcha.\n * It is named `syncSession` because this can wind up unobfuscated in client bundles\n * and we don't want to make it that easy to figure out how to bypass our recaptcha setup.\n *\n * If this is used by a mobile client that doesn't support recaptcha, we have to completely bypass the\n * web-based recaptcha check because web recaptcha does not work when rendered in a mobile webview.\n */\n useSyncSession: () => UseMutationResult;\n recaptchaSiteKey?: string;\n};\n\n/** Make the hook that provides recaptcha functionality to the client */\nexport const makeUseRecaptcha =\n ({logger, recaptchaSiteKey, useSyncSession}: RecaptchaHookConfig) =>\n (actionName: string) => {\n const recaptchaRef = React.useRef(null);\n const {mutateAsync: syncSession} = useSyncSession();\n\n // We put this in a ref so we can await it in the getRecaptchaData function just in case the request is slow or the user is super fast\n const supportsRecaptchaRequest = React.useRef>();\n React.useEffect(() => {\n // The promise has to be set in an effect to prvent it from being called multiple times.\n // Directly constructing the promise here will cause it to start immediately.\n supportsRecaptchaRequest.current = new Promise(resolve => {\n if (!inMobileApp) return resolve(true);\n\n postMessageToMobileApp(makeChannelUpdateMessage('generic', true));\n postMessageToMobileApp({\n type: 'supports_feature',\n feature: 'recaptcha',\n });\n\n const handleResponse = (event: MessageEvent) => {\n // an unrelated 'recaptcha-setup' message is sent with a string payload\n // so we need to rule out payloads that can't be JSON.parsed\n const data = parseAppToSitesMessage(event.data);\n if (\n data &&\n data.channel === 'generic' &&\n data.type === 'supports_feature' &&\n data.payload === 'recaptcha'\n ) {\n window.removeEventListener('message', handleResponse);\n return resolve(true);\n }\n };\n\n window.addEventListener('message', handleResponse);\n\n // If we don't get a response from the mobile app, we'll assume that it doesn't support recaptcha\n setTimeout(() => {\n window.removeEventListener('message', handleResponse);\n return resolve(false);\n }, 5000);\n\n return () => {\n window.removeEventListener('message', handleResponse);\n };\n });\n }, []);\n\n return {\n getRecaptchaData: async () => {\n const supportsRecaptcha = await supportsRecaptchaRequest.current;\n return new Promise<{\n recaptchaToken: string;\n platform: RecaptchaPlatform;\n }>(resolve => {\n if (inMobileApp) {\n if (!supportsRecaptcha) {\n return syncSession().then(() => {\n resolve({recaptchaToken: '89120016371', platform: 'mobile'});\n });\n }\n\n postMessageToMobileApp(makeChannelUpdateMessage('recaptcha', true));\n postMessageToMobileApp({\n type: 'request_recaptcha_token',\n payload: {actionName},\n });\n const handleMessage = (event: MessageEvent) => {\n const data = parseAppToSitesMessage(event.data);\n if (\n data &&\n data.channel === 'recaptcha' &&\n data.type === 'receive_recaptcha_token'\n ) {\n const {recaptchaToken, platform} = data.payload;\n resolve({recaptchaToken, platform});\n }\n };\n\n window.addEventListener('message', handleMessage);\n } else {\n const ref = recaptchaRef.current;\n\n /*\n * If the user can submit before this mounts, then the check will fail,\n * but they are also arguably non-human... 🤖\n */\n if (\n !ref ||\n // @ts-expect-error This is a private method, but it's the only way to get the recaptcha token\n !ref.getCaptchaFunction ||\n // @ts-expect-error This is a private method, but it's the only way to get the recaptcha token\n !ref.getCaptchaFunction('execute')\n ) {\n logger.error(\n 'Attempted Recaptcha token request before it was ready'\n );\n return resolve({\n recaptchaToken: '',\n platform: 'web' as const,\n });\n }\n\n const formId = ref.getWidgetId();\n\n /*\n * Unfortunately, this dangerously undocumented method is the only way to\n * appropriately utilize Enterprise ReCAPTCHA. This version relies upon\n * the \"action\", which is not yet available in this library.\n *\n * @see https://github.com/dozoisch/react-google-recaptcha/issues/289\n */\n ref\n // @ts-expect-error See above\n .getCaptchaFunction('execute')(formId, {\n action: actionName,\n })\n .then((res: string) => {\n resolve({\n recaptchaToken: res,\n platform: 'web',\n });\n });\n }\n });\n },\n RecaptchaComponent:\n inMobileApp || !recaptchaSiteKey ? null : (\n \n \n \n \n ),\n };\n };\n","import {useMutation, useQuery} from '@tanstack/react-query';\nimport * as R from 'ramda';\nimport {pipe} from '@practicegenius/pg-util/src/FunctionUtils';\nimport {\n Practice,\n PracticeOffice,\n PracticeStatus,\n PracticeType,\n} from '@practicegenius/domain/src/data/practice';\nimport {objectKeysToCamelCaseDeep} from '@practicegenius/pg-util/src/ObjectUtils';\nimport {isNotNil} from '@practicegenius/pg-util/src/TypescriptUtils';\nimport {getLogoUrl} from '../../utils/practice';\nimport {sitesHttpClient} from '../../http/AuthApiProvider';\n\nexport type UnauthenticatedContext = {\n // This is currently an old representation of the practice because it is sourced from the legacy API.\n // In the long run, this will eventually be provided via the modern API and will become a\n // more common, shared representation of the practice.\n practice: {\n practiceId: number;\n practiceUri: string;\n practiceName: null | string;\n practiceType: PracticeType;\n website: Practice['website'] | null;\n address1: PracticeOffice['addressLine1'] | null;\n address2: PracticeOffice['addressLine2'] | null;\n city: PracticeOffice['city'] | null;\n state: PracticeOffice['state'] | null;\n zip: PracticeOffice['zip'] | null;\n country: PracticeOffice['country'] | null;\n phone: Practice['website'] | null;\n fax: string | null;\n email: Practice['email'] | null;\n logo1: string | null;\n logo2: string | null;\n dashBanner: string | null;\n rewardCard: string | null;\n timeZone: string;\n logo3: string | null;\n status: PracticeStatus;\n appointmentsStatus: boolean;\n };\n};\n\nconst parseLogoUrl = R.when(isNotNil, getLogoUrl);\n\nexport const useUnauthenticatedContextQuery = () => {\n return useQuery({\n queryKey: ['global-unathenticated-context'],\n queryFn: () =>\n sitesHttpClient._unsafe.get('/api/unauthenticated_context').then(\n pipe(\n R.prop('data'),\n objectKeysToCamelCaseDeep,\n R.evolve({\n practice: {\n logo1: parseLogoUrl,\n logo2: parseLogoUrl,\n logo3: parseLogoUrl,\n dashBanner: parseLogoUrl,\n },\n })\n )\n ),\n });\n};\n\n/** If there's a referrer (post-login page) in the session, clear it */\nexport const useClearReferrerInSession = () =>\n useMutation({\n mutationFn: () => sitesHttpClient._unsafe.get('/api/session/clearreferrer'),\n });\n\n/** This sets a session variable in the session which the backends uses to bypass recaptcha validation.\n * The hook name is intentionally vague to make it less clear what it does if build process doesn't change name.\n * This should be removed once the recaptcha feature is expected to be enabled on all versions of mobile app */\nexport const useSyncSession = () =>\n useMutation({\n mutationKey: ['sync-session'],\n mutationFn: () => sitesHttpClient._unsafe.post('/api/sync-session'),\n });\n","import {makeUseRecaptcha} from '@practicegenius/pg-ui/src/hooks/makeUseRecaptcha';\nimport log from '../../utils/logger';\nimport {useSyncSession} from '../queries/global';\nimport ServiceBrand from '../../utils/ServiceBrand';\n\nexport const useRecaptcha = makeUseRecaptcha({\n logger: log,\n // This works because it is in a callback. The eslint rule can't validate this\n recaptchaSiteKey: ServiceBrand.data.googleRecaptchaSiteKey,\n useSyncSession,\n});\n","import {Checkbox} from '@practicegenius/pg-ui/src/base/Material/components/Checkbox';\nimport Box from '@mui/material/Box';\nimport React from 'react';\nimport CircularProgress from '@mui/material/CircularProgress';\nimport {Grow} from '@mui/material';\nimport {Field} from '../../../@practicegenius/react-final-form';\n\nconst VERIFICATION_RANGE_MS = [1500, 3000];\n\ntype Verification = 'unverified' | 'pending' | 'verified';\n\ntype Props = {\n verifyHumanFieldName: string;\n honeyPotFieldName: string;\n};\n\nexport const VerifyHumanPanel = ({\n verifyHumanFieldName,\n honeyPotFieldName,\n}: Props) => {\n const [verification, setVerification] =\n React.useState('unverified');\n\n // TODO replace with real human verification (or just remove it in favor of MFA)\n const verifyHuman = () => {\n return new Promise(resolve => {\n const timeout =\n Math.floor(\n Math.random() *\n (VERIFICATION_RANGE_MS[1] - VERIFICATION_RANGE_MS[0] + 1)\n ) + VERIFICATION_RANGE_MS[0];\n setTimeout(() => {\n setVerification('verified');\n resolve(void 0);\n }, timeout);\n });\n };\n\n return (\n \n \n \n \n {({input}) => (\n \n {/* @ts-expect-error */}\n theme.palette.success.main\n : undefined,\n },\n '& .input.Mui-disabled': {\n color:\n verification === 'verified'\n ? theme => theme.palette.success.main\n : undefined,\n },\n }}\n onChange={e => {\n if (e.target.checked) {\n setVerification('pending');\n verifyHuman().then(() => {\n setVerification('verified');\n // @ts-expect-error Despite the TS issue, this works\n input.onChange(true);\n });\n }\n }}\n label=\"I am a Human\"\n />\n {verification === 'pending' && (\n \n )}\n \n )}\n \n \n \n {({input}) => (\n // @ts-expect-error\n \n )}\n \n \n \n \n \n );\n};\n","import * as React from 'react';\nimport * as R from 'ramda';\nimport Box from '@mui/material/Box';\nimport {RouteChildrenProps, useLocation} from 'react-router-dom';\nimport {styled} from '@mui/material/styles';\nimport {SocialAuthIntegration} from '@practicegenius/domain/src/data/integrations';\nimport {FieldInput} from '@practicegenius/pg-ui/src/base/Material/components/FieldInput';\nimport {PasswordInput} from '@practicegenius/pg-ui/src/base/Material/components/PasswordInput';\nimport {Checkbox} from '@practicegenius/pg-ui/src/base/Material/components/Checkbox';\nimport {TransitionGroup} from 'react-transition-group';\nimport {v4 as uuidv4} from 'uuid';\nimport {inMobileApp} from '@practicegenius/pg-ui/src/utils/MobileApp';\nimport {Field, Form} from '../../../@practicegenius/react-final-form';\nimport {EmailInput} from '../../../shared/Material/components/EmailFieldInput';\nimport {ErrorList} from '../../../@practicegenius/react-final-form/effects/handlesInitialErrors';\nimport {TextHr} from '../../../components/TextHr';\nimport {Link} from '../../../components/Link';\nimport {routes} from '../routes';\nimport {routes as registrationRoutes} from '../../register-account/routes';\nimport {UserLoginPayload} from '../../../types/loginTypes';\nimport {loginWithCredentials} from '../../../http/login';\nimport {withSessionErrors} from '../../../utils/php-js/withSessionErrors';\nimport {UnauthenticatedError, ValidationError} from '../../../http/exceptions';\nimport {preverifyRewardsCard} from '../../../shared/http/register-account';\nimport {SociallyRegisteredModal} from './SociallyRegisteredModal';\nimport {queryStringToObject} from '../../../shared/utils/queryParams';\nimport {\n unregisteredAccountMethods,\n UnregisteredAccountModal,\n} from './UnregisteredAccountModal';\nimport {OrphanedAccountModal} from './OrphanedAccountModal';\nimport {DeletedPracticeAccountModal} from './DeletedPracticeAccountModal';\nimport {UnregisteredSocialAccountModal} from './UnregisteredSocialAccountModal';\nimport {UserRateLimitedModal} from './UserRateLimitedModal';\nimport {GenericErrorModal} from './GenericErrorModal';\nimport log from '../../../utils/logger';\nimport {BaseScreen} from '../../../components/screens/BaseScreen';\nimport {ErrorMessage} from '../../../components/InlineError';\nimport {usePhpJs} from '../../../utils/php-js';\nimport {SocialLoginButtons} from '../../../components/SitesDotSocialLoginButtons';\nimport {LoginSupportFooter} from '../../../components/LoginSupportFooter';\nimport {RecaptchaFailedModal} from './RecaptchaFailedModal';\nimport {useRecaptcha} from '../../../shared/hooks/useRecaptcha';\nimport {VerifyHumanPanel} from '../components/VerifyHumanCheckbox';\nimport {useSyncSession} from '../../../shared/queries/global';\n\nconst RECAPTCHA_FAILURE_DISABLE_FORM_THRESHOLD = 3;\nconst RECAPTCHA_FAILURE_REQUIRE_VERIFICATION_THRESHOLD = 1;\n\n// randomize the field names every time the module loads to add friction for any bots\nconst VERIFY_HUMAN_FIELD_NAME = uuidv4();\nconst HONEY_POT_FIELD_NAME = uuidv4();\n\nconst Modals = {\n UnregisteredCard: 'UnregisteredCard',\n UnregisteredTempRegCode: 'UnregisteredTempRegCode',\n UnregisteredSocialAccount: 'UnregisteredSocialAccount',\n RegistrationNotCompleted: 'RegistrationNotCompleted',\n OrphanedAccount: 'OrphanedAccount',\n DeletedPracticeAccount: 'DeletedPracticeAccount',\n SociallyRegistered: 'SociallyRegistered',\n UserThrottled: 'UserThrottled',\n RecaptchaFailed: 'RecaptchaFailed',\n GenericError: 'GenericError',\n} as const;\n\ntype LoginState = {\n login: string;\n password: string;\n remember_me: boolean;\n humanVerification:\n | {\n required: false;\n }\n | {\n required: true;\n isHuman: boolean;\n isRobot: boolean;\n };\n};\n\nconst stripLogin = (login: string): string => login.replace(/ /g, '');\n\nconst RememberMeWrapper = styled('div')({\n mt: '10px',\n});\n\nconst ForgotLinkWrapper = styled('div')({\n display: 'flex',\n flexDirection: 'row-reverse',\n});\n\nconst ForgotLink = styled(Link)({\n fontWeight: 'normal',\n width: 'max-content',\n});\n\nconst InitialErrors = styled(ErrorMessage)({\n margin: 0,\n});\n\nclass UnregisteredRewardsCardError extends Error {\n static ERROR_NAME = 'unregistered_card';\n}\n\nclass UnregisteredTempRegCodeError extends Error {\n static ERROR_NAME = 'unregistered_username';\n}\n\nclass UnregisteredSocialAccountError extends Error {\n static ERROR_NAME = 'unregistered_social_account';\n}\n\nclass RegistrationNotFinishedError extends Error {\n static ERROR_NAME = 'registration_not_finished';\n}\n\nclass OrphanedUserError extends Error {\n static ERROR_NAME = 'orphaned_user';\n}\n\nclass SociallyRegisteredError extends Error {\n static ERROR_NAME = 'social_registered';\n}\n\nclass UserThrottledError extends Error {\n static ERROR_NAME = 'user_throttled';\n}\n\nfunction Login({\n loginWithCredentials,\n initialErrors,\n}: RouteChildrenProps & {\n initialErrors: ErrorList;\n loginWithCredentials: (\n login: string,\n password: string,\n csrf_token: string,\n recaptcha_token: string | null,\n remember_me: boolean,\n platform: string\n ) => Promise;\n}) {\n // The registration app can redirect back to this screen with the identifier\n // of an already-registered user in the query string.\n const params = queryStringToObject();\n\n const location = useLocation<{\n showBackButton?: boolean;\n }>();\n const showBackButton = inMobileApp && location.state?.showBackButton;\n\n const csrfToken = usePhpJs(({csrf_token}) => csrf_token);\n\n const {mutateAsync: syncSession} = useSyncSession();\n const {getRecaptchaData, RecaptchaComponent} = useRecaptcha('LOGIN');\n const [recaptchaFailures, setRecaptchaFailures] = React.useState(0);\n\n const [modal, setModal] = React.useState<\n keyof typeof Modals | undefined | null\n >(null);\n const [socialAccountProps, setSocialAccountProps] = React.useState<{\n message: string;\n accounts: SocialAuthIntegration[];\n }>({\n message: '',\n accounts: [],\n });\n const [token, setToken] = React.useState(null);\n const [unregisteredSocialProvider, setUnregisteredSocialProvider] =\n React.useState(null);\n const [userThrottlerProps, setUserThrottlerProps] = React.useState<{\n responseAction: any;\n availableIn: any;\n nextBlockDuration: any;\n } | null>(null);\n\n React.useEffect(() => {\n if (params.token) {\n setToken(params.token);\n }\n }, [params.token]);\n\n React.useEffect(() => {\n if (params.provider) {\n setUnregisteredSocialProvider(params.provider);\n }\n }, [params.provider]);\n\n React.useEffect(() => {\n if ('error' in params) {\n switch (params.error) {\n case UnregisteredSocialAccountError.ERROR_NAME:\n setModal(Modals.UnregisteredSocialAccount);\n break;\n case RegistrationNotFinishedError.ERROR_NAME:\n setModal(Modals.RegistrationNotCompleted);\n break;\n case OrphanedUserError.ERROR_NAME:\n setModal(\n params.was_deleted\n ? Modals.DeletedPracticeAccount\n : Modals.OrphanedAccount\n );\n break;\n default:\n }\n }\n // eslint-disable-next-line\n }, [params.error]);\n\n const handleLoginError = async (\n err: Error,\n opts: Partial<{\n login: string;\n }> = {}\n ) => {\n switch (true) {\n case err instanceof ValidationError:\n // Throw the validation error back up so our form can handle it\n throw err;\n case err instanceof UnauthenticatedError:\n // Just pass through to our other handlers below\n break;\n default:\n log.error('Sites. Login: Unhandled error response.', err);\n setModal(Modals.GenericError);\n return;\n }\n\n type UnauthenticatedErrorResponse = UnauthenticatedError['response'];\n interface ErrResponse extends UnauthenticatedErrorResponse {\n data: Record;\n }\n interface Err extends UnauthenticatedError {\n response: ErrResponse;\n }\n const e = err as Err;\n\n /**\n * If we encounter an error from the server that the the user is trying to login with a rewards card,\n * and does not have a global user account, push them to the registration process.\n */\n if (\n e.response.data.error === UnregisteredRewardsCardError.ERROR_NAME &&\n opts.login\n ) {\n await preverifyRewardsCard(stripLogin(opts.login));\n setModal(Modals.UnregisteredCard);\n /**\n * This tree of logic is meant to be removed as cardless practices start using digital reward cards\n * @see https://practicegenius.atlassian.net/browse/PAT-8006\n */\n } else if (\n e.response.data.error === UnregisteredTempRegCodeError.ERROR_NAME &&\n opts.login\n ) {\n // This says it preverify's rewards cards...but it also works for usernames because of cardless offices (their generated username is their rewards card number).\n await preverifyRewardsCard(stripLogin(opts.login));\n setModal(Modals.UnregisteredTempRegCode);\n } else if (\n e.response.data.error === RegistrationNotFinishedError.ERROR_NAME\n ) {\n setToken(e.response.data.token as string);\n setModal(Modals.RegistrationNotCompleted);\n } else if (e.response.data.error === OrphanedUserError.ERROR_NAME) {\n setToken(e.response.data.token as string);\n setModal(\n e.response.data.was_deleted\n ? Modals.DeletedPracticeAccount\n : Modals.OrphanedAccount\n );\n } else if (e.response.data.error === SociallyRegisteredError.ERROR_NAME) {\n setSocialAccountProps({\n message: e.response.data.message as string,\n accounts: e.response.data.hint as SocialAuthIntegration[],\n });\n\n setModal(Modals.SociallyRegistered);\n } else if (e.response.data.error === UserThrottledError.ERROR_NAME) {\n setUserThrottlerProps({\n responseAction: e.response.data.response_action,\n availableIn: e.response.data.available_in,\n nextBlockDuration: e.response.data.next_block_duration,\n });\n\n setModal(Modals.UserThrottled);\n } else if (\n e.response.data.error === UnregisteredSocialAccountError.ERROR_NAME\n ) {\n setUnregisteredSocialProvider(\n e.response.data.provider as SocialAuthIntegration\n );\n setModal(Modals.UnregisteredSocialAccount);\n } else if (e.response.data.error === 'failed_recaptcha') {\n setRecaptchaFailures(R.inc);\n if (recaptchaFailures >= RECAPTCHA_FAILURE_DISABLE_FORM_THRESHOLD) {\n setModal(Modals.RecaptchaFailed);\n }\n } else {\n log.error('Sites. Login: Unhandled 401/403 response.', e);\n setModal(Modals.GenericError);\n }\n };\n\n const handleLogin = React.useCallback(\n async ({login, password, remember_me, ...state}: LoginState) => {\n try {\n const {recaptchaToken, platform} = await getRecaptchaData();\n\n if (state.humanVerification.required) {\n if (state.humanVerification.isRobot)\n throw new Error('User failed human verification');\n\n // this sets up the next login request to bypass the recaptcha check\n if (state.humanVerification.isHuman) await syncSession();\n }\n\n const payload = await loginWithCredentials(\n login,\n password,\n csrfToken,\n recaptchaToken,\n remember_me,\n platform\n );\n\n window.location.href = payload.redirect;\n } catch (err) {\n await handleLoginError(err as Error, {login});\n }\n },\n [loginWithCredentials]\n );\n\n const tooManyRecaptchaFailures =\n recaptchaFailures >= RECAPTCHA_FAILURE_DISABLE_FORM_THRESHOLD;\n const requiresHumanVerification =\n recaptchaFailures >= RECAPTCHA_FAILURE_REQUIRE_VERIFICATION_THRESHOLD;\n\n const initialValues = {\n login: params.user ?? '',\n password: '',\n remember_me: true,\n [VERIFY_HUMAN_FIELD_NAME]: false,\n [HONEY_POT_FIELD_NAME]: false,\n };\n\n return (\n {\n const data = formData as typeof initialValues;\n const humanVerification: LoginState['humanVerification'] =\n requiresHumanVerification\n ? {\n required: true,\n isHuman: data[VERIFY_HUMAN_FIELD_NAME],\n isRobot: data[HONEY_POT_FIELD_NAME],\n }\n : {\n required: false,\n };\n return handleLogin({...data, humanVerification} as LoginState);\n }}\n >\n {formRP => {\n const {pristine, initialErrors, values} = formRP;\n const disableSubmit =\n tooManyRecaptchaFailures ||\n (requiresHumanVerification && !values[VERIFY_HUMAN_FIELD_NAME]);\n\n return (\n \n \n or\n \n handleLoginError(e)}\n />\n \n }\n bottomText={\n \n \n Don't have an account?{' '}\n \n Register new account\n \n \n \n This site is protected by reCAPTCHA and the Google{' '}\n \n Privacy Policy\n {' '}\n and{' '}\n \n Terms of Service\n {' '}\n apply.\n \n \n \n }\n >\n \n \n \n Forgot Username\n \n \n\n \n \n \n Forgot Password\n \n \n\n {/** This is not shown in the mobile app. It will always be true per the form's initial values\n * @see https://practicegenius.atlassian.net/browse/PAT-13186\n */}\n {!inMobileApp && (\n \n \n {({input}) => (\n // @ts-ignore\n \n )}\n \n \n )}\n\n {requiresHumanVerification && (\n \n \n \n )}\n\n setModal(null)}\n redirectTo={`/account/register/link-a-practice?orphanedAccount=1&token=${String(\n token\n )}`}\n />\n\n setModal(null)}\n />\n\n setModal(null)}\n methodUsed={unregisteredAccountMethods.REWARDS_NUMBER}\n redirectTo={loginValue => {\n if (modal === Modals.UnregisteredCard) {\n return `/account/register/registration-methods?unregisteredInput=${loginValue}`;\n }\n return `/account/register/link-a-practice?token=${String(\n token\n )}&linkingViaSocial=${Number(params.viaSocial) || 0}`;\n }}\n />\n\n setModal(null)}\n methodUsed={unregisteredAccountMethods.TEMP_REG_CODE}\n redirectTo={loginValue =>\n `/account/register/registration-methods?unregisteredInput=${loginValue}`\n }\n />\n\n setModal(null)}\n provider={unregisteredSocialProvider ?? 'facebook'}\n />\n\n setModal(null)}\n message={socialAccountProps.message}\n socialAccounts={socialAccountProps.accounts}\n /** Not point-free to satisfy TS on the second arg */\n onLoginError={e => handleLoginError(e)}\n />\n\n {userThrottlerProps && (\n setModal(null)}\n formValues={values}\n responseAction={userThrottlerProps.responseAction}\n availableIn={userThrottlerProps.availableIn}\n nextBlockDuration={userThrottlerProps.nextBlockDuration}\n />\n )}\n\n setModal(null)}\n />\n\n setModal(null)}\n />\n {initialErrors && pristine && (\n {formRP.initialErrors}\n )}\n\n {RecaptchaComponent}\n \n );\n }}\n \n );\n}\n\nexport default withSessionErrors(Login);\n\nLogin.defaultProps = {\n loginWithCredentials,\n};\n","import * as React from 'react';\nimport {withPhpJs} from './index';\n\nexport const withSessionErrors = (Inner: any) =>\n withPhpJs(({sessionErrors}) => ({\n initialErrors: sessionErrors,\n }))((props: any) => );\n","var _style, _path, _path2, _path3, _g;\nfunction _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }\nimport * as React from \"react\";\nfunction SvgLogoShimmer(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n id: \"logo-shimmer_svg__Layer_1\",\n xmlns: \"http://www.w3.org/2000/svg\",\n x: 0,\n y: 0,\n viewBox: \"0 0 206 144\",\n xmlSpace: \"preserve\"\n }, props), _style || (_style = /*#__PURE__*/React.createElement(\"style\", null, \".logo-shimmer_svg__st0{fill:#fff}.logo-shimmer_svg__st1{fill:#505050}\")), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n className: \"logo-shimmer_svg__st0\",\n d: \"M174.1 88.5c-14 0-13.2 11.3-13.2 19.1 0 0-2.1 20 13 20 13.7 0 12.5-18.8 12.5-18.8s2.3-20.3-12.3-20.3z\"\n })), _path2 || (_path2 = /*#__PURE__*/React.createElement(\"path\", {\n className: \"logo-shimmer_svg__st0\",\n d: \"M0 0v144h206V0H0zm61.9 142H44.1v-37.6c0-8.5-4.1-14.3-11.6-14.3-5.3 0-9.8 3.4-11.2 7-.5 1.3-.7 3-.7 4.5V142H2.7V50.6h17.8v28.9l.3-.1c2.1-2.2 3.7-3.2 7.2-4.3 3.3-1.1 7.5-1.3 11.2-1.3 12.9 0 22.7 8.9 22.7 28.4V142zm50.1 0l.1-6.8-.4.4c-2.6 2.6-5.3 6.3-17.5 6.3-13.1 0-20.9-8.6-20.9-28.6V75.4h18v34.7c0 9.4 3 15.1 10.1 15.1 5.6 0 8.8-3.8 10.1-7 .5-1.2.7-2.8.7-4.4V90 75.4h18v43.8c0 8 .2 17.3.5 22.8H112zm64.1 0c-7.6 0-14-.7-18-6.3h-.3v6.3h-15.5c.2-5.1.5-15 .5-21.3V50.6h17.8v32.3h.3c3.8-5.6 8.9-9.1 17.9-9.1 15.5 0 24.7 12.9 24.5 32.7 0 23.3-12.4 35.5-27.2 35.5z\"\n })), _path3 || (_path3 = /*#__PURE__*/React.createElement(\"path\", {\n className: \"logo-shimmer_svg__st1\",\n d: \"M128.1 27.1c0-3.1.2-4.9.5-5.9.5-1.4 1.3-2.2 2.5-2.9.8-.5 1.9-.8 3.5-.8 1.8 0 2.9.4 3.5.8 1.3.9 2 1.6 2.5 3.1.3 1.1.5 2.8.5 5.6v11.6h4.4v-12c0-3.5-.4-6.2-1.2-8-.8-1.8-2-3.1-3.6-4.1-1.6-1-3.7-1.5-6.1-1.5-2.4 0-4.5.5-6.1 1.5-1.6 1-2.8 2.3-3.6 4.1-.8 1.7-1.2 4.3-1.2 7.8v12.2h4.4V27.1zM106.5 39.5c2.6 0 4.9-.5 6.9-1.5s3.6-2.4 4.8-4.2l-3.3-2.4c-2.1 2.6-4.6 3.9-8.3 3.9-2 0-3.5-.4-5.1-1.3-1.6-.9-2.3-1.5-3.4-3.1-.6-.8-.9-1.7-1.1-2.7 5 1 13.8 1.9 22.3-6.5-.2-.6-.5-1.2-.8-1.7l-.4-.7c-.9-1.3-1.9-2.6-3.2-3.6-1-.7-2.2-1.3-3.5-1.7-1.5-.5-3.1-.8-4.8-.8-2.6 0-5 .6-7.1 1.7-2.1 1.2-3.8 2.8-5 4.8-1.2 2.1-1.8 4.3-1.8 6.7 0 3.6 1.3 6.6 3.9 9.1 2.7 2.8 6 4 9.9 4zm-6.6-19.8c1.7-1.6 4.5-2.2 6.8-2.2 3 0 5.3 1 7.3 3.3-4.3 2.9-9.8 4.7-16.7 3.3.4-1.7 1.2-3.1 2.6-4.4zM70.3 28c.1 3.1.3 5.9 1.1 7.6.7 1.6 1.7 3.2 3 4.4l3-3.3c-1.7-1.8-2.7-4.1-2.7-9.9v-8.9h3.9V14h-3.9V4.7h-4.4V14H66v3.9h4.4V28zM157.1 4.7h-4.4V14h-4.4v3.9h4.4V28c0 3.1.3 5.9 1.1 7.6.7 1.6 1.7 3.2 3 4.4l3-3.3c-1.7-1.8-2.7-4.1-2.7-9.9v-8.9h3.9V14h-3.9V4.7zM86.4 7.3c.7 0 1.4-.3 1.9-.8s.7-1.1.7-1.8-.3-1.4-.8-1.9-1.1-.8-1.8-.8-1.3.3-1.9.8c-.5.5-.8 1.1-.8 1.9 0 .7.3 1.3.8 1.9.6.4 1.2.7 1.9.7zM88.4 14H84v14c.1 3.1.3 5.9 1.1 7.6.7 1.6 1.7 3.2 3 4.4l3-3.3c-1.7-1.8-2.7-4.1-2.7-9.9V14zM45.8 39.5c2 0 4.1-.3 5.8-1.2 1.7-.8 3.1-1.6 4.5-3.3l.4-.5.3.9c.7 1.6 1.8 3.3 3.2 4.5l3-3.3c-1.6-1.7-2.6-4.6-2.7-8V14H56v4.6c-1.3-1.7-2.7-3-4.4-3.9-1.7-.9-3.5-1.3-5.6-1.3-3.6 0-6.6 1.3-9.1 3.8-2.5 2.6-3.8 5.6-3.8 9.2 0 3.7 1.2 6.8 3.7 9.3 2.4 2.6 5.4 3.8 9 3.8zm-7.3-17.7c.8-1.4 1.9-2.6 3.2-3.4 1.4-.8 2.8-1.2 4.4-1.2 2.5 0 4.6.9 6.3 2.6 1.7 1.8 2.6 4 2.6 6.6 0 1.7-.4 3.3-1.1 4.6-.8 1.4-1.8 2.5-3.3 3.3-1.4.8-2.9 1.2-4.5 1.2s-3-.4-4.4-1.2c-1.4-.8-2.5-1.9-3.3-3.4-.8-1.5-1.2-3-1.2-4.6.1-1.5.5-3 1.3-4.5zM25.3 17.6c-2.5-2.8-5.7-4.2-9.6-4.2-3.9 0-7.1 1.4-9.6 4.2-2.3 2.5-3.4 5.5-3.4 9v21H7V36.3c.1.2.3.3.4.5 2 2 5.1 2.7 8.3 2.7 3.8 0 6.9-1.3 9.4-3.9 2.4-2.6 3.6-5.6 3.6-9.1.1-3.4-1.1-6.4-3.4-8.9zm-2 13.5c-.8 1.4-1.8 2.5-3.2 3.2-1.3.8-2.8 1.1-4.4 1.1-1.6 0-3.1-.4-4.4-1.1-1.3-.7-2.3-1.8-3.1-3.2-.8-1.4-1.2-2.9-1.2-4.5 0-2.5.9-4.7 2.6-6.4 1.7-1.8 3.8-2.7 6.1-2.7 2.4 0 4.4.9 6.1 2.7 1.7 1.8 2.6 3.9 2.6 6.4.1 1.6-.3 3.1-1.1 4.5z\"\n })), _g || (_g = /*#__PURE__*/React.createElement(\"g\", null, /*#__PURE__*/React.createElement(\"path\", {\n className: \"logo-shimmer_svg__st1\",\n d: \"M111.8 63.4c1.4 1.6 3.2 2.4 5.4 2.4s4-.8 5.4-2.4c1.3-1.4 2-3.1 2-5.1v-7.2c0-1.8-.2-3.7-.6-4.7-.4-.9-1-1.8-1.7-2.5l-1.7 1.9c1 1 1.5 2.7 1.5 6v1c-.1-.1-.1-.2-.2-.3-1.2-1.2-2.9-1.6-4.7-1.6-2.2 0-3.9.7-5.3 2.2-1.4 1.5-2.1 3.2-2.1 5.2.1 2 .7 3.7 2 5.1zm1.2-7.7c.4-.8 1-1.4 1.8-1.8.8-.4 1.6-.6 2.5-.6.9 0 1.7.2 2.5.6.8.4 1.4 1 1.8 1.8.4.8.7 1.7.7 2.6 0 1.4-.5 2.6-1.5 3.6s-2.1 1.5-3.5 1.5c-1.3 0-2.5-.5-3.5-1.5s-1.5-2.2-1.5-3.6c0-.9.2-1.8.7-2.6zM92.4 51.1v2.6c-.7-1-1.5-1.7-2.5-2.2-.9-.5-2-.7-3.2-.7-2 0-3.7.7-5.2 2.2-1.4 1.5-2.1 3.2-2.1 5.2 0 2.1.7 3.9 2.1 5.3 1.4 1.5 3.1 2.2 5.1 2.2 1.1 0 2.3-.2 3.3-.7.9-.5 1.8-.9 2.5-1.9l.2-.3c.1.2.1.3.2.5.4.9 1.1 1.9 1.8 2.5l1.7-1.9c-.9-1-1.5-2.6-1.5-4.6v-8.4h-2.4zm-1 9.7c-.4.8-1.1 1.4-1.9 1.9-.8.5-1.7.7-2.5.7-.9 0-1.7-.2-2.5-.7-.8-.5-1.4-1.1-1.9-1.9-.5-.8-.7-1.7-.7-2.6 0-.9.2-1.8.7-2.6.5-.8 1.1-1.5 1.8-1.9.8-.5 1.6-.7 2.6-.7 1.4 0 2.6.5 3.6 1.5s1.5 2.2 1.5 3.7c-.1 1-.3 1.9-.7 2.6zM71.5 65.8c1.4 0 2.5-.3 3.4-.8.9-.6 1.6-1.3 2.1-2.3.5-1 .7-2.5.7-4.4v-7h-2.5v6.6c0 1.8-.1 2.8-.3 3.3-.3.8-.7 1.2-1.4 1.6-.5.3-1.1.5-2 .5-1 0-1.6-.2-2-.4-.7-.5-1.1-.9-1.4-1.8-.2-.6-.3-1.6-.3-3.2v-6.6h-2.6v6.6c0 1.8-.1 2.8-.3 3.3-.3.8-.7 1.2-1.4 1.6-.5.3-1.1.5-2 .5-1 0-1.6-.2-2-.4-.7-.5-1.1-.9-1.4-1.8-.2-.6-.3-1.6-.3-3.2v-6.6h-2.5v6.8c0 2 .2 3.5.7 4.5.5 1 1.1 1.8 2.1 2.3.9.6 2.1.8 3.5.8s2.5-.3 3.4-.8c.6-.4 1.1-.9 1.5-1.4.4.6.9 1.1 1.5 1.4.9.7 2.1.9 3.5.9zM28.3 52.7c-.3-.6-.8-1.2-1.3-1.7l-1.7 1.9c1 1 1.5 2.3 1.5 5.6v7.3h2.5v-8c0-.8-.1-1.6-.1-2.4.5-.8 1.1-1.4 1.8-1.9.8-.5 1.6-.7 2.5-.7 1.4 0 2.6.8 3.6 1.8l.2.2 1.1-2c-.6-.6-1.2-1.1-1.9-1.5-.9-.5-2-.7-3.2-.7-2 .1-3.6.8-5 2.1zM53.4 54.1c-.5-.8-1.1-1.5-1.8-2-.6-.4-1.2-.7-2-1-.9-.3-1.8-.4-2.7-.4-1.5 0-2.8.3-4 1-1.2.7-2.2 1.6-2.8 2.8-.7 1.2-1 2.4-1 3.8 0 2 .7 3.8 2.2 5.2 1.5 1.4 3.3 2.1 5.6 2.1 1.5 0 2.8-.3 3.9-.8 1.1-.6 2.1-1.4 2.7-2.4l-2-1.4c-1.2 1.5-2.6 2.2-4.7 2.2-1.1 0-2-.2-2.9-.7-.9-.5-1.3-.9-1.9-1.8-.3-.5-.5-.9-.6-1.5 2.9.6 7.8 1.1 12.7-3.7-.1-.4-.3-.7-.4-1l-.3-.4zm-11.9 2.7c.2-.9.7-1.8 1.5-2.5 1-.9 2.5-1.3 3.8-1.2 1.7 0 3 .6 4.2 1.9-2.5 1.6-5.6 2.7-9.5 1.8zM105 50.7c-1.9 0-3.6.7-5 2-.3-.6-.8-1.2-1.3-1.7L97 52.9c1 1 1.5 2.3 1.5 5.6v7.3h2.5v-8c0-.8-.1-1.6-.1-2.4.5-.8 1.1-1.4 1.8-1.9.8-.5 1.6-.7 2.5-.7 1.4 0 2.6.8 3.6 1.8.1.1.1.1.1.2l1.1-2c-.6-.6-1.2-1.1-1.9-1.5-.9-.4-2-.6-3.1-.6zM129.7 53.3c.8-.4 1.8-.6 2.5-.6 1.4 0 2.8.2 4.3 1.2l1.4-1.6c-2-1.2-3.6-1.7-5.6-1.7-1.7 0-3.1.4-4.3 1.1-1.1.8-1.8 1.5-1.8 2.6 0 .9.4 1.7 1.1 2.3.7.7 1.9 1.4 3.9 2.1 1.8.6 3.1 1.2 3.6 1.6.5.4.8.8.8 1.3 0 .3-.2.9-.8 1.3-.8.5-1.6.7-2.7.7-1.6 0-3.2-.1-4.8-1.1l-1.4 1.7c.8.6 1.3.9 2.3 1.2 1.1.4 2.3.6 3.6.6 1.9 0 3.5-.4 4.7-1.3 1.3-.9 1.8-1.9 1.8-2.9 0-.9-.2-1.6-.9-2.3-.7-.7-1.3-1.3-4.5-2.4-1.7-.6-2.8-1.1-3.3-1.6-.5-.4-.6-.6-.6-1-.1-.7.3-1 .7-1.2z\"\n }))));\n}\nexport default __webpack_public_path__ + \"191b54b99d3be5b65ffeda3edc1ab805.svg\";\nexport { SvgLogoShimmer as ReactComponent };","var _defs, _g, _g2;\nfunction _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }\nimport * as React from \"react\";\nfunction SvgLogo(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 330.49 320.9\"\n }, props), _defs || (_defs = /*#__PURE__*/React.createElement(\"defs\", null, /*#__PURE__*/React.createElement(\"style\", null, \".logo_svg__cls-1{fill:#444}.logo_svg__cls-2{fill:#ed1c24}\"))), _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n id: \"logo_svg__Layer_1\",\n \"data-name\": \"Layer 1\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n className: \"logo_svg__cls-1\",\n d: \"M211.69 196.33c-1.92-2-3-5.4-3.14-9.47v-18.94h-6.74v5.28-.09a11 11 0 00-4.35-3.47 15.12 15.12 0 00-7.17-1.7 15.87 15.87 0 00-11.7 4.94 16.47 16.47 0 00-4.86 11.92 16.72 16.72 0 004.81 12 15.7 15.7 0 0011.64 5 17.09 17.09 0 007.44-1.53 18.52 18.52 0 005.35-3.82 3.88 3.88 0 00.23-.33 17.4 17.4 0 003.81 5.23l.52.46 4.62-5zm-12.74-6a9.42 9.42 0 01-3.63 3.7 9.86 9.86 0 01-5 1.37 9.29 9.29 0 01-4.9-1.38 10.14 10.14 0 01-3.65-3.86 10.85 10.85 0 01-1.37-5.21 10.63 10.63 0 011.37-5.22 9.77 9.77 0 013.62-3.81 9.58 9.58 0 015-1.35 9.37 9.37 0 017 3 10.47 10.47 0 012.87 7.49 11 11 0 01-1.26 5.23zM122.56 199.86a15.79 15.79 0 0015.33 0 12.26 12.26 0 002.86-2.62 12 12 0 002.88 2.63 14.19 14.19 0 007.68 2 13.89 13.89 0 007.64-2 12.28 12.28 0 004.63-5.51c1-2.3 1.51-5.72 1.51-10.16v-16.26h-6.72v15.49a28.58 28.58 0 01-.56 7.22 5.5 5.5 0 01-2.65 3.25 7 7 0 01-3.9.92 6.7 6.7 0 01-3.86-.88 5.69 5.69 0 01-2.68-3.57 29.53 29.53 0 01-.61-6.94v-15.49h-6.82v15.49c0 3.7-.18 6.06-.56 7.21a5.51 5.51 0 01-2.65 3.26 7 7 0 01-3.89.92 6.74 6.74 0 01-3.87-.88 5.72 5.72 0 01-2.68-3.57 29.53 29.53 0 01-.61-6.94v-15.49h-6.64v15.95c0 4.56.51 8.07 1.51 10.42a12.19 12.19 0 004.66 5.55zM55.62 175.54a9.64 9.64 0 015-1.37c2.39 0 4.77 1.23 7.08 3.66l.13.14a2.23 2.23 0 00.19.24l.65.7 3-5.6-.33-.37a15.11 15.11 0 00-4.16-3.33 14.72 14.72 0 00-7-1.67 15.35 15.35 0 00-10.48 4 14.09 14.09 0 00-2.42-3l-.51-.45-4.52 5 .45.47c1.84 2 3.06 4.66 3.06 11.57v16.38h6.63v-18.5c0-1.58-.13-3-.27-4.22a9.86 9.86 0 013.5-3.65zM108.44 176.69l-.53-.93a19.35 19.35 0 00-4-4.61 16.29 16.29 0 00-4.35-2.23 18.41 18.41 0 00-6-1 17.91 17.91 0 00-8.9 2.24 16.47 16.47 0 00-6.29 6.27 17.39 17.39 0 00-2.28 8.7A16.12 16.12 0 0081 197a16.76 16.76 0 0012.27 4.86 18.73 18.73 0 008.57-1.91 15.46 15.46 0 006-5.42l.36-.57-5-3.72-.41.52a11.9 11.9 0 01-15.2 3 9.43 9.43 0 01-3.81-3.59 7.72 7.72 0 01-1-2.07c6.89 1.27 16.71 1.41 26.42-8.41l.31-.32-.15-.44a20.82 20.82 0 00-.92-2.24zm-7.24 1.85a24.69 24.69 0 01-18.15 3.52 10.06 10.06 0 012.73-4.29c1.6-1.53 4.36-2.43 7.41-2.43h.22a10.31 10.31 0 017.79 3.2zM226.13 185.46v16.38h6.64v-18.5c0-1.6-.13-3-.26-4.22a9.74 9.74 0 018.5-5c2.41 0 4.73 1.2 7.08 3.65l.12.15a2.23 2.23 0 00.19.24l.65.7 3-5.6-.32-.37a15.19 15.19 0 00-4.16-3.33 14.72 14.72 0 00-7-1.67 15.33 15.33 0 00-10.48 4 13.35 13.35 0 00-2.43-3l-.5-.44-4.52 4.95.44.47c1.83 1.97 3.05 4.68 3.05 11.59zM308.18 195.49c-3.43 0-6.53-.17-9.79-2.26l-.5-.33-3.89 4.58.55.44a14.62 14.62 0 005.15 2.67 24.75 24.75 0 007.84 1.25 17.9 17.9 0 0010.38-2.84c2.61-1.79 4.05-4.17 4.05-6.67a7.31 7.31 0 00-2-5.41c-1.65-1.78-3-3-9.84-5.27-4.17-1.39-6-2.5-6.78-3.17-1.06-.92-1.1-1.12-1.1-1.67 0-.72.36-1.19 1.31-1.69a11.61 11.61 0 015.05-1.22 14.27 14.27 0 018.72 2.37l.51.34 3.84-4.45-.69-.42c-4.34-2.69-7.9-3.78-12.28-3.78a16.62 16.62 0 00-9.44 2.53c-2.58 1.74-4.18 3.36-4.18 6.08a7.4 7.4 0 002.47 5.46c1.72 1.65 4.58 3.21 8.5 4.61 3.07 1.09 6.37 2.33 7.5 3.24s1.41 1.44 1.41 2.28a2.93 2.93 0 01-1.43 2.06 9.46 9.46 0 01-5.36 1.27zM280.73 158.56c0 7.65.07 10 .08 11.06v1.27c-2.36-1.91-5.78-2.91-10-2.91a15.86 15.86 0 00-12.09 5.07 17.25 17.25 0 00-.25 23.4 16.81 16.81 0 0024.7 0 16.74 16.74 0 004.44-11.59V168.4v-10.17zm-18.54 21a9.35 9.35 0 013.65-3.75 10.47 10.47 0 0110.14 0 9.64 9.64 0 013.66 3.75 10.64 10.64 0 011.35 5.25 10.38 10.38 0 01-3 7.45 9.72 9.72 0 01-14.18 0 10.15 10.15 0 01-3-7.45 10.59 10.59 0 011.38-5.22z\"\n }))), _g2 || (_g2 = /*#__PURE__*/React.createElement(\"g\", {\n id: \"logo_svg__Layer_2\",\n \"data-name\": \"Layer 2\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n className: \"logo_svg__cls-2\",\n d: \"M.79 0h30v58.08h.4A36.39 36.39 0 0143 47.68a32.19 32.19 0 0115.57-4c19.11 0 33.7 14 33.7 44.55v59.55h-30v-56c0-13.32-4.33-22.48-15.56-22.48-7.89 0-12.81 5.41-15 11a21.14 21.14 0 00-1 7.08v60.38H.79zM207.12 115.13c0 13.32.39 24.15.79 32.69h-26l-1.37-14.37h-.6c-3.74 6.25-12.81 16.66-30.15 16.66-19.51 0-33.89-12.91-33.89-44.35V46H146v54.75c0 14.79 4.53 23.74 15 23.74 8.27 0 13-6 15-11a18.53 18.53 0 001-6.87V46h30.15zM230.37 147.82c.4-6.67.79-18.95.79-30.4V0h30v58.08h.39c5.71-8.74 15.77-14.36 29.17-14.36 23.05 0 40 20.19 39.8 51.42 0 36.64-22.07 55-44.14 55-11.23 0-22.07-4.38-29-16.45H257l-1.19 14.16zm30.75-43.31a24.12 24.12 0 00.59 5.62c2 8.54 8.87 15 17.54 15 12.81 0 20.69-10.41 20.69-28.73 0-15.82-6.7-28.31-20.69-28.31-8.08 0-15.57 6.45-17.54 15.61a27.44 27.44 0 00-.59 5.83zM0 318.61c.39-6.66.79-18.94.79-30.39V170.8h30v58.08h.4c5.71-8.74 15.76-14.36 29.16-14.36 23.06 0 40 20.19 39.81 51.42 0 36.64-22.07 55-44.14 55-11.24 0-22.07-4.37-29-16.45h-.4l-1.18 14.16zm30.74-43.3a24.74 24.74 0 00.59 5.62c2 8.53 8.87 15 17.54 15 12.81 0 20.69-10.41 20.69-28.73 0-15.82-6.7-28.32-20.69-28.32-8.08 0-15.57 6.46-17.54 15.62a28 28 0 00-.59 5.83zM213.22 285.93c0 13.32.4 24.15.79 32.68H188l-1.38-14.36H186c-3.74 6.24-12.81 16.65-30.15 16.65-19.51 0-33.9-12.91-33.9-44.34v-59.75h30.15v54.75c0 14.78 4.54 23.73 15 23.73 8.28 0 13-6 15-11a18.54 18.54 0 001-6.87v-60.61h30.15zM263.87 216.81l9.46 16.86c2.76 5.2 5.32 10.41 7.88 15.2h.4c2.56-5.42 4.92-10.62 7.48-15.62l8.48-16.44h32.51l-31.72 48.5 32.12 53.3h-33.9l-9.65-18.32c-2.76-5-5.13-10.2-7.49-15.41h-.59c-2.37 5.42-4.93 10.41-7.3 15.41l-9.06 18.32h-32.91l32.71-51.84-31.92-50z\"\n }))));\n}\nexport default __webpack_public_path__ + \"ad53e7a13169fadf2d3197c62f51bbe8.svg\";\nexport { SvgLogo as ReactComponent };","var _defs, _path, _path2, _path3, _image, _image2, _image3;\nfunction _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }\nimport * as React from \"react\";\nfunction SvgLogo(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n xmlnsXlink: \"http://www.w3.org/1999/xlink\",\n viewBox: \"0 0 1492.52 1341.41\"\n }, props), _defs || (_defs = /*#__PURE__*/React.createElement(\"defs\", null, /*#__PURE__*/React.createElement(\"style\", null, \".logo_svg__cls-1{fill:#181749}\"))), /*#__PURE__*/React.createElement(\"g\", {\n style: {\n isolation: \"isolate\"\n }\n }, /*#__PURE__*/React.createElement(\"g\", {\n id: \"logo_svg__Layer_2\",\n \"data-name\": \"Layer 2\"\n }, /*#__PURE__*/React.createElement(\"g\", {\n id: \"logo_svg__Layer_1-2\",\n \"data-name\": \"Layer 1\"\n }, _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n className: \"logo_svg__cls-1\",\n d: \"M96 1341.41c-18.04 0-34.35-4.19-48.95-12.57-14.61-8.38-26.09-19.81-34.48-34.29C4.19 1280.07 0 1263.95 0 1246.17s4.19-34.22 12.57-48.57c8.38-14.34 19.87-25.71 34.48-34.09 14.6-8.38 30.92-12.57 48.95-12.57 14.22 0 27.49 2.73 39.81 8.19 12.32 5.46 22.79 13.27 31.43 23.43l-27.43 27.81c-5.33-6.35-11.75-11.11-19.24-14.29-7.49-3.17-15.69-4.76-24.57-4.76-10.42 0-19.62 2.35-27.62 7.05-8 4.7-14.23 11.11-18.67 19.24-4.45 8.13-6.67 17.65-6.67 28.57s2.22 20.13 6.67 28.38c4.44 8.26 10.67 14.73 18.67 19.43 8 4.7 17.2 7.05 27.62 7.05 8.89 0 17.08-1.58 24.57-4.76 7.49-3.17 13.9-7.93 19.24-14.29l27.43 27.81c-8.64 10.16-19.11 17.97-31.43 23.43-12.32 5.46-25.59 8.19-39.81 8.19zM264.68 1341.41c-15.49 0-29.27-3.43-41.33-10.29-12.07-6.86-21.46-16.32-28.19-28.38-6.73-12.06-10.1-25.96-10.1-41.71v-106.28h41.9v104.38c0 8.89 1.46 16.45 4.38 22.67 2.92 6.23 7.24 10.99 12.95 14.29 5.71 3.3 12.51 4.95 20.38 4.95 12.19 0 21.52-3.62 28-10.86 6.48-7.24 9.71-17.58 9.71-31.05v-104.38h41.9v106.28c0 16-3.37 30.04-10.1 42.09-6.73 12.07-16.06 21.46-28 28.19-11.94 6.73-25.78 10.09-41.52 10.09zM371.01 1337.6v-259.04h41.9v259.04h-41.9zM518.67 1078.55h-41.91v76.19h-43.81v38.1h43.81v144.76h41.91v-144.76h43.8v-38.1h-43.8v-76.19zM698.01 1259.12c0 13.46-3.24 23.81-9.71 31.05-6.47 7.24-15.81 10.86-28 10.86-7.87 0-14.67-1.65-20.38-4.95-5.71-3.3-10.04-8.06-12.95-14.29-2.92-6.22-4.38-13.77-4.38-22.67v-104.38h-41.9v106.28c0 15.75 3.36 29.65 10.1 41.71 6.73 12.06 16.12 21.52 28.19 28.38 12.06 6.86 25.84 10.29 41.33 10.29s29.58-3.37 41.52-10.09c11.93-6.73 21.27-16.12 28-28.19 6.73-12.06 10.1-26.09 10.1-42.09v-106.28h-41.9v104.38zM880.72 1155.89c-7.37-3.3-15.62-4.95-24.76-4.95-20.83 0-36.38 7.18-46.67 21.52-.33.46-.63.93-.95 1.4v-19.11h-41.9v182.85h41.9v-101.71c0-15.74 3.81-27.3 11.43-34.67 7.62-7.36 17.27-11.05 28.95-11.05 5.33 0 10.03.76 14.09 2.29 4.06 1.52 7.74 4.07 11.05 7.62l25.47-30.36c-5.8-6.24-12-10.87-18.62-13.83z\"\n })), _path2 || (_path2 = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M1469.85 1178.27c-15.04-16.42-36.12-25.83-57.83-25.83s-44.16 9.45-61.53 25.92c-18.31 17.36-29.62 41.01-31.86 66.61-1.29 14.77.47 28.89 5.02 41.66-13.1 10.58-26.47 16.68-37.14 16.68-17.42 0-31.04-10.24-39.86-28.91 39.89-45.35 70.12-107.91 70.12-146.7 0-14.49-5.07-27.7-14.28-37.19-8.74-9.01-20.8-14.18-33.08-14.18-35.2 0-70.72 41.37-70.72 133.81 0 21.19 2.19 40.08 6.54 56.53-22.47 26.85-43.08 36.64-55.47 36.64-17.42 0-31.04-10.24-39.86-28.91 39.86-45.33 70.12-107.98 70.12-146.7 0-14.49-5.07-27.7-14.28-37.19-8.74-9.01-20.8-14.18-33.08-14.18-35.2 0-70.72 41.37-70.72 133.81 0 20.53 2.06 38.89 6.14 54.97-26.57 24.1-62.13 39.78-91.51 39.78-27.84 0-42.59-9.05-50.21-20.13 33.99-3.89 56.67-15.18 70.47-24.94 22.3-15.76 35.61-37.77 35.61-58.87 0-31.8-28.21-48.44-56.07-48.44-24.14 0-48.31 11.56-66.3 31.71-17.99 20.15-27.9 46.2-27.9 73.36 0 50.91 37.05 83.81 94.4 83.81 34.76 0 74.18-15.49 106.02-40.75.67 1.1 1.36 2.18 2.07 3.23 15.43 23.17 38.55 35.93 65.11 35.93 22.82 0 47.93-13.01 71.32-36.43.11.17.22.33.33.5 15.43 23.17 38.55 35.93 65.11 35.93 18.19 0 37.79-7.74 56.58-22.05 14.84 15 34.93 23.55 55.6 23.55 21.74 0 44.17-9.47 61.54-25.98 18.31-17.4 29.63-41.15 31.88-66.88 2.37-27.03-5.54-51.96-22.26-70.2zm-493.5 10.76c.8 0 19.57.13 19.57 11.93 0 6.82-5.29 18.53-20.18 29.06-10.55 7.45-28.42 16.1-56.49 18.8 3.91-29.8 27.05-59.79 57.11-59.79zm122.08 21.11c0-31.64 5.03-59.19 14.17-77.57 6.05-12.17 13.73-19.73 20.05-19.73 5.23 0 10.86 4.65 10.86 14.86 0 21.97-17.37 64.21-44.32 101.59-.5-6.06-.75-12.45-.75-19.15zm136.76 0c0-31.64 5.03-59.19 14.17-77.57 6.05-12.17 13.73-19.73 20.05-19.73 5.23 0 10.86 4.65 10.86 14.86 0 22.02-17.36 64.22-44.32 101.59-.5-6.06-.75-12.45-.75-19.15zm220.55 35.15c-2.52 28.75-26.04 59.53-57.05 59.53-11.48 0-22.72-5.08-30.84-13.95-9.76-10.65-14.33-25.82-12.85-42.71 2.5-28.59 26.01-59.21 57.03-59.21 11.5 0 22.77 5.1 30.91 13.99 9.72 10.61 14.27 25.65 12.81 42.36z\",\n fill: \"#1f1f51\"\n })), _path3 || (_path3 = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M1470.4 1325.4v-1.51h7.23v1.51h-7.23zm2.77 7.18v-8.49h1.7v8.49h-1.7zm4.98 0v-8.69h1.19l3.56 5.63h-.69l3.53-5.63h1.19v8.69h-1.68v-5.8l.35.07-2.47 3.95h-1.16l-2.44-3.95.35-.07v5.8h-1.7z\",\n fill: \"#1f2449\"\n })), /*#__PURE__*/React.createElement(\"g\", null, _image || (_image = /*#__PURE__*/React.createElement(\"image\", {\n width: 726,\n height: 888,\n transform: \"translate(565.82 112.14)\",\n xlinkHref: \"\"\n })), /*#__PURE__*/React.createElement(\"image\", {\n width: 225,\n height: 242,\n transform: \"translate(645.82 237.14)\",\n xlinkHref: \"\",\n style: {\n mixBlendMode: \"multiply\"\n },\n opacity: 0.62\n }), _image2 || (_image2 = /*#__PURE__*/React.createElement(\"image\", {\n width: 946,\n height: 1002,\n transform: \"translate(156.82 -.86)\",\n xlinkHref: \"\"\n })), /*#__PURE__*/React.createElement(\"image\", {\n width: 250,\n height: 472,\n transform: \"translate(851.82 512.14)\",\n xlinkHref: \"\",\n style: {\n mixBlendMode: \"multiply\"\n }\n })), _image3 || (_image3 = /*#__PURE__*/React.createElement(\"image\", {\n width: 965,\n height: 860,\n transform: \"translate(326.82 141.14)\",\n xlinkHref: \"\"\n }))))));\n}\nexport default __webpack_public_path__ + \"8fac666bb02e9e9d3071cb8c726e96b2.svg\";\nexport { SvgLogo as ReactComponent };","import React from 'react';\nimport Box from '@mui/material/Box';\nimport Typography from '@mui/material/Typography';\nimport ButtonBase, {ButtonBaseProps} from '@mui/material/ButtonBase';\nimport {SxImg} from '@practicegenius/pg-ui/src/base/Material/components/StyleableBaseComponents';\nimport {MuiSxProps} from '@practicegenius/pg-ui/src/base/Material/utils/sx-helpers';\nimport {ServiceBrand} from '@practicegenius/domain/src/data/serviceBrand';\n// Using CSS modules here as it's the best way to define the animation parameters in a future-proof way.\nimport styles from './Home.module.css';\nimport prhShimmerLogo from '../../../../assets/svg/logos/prh/logo-shimmer.svg';\nimport hubbuxLogo from '../../../../assets/svg/logos/hubbux/logo.svg';\nimport culturelloLogo from '../../../../assets/svg/logos/culturello/logo.svg';\nimport {\n BundledImageAsset,\n getBundledImageAssetProps,\n} from '../../../../assets/BundledImageAsset';\n\nconst prhLogoAspectRatio = 206 / 144;\nconst logoMaxWidth = `calc(350px * ${prhLogoAspectRatio})`;\nconst logoImageLimitSx: MuiSxProps = {\n maxHeight: '350px',\n maxWidth: logoMaxWidth,\n};\n\nconst brandedLogoSrc: Record = {\n patientrewardshub: prhShimmerLogo,\n hubbux: hubbuxLogo,\n culturello: culturelloLogo,\n};\n\nconst brandedGradientBackgroundClassname: Record<\n ServiceBrand,\n string | undefined\n> = {\n patientrewardshub: styles.gradientBackground,\n hubbux: undefined,\n culturello: undefined,\n};\n\nconst baseButtonSx: MuiSxProps = {\n width: '100%',\n py: 2,\n textAlign: 'center',\n borderRadius: '100px',\n border: theme => `1px solid ${theme.palette.grey[400]}`,\n color: 'text.secondary',\n fontWeight: 600,\n '&:hover': {\n backgroundColor: theme => theme.palette.grey[100],\n },\n maxWidth: logoMaxWidth,\n alignSelf: 'center',\n};\n\ntype ButtonProps = Omit;\n/** This currently only provides home screen of sites-dot that is presented in the mobile app.\n * The web version of the home page is still implemented in Kohana\n */\nexport const Home = ({\n serviceBrand,\n buttonProps,\n}: {\n serviceBrand: ServiceBrand;\n buttonProps: {\n login: ButtonProps;\n register: ButtonProps;\n };\n}) => {\n return (\n \n \n \n \n \n \n \n \n Get Rewarded!\n \n \n Earn, redeem, build good habits!\n \n \n \n \n Log In\n \n \n Register New Account\n \n \n \n );\n};\n","// extracted by mini-css-extract-plugin\nexport default {\"\\t\":\"mP47X659Y72CFuMA1ajS\",\"gradientBackground\":\"rtQ8efZeLqVQCwhu2s1Q\",\"gradient\":\"PpJKdq_LqOkbqmJD3_n_\"};","/** Bundled Image Assets have different data structures depending on the build context\n * - Under webpack, they are compiled to a string representing the src of the image\n * - Under next.js, they are compiled to the object representation\n */\nexport type BundledImageAsset =\n | string\n | {\n src: string;\n width: number;\n height: number;\n };\n\nexport const getBundledImageAssetProps = (\n asset: BundledImageAsset\n): React.ComponentProps<'img'> => {\n if (typeof asset === 'string') {\n return {src: asset};\n }\n return {\n src: asset.src,\n width: asset.width,\n height: asset.height,\n };\n};\n","/* eslint-disable @typescript-eslint/no-use-before-define */\nimport * as React from 'react';\nimport {styled} from '@mui/material/styles';\nimport {\n Button,\n ButtonVariant,\n} from '@practicegenius/pg-ui/src/base/Material/components/Button';\nimport {ErrorList} from '../../@practicegenius/react-final-form/effects/handlesInitialErrors';\nimport {Form} from '../../@practicegenius/react-final-form';\nimport {BaseScreen, ExtendedButtonProps} from './BaseScreen';\nimport {ProgressBar} from '../ProgressBar';\nimport {ErrorMessage} from '../InlineError';\nimport {FormRenderProps} from '../../@practicegenius/react-final-form/Form';\n\nconst InitialErrors = styled(ErrorMessage)({\n margin: 0,\n});\n\nconst btns = {\n submit: 'submit',\n secondary: 'secondary',\n};\n\nexport function FormScreen({\n submit,\n submitText = 'Next',\n secondaryButtonProps,\n initialValues,\n initialErrors,\n validate,\n children,\n progress,\n ...otherProps\n}: Omit, 'children' | 'progress'> & {\n submit: (values: any) => Promise;\n submitText: string;\n secondaryButtonProps?: React.ComponentProps;\n initialValues?: any;\n initialErrors?: ErrorList;\n validate?: (values: any) => any | Promise;\n children: React.ReactNode | ((a: FormRenderProps) => React.ReactNode);\n progress?: number;\n}) {\n const [btnClicked, setBtnClicked] = React.useState(\n null\n );\n return (\n \n {formRP => {\n const {pristine, initialErrors} = formRP;\n\n const submitButtonProps = {\n 'data-testid': 'submit',\n type: 'submit' as const,\n disabled: formRP.submitDisabled,\n children: submitText,\n onClick: () => setBtnClicked(btns.submit as 'submit'),\n loading: btnClicked === btns.submit && formRP.submitting,\n color: 'primary' as const,\n };\n\n const secondarySubmit =\n secondaryButtonProps && secondaryButtonProps.type === 'submit'\n ? {loading: btnClicked === btns.secondary && formRP.submitting}\n : {};\n\n const actionButtons = secondaryButtonProps\n ? [\n submitButtonProps,\n {\n color: 'secondary' as const,\n variant: ButtonVariant.outlined as const,\n ...secondaryButtonProps,\n ...secondarySubmit,\n onClick: (e: React.MouseEvent) => {\n setBtnClicked(btns.secondary as 'secondary');\n secondaryButtonProps?.onClick?.(e);\n },\n } as ExtendedButtonProps,\n ]\n : [submitButtonProps];\n\n return (\n : undefined}\n >\n {typeof children === 'function' ? children(formRP) : children}\n\n {initialErrors && pristine && (\n {formRP.initialErrors}\n )}\n \n );\n }}\n \n );\n}\n","import React from 'react';\n\nimport {routes} from './routes';\nimport {Link} from '../../components/Link';\n\nexport const bottomText = (credential: string) => (\n

\n Remember your {credential}. Log In\n

\n);\n\nexport const ResendEmail = ({resend}: {resend: React.MouseEventHandler}) => {\n return (\n

\n Didn't receive an email? Resend the email\n

\n );\n};\n","/* eslint-disable @typescript-eslint/no-use-before-define */\nimport React from 'react';\nimport {\n Button,\n ButtonWidth,\n} from '@practicegenius/pg-ui/src/base/Material/components/Button';\nimport {Modal} from '../../../components/Modal/Modal';\nimport {ModalButtons} from '../../../components/Modal/layout';\nimport {Content, Title} from '../../../shared/utils/sharedStyledElements';\n\nconst INVALID_TOKEN_REASONS = Object.freeze({\n INVALID: 'invalid',\n EXPIRED: 'expired',\n});\n\nexport type InvalidTokenReason =\n typeof INVALID_TOKEN_REASONS[keyof typeof INVALID_TOKEN_REASONS];\n\nconst titles: {\n [k in InvalidTokenReason]: string;\n} = {\n [INVALID_TOKEN_REASONS.INVALID]: 'Password Reset Link Invalid',\n [INVALID_TOKEN_REASONS.EXPIRED]: 'Password Reset Link Expired',\n};\n\nconst messages: {\n [k in InvalidTokenReason]: string;\n} = {\n [INVALID_TOKEN_REASONS.INVALID]:\n 'Your password reset link invalid. Please try again with a new link.',\n [INVALID_TOKEN_REASONS.EXPIRED]:\n 'Your password reset link expired. Please try again with a new link.',\n};\n\nexport function InvalidResetTokenModal({\n reason,\n open,\n close,\n}: {\n reason: InvalidTokenReason;\n open: boolean;\n close: () => unknown;\n}) {\n return (\n \n {titles[reason]}\n {messages[reason]}\n\n \n \n \n \n );\n}\n","import * as React from 'react';\nimport path from 'lodash/fp/path';\nimport {RouteChildrenProps} from 'react-router-dom';\nimport {FieldInput} from '@practicegenius/pg-ui/src/base/Material/components/FieldInput';\nimport {FormScreen} from '../../../components/screens/FormScreen';\nimport {EmailInput} from '../../../shared/Material/components/EmailFieldInput';\nimport {bottomText} from '../layout';\nimport {forgotPassword} from '../../../http/login';\nimport {routes} from '../routes';\nimport {useQueryParams} from '../../../utils/custom-hooks';\nimport {\n InvalidTokenReason,\n InvalidResetTokenModal,\n} from './InvalidResetTokenModal';\nimport {queryStringToObject} from '../../../shared/utils/queryParams';\nimport {LoginSupportFooter} from '../../../components/LoginSupportFooter';\n\nexport function ForgotPassword({\n submit,\n history,\n ...otherProps\n}: RouteChildrenProps & {\n submit: (a: any) => Promise;\n}) {\n const params = queryStringToObject();\n const initialLogin = params.user || '';\n const {invalidToken, invalidTokenHint} = useQueryParams<{\n invalidToken?: InvalidTokenReason;\n invalidTokenHint?: string;\n }>();\n\n const [invalidModal, setInvalidModal] = React.useState<\n null | undefined | InvalidTokenReason\n >(invalidToken);\n\n const onSubmit = React.useCallback(\n async (data: {email: string}) => {\n await submit(data);\n history.push(routes.login.forgotPasswordEmailSent, data);\n },\n [submit, history]\n );\n\n return (\n <>\n \n {bottomText('password')}\n \n \n }\n >\n \n \n {invalidModal && (\n setInvalidModal(null)}\n reason={invalidModal}\n />\n )}\n \n );\n}\n\nForgotPassword.defaultProps = {\n submit: forgotPassword,\n};\n","import * as React from 'react';\nimport {useHistory} from 'react-router';\nimport {BaseScreen} from '../../../components/screens/BaseScreen';\nimport {SvgImage} from '../../../components/SvgImage/SvgImage';\nimport {CenteredWrapper} from '../../../components/screens/layout';\nimport {ResendEmail} from '../layout';\nimport {routes} from '../routes';\nimport {forgotPassword} from '../../../http/login';\n\nexport const PasswordEmailSent: React.FC = () => {\n const history = useHistory<{username_or_email: string}>();\n const {username_or_email} = history.location.state;\n return (\n \n We have sent an email to {username_or_email} with\n further instructions.\n \n }\n actionButtons={[\n {onClick: () => history.push(routes.login.index), children: 'Login'},\n ]}\n bottomText={\n forgotPassword({username_or_email})} />\n }\n >\n \n \n \n \n );\n};\n","import * as React from 'react';\nimport {RouteChildrenProps} from 'react-router-dom';\nimport {Field} from '@practicegenius/react-final-form/src/Field';\nimport {FormScreen} from '../../../components/screens/FormScreen';\nimport {bottomText} from '../layout';\nimport {loginWithOauthAccessTokens, resetPassword} from '../../../http/login';\nimport {CreatePasswordInput} from '../../../components/CreatePasswordInput';\nimport {withQueryParams} from '../../../shared/utils/queryParams';\nimport {ValidationError} from '../../../http/exceptions';\nimport {routes} from '../routes';\n\nfunction isInvalidTokenError(error: Error): boolean {\n return error instanceof ValidationError && 'token' in error.errors;\n}\n\nclass ForgotPasswordReset extends React.Component<\n RouteChildrenProps & {\n resetPassword: typeof resetPassword;\n token: string;\n }\n> {\n static defaultProps = {\n resetPassword,\n };\n\n resetPassword = async ({password}: {password: string}) => {\n try {\n const authorization = await this.props.resetPassword({\n password,\n password_confirmation: password,\n token: this.props.token,\n });\n\n const {redirect} = await loginWithOauthAccessTokens(authorization);\n\n this.props.history.push(routes.login.passwordResetSuccess, {redirect});\n } catch (error) {\n if (isInvalidTokenError(error as Error)) {\n throw new ValidationError({\n password:\n 'Invalid password reset link. Please start over and request a new one.',\n });\n }\n\n throw error;\n }\n };\n\n render() {\n return (\n \n \n {({input, meta}) => (\n \n )}\n \n \n );\n }\n}\n\nexport default withQueryParams(({token}) => ({token}))(ForgotPasswordReset);\n","import * as React from 'react';\nimport {RouteChildrenProps} from 'react-router-dom';\nimport {BaseScreen} from '../../../components/screens/BaseScreen';\nimport {CenteredWrapper} from '../../../components/screens/layout';\nimport {SvgImage} from '../../../components/SvgImage/SvgImage';\n\nexport class PasswordResetSuccess extends React.Component<\n RouteChildrenProps<{}, {redirect: string}>\n> {\n getRedirectUrl = (): string => {\n return (this.props.location.state || {}).redirect || '/dashboard';\n };\n\n render() {\n return (\n \n \n \n \n \n );\n }\n}\n","import * as React from 'react';\nimport {RouteChildrenProps} from 'react-router-dom';\nimport path from 'lodash/fp/path';\nimport {FieldInput} from '@practicegenius/pg-ui/src/base/Material/components/FieldInput';\nimport {FormScreen} from '../../../components/screens/FormScreen';\nimport {EmailInput} from '../../../shared/Material/components/EmailFieldInput';\nimport {bottomText} from '../layout';\nimport {forgotUsername} from '../../../http/login';\nimport {routes} from '../routes';\nimport {isEmail} from '../../../utils/string';\nimport {LoginSupportFooter} from '../../../components/LoginSupportFooter';\n\nexport class ForgotUsername extends React.Component<\n RouteChildrenProps & {\n submit: (a: any) => Promise;\n }\n> {\n static defaultProps = {\n submit: forgotUsername,\n };\n\n loginCredential = path(['location', 'state', 'login'], this.props);\n\n onSubmit = async (data: {email: string}) => {\n await this.props.submit(data);\n this.props.history.push(routes.login.forgotUsernameEmailSent, data);\n };\n\n render() {\n return (\n \n {bottomText('username')}\n \n \n }\n >\n \n \n );\n }\n}\n","import * as React from 'react';\nimport {useHistory} from 'react-router';\nimport {BaseScreen} from '../../../components/screens/BaseScreen';\nimport {SvgImage} from '../../../components/SvgImage/SvgImage';\nimport {CenteredWrapper} from '../../../components/screens/layout';\nimport {ResendEmail} from '../layout';\nimport {routes} from '../routes';\nimport {forgotUsername} from '../../../http/login';\n\nexport const UsernameEmailSent: React.FC = () => {\n const history = useHistory<{email: string}>();\n const {email} = history.location.state;\n return (\n \n We have sent an email to {email} with further\n instructions.\n \n }\n actionButtons={[\n {onClick: () => history.push(routes.login.index), children: 'Login'},\n ]}\n bottomText={ forgotUsername({email})} />}\n >\n \n \n \n \n );\n};\n","import React from 'react';\nimport {OauthAuthorizationTokens} from '@practicegenius/register-account/src/data/types';\nimport {usePhpJs} from '../../../utils/php-js';\nimport {BaseScreen} from '../../../components/screens/BaseScreen';\nimport {CenteredWrapper} from '../../../components/screens/layout';\nimport {SvgImage} from '../../../components/SvgImage/SvgImage';\nimport {loginWithOauthAccessTokens} from '../../../http/login';\n\nconst IncompleteRegistration = ({token}: {token?: string}) => (\n \n

The account associated with this email is not set up.

\n

Let's finish registering so you can start earning rewards.

\n \n);\n\nconst AlreadyRegisteredButCannotLogIn = ({\n identifier,\n}: {\n identifier: string;\n}) => (\n \n

You joined RewardsHub with {identifier}. Please use that to log in.

\n \n);\n\nconst AlreadyRegisteredAndCanLogIn = ({\n authorization,\n}: {\n authorization: OauthAuthorizationTokens;\n}) => {\n const goToAccount = async () => {\n try {\n const {redirect} = await loginWithOauthAccessTokens(authorization);\n\n /**\n * Login unfortunately sends down either a fully qualified url with\n * protocol, or a relative url that may be missing the \"/\" prefix.\n */\n window.location.href = /^http/.test(redirect)\n ? redirect\n : `/${redirect}`.replace('//', '/');\n } catch (error) {\n alert('Something went wrong, please try logging in again.');\n\n window.location.href = '/login';\n }\n };\n\n return (\n \n \n \n \n \n );\n};\n\nconst states = {\n INCOMPLETE_REGISTRATION: 'INCOMPLETE_REGISTRATION',\n REGISTERED_BUT_CANNOT_LOG_IN: 'REGISTERED_BUT_CANNOT_LOG_IN',\n REGISTERED_AND_CAN_LOG_IN: 'REGISTERED_AND_CAN_LOG_IN',\n};\n\nconst stateMap = {\n [states.INCOMPLETE_REGISTRATION]: IncompleteRegistration,\n [states.REGISTERED_BUT_CANNOT_LOG_IN]: AlreadyRegisteredButCannotLogIn,\n [states.REGISTERED_AND_CAN_LOG_IN]: AlreadyRegisteredAndCanLogIn,\n};\n\nexport function LegacyContactVerificationLanding() {\n const {state, data} = usePhpJs(\n ({legacyContactVerification: {state, data = {}}}) => ({\n state,\n data,\n })\n );\n\n const Component = stateMap[state];\n\n return ;\n}\n","import {PgForm} from '@practicegenius/domain/src/hooks/usePgForm';\nimport * as R from 'ramda';\nimport * as Yup from 'yup';\nimport React from 'react';\nimport {dropNilOrEmptyValues} from '@practicegenius/pg-util/src/ObjectUtils';\nimport FormHelperText from '@mui/material/FormHelperText';\nimport {InvariantError} from 'ts-invariant';\nimport Box from '@mui/material/Box';\nimport TextField from '@mui/material/TextField';\nimport {format, isValid, parse} from 'date-fns';\nimport FormControl from '@mui/material/FormControl';\nimport InputLabel from '@mui/material/InputLabel';\nimport Select from '@mui/material/Select';\nimport MenuItem from '@mui/material/MenuItem';\nimport {CommonDateFormats} from '@practicegenius/pg-util/src/DateUtils';\n\n/** Representation of a date's components. For maximum flexibility these are internally represented as strings and */\nexport type MemorableDate = {\n month: string;\n day: string;\n year: string;\n};\n\nconst getMonthsForLocale = (locale = navigator.language) => {\n const format = new Intl.DateTimeFormat(locale, {month: 'long'});\n const months = [];\n for (let month = 0; month < 12; month++) {\n const testDate = new Date(0, month, 1, 0, 0, 0);\n months.push(format.format(testDate));\n }\n return months;\n};\n\nconst localeMonths = getMonthsForLocale();\n\nexport const parseMemorableDateFieldsFromDate = (date: Date): MemorableDate =>\n isValid(date)\n ? {\n month: String(date.getMonth() + 1),\n day: String(date.getDate()),\n year: String(date.getFullYear()),\n }\n : {\n month: '',\n day: '',\n year: '',\n };\n\nexport const parseDateFromMemorableDate = (\n memDate: MemorableDate$Form\n): Date | null => {\n const parseValue = (value: string) => parseInt(value, 10);\n const parsed = R.mapObjIndexed(parseValue, R.omit(['composedDate'], memDate));\n if (Object.values(parsed).some(Number.isNaN)) return null;\n\n // Parse the date with date-fns to avoid strange edge cases with the Date constructor (e.g. 2021-02-31 -> 2021-03-03)\n return parse(\n `${parsed.year}-${parsed.month}-${parsed.day}`,\n 'y-M-d',\n new Date()\n );\n};\n\ntype SubfieldProps = {\n value: string;\n name: string;\n onChange: React.ChangeEventHandler;\n onBlur: React.FocusEventHandler;\n /** Subfield errors are joined together if there are multiple */\n error?: string;\n};\ntype MemorableDateInputProps = {\n /** id used as a prefix for subfield ids */\n fieldId: string;\n fields: Record;\n /** A field-level error will only render if no field level errors are present. It's only expected that this will happen for server errors that can't be validated on the client */\n error?: string;\n /** This is added to the month field to inform the user of the date's context */\n monthFieldPrefix?: string;\n};\n\nconst getFieldError = ({\n error,\n fields,\n}: Pick) => {\n const errors = dropNilOrEmptyValues([\n ...Object.values(fields).map(field => field.error),\n ]).filter(Boolean) as string[];\n const hasFieldErrors = errors.length > 0;\n if (!hasFieldErrors) return error;\n return errors.join(', ');\n};\n\n/**\n * A user-friendly input for memorable dates (such as birthdays or anniversaries).\n * This component implements the best practices for prompting users for memorable dates as outlined by the USWDS\n * @see https://designsystem.digital.gov/patterns/create-a-user-profile/date-of-birth/\n */\nexport const MemorableDateInput: React.FC = ({\n fieldId,\n fields,\n error,\n monthFieldPrefix,\n}) => {\n const fieldError = getFieldError({error, fields});\n return (\n \n \n {/* Month Field */}\n {(() => {\n let labelText = 'Month';\n if (monthFieldPrefix) labelText = `${monthFieldPrefix} ${labelText}`;\n\n return (\n \n {labelText}\n \n // @ts-expect-error this works fine but Select's types are a little weird\n fields.month.onChange(e)\n }\n onBlur={fields.month.onBlur}\n error={Boolean(error || fields.month.error)}\n MenuProps={{\n sx: {\n '& .MuiList-root': {\n maxHeight: '280px',\n },\n },\n }}\n >\n {localeMonths.map((label, idx) => {\n const monthNum = String(idx + 1);\n return (\n \n {monthNum} - {label}\n \n );\n })}\n \n \n );\n })()}\n\n {/* Day Field */}\n \n\n {/* Year Field */}\n \n \n {fieldError}\n \n );\n};\n\ntype MemorableDateValidationSchemaInput = {\n /**\n * Add additional validation rules to the composed date\n * @default R.identity\n * */\n enhanceDateSchema?: (input: Yup.DateSchema) => Yup.DateSchema;\n};\n\nconst memorableDateSchema = Yup.object().shape({\n month: Yup.number()\n .typeError('Month must be a number')\n .min(1, 'Month must be greater than 0')\n .max(12, 'Month cannot exceed 12')\n .integer('Month must be a whole number')\n .required('Month is required'),\n day: Yup.number()\n .typeError('Day must be a number')\n .min(1, 'Day must be greater than 0')\n .max(31, 'Day cannot exceed 31')\n .integer('Day must be a whole number')\n .required('Day is required'),\n year: Yup.number()\n .typeError('Year must be a number')\n .min(1000, 'Year must be 4 digits')\n .integer('Year must be a whole number')\n .required('Year is required'),\n});\n\nexport const makeMemorableDateValidationSchema = ({\n enhanceDateSchema = R.identity,\n}: MemorableDateValidationSchemaInput) => {\n const baseDateSchema = Yup.date().typeError('Date is invalid');\n\n return memorableDateSchema.shape({\n composedDate: enhanceDateSchema(baseDateSchema),\n });\n};\n\nexport type MemorableDate$Form = MemorableDate & {\n /** Composed Date is set automatically by FormikMemorableDateInput when all other fields are valid */\n composedDate?: Date;\n};\n\nconst getMemorableDateFieldsPropFromFormik = (\n form: PgForm,\n dateFieldName: string\n): MemorableDateInputProps['fields'] => {\n const value = form.values[dateFieldName];\n if (!value || !('day' in value) || !('month' in value) || !('year' in value))\n throw new InvariantError(\n `${dateFieldName} does not have the expected shape in the form data`\n );\n\n const getSubfieldProps = (subfield: keyof MemorableDate) => {\n const fieldName = `${dateFieldName}.${subfield}`;\n const formikFieldProps = form.getFieldProps(fieldName);\n return {\n ...formikFieldProps,\n onChange: (e: React.ChangeEvent) => {\n const {value} = e.target;\n // Select fields have a different signature and need to be handled differently\n if (subfield === 'month') {\n // Select fields can validate on every change because input is constrained\n return form.setFieldValue(fieldName, value, true);\n }\n\n return formikFieldProps.onChange(e);\n },\n };\n };\n\n return {\n month: getSubfieldProps('month'),\n day: getSubfieldProps('day'),\n year: getSubfieldProps('year'),\n };\n};\n\n// Trying to do equality checks on dates will result in a re-render loop, so we'll build our own comparable version\nconst getComparableDate = (date?: Date | null) => {\n try {\n if (!date) return 'undefined';\n if (!isValid(date)) return 'invalid';\n return format(date, CommonDateFormats['01/20/2020']);\n } catch (e) {\n return 'parseError';\n }\n};\n\nconst withoutComposedDate = R.omit(['composedDate']);\n\n/**\n * A user-friendly input for memorable dates that cleanly integrates into an existing formik (such as birthdays or anniversaries).\n * This component implements the best practices for prompting users for memorable dates as outlined by the USWDS\n * @see https://designsystem.digital.gov/patterns/create-a-user-profile/date-of-birth/\n *\n * When the date components are all valid and parse to a valid date, this sets that date in `form[dateFieldName].composedDate` for convenience\n */\nexport function FormikMemorableDateInput<\n TDateFieldName extends string,\n TFormValue extends Record\n>(\n props: Pick & {\n form: PgForm;\n dateFieldName: TDateFieldName;\n }\n) {\n const {form, dateFieldName, monthFieldPrefix} = props;\n const fieldError = R.path([dateFieldName, 'composedDate'], form.errors) as\n | string\n | undefined;\n\n // When form errors change, check if the composed date should be updated\n // This is necessary because the composed date is derived from the subfields values and errors\n // Trying to do this in the subfield update handler will not have the updated error values\n React.useEffect(() => {\n const updateComposedDateField = (nextDate: Date | null) =>\n form.setFieldValue(\n `${dateFieldName}.composedDate`,\n // ?? is needed to coerce null to undefined\n nextDate ?? undefined,\n true\n );\n\n const fieldValues = form.values[dateFieldName] as MemorableDate$Form;\n const touchedFields = withoutComposedDate(\n // @ts-expect-error\n form.touched[dateFieldName]\n ) as Partial>;\n\n const fieldsAreValid = memorableDateSchema.isValidSync(fieldValues);\n const allFieldsAreTouched = R.equals(touchedFields, {\n day: true,\n month: true,\n year: true,\n });\n const nextComposedDate = parseDateFromMemorableDate(fieldValues);\n const composedDateWouldChange =\n getComparableDate(fieldValues.composedDate) !==\n getComparableDate(nextComposedDate);\n\n // Never update the composed date if it hasn't changed\n if (!composedDateWouldChange) return;\n\n // If all fields are touched, then update the composed date regardless of field-level validity\n if (allFieldsAreTouched) {\n updateComposedDateField(nextComposedDate);\n return;\n }\n\n // If the fields are not all touched, only update the composed date if the fields are valid\n if (fieldsAreValid) {\n updateComposedDateField(nextComposedDate);\n }\n }, [form.values[dateFieldName]]);\n\n return (\n \n );\n}\n","import React from 'react';\nimport {usePgMutationForm} from '@practicegenius/domain/src/hooks/usePgForm';\nimport * as Yup from 'yup';\nimport {assertNever} from '@practicegenius/pg-util/src/TypescriptUtils';\nimport {addQueryParams} from '@practicegenius/pg-util/src/UrlUtils';\nimport {\n Button,\n ButtonVariant,\n} from '@practicegenius/pg-ui/src/base/Material/components/Button';\nimport Typography from '@mui/material/Typography';\nimport Box from '@mui/material/Box';\nimport {styled} from '@mui/material/styles';\nimport {Input} from '@practicegenius/pg-ui/src/base/Material/components/Input';\nimport {objectKeysToCamelCaseDeep} from '@practicegenius/pg-util/src/ObjectUtils';\nimport {UnknownServerData} from '@practicegenius/http-clients-js/src/types';\nimport {SxImg} from '@practicegenius/pg-ui/src/base/Material/components/StyleableBaseComponents';\nimport * as R from 'ramda';\nimport {TemplateLottie} from '@practicegenius/pg-animation/src/Template';\nimport confetti from '@practicegenius/pg-animation/src/lotties/14162-taras-chenenko-success-confetti.json';\nimport {useSnackbar} from 'notistack';\nimport {ValidationException} from '@practicegenius/http-clients-js/src/exceptions';\nimport {useMutation} from '@tanstack/react-query';\nimport {\n FormikMemorableDateInput,\n MemorableDate$Form,\n makeMemorableDateValidationSchema,\n} from '@practicegenius/pg-ui/src/base/Material/components/MemorableDateInput';\nimport {FormikErrors} from 'formik';\nimport {format, subYears} from 'date-fns';\nimport {CommonDateFormats} from '@practicegenius/pg-util/src/DateUtils';\nimport {Link, useHistory} from 'react-router-dom';\nimport {inMobileApp} from '@practicegenius/pg-ui/src/utils/MobileApp';\nimport {usePhpJs} from '../../../utils/php-js';\nimport success from '../../../components/SvgImage/svgs-raw/registrationSuccess.svg';\nimport {TextHr} from '../../../components/TextHr';\nimport {PracticeLogo} from '../../../components/PracticeLogo';\nimport {globalRoutes} from '../../../shared/globalRoutes';\nimport logger from '../../../utils/logger';\nimport {coreApiClient} from '../../../http/httpClientsJs';\nimport {parseCheckInDataFromQueryString} from '../../earn-points/data/checkIn';\nimport {useClearReferrerInSession} from '../../../shared/queries/global';\n\n// TODO this should be considered temporary as an overhaul of all the buttons in sites-dot (at least on the React side) will soon be on the table\n// see https://practicegenius.atlassian.net/browse/PAT-15063\nconst StyledButton = styled(Button)(({theme}) => ({\n height: '56px',\n paddingLeft: theme.spacing(3),\n paddingRight: theme.spacing(3),\n}));\n\nconst NarrowContent = styled(Box)({\n display: 'flex',\n flexDirection: 'column',\n width: '100%',\n maxWidth: '320px',\n});\n\nconst FormInputWrapper = styled(NarrowContent)(({theme}) => ({\n gap: theme.spacing(),\n}));\n\nconst EndButtonsWrapper = styled(NarrowContent)(({theme}) => ({\n gap: theme.spacing(3),\n}));\n\ntype CheckInUserData$Form = {\n firstname: string;\n lastname: string;\n birthdate: MemorableDate$Form;\n};\n\nconst serializeCheckInUserData = (userData: CheckInUserData$Form) => ({\n ...userData,\n birthdate: userData.birthdate.composedDate\n ? format(userData.birthdate.composedDate, CommonDateFormats['2020-01-20'])\n : null,\n});\n\n/**\n * This code is intentionally not human readable to limit the ability of a malicious user to parse a user's existence from the response\n * This comment is stripped out of the bundle for production, so it's safe to decode them here:\n * 0: No User Match\n * 1: Single Unregistered User Match\n * 2: Single Registered User Match\n * 3: Multiple User Matches\n *\n * This corresponds with api-core's UnregisteredUserCheckInCode enum, but it is intentionally not represented as a TS enum\n * to avoid leaking the enum values in the bundle\n */\ntype UnregisteredUserCheckInCode = 0 | 1 | 2 | 3;\n\ntype UnregisteredUserCheckInResponse = {\n code: UnregisteredUserCheckInCode;\n registrationToken?: string;\n /** The amount of points potentially awarded by the scan */\n pointsAward: number;\n};\n\nconst parseUnregisteredUserCheckInResponse = (data: UnknownServerData) =>\n objectKeysToCamelCaseDeep(data) as UnregisteredUserCheckInResponse;\n\ntype ActiveScreen =\n | {\n type: 'entry' | 'form';\n }\n | ({\n type: 'result';\n userFirstname: string;\n } & UnregisteredUserCheckInResponse);\n\nconst ScreenHeading: React.FCC = ({children}) => (\n \n {children}\n \n);\n\nconst EntryScreen: React.FC<{\n onConfirmCheckIn: () => void;\n}> = ({onConfirmCheckIn}) => {\n return (\n <>\n \n How would you like to claim your points today?\n \n \n \n Name and Birthdate\n \n or\n \n Log In\n \n \n \n );\n};\n\nconst checkInFormValidationSchema = Yup.object().shape({\n firstname: Yup.string().required('First Name is required'),\n lastname: Yup.string().required('Last Name is required'),\n birthdate: makeMemorableDateValidationSchema({\n enhanceDateSchema: schema =>\n schema\n .min(\n // Disallow dates more than 130 years in the\n subYears(new Date(), 130),\n 'Birthdate is too far in the past'\n )\n .max(\n // disallow dates in the future\n new Date(),\n 'Birthdate cannot be in the future'\n ),\n }),\n});\n\nconst FormScreen: React.FC<{\n onGoBack: () => void;\n onSubmitSuccess: (result: {\n formData: CheckInUserData$Form;\n response: UnregisteredUserCheckInResponse;\n }) => void;\n checkInType: keyof typeof globalRoutes.points.checkin;\n recipeId: number;\n practiceId: number;\n}> = ({onGoBack, onSubmitSuccess, checkInType, recipeId, practiceId}) => {\n const router = useHistory();\n const {enqueueSnackbar} = useSnackbar();\n const checkInMutation = useMutation({\n mutationFn: (userInfo: CheckInUserData$Form) =>\n coreApiClient._unsafe\n .post(`/user/check-in/${checkInType}`, {\n practice_id: practiceId,\n recipe_id: recipeId,\n user_data: serializeCheckInUserData(userInfo),\n })\n .then(response => ({\n formData: userInfo,\n response: parseUnregisteredUserCheckInResponse(response.data),\n })),\n });\n\n const formik = usePgMutationForm({\n formikConfig: {\n initialValues: {\n firstname: '',\n lastname: '',\n birthdate: {\n day: '',\n month: '',\n year: '',\n },\n } as CheckInUserData$Form,\n validationSchema: checkInFormValidationSchema,\n validateOnChange: false,\n onSubmit: form => {\n checkInMutation.mutate(form);\n },\n },\n mutationResult: checkInMutation,\n onSubmitSuccess,\n transformServerErrors: err => {\n return R.applySpec({\n firstname: R.path(['user_data.firstname', 0]),\n lastname: R.path(['user_data.lastname', 0]),\n birthdate: {\n composedDate: R.path(['user_data.birthdate', 0]),\n },\n })(err) as FormikErrors;\n },\n onSubmitError: err => {\n if (err instanceof ValidationException) {\n // If recipe_id is in validation errors, then we must be on an invalid recipe\n if ('recipe_id' in err.errors) router.replace(globalRoutes.login.index);\n } else {\n logger.error(\n 'Got an unexpected error when attempting unauthenticated user check-in',\n err\n );\n const message =\n err instanceof Error ? err.message : 'An error occurred';\n enqueueSnackbar(message, {\n variant: 'error',\n });\n }\n },\n });\n\n return (\n \n Claim with your Name and Birthday\n \n \n\n \n \n \n \n \n Submit\n \n \n Back\n \n \n \n );\n};\n\nconst makeRegistrationLinkWithToken = (token: string) =>\n addQueryParams(globalRoutes.account.register.RegistrationMethods, {\n token,\n });\n\nconst SuccessGraphic = () => {\n const [showAnimation, setShowAnimation] = React.useState(false);\n\n return (\n \n {showAnimation && (\n \n \n \n )}\n setShowAnimation(true)}\n />\n \n );\n};\n\nconst CheckInResultScreen: React.FC> =\n ({userFirstname, pointsAward, registrationToken, code}) => {\n const verified = code !== 3;\n return (\n \n \n <>\n Hi {userFirstname} 👋\n \n {verified\n ? `You scanned the QR code for ${pointsAward} points!`\n : \"We couldn't verify your account\"}\n \n \n {verified\n ? \"If eligible, they'll appear in your account soon. Log in or sign up to see your points.\"\n : `Please contact ${window.phpJs.practice.practice_name} for help.`}\n \n {verified && (\n \n \n \n )}\n \n \n\n \n {(() => {\n const makeButtonText = (text: string) =>\n `${text}${verified ? ' To View Points' : ''}`;\n\n const {primaryButtonProps, secondaryButtonProps} = registrationToken\n ? ({\n primaryButtonProps: {\n href: makeRegistrationLinkWithToken(registrationToken),\n children: makeButtonText('Sign Up'),\n },\n secondaryButtonProps: {\n variant: ButtonVariant.text,\n children: 'Exit and Sign Up Later',\n },\n } as const)\n : ({\n primaryButtonProps: {\n component: Link,\n children: makeButtonText('Log In'),\n to: {\n pathname: globalRoutes.login.index,\n state: {\n showBackButton: true,\n },\n },\n },\n secondaryButtonProps: {\n variant: ButtonVariant.outlined,\n children: 'Done',\n },\n } as const);\n\n return (\n <>\n \n \n \n );\n })()}\n \n \n );\n };\n\nexport const UnauthenticatedCheckIn = () => {\n const {practice_id: practiceId} = usePhpJs(x => x.practice) as {\n practice_id: number;\n practice_name: string;\n };\n\n const checkIn = React.useMemo(\n () => parseCheckInDataFromQueryString(window.location.search),\n []\n );\n\n // Setup initial state\n const [activeScreen, setActiveScreen] = React.useState({\n type: 'entry',\n });\n const clearReferrerInSession = useClearReferrerInSession();\n\n // If checkIn data did not parse or practice id does not correspond to a real practice then redirect to the login form\n if (!checkIn || practiceId <= 0) {\n window.location.href = '/login';\n return null;\n }\n\n return (\n \n \n {\n // While not in the mobile app this logo is rendered by the Kohana layout\n inMobileApp && (\n \n )\n }\n {(() => {\n switch (activeScreen.type) {\n case 'entry':\n return (\n setActiveScreen({type: 'form'})}\n />\n );\n case 'form':\n return (\n setActiveScreen({type: 'entry'})}\n onSubmitSuccess={({formData, response}) => {\n // Usually when a scan lands on this page they will have been redirected to this landing page\n // and the actual check-in page will be there referrer in the session.\n\n // We want to leave this referrer in place if a user is unregistered because this scan\n // does not award them any points.\n\n // However, a single matched user will be awarded points by entering their information.\n // If the entered info matches a user, we want to clear this referrer so that when the user logs in\n // or registers they won't see the points screen again (which would trigger another check-in attempt)\n if (response.code !== 0) {\n clearReferrerInSession.mutate();\n }\n\n return setActiveScreen({\n type: 'result',\n userFirstname: formData.firstname,\n ...response,\n });\n }}\n />\n );\n case 'result':\n return ;\n\n default:\n assertNever(activeScreen);\n }\n })()}\n \n \n );\n};\n","import * as React from 'react';\nimport {\n BrowserRouter as Router,\n Redirect,\n Route,\n Switch,\n Link,\n} from 'react-router-dom';\nimport {Box} from '@mui/material';\nimport {useSecretMobileUtilityMenu} from '@practicegenius/pg-ui/src/hooks/useSecretMobileUtilityMenu';\nimport {postMessageToMobileApp} from '@practicegenius/pg-ui/src/utils/MobileApp';\nimport {inferServiceBrandFromWindow} from '@practicegenius/domain/src/data/serviceBrand';\nimport Login from './screens/Login';\nimport {Home} from './screens/Home';\nimport {ForgotPassword} from './screens/ForgotPassword';\nimport {PasswordEmailSent} from './screens/PasswordEmailSent';\nimport ForgotPasswordReset from './screens/ForgotPasswordReset';\nimport {PasswordResetSuccess} from './screens/PasswordResetSuccess';\nimport {ForgotUsername} from './screens/ForgotUsername';\nimport {UsernameEmailSent} from './screens/UsernameEmailSent';\nimport {routes} from './routes';\nimport {LegacyContactVerificationLanding} from './screens/LegacyContactVerificationLanding';\nimport {UnauthenticatedStandardProvider} from '../../components/StandardProvider';\nimport {UnauthenticatedCheckIn} from './screens/UnauthenticatedCheckIn';\n\n/**\n * The Home app provides most of the UI for the unauthenticated portion of sites dot. The exceptions are:\n * - account registration\n * - promotions\n *\n * There is not a huge appetite to refactor those apps into this one with the idea of a Next.js migration on the horizon.\n */\nexport default function App() {\n const utilityMenu = useSecretMobileUtilityMenu({\n practiceInfo: {\n id: window.phpJs.practice.practice_id,\n hubUrl: window.location.origin,\n practiceFeatures: window.phpJs.practiceFeatures,\n },\n });\n const serviceBrand = inferServiceBrandFromWindow();\n\n // Let the mobile app know that the user is not authenticated\n React.useEffect(() => {\n postMessageToMobileApp({\n type: 'notify_user_authenticated_status',\n payload: {\n authenticated: false,\n },\n });\n }, []);\n\n return (\n \n \n \n \n \n {(\n [\n [\n routes.index,\n () => (\n \n ),\n ],\n [routes.checkin, UnauthenticatedCheckIn],\n [routes.login.index, Login],\n [routes.login.forgotUsername, ForgotUsername],\n [routes.login.forgotUsernameEmailSent, UsernameEmailSent],\n [routes.login.forgotPassword, ForgotPassword],\n [routes.login.forgotPasswordEmailSent, PasswordEmailSent],\n [routes.login.resetPassword, ForgotPasswordReset],\n [routes.login.passwordResetSuccess, PasswordResetSuccess],\n\n // Temporary: A little landing page for legacy contact verification emails.\n [\n routes.login.legacyContactVerification,\n LegacyContactVerificationLanding,\n ],\n ] as [string, React.ComponentType][]\n ).map(([path, Component]) => (\n \n ))}\n \n \n \n {utilityMenu.displayMenu && (\n <>\n theme.spacing(2),\n right: theme => theme.spacing(2),\n width: '60px',\n height: '60px',\n }}\n onClick={utilityMenu.incrementTickCount}\n />\n {utilityMenu.dialog}\n \n )}\n \n );\n}\n","/* eslint-disable @typescript-eslint/no-use-before-define */\nimport './Modal.scss';\nimport cn from 'classnames';\nimport * as React from 'react';\n// @ts-expect-error\nimport ReactModal from 'react-modal';\nimport {styled} from '@mui/material/styles';\nimport {BREAKPOINTS} from '../../constants/layout';\nimport {EscapeX} from './ui';\n\n// See http://reactcommunity.org/react-modal/accessibility/\nReactModal.setAppElement('body');\n\ntype ModalProps = {\n children: React.ReactNode;\n close: () => void;\n} & React.ComponentProps;\n\nconst ResponsiveModal = styled(ReactModal)({\n [`@media (max-width: ${BREAKPOINTS.MEDIUM})`]: {\n width: '100%',\n minHeight: '100%',\n margin: 0,\n borderRadius: 0,\n },\n});\n\nexport function Modal({children, className, noEsc, ...props}: ModalProps) {\n return (\n \n {!noEsc && (\n \n )}\n {children}\n \n );\n}\n","import {styled} from '@mui/material/styles';\nimport {Box} from '@mui/material';\n\nexport const ModalButtons = styled(Box)({\n display: 'flex',\n justifyContent: 'center',\n marginTop: 25,\n\n '& button:first-child': {\n marginRight: 15,\n },\n});\n","import * as React from 'react';\nimport './Modal.scss';\nimport {styled} from '@mui/material/styles';\nimport {TextButton} from '../TextButton';\n\nexport const ModalTitle = styled('h3')({\n lineHeight: '40px',\n margin: 0,\n});\n\nexport const ModalContent = styled('div')({\n marginTop: '20px',\n textAlign: 'center',\n color: '#474747',\n});\n\nconst BlackX = styled(TextButton)({\n color: 'black',\n cursor: 'pointer',\n fontSize: '20px',\n fontWeight: 500,\n});\n\nconst ModalHeaderBar = styled('div')({\n display: 'flex',\n justifyContent: 'space-between',\n alignItems: 'center',\n borderRadius: '7px 7px 0 0',\n backgroundColor: '#f1f2f2',\n fontSize: '20px',\n color: 'var(--template-color-2)',\n\n '& > span': {\n fontSize: '25px',\n },\n});\n\nexport const EscapeX: React.FC<{\n close: () => unknown;\n style?: React.CSSProperties;\n}> = ({close, ...props}) => (\n \n ✕\n \n);\n\nexport const ModalHeader = ({children}: {children: React.ReactNode}) => (\n {children}\n);\n","import React from 'react';\nimport * as R from 'ramda';\nimport {MuiSxProps} from '@practicegenius/pg-ui/src/base/Material/utils/sx-helpers';\nimport {SxImg} from '@practicegenius/pg-ui/src/base/Material/components/StyleableBaseComponents';\nimport {makeGetPracticeLogoUrl} from '@practicegenius/domain/src/data/practice';\nimport {useIsAuthenticated} from './AuthenticationContext';\nimport {useActivePractice} from '../shared/hooks/useActivePractice';\nimport {PG_CORE_URL} from '../constants/env';\nimport {usePhpJs} from '../utils/php-js';\n\ntype Props = {\n sx?: MuiSxProps;\n /** override the default alt text */\n alt?: string;\n};\n\nconst DEFAULT_PRACTICE_ALT_TEXT = 'Practice Logo';\nexport const getPracticeLogoUrl = makeGetPracticeLogoUrl({\n coreServiceUrl: PG_CORE_URL,\n});\n\nconst UnauthenticatedPracticeLogo: React.FC = ({sx, alt}) => {\n // TODO When we introduce Next.js to the project I expect that we'll scope this even farther:\n // UnauthenticatedKohanaPracticeLogo and UnauthenticatedNextPracticeLogo.\n const practiceId = usePhpJs(R.pathOr(0, ['practice', 'practice_id']));\n return (\n \n );\n};\n\nconst AuthenitcatedPracticeLogo: React.FC = ({sx, alt}) => {\n const practice = useActivePractice();\n return (\n \n );\n};\n\n/** Renders a stylable logo for the current practice. If there is no practice, no logo will render */\nexport const PracticeLogo: React.FC = props => {\n const isAuthenticated = useIsAuthenticated();\n\n return isAuthenticated ? (\n \n ) : (\n \n );\n};\n","import {makeNoAuthApiClient} from '@practicegenius/http-clients-js/src/ApiClient';\nimport {PG_CORE_URL} from '../constants/env';\n\nexport const coreApiClient = makeNoAuthApiClient({\n baseURL: PG_CORE_URL,\n});\n","import {SocialAuthIntegration} from '@practicegenius/domain/src/data/integrations';\n\nexport const platformLabels: {\n [k in SocialAuthIntegration]: string;\n} = {\n facebook: 'Facebook',\n google: 'Google',\n apple: 'Apple',\n};\n","import {Practice} from '@practicegenius/domain/src/data/practice';\nimport {useUserProfile} from '../../components/UserProfileProvider';\nimport {useApi} from '../../http/AuthApiProvider';\n\n/**\n * In theory, we should be able to fetch this statically from the subdomain in the host header\n * We don't currently have that ability at hand, so this uses the practice id from the core JWT\n */\n/** Get the Practice info for the currently-logged-in practice */\nexport const useActivePractice = (): Practice => {\n const {practices} = useUserProfile();\n const {decodedToken} = useApi();\n\n const practice = practices.find(p => p.id === decodedToken.practiceId);\n if (!practice)\n throw new Error(\n 'Not able to find an entry for the current practice in the user profile!'\n );\n\n return practice;\n};\n","import * as React from 'react';\nimport qs from 'qs';\n\nexport function queryStringToObject(): any {\n return qs.parse(window.location.search.slice(1));\n}\n\n/**\n * @deprecated Use a hook for this instead\n */\nexport const withQueryParams =\n (parseQueryParams: (a: any) => any) =>\n (\n Inner: React.ComponentType\n ): React.ComponentType> => {\n return props => (\n \n );\n };\n","import * as R from 'ramda';\nimport {CountryCode} from '@practicegenius/countries/src/types';\nimport {\n ApiClient,\n UnknownServerData,\n} from '@practicegenius/http-clients-js/src/types';\nimport {objectKeysToCamelCaseDeep} from '@practicegenius/pg-util/src/ObjectUtils';\nimport {setType} from '@practicegenius/pg-util/src/TypescriptUtils';\nimport {pipe} from '@practicegenius/pg-util/src/FunctionUtils';\nimport {addQueryParams} from '@practicegenius/pg-util/src/UrlUtils';\nimport {parseIsoOrNull} from '@practicegenius/pg-util/src/DateUtils';\nimport {Flavor} from './flavor';\nimport {ServiceBrand} from './serviceBrand';\nimport {MembershipType} from './membershipType';\n\nexport type PracticeType = 'dental' | 'ortho' | 'education';\nexport type PracticeStatus =\n | 'live'\n | 'training'\n | 'postTraining'\n | 'demo'\n | 'disabled'\n | 'deleted';\n\nexport type PracticeFeature =\n | 'login_only'\n | 'user_parent_accounts'\n | 'communication_manager'\n | 'sites_accessible_by_team_member'\n | 'referral_manager'\n | 'promotions'\n | 'contests_beta'\n | 'duplicate_manager'\n | 'analytics_dummy_data'\n | 'global_user_beta'\n | 'home_page_alerts_beta'\n | 'automation_manager'\n | 'automation_manager_beta'\n | 'reviews_automation_beta'\n | 'instagram'\n | 'hubbux_teams_beta'\n | 'sweepstakes_beta'\n | 'registration_invite_beta'\n | 'stock_image_cms_beta'\n | 'reactions_comments_beta'\n | 'recognition_giphy_beta'\n | 'hide_non_admin_redeem_beta'\n | 'add_updated_members_table'\n | 'internal_analytics_beta'\n | 'try_members_app'\n | 'members_app_beta'\n | 'identity_service_beta'\n | 'generic_posts_beta'\n | 'global_staff_beta'\n | 'account_billing_beta';\n\nexport type PracticeSegmentIdentifier =\n | 'dental'\n | 'ortho'\n | 'education'\n | 'medical'\n | 'physical_therapy'\n | 'teams'\n | 'chiropractic'\n | 'optometry';\n\nexport type PracticeSegment = {\n id: number;\n flavor: Flavor;\n identifier: PracticeSegmentIdentifier;\n label: string;\n};\n\ntype LinkedPracticeType = 'business' | 'teams';\ntype LinkedPractice = {\n /** practiceId of the linked practice */\n id: number;\n /** Fully Qualified logo to the URL image */\n logo: string;\n name: string;\n serviceBrand: ServiceBrand;\n membershipType: MembershipType;\n segment: PracticeSegment;\n};\n\nexport type Practice = {\n id: number;\n businessCode: string;\n uri: string;\n hubUrl: string;\n name: string;\n type: PracticeType;\n serviceBrand: ServiceBrand;\n membershipType: MembershipType;\n status: PracticeStatus;\n website: string;\n phone: string;\n email: string;\n timeZone: string;\n appointmentsEnabled: boolean;\n logo: string;\n logoAlternate: string;\n rewardCard: string;\n colors: {\n color1: string;\n color2: string;\n color3: string;\n color4: string;\n color5: string;\n color6: string;\n color7: string;\n color8: string;\n color9: string;\n color10: string;\n color11: string;\n };\n practiceFeatures: PracticeFeature[];\n hasPmsIntegration: boolean;\n segment: PracticeSegment;\n linkedPractices?: Partial>;\n country: CountryCode;\n software: string | null;\n startedAt: Date | null;\n};\n\nexport type PracticeOffice = {\n id: number;\n name: string;\n addressLine1: string;\n addressLine2: string;\n city: string;\n state: string;\n zip: string;\n country: CountryCode;\n};\n\nexport type PracticeLocation = PracticeOffice & {\n geometry: {\n location: {\n lat: number;\n lng: number;\n };\n viewport: {\n south: number;\n west: number;\n north: number;\n east: number;\n };\n };\n};\n\nexport type PracticeReview = {\n id: number;\n reviewUrl: string;\n practiceId: number;\n locationId: number;\n userId: number;\n rating: number;\n message: string;\n featured: boolean;\n status: 'unpublished' | 'published';\n createdAt: Date;\n};\n\nexport const transformPracticeOffices: (\n data: UnknownServerData\n) => PracticeOffice[] = R.pipe(\n R.pipe(R.propOr({}, 'items'), objectKeysToCamelCaseDeep),\n setType()\n);\n\n/** Pull linked practices from response meta and attach it to the main entity */\nconst parseLinkedPractices = (data: UnknownServerData) => {\n const {item, meta} = data;\n const linkedPractices: Practice['linkedPractices'] = {};\n\n if (meta?.teamAccount) linkedPractices.teams = meta.teamAccount;\n if (meta?.businessAccount) linkedPractices.business = meta.businessAccount;\n\n return R.isEmpty(linkedPractices)\n ? item\n : {\n ...item,\n linkedPractices,\n };\n};\n\nexport const transformPractice = pipe(\n R.pick(['item', 'meta']),\n objectKeysToCamelCaseDeep,\n R.evolve({item: {startedAt: parseIsoOrNull}}),\n parseLinkedPractices\n);\n\nexport const fetchRawPractice =\n (coreAuth: ApiClient) =>\n ({practiceId}: {practiceId: number}) =>\n coreAuth._unsafe\n .get(`/practices/${practiceId}`)\n .then(x => x.data as UnknownServerData);\n\n/**\n * Is the practice of the given flavor?\n *\n * @deprecated\n */\nexport const practiceIsFlavor = R.curry(\n (flavor: Flavor, p: Practice) => p.segment.flavor === flavor\n);\n/** Is the practice of the given brand? */\nexport const practiceIsServiceBrand = R.curry(\n (serviceBrand: ServiceBrand, p: Practice) => p.serviceBrand === serviceBrand\n);\n/** Is the practice of the given segment? */\nexport const practiceIsSegment = R.curry(\n (segment: PracticeSegmentIdentifier, p: Practice) =>\n p.segment.identifier === segment\n);\n/** Does the practice have a linkage to another practice of the given type? */\nexport const practiceHasLinkToType = R.curry(\n (type: LinkedPracticeType, p: Practice) => Boolean(p.linkedPractices?.[type])\n);\n\n/** Is the given practice a Teams account? */\nexport const practiceIsHubbuxTeams = (practice: Practice) =>\n practice.membershipType === 'employees';\n\n/** Make a getter for the URL for a given practice's logo */\nexport type PracticeLogoUrlOptions = Partial<{\n width: number;\n pixelDensity: number;\n trimWhiteSpace: boolean;\n}>;\n\nexport const makeGetPracticeLogoUrl =\n (config: {coreServiceUrl: string}) =>\n (practiceId: number, options: PracticeLogoUrlOptions = {}) => {\n const logoBaseUrl = `${config.coreServiceUrl}/practices/${practiceId}/logo`;\n\n if (R.isEmpty(options)) return logoBaseUrl;\n\n const params: Record = {};\n if (options.width) {\n params.w = options.width;\n if (options.pixelDensity) params.w *= options.pixelDensity;\n }\n if (options.trimWhiteSpace) params.trimaway = 'true';\n\n return addQueryParams(\n `${config.coreServiceUrl}/practices/${practiceId}/logo`,\n params\n );\n };\n","import React from 'react';\nimport * as R from 'ramda';\nimport {\n FormikConfig,\n FormikValues,\n FormikErrors,\n useFormik,\n FormikTouched,\n FormikState,\n FieldInputProps,\n FieldMetaProps,\n FieldHelperProps,\n} from 'formik';\nimport {UseMutationResult} from '@tanstack/react-query';\nimport {UnknownServerData} from '@practicegenius/http-clients-js/src/types';\nimport {ValidationException} from '@practicegenius/http-clients-js/src/exceptions';\nimport {voidOp} from '@practicegenius/pg-util/src/TypescriptUtils';\nimport {objectKeysToCamelCaseDeep} from '@practicegenius/pg-util/src/ObjectUtils';\nimport {pipe} from '@practicegenius/pg-util/src/FunctionUtils';\nimport {ZodError} from 'zod';\n\n/** This is a copy-paste of Formik's definition of the return type of `useFormik`\n * It's copy-pasted because it's not a named type in their library, and we really need a\n * direct definition of it so we can do our shenanigans with the generics.\n */\nexport type PgForm = {\n initialValues: Values;\n initialErrors: FormikErrors;\n initialTouched: FormikTouched;\n initialStatus: any;\n handleBlur: {\n (e: React.FocusEvent): void;\n (fieldOrEvent: T): T extends string ? (e: any) => void : void;\n };\n handleChange: {\n (e: React.ChangeEvent): void;\n >(\n field: T_1\n ): T_1 extends React.ChangeEvent\n ? void\n : (e: string | React.ChangeEvent) => void;\n };\n handleReset: (e: any) => void;\n handleSubmit: (e?: React.FormEvent | undefined) => void;\n resetForm: (nextState?: Partial> | undefined) => void;\n setErrors: (errors: FormikErrors) => void;\n setFormikState: (\n stateOrCb:\n | FormikState\n | ((state: FormikState) => FormikState)\n ) => void;\n setFieldTouched: (\n field: string,\n touched?: boolean,\n shouldValidate?: boolean | undefined\n ) => any;\n setFieldValue: (\n field: string,\n value: any,\n shouldValidate?: boolean | undefined\n ) => any;\n setFieldError: (field: string, value: string | undefined) => void;\n setStatus: (status: any) => void;\n setSubmitting: (isSubmitting: boolean) => void;\n setTouched: (\n touched: FormikTouched,\n shouldValidate?: boolean | undefined\n ) => any;\n setValues: (values: Values, shouldValidate?: boolean | undefined) => any;\n submitForm: () => Promise;\n validateForm: (values?: Values) => Promise>;\n validateField: (name: string) => Promise | Promise;\n isValid: boolean;\n dirty: boolean;\n unregisterField: (name: string) => void;\n registerField: (name: string, {validate}: any) => void;\n getFieldProps: (\n nameOrOptions: any\n ) => FieldInputProps & {error: string | undefined};\n getFieldMeta: (name: string) => FieldMetaProps;\n getFieldHelpers: (name: string) => FieldHelperProps;\n validateOnBlur: boolean;\n validateOnChange: boolean;\n validateOnMount: boolean;\n values: Values;\n errors: FormikErrors;\n touched: FormikTouched;\n isSubmitting: boolean;\n isValidating: boolean;\n status?: any;\n submitCount: number;\n};\n\ntype Props = {\n formikConfig: FormikConfig;\n /**\n * The value returned by `useMutation()` from react-query\n */\n mutationResult: UseMutationResult<\n TResultData,\n TResultError,\n TMutationVariables\n >;\n /**\n * Called when the form submission is successful\n */\n onSubmitSuccess?: (\n data: TResultData,\n formik: PgForm,\n mutationResult: UseMutationResult<\n TResultData,\n TResultError,\n TMutationVariables\n >\n ) => void;\n /**\n * Called when the form submission fails. This hook already integrates server-side validation errors\n * with Formik, so this only needs to do form-specific work.\n */\n onSubmitError?: (\n error: TResultError | null,\n formik: PgForm,\n mutationResult: UseMutationResult<\n TResultData,\n TResultError,\n TMutationVariables\n >\n ) => void;\n\n transformServerErrors?: (\n errors: UnknownServerData\n ) => FormikErrors;\n};\n\nexport type PgFormFieldProps = FieldInputProps & {\n error: string | undefined;\n};\n\n/**\n * This hook is effectively a lightweight wrapper around formik\n * It has the exact same signature as the `useFormik`, except for a\n * slightly-enhanced `getFieldProps` helper that includes an error prop.\n * This builds in our desired UX of not showing any field-level errors\n * unless that field has been touched.\n */\nexport function usePgForm(\n config: FormikConfig\n): PgForm {\n const formik = useFormik(config);\n\n // This enhances `formik.getFieldProps` by adding an 'error' prop\n // that is only defined if the field has been touched\n const getFieldProps = (field: keyof TFormValue) => {\n const {error, touched} = formik.getFieldMeta(field as string);\n\n return {\n error: touched ? error : undefined,\n ...formik.getFieldProps(field as string),\n } as PgFormFieldProps;\n };\n\n // We only want to consider errors on fields that have been touched\n const errorsOnTouchedFields = R.pick(\n R.keys(formik.touched),\n formik.errors\n ) as FormikErrors;\n\n // setFieldValue doesn't set fields to Touched\n const setFieldValue: typeof formik.setFieldValue = async (...args) => {\n formik.setFieldValue(...args);\n formik.setFieldTouched(args[0], true, false);\n };\n\n return {\n ...formik,\n getFieldProps,\n errors: errorsOnTouchedFields,\n setFieldValue,\n };\n}\n\n/** Extract field-level validation errors from typical 422 response from api-core */\nexport function parseLaravelValidationErrorsForFormik<\n T = Record\n>(data: UnknownServerData): FormikErrors {\n return pipe>(objectKeysToCamelCaseDeep, R.map(R.head))(data);\n}\n\nexport function parseZodErrorsForFormik>(\n errors: ZodError['errors']\n): FormikErrors {\n return errors.reduce((acc, error) => {\n return R.assocPath(error.path, error.message, acc);\n }, {});\n}\n\n/**\n * Does the bulk of the work to integrate a formik instance and a mutation from react-query\n *\n * This hook is an extension of `usePgForm` that aims to be a more complete solution.\n * It accepts the result of a `useMutation` from react-query and sets up an effect that\n * simplifies getting it to work well with formik.\n */\nexport function usePgMutationForm<\n TFormValue extends FormikValues,\n TResultData,\n TResultError,\n TMutationVariables\n>({\n formikConfig,\n mutationResult,\n onSubmitSuccess = voidOp,\n onSubmitError = voidOp,\n transformServerErrors,\n}: Props<\n TFormValue,\n TResultData,\n TResultError,\n TMutationVariables\n>): PgForm {\n const formik = usePgForm(formikConfig);\n React.useEffect(() => {\n switch (mutationResult.status) {\n case 'success': {\n // Set the internal form status to success, which the discard dialog uses\n // to unblock navigation\n formik.setStatus('success');\n // Defer excuting the success callback to the next tick so the formik status\n // will definitely be updated.\n setTimeout(\n () => onSubmitSuccess(mutationResult.data, formik, mutationResult),\n 0\n );\n return;\n }\n\n case 'error': {\n // Formik requires manually setting this\n formik.setSubmitting(false);\n const {error} = mutationResult;\n\n if (error instanceof ValidationException) {\n formik.setErrors(\n transformServerErrors\n ? transformServerErrors(error.errors)\n : parseLaravelValidationErrorsForFormik(error.errors)\n );\n }\n\n return onSubmitError(error, formik, mutationResult);\n }\n\n default:\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [mutationResult.status, formik.setErrors, formik.setStatus]);\n\n return formik;\n}\n\n/**\n * Wraps around getFieldProps for a simple text input.\n * The yielded value is updated immediately for maximum responsiveness, but the\n * call to the formik onChange is debounced so we don't pay the high cost of\n * full form validation with every input change.\n */\nexport const useDebouncedInputProps = (\n {value, onChange, ...rest}: PgFormFieldProps,\n debounceTimeMs = 250\n): PgFormFieldProps => {\n /** We capture the incoming change events from the input so we can make the debounced call to onChange */\n const [changeEvent, setChangeEvent] =\n React.useState | null>(null);\n\n /** Debounce calls to `props.onChange` for the given debounceTime */\n React.useEffect(() => {\n const handler = setTimeout(() => {\n if (onChange && changeEvent) {\n onChange(changeEvent);\n }\n }, debounceTimeMs);\n\n return () => {\n clearTimeout(handler);\n };\n }, [changeEvent]);\n\n return {\n // Return the value from the last change event if we have it\n value: changeEvent?.target.value ?? value,\n onChange: setChangeEvent,\n ...rest,\n };\n};\n","import React from 'react';\nimport Lottie from 'react-lottie';\n\ntype Props = {\n animationData: unknown;\n height?: number;\n width?: number;\n isClickToPauseDisabled?: boolean;\n options?: Partial['options']>;\n};\n\nexport type ImplementerProps = Omit;\n\nexport const TemplateLottie: React.FC = ({\n options,\n isClickToPauseDisabled = true,\n animationData,\n ...otherProps\n}) => {\n const mergedOptions = {\n rendererSettings: {\n preserveAspectRatio: 'xMidYMid slice',\n },\n autoplay: true,\n loop: false,\n ...options,\n animationData,\n };\n\n return (\n \n );\n};\n","import {styled} from '@mui/material';\n\n/** An unstyled div element that can take the sx prop */\nexport const SxDiv = styled('div')({});\n/** An unstyled span element that can take the sx prop */\nexport const SxSpan = styled('span')({});\n/** An unstyled img element that can take the sx prop */\nexport const SxImg = styled('img')({});\n/** An unstyled 'a' element that can take the sx prop */\nexport const SxAnchor = styled('a')({});\n/** An unstyled section element that can take the sx prop */\nexport const SxSection = styled('section')({});\n","import React from 'react';\nimport {assertNever} from '@practicegenius/pg-util/src/TypescriptUtils';\nimport {\n makeChannelUpdateMessage,\n AppToSitesMessage,\n} from '@practicegenius/domain/src/sites-mobile-app/messages';\nimport {inMobileApp, postMessageToMobileApp} from '../utils/MobileApp';\n\n/** Ask mobile app for debug info */\nexport const useAppDebugInfo = () => {\n const [debugInfo, setDebugInfo] = React.useState(null);\n\n React.useEffect(() => {\n if (!inMobileApp) return;\n\n postMessageToMobileApp(makeChannelUpdateMessage('debug', true));\n postMessageToMobileApp({\n type: 'request_app_debug_info',\n });\n\n const handleMobileAppEvent = async (event: MessageEvent) => {\n if (typeof event.data !== 'string') return;\n\n try {\n // TODO We need a more reliable way to parse events from the mobile app such that new additions to sites-dot don't cause this logic to choke\n const data = JSON.parse(event.data) as AppToSitesMessage;\n\n if (data.channel !== 'debug') return;\n\n switch (data.type) {\n case 'receive_app_debug_info':\n return setDebugInfo(data.payload);\n\n default:\n assertNever(data);\n }\n } catch (e) {\n // This might handle messages from other sources and they might not be JSON, so we need to ignore them\n if (e instanceof SyntaxError) {\n // JSON failed to parse, so it must not be a known message\n return;\n }\n\n // otherwise, the error is unexpected and should be thrown\n throw e;\n }\n };\n\n window.addEventListener('message', handleMobileAppEvent, true);\n return () => {\n window.removeEventListener('message', handleMobileAppEvent, true);\n postMessageToMobileApp(makeChannelUpdateMessage('debug', false));\n };\n }, []);\n\n return debugInfo;\n};\n","import React from 'react';\nimport {PracticeFeature} from '@practicegenius/domain/src/data/practice';\nimport Dialog from '@mui/material/Dialog';\nimport DialogTitle from '@mui/material/DialogTitle';\nimport {useTickerAction} from '@practicegenius/domain/src/hooks/useTickerAction';\nimport List from '@mui/material/List';\nimport ListItem from '@mui/material/ListItem';\nimport ListItemButton from '@mui/material/ListItemButton';\nimport {useAppDebugInfo} from './useAppDebugInfo';\nimport {inMobileApp, postMessageToMobileApp} from '../utils/MobileApp';\n\ntype PracticeInfo = {\n id: number;\n hubUrl: string;\n practiceFeatures: PracticeFeature[];\n};\n\ntype Props = {\n practiceInfo?: PracticeInfo;\n authenticated?: true;\n inNewApp?: true;\n};\n\nconst useSwapAppMenuItem = ({\n practiceInfo: practice,\n inNewApp,\n}: Props): JSX.Element | null => {\n if (!practice || !practice.practiceFeatures.includes('try_members_app'))\n return null;\n\n const itemHref = (() => {\n if (inNewApp) return practice.hubUrl;\n\n const membersHref = practice.hubUrl.replace(\n /^https?:\\/\\/[^.]+/,\n 'https://members'\n );\n const membersUrl = new URL(membersHref);\n membersUrl.searchParams.set('bid', practice.id.toString());\n\n return membersUrl.toString();\n })();\n\n return (\n \n \n Swap to {inNewApp ? 'Old' : 'New'} App\n \n \n );\n};\n\nconst useDebugMenuItem = (): JSX.Element | null => {\n const debugInfo = useAppDebugInfo();\n return !debugInfo?.isDebug ? null : (\n \n {\n postMessageToMobileApp({\n type: 'open_mobile_debug',\n });\n }}\n >\n Debug Menu\n \n \n );\n};\n\n// TODO extract to pg-ui\nexport const useSecretMobileUtilityMenu = (props: Props) => {\n const [dialogOpen, setDialogOpen] = React.useState(false);\n // These are hooks so they can give us a legitimate null value if they shouldn't render.\n // This is important for providing the correct value of `displayUtilityMenu`\n const swapAppMenuItem = useSwapAppMenuItem(props);\n const debugMenuItem = useDebugMenuItem();\n\n // Display the menu if we're in the mobile app and there's at least one item to display\n const displayMenu =\n inMobileApp && [swapAppMenuItem, debugMenuItem].filter(Boolean).length > 0;\n\n const ticker = useTickerAction({\n numTicks: 3,\n onTickCountReached: () => {\n setDialogOpen(true);\n },\n });\n\n const dialog = !displayMenu ? null : (\n setDialogOpen(false)}\n onClick={() => setDialogOpen(false)}\n >\n Mobile App Utilities\n \n {swapAppMenuItem}\n {debugMenuItem}\n \n \n );\n return {\n displayMenu,\n dialog,\n incrementTickCount: () => {\n if (displayMenu) ticker.incrementTickCount();\n },\n };\n};\n","import React from 'react';\n\ntype DebugCallbackProps = {\n /** Number of ticks currently tracked */\n numTicks: number;\n};\ntype DebugCallback = (props: DebugCallbackProps) => void;\n\ntype Props = {\n /** Number of ticks required to trigger the callback */\n numTicks: number;\n /** Callback to trigger */\n onTickCountReached: () => void;\n /**\n * Time in milliseconds to wait for the next tick before resetting the counter\n * @default 2000\n */\n tickCountResetMs?: number;\n /**\n * Whether the hook is enabled\n * @default true\n */\n enabled?: boolean;\n /** Optional debug options */\n debug?: Partial<{\n /** Called every time the effect runs. Not called if the hook is disabled */\n onEffectCalled: DebugCallback;\n /** Called when the tick count is reset */\n onResetTickCount: DebugCallback;\n }>;\n};\n\n/** Fires the given callback when a given number of ticks is reached */\nexport const useTickerAction = ({\n numTicks,\n onTickCountReached,\n tickCountResetMs = 2000,\n enabled = true,\n debug = {},\n}: Props) => {\n const [tickCount, setTickCount] = React.useState(0);\n const tapTimeout = React.useRef(null);\n\n const resetTickCount = () => {\n debug.onResetTickCount?.({numTicks: tickCount});\n setTickCount(0);\n };\n // handle logo screen taps side-effects\n React.useEffect(() => {\n if (!enabled) return;\n const debugProps = {numTicks: tickCount};\n debug.onEffectCalled?.(debugProps);\n if (tapTimeout.current) clearTimeout(tapTimeout.current);\n\n if (tickCount >= numTicks) {\n onTickCountReached();\n setTickCount(0);\n } else if (tickCount > 0) {\n tapTimeout.current = setTimeout(resetTickCount, tickCountResetMs);\n }\n\n // Don't do anything if tickCount is 0\n }, [tickCount]);\n\n return {\n incrementTickCount: () => setTickCount(prev => prev + 1),\n decrementTickCount: () => setTickCount(prev => prev - 1),\n resetTickCount,\n };\n};\n"],"names":["setSessionErrors","errors","state","formState","submitErrors","submitFailed","lastSubmittedValues","values","InitializeInitialErrors","componentDidMount","initialErrors","form","mutators","this","props","Object","keys","length","render","component","formRPToDisableSubmit","pristine","invalid","dirtySinceLastSubmit","submitting","Boolean","Form","children","onSubmit","otherProps","handleSubmit","args","error","formRP","style","margin","noValidate","submitDisabled","combinedErrors","getState","map","name","message","filter","reduce","acc","key","Field","fieldRP","displayError","meta","touched","submitError","fieldRPToError","input","defaultProps","parse","value","parseCheckInDataFromQueryString","queryString","checkin","checkinData","ignoreQueryPrefix","Array","isArray","type","id","parseInt","Number","isNaN","inferServiceBrandFromWindow","window","patientrewardshub","hubbux","culturello","location","hostname","replace","Wrapper","styled","height","flexDirection","alignItems","flex","display","Divider","backgroundColor","Text","TextHr","Title","textAlign","color","Content","SociallyRegisteredModal","isOpen","close","socialAccounts","onLoginError","Modal","platforms","unregisteredAccountMethods","freeze","REWARDS_NUMBER","TEMP_REG_CODE","unregisteredAccountMethodDescriptions","UnregisteredAccountModal","methodUsed","redirectTo","Button","width","WIDE","onClick","data","href","OrphanedAccountModal","Link","DeletedPracticeAccountModal","UnregisteredSocialAccountModal","provider","ServiceBrand","lang","hubProduct","variant","outlined","ELASTIC","titles","account_paused","help","pause_warning","humanizeMinutes","seconds","minutes","Math","floor","humanizeSeconds","messages","nextBlockDuration","availableIn","displaySeconds","timeSeconds","tickSeconds","timeMs","tickMs","timeRemaining","setTimeRemaining","intervalId","setInterval","prevTime","clearInterval","useCountDown","ceil","useCountDownSeconds","UserRateLimitedModal","responseAction","formValues","title","hasOwnProperty","Dialog","open","onClose","DialogTitle","DialogContent","Typography","DialogActions","Box","marginRight","text","to","pathname","routes","login","forgotUsername","forgotPassword","GenericErrorModal","RecaptchaFailedModal","recaptchaOptions","useRecaptchaNet","enterprise","z","enum","useSyncSession","useMutation","mutationKey","mutationFn","_unsafe","post","useRecaptcha","logger","recaptchaSiteKey","actionName","recaptchaRef","mutateAsync","syncSession","supportsRecaptchaRequest","current","Promise","resolve","feature","handleResponse","event","channel","payload","removeEventListener","addEventListener","setTimeout","getRecaptchaData","supportsRecaptcha","then","recaptchaToken","platform","handleMessage","ref","getCaptchaFunction","formId","getWidgetId","action","res","RecaptchaComponent","CatastrophicErrorBoundary","errorNode","errorLogMessage","sitekey","size","makeUseRecaptcha","googleRecaptchaSiteKey","VERIFICATION_RANGE_MS","VerifyHumanPanel","verifyHumanFieldName","honeyPotFieldName","verification","setVerification","Grow","in","sx","mt","justifyContent","px","py","border","borderRadius","borderColor","Checkbox","checked","disabled","fontWeight","theme","palette","success","main","onChange","e","target","timeout","random","label","CircularProgress","ml","position","top","tabIndex","VERIFY_HUMAN_FIELD_NAME","HONEY_POT_FIELD_NAME","Modals","UnregisteredCard","UnregisteredTempRegCode","UnregisteredSocialAccount","RegistrationNotCompleted","OrphanedAccount","DeletedPracticeAccount","SociallyRegistered","UserThrottled","RecaptchaFailed","GenericError","stripLogin","RememberMeWrapper","ForgotLinkWrapper","ForgotLink","InitialErrors","UnregisteredRewardsCardError","Error","ERROR_NAME","UnregisteredTempRegCodeError","UnregisteredSocialAccountError","RegistrationNotFinishedError","OrphanedUserError","SociallyRegisteredError","UserThrottledError","Login","loginWithCredentials","params","showBackButton","csrfToken","csrf_token","recaptchaFailures","setRecaptchaFailures","modal","setModal","socialAccountProps","setSocialAccountProps","accounts","token","setToken","unregisteredSocialProvider","setUnregisteredSocialProvider","userThrottlerProps","setUserThrottlerProps","was_deleted","handleLoginError","err","opts","response","hint","response_action","available_in","next_block_duration","handleLogin","password","remember_me","humanVerification","required","isRobot","isHuman","redirect","tooManyRecaptchaFailures","requiresHumanVerification","initialValues","user","formData","disableSubmit","BaseScreen","hideBackButton","helmetTitle","headerTitle","actionButtons","loading","customHeight","customWidth","bottomMargin","afterButtons","my","bottomText","LinkPractice","LoginSupportFooter","FieldInput","autoComplete","autoFocus","PasswordInput","TransitionGroup","String","includes","loginValue","viaSocial","Inner","sessionErrors","logoMaxWidth","logoImageLimitSx","maxHeight","maxWidth","brandedLogoSrc","brandedGradientBackgroundClassname","baseButtonSx","grey","alignSelf","Home","serviceBrand","buttonProps","grow","mb","minHeight","className","transform","alt","asset","src","fontSize","lineHeight","gap","ButtonBase","register","btns","submit","secondary","FormScreen","submitText","secondaryButtonProps","validate","progress","btnClicked","setBtnClicked","submitButtonProps","secondarySubmit","divider","ProgressBar","credential","index","ResendEmail","resend","INVALID_TOKEN_REASONS","INVALID","EXPIRED","InvalidResetTokenModal","reason","ForgotPassword","history","initialLogin","invalidToken","invalidTokenHint","invalidModal","setInvalidModal","push","forgotPasswordEmailSent","username_or_email","instructions","PasswordEmailSent","SvgImage","ForgotPasswordReset","resetPassword","authorization","password_confirmation","passwordResetSuccess","isInvalidTokenError","CreatePasswordInput","PasswordResetSuccess","getRedirectUrl","ForgotUsername","loginCredential","forgotUsernameEmailSent","email","UsernameEmailSent","states","stateMap","identifier","test","alert","LegacyContactVerificationLanding","legacyContactVerification","Component","localeMonths","locale","navigator","language","Intl","DateTimeFormat","month","months","testDate","Date","format","getMonthsForLocale","MemorableDateInput","fieldId","fields","monthFieldPrefix","fieldError","field","join","getFieldError","labelText","FormControl","fullWidth","InputLabel","Select","labelId","onBlur","MenuProps","idx","monthNum","MenuItem","TextField","placeholder","day","inputProps","inputMode","pattern","maxLength","year","FormHelperText","memorableDateSchema","shape","typeError","min","max","integer","getMemorableDateFieldsPropFromFormik","dateFieldName","getSubfieldProps","subfield","fieldName","formikFieldProps","getFieldProps","setFieldValue","getComparableDate","date","withoutComposedDate","FormikMemorableDateInput","fieldValues","touchedFields","fieldsAreValid","isValidSync","allFieldsAreTouched","nextComposedDate","memDate","parsed","some","parseDateFromMemorableDate","nextDate","composedDate","StyledButton","paddingLeft","spacing","paddingRight","NarrowContent","FormInputWrapper","EndButtonsWrapper","ScreenHeading","EntryScreen","onConfirmCheckIn","contained","globalRoutes","checkInFormValidationSchema","firstname","lastname","birthdate","enhanceDateSchema","baseDateSchema","makeMemorableDateValidationSchema","schema","subYears","onGoBack","onSubmitSuccess","checkInType","recipeId","practiceId","router","enqueueSnackbar","checkInMutation","userInfo","practice_id","recipe_id","user_data","userData","formik","formikConfig","validationSchema","validateOnChange","mutate","mutationResult","transformServerErrors","onSubmitError","Input","isPending","SuccessGraphic","showAnimation","setShowAnimation","left","Template","animationData","onLoad","CheckInResultScreen","userFirstname","pointsAward","registrationToken","code","verified","phpJs","practice","practice_name","justifySelf","makeButtonText","primaryButtonProps","account","RegistrationMethods","UnauthenticatedCheckIn","x","checkIn","search","activeScreen","setActiveScreen","clearReferrerInSession","get","pb","PracticeLogo","xs","sm","App","utilityMenu","useSecretMobileUtilityMenu","practiceInfo","hubUrl","origin","practiceFeatures","authenticated","showErrorMessage","from","exact","path","displayMenu","bottom","right","incrementTickCount","dialog","ResponsiveModal","MEDIUM","noEsc","onRequestClose","closeTimeoutMS","shouldCloseOnOverlayClick","shouldCloseOnEsc","ModalButtons","marginTop","ModalTitle","ModalContent","BlackX","cursor","ModalHeaderBar","EscapeX","ModalHeader","DEFAULT_PRACTICE_ALT_TEXT","getPracticeLogoUrl","coreServiceUrl","UnauthenticatedPracticeLogo","AuthenitcatedPracticeLogo","logo","coreApiClient","baseURL","platformLabels","facebook","google","apple","useActivePractice","practices","decodedToken","find","p","queryStringToObject","slice","withQueryParams","parseQueryParams","item","startedAt","linkedPractices","teamAccount","teams","businessAccount","business","flavor","segment","practiceIsHubbuxTeams","membershipType","makeGetPracticeLogoUrl","config","options","logoBaseUrl","w","pixelDensity","trimWhiteSpace","trimaway","usePgForm","errorsOnTouchedFields","getFieldMeta","setFieldTouched","usePgMutationForm","status","setStatus","setSubmitting","setErrors","useDebouncedInputProps","debounceTimeMs","rest","changeEvent","setChangeEvent","handler","clearTimeout","TemplateLottie","isClickToPauseDisabled","mergedOptions","rendererSettings","preserveAspectRatio","autoplay","loop","SxDiv","SxSpan","SxImg","dialogOpen","setDialogOpen","swapAppMenuItem","inNewApp","itemHref","membersHref","membersUrl","URL","searchParams","set","toString","ListItem","disableGutters","ListItemButton","useSwapAppMenuItem","debugMenuItem","debugInfo","setDebugInfo","handleMobileAppEvent","JSON","SyntaxError","useAppDebugInfo","isDebug","useDebugMenuItem","ticker","numTicks","onTickCountReached","tickCountResetMs","enabled","debug","tickCount","setTickCount","tapTimeout","resetTickCount","onResetTickCount","debugProps","onEffectCalled","prev","decrementTickCount","useTickerAction","List"],"sourceRoot":""}