{"version":3,"file":"static/js/main.f91aeac2.js","sources":["api/analytics/api.ts","api/audio/api.ts","api/conversation/api.ts","api/payment/api.ts","api/statistics/api.ts","api/user/api.ts","apiClients/utils/zodValidator/ZodValidator.ts","apiClients/utils/responses.ts","apiClients/utils/baseAPIClient/BaseAPIClient.ts","apiClients/utils/logger/Logger.ts","apiClients/utils/amplifyAPIClient/AmplifyAPIClient.ts","apiClients/ConversationAPIClient.ts","components/ContactForm/styles.ts","components/ContactForm/ContactForm.hooks.ts","api/contact/api.ts","components/ContactForm/ContactForm.tsx","components/ContactForm/index.ts","components/ConversationPage/Avatar/Avatar.data.ts","components/ConversationPage/PropViewer/PropViewer.data.ts","components/LandingPage/LandingPageButton/styles.ts","components/LandingPage/LandingPageButton/LandingPageButton.tsx","components/LandingPage/LandingPageButton/index.ts","components/ListenableText/ListenableText.hooks.ts","components/ListenableText/styles.ts","components/ListenableText/ListenableText.tsx","components/ListenableText/index.ts","components/LoadingWrapper/LoadingComponent/styles.ts","components/LoadingWrapper/LoadingComponent/LoadingComponent.tsx","components/LoadingWrapper/LoadingComponent/index.ts","components/Recorder/styles.ts","components/Recorder/Recorder.hooks.ts","components/Recorder/Recorder.tsx","components/Recorder/index.ts","components/SpeakableButton/styles.ts","components/SpeakableButton/SpeakableButton.tsx","components/SpeakableButton/index.ts","components/TextInput/styles.ts","components/TextInput/TextInput.tsx","components/TextInput/index.ts","config/config.ts","hooks/useIsMounted.ts","store/authentication/data.ts","store/authentication/index.ts","store/conversation/data.ts","../node_modules/syllable/problematic.js","../node_modules/syllable/index.js","hooks/conversation/prompting/evaluation/evaluation.ts","store/conversation/index.ts","../node_modules/redux-persist/es/storage/getStorage.js","../node_modules/redux-persist/es/storage/index.js","store/experimental/data.ts","../node_modules/redux-persist/es/storage/createWebStorage.js","store/experimental/index.ts","store/goals/data.ts","store/goals/index.ts","store/hooks/index.ts","store/rootReducer.ts","store/index.ts","store/selectors/authenticationSelector.ts","store/selectors/goalsSelector.ts","store/selectors/siteSelector.ts","store/selectors/userSelector.ts","store/site/data.ts","store/site/index.ts","store/user/index.ts","store/userSettings/data.ts","store/userSettings/index.ts","utils/classes/audioPlayer.ts","utils/classes/recorder.ts","utils/constants.ts","../node_modules/@sentry/src/redux.ts","utils/sentry.ts","../node_modules/tslib/tslib.es6.mjs","../node_modules/@aws-amplify/core/node_modules/@aws-crypto/sha256-js/src/constants.ts","../node_modules/@aws-amplify/core/node_modules/@aws-crypto/sha256-js/src/RawSha256.ts","../node_modules/@aws-amplify/core/node_modules/@aws-crypto/util/src/convertToBuffer.ts","../node_modules/@smithy/util-utf8/dist-es/fromUtf8.browser.js","../node_modules/@aws-amplify/core/node_modules/@aws-crypto/sha256-js/src/jsSha256.ts","../node_modules/@aws-amplify/core/node_modules/@aws-crypto/util/src/isEmptyData.ts","../node_modules/@aws-amplify/core/node_modules/@smithy/util-hex-encoding/dist-es/index.js","../node_modules/@aws-crypto/sha256-js/src/RawSha256.ts","../node_modules/@aws-crypto/sha256-js/src/constants.ts","../node_modules/@aws-crypto/sha256-js/src/index.ts","../node_modules/@aws-crypto/sha256-js/src/jsSha256.ts","../node_modules/@aws-crypto/sha256-js/node_modules/tslib/tslib.es6.js","../node_modules/@aws-crypto/util/src/convertToBuffer.ts","../node_modules/@aws-crypto/util/src/index.ts","../node_modules/@aws-crypto/util/src/isEmptyData.ts","../node_modules/@aws-crypto/util/src/numToUint8.ts","../node_modules/@aws-crypto/util/src/uint32ArrayFrom.ts","../node_modules/@aws-sdk/util-utf8-browser/dist-es/index.js","../node_modules/@aws-sdk/util-utf8-browser/dist-es/whatwgEncodingApi.js","../node_modules/@aws-sdk/util-utf8-browser/dist-es/pureJs.js","../node_modules/@emotion/sheet/dist/emotion-sheet.browser.esm.js","../node_modules/stylis/src/Utility.js","../node_modules/stylis/src/Tokenizer.js","../node_modules/stylis/src/Enum.js","../node_modules/stylis/src/Serializer.js","../node_modules/stylis/src/Parser.js","../node_modules/@emotion/cache/dist/emotion-cache.browser.esm.js","../node_modules/stylis/src/Middleware.js","../node_modules/@emotion/memoize/dist/emotion-memoize.esm.js","../node_modules/@emotion/react/dist/emotion-element-43c6fea0.browser.esm.js","../node_modules/@emotion/react/dist/emotion-react.browser.esm.js","../node_modules/@emotion/unitless/dist/emotion-unitless.esm.js","../node_modules/@emotion/serialize/dist/emotion-serialize.browser.esm.js","../node_modules/@emotion/hash/dist/emotion-hash.esm.js","../node_modules/@emotion/use-insertion-effect-with-fallbacks/dist/emotion-use-insertion-effect-with-fallbacks.browser.esm.js","../node_modules/@emotion/utils/dist/emotion-utils.browser.esm.js","../node_modules/@mui/base/Portal/Portal.js","../node_modules/@mui/base/utils/appendOwnerState.js","../node_modules/@mui/base/utils/extractEventHandlers.js","../node_modules/@mui/base/utils/isHostComponent.js","../node_modules/@mui/base/utils/omitEventHandlers.js","../node_modules/@mui/base/utils/mergeSlotProps.js","../node_modules/@mui/base/utils/resolveComponentProps.js","../node_modules/@mui/base/utils/useSlotProps.js","../node_modules/@mui/icons-material/Close.js","../node_modules/@mui/icons-material/Fastfood.js","../node_modules/@mui/icons-material/LocalHospital.js","../node_modules/@mui/icons-material/Menu.js","../node_modules/@mui/icons-material/Movie.js","../node_modules/@mui/icons-material/PeopleAlt.js","../node_modules/@mui/icons-material/PlayArrowRounded.js","../node_modules/@mui/icons-material/Store.js","../node_modules/@mui/icons-material/VolumeUp.js","../node_modules/@mui/icons-material/Work.js","../node_modules/@mui/icons-material/utils/createSvgIcon.js","../node_modules/@mui/system/esm/createBox.js","../node_modules/@mui/material/Box/boxClasses.js","../node_modules/@mui/material/Box/Box.js","../node_modules/@mui/material/ButtonBase/Ripple.js","../node_modules/@mui/material/ButtonBase/touchRippleClasses.js","../node_modules/@mui/material/ButtonBase/TouchRipple.js","../node_modules/@mui/material/ButtonBase/buttonBaseClasses.js","../node_modules/@mui/material/ButtonBase/ButtonBase.js","../node_modules/@mui/material/internal/svg-icons/CheckBoxOutlineBlank.js","../node_modules/@mui/material/internal/svg-icons/CheckBox.js","../node_modules/@mui/material/internal/svg-icons/IndeterminateCheckBox.js","../node_modules/@mui/material/Checkbox/checkboxClasses.js","../node_modules/@mui/material/Checkbox/Checkbox.js","../node_modules/@mui/material/CircularProgress/circularProgressClasses.js","../node_modules/@mui/material/CircularProgress/CircularProgress.js","../node_modules/@mui/material/Fade/Fade.js","../node_modules/@mui/material/FormControl/FormControlContext.js","../node_modules/@mui/material/FormControl/formControlState.js","../node_modules/@mui/material/FormControl/useFormControl.js","../node_modules/@mui/system/esm/GlobalStyles/GlobalStyles.js","../node_modules/@mui/material/GlobalStyles/GlobalStyles.js","../node_modules/@mui/material/Grow/Grow.js","../node_modules/@mui/material/Input/inputClasses.js","../node_modules/@mui/material/Input/Input.js","../node_modules/@mui/base/TextareaAutosize/TextareaAutosize.js","../node_modules/@mui/material/InputBase/InputBase.js","../node_modules/@mui/material/InputBase/inputBaseClasses.js","../node_modules/@mui/material/InputBase/utils.js","../node_modules/@mui/base/unstable_useModal/ModalManager.js","../node_modules/@mui/base/unstable_useModal/useModal.js","../node_modules/@mui/base/FocusTrap/FocusTrap.js","../node_modules/@mui/material/Backdrop/backdropClasses.js","../node_modules/@mui/material/Backdrop/Backdrop.js","../node_modules/@mui/material/Modal/modalClasses.js","../node_modules/@mui/material/Modal/Modal.js","../node_modules/@mui/material/styles/getOverlayAlpha.js","../node_modules/@mui/material/Paper/paperClasses.js","../node_modules/@mui/material/Paper/Paper.js","../node_modules/@popperjs/core/lib/dom-utils/getWindow.js","../node_modules/@popperjs/core/lib/dom-utils/instanceOf.js","../node_modules/@popperjs/core/lib/utils/math.js","../node_modules/@popperjs/core/lib/utils/userAgent.js","../node_modules/@popperjs/core/lib/dom-utils/isLayoutViewport.js","../node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.js","../node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.js","../node_modules/@popperjs/core/lib/dom-utils/getNodeName.js","../node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.js","../node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.js","../node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.js","../node_modules/@popperjs/core/lib/dom-utils/isScrollParent.js","../node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.js","../node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.js","../node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.js","../node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.js","../node_modules/@popperjs/core/lib/dom-utils/getParentNode.js","../node_modules/@popperjs/core/lib/dom-utils/getScrollParent.js","../node_modules/@popperjs/core/lib/dom-utils/listScrollParents.js","../node_modules/@popperjs/core/lib/dom-utils/isTableElement.js","../node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.js","../node_modules/@popperjs/core/lib/enums.js","../node_modules/@popperjs/core/lib/utils/orderModifiers.js","../node_modules/@popperjs/core/lib/utils/debounce.js","../node_modules/@popperjs/core/lib/createPopper.js","../node_modules/@popperjs/core/lib/utils/mergeByName.js","../node_modules/@popperjs/core/lib/modifiers/eventListeners.js","../node_modules/@popperjs/core/lib/utils/getBasePlacement.js","../node_modules/@popperjs/core/lib/utils/getVariation.js","../node_modules/@popperjs/core/lib/utils/getMainAxisFromPlacement.js","../node_modules/@popperjs/core/lib/utils/computeOffsets.js","../node_modules/@popperjs/core/lib/modifiers/computeStyles.js","../node_modules/@popperjs/core/lib/modifiers/offset.js","../node_modules/@popperjs/core/lib/utils/getOppositePlacement.js","../node_modules/@popperjs/core/lib/utils/getOppositeVariationPlacement.js","../node_modules/@popperjs/core/lib/dom-utils/contains.js","../node_modules/@popperjs/core/lib/utils/rectToClientRect.js","../node_modules/@popperjs/core/lib/dom-utils/getClippingRect.js","../node_modules/@popperjs/core/lib/dom-utils/getViewportRect.js","../node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.js","../node_modules/@popperjs/core/lib/utils/mergePaddingObject.js","../node_modules/@popperjs/core/lib/utils/getFreshSideObject.js","../node_modules/@popperjs/core/lib/utils/expandToHashMap.js","../node_modules/@popperjs/core/lib/utils/detectOverflow.js","../node_modules/@popperjs/core/lib/utils/within.js","../node_modules/@popperjs/core/lib/modifiers/preventOverflow.js","../node_modules/@popperjs/core/lib/utils/getAltAxis.js","../node_modules/@popperjs/core/lib/modifiers/arrow.js","../node_modules/@popperjs/core/lib/modifiers/hide.js","../node_modules/@popperjs/core/lib/popper.js","../node_modules/@popperjs/core/lib/modifiers/popperOffsets.js","../node_modules/@popperjs/core/lib/modifiers/applyStyles.js","../node_modules/@popperjs/core/lib/modifiers/flip.js","../node_modules/@popperjs/core/lib/utils/computeAutoPlacement.js","../node_modules/@mui/base/generateUtilityClass/index.js","../node_modules/@mui/base/Popper/popperClasses.js","../node_modules/@mui/base/generateUtilityClasses/index.js","../node_modules/@mui/base/utils/ClassNameConfigurator.js","../node_modules/@mui/base/Popper/Popper.js","../node_modules/@mui/material/Popper/Popper.js","../node_modules/@mui/material/Tooltip/tooltipClasses.js","../node_modules/@mui/material/Tooltip/Tooltip.js","../node_modules/@mui/material/Typography/typographyClasses.js","../node_modules/@mui/material/Typography/Typography.js","../node_modules/@mui/material/internal/switchBaseClasses.js","../node_modules/@mui/material/internal/SwitchBase.js","../node_modules/@mui/material/colors/common.js","../node_modules/@mui/material/colors/grey.js","../node_modules/@mui/material/colors/purple.js","../node_modules/@mui/material/colors/red.js","../node_modules/@mui/material/colors/orange.js","../node_modules/@mui/material/colors/blue.js","../node_modules/@mui/material/colors/lightBlue.js","../node_modules/@mui/material/colors/green.js","../node_modules/@mui/material/styles/createPalette.js","../node_modules/@mui/material/styles/createTypography.js","../node_modules/@mui/material/styles/shadows.js","../node_modules/@mui/material/styles/zIndex.js","../node_modules/@mui/material/styles/createTheme.js","../node_modules/@mui/material/styles/createMixins.js","../node_modules/@mui/material/styles/createTransitions.js","../node_modules/@mui/material/styles/defaultTheme.js","../node_modules/@mui/material/styles/identifier.js","../node_modules/@mui/material/styles/rootShouldForwardProp.js","../node_modules/@mui/material/styles/slotShouldForwardProp.js","../node_modules/@mui/material/styles/styled.js","../node_modules/@mui/material/styles/useTheme.js","../node_modules/@mui/material/styles/useThemeProps.js","../node_modules/@mui/material/transitions/utils.js","../node_modules/@mui/material/utils/capitalize.js","../node_modules/@mui/material/utils/createChainedFunction.js","../node_modules/@mui/material/SvgIcon/svgIconClasses.js","../node_modules/@mui/material/SvgIcon/SvgIcon.js","../node_modules/@mui/material/utils/createSvgIcon.js","../node_modules/@mui/material/utils/debounce.js","../node_modules/@mui/material/utils/deprecatedPropType.js","../node_modules/@mui/utils/deprecatedPropType/deprecatedPropType.js","../node_modules/@mui/material/utils/requirePropFactory.js","../node_modules/@mui/utils/requirePropFactory/requirePropFactory.js","../node_modules/@mui/material/utils/setRef.js","../node_modules/@mui/material/utils/unsupportedProp.js","../node_modules/@mui/utils/unsupportedProp/unsupportedProp.js","../node_modules/@mui/material/utils/index.js","../node_modules/@mui/material/utils/isMuiElement.js","../node_modules/@mui/utils/isMuiElement/isMuiElement.js","../node_modules/@mui/material/utils/ownerDocument.js","../node_modules/@mui/material/utils/ownerWindow.js","../node_modules/@mui/material/utils/useControlled.js","../node_modules/@mui/utils/useControlled/useControlled.js","../node_modules/@mui/material/utils/useEnhancedEffect.js","../node_modules/@mui/material/utils/useEventCallback.js","../node_modules/@mui/material/utils/useForkRef.js","../node_modules/@mui/material/utils/useId.js","../node_modules/@mui/utils/useIsFocusVisible/useIsFocusVisible.js","../node_modules/@mui/material/utils/useIsFocusVisible.js","../node_modules/@mui/styled-engine/GlobalStyles/GlobalStyles.js","../node_modules/@emotion/is-prop-valid/dist/emotion-is-prop-valid.esm.js","../node_modules/@emotion/styled/base/dist/emotion-styled-base.browser.esm.js","../node_modules/@emotion/styled/dist/emotion-styled.browser.esm.js","../node_modules/@mui/styled-engine/StyledEngineProvider/StyledEngineProvider.js","../node_modules/@mui/styled-engine/index.js","../node_modules/@mui/system/colorManipulator.js","../node_modules/@mui/system/createStyled.js","../node_modules/@mui/system/esm/RtlProvider/index.js","../node_modules/@mui/system/esm/breakpoints.js","../node_modules/@mui/system/esm/createTheme/applyStyles.js","../node_modules/@mui/system/esm/createTheme/createBreakpoints.js","../node_modules/@mui/system/esm/createTheme/shape.js","../node_modules/@mui/system/esm/createTheme/createTheme.js","../node_modules/@mui/system/esm/createTheme/createSpacing.js","../node_modules/@mui/system/esm/merge.js","../node_modules/@mui/system/esm/spacing.js","../node_modules/@mui/system/esm/memoize.js","../node_modules/@mui/system/esm/style.js","../node_modules/@mui/system/esm/compose.js","../node_modules/@mui/system/esm/borders.js","../node_modules/@mui/system/esm/cssGrid.js","../node_modules/@mui/system/esm/palette.js","../node_modules/@mui/system/esm/sizing.js","../node_modules/@mui/system/esm/styleFunctionSx/defaultSxConfig.js","../node_modules/@mui/system/esm/styleFunctionSx/extendSxProp.js","../node_modules/@mui/system/esm/styleFunctionSx/styleFunctionSx.js","../node_modules/@mui/system/esm/useTheme.js","../node_modules/@mui/utils/resolveProps/resolveProps.js","../node_modules/@mui/system/esm/useThemeProps/getThemeProps.js","../node_modules/@mui/system/esm/useThemeProps/useThemeProps.js","../node_modules/@mui/system/esm/useThemeWithoutDefault.js","../node_modules/@mui/system/useThemeWithoutDefault.js","../node_modules/@mui/utils/ClassNameGenerator/ClassNameGenerator.js","../node_modules/@mui/utils/capitalize/capitalize.js","../node_modules/@mui/utils/clamp/clamp.js","../node_modules/@mui/utils/composeClasses/composeClasses.js","../node_modules/@mui/utils/createChainedFunction/createChainedFunction.js","../node_modules/@mui/utils/debounce/debounce.js","../node_modules/@mui/utils/deepmerge/deepmerge.js","../node_modules/@mui/utils/formatMuiErrorMessage/formatMuiErrorMessage.js","../node_modules/@mui/utils/generateUtilityClass/generateUtilityClass.js","../node_modules/@mui/utils/generateUtilityClasses/generateUtilityClasses.js","../node_modules/@mui/utils/getDisplayName/getDisplayName.js","../node_modules/@mui/utils/getScrollbarSize/getScrollbarSize.js","../node_modules/@mui/utils/ownerDocument/ownerDocument.js","../node_modules/@mui/utils/ownerWindow/ownerWindow.js","../node_modules/@mui/utils/setRef/setRef.js","../node_modules/@mui/utils/useEnhancedEffect/useEnhancedEffect.js","../node_modules/@mui/utils/useEventCallback/useEventCallback.js","../node_modules/@mui/utils/useForkRef/useForkRef.js","../node_modules/@mui/utils/useId/useId.js","../node_modules/@mui/utils/useLazyRef/useLazyRef.js","../node_modules/@mui/utils/useOnMount/useOnMount.js","../node_modules/@mui/utils/useTimeout/useTimeout.js","../node_modules/immer/src/utils/errors.ts","../node_modules/immer/src/utils/common.ts","../node_modules/immer/src/utils/plugins.ts","../node_modules/immer/src/core/scope.ts","../node_modules/immer/src/core/finalize.ts","../node_modules/immer/src/core/proxy.ts","../node_modules/immer/src/core/immerClass.ts","../node_modules/immer/src/core/current.ts","../node_modules/immer/src/plugins/es5.ts","../node_modules/immer/src/immer.ts","../node_modules/immer/src/utils/env.ts","../node_modules/redux-thunk/es/index.js","../node_modules/@reduxjs/toolkit/src/devtoolsExtension.ts","../node_modules/@reduxjs/toolkit/src/isPlainObject.ts","../node_modules/@reduxjs/toolkit/src/createAction.ts","../node_modules/@reduxjs/toolkit/src/utils.ts","../node_modules/@reduxjs/toolkit/src/getDefaultMiddleware.ts","../node_modules/@reduxjs/toolkit/src/configureStore.ts","../node_modules/@reduxjs/toolkit/src/mapBuilders.ts","../node_modules/@reduxjs/toolkit/src/createSlice.ts","../node_modules/@reduxjs/toolkit/src/createReducer.ts","../node_modules/@reduxjs/toolkit/src/nanoid.ts","../node_modules/@reduxjs/toolkit/src/createAsyncThunk.ts","../node_modules/@reduxjs/toolkit/src/listenerMiddleware/index.ts","../node_modules/@reduxjs/toolkit/src/listenerMiddleware/task.ts","../node_modules/@reduxjs/toolkit/src/autoBatchEnhancer.ts","../node_modules/@reduxjs/toolkit/src/index.ts","../node_modules/@remix-run/router/history.ts","../node_modules/@remix-run/router/utils.ts","../node_modules/@remix-run/router/router.ts","../../_common/frame-processor.ts","../../_common/index.ts","../../_common/logging.ts","../../_common/messages.ts","../../_common/models.ts","../../_common/non-real-time-vad.ts","../../_common/resampler.ts","../../_common/utils.ts","../../src/asset-path.ts","../../src/default-model-fetcher.ts","../../src/index.ts","../../src/real-time-vad.ts","../../src/utils.ts","../node_modules/@sentry/src/constants.ts","../node_modules/@sentry/src/debug-build.ts","../node_modules/@sentry/src/eventProcessors.ts","../node_modules/@sentry/src/exports.ts","../node_modules/@sentry/src/hub.ts","../node_modules/@sentry/src/scope.ts","../node_modules/@sentry/src/session.ts","../node_modules/@sentry/src/tracing/dynamicSamplingContext.ts","../node_modules/@sentry/src/utils/applyScopeDataToEvent.ts","../node_modules/@sentry/src/utils/getRootSpan.ts","../node_modules/@sentry/src/utils/prepareEvent.ts","../node_modules/@sentry/src/utils/spanUtils.ts","../node_modules/@sentry/src/version.ts","../node_modules/@sentry/src/browser.ts","../node_modules/@sentry/src/is.ts","../node_modules/@sentry/src/logger.ts","../node_modules/@sentry/src/misc.ts","../node_modules/@sentry/src/normalize.ts","../node_modules/@sentry/src/memo.ts","../node_modules/@sentry/src/object.ts","../node_modules/@sentry/src/stacktrace.ts","../node_modules/@sentry/src/string.ts","../node_modules/@sentry/src/syncpromise.ts","../node_modules/@sentry/src/time.ts","../node_modules/@sentry/src/worldwide.ts","../node_modules/@speakable/speakable-service-contracts/lib/conversation/index.js","../node_modules/@speakable/speakable-service-contracts/lib/status/conversation/index.js","../node_modules/deepmerge/dist/cjs.js","../node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js","../node_modules/hoist-non-react-statics/node_modules/react-is/cjs/react-is.production.min.js","../node_modules/hoist-non-react-statics/node_modules/react-is/index.js","../node_modules/load-script/index.js","../node_modules/memoize-one/dist/memoize-one.esm.js","../node_modules/normalize-strings/index.js","../node_modules/pluralize/pluralize.js","../node_modules/prop-types/factoryWithThrowingShims.js","../node_modules/prop-types/index.js","../node_modules/prop-types/lib/ReactPropTypesSecret.js","../node_modules/react-dom/cjs/react-dom.production.min.js","../node_modules/react-dom/client.js","../node_modules/react-dom/index.js","../node_modules/react-dom/node_modules/scheduler/cjs/scheduler.production.min.js","../node_modules/react-dom/node_modules/scheduler/index.js","../node_modules/react-fast-compare/index.js","../node_modules/react-is/cjs/react-is.production.min.js","../node_modules/react-is/index.js","../node_modules/react-player/lib/Player.js","../node_modules/react-player/lib/ReactPlayer.js","../node_modules/react-player/lib/index.js","../node_modules/react-player/lib/patterns.js","../node_modules/react-player/lib/players/index.js","../node_modules/react-player/lib/props.js","../node_modules/react-player/lib/utils.js","../node_modules/react-redux/es/utils/batch.js","../node_modules/react-redux/es/components/Context.js","../node_modules/react-redux/es/hooks/useReduxContext.js","../node_modules/react-redux/es/hooks/useSelector.js","../node_modules/react-redux/es/utils/useSyncExternalStore.js","../node_modules/react-redux/es/utils/Subscription.js","../node_modules/react-redux/es/utils/useIsomorphicLayoutEffect.js","../node_modules/react-redux/es/components/connect.js","../node_modules/react-redux/es/components/Provider.js","../node_modules/react-redux/es/hooks/useStore.js","../node_modules/react-redux/es/hooks/useDispatch.js","../node_modules/react-redux/es/index.js","../node_modules/react-router/lib/context.ts","../node_modules/react-router/lib/hooks.tsx","../node_modules/react-router/lib/components.tsx","../node_modules/react-transition-group/esm/config.js","../node_modules/react-transition-group/esm/Transition.js","../node_modules/react-transition-group/esm/utils/reflow.js","../node_modules/react-transition-group/esm/utils/ChildMapping.js","../node_modules/react-transition-group/esm/TransitionGroup.js","../node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js","../node_modules/react-transition-group/esm/TransitionGroupContext.js","../node_modules/react/cjs/react-jsx-runtime.production.min.js","../node_modules/react/cjs/react.production.min.js","../node_modules/react/index.js","../node_modules/react/jsx-runtime.js","../node_modules/redux-persist/es/constants.js","../node_modules/redux-persist/es/stateReconciler/autoMergeLevel1.js","../node_modules/redux-persist/es/createPersistoid.js","../node_modules/redux-persist/es/getStoredState.js","../node_modules/redux-persist/es/purgeStoredState.js","../node_modules/redux-persist/es/persistReducer.js","../node_modules/redux-persist/es/persistStore.js","../node_modules/redux-persist/lib/storage/createWebStorage.js","../node_modules/redux-persist/lib/storage/getStorage.js","../node_modules/redux-persist/lib/storage/index.js","../node_modules/@babel/runtime/helpers/esm/typeof.js","../node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","../node_modules/@babel/runtime/helpers/esm/toPrimitive.js","../node_modules/@babel/runtime/helpers/esm/defineProperty.js","../node_modules/@babel/runtime/helpers/esm/objectSpread2.js","../node_modules/redux/es/redux.js","../node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.min.js","../node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.production.min.js","../node_modules/use-sync-external-store/shim/index.js","../node_modules/use-sync-external-store/shim/with-selector.js","../node_modules/zod/lib/ZodError.js","../node_modules/zod/lib/errors.js","../node_modules/zod/lib/external.js","../node_modules/zod/lib/helpers/errorUtil.js","../node_modules/zod/lib/helpers/parseUtil.js","../node_modules/zod/lib/helpers/typeAliases.js","../node_modules/zod/lib/helpers/util.js","../node_modules/zod/lib/index.js","../node_modules/zod/lib/locales/en.js","../node_modules/zod/lib/types.js","../node_modules/@babel/runtime/helpers/extends.js","../node_modules/@babel/runtime/helpers/interopRequireDefault.js","../node_modules/@babel/runtime/helpers/objectWithoutPropertiesLoose.js","../node_modules/common/lib/backend-impl.ts","../node_modules/common/lib/backend.ts","../node_modules/common/lib/version.ts","../node_modules/common/lib/env-impl.ts","../node_modules/common/lib/env.ts","../node_modules/common/lib/tensor-conversion-impl.ts","../node_modules/common/lib/tensor-factory-impl.ts","../node_modules/common/lib/tensor-impl-type-mapping.ts","../node_modules/common/lib/tensor-utils-impl.ts","../node_modules/common/lib/tensor-impl.ts","../node_modules/common/lib/tensor.ts","../node_modules/common/lib/trace.ts","../node_modules/common/lib/inference-session-impl.ts","../node_modules/common/lib/inference-session.ts","../node_modules/common/lib/tensor-conversion.ts","../node_modules/common/lib/tensor-factory.ts","../node_modules/common/lib/onnx-model.ts","../node_modules/common/lib/onnx-value.ts","../node_modules/common/lib/training-session-impl.ts","../node_modules/common/lib/training-session.ts","../node_modules/common/lib/index.ts","../node_modules/onnxruntime-web/lib/onnxjs/instrument.ts","../node_modules/onnxruntime-web/lib/onnxjs/opset.ts","../node_modules/onnxruntime-web/node_modules/guid-typescript/dist/guid.js","../node_modules/onnxruntime-web/node_modules/long/index.js","../node_modules/onnxruntime-web/node_modules/flatbuffers/js/flatbuffers.mjs","../node_modules/onnxruntime-web/lib/onnxjs/ort-schema/flatbuffers/ort-generated.ts","../node_modules/onnxruntime-web/node_modules/@protobufjs/aspromise/index.js","../node_modules/onnxruntime-web/node_modules/@protobufjs/base64/index.js","../node_modules/onnxruntime-web/node_modules/@protobufjs/eventemitter/index.js","../node_modules/onnxruntime-web/node_modules/@protobufjs/float/index.js","../node_modules/onnxruntime-web/node_modules/@protobufjs/inquire/index.js","../node_modules/onnxruntime-web/node_modules/@protobufjs/utf8/index.js","../node_modules/onnxruntime-web/node_modules/@protobufjs/pool/index.js","../node_modules/onnxruntime-web/node_modules/protobufjs/src/util/longbits.js","../node_modules/onnxruntime-web/node_modules/protobufjs/src/util/minimal.js","../node_modules/onnxruntime-web/node_modules/protobufjs/src/writer.js","../node_modules/onnxruntime-web/node_modules/protobufjs/src/writer_buffer.js","../node_modules/onnxruntime-web/node_modules/protobufjs/src/reader.js","../node_modules/onnxruntime-web/node_modules/protobufjs/src/reader_buffer.js","../node_modules/onnxruntime-web/node_modules/protobufjs/src/rpc/service.js","../node_modules/onnxruntime-web/node_modules/protobufjs/src/rpc.js","../node_modules/onnxruntime-web/node_modules/protobufjs/src/roots.js","../node_modules/onnxruntime-web/node_modules/protobufjs/src/index-minimal.js","../node_modules/onnxruntime-web/node_modules/protobufjs/minimal.js","../node_modules/onnxruntime-web/lib/onnxjs/ort-schema/protobuf/onnx.js","../node_modules/onnxruntime-web/lib/onnxjs/util.ts","../node_modules/onnxruntime-web/lib/onnxjs/tensor.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/glsl-source.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/types.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/utils.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/packing-utils.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/pack.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/reshape-packed.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/uint8-encode.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/unpack.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/texture-data-encoder.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/texture-layout.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/inference-handler.ts","../node_modules/onnxruntime-web/lib/onnxjs/attribute-with-cache-key.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/batch-normalization.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/glsl-definitions.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/binary-op.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/cast.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/concat-packed.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/concat.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/unary-op.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/fuse-utils.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/conv-grouped.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/im2col-pack.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/matmul.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/matmul-pack.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/conv-pack.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/im2col.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/dot-product.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/conv.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/conv-transpose.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/transpose.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/depth-to-space.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/flatten.ts","../node_modules/onnxruntime-web/lib/onnxjs/operators.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/gather.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/gemm.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/image-scaler.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/instance-normalization.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/lrn.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/pad.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/pool.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/reduce.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/reshape.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/upsample.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/resize-packed.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/shape.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/slice.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/softmax.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/split.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/squeeze.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/sum.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/tile.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/ops/unsqueeze.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/op-resolve-rules.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/glsl-function-inliner.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/texture-layout-strategy.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/glsl-coordinate-lib.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/glsl-encoding-lib.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/glsl-fragcolor-lib.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/glsl-shape-utils-lib.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/glsl-vec-lib.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/glsl-registered-libs.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/glsl-preprocessor.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/program-manager.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/texture-manager.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/session-handler.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/webgl-context.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/webgl/webgl-context-factory.ts","../node_modules/onnxruntime-web/lib/onnxjs/backends/backend-webgl.ts","../node_modules/onnxruntime-web/lib/onnxjs/backend.ts","../node_modules/onnxruntime-web/lib/onnxjs/execution-plan.ts","../node_modules/onnxruntime-web/lib/onnxjs/attribute.ts","../node_modules/onnxruntime-web/lib/onnxjs/graph.ts","../node_modules/onnxruntime-web/lib/onnxjs/model.ts","../node_modules/onnxruntime-web/lib/onnxjs/session.ts","../node_modules/onnxruntime-web/lib/onnxjs/session-handler-inference.ts","../node_modules/onnxruntime-web/lib/backend-onnxjs.ts","../nodejs-ignore:fs","../nodejs-ignore:path","../node_modules/onnxruntime-web/lib/wasm/binding/ort-wasm.js","../nodejs-ignore:worker_threads","../nodejs-ignore:perf_hooks","../nodejs-ignore:os","../node_modules/onnxruntime-web/lib/wasm/binding/ort-wasm-threaded.js","../node_modules/onnxruntime-web/lib/wasm/binding/ort-wasm-threaded.worker.js","../node_modules/onnxruntime-web/lib/wasm/wasm-factory.ts","../node_modules/onnxruntime-web/lib/wasm/wasm-utils.ts","../node_modules/onnxruntime-web/lib/wasm/run-options.ts","../node_modules/onnxruntime-web/lib/wasm/session-options.ts","../node_modules/onnxruntime-web/lib/wasm/wasm-common.ts","../node_modules/onnxruntime-web/lib/wasm/wasm-utils-load-file.ts","../node_modules/onnxruntime-web/lib/wasm/wasm-core-impl.ts","../proxy-worker:./proxy-worker/main","../node_modules/onnxruntime-web/lib/wasm/proxy-wrapper.ts","../node_modules/onnxruntime-web/lib/wasm/session-handler-inference.ts","../node_modules/onnxruntime-web/lib/backend-wasm.ts","../node_modules/onnxruntime-web/lib/backend-wasm-inference.ts","../node_modules/onnxruntime-web/lib/index.ts","../node_modules/onnxruntime-web/lib/version.ts","../node_modules/@babel/runtime/helpers/esm/extends.js","../node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js","../node_modules/@babel/runtime/helpers/esm/inheritsLoose.js","../node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","../node_modules/@babel/runtime/helpers/esm/taggedTemplateLiteral.js","../node_modules/@aws-amplify/api-rest/src/errors/RestApiError.ts","../node_modules/@aws-amplify/api-rest/src/errors/CanceledError.ts","../node_modules/@aws-amplify/api-rest/src/errors/validation.ts","../node_modules/@aws-amplify/api-rest/src/utils/serviceError.ts","../node_modules/@aws-amplify/api-rest/src/utils/logger.ts","../node_modules/@aws-amplify/api-rest/src/utils/constants.ts","../node_modules/@aws-amplify/api-rest/src/utils/parseSigningInfo.ts","../node_modules/@aws-amplify/api-rest/src/utils/resolveApiUrl.ts","../node_modules/@aws-amplify/api-rest/src/errors/assertValidatonError.ts","../node_modules/@aws-amplify/core/src/clients/middleware/signing/signer/signatureV4/utils/getSignedHeaders.ts","../node_modules/@aws-amplify/core/src/clients/middleware/signing/signer/signatureV4/constants.ts","../node_modules/@aws-amplify/core/src/clients/middleware/signing/signer/signatureV4/utils/getSigningValues.ts","../node_modules/@aws-amplify/core/src/clients/middleware/signing/signer/signatureV4/utils/getFormattedDates.ts","../node_modules/@aws-amplify/core/src/clients/middleware/signing/signer/signatureV4/utils/getCredentialScope.ts","../node_modules/@aws-amplify/core/src/clients/middleware/signing/signer/signatureV4/utils/dataHashHelpers.ts","../node_modules/@aws-amplify/core/src/clients/middleware/signing/signer/signatureV4/utils/getCanonicalHeaders.ts","../node_modules/@aws-amplify/core/src/clients/middleware/signing/signer/signatureV4/utils/getCanonicalQueryString.ts","../node_modules/@aws-amplify/core/src/clients/middleware/signing/signer/signatureV4/utils/getCanonicalUri.ts","../node_modules/@aws-amplify/core/src/clients/middleware/signing/signer/signatureV4/utils/getHashedPayload.ts","../node_modules/@aws-amplify/core/src/clients/middleware/signing/signer/signatureV4/utils/getSignature.ts","../node_modules/@aws-amplify/core/src/clients/middleware/signing/signer/signatureV4/utils/getCanonicalRequest.ts","../node_modules/@aws-amplify/core/src/clients/middleware/signing/signer/signatureV4/utils/getStringToSign.ts","../node_modules/@aws-amplify/core/src/clients/middleware/signing/signer/signatureV4/utils/getSigningKey.ts","../node_modules/@aws-amplify/core/src/clients/middleware/signing/utils/getSkewCorrectedDate.ts","../node_modules/@aws-amplify/core/src/clients/middleware/signing/utils/getUpdatedSystemClockOffset.ts","../node_modules/@aws-amplify/core/src/clients/middleware/signing/utils/isClockSkewed.ts","../node_modules/@aws-amplify/core/src/clients/middleware/signing/middleware.ts","../node_modules/@aws-amplify/core/src/clients/handlers/authenticated.ts","../node_modules/@aws-amplify/core/src/clients/middleware/signing/signer/signatureV4/signRequest.ts","../node_modules/@aws-amplify/api-rest/src/utils/resolveHeaders.ts","../node_modules/@aws-amplify/api-rest/src/apis/common/handler.ts","../node_modules/@aws-amplify/api-rest/src/apis/common/publicApis.ts","../node_modules/@aws-amplify/api-rest/src/utils/createCancellableOperation.ts","../node_modules/@aws-amplify/api-rest/src/apis/index.ts","../node_modules/@aws-amplify/core/src/Hub/index.ts","../node_modules/@aws-amplify/core/src/Logger/types.ts","../node_modules/@aws-amplify/core/src/Logger/ConsoleLogger.ts","../node_modules/@aws-amplify/core/src/clients/utils/memoization.ts","../node_modules/@aws-amplify/core/src/clients/handlers/fetch.ts","../node_modules/@aws-amplify/core/src/clients/handlers/unauthenticated.ts","../node_modules/@aws-amplify/core/src/clients/internal/composeTransferHandler.ts","../node_modules/@aws-amplify/core/src/clients/middleware/retry/isClockSkewError.ts","../node_modules/@aws-amplify/core/src/clients/middleware/retry/defaultRetryDecider.ts","../node_modules/@aws-amplify/core/src/clients/middleware/retry/jitteredBackoff.ts","../node_modules/@aws-amplify/core/src/utils/retry/jitteredBackoff.ts","../node_modules/@aws-amplify/core/src/utils/retry/constants.ts","../node_modules/@aws-amplify/core/src/clients/middleware/retry/middleware.ts","../node_modules/@aws-amplify/core/src/clients/middleware/userAgent/middleware.ts","../node_modules/@aws-amplify/core/src/clients/serde/json.ts","../node_modules/@aws-amplify/core/src/clients/serde/responseInfo.ts","../node_modules/@aws-amplify/core/src/constants.ts","../node_modules/@aws-amplify/core/src/errors/APIError.ts","../node_modules/@aws-amplify/core/src/errors/AmplifyError.ts","../node_modules/@aws-amplify/core/src/utils/deepFreeze.ts","../node_modules/@aws-amplify/core/src/singleton/Amplify.ts","../node_modules/@aws-amplify/core/src/singleton/Auth/index.ts","../node_modules/@aws-amplify/core/src/singleton/constants.ts","../node_modules/@aws-amplify/core/src/utils/amplifyUrl/index.ts","../node_modules/@aws-amplify/core/src/parseAWSExports.ts","../node_modules/@aws-amplify/core/src/parseAmplifyOutputs.ts","../node_modules/@aws-amplify/core/src/utils/parseAmplifyConfig.ts","../node_modules/clsx/dist/clsx.mjs","../node_modules/react-toastify/node_modules/clsx/dist/clsx.m.js","../node_modules/three/build/three.module.js","../webpack/bootstrap","../webpack/runtime/compat get default export","../webpack/runtime/create fake namespace object","../webpack/runtime/define property getters","../webpack/runtime/ensure chunk","../webpack/runtime/get javascript chunk filename","../webpack/runtime/get mini-css chunk filename","../webpack/runtime/global","../webpack/runtime/hasOwnProperty shorthand","../webpack/runtime/load script","../webpack/runtime/make namespace object","../webpack/runtime/node module decorator","../webpack/runtime/publicPath","../webpack/runtime/jsonp chunk loading","../node_modules/@mui/private-theming/useTheme/ThemeContext.js","../node_modules/@mui/private-theming/useTheme/useTheme.js","../node_modules/@mui/private-theming/ThemeProvider/nested.js","../node_modules/@mui/private-theming/ThemeProvider/ThemeProvider.js","../node_modules/@mui/system/esm/ThemeProvider/ThemeProvider.js","../node_modules/@mui/material/styles/ThemeProvider.js","../node_modules/@mui/material/CssBaseline/CssBaseline.js","utils/theme.ts","../node_modules/js-cookie/dist/js.cookie.mjs","../node_modules/@aws-amplify/core/src/types/errors.ts","../node_modules/@aws-amplify/core/src/storage/CookieStorage.ts","../node_modules/@aws-amplify/core/src/errors/PlatformNotSupportedError.ts","../node_modules/@aws-amplify/core/src/storage/KeyValueStorage.ts","../node_modules/@aws-amplify/core/src/storage/InMemoryStorage.ts","../node_modules/@aws-amplify/core/src/storage/index.ts","../node_modules/@aws-amplify/core/src/storage/DefaultStorage.ts","../node_modules/@aws-amplify/core/src/storage/utils.ts","../node_modules/@aws-amplify/core/src/storage/SessionStorage.ts","../node_modules/@aws-amplify/core/src/utils/globalHelpers/index.ts","../node_modules/@aws-amplify/core/src/utils/convert/base64/base64Decoder.ts","../node_modules/@aws-amplify/core/src/errors/createAssertionFunction.ts","../node_modules/@aws-amplify/core/src/singleton/Auth/utils/errorHelpers.ts","../node_modules/@aws-amplify/core/src/singleton/Auth/utils/index.ts","../node_modules/@aws-amplify/core/src/utils/deDupeAsyncFunction.ts","../node_modules/@aws-amplify/core/src/clients/internal/composeServiceApi.ts","../node_modules/@aws-amplify/auth/src/errors/AuthError.ts","../node_modules/@aws-amplify/auth/src/errors/utils/assertServiceError.ts","../node_modules/@aws-amplify/core/src/clients/endpoints/partitions.ts","../node_modules/@aws-amplify/core/src/clients/endpoints/getDnsSuffix.ts","../node_modules/@aws-amplify/core/src/Platform/types.ts","../node_modules/@aws-amplify/core/src/Platform/version.ts","../node_modules/@aws-amplify/core/src/Platform/detection/helpers.ts","../node_modules/@aws-amplify/core/src/Platform/detection/index.ts","../node_modules/@aws-amplify/core/src/Platform/detection/Expo.ts","../node_modules/@aws-amplify/core/src/Platform/detection/ReactNative.ts","../node_modules/@aws-amplify/core/src/Platform/detection/Next.ts","../node_modules/@aws-amplify/core/src/Platform/detection/Nuxt.ts","../node_modules/@aws-amplify/core/src/Platform/detection/Angular.ts","../node_modules/@aws-amplify/core/src/Platform/detection/React.ts","../node_modules/@aws-amplify/core/src/Platform/detection/Vue.ts","../node_modules/@aws-amplify/core/src/Platform/detection/Svelte.ts","../node_modules/@aws-amplify/core/src/Platform/detection/Web.ts","../node_modules/@aws-amplify/core/src/Platform/detectFramework.ts","../node_modules/@aws-amplify/core/src/Platform/customUserAgent.ts","../node_modules/@aws-amplify/core/src/Platform/index.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/clients/CognitoIdentityProvider/base.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/clients/CognitoIdentityProvider/index.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/clients/CognitoIdentityProvider/utils.ts","../node_modules/@aws-amplify/auth/src/errors/constants.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/types.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/userContextData.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/refreshAuthTokens.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/tokenProvider/types.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/tokenProvider/errorHelpers.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/tokenProvider/TokenStore.ts","../node_modules/@aws-amplify/core/src/utils/isBrowser.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/signInWithRedirectStore.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/oauth/oAuthStore.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/oauth/inflightPromise.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/tokenProvider/TokenOrchestrator.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/tokenProvider/tokenProvider.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/tokenProvider/CognitoUserPoolsTokenProvider.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/credentialsProvider/types.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/credentialsProvider/IdentityIdStore.ts","../node_modules/@aws-amplify/core/src/awsClients/cognitoIdentity/base.ts","../node_modules/@aws-amplify/core/src/awsClients/cognitoIdentity/getCredentialsForIdentity.ts","../node_modules/@aws-amplify/core/src/awsClients/cognitoIdentity/getId.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/credentialsProvider/utils.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/credentialsProvider/IdentityIdProvider.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/credentialsProvider/credentialsProvider.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/credentialsProvider/index.ts","../node_modules/aws-amplify/src/initSingleton.ts","config/amplify.ts","../node_modules/@sentry/src/integration.ts","../node_modules/@sentry/src/integrations/inboundfilters.ts","../node_modules/@sentry/src/integrations/functiontostring.ts","../node_modules/@sentry/src/sdk.ts","../node_modules/@sentry/src/supports.ts","../node_modules/@sentry/src/vendor/supportsHistory.ts","../node_modules/@sentry/src/instrument/_handlers.ts","../node_modules/@sentry/src/instrument/history.ts","../node_modules/@sentry/src/dsn.ts","../node_modules/@sentry/src/envelope.ts","../node_modules/@sentry/src/error.ts","../node_modules/@sentry/src/api.ts","../node_modules/@sentry/src/metrics/envelope.ts","../node_modules/@sentry/src/metrics/utils.ts","../node_modules/@sentry/src/baseclient.ts","../node_modules/@sentry/src/utils/sdkMetadata.ts","../node_modules/src/debug-build.ts","../node_modules/src/eventbuilder.ts","../node_modules/src/helpers.ts","../node_modules/src/client.ts","../node_modules/@sentry/src/env.ts","../node_modules/src/userfeedback.ts","../node_modules/@sentry/src/clientreport.ts","../node_modules/@sentry/src/instrument/console.ts","../node_modules/@sentry/src/instrument/dom.ts","../node_modules/@sentry/src/instrument/xhr.ts","../node_modules/@sentry/src/instrument/fetch.ts","../node_modules/@sentry/src/severity.ts","../node_modules/@sentry/src/url.ts","../node_modules/src/integrations/breadcrumbs.ts","../node_modules/src/integrations/dedupe.ts","../node_modules/@sentry/src/instrument/globalError.ts","../node_modules/@sentry/src/instrument/globalUnhandledRejection.ts","../node_modules/src/integrations/globalhandlers.ts","../node_modules/src/integrations/httpcontext.ts","../node_modules/@sentry/src/aggregate-errors.ts","../node_modules/src/integrations/linkederrors.ts","../node_modules/src/integrations/trycatch.ts","../node_modules/src/stack-parsers.ts","../node_modules/@sentry/src/promisebuffer.ts","../node_modules/@sentry/src/ratelimit.ts","../node_modules/@sentry/src/transports/base.ts","../node_modules/src/transports/utils.ts","../node_modules/src/transports/fetch.ts","../node_modules/src/transports/xhr.ts","../node_modules/src/sdk.ts","../node_modules/redux-persist/es/integration/react.js","../node_modules/react-router-dom/dom.ts","../node_modules/react-router-dom/index.tsx","pages/LandingPage/LandingPage.data.ts","pages/LandingPage/LandingPage.hooks.ts","components/Navbar/Navbar.data.ts","pages/HomePage/styles.ts","../node_modules/@mui/material/styles/cssUtils.js","../node_modules/@mui/system/esm/colorManipulator.js","../node_modules/@mui/material/Skeleton/skeletonClasses.js","../node_modules/@mui/material/Skeleton/Skeleton.js","components/SpeakableImage/SpeakableImage.hooks.ts","components/SpeakableImage/SpeakableImage.tsx","pages/HomePage/HomePage.hooks.ts","pages/HomePage/HomePage.data.ts","pages/HomePage/index.ts","pages/HomePage/HomePage.tsx","pages/LandingPage/styles.ts","assets/images/LandingPage/HomeSection/BackgroundImage.svg","components/LandingPage/LandingPageProductSection/styles.ts","../node_modules/@mui/system/esm/useMediaQuery/useMediaQuery.js","hooks/useIsMobile.ts","hooks/useIsSmallDesktop.ts","components/LandingPage/data.ts","components/LandingPage/styles.ts","components/LandingPage/hooks.ts","assets/images/LandingPage/PatternOrange.svg","assets/images/LandingPage/PatternBlue.svg","components/LandingPage/LandingPageProductSection/LandingPageProductSection.tsx","components/LandingPage/LandingPageProductSection/LandingPageProductSection.hooks.ts","components/LandingPage/LandingPageProductSection/LandingPageProductSection.data.ts","components/LandingPage/LandingPageProductSection/index.ts","components/LandingPage/LandingPageFeaturesSection/styles.ts","components/LandingPage/LandingPageFeaturesSection/LandingPageFeaturesSection.hooks.ts","components/LandingPage/LandingPageFeaturesSection/LandingPageFeaturesSection.data.ts","components/LandingPage/LandingPageTag/styles.ts","components/LandingPage/LandingPageTag/index.ts","components/LandingPage/LandingPageTag/LandingPageTag.tsx","components/LandingPage/LandingPageFeaturesSection/FeatureInformation/styles.ts","components/LandingPage/LandingPageFeaturesSection/FeatureInformation/FeatureInformation.hooks.ts","components/LandingPage/LandingPageFeaturesSection/FeatureInformation/index.ts","components/LandingPage/LandingPageFeaturesSection/FeatureInformation/FeatureInformation.tsx","components/LandingPage/LandingPageFeaturesSection/LandingPageFeaturesSection.tsx","components/LandingPage/LandingPageFeaturesSection/index.ts","components/LandingPage/LandingPageStorySection/styles.ts","components/LandingPage/LandingPageStorySection/LandingPageStorySection.hooks.ts","components/LandingPage/LandingPageStorySection/LandingPageStorySection.tsx","components/LandingPage/LandingPageStorySection/LandingPageStorySection.data.ts","components/LandingPage/LandingPageStorySection/index.ts","assets/images/LandingPage/PricingSection/Background.svg","components/LandingPage/LandingPagePricingSection/styles.ts","components/LandingPage/LandingPagePricingSection/LandingPagePricingSection.hooks.ts","components/LandingPage/PricingCard/styles.ts","assets/logos/LandingPageCheck.svg","components/LandingPage/PricingCard/PricingCard.hooks.ts","components/LandingPage/PricingCard/PricingCard.tsx","components/LandingPage/PricingCard/index.ts","components/LandingPage/LandingPagePricingSection/LandingPagePricingSection.tsx","components/LandingPage/LandingPagePricingSection/LandingPagePricingSection.data.ts","components/LandingPage/LandingPagePricingSection/index.ts","components/LandingPage/LandingPageContactSection/styles.ts","components/LandingPage/LandingPageContactSection/LandingPageContactSection.hooks.ts","components/LandingPage/LandingPageContactSection/LandingPageContactSection.tsx","components/LandingPage/LandingPageContactSection/LandingPageContactSection.data.ts","components/LandingPage/LandingPageContactSection/index.ts","../node_modules/@mui/base/NoSsr/NoSsr.js","../node_modules/@mui/material/Slide/Slide.js","../node_modules/@mui/material/Drawer/drawerClasses.js","../node_modules/@mui/material/Drawer/Drawer.js","../node_modules/@mui/material/SwipeableDrawer/SwipeArea.js","../node_modules/@mui/material/SwipeableDrawer/SwipeableDrawer.js","components/LandingPage/LandingPageSidebar/styles.ts","components/LandingPage/LandingPageSidebar/LandingPageSidebar.data.ts","components/LandingPage/LandingPageSidebar/LandingPageSidebar.tsx","components/LandingPage/LandingPageFooter/styles.ts","components/LandingPage/LandingPageFooter/LandingPageFooter.hooks.ts","components/LandingPage/LandingPageFooter/LandingPageFooter.data.ts","components/SpeakableLogo/SpeakableLogo.data.ts","components/SpeakableLogo/styles.ts","components/SpeakableLogo/SpeakableLogo.hooks.ts","components/SpeakableLogo/SpeakableLogo.tsx","components/SpeakableLogo/index.ts","components/LandingPage/LandingPageFooter/index.ts","components/LandingPage/LandingPageFooter/LandingPageFooter.tsx","pages/LandingPage/index.ts","pages/LandingPage/LandingPage.tsx","pages/NotFoundPage/styles.ts","pages/NotFoundPage/NotFound.hooks.ts","pages/NotFoundPage/index.ts","pages/NotFoundPage/NotFoundPage.tsx","../node_modules/@mui/material/FormControl/formControlClasses.js","../node_modules/@mui/material/FormControl/FormControl.js","../node_modules/@mui/material/FormLabel/formLabelClasses.js","../node_modules/@mui/material/FormLabel/FormLabel.js","../node_modules/@mui/material/InputLabel/inputLabelClasses.js","../node_modules/@mui/material/InputLabel/InputLabel.js","../node_modules/@mui/material/List/ListContext.js","../node_modules/@mui/material/List/listClasses.js","../node_modules/@mui/material/List/List.js","../node_modules/@mui/material/utils/getScrollbarSize.js","../node_modules/@mui/material/MenuList/MenuList.js","../node_modules/@mui/material/Popover/popoverClasses.js","../node_modules/@mui/material/Popover/Popover.js","../node_modules/@mui/material/Menu/menuClasses.js","../node_modules/@mui/material/Menu/Menu.js","../node_modules/@mui/material/NativeSelect/nativeSelectClasses.js","../node_modules/@mui/material/NativeSelect/NativeSelectInput.js","../node_modules/@mui/material/Select/selectClasses.js","../node_modules/@mui/material/Select/SelectInput.js","../node_modules/@mui/material/internal/svg-icons/ArrowDropDown.js","../node_modules/@mui/material/FilledInput/filledInputClasses.js","../node_modules/@mui/material/FilledInput/FilledInput.js","../node_modules/@mui/material/OutlinedInput/NotchedOutline.js","../node_modules/@mui/material/OutlinedInput/outlinedInputClasses.js","../node_modules/@mui/material/OutlinedInput/OutlinedInput.js","../node_modules/@mui/material/Select/Select.js","../node_modules/@mui/material/Divider/dividerClasses.js","../node_modules/@mui/material/ListItemIcon/listItemIconClasses.js","../node_modules/@mui/material/ListItemText/listItemTextClasses.js","../node_modules/@mui/material/MenuItem/menuItemClasses.js","../node_modules/@mui/material/MenuItem/MenuItem.js","pages/OnboardingPage/styles.ts","pages/OnboardingPage/OnboardingPage.hooks.ts","pages/OnboardingPage/OnboardingPage.tsx","pages/OnboardingPage/index.ts","pages/PrivacyPage/styles.ts","pages/PrivacyPage/PrivacyPage.data.ts","pages/PrivacyPage/index.ts","pages/PrivacyPage/PrivacyPage.tsx","pages/ProfilePage/styles.ts","../node_modules/@aws-amplify/core/src/singleton/apis/clearCredentials.ts","../node_modules/@aws-amplify/auth/src/utils/getAuthUserAgentValue.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/oauth/completeOAuthSignOut.ts","../node_modules/@aws-amplify/auth/src/utils/openAuthSession.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/oauth/getRedirectUrl.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/oauth/handleOAuthSignOut.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/oauth/oAuthSignOutRedirect.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/apis/signOut.ts","pages/ProfilePage/ProfilePage.data.ts","pages/ProfilePage/ProfilePage.hooks.tsx","pages/ProfilePage/ProfilePage.tsx","pages/ProfilePage/index.ts","pages/TOSPage/styles.ts","pages/TOSPage/TOSPage.data.ts","pages/TOSPage/index.ts","pages/TOSPage/TOSPage.tsx","pages/VerificationBlockerPage/styles.ts","api/auth/api.ts","pages/VerificationBlockerPage/VerificationBlockerPage.hooks.ts","pages/VerificationBlockerPage/index.ts","pages/VerificationBlockerPage/VerificationBlockerPage.tsx","pages/VerifyEmailPage/styles.ts","pages/VerifyEmailPage/VerifyEmailPage.data.ts","pages/VerifyEmailPage/VerifyEmailPage.hooks.ts","pages/VerifyEmailPage/VerifyEmailPage.tsx","pages/VerifyEmailPage/index.ts","hooks/useDescriptiveNavigate.ts","pages/ConversationDetailsPage/ConversationDetailsPage.hooks.ts","pages/ConversationDetailsPage/styles.ts","components/SpeakableImage/index.ts","pages/ConversationDetailsPage/ConversationDetailsPage.tsx","pages/ConversationDetailsPage/index.ts","components/PracticeGoals/PracticeGoals.data.ts","components/PracticeGoals/styles.ts","components/PracticeGoals/PracticeGoalSelector/styles.ts","components/PracticeGoals/PracticeGoalSelector/PracticeGoalSelector.data.ts","components/PracticeGoals/PracticeGoalOption/styles.ts","components/PracticeGoals/PracticeGoalOption/index.ts","components/PracticeGoals/PracticeGoalOption/PracticeGoalOption.tsx","components/PracticeGoals/PracticeGoalOption/PracticeGoalOption.data.ts","components/PracticeGoals/PracticeGoalSelector/index.ts","components/PracticeGoals/PracticeGoalSelector/PracticeGoalSelector.tsx","api/goals/api.ts","components/PracticeGoals/PracticeGoals.tsx","pages/PracticeGoalPage/styles.ts","pages/PracticeGoalPage/index.ts","pages/PracticeGoalPage/PracticeGoalPage.tsx","router/router.data.tsx","components/NoMobileComponent/styles.ts","components/NoMobileComponent/index.ts","components/NoMobileComponent/NoMobileComponent.tsx","wrappers/MobileWrapper/styles.ts","wrappers/MobileWrapper/MobileWrapper.hooks.ts","wrappers/MobileWrapper/index.ts","wrappers/MobileWrapper/MobileWrapper.tsx","components/Navbar/LandingPageNavbar/LandingPageNavbar.data.ts","components/Navbar/LandingPageNavbar/styles.ts","components/Navbar/styles.ts","components/Navbar/Navbar.hooks.ts","components/Navbar/LandingPageNavbar/LandingPageNavbar.hooks.ts","components/Navbar/LandingPageNavbar/LandingPageNavbar.tsx","components/Navbar/LandingPageNavbar/index.ts","components/Navbar/RegularNavbar/styles.ts","components/Navbar/RegularNavbar/RegularNavbar.hooks.ts","components/Navbar/RegularNavbar/RegularNavbar.tsx","components/Navbar/index.ts","components/Navbar/Navbar.tsx","utils/routes.ts","wrappers/PageWrapper/styles.ts","wrappers/PageWrapper/Banner.tsx","wrappers/PageWrapper/PageWrapper.hooks.ts","components/ModalManager/styles.ts","components/AuthComponents/LoginComponent/styles.ts","components/AuthComponents/styles.ts","components/AuthComponents/GoogleButton/styles.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/tokenProvider/cacheTokens.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/apis/getCurrentUser.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/apis/internal/getCurrentUser.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/dispatchSignedInHubEvent.ts","../node_modules/@aws-amplify/auth/src/errors/types/validation.ts","../node_modules/@aws-amplify/auth/src/common/AuthErrorStrings.ts","../node_modules/@aws-amplify/auth/src/Errors.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/oauth/createOAuthError.ts","../node_modules/@aws-amplify/auth/src/types/Auth.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/oauth/validateState.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/oauth/completeOAuthFlow.ts","../node_modules/@aws-amplify/core/src/utils/urlSafeDecode.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/oauth/handleFailure.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/oauth/attemptCompleteOAuthFlow.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/oauth/enableOAuthListener.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/types/models.ts","../node_modules/@aws-amplify/core/src/utils/convert/base64/base64Encoder.ts","../node_modules/@aws-amplify/core/src/utils/convert/base64/bytesToString.ts","../node_modules/@aws-amplify/core/src/utils/deviceName/getDeviceName.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/types/errors.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/signInStore.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/textEncoder/index.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/srp/BigInteger/BigInteger.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/srp/calculate/calculateS.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/srp/constants.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/srp/getBytesFromHex.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/srp/getHexFromBytes.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/srp/getHashFromData.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/srp/getHashFromHex.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/srp/getPaddedHex.ts","../node_modules/@aws-amplify/core/src/utils/WordArray.ts","../node_modules/@aws-amplify/core/src/utils/cryptoSecureRandomInt.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/srp/getRandomBytes.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/srp/AuthenticationHelper/AuthenticationHelper.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/srp/getRandomString.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/srp/calculate/calculateU.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/srp/getHkdfKey.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/srp/calculate/calculateA.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/srp/getAuthenticationHelper.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/srp/getNowString.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/srp/getSignatureString.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/signInHelpers.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/oauth/generateCodeVerifier.ts","../node_modules/@aws-amplify/core/src/utils/generateRandomString.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/oauth/generateState.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/apis/signInWithRedirect.ts","../node_modules/@aws-amplify/core/src/utils/urlSafeEncode.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/oauth/cancelOAuthFlow.ts","components/AuthComponents/GoogleButton/GoogleButton.hooks.ts","components/AuthComponents/GoogleButton/index.ts","components/AuthComponents/GoogleButton/GoogleButton.tsx","components/AuthComponents/data.ts","../node_modules/@aws-amplify/auth/src/errors/utils/assertValidationError.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/apis/signInWithCustomSRPAuth.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/apis/signInWithSRP.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/apis/signIn.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/apis/signInWithUserPassword.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/apis/signInWithCustomAuth.ts","components/AuthComponents/LoginComponent/LoginComponent.hooks.ts","components/AuthComponents/SwitchText/styles.ts","components/AuthComponents/SwitchText/SwitchText.data.ts","components/AuthComponents/SwitchText/SwitchText.hooks.ts","components/AuthComponents/SwitchText/index.ts","components/AuthComponents/SwitchText/SwitchText.tsx","components/AuthComponents/Field/styles.ts","components/AuthComponents/Field/Field.hooks.ts","components/AuthComponents/Field/Field.tsx","components/AuthComponents/LoginComponent/index.ts","components/AuthComponents/LoginComponent/LoginComponent.tsx","components/AuthComponents/SignupComponent/styles.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/apiHelpers.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/apis/autoSignIn.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/utils/signUpHelpers.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/apis/signUp.ts","components/AuthComponents/SignupComponent/SignupComponent.hooks.ts","components/AuthComponents/SignupComponent/index.ts","components/AuthComponents/SignupComponent/SignupComponent.tsx","components/AuthComponents/ForgotPasswordComponent/ForgotPasswordComponent.hooks.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/apis/resetPassword.ts","../node_modules/@aws-amplify/auth/src/providers/cognito/apis/confirmResetPassword.ts","components/AuthComponents/ForgotPasswordComponent/index.ts","components/AuthComponents/ForgotPasswordComponent/ForgotPasswordComponent.tsx","components/PlaybackBlockedComponent/styles.ts","components/PlaybackBlockedComponent/PlaybackBlockedComponent.tsx","components/ModalManager/ModalManager.data.tsx","components/ModalManager/ModalManager.hooks.ts","components/ModalManager/index.ts","components/ModalManager/ModalManager.tsx","wrappers/PageWrapper/index.ts","wrappers/PageWrapper/PageWrapper.tsx","api/utils/validation.ts","api/status/conversation/api.ts","api/utils/requests.ts","app/App.hooks.ts","app/App.tsx","app/index.ts","components/NotAuthorizedComponent/NotAuthorizedComponent.hooks.ts","components/NotAuthorizedComponent/styles.ts","components/NotAuthorizedComponent/NotAuthorizedComponent.tsx","router/router.tsx","components/ToastController/styles.ts","components/ToastController/index.ts","components/ToastController/ToastController.tsx","config/sentry.ts","index.tsx"],"sourceRoot":"","sourcesContent":["import { ApiError, get, post } from 'aws-amplify/api'\nimport { CreateConversationResponse } from '@speakable/speakable-service-contracts/lib/analytics/conversation'\nimport { AddToSessionRequest, AddToSessionResponse } from '@speakable/speakable-service-contracts/lib/analytics/session'\n\nexport const addToSession = async (requestBody: AddToSessionRequest): Promise => {\n try {\n const { response: promise } = post({\n apiName: 'analytics',\n path: '/session',\n options: { body: requestBody }\n })\n\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as any\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as any\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n\nexport const createEvent = async (\n {\n eventId,\n eventType = 'click',\n time\n }: {\n eventId: string\n time: number\n eventType?: 'click' | 'load'\n },\n isPrivate = true\n): Promise => {\n try {\n const { response: promise } = post({\n apiName: 'analytics',\n path: isPrivate ? '/event' : '/event/public',\n options: { body: { eventId, time, eventType } }\n })\n\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as any\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as any\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n\nexport const getSessionTime = async ({ startTime, endTime }: { startTime: number; endTime: number }): Promise => {\n try {\n const { response: promise } = get({\n apiName: 'analytics',\n path: '/session/time',\n options: { queryParams: { startTime: startTime.toString(), endTime: endTime.toString() } }\n })\n\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as any\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as any\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n","import { ApiError, post } from 'aws-amplify/api'\nimport {\n GetLipSyncRequest,\n GetLipSyncResponse,\n TextToSpeechRequest,\n TextToSpeechResponse,\n TranscribeRequest,\n TranscribeResponse\n} from '@speakable/speakable-service-contracts/lib/audio'\n\nexport const textToSpeech = async (requestBody: TextToSpeechRequest): Promise => {\n try {\n const { response: promise } = post({\n apiName: 'audio',\n path: '/text-to-speech',\n options: { body: requestBody }\n })\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as TextToSpeechResponse\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as TextToSpeechResponse\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n\n// TODO: Fix request type in service contracts\nexport const transcribe = async (requestBody: { audio: number[] }): Promise => {\n try {\n const { response: promise } = post({\n apiName: 'audio',\n path: '/transcribe',\n options: { body: requestBody }\n })\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as TranscribeResponse\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as TranscribeResponse\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n\nexport const lipSync = async (requestBody: GetLipSyncRequest): Promise => {\n try {\n const { response: promise } = post({\n apiName: 'audio',\n path: '/lipsync',\n options: { body: requestBody }\n })\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as any\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as any\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n","import { post, get, ApiError } from 'aws-amplify/api'\nimport {\n GetRunRequest,\n GetRunResponse,\n StartRunRequest,\n StartRunResponse,\n GetMessagesRequest,\n GetMessagesResponse,\n CreateThreadRequest,\n CreateThreadResponse,\n AddMessageRequest,\n AddMessageResponse\n} from '@speakable/speakable-service-contracts/lib/conversation'\n\nexport const createThread = async (requestBody: CreateThreadRequest): Promise => {\n try {\n const { response: promise } = post({\n apiName: 'conversation',\n path: '/thread',\n options: { body: { ...(requestBody as FormData), metadata: requestBody.metadata as any } }\n })\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as CreateThreadResponse\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as CreateThreadResponse\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n\nexport const getMessages = async (queryParams: GetMessagesRequest): Promise => {\n try {\n const { response: promise } = get({\n apiName: 'conversation',\n path: '/messages',\n options: { queryParams }\n })\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as GetMessagesResponse\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as GetMessagesResponse\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n\nexport const getRun = async (queryParams: GetRunRequest): Promise => {\n try {\n const { response: promise } = get({\n apiName: 'conversation',\n path: '/run',\n options: { queryParams }\n })\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as GetRunResponse\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as GetRunResponse\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n\nexport const addMessage = async (requestBody: AddMessageRequest): Promise => {\n try {\n const { response: promise } = post({\n apiName: 'conversation',\n path: '/message',\n options: { body: requestBody }\n })\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as AddMessageResponse\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as AddMessageResponse\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n\nexport const startRun = async (requestBody: StartRunRequest): Promise => {\n try {\n const { response: promise } = post({\n apiName: 'conversation',\n path: '/run',\n options: { body: requestBody }\n })\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as StartRunResponse\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as StartRunResponse\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n","import { ApiError, get, post } from 'aws-amplify/api'\nimport {\n GetCustomerStatusResponse,\n CreatePortalSessionResponse,\n CreateCheckoutSessionResponse\n} from '@speakable/speakable-service-contracts/lib/payment'\n\n// TODO add this input to the service-contracts\nexport const getSubscriptionStatus = async ({\n customerId\n}: {\n customerId: string\n}): Promise => {\n try {\n const { response: promise } = get({\n apiName: 'payment',\n path: '/subscription-status',\n options: { queryParams: { customerId } }\n })\n\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as GetCustomerStatusResponse\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as GetCustomerStatusResponse\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n\n// TODO: Fix service contracts\nexport const createPortalSession = async ({\n customerId\n}: {\n customerId: string\n}): Promise => {\n try {\n const { response: promise } = post({\n apiName: 'payment',\n path: '/portal-session',\n options: { body: { customerId } }\n })\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as CreatePortalSessionResponse\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as CreatePortalSessionResponse\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n\n// TODO: Fix service contracts\nexport const createCheckoutSession = async ({\n customerId\n}: {\n customerId: string\n}): Promise => {\n try {\n const { response: promise } = post({\n apiName: 'payment',\n path: '/checkout-session',\n options: { body: { customerId } }\n })\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as CreateCheckoutSessionResponse\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as CreateCheckoutSessionResponse\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n","import { ApiError, get, post } from 'aws-amplify/api'\n\nexport const createConversation = async (\n requestBody:\n | {\n conversationId: number\n conversation: { role: 'user' | 'assistant'; message: string }[]\n startDateString: string\n endDateString: string\n }\n | {\n conversationId: number\n conversation: { role: 'user' | 'assistant'; message: string }[]\n startDateString: string\n endDateString: string\n customizations: {\n place: string\n assistantRole: string\n purpose: string\n assistantBehavior: string\n gender: string\n }\n }\n): Promise => {\n try {\n const { response: promise } = post({\n apiName: 'statistics',\n path: '/conversation',\n options: { body: requestBody }\n })\n\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as any\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as any\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n\n// @todo add to lib\nexport const getPracticeHistory = async ({\n startDateString,\n endDateString\n}: {\n startDateString: string\n endDateString: string\n}): Promise => {\n try {\n const { response: promise } = get({\n apiName: 'statistics',\n path: `/progress`,\n options: { queryParams: { startDateString, endDateString } }\n })\n\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as any\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as any\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n\nexport const acknowledgeBadge = async ({\n achievementId,\n achievedAt\n}: {\n achievementId: number\n achievedAt: number\n}): Promise => {\n try {\n const { response: promise } = post({\n apiName: 'statistics',\n path: `/achievement/acknowledge`,\n options: { body: { achievementId, achievedAt } }\n })\n\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as any\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as any\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n","import { ApiError, get, post, put } from 'aws-amplify/api'\nimport { GetUserResponse, CompleteOnboardingResponse } from '@speakable/speakable-service-contracts/lib/user'\n\nexport const getUser = async (): Promise => {\n try {\n const { response: promise } = get({\n apiName: 'user',\n path: '/'\n })\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as GetUserResponse\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as GetUserResponse\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n\nexport const completeOnboarding = async ({\n selfReportedReferrer\n}: {\n selfReportedReferrer: string\n}): Promise => {\n try {\n const { response: promise } = post({\n apiName: 'user',\n path: '/complete-onboarding',\n options: { body: { selfReportedReferrer } }\n })\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as CompleteOnboardingResponse\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as CompleteOnboardingResponse\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n\n// @todo get types for this\nexport const getUserSettings = async (): Promise => {\n try {\n const { response: promise } = get({\n apiName: 'user',\n path: '/settings'\n })\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as any\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as any\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n\n// @todo get types for this\nexport const updateUserSettings = async (\n data: Partial<{\n questionFrequency: number\n responseLength: number\n responseComplexity: number\n allowConversationAnalysis: boolean\n autoRecordEnabled: boolean\n }>\n): Promise => {\n try {\n const { response: promise } = put({\n apiName: 'user',\n path: '/settings',\n options: {\n body: data\n }\n })\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as any\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as any\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n","import { z } from 'zod'\nimport { IZodValidator } from './IZodValidator.js'\n\n/**\n * A validator that uses the Zod library to validate objects.\n */\nexport class ZodValidator implements IZodValidator {\n validate(payload: any, schema: z.ZodTypeAny): boolean {\n const result = schema.safeParse(payload)\n return result.success\n }\n}\n","export type Response = {\n statusCode: TStatusCode\n body: TBody\n}\n\nexport type InternalServerErrorResponse = Response<500, { message: string }>\n\nexport type BadRequestResponse = Response<400, { message: string }>\n\nexport type ClientClosedRequestResponse = Response<499, { message: string }>\n\nexport const internalServerErrorResponse = (message: string): InternalServerErrorResponse => ({\n statusCode: 500,\n body: { message }\n})\n\nexport const badRequestResponse = (message: string): BadRequestResponse => ({ statusCode: 400, body: { message } })\n\nexport const clientClosedRequestResponse = (message: string): ClientClosedRequestResponse => ({\n statusCode: 499,\n body: { message }\n})\n","import { z } from 'zod'\nimport { get } from '@aws-amplify/api'\nimport { ILogger } from '../logger/ILogger'\nimport { IZodValidator } from '../zodValidator/IZodValidator'\nimport {\n BadRequestResponse,\n ClientClosedRequestResponse,\n InternalServerErrorResponse,\n badRequestResponse,\n clientClosedRequestResponse,\n internalServerErrorResponse\n} from '../responses'\nimport { IAmplifyAPIClient } from '../amplifyAPIClient/IAmplifyAPIClient'\nimport { ResponseSchema } from '../../../api/utils/types'\nimport { isCancelError, post } from 'aws-amplify/api'\nimport { IBaseAPIClient } from './IBaseAPIClient'\n\n/**\n * Base class for all API clients. It provides validation for input and output objects as well as the ability\n * to cancel requests early.\n */\nexport class BaseAPIClient implements IBaseAPIClient {\n protected apiName: string\n private amplifyAPIClient: IAmplifyAPIClient\n private zodValidator: IZodValidator\n private logger: ILogger\n\n /**\n * Creates a new instance of the BaseAPIClient class.\n *\n * @param apiName the name of the api in Amplify\n * @param zodValidator the zod validator to use for input and output validation\n * @param logger the logger to use for logging\n */\n constructor(apiName: string, amplifyAPIClient: IAmplifyAPIClient, zodValidator: IZodValidator, logger: ILogger) {\n this.apiName = apiName\n this.amplifyAPIClient = amplifyAPIClient\n this.zodValidator = zodValidator\n this.logger = logger\n }\n\n /**\n * @inheritdoc\n */\n public async get(\n path: string,\n options: Omit[0]['options'], 'queryParams'> & {\n requestQueryParams?: z.infer\n abortSignal?: AbortSignal\n },\n validation: { requestQueryParamsSchema: TRequestQueryParams; responseBodySchema: TResponseBody }\n ): Promise<\n z.infer | InternalServerErrorResponse | BadRequestResponse | ClientClosedRequestResponse\n > {\n try {\n const queryParamsValidationResult = this.zodValidator.validate(\n options?.requestQueryParams,\n validation.requestQueryParamsSchema\n )\n if (queryParamsValidationResult === false) {\n this.logger.logError('Invalid query parameters.')\n return badRequestResponse('Invalid query parameters.')\n }\n\n const { response, cancel } = this.amplifyAPIClient.get({\n apiName: this.apiName,\n path,\n options: { ...options, queryParams: options.requestQueryParams }\n })\n if (options?.abortSignal) {\n options.abortSignal.onabort = () => {\n cancel('Request was cancelled by the user.')\n }\n }\n\n const responseInformation = await response\n const body = { statusCode: responseInformation.statusCode, body: await (await response).body.json() }\n\n const responseBodyValidationResult = this.zodValidator.validate(body, validation.responseBodySchema)\n if (responseBodyValidationResult === false) {\n this.logger.logError('Invalid response body')\n return internalServerErrorResponse('Invalid response body')\n }\n\n return body as z.infer\n } catch (error) {\n if (isCancelError(error)) {\n this.logger.logInfo('Request was cancelled by the user.')\n return clientClosedRequestResponse('Request was cancelled by the user.')\n }\n\n this.logger.logError('An error occurred while processing the request.')\n return internalServerErrorResponse('An error occurred while processing the request.')\n }\n }\n\n /**\n * @inheritdoc\n */\n public async post(\n path: string,\n options: Omit[0]['options'], 'body'> & {\n requestBody?: z.infer\n abortSignal?: AbortSignal\n },\n validation: { requestBodySchema: TRequestBody; responseBodySchema: TResponseBody }\n ): Promise<\n z.infer | InternalServerErrorResponse | BadRequestResponse | ClientClosedRequestResponse\n > {\n try {\n const queryParamsValidationResult = this.zodValidator.validate(\n options?.requestBody,\n validation.requestBodySchema\n )\n if (queryParamsValidationResult === false) {\n this.logger.logError('Invalid body.')\n return badRequestResponse('Invalid body.')\n }\n\n const { response, cancel } = this.amplifyAPIClient.post({\n apiName: this.apiName,\n path,\n options: { ...options, body: options.requestBody }\n })\n if (options?.abortSignal) {\n options.abortSignal.onabort = () => {\n cancel('Request was cancelled by the user.')\n }\n }\n\n const responseInformation = await response\n const body = { statusCode: responseInformation.statusCode, body: await (await response).body.json() }\n\n const responseBodyValidationResult = this.zodValidator.validate(body, validation.responseBodySchema)\n if (responseBodyValidationResult === false) {\n this.logger.logError('Invalid response body')\n return internalServerErrorResponse('Invalid response body')\n }\n\n return body as z.infer\n } catch (error) {\n if (isCancelError(error)) {\n this.logger.logInfo('Request was cancelled by the user.')\n return clientClosedRequestResponse('Request was cancelled by the user.')\n }\n\n this.logger.logError('An error occurred while processing the request.')\n return internalServerErrorResponse('An error occurred while processing the request.')\n }\n }\n}\n","import { ILogger } from './ILogger'\n\n/**\n * A logger that does nothing (yet!).\n */\nexport class Logger implements ILogger {\n logError(error: string): void {}\n logInfo(message: string): void {}\n logWarn(message: string): void {}\n}\n","import {\n GetInput,\n GetOperation,\n PostInput,\n PostOperation,\n PutInput,\n PutOperation,\n PatchInput,\n PatchOperation,\n DeleteInput,\n DeleteOperation\n} from '@aws-amplify/api-rest/dist/esm/types'\nimport { get, post, put, patch, del } from '@aws-amplify/api'\nimport { IAmplifyAPIClient } from './IAmplifyAPIClient'\n\nexport class AmplifyAPIClient implements IAmplifyAPIClient {\n get(input: GetInput): GetOperation {\n return get(input)\n }\n post(input: PostInput): PostOperation {\n return post(input)\n }\n put(input: PutInput): PutOperation {\n return put(input)\n }\n patch(input: PatchInput): PatchOperation {\n return patch(input)\n }\n del(input: DeleteInput): DeleteOperation {\n return del(input)\n }\n}\n","import { ZodValidator } from './utils/zodValidator/ZodValidator'\nimport { BaseAPIClient } from './utils/baseAPIClient/BaseAPIClient'\nimport { Logger } from './utils/logger/Logger'\nimport { AmplifyAPIClient } from './utils/amplifyAPIClient/AmplifyAPIClient'\nimport { z } from 'zod'\nimport {\n createThreadRequestBodySchema,\n createThreadResponseBodySchema\n} from '@speakable/speakable-service-contracts/lib/conversation'\n\nexport class ConversationAPIClient extends BaseAPIClient {\n private static apiName: string = 'conversation'\n\n constructor() {\n super(ConversationAPIClient.apiName, new AmplifyAPIClient(), new ZodValidator(), new Logger())\n }\n\n async createThread(body: z.infer = undefined) {\n return this.post(\n '/thread',\n { requestBody: body },\n {\n requestBodySchema: createThreadRequestBodySchema,\n responseBodySchema: createThreadResponseBodySchema\n }\n )\n }\n}\n","import { Theme } from '@emotion/react'\nimport { SxProps } from '@mui/material'\n\nconst gap = 20\n\nconst styles: { [name: string]: SxProps } = {\n container: {\n display: 'flex',\n flexDirection: 'column',\n borderRadius: 2,\n gap,\n backgroundColor: '#F7F8F9',\n p: gap * 2\n },\n button: {\n width: '100%',\n height: 45\n },\n input: {\n width: '100%'\n },\n largeInput: {\n flexGrow: 1,\n minHeight: 150,\n overflowY: 'auto'\n },\n messageRow: {\n display: 'flex',\n flexGrow: 1,\n flexDirection: 'row',\n width: '100%',\n gap: 20\n }\n}\n\nexport default styles\n","import { useRef, useState } from 'react'\nimport { sendMessage } from '../../api/contact/api'\nimport { useGetUser } from '../../store/selectors/userSelector'\nimport { toast } from 'react-toastify'\nimport styles from './styles'\nimport { BRIGHT_GREEN, DISABLED_GRAY } from '../../utils/constants'\n\nconst useContactForm = (withoutEmail?: boolean) => {\n const [email, setEmail] = useState('')\n const [message, setMessage] = useState('')\n const [isLoading, setIsLoading] = useState()\n const { email: userEmail } = useGetUser()\n\n const senderEmail = withoutEmail && userEmail ? userEmail : (email as string)\n const canSubmit = [senderEmail, message].every((val) => val.length > 0)\n\n const onSubmit = async (): Promise => {\n if (canSubmit) {\n setIsLoading(true)\n try {\n await sendMessage({ senderEmail, message })\n toast.success('Message successfully sent!')\n setMessage('')\n setEmail('')\n } catch (e) {\n toast.error('There was an error sending your message.')\n } finally {\n setIsLoading(false)\n }\n }\n }\n\n const onTranscription = (transcription: string) => {\n setMessage(transcription)\n }\n\n const buttonStyles = {\n ...styles.button,\n backgroundColor: canSubmit ? BRIGHT_GREEN : DISABLED_GRAY,\n '&:hover': { cursor: canSubmit ? 'pointer' : 'default' }\n }\n\n return { buttonStyles, onSubmit, onTranscription, email, setEmail, message, setMessage, isLoading }\n}\n\nconst useDisableStates = () => {\n const [isRecording, setIsRecording] = useState(false)\n const [isProcessingAudio, setIsProcessingAudio] = useState(false)\n\n return { isRecording, setIsRecording, isProcessingAudio, setIsProcessingAudio }\n}\n\nexport { useContactForm, useDisableStates }\n","import { ApiError, post } from 'aws-amplify/api'\nimport {\n SendContactFormRequest,\n SendClinicianFormRequest,\n SendContactFormResponse,\n SendClinicianFormResponse\n} from '@speakable/speakable-service-contracts/lib/contact'\n\nexport const sendMessage = async (requestBody: SendContactFormRequest): Promise => {\n try {\n const { response: promise } = post({\n apiName: 'contact',\n path: '/contact-form',\n options: { body: requestBody }\n })\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as SendContactFormResponse\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as SendContactFormResponse\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n\nexport const sendForm = async (requestBody: SendClinicianFormRequest): Promise => {\n try {\n const { response: promise } = post({\n apiName: 'contact',\n path: '/clinician-form',\n options: { body: requestBody }\n })\n const { body: serializedBody, statusCode } = await promise\n return { body: await serializedBody.json(), statusCode } as SendClinicianFormResponse\n } catch (error) {\n try {\n if (error instanceof ApiError) {\n if (error.response) {\n const { statusCode, body } = error.response\n return { body, statusCode } as SendClinicianFormResponse\n }\n }\n throw new Error()\n } catch (e) {\n return {\n statusCode: 500,\n body: 'Internal Server Error'\n }\n }\n }\n}\n","import { Box, SxProps, Theme, Typography } from '@mui/material'\nimport styles from './styles'\nimport LandingPageButton from '../LandingPage/LandingPageButton'\nimport TextInput from '../../components/TextInput'\nimport { useContactForm, useDisableStates } from './ContactForm.hooks'\nimport Recorder from '../Recorder'\n\nexport interface IContactFormProps {\n sx?: SxProps\n withoutEmail?: boolean\n recordable?: boolean\n}\n\nconst ContactForm = ({ sx, withoutEmail, recordable }: IContactFormProps): JSX.Element => {\n const { buttonStyles, onSubmit, isLoading, onTranscription, email, setEmail, message, setMessage } =\n useContactForm(withoutEmail)\n const { isRecording, setIsRecording, isProcessingAudio, setIsProcessingAudio } = useDisableStates()\n\n return (\n }>\n {withoutEmail !== true && {'Email'}}\n {withoutEmail !== true && (\n \n )}\n {'Message'}\n \n {recordable && (\n \n )}\n }\n placeholder={'Your message...'}\n disabled={isRecording || isProcessingAudio}\n />\n \n \n \n )\n}\n\nexport default ContactForm\n","import ContactForm from './ContactForm'\n\nexport default ContactForm\n","import { GLTF } from 'three-stdlib'\nimport { AvatarAction, Conversation, Role, VisemeInformation } from '../../../store/conversation/data'\nimport * as THREE from 'three'\n\nexport type Node =\n | 'EyeLeft'\n | 'EyeRight'\n | 'Wolf3D_Head'\n | 'Wolf3D_Teeth'\n | 'Wolf3D_Hair'\n | 'Wolf3D_Body'\n | 'Wolf3D_Outfit_Bottom'\n | 'Wolf3D_Outfit_Footwear'\n | 'Wolf3D_Outfit_Top'\n | 'Hips'\n\nexport type Material =\n | 'Wolf3D_Eye'\n | 'Wolf3D_Skin'\n | 'Wolf3D_Teeth'\n | 'Wolf3D_Hair'\n | 'Wolf3D_Body'\n | 'Wolf3D_Outfit_Bottom'\n | 'Wolf3D_Outfit_Footwear'\n | 'Wolf3D_Outfit_Top'\n\nexport type GLTFResult = GLTF & GLTFNodesAndMaterials\n\nexport type GLTFNodesAndMaterials = {\n nodes: {\n EyeLeft: THREE.SkinnedMesh\n EyeRight: THREE.SkinnedMesh\n Wolf3D_Head: THREE.SkinnedMesh\n Wolf3D_Teeth: THREE.SkinnedMesh\n Wolf3D_Hair: THREE.SkinnedMesh\n Wolf3D_Body: THREE.SkinnedMesh\n Wolf3D_Outfit_Bottom: THREE.SkinnedMesh\n Wolf3D_Outfit_Footwear: THREE.SkinnedMesh\n Wolf3D_Outfit_Top: THREE.SkinnedMesh\n Hips: THREE.Bone\n }\n materials: {\n Wolf3D_Eye: THREE.MeshStandardMaterial\n Wolf3D_Skin: THREE.MeshStandardMaterial\n Wolf3D_Teeth: THREE.MeshStandardMaterial\n Wolf3D_Hair: THREE.MeshStandardMaterial\n Wolf3D_Body: THREE.MeshStandardMaterial\n Wolf3D_Outfit_Bottom: THREE.MeshStandardMaterial\n Wolf3D_Outfit_Footwear: THREE.MeshStandardMaterial\n Wolf3D_Outfit_Top: THREE.MeshStandardMaterial\n }\n}\n\nexport type Child = THREE.Object3D & {\n isSkinnedMesh: any\n morphTargetDictionary: any\n morphTargetInfluences: any\n}\n\nexport const azureToOculusVisemeMap: Map = new Map([\n [0, 'viseme_sil'],\n [1, 'viseme_aa'],\n [2, 'viseme_aa'],\n [3, 'viseme_O'],\n [4, 'viseme_E'],\n [5, 'viseme_RR'],\n [6, 'viseme_CH'], // double check this out\n [7, 'viseme_U'],\n [8, 'viseme_O'],\n [9, 'viseme_aa'],\n [10, 'viseme_O'],\n [11, 'viseme_aa'], // double check\n [12, 'viseme_E'], // double check\n [13, 'viseme_RR'],\n [14, 'viseme_nn'],\n [15, 'viseme_SS'],\n [16, 'viseme_CH'],\n [17, 'viseme_TH'],\n [18, 'viseme_FF'],\n [19, 'viseme_DD'],\n [20, 'viseme_kk'],\n [21, 'viseme_PP']\n])\n\nexport enum Voice {\n ANDREW_NEURAL = 'en-US-AndrewNeural',\n AVA_NEURAL = 'en-US-AvaNeural',\n BRIAN_NEURAL = 'en-US-BrianNeural',\n GUY_NEURAL = 'en-US-GuyNeural',\n EMMA_NEURAL = 'en-US-EmmaNeural',\n DAVIS_NEURAL = 'en-US-DavisNeural',\n JENNY_NEURAL = 'en-US-JennyNeural',\n ARIA_NEURAL = 'en-US-AriaNeural',\n JANE_NEURAL = 'en-US-JaneNeural',\n JASON_NEURAL = 'en-US-JasonNeural',\n BRANDON_NEURAL = 'en-US-BrandonNeural',\n TONY_NEURAL = 'en-US-TonyNeural'\n}\n\nexport enum AvatarState {\n STANDING,\n THINKING,\n TALKING\n}\n\nexport enum Gender {\n MALE = 'Male',\n FEMALE = 'Female'\n}\n\nexport interface Avatar {\n id: number\n name: string\n gender: Gender\n voice: Voice\n complexity: 'easy' | 'medium' | 'advanced'\n personality: string\n background: string\n mesh: Node[]\n}\n\nexport const allAvatars: Array = [\n {\n id: 0,\n name: 'Rachel',\n gender: Gender.FEMALE,\n voice: Voice.AVA_NEURAL,\n complexity: 'easy',\n personality:\n 'You are Rachel, a young, friendly woman who speaks in a peppy and upbeat tone. You are emphatic and understanding. You speak in a plain, simple manner.',\n background:\n 'If asked about your background, you are currently a nursing student with aspirations of being an ICU nurse. You grew up in a small midwestern town, and enjoy knitting, cooking, and playing the guitar in your free time.',\n mesh: [\n 'EyeLeft',\n 'EyeRight',\n 'Wolf3D_Head',\n 'Wolf3D_Teeth',\n 'Wolf3D_Hair',\n 'Wolf3D_Body',\n 'Wolf3D_Outfit_Bottom',\n 'Wolf3D_Outfit_Footwear',\n 'Wolf3D_Outfit_Top'\n ]\n },\n {\n id: 1,\n name: 'Carlos',\n gender: Gender.MALE,\n voice: Voice.BRIAN_NEURAL,\n complexity: 'easy',\n personality:\n 'You are Carlos. You are a kind, generous man who likes to compliment other people. You speak in short, simple sentences.',\n background:\n 'If asked about your background, you are the owner and operator of an Empanada shop in North Carolina. You moved to North Carolina from Argentina for better economic conditions. You have two high school age kids and a wife. In your free time, you enjoy watching soccer, playing soccer, and volunteering with your church.',\n mesh: [\n 'EyeLeft',\n 'EyeRight',\n 'Wolf3D_Head',\n 'Wolf3D_Teeth',\n 'Wolf3D_Hair',\n 'Wolf3D_Body',\n 'Wolf3D_Outfit_Bottom',\n 'Wolf3D_Outfit_Footwear',\n 'Wolf3D_Outfit_Top'\n ]\n },\n {\n id: 2,\n name: 'Marcus',\n gender: Gender.MALE,\n voice: Voice.DAVIS_NEURAL,\n complexity: 'medium',\n personality:\n 'You are Marcus, a thoughtful, contemplative, academic man. You enjoy talking about history and reminiscing about past times. You enjoy sharing your opinion and asking other people about theirs.',\n background:\n 'If asked about your background, you are a retired university professor of history from New Orleans. Your focus area was on the Vietnam war. In your free time, you enjoy reading historical accounts, watching documentaries, playing with your dogs, and mentoring high school students with an interest in history.',\n mesh: [\n 'EyeLeft',\n 'EyeRight',\n 'Wolf3D_Head',\n 'Wolf3D_Teeth',\n 'Wolf3D_Hair',\n 'Wolf3D_Body',\n 'Wolf3D_Outfit_Bottom',\n 'Wolf3D_Outfit_Footwear',\n 'Wolf3D_Outfit_Top'\n ]\n },\n {\n id: 3,\n name: 'Vivian',\n gender: Gender.FEMALE,\n voice: Voice.JANE_NEURAL,\n complexity: 'advanced',\n personality:\n 'You are Vivian, a person with a love of science. You speak in precise, informative sentences. You enjoy learning why people believe or think certain things.',\n background:\n 'If asked about your background, you are a scientist with a Ph.D. in biochemistry from Boston. You work in a research lab focusing on genomics research. In your free time, you enjoy reading scientific journals, woodworking, and practicing tai chi.',\n mesh: [\n 'EyeLeft',\n 'EyeRight',\n 'Wolf3D_Head',\n 'Wolf3D_Teeth',\n 'Wolf3D_Hair',\n 'Wolf3D_Body',\n 'Wolf3D_Outfit_Footwear',\n 'Wolf3D_Outfit_Top'\n ]\n },\n {\n id: 4,\n name: 'Luna',\n gender: Gender.FEMALE,\n voice: Voice.ARIA_NEURAL,\n complexity: 'advanced',\n personality:\n 'You are Luna, a free spirit that enjoys nature, the environment and travel. You are a kind person that cares about the feelings of others.',\n background:\n 'If asked about your background, you are a freelance artist from the Pacific Northwest. You are a painter with several successful pieces. In your free time, you enjoy stargazing, writing poetry, and attending local art and thrift clothing events.',\n mesh: [\n 'EyeLeft',\n 'EyeRight',\n 'Wolf3D_Head',\n 'Wolf3D_Teeth',\n 'Wolf3D_Hair',\n 'Wolf3D_Body',\n 'Wolf3D_Outfit_Bottom',\n 'Wolf3D_Outfit_Footwear',\n 'Wolf3D_Outfit_Top'\n ]\n },\n {\n id: 5,\n name: 'James',\n gender: Gender.MALE,\n voice: Voice.ANDREW_NEURAL,\n complexity: 'easy',\n personality:\n 'You are James, a down-to-earth guy that speaks in a straightforward, simple manner. You talk in short, simple sentences.',\n background:\n 'If asked about your background, you are a highschool teacher from the West Coast. You teach in the same town you grew up in. In your free time, you coach the school’s soccer team, watch 80’s movies, and train for triathlons.',\n mesh: [\n 'EyeLeft',\n 'EyeRight',\n 'Wolf3D_Head',\n 'Wolf3D_Teeth',\n 'Wolf3D_Hair',\n 'Wolf3D_Body',\n 'Wolf3D_Outfit_Bottom',\n 'Wolf3D_Outfit_Footwear',\n 'Wolf3D_Outfit_Top'\n ]\n },\n {\n id: 6,\n name: 'Mark',\n gender: Gender.MALE,\n voice: Voice.GUY_NEURAL,\n complexity: 'easy',\n personality:\n 'You are Mark, a jovial and outgoing man. You easily make new friends. You are adventurous and love trying new things, often seeking out adrenaline-pumping activities for excitement. You speak in shorter sentences.',\n background:\n 'If asked about your background, you work as a firefighter. You have a strong sense of duty and take pride in helping others. You grew up in a large family and learned the value of camaraderie at an early age. In your free time, you enjoy hiking, camping, and attending live music events.',\n mesh: [\n 'EyeLeft',\n 'EyeRight',\n 'Wolf3D_Head',\n 'Wolf3D_Teeth',\n 'Wolf3D_Hair',\n 'Wolf3D_Body',\n 'Wolf3D_Outfit_Bottom',\n 'Wolf3D_Outfit_Footwear',\n 'Wolf3D_Outfit_Top'\n ]\n },\n {\n id: 7,\n name: 'Myra',\n gender: Gender.FEMALE,\n voice: Voice.EMMA_NEURAL,\n complexity: 'easy',\n personality:\n 'You are Myra, a gentle and compassionate soul. You listen more than you talk. You are deeply empathetic, try to understand others’ feelings and perspectives, and find joy in the simple things. You are a succinct, caring speaker.',\n background:\n 'If asked about your background, you are a librarian in a small town. You have always had a passion for books, which goes back to your experience growing up as a girl in this town and going to this library. In your free time, you volunteer at the local animal shelter and tend to your garden.',\n mesh: [\n 'EyeLeft',\n 'EyeRight',\n 'Wolf3D_Head',\n 'Wolf3D_Teeth',\n 'Wolf3D_Hair',\n 'Wolf3D_Body',\n 'Wolf3D_Outfit_Bottom',\n 'Wolf3D_Outfit_Footwear',\n 'Wolf3D_Outfit_Top'\n ]\n },\n {\n id: 8,\n name: 'Evelyn',\n gender: Gender.FEMALE,\n voice: Voice.JENNY_NEURAL,\n complexity: 'medium',\n personality:\n 'You are Evelyn, a kind-hearted and compassionate woman. You have a gentle spirit and a nurturing nature that makes you beloved by all who know you. You are a great listener and offer sage advice drawn from your own life experiences. You value family above all else.',\n background:\n 'If asked about your background, you are a retired receptionist at a doctor’s office. You have seen it all in your years on the job and have countless stories to share. You grew up in a tight-knit community and have remained close with your childhood friends throughout your life. In your free time, you enjoy your book club, baking, and hosting gatherings for your family and friends.',\n mesh: [\n 'EyeLeft',\n 'EyeRight',\n 'Wolf3D_Head',\n 'Wolf3D_Teeth',\n 'Wolf3D_Hair',\n 'Wolf3D_Body',\n 'Wolf3D_Outfit_Bottom',\n 'Wolf3D_Outfit_Footwear',\n 'Wolf3D_Outfit_Top'\n ]\n },\n {\n id: 9,\n name: 'Dimitri',\n gender: Gender.MALE,\n voice: Voice.JASON_NEURAL,\n complexity: 'advanced',\n personality:\n 'You are Dimitri, a suave individual that exudes confidence and charm. You are well-spoken and articulate, with a knack for diplomacy, persuasion, and navigating social situations with finesse.',\n background:\n 'You work as a diplomatic liaison for the World Health Organization, negotiating agreements and fostering diplomatic relations between countries. You hold degrees in political science and international relations. You grew up in a diplomatic family, where you developed a keen understanding of global affairs from a young age. In his free time, you enjoy attending cultural events and practicing martial arts.',\n mesh: [\n 'EyeLeft',\n 'EyeRight',\n 'Wolf3D_Head',\n 'Wolf3D_Teeth',\n 'Wolf3D_Hair',\n 'Wolf3D_Body',\n 'Wolf3D_Outfit_Bottom',\n 'Wolf3D_Outfit_Footwear',\n 'Wolf3D_Outfit_Top'\n ]\n },\n {\n id: 10,\n name: 'Alex',\n gender: Gender.MALE,\n voice: Voice.TONY_NEURAL,\n complexity: 'advanced',\n personality:\n 'You are Alex, a charming and articulate conversationalist. You possess a natural ability to engage others with your wit and intellect. You enjoy discussing a wide range of topics, from philosophy to pop culture, and you’re always eager to learn something new. You have a knack for storytelling and often captivates your audience with anecdotes and insights.',\n background:\n 'If asked about your background, you work as a journalist for the New York Times. You have a passion for storytelling and believe in the power of journalism to inspire change. You grew up in a multicultural environment, which fueled your curiosity about the world. In your free time, you enjoy attending literary events, exploring new cafes, and writing fiction.',\n mesh: [\n 'EyeLeft',\n 'EyeRight',\n 'Wolf3D_Head',\n 'Wolf3D_Teeth',\n 'Wolf3D_Hair',\n 'Wolf3D_Body',\n 'Wolf3D_Outfit_Bottom',\n 'Wolf3D_Outfit_Footwear',\n 'Wolf3D_Outfit_Top'\n ]\n },\n {\n id: 11,\n name: 'William',\n gender: Gender.MALE,\n voice: Voice.BRIAN_NEURAL,\n complexity: 'advanced',\n personality:\n 'You are William, a determined and ambitious individual. You have a strong work ethic, are confident and assertive, and are unafraid to speak your mind and stand up for what you believe in.',\n background:\n 'If asked about your background, you work as a lawyer in a prestigious law firm. You studied law at Harvard and excelled in your studies. You grew up in a bustling city and was raised by a single mother, who instilled in you the values of hard work and perseverance. In your free time, you enjoy crossfit, reading, and whiskey tasting.',\n mesh: [\n 'EyeLeft',\n 'EyeRight',\n 'Wolf3D_Head',\n 'Wolf3D_Teeth',\n 'Wolf3D_Hair',\n 'Wolf3D_Body',\n 'Wolf3D_Outfit_Bottom',\n 'Wolf3D_Outfit_Footwear',\n 'Wolf3D_Outfit_Top'\n ]\n }\n]\n\nexport const avatarMap: Map = new Map([\n [0, allAvatars[0]], // Rachel\n [1, allAvatars[1]], // Carlos\n [2, allAvatars[2]], // Marcus\n [3, allAvatars[3]], // Vivian\n [4, allAvatars[4]], // Luna\n [5, allAvatars[5]], // James\n [6, allAvatars[6]], // Mark\n [7, allAvatars[7]], // Myra\n [8, allAvatars[8]], // Evelyn\n [9, allAvatars[9]], // Dimitri\n [10, allAvatars[10]], // Alex\n [11, allAvatars[11]] // William\n])\n\nexport interface IAvatarProps {\n avatarId: number\n setIsLoadingAvatar?: React.Dispatch>\n avatarAction: AvatarAction\n visemeInformation: VisemeInformation[]\n}\n\n/**\n * This function is used to lerp the morph target of the avatar.\n *\n * @param scene the scene in which the avatar is in\n * @param target the morphtarget to lerp\n * @param value the value to lerp to\n * @param speed the speed at which to lerp\n */\nexport const lerpMorphTarget = (\n scene: THREE.Group,\n target: string,\n value: number,\n speed = 0.1\n) => {\n scene.traverse((child: any) => {\n const modifiedChild = child as Child\n if (modifiedChild.isSkinnedMesh && modifiedChild.morphTargetDictionary) {\n const index = modifiedChild.morphTargetDictionary[target]\n\n modifiedChild.morphTargetInfluences[index] = THREE.MathUtils.lerp(\n modifiedChild.morphTargetInfluences[index],\n value,\n speed\n )\n }\n })\n}\n\nexport const MAX_LERP_VALUE = 1\nexport const MIN_LERP_VALUE = 0\n\n/**\n * This enum is used to determine the type of animation the avatar should be playing.\n */\nexport enum AnimationType {\n GREETING, // greets the user (only played once at the beginning of a conversation)\n STANDING, // standing idle (waiting for user input)\n TALKING, // talking to the user (responding to user input)\n THINKING, // generating a response to the user\n QUESTIONING // asking the user a question\n}\n\n/**\n * Maps the AnimationType to an array of animation names that should be played for that type\n */\nexport const animationTypeMap = new Map([\n [AnimationType.GREETING, ['Greeting-1']],\n [AnimationType.STANDING, ['Standing-1', 'Standing-2']],\n [AnimationType.TALKING, ['Talking-2']], // Talking-1 is deemed not good\n [AnimationType.THINKING, ['Thinking-1', 'Thinking-2']],\n [AnimationType.QUESTIONING, ['Question-1']] // Question-2 is deemed not good\n])\n\n/**\n * This function is used to get the next animation name based on the current animation type.\n * We pick a random animation from the list of animations for that type. If `currentAnimation` is\n * provided, we ensure that the next animation is different from the current one unless there is only\n * one animation to choose from.\n *\n * @param animationType the current animation type\n * @param currentAnimation the current animation name\n * @returns a random animation from the list of animations for that type\n */\nexport const getRandomAnimation = (animationType: AnimationType, currentAnimation?: string): string => {\n let animations = animationTypeMap.get(animationType)\n if (animations === undefined) throw new Error('AnimationType not found!')\n if (currentAnimation !== undefined && animations.length > 1) {\n animations = animations.filter((a) => a !== currentAnimation)\n }\n return animations[Math.floor(Math.random() * animations.length)]\n}\n\n/**\n * This function is used to determine if the last assistant message in the conversation contains a question.\n *\n * @returns true if the last assistant message contains a question, false otherwise\n */\nexport const doesLastAssistantMessageContainQuestion = (conversation: Conversation): boolean => {\n const assistantMessages = conversation.filter((c) => c.role === Role.ASSISTANT)\n if (assistantMessages.length === 0) return false\n return assistantMessages[assistantMessages.length - 1].content.includes('?')\n}\n","export interface IPropViewerProps {\n prop: ConversationProp\n}\n\nexport enum ConversationProp {\n CHINESE_MENU,\n MEXICAN_MENU,\n FAST_FOOD_MENU,\n FINE_DINING_MENU,\n ITALIAN_MENU,\n COFFEE_SHOP_MENU\n}\n\nexport interface Prop {\n internalName: string\n externalName: string\n image: any\n}\n\nexport const allProps: Array = [\n {\n internalName: 'Chinese Menu',\n externalName: 'Menu',\n image: require('../../../assets/images/ConversationPage/Restaurant/ChineseMenu.png')\n },\n {\n internalName: 'Mexican Menu',\n externalName: 'Menu',\n image: require('../../../assets/images/ConversationPage/Restaurant/MexicanMenu.png')\n },\n {\n internalName: 'Fast Food Menu',\n externalName: 'Menu',\n image: require('../../../assets/images/ConversationPage/Restaurant/FastFoodMenu.png')\n },\n {\n internalName: 'Fine Dining Menu',\n externalName: 'Menu',\n image: require('../../../assets/images/ConversationPage/Restaurant/FineDiningMenu.png')\n },\n {\n internalName: 'Italian Menu',\n externalName: 'Menu',\n image: require('../../../assets/images/ConversationPage/Restaurant/ItalianMenu.png')\n },\n {\n internalName: 'Coffee Shop Menu',\n externalName: 'Menu',\n image: '/images/props/coffeeShopMenu.jpeg'\n }\n]\n\nexport const propMap: Map = new Map([\n [ConversationProp.CHINESE_MENU, allProps[0]],\n [ConversationProp.MEXICAN_MENU, allProps[1]],\n [ConversationProp.FAST_FOOD_MENU, allProps[2]],\n [ConversationProp.FINE_DINING_MENU, allProps[3]],\n [ConversationProp.ITALIAN_MENU, allProps[4]],\n [ConversationProp.COFFEE_SHOP_MENU, allProps[5]]\n])\n","import { Theme } from '@emotion/react'\nimport { SxProps } from '@mui/material'\nimport { BRIGHT_GREEN, DISABLED_GRAY } from '../../../utils/constants'\n\nconst verticalPadding = 10\nconst horizontalPadding = verticalPadding * 2\n\nconst styles: { [name: string]: SxProps } = {\n container: {\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n backgroundColor: BRIGHT_GREEN,\n borderRadius: 2,\n p: verticalPadding,\n pl: horizontalPadding,\n pr: horizontalPadding,\n width: 'fit-content',\n '&:hover': { cursor: 'pointer' }\n },\n text: { color: 'white', userSelect: 'none' },\n disabled: {\n '&:hover': { cursor: 'default' },\n backgroundColor: DISABLED_GRAY\n }\n}\n\nexport default styles\n","import { Box, CircularProgress, SxProps, Theme, Typography } from '@mui/material'\nimport styles from './styles'\nimport { createEvent } from '../../../api/analytics/api'\nimport { useGetAuthentication } from '../../../store/selectors/authenticationSelector'\n\nexport interface LandingPageButtonProps {\n id: string\n onClick: () => void\n text: string\n containerOverrides?: SxProps\n disabled?: boolean\n loading?: boolean\n}\n\nconst LandingPageButton = ({\n id,\n onClick: passedOnClick,\n text,\n containerOverrides,\n disabled,\n loading\n}: LandingPageButtonProps): JSX.Element => {\n const { isAuthenticated } = useGetAuthentication()\n const containerStyles = { ...styles.container, ...(loading || disabled ? styles.disabled : {}) } as SxProps\n\n const onClick = () => {\n createEvent({ eventId: id, time: new Date().getTime() }, isAuthenticated === true)\n if (!loading && !disabled) passedOnClick()\n }\n\n return (\n } onClick={onClick}>\n {loading ? : {text}}\n \n )\n}\n\nexport default LandingPageButton\n","import LandingPageButton from './LandingPageButton'\n\nexport default LandingPageButton\n","import { useEffect, useState } from 'react'\nimport AudioPlayer, { StartPlaybackResponse } from '../../utils/classes/audioPlayer'\nimport { toast } from 'react-toastify'\nimport { textToSpeech } from '../../api/audio/api'\nimport { throwSentryException } from '../../utils/sentry'\nimport Recorder from '../../utils/classes/recorder'\nimport { createEvent } from '../../api/analytics/api'\nimport { useGetAuthentication } from '../../store/selectors/authenticationSelector'\nimport { useIsMounted } from '../../hooks/useIsMounted'\n\nconst audioPlayer = AudioPlayer.GetAudioPlayer()\nconst audioRecorder = Recorder.getRecorder()\n\nconst useListenableText = ({ gender, text }: { gender?: 'MALE' | 'FEMALE'; text: string }) => {\n const isMounted = useIsMounted()\n const { isAuthenticated } = useGetAuthentication()\n const [cachedAudio, setCachedAudio] = useState()\n const [isLoadingAudio, setIsLoadingAudio] = useState(false)\n const [isPlayingAudio, setIsPlayingAudio] = useState(false)\n\n // stop the audio if the component is unmounted\n useEffect(() => {\n if (isPlayingAudio) {\n return () => {\n if (!isMounted()) audioPlayer.stop()\n }\n }\n }, [isPlayingAudio])\n\n // whenever the text changes, we need to clear the cached audio\n useEffect(() => {\n setCachedAudio(undefined)\n }, [text])\n\n const onClick = async () => {\n if (audioPlayer.isPlaying || isLoadingAudio || audioRecorder.isRecording) return\n createEvent(\n { eventId: `listenable-text-${text.slice(0, 10)}`, time: new Date().getTime() },\n isAuthenticated === true\n )\n if (cachedAudio !== undefined) {\n const source = URL.createObjectURL(cachedAudio)\n setIsPlayingAudio(true)\n const response = await audioPlayer.play({ source })\n if (response !== StartPlaybackResponse.SUCCESS) {\n throwSentryException({\n error: `Could not play cached audio from ListenableText. StartPlaybackResponse = ${response}`\n })\n toast.error('Could not play the audio.')\n }\n setIsPlayingAudio(false)\n return\n }\n\n setIsLoadingAudio(true)\n const audioGender = gender ?? (['MALE', 'FEMALE'][Math.floor(Math.random() * 2)] as 'MALE' | 'FEMALE')\n const { statusCode, body } = await textToSpeech({ text, gender: audioGender })\n setIsLoadingAudio(false)\n if (statusCode === 200) {\n const data = new Uint8Array((body.audio as any).data)\n const blob = new Blob([data], { type: 'audio/mp3' })\n setCachedAudio(blob)\n const source = URL.createObjectURL(blob)\n setIsPlayingAudio(true)\n const response = await audioPlayer.play({ source })\n if (response !== StartPlaybackResponse.SUCCESS) {\n throwSentryException({\n error: `Could not play cached audio from ListenableText. StartPlaybackResponse = ${response}`\n })\n toast.error('Could not play the audio.')\n }\n setIsPlayingAudio(false)\n } else {\n throwSentryException({ error: `Could not play generated audio from ListenableText.` })\n toast.error('Could not play the audio.')\n }\n }\n\n return { onClick, isLoadingAudio }\n}\n\nexport default useListenableText\n","const styles = {\n container: {\n display: 'flex',\n flexDirection: 'row',\n maxWidth: '100%',\n alignItems: 'center'\n },\n buttonContainer: {\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n mr: 10,\n border: 1,\n borderRadius: '50%'\n },\n icon: { width: '75%', height: '75%' }\n}\n\nexport default styles\n","import { Box, CircularProgress, SxProps, Theme, Tooltip, Typography } from '@mui/material'\nimport VolumeUpIcon from '@mui/icons-material/VolumeUp'\nimport { HOVER_GRAY } from '../../utils/constants'\nimport useListenableText from './ListenableText.hooks'\nimport styles from './styles'\nimport { ListenableTextProps } from './ListenableText.data'\n\nconst ListenableText = ({\n text,\n textSx,\n containerSx,\n noWrap,\n size,\n gender,\n containerRef\n}: ListenableTextProps): JSX.Element => {\n const { onClick, isLoadingAudio } = useListenableText({ gender, text })\n let buttonSize = size === 'large' ? 50 : size === 'medium' ? 35 : 25\n\n return (\n }\n onClick={(e) => e.stopPropagation()}\n >\n \n \n {isLoadingAudio ? (\n \n ) : (\n \n )}\n \n \n \n {text}\n \n \n )\n}\n\nexport default ListenableText\n","import ListenableText from './ListenableText'\n\nexport default ListenableText\n","import { SxProps, Theme } from '@mui/material'\n\nconst styles: { [name: string]: SxProps } = {\n container: {\n display: 'flex',\n width: '100%',\n height: '100%',\n alignItems: 'center',\n justifyContent: 'center',\n flexDirection: 'column'\n },\n loadingSpinner: {\n color: 'black',\n mt: 20\n },\n text: {\n textAlign: 'center'\n }\n}\n\nexport default styles\n","import { Box, CircularProgress, SxProps, Theme, Typography } from '@mui/material'\nimport styles from './styles'\nimport { memo } from 'react'\n\ntype LoadingComponentProps = {\n loadingMessage: string\n sx?: SxProps\n textSx?: SxProps\n spinnerSize?: string | number\n}\n\nconst LoadingComponent = ({ loadingMessage, sx, textSx, spinnerSize }: LoadingComponentProps): JSX.Element => {\n return (\n }>\n }>\n {loadingMessage}\n \n \n \n )\n}\n\nexport default memo(LoadingComponent)\n","import LoadingComponent from './LoadingComponent'\n\nexport default LoadingComponent\n","import { SxProps, Theme } from '@mui/material'\nimport { DISABLED_GRAY, HOVER_GRAY, LIGHT_GREEN } from '../../utils/constants'\n\nconst sideLength = 60\nconst borderRadius = 2\n\nconst styles: { [name: string]: SxProps } = {\n container: {\n display: 'flex',\n position: 'relative',\n alignItems: 'center',\n justifyContent: 'center',\n border: 1,\n borderRadius,\n minWidth: sideLength,\n minHeight: sideLength,\n maxWidth: sideLength,\n maxHeight: sideLength,\n backgroundColor: 'white',\n p: 5,\n '&:hover': { cursor: 'pointer', backgroundColor: HOVER_GRAY }\n },\n image: {\n width: '80%',\n aspectRatio: 1,\n userSelect: 'none'\n },\n loading: {\n '&:hover': { cursor: 'default', backgroundColor: DISABLED_GRAY },\n backgroundColor: DISABLED_GRAY\n },\n disabled: {\n '&:hover': { cursor: 'default', backgroundColor: DISABLED_GRAY },\n backgroundColor: DISABLED_GRAY\n },\n popupContainer: {\n position: 'absolute',\n opacity: 0.95,\n '&:hover': { cursor: 'default' },\n width: 250,\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n bottom: '100%',\n left: '50%',\n translate: '-50% -10px',\n textAlign: 'center',\n backgroundColor: 'white',\n p: 5,\n borderRadius: 2,\n border: 1,\n zIndex: 3,\n userSelect: 'none'\n },\n popupText: {\n color: 'black',\n userSelect: 'none'\n }\n}\n\nexport default styles\n","import { useEffect, useState } from 'react'\nimport styles from './styles'\nimport { SxProps, Theme } from '@mui/material'\nimport { maxRecordingTime } from './Recorder.data'\nimport { LIGHT_GREEN } from '../../utils/constants'\nimport { toast } from 'react-toastify'\nimport { throwSentryException } from '../../utils/sentry'\nimport { transcribe } from '../../api/audio/api'\nimport Recorder, { StartRecordingResponse, StopRecordingResponse } from '../../utils/classes/recorder'\nimport { createEvent } from '../../api/analytics/api'\nimport { useGetAuthentication } from '../../store/selectors/authenticationSelector'\n\nconst useRecorder = (\n onTranscription: ((transcription: string) => void) | ((transcription: string) => Promise),\n setRecording?: React.Dispatch> | undefined,\n setLoading?: React.Dispatch> | undefined,\n isDisabled?: boolean\n) => {\n const pathname = window.location.pathname\n const [isRecording, setIsRecording] = useState(false)\n const [isHovering, setIsHovering] = useState(false)\n const [timePercentageLeft, setTimePercentageLeft] = useState(1)\n const [timeInterval, setTimeInterval] = useState()\n const [isLoading, setIsLoading] = useState(false)\n const [isLoadingRecorder, setIsLoadingRecorder] = useState(false)\n const { isAuthenticated } = useGetAuthentication()\n\n useEffect(() => {\n if (setRecording !== undefined) {\n setRecording(isRecording)\n }\n }, [isRecording])\n\n useEffect(() => {\n if (setLoading !== undefined) {\n setLoading(isLoading)\n }\n }, [isLoading])\n\n const containerStyles = {\n ...styles.container,\n ...(isLoading ? styles.loading : {}),\n ...(isRecording\n ? {\n background: `linear-gradient(to top, ${LIGHT_GREEN} ${100 * timePercentageLeft}%, white ${\n 100 * timePercentageLeft\n }%)`\n }\n : {}),\n ...(isDisabled ? styles.disabled : {})\n } as SxProps\n\n const onClick = () => {\n createEvent(\n {\n eventId: `recorder-button-${isLoading || isDisabled ? 'disabled' : 'enabled'}-${pathname}`,\n time: new Date().getTime()\n },\n isAuthenticated === true\n )\n if (isLoading || isDisabled) return\n\n if (isRecording) {\n stopRecording()\n } else {\n startRecording()\n }\n }\n\n const startRecording = async () => {\n if (isLoadingRecorder) return\n const audioRecorder = Recorder.getRecorder()\n setIsLoadingRecorder(true)\n const startRecordingResult = await audioRecorder.startRecording()\n switch (startRecordingResult) {\n case StartRecordingResponse.ALREADY_RECORDING:\n toast.error('You are already recording! Please finish your current recording before recording again.')\n break\n case StartRecordingResponse.NO_PERMISSION:\n toast.error('You have not given Speakable permission to use your microphone.')\n break\n case StartRecordingResponse.UNEXPECTED_ERROR:\n toast.error('There was an unexpected problem while starting the recording.')\n break\n case StartRecordingResponse.SUCCESS:\n setIsRecording(true)\n const startTime = new Date().getTime()\n const intervalId = setInterval(() => {\n const newInterval = 1 - (new Date().getTime() - startTime) / (1000 * maxRecordingTime)\n if (newInterval < 0) {\n clearInterval(intervalId)\n stopRecording()\n } else {\n setTimePercentageLeft(newInterval)\n }\n }, 50)\n setTimeInterval(intervalId)\n break\n }\n\n setIsLoadingRecorder(false)\n }\n\n const stopRecording = async () => {\n cleanupRecording()\n const audioRecorder = Recorder.getRecorder()\n const stopRecordingResult = await audioRecorder.stopRecording()\n switch (stopRecordingResult) {\n case StopRecordingResponse.MISSING_MEDIA_RECORDER:\n toast.error('There was an unexpected problem while stopping the recording.')\n throwSentryException({ error: 'Missing Media Recorder', hint: {} })\n break\n case StopRecordingResponse.UNEXPECTED_ERROR:\n toast.error('There was an unexpected problem while stopping the recording.')\n throwSentryException({ error: 'Unexpected Error', hint: {} })\n break\n case StopRecordingResponse.SUCCESS:\n try {\n const blob = audioRecorder.blob\n if (blob === undefined) {\n toast.error('There was an unexpected problem while stopping the recording.')\n throwSentryException({ error: 'Error getting blob', hint: {} })\n return\n }\n\n setIsLoading(true)\n const audio = [...new Uint8Array(await blob.arrayBuffer())]\n if (audio.length < 1000) {\n onTranscription('')\n setIsLoading(false)\n return\n }\n const { statusCode, body } = await transcribe({ audio })\n if (statusCode === 200) {\n onTranscription(body.transcription)\n } else {\n throw new Error()\n }\n } catch (e: any) {\n throwSentryException({ error: 'Error transcribing audio', hint: {} })\n toast.error('There was an unexpected problem while processing your audio.')\n } finally {\n setIsLoading(false)\n }\n break\n }\n }\n\n const cleanupRecording = () => {\n setIsRecording(false)\n clearInterval(timeInterval)\n setTimeInterval(undefined)\n setTimePercentageLeft(1)\n }\n\n const onMouseEnter = () => setIsHovering(true)\n const onMouseLeave = () => setIsHovering(false)\n\n return {\n containerStyles,\n isRecording,\n isHovering,\n timePercentageLeft,\n isLoading,\n onClick,\n onMouseEnter,\n onMouseLeave\n }\n}\n\nexport default useRecorder\n","import { Box, CircularProgress, SxProps, Theme, Typography } from '@mui/material'\nimport styles from './styles'\nimport useRecorder from './Recorder.hooks'\nimport { IRecorderProps } from './Recorder.data'\nimport R from '../../utils/classes/recorder'\n\nconst Recorder = ({\n sx,\n iconSx,\n disabled,\n disableTooltip,\n onTranscription,\n setRecordingState,\n setLoadingState\n}: IRecorderProps): JSX.Element => {\n const { containerStyles, isRecording, isHovering, isLoading, onClick, onMouseEnter, onMouseLeave } = useRecorder(\n onTranscription,\n setRecordingState,\n setLoadingState,\n disabled\n )\n\n return (\n \n }\n onClick={onClick}\n onMouseEnter={onMouseEnter}\n onMouseLeave={onMouseLeave}\n >\n {isLoading ? (\n \n ) : (\n {\n e.preventDefault()\n e.stopPropagation()\n }}\n sx={{ ...styles.image, ...iconSx } as SxProps}\n src={require('../../assets/logos/micLogo.png')}\n />\n )}\n {(isHovering || isRecording) && !disabled && !disableTooltip && (\n e.stopPropagation()}>\n \n {isLoading\n ? 'Processing your audio'\n : isRecording\n ? 'Click again to stop recording'\n : 'Click to start recording'}\n \n \n )}\n \n )\n}\n\nexport default Recorder\n","import Recorder from './Recorder'\n\nexport default Recorder\n","import { BOLD_FONT_WEIGHT, componentShadow } from '../../utils/constants'\n\nconst styles = {\n container: {\n display: 'flex',\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center',\n border: 1,\n borderColor: 'black',\n borderRadius: 5\n },\n text: {\n fontWeight: BOLD_FONT_WEIGHT,\n textAlign: 'center',\n userSelect: 'none'\n },\n loadingSpinner: {\n color: 'white'\n },\n icon: {\n width: 50,\n aspectRatio: 1\n },\n contentContainer: {\n display: 'flex',\n flexDirection: 'row',\n alignItems: 'center',\n gap: 5\n }\n}\n\nexport default styles\n","import { Box, CircularProgress, SxProps, Theme, Typography } from '@mui/material'\nimport styles from './styles'\nimport { DARK_GREEN, DISABLED_GRAY, GREEN, HOVER_GRAY, LIGHT_GREEN, componentShadow } from '../../utils/constants'\nimport { useState } from 'react'\nimport { createEvent } from '../../api/analytics/api'\nimport { useGetAuthentication } from '../../store/selectors/authenticationSelector'\n\ntype SpeakableButtonProps = {\n id: string\n text: string\n disabled?: boolean\n onClick?: () => void\n icon?: JSX.Element\n loading?: boolean\n variant?: 'important' | 'normal'\n size?: 'small' | 'medium' | 'large'\n selected?: boolean\n containerSxOverride?: SxProps\n textSxOverride?: SxProps\n spinnerSxOverride?: SxProps\n testId?: string\n}\n\nconst sizeScale = 80\n\nconst SpeakableButton = (props: SpeakableButtonProps) => {\n const { isAuthenticated } = useGetAuthentication()\n const [isPressed, setIsPressed] = useState(false)\n\n // don't want the button to be enabled if it's disabled or in a loading state\n const effectivelyDisabled = props.disabled || props.loading\n\n // colors (defaults to white button)\n const normalBackgroundColor = effectivelyDisabled\n ? DISABLED_GRAY\n : props.variant === 'important'\n ? props.selected\n ? DARK_GREEN\n : GREEN\n : props.selected\n ? GREEN\n : 'white'\n const hoverBackgroundColor = props.variant === 'important' ? DARK_GREEN : HOVER_GRAY\n\n // sizing (defaults to medium size)\n const containerWidth =\n props.size === 'large' ? sizeScale * 3 : props.size === 'small' ? sizeScale * 2 : (sizeScale * 5) / 2\n const containerHeight =\n props.size === 'large' ? (sizeScale * 3) / 4 : props.size === 'small' ? sizeScale / 2 : (sizeScale * 5) / 8\n const spinnerSize =\n props.size === 'large'\n ? `${(sizeScale * 3) / 100}em`\n : props.size === 'small'\n ? `${sizeScale / 50}em`\n : `${(sizeScale * 5) / 2 / 100}em`\n const textVariant = props.size === 'large' ? 'h5' : props.size === 'small' ? 'h6' : 'h5'\n\n const baseTextStyles: SxProps = {\n ...styles.text\n }\n\n const baseContainerStyles: SxProps = {\n ...styles.container,\n boxShadow: isPressed && !effectivelyDisabled ? 'default' : componentShadow,\n translate: `0px ${isPressed && !effectivelyDisabled ? 3 : 0}px`,\n width: containerWidth,\n maxWidth: containerWidth,\n minWidth: containerWidth,\n height: containerHeight,\n maxHeight: containerHeight,\n minHeight: containerHeight,\n backgroundColor: normalBackgroundColor,\n '&:hover': {\n cursor: effectivelyDisabled ? 'default' : 'pointer',\n backgroundColor: effectivelyDisabled\n ? DISABLED_GRAY\n : props.selected\n ? normalBackgroundColor\n : hoverBackgroundColor\n }\n }\n\n const baseSpinnerStyles: SxProps = {\n ...styles.loadingSpinner,\n ...props.spinnerSxOverride\n }\n\n const onClick = () => {\n createEvent({ eventId: props.id, time: new Date().getTime() }, isAuthenticated === true)\n if (effectivelyDisabled || props.onClick === undefined) return\n props.onClick()\n }\n\n return (\n setIsPressed(true)}\n onMouseUp={() => setIsPressed(false)}\n onMouseLeave={() => setIsPressed(false)}\n data-testid={props.testId}\n >\n {props.loading ? (\n \n ) : (\n \n {props.text.length > 0 && (\n \n {props.text}\n \n )}\n {props.icon !== undefined && <>{props.icon}}\n \n )}\n \n )\n}\n\nexport default SpeakableButton\n","import SpeakableButton from './SpeakableButton'\n\nexport default SpeakableButton\n","import { SxProps, Theme } from '@mui/material'\n\nconst styles: { [name: string]: SxProps } = {\n input: {\n display: 'flex',\n alignItems: 'flex-start',\n border: 1,\n borderRadius: 2,\n borderColor: '#D5DAE1',\n p: 5,\n pl: 10,\n pr: 10,\n backgroundColor: 'white'\n }\n}\n\nexport default styles\n","import { Input, SxProps, Theme } from '@mui/material'\nimport { ITextInputProps } from './TextInput.data'\nimport { ForwardedRef, forwardRef } from 'react'\nimport styles from './styles'\n\nconst TextInput = (props: ITextInputProps, ref: ForwardedRef): JSX.Element => {\n return (\n {\n if (e.target.value === '\\n') return\n props.setvalue(e.target.value)\n }}\n disableUnderline={true}\n sx={{ ...styles.input, ...props.sx } as SxProps}\n maxRows={props.multiline ? 2 : undefined}\n />\n )\n}\n\nexport default forwardRef(TextInput)\n","import TextInput from './TextInput'\n\nexport default TextInput\n","type Config = {\n name: 'prod' | 'dev' | 'experimental' | 'local'\n baseUrl:\n | 'https://speakabletherapy.com'\n | 'https://dev.speakabletherapy.com'\n | 'https://exp.speakabletherapy.com'\n | 'http://localhost:3000'\n cognito: {\n region: string\n userPoolID: string\n userPoolAppClientID: string\n identityPoolID: string\n }\n endpoints: Endpoints\n}\n\ntype Endpoints = {\n conversation: string\n user: string\n contact: string\n auth: string\n payment: string\n audio: string\n analytics: string\n status: string\n statistics: string\n goals: string\n}\n\nconst prod: Config = {\n name: 'prod',\n baseUrl: 'https://speakabletherapy.com',\n cognito: {\n region: 'us-east-1',\n userPoolID: 'us-east-1_38gPOYxev',\n userPoolAppClientID: 'tko23lqmuhf9m1dosrdl4jjtk',\n identityPoolID: 'us-east-1:a1189aaa-81eb-4779-bd84-b5080e839c24'\n },\n endpoints: {\n conversation: 'https://25uwwy2y8j.execute-api.us-east-1.amazonaws.com',\n user: 'https://lyrsqp585l.execute-api.us-east-1.amazonaws.com',\n contact: 'https://rs6hew1bae.execute-api.us-east-1.amazonaws.com',\n auth: 'https://bcghablqh6.execute-api.us-east-1.amazonaws.com',\n payment: 'https://9lbm7wcj30.execute-api.us-east-1.amazonaws.com',\n audio: 'https://1vbjmxe9i6.execute-api.us-east-1.amazonaws.com',\n analytics: 'https://89mlep4eni.execute-api.us-east-1.amazonaws.com',\n status: 'https://xqdhpdee6e.execute-api.us-east-1.amazonaws.com',\n statistics: 'https://ata65om5bj.execute-api.us-east-1.amazonaws.com',\n goals: 'https://oswkjpas01.execute-api.us-east-1.amazonaws.com'\n }\n}\n\nconst dev: Config = {\n name: 'dev',\n baseUrl: 'https://dev.speakabletherapy.com',\n cognito: {\n region: 'us-east-1',\n userPoolID: 'us-east-1_d9djbzwWp',\n userPoolAppClientID: '7bfa26ki26i3d2dfsrh4ojhjg5',\n identityPoolID: 'us-east-1:2d4464fa-1d9f-4f57-8d74-092d03756a3f'\n },\n endpoints: {\n conversation: 'https://7z5wzrig1b.execute-api.us-east-1.amazonaws.com',\n user: 'https://slj6byc1t0.execute-api.us-east-1.amazonaws.com',\n contact: 'https://03qoh9vqs7.execute-api.us-east-1.amazonaws.com',\n auth: 'https://2pic3ii0di.execute-api.us-east-1.amazonaws.com',\n payment: 'https://wq9q31qmcc.execute-api.us-east-1.amazonaws.com',\n audio: 'https://i2jebrfa59.execute-api.us-east-1.amazonaws.com',\n analytics: 'https://0d1ybnqo76.execute-api.us-east-1.amazonaws.com',\n status: 'https://8xzopz5vtg.execute-api.us-east-1.amazonaws.com',\n statistics: 'https://f8uigjv3h8.execute-api.us-east-1.amazonaws.com',\n goals: 'https://3l6lhnfma2.execute-api.us-east-1.amazonaws.com'\n }\n}\n\nconst experimental: Config = {\n name: 'experimental',\n baseUrl: 'https://exp.speakabletherapy.com',\n cognito: dev.cognito,\n endpoints: dev.endpoints\n}\n\nconst local: Config = {\n name: 'local',\n baseUrl: 'http://localhost:3000',\n cognito: {\n region: process.env.REACT_APP_LOCAL_REGION as string,\n userPoolID: process.env.REACT_APP_LOCAL_USER_POOL_ID as string,\n userPoolAppClientID: process.env.REACT_APP_LOCAL_USER_POOL_APP_CLIENT_ID as string,\n identityPoolID: process.env.REACT_APP_LOCAL_IDENTITY_POOL_ID as string\n },\n endpoints: {\n conversation: process.env.REACT_APP_LOCAL_ENDPOINT_CONVERSATION as string,\n user: process.env.REACT_APP_LOCAL_ENDPOINT_USER as string,\n contact: process.env.REACT_APP_LOCAL_ENDPOINT_CONTACT as string,\n auth: process.env.REACT_APP_LOCAL_ENDPOINT_AUTH as string,\n payment: process.env.REACT_APP_LOCAL_ENDPOINT_PAYMENT as string,\n audio: process.env.REACT_APP_LOCAL_ENDPOINT_AUDIO as string,\n analytics: process.env.REACT_APP_LOCAL_ENDPOINT_ANALYTICS as string,\n status: process.env.REACT_APP_LOCAL_ENDPOINT_STATUS as string,\n statistics: process.env.REACT_APP_LOCAL_ENDPOINT_STATISTICS as string,\n goals: process.env.REACT_APP_LOCAL_ENDPOINT_GOALS as string\n }\n}\n\nconst current_env = process.env.REACT_APP_ENV\n\n// use `config` to hit the correct endpoints depending on what environment you're working in\nexport const config =\n current_env === 'prod' ? prod : current_env === 'dev' ? dev : current_env === 'experimental' ? experimental : local\n","import { useEffect, useRef } from 'react'\n\n/**\n * This hook returns a function that returns whether the component is mounted.\n *\n * @returns a function that returns whether the component is mounted\n */\nexport const useIsMounted = () => {\n const isMounted = useRef(false)\n useEffect(() => {\n isMounted.current = true\n return () => {\n isMounted.current = false\n }\n }, [])\n return () => isMounted.current\n}\n","export type SliceState = {\n isAuthenticated: boolean | 'unknown'\n}\n\nexport const initialState: SliceState = {\n isAuthenticated: 'unknown'\n}\n","import { PayloadAction, createSlice } from '@reduxjs/toolkit'\nimport { initialState } from './data'\n\nconst authenticationSlice = createSlice({\n name: 'authentication',\n initialState,\n reducers: {\n setAuthenticationState(state, action: PayloadAction) {\n state.isAuthenticated = action.payload\n }\n }\n})\n\nexport const { setAuthenticationState } = authenticationSlice.actions\nexport default authenticationSlice.reducer\n","import { ConversationProp } from '../../components/ConversationPage/PropViewer/PropViewer.data'\nimport storage from 'redux-persist/lib/storage'\nimport FastfoodIcon from '@mui/icons-material/Fastfood'\nimport StoreIcon from '@mui/icons-material/Store'\nimport WorkIcon from '@mui/icons-material/Work'\nimport LocalHospitalIcon from '@mui/icons-material/LocalHospital'\nimport PeopleAltIcon from '@mui/icons-material/PeopleAlt'\nimport MovieIcon from '@mui/icons-material/Movie'\n\nexport enum ConversationTag {\n PROFESSIONAL = 'Professional',\n FOOD = 'Food',\n HEALTH = 'Health',\n ERRANDS = 'Errands',\n SOCIAL = 'Social',\n POP_CULTURE = 'Pop Culture'\n}\n\nexport const conversationTags = new Map([\n [ConversationTag.ERRANDS, StoreIcon],\n [ConversationTag.PROFESSIONAL, WorkIcon],\n [ConversationTag.FOOD, FastfoodIcon],\n [ConversationTag.HEALTH, LocalHospitalIcon],\n [ConversationTag.SOCIAL, PeopleAltIcon],\n [ConversationTag.POP_CULTURE, MovieIcon]\n])\n\nexport interface ConversationDetails {\n externalName: string // what the users will see this conversation be called\n assistantId: string\n details?: {\n // (optional) more details about the conversation\n place: string\n role: string\n purpose: string\n behavior: string\n }\n tags: ConversationTag[] // tags for the conversation\n description: string[] // a user-facing description of the conversation, divided into chunks\n categoryName?: string // name of the overarching conversation topic this specific conversation belongs to (optional)\n prop?: ConversationProp // a prop for this conversation (optional)\n}\n\nexport const conversationMap: Map = new Map([\n [\n 0,\n {\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: 'Custom Conversation',\n tags: [],\n description: []\n }\n ],\n [\n 1,\n {\n assistantId: 'asst_Tcc9PV3RKJAlTkfwYfWL453Y',\n externalName: 'Custom Conversation',\n tags: [],\n description: [\n 'First you will speak with an avatar to determine what conversation you would like to have.',\n 'After, you will have that conversation!'\n ]\n }\n ],\n [\n 2,\n {\n categoryName: 'Chinese Restaurant',\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: 'Ordering Food at a Chinese Restaruant',\n details: {\n place: 'Chinese Restaurant',\n role: 'You are a server at a restaurant that serves the MENU below.',\n purpose: \"Take the user's drink and food orders.\",\n behavior:\n 'You should be polite and professional. Ask the user if they have any questions about the menu or any dietary restrictions, and help them find something they like to eat. Feel free to make small talk to encourage further conversation.'\n },\n prop: ConversationProp.CHINESE_MENU,\n tags: [ConversationTag.FOOD],\n description: [\n 'In this conversation, you are ordering food at a Chinese restaurant. The avatar will be your waiter or waitress and will help you order from the menu.',\n 'Your task is to place your food and drink order.'\n ]\n }\n ],\n [\n 3,\n {\n categoryName: 'Mexican Restaurant',\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: 'Ordering Food at a Mexican Restaruant',\n details: {\n place: 'Mexican Restaurant',\n role: 'You are a server at a restaurant that serves the MENU below.',\n purpose: \"Take the user's drink and food orders.\",\n behavior:\n 'You should be polite and professional. Ask the user if they have any questions about the menu or any dietary restrictions, and help them find something they like to eat. Feel free to make small talk to encourage further conversation.'\n },\n prop: ConversationProp.MEXICAN_MENU,\n tags: [ConversationTag.FOOD],\n description: [\n 'In this conversation, you are ordering food at a Mexican restaurant. The avatar will be your waiter or waitress and will help you order from the menu.',\n 'Your task is to place your food and drink order.'\n ]\n }\n ],\n [\n 4,\n {\n categoryName: 'Fast Food Restaurant',\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: 'Ordering Food at a Fast Food Restaruant',\n details: {\n place: 'Fast Food Restaurant',\n role: 'You are a server at a restaurant that serves the MENU below.',\n purpose: \"Take the user's drink and food orders.\",\n behavior:\n 'You should be polite and professional. Ask the user if they have any questions about the menu or any dietary restrictions, and help them find something they like to eat. Feel free to make small talk to encourage further conversation.'\n },\n prop: ConversationProp.FAST_FOOD_MENU,\n tags: [ConversationTag.FOOD],\n description: [\n 'In this conversation, you are ordering food at a Fast Food restaurant. The avatar will be the cashier and will help you order from the menu.',\n 'Your task is to place your food and drink order.'\n ]\n }\n ],\n [\n 5,\n {\n categoryName: 'Fine Dining Restaurant',\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: 'Ordering Food at a Fine Dining Restaruant',\n details: {\n place: 'Fine Dining Restaurant',\n role: 'You are a server at a restaurant that serves the MENU below.',\n purpose: \"Take the user's drink and food orders.\",\n behavior:\n 'You should be polite and professional. Ask the user if they have any questions about the menu or any dietary restrictions, and help them find something they like to eat. Feel free to make small talk to encourage further conversation.'\n },\n prop: ConversationProp.FINE_DINING_MENU,\n tags: [ConversationTag.FOOD],\n description: [\n 'In this conversation, you are ordering food at a Fine Dining restaurant. The avatar will be your waiter or waitress and will help you order from the menu.',\n 'Your task is to place your food and drink order.'\n ]\n }\n ],\n [\n 6,\n {\n categoryName: 'Italian Restaurant',\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: 'Ordering Food at an Italian Restaruant',\n details: {\n place: 'Italian Restaurant',\n role: 'You are a server at a restaurant that serves the MENU below.',\n purpose: \"Take the user's drink and food orders.\",\n behavior:\n 'You should be polite and professional. Ask the user if they have any questions about the menu or any dietary restrictions, and help them find something they like to eat. Feel free to make small talk to encourage further conversation.'\n },\n prop: ConversationProp.ITALIAN_MENU,\n tags: [ConversationTag.FOOD],\n description: [\n 'In this conversation, you are ordering food at an Italian restaurant. The avatar will be your waiter or waitress and will help you order from the menu.',\n 'Your task is to place your food and drink order.'\n ]\n }\n ],\n [\n 7,\n {\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: 'Meeting a new Person',\n tags: [ConversationTag.SOCIAL],\n description: [\n 'In this conversation, you are meeting a new person. The avatar will be the new person you are meeting.'\n ]\n }\n ],\n [\n 8,\n {\n assistantId: 'asst_wKqzi5Q0jAOvo2ifv0NA05Rm',\n externalName: 'Talking About Your Speech',\n tags: [ConversationTag.HEALTH],\n description: [\n 'In this conversation, you will talk about your speech with the avatar.',\n 'The avatar will be a supportive listener who will help you express your thoughts and feelings about your speech.'\n ]\n }\n ],\n [\n 9,\n {\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: 'Opinion Sharing',\n details: {\n place: '',\n role: 'You are an inquisitive person asking the user a fun, opinion-sharing question like the one from the EXAMPLE QUESTIONs list.',\n purpose: 'Discuss a fun, opinion-sharing question with the user.',\n behavior:\n 'Begin the conversation by asking the user a question like one from the EXAMPLE QUESTIONS list. After the user replies, follow up to ask why they made their choices. After asking follow-up questions, you should either politely offer an opposing/complementary viewpoint or start a new conversation with a new question.'\n },\n tags: [ConversationTag.SOCIAL],\n description: [\n 'In this conversation, you will share your opinions on fun, light-hearted topics with the avatar.',\n 'The avatar will ask you questions to encourage you to share your thoughts and feelings.'\n ]\n }\n ],\n [\n 10,\n {\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: 'Advising a Friend',\n tags: [ConversationTag.SOCIAL],\n description: [\n 'In this conversation, you will advise a friend on a problem they are facing. The avatar will be your friend who needs your help.'\n ]\n }\n ],\n [\n 11,\n {\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: 'Job Interview',\n tags: [ConversationTag.PROFESSIONAL],\n description: [\n 'In this conversation, you are in a job interview. The avatar will be the interviewer asking you questions.',\n 'Your task is to answer the interviewer’s questions and ask any questions you have about the job.'\n ]\n }\n ],\n [\n 12,\n {\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: 'Hardware Store',\n tags: [ConversationTag.ERRANDS],\n description: [\n 'In this conversation, you are at the hardware store.',\n 'The avatar will be the store employee helping you find the right tools and materials for your home improvement project.'\n ]\n }\n ],\n [\n 13,\n {\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: 'Dinner Party Planning',\n tags: [ConversationTag.FOOD],\n description: [\n 'In this conversation, you are planning a dinner party.',\n 'The avatar will be a family member who will help you decide what to make for everyone.'\n ]\n }\n ],\n [\n 14,\n {\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: 'Networking Event',\n tags: [ConversationTag.PROFESSIONAL],\n description: [\n 'In this conversation, you are at a networking event.',\n 'The avatar will be another person at the event who you can network with.'\n ]\n }\n ],\n [\n 15,\n {\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: 'Recipe Sharing',\n tags: [ConversationTag.FOOD],\n description: [\n 'In this conversation, you are talking about recipes.',\n 'The avatar will be a friend to share your recipes with.'\n ]\n }\n ],\n [\n 16,\n {\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: 'Auto Mechanic Visit',\n tags: [ConversationTag.ERRANDS],\n description: [\n 'In this conversation, you are at the auto mechanic.',\n 'The avatar will be a mechanic who will answer your car-related issues or questions.'\n ]\n }\n ],\n [\n 17,\n {\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: 'Dry Cleaner Visit',\n tags: [ConversationTag.ERRANDS],\n description: [\n 'In this conversation, you are at the dry cleaner.',\n 'The avatar will be a worker at the dry cleaner who will help you with your dry cleaning assistance.'\n ]\n }\n ],\n [\n 18,\n {\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: 'Library Visit',\n tags: [ConversationTag.ERRANDS],\n description: [\n 'In this conversation, you are at a library.',\n 'The avatar will be a librarian who will help you find books or chat about books.'\n ]\n }\n ],\n [\n 19,\n {\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: 'Making an Appointment',\n tags: [ConversationTag.HEALTH],\n description: [\n 'In this conversation, you are speaking with a hospital worker.',\n `The avatar will help you schedule a doctor's appointment.`\n ]\n }\n ],\n [\n 20,\n {\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: `Doctor's Office Check-In`,\n tags: [ConversationTag.HEALTH],\n description: [\n 'In this conversation, you are speaking with a hospital worker.',\n `The avatar will help you schedule a doctor's appointment.`\n ]\n }\n ],\n [\n 21,\n {\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: `Pet Store`,\n tags: [ConversationTag.ERRANDS],\n description: [\n 'In this conversation, you are at a pet store.',\n `The avatar will be a worker at the store who will help you with your needs.`\n ]\n }\n ],\n [\n 22,\n {\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: `Electronics Store`,\n tags: [ConversationTag.ERRANDS],\n description: [\n 'In this conversation, you are at an electronics store.',\n `The avatar will be a worker at the store who will help you with your needs.`\n ]\n }\n ],\n [\n 23,\n {\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: `Coffee Shop`,\n tags: [ConversationTag.FOOD],\n description: [\n 'In this conversation, you are at a coffee shop.',\n `The avatar will be the barista who will take your order.`\n ],\n prop: ConversationProp.COFFEE_SHOP_MENU\n }\n ],\n [\n 24,\n {\n assistantId: 'asst_uC2IukKBVDXQpckLrGLF3U2u',\n externalName: `Grocery Store`,\n tags: [ConversationTag.ERRANDS],\n description: [\n 'In this conversation, you are at a grocery store.',\n `The avatar will be a worker at the store who will help you find what you need.`\n ]\n }\n ]\n])\n\nexport enum AvatarAction {\n STANDING,\n TALKING,\n LISTENING,\n THINKING\n}\n\nexport interface Customizations {\n place: string\n assistantRole: string\n purpose: string\n assistantBehavior: string\n gender: 'Male' | 'Female' | 'Unknown'\n}\n\nexport enum Role {\n ASSISTANT = 'assistant',\n USER = 'user'\n}\n\nexport interface VisemeInformation {\n timestamp: number // ms offset from the start of the audio,\n visemeId: number\n}\n\nexport interface AvatarAudioInformation {\n audio: Blob\n visemes: VisemeInformation[]\n action: AvatarAction\n}\n\nexport interface Message {\n content: string\n role: Role\n}\n\nexport interface WordBoundaries {\n audioOffset: number\n boundaryType: string\n text: string\n textOffset: number\n wordLength: number\n}\n\nexport interface UserMessage extends Message {\n addedToThread: boolean // has the message been added to the thread yet?\n numResponsesToGenerate: number // how many responses should be generated for this message?\n}\n\nexport interface AssistantMessage extends Message {\n avatarAction: AvatarAction\n avatarId: number\n auxillaryInformation?: {\n audio: string // base64 string\n visemes: VisemeInformation[]\n wordBoundaries: WordBoundaries[]\n }\n}\n\nexport type Conversation = Array\n\nexport type InitializeConversationInput = {\n conversationId: number\n avatarId: number\n customizations?: Customizations\n} | void\n\nexport type SerializedActionNode = {\n name: string\n _result: string | undefined\n dependencies: string[]\n}\n\nexport type SliceState = {\n conversationId?: number // if doing a conversation, which one is it?\n avatarAction?: AvatarAction // what should the avatar be doing right now\n avatarId?: number // what avatar is being used in this conversation?\n customizations?: Customizations // if doing a custom conversation, how is it structured?\n threadId?: string // what thread is this conversation living on?\n runIds?: { threadId: string; runId: string }[] // the ids of the run objects that are currently being executed. This will be undefined if no run is currently being executed\n conversation?: Conversation // what is the actual content of the conversation from the thread?\n actionNodes?: SerializedActionNode[] // the (serialized) action nodes that are currently being used for generating assistant instructions\n mostRecentInstruction?: string // what was the most recent instruction we passed to the assistant?\n startTime?: number // at what time was this conversation initiated? (milliseconds since the epoch)\n error?: string // an error message showing a user-friendly message of what went wrong\n}\n\nexport const initialState: SliceState = {\n conversationId: undefined,\n avatarAction: undefined,\n avatarId: undefined,\n customizations: undefined,\n threadId: undefined,\n runIds: undefined,\n conversation: undefined,\n actionNodes: undefined,\n mostRecentInstruction: undefined,\n startTime: undefined,\n error: undefined\n}\n\nexport const conversationPersistConfig = {\n key: 'conversation',\n storage,\n blacklist: ['avatarAction', 'error']\n}\n","/** @type {Record} */\nexport const problematic = {\n abalone: 4,\n abare: 3,\n abbruzzese: 4,\n abed: 2,\n aborigine: 5,\n abruzzese: 4,\n acreage: 3,\n adame: 3,\n adieu: 2,\n adobe: 3,\n anemone: 4,\n anyone: 3,\n apache: 3,\n aphrodite: 4,\n apostrophe: 4,\n ariadne: 4,\n cafe: 2,\n calliope: 4,\n catastrophe: 4,\n chile: 2,\n chloe: 2,\n circe: 2,\n coyote: 3,\n daphne: 2,\n epitome: 4,\n eurydice: 4,\n euterpe: 3,\n every: 2,\n everywhere: 3,\n forever: 3,\n gethsemane: 4,\n guacamole: 4,\n hermione: 4,\n hyperbole: 4,\n jesse: 2,\n jukebox: 2,\n karate: 3,\n machete: 3,\n maybe: 2,\n naive: 2,\n newlywed: 3,\n penelope: 4,\n people: 2,\n persephone: 4,\n phoebe: 2,\n pulse: 1,\n queue: 1,\n recipe: 3,\n riverbed: 3,\n sesame: 3,\n shoreline: 2,\n simile: 3,\n snuffleupagus: 5,\n sometimes: 2,\n syncope: 3,\n tamale: 3,\n waterbed: 3,\n wednesday: 2,\n yosemite: 4,\n zoe: 2\n}\n","import pluralize from 'pluralize'\n// @ts-ignore remove when typed.\nimport normalize from 'normalize-strings'\nimport {problematic} from './problematic.js'\n\nconst own = {}.hasOwnProperty\n\n// Two expressions of occurrences which normally would be counted as two\n// syllables, but should be counted as one.\nconst EXPRESSION_MONOSYLLABIC_ONE = new RegExp(\n [\n 'awe($|d|so)',\n 'cia(?:l|$)',\n 'tia',\n 'cius',\n 'cious',\n '[^aeiou]giu',\n '[aeiouy][^aeiouy]ion',\n 'iou',\n 'sia$',\n 'eous$',\n '[oa]gue$',\n '.[^aeiuoycgltdb]{2,}ed$',\n '.ely$',\n '^jua',\n 'uai',\n 'eau',\n '^busi$',\n '(?:[aeiouy](?:' +\n [\n '[bcfgklmnprsvwxyz]',\n 'ch',\n 'dg',\n 'g[hn]',\n 'lch',\n 'l[lv]',\n 'mm',\n 'nch',\n 'n[cgn]',\n 'r[bcnsv]',\n 'squ',\n 's[chkls]',\n 'th'\n ].join('|') +\n ')ed$)',\n '(?:[aeiouy](?:' +\n [\n '[bdfklmnprstvy]',\n 'ch',\n 'g[hn]',\n 'lch',\n 'l[lv]',\n 'mm',\n 'nch',\n 'nn',\n 'r[nsv]',\n 'squ',\n 's[cklst]',\n 'th'\n ].join('|') +\n ')es$)'\n ].join('|'),\n 'g'\n)\n\nconst EXPRESSION_MONOSYLLABIC_TWO = new RegExp(\n '[aeiouy](?:' +\n [\n '[bcdfgklmnprstvyz]',\n 'ch',\n 'dg',\n 'g[hn]',\n 'l[lv]',\n 'mm',\n 'n[cgns]',\n 'r[cnsv]',\n 'squ',\n 's[cklst]',\n 'th'\n ].join('|') +\n ')e$',\n 'g'\n)\n\n// Four expression of occurrences which normally would be counted as one\n// syllable, but should be counted as two.\nconst EXPRESSION_DOUBLE_SYLLABIC_ONE = new RegExp(\n '(?:' +\n [\n '([^aeiouy])\\\\1l',\n '[^aeiouy]ie(?:r|s?t)',\n '[aeiouym]bl',\n 'eo',\n 'ism',\n 'asm',\n 'thm',\n 'dnt',\n 'snt',\n 'uity',\n 'dea',\n 'gean',\n 'oa',\n 'ua',\n 'react?',\n 'orbed', // Cancel `'.[^aeiuoycgltdb]{2,}ed$',`\n 'shred', // Cancel `'.[^aeiuoycgltdb]{2,}ed$',`\n 'eings?',\n '[aeiouy]sh?e[rs]'\n ].join('|') +\n ')$',\n 'g'\n)\n\nconst EXPRESSION_DOUBLE_SYLLABIC_TWO = new RegExp(\n [\n 'creat(?!u)',\n '[^gq]ua[^auieo]',\n '[aeiou]{3}',\n '^(?:ia|mc|coa[dglx].)',\n '^re(app|es|im|us)',\n '(th|d)eist'\n ].join('|'),\n 'g'\n)\n\nconst EXPRESSION_DOUBLE_SYLLABIC_THREE = new RegExp(\n [\n '[^aeiou]y[ae]',\n '[^l]lien',\n 'riet',\n 'dien',\n 'iu',\n 'io',\n 'ii',\n 'uen',\n '[aeilotu]real',\n 'real[aeilotu]',\n 'iell',\n 'eo[^aeiou]',\n '[aeiou]y[aeiou]'\n ].join('|'),\n 'g'\n)\n\nconst EXPRESSION_DOUBLE_SYLLABIC_FOUR = /[^s]ia/\n\n// Expression to match single syllable pre- and suffixes.\nconst EXPRESSION_SINGLE = new RegExp(\n [\n '^(?:' +\n [\n 'un',\n 'fore',\n 'ware',\n 'none?',\n 'out',\n 'post',\n 'sub',\n 'pre',\n 'pro',\n 'dis',\n 'side',\n 'some'\n ].join('|') +\n ')',\n '(?:' +\n [\n 'ly',\n 'less',\n 'some',\n 'ful',\n 'ers?',\n 'ness',\n 'cians?',\n 'ments?',\n 'ettes?',\n 'villes?',\n 'ships?',\n 'sides?',\n 'ports?',\n 'shires?',\n '[gnst]ion(?:ed|s)?'\n ].join('|') +\n ')$'\n ].join('|'),\n 'g'\n)\n\n// Expression to match double syllable pre- and suffixes.\nconst EXPRESSION_DOUBLE = new RegExp(\n [\n '^' +\n '(?:' +\n [\n 'above',\n 'anti',\n 'ante',\n 'counter',\n 'hyper',\n 'afore',\n 'agri',\n 'infra',\n 'intra',\n 'inter',\n 'over',\n 'semi',\n 'ultra',\n 'under',\n 'extra',\n 'dia',\n 'micro',\n 'mega',\n 'kilo',\n 'pico',\n 'nano',\n 'macro',\n 'somer'\n ].join('|') +\n ')',\n '(?:fully|berry|woman|women|edly|union|((?:[bcdfghjklmnpqrstvwxz])|[aeiou])ye?ing)$'\n ].join('|'),\n 'g'\n)\n\n// Expression to match triple syllable suffixes.\nconst EXPRESSION_TRIPLE = /(creations?|ology|ologist|onomy|onomist)$/g\n\n/**\n * Count syllables in `value`.\n *\n * @param {string} value\n * Value to check.\n * @returns {number}\n * Syllables in `value`.\n */\nexport function syllable(value) {\n const values = normalize(String(value))\n .toLowerCase()\n // Remove apostrophes.\n .replace(/['’]/g, '')\n // Split on word boundaries.\n .split(/\\b/g)\n let index = -1\n let sum = 0\n\n while (++index < values.length) {\n // Remove non-alphabetic characters from a given value.\n sum += one(values[index].replace(/[^a-z]/g, ''))\n }\n\n return sum\n}\n\n/**\n * Get syllables in a word.\n *\n * @param {string} value\n * @returns {number}\n */\nfunction one(value) {\n let count = 0\n\n if (value.length === 0) {\n return count\n }\n\n // Return early when possible.\n if (value.length < 3) {\n return 1\n }\n\n // If `value` is a hard to count, it might be in `problematic`.\n if (own.call(problematic, value)) {\n return problematic[value]\n }\n\n // Additionally, the singular word might be in `problematic`.\n const singular = pluralize(value, 1)\n\n if (own.call(problematic, singular)) {\n return problematic[singular]\n }\n\n const addOne = returnFactory(1)\n const subtractOne = returnFactory(-1)\n\n // Count some prefixes and suffixes, and remove their matched ranges.\n value = value\n .replace(EXPRESSION_TRIPLE, countFactory(3))\n .replace(EXPRESSION_DOUBLE, countFactory(2))\n .replace(EXPRESSION_SINGLE, countFactory(1))\n\n // Count multiple consonants.\n const parts = value.split(/[^aeiouy]+/)\n let index = -1\n\n while (++index < parts.length) {\n if (parts[index] !== '') {\n count++\n }\n }\n\n // Subtract one for occurrences which should be counted as one (but are\n // counted as two).\n value\n .replace(EXPRESSION_MONOSYLLABIC_ONE, subtractOne)\n .replace(EXPRESSION_MONOSYLLABIC_TWO, subtractOne)\n\n // Add one for occurrences which should be counted as two (but are counted as\n // one).\n value\n .replace(EXPRESSION_DOUBLE_SYLLABIC_ONE, addOne)\n .replace(EXPRESSION_DOUBLE_SYLLABIC_TWO, addOne)\n .replace(EXPRESSION_DOUBLE_SYLLABIC_THREE, addOne)\n .replace(EXPRESSION_DOUBLE_SYLLABIC_FOUR, addOne)\n\n // Make sure at least on is returned.\n return count || 1\n\n /**\n * Define scoped counters, to be used in `String#replace()` calls.\n * The scoped counter removes the matched value from the input.\n *\n * @param {number} addition\n */\n function countFactory(addition) {\n return counter\n /**\n * @returns {string}\n */\n function counter() {\n count += addition\n return ''\n }\n }\n\n /**\n * This scoped counter does not remove the matched value from the input.\n *\n * @param {number} addition\n */\n function returnFactory(addition) {\n return returner\n /**\n * @param {string} $0\n * @returns {string}\n */\n function returner($0) {\n count += addition\n return $0\n }\n }\n}\n","// import { getEncoding } from 'js-tiktoken'\nimport { syllable } from 'syllable'\n\nconst adheresToQuestionAsking = (prompt: string, response: string): boolean => {\n if (prompt.includes('Ask the user a question in your response.')) {\n if (!response.includes('?')) {\n return false\n }\n } else if (prompt.includes('Do not ask any questions.')) {\n if (response.includes('?')) {\n return false\n }\n }\n\n return true\n}\n\nconst adheresToTokenLength = (prompt: string, response: string): boolean => {\n const numTokens = response.split(' ').length / 0.75 // one token is approximately 0.75 words\n\n if (prompt.includes('Your response should be at most 15 tokens.')) {\n if (numTokens > 15) {\n return false\n }\n } else if (prompt.includes('Your response should be at most 20 tokens.')) {\n if (numTokens > 20) {\n return false\n }\n } else if (prompt.includes('Your response should be at most 25 tokens.')) {\n if (numTokens > 25) {\n return false\n }\n } else if (prompt.includes('Your response should be at most 40 tokens.')) {\n if (numTokens > 40) {\n return false\n }\n }\n\n return true\n}\n\nconst adheresToComplexity = (prompt: string, response: string): boolean => {\n const numSyllables = syllable(response)\n const numWords = response.split(' ').length\n const numSentences = response.split(/.|!|\\\\?/).length\n const fleschKincaidScore = 206.835 - 1.015 * (numWords / numSentences) - 84.6 * (numSyllables / numWords)\n\n if (prompt.includes('fourth grade reading level.')) {\n if (fleschKincaidScore < 80) {\n return false\n }\n } else if (prompt.includes('sixth grade reading level.')) {\n if (fleschKincaidScore < 60) {\n return false\n }\n }\n\n return true\n}\n\nexport const scoreResponse = (prompt: string, response: string): number => {\n let score = 1\n if (!adheresToQuestionAsking(prompt, response)) score -= 1 / 4\n if (!adheresToTokenLength(prompt, response)) score -= 1 / 2\n if (!adheresToComplexity(prompt, response)) score -= 1 / 8\n return score\n}\n","import { createAsyncThunk, createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport {\n addMessage,\n createThread as createThreadApiCall,\n getMessages,\n getRun,\n startRun\n} from '../../api/conversation/api'\nimport { lipSync } from '../../api/audio/api'\nimport {\n AssistantMessage,\n AvatarAction,\n conversationPersistConfig,\n Customizations,\n InitializeConversationInput,\n initialState,\n Role,\n SliceState,\n VisemeInformation,\n SerializedActionNode,\n UserMessage,\n Conversation,\n WordBoundaries\n} from './data'\nimport { Avatar, avatarMap } from '../../components/ConversationPage/Avatar/Avatar.data'\nimport { persistReducer } from 'redux-persist'\nimport { scoreResponse } from '../../hooks/conversation/prompting/evaluation/evaluation'\nimport { config } from '../../config/config'\nimport OpenAI from 'openai'\nimport { TextContentBlock } from 'openai/resources/beta/threads/messages'\nimport { RootState } from '..'\nimport { ConversationAPIClient } from '../../apiClients/ConversationAPIClient'\n\nconst conversationSlice = createSlice({\n name: 'conversation',\n initialState,\n reducers: {\n setConversationId(state, action: PayloadAction) {\n state.conversationId = action.payload\n },\n stopTalking(state, _action: PayloadAction) {\n state.avatarAction = AvatarAction.STANDING\n },\n startTalking(state, _action: PayloadAction) {\n if (state.conversation === undefined) return\n const messagesWithAvatarState = state\n .conversation!.filter((message) => message.role === Role.ASSISTANT)\n .filter((message) => (message as AssistantMessage).auxillaryInformation !== undefined)\n const lastMessageWithAvatarState = messagesWithAvatarState[messagesWithAvatarState.length - 1]\n if (lastMessageWithAvatarState === undefined) return\n const lastAvatarAction = (lastMessageWithAvatarState as AssistantMessage).avatarAction\n state.avatarAction = lastAvatarAction\n },\n setConversation(state, action: PayloadAction) {\n state.conversation = action.payload\n },\n setCustomizations(state, action: PayloadAction) {\n state.customizations = action.payload\n },\n setActionNodes(state, action: PayloadAction) {\n state.actionNodes = action.payload\n },\n setMostRecentInstruction(state, action: PayloadAction) {\n state.mostRecentInstruction = action.payload\n },\n setError(state, action: PayloadAction) {\n state.error = action.payload\n },\n resetConversation(state, _action: PayloadAction) {\n state.conversationId = initialState.conversationId\n state.avatarAction = initialState.conversationId\n state.avatarId = initialState.conversationId\n state.customizations = initialState.customizations\n state.runIds = initialState.runIds\n state.threadId = initialState.threadId\n state.conversation = initialState.conversation\n state.actionNodes = initialState.actionNodes\n state.mostRecentInstruction = initialState.mostRecentInstruction\n state.startTime = initialState.startTime\n state.error = initialState.error\n }\n },\n extraReducers: (builder) => {\n // initializeConversation\n builder.addCase(initializeConversation.fulfilled, (state, action) => {\n const newConversationParameters = action.meta.arg\n\n // state updates for both new and existing conversations\n state.avatarAction = AvatarAction.STANDING\n state.runIds = initialState.runIds\n state.error = initialState.error\n\n if (newConversationParameters !== undefined) {\n // state updates for new conversations only\n state.conversationId = newConversationParameters.conversationId\n state.avatarId = newConversationParameters.avatarId\n state.customizations = newConversationParameters.customizations\n state.conversation = []\n state.actionNodes = initialState.actionNodes\n state.mostRecentInstruction = initialState.mostRecentInstruction\n state.startTime = new Date().getTime()\n } else {\n /* state updates for existing conversations only */\n }\n\n const payload = action.payload as unknown as { threadId: string }\n state.threadId = payload.threadId\n })\n builder.addCase(initializeConversation.rejected, (state, action) => {\n state.conversationId = initialState.conversationId\n state.avatarAction = initialState.conversationId\n state.avatarId = initialState.conversationId\n state.customizations = initialState.customizations\n state.threadId = initialState.threadId\n state.conversation = initialState.conversation\n state.actionNodes = initialState.actionNodes\n state.mostRecentInstruction = initialState.mostRecentInstruction\n state.startTime = initialState.startTime\n state.error = initialState.error\n if (!action.meta.aborted) {\n state.error = 'Failed to create your conversation.'\n }\n })\n\n // runThread\n builder.addCase(runThread.pending, (state, _action) => {\n state.avatarAction = AvatarAction.THINKING\n })\n builder.addCase(runThread.fulfilled, (state, action) => {\n state.runIds = action.payload\n })\n builder.addCase(runThread.rejected, (state, action) => {\n if (action.meta.aborted) return\n state.error = 'There was a problem with processing your message.'\n })\n\n // sendMessage\n builder.addCase(sendMessage.pending, (state, action) => {\n state.conversation = [\n ...(state.conversation ?? []),\n {\n role: Role.USER,\n content: action.meta.arg.message,\n addedToThread: false,\n numResponsesToGenerate: action.meta.arg.numResponsesToGenerate\n }\n ]\n state.avatarAction = AvatarAction.THINKING\n })\n builder.addCase(sendMessage.fulfilled, (state, action) => {\n const newConversation = [\n ...(state.conversation?.slice(0, -1) ?? []),\n {\n role: Role.USER,\n content: action.meta.arg.message,\n addedToThread: true,\n numResponsesToGenerate: action.meta.arg.numResponsesToGenerate\n }\n ]\n state.conversation = newConversation\n })\n builder.addCase(sendMessage.rejected, (state, action) => {\n if (action.meta.aborted) return\n state.error = 'There was a problem with sending your message.'\n })\n\n // getResponse\n builder.addCase(getResponse.pending, (state, _action) => {\n state.avatarAction = AvatarAction.THINKING\n })\n builder.addCase(getResponse.fulfilled, (state, action) => {\n state.conversation = [...(state.conversation ?? []), action.payload.nextMessage]\n state.threadId = action.payload.threadId\n state.runIds = initialState.runIds\n })\n builder.addCase(getResponse.rejected, (state, action) => {\n if (action.meta.aborted) return\n state.error = 'There was a problem with getting a response.'\n })\n\n // hydrateAudioInformation\n builder.addCase(hydrateAudioInformation.fulfilled, (state, action) => {\n const toUpdate = action.payload\n const newConversation = [...(state.conversation ?? [])]\n for (const { ix, audio, visemes, wordBoundaries } of toUpdate) {\n newConversation[ix] = {\n ...newConversation[ix],\n auxillaryInformation: { audio, visemes, wordBoundaries }\n }\n }\n\n state.conversation = newConversation\n })\n builder.addCase(hydrateAudioInformation.rejected, (state, _action) => {\n state.error = 'There was a problem getting the audio information.'\n })\n }\n})\n\n/**\n * Sets up the information in redux to be able to start a conversation (new or existing).\n * Sanitizes the redux store to ensure that we are in a good state to start a conversation.\n *\n * It handles both new and existing conversations.\n */\nconst initializeConversation = createAsyncThunk(\n '/conversation/initialize',\n async (\n newConversationParameters: InitializeConversationInput,\n { rejectWithValue, getState, dispatch, fulfillWithValue }\n ) => {\n const conversationAPIClient = new ConversationAPIClient()\n if (newConversationParameters !== undefined) {\n // need to generate new thread!\n // try to create a thread 5 times before giving up\n for (let ix = 0; ix < 5; ix += 1) {\n const { statusCode, body } = await conversationAPIClient.createThread()\n if (statusCode !== 201) {\n await new Promise((res) => setTimeout(res, 200 * (Math.random() + 0.5)))\n continue\n }\n return fulfillWithValue({ threadId: body.id })\n }\n\n return rejectWithValue('failed at creating new thread')\n } else {\n // want to keep the conversation consistent with the current state.\n const { threadId } = (getState() as RootState).conversation as SliceState\n\n // try to get messages 5 times before giving up\n let messages: OpenAI.Beta.Threads.Messages.Message[] = []\n for (let ix = 0; ix < 5; ix += 1) {\n const result = await getMessages({ threadId: threadId! })\n if (result.statusCode === 500) {\n if (ix === 4) return rejectWithValue('failed at getting existing conversation messages')\n await new Promise((res) => setTimeout(res, 200 * (Math.random() + 0.5)))\n continue\n }\n\n messages = result.body.messages.reverse().filter((message) => message.content[0].text.value != ' ')\n break\n }\n\n // create a fresh thread, using these messages. Try 5 times before giving up\n let newThreadId: string | undefined = undefined\n for (let ix = 0; ix < 5; ix += 1) {\n const { statusCode, body } = await conversationAPIClient.createThread({\n messages: messages.map((message) => {\n return { content: (message.content[0] as TextContentBlock).text.value, role: message.role }\n })\n })\n\n if (statusCode !== 201) {\n if (ix === 4) return rejectWithValue('failed at getting existing conversation messages')\n await new Promise((res) => setTimeout(res, 200 * (Math.random() + 0.5)))\n continue\n }\n\n newThreadId = body.id\n break\n }\n\n // now that we have a new thread, we need to update the conversation state and populate the auxillary information\n // so that we can resume the conversation\n const { avatarId } = (getState() as RootState).conversation as SliceState\n const newConversation = messages.map((message) => {\n if (message.role === 'user') {\n return {\n role: Role.USER,\n content: (message.content[0] as TextContentBlock).text.value,\n addedToThread: true,\n numResponsesToGenerate: 3\n }\n } else {\n return {\n role: Role.ASSISTANT,\n content: (message.content[0] as TextContentBlock).text.value,\n avatarAction: AvatarAction.TALKING,\n avatarId: avatarId!\n }\n }\n })\n\n // update conversation\n dispatch(setConversation(newConversation))\n\n // fill in the auxillary information, and stall until this process is done\n await dispatch(hydrateAudioInformation())\n\n return fulfillWithValue({ threadId: newThreadId })\n }\n }\n)\n\n/**\n * Runs a thread with an assistant.\n */\nconst runThread = createAsyncThunk(\n '/conversation/runThread',\n async (\n { threadId, assistantId, instructions }: { threadId: string; assistantId: string; instructions?: string },\n { getState, rejectWithValue }\n ) => {\n const conversationAPIClient = new ConversationAPIClient()\n const { conversation } = (getState() as any).conversation as SliceState\n const userMessages = conversation!.filter((message) => message.role === Role.USER) as UserMessage[]\n const numResponsesToGenerate =\n userMessages.length === 0 ? 3 : userMessages[userMessages.length - 1].numResponsesToGenerate\n\n const branchTasks = []\n for (let ix = 0; ix < numResponsesToGenerate - 1; ix += 1) {\n branchTasks.push(\n conversationAPIClient.createThread({\n messages: conversation!.map((message) => {\n return { content: message.content, role: message.role }\n })\n })\n )\n }\n const branchThreads = (await Promise.all(branchTasks))\n .filter((result) => result.statusCode === 201)\n .map((result) => (result.body as any).id)\n\n for (let ix = 0; ix < 3; ix += 1) {\n const startRunTasks = []\n for (const thread of [threadId, ...branchThreads]) {\n startRunTasks.push(startRun({ threadId: thread, assistantId, instructions }))\n }\n try {\n const runIds = await Promise.all(startRunTasks)\n const records = runIds\n .map((task, ix) => {\n return { thread: [threadId, ...branchThreads][ix], runId: task }\n })\n .filter((record) => record.runId.statusCode === 200)\n .map((record) => {\n return { threadId: record.thread, runId: (record.runId.body as any).runId }\n }) as { threadId: string; runId: string }[]\n return records\n } catch (e) {}\n }\n return rejectWithValue('failed at running thread')\n }\n)\n\n/**\n * Adds a message to the thread currently in state.\n */\nconst sendMessage = createAsyncThunk(\n '/conversation/sendMessage',\n async (\n { message, numResponsesToGenerate }: { message: string; numResponsesToGenerate: number },\n { getState, rejectWithValue }\n ) => {\n const { threadId } = (getState() as any).conversation as SliceState\n if (threadId === undefined) {\n return rejectWithValue('failed at sending message')\n }\n\n for (let ix = 0; ix < 3; ix += 1) {\n const { statusCode } = await addMessage({ threadId, content: message })\n if (statusCode === 500) {\n await new Promise((res) => setTimeout(res, 200))\n continue\n }\n return\n }\n\n return rejectWithValue('failed at sending message')\n }\n)\n\nenum GetResponseFailureType {\n OPENAI = 'openai',\n TIMEOUT = 'timeout',\n EMPTY_CONVERSATION = 'empty conversation',\n EMPTY_AVATAR = 'empty avatar'\n}\n\n/**\n * Given a runId, this function constantly polls until we get the response that we want. Once we get the response,\n * we add the message to the conversation state.\n */\nconst getResponse = createAsyncThunk(\n '/conversation/getResponse',\n async (_args: void, { getState, rejectWithValue }) => {\n const { avatarId, mostRecentInstruction, runIds } = (getState() as any).conversation as SliceState\n\n for (const { threadId, runId } of runIds!) {\n const startTime = new Date().getTime()\n while (true) {\n const { statusCode, body } = await getRun({ runId, threadId })\n if (statusCode === 500) continue\n\n const status = body.status\n if (status === 'completed') {\n break\n }\n\n if (['cancelling', 'cancelled', 'failed', 'expired'].includes(status)) {\n return rejectWithValue(GetResponseFailureType.OPENAI)\n }\n\n const now = new Date().getTime()\n if (now - startTime >= 30 * 1000) {\n // if we haven't gotten a response in 30 seconds, then fail the request.\n return rejectWithValue(GetResponseFailureType.TIMEOUT)\n }\n\n // space out requests to be every half second\n await new Promise((res, _rej) => setTimeout(() => res(), 500))\n }\n }\n\n const branchResults: { threadId: string; content: string; score: number }[] = []\n const messagePromises = []\n for (const { threadId } of runIds!) {\n // at this point, the run should be done, so we can pick up the message!\n messagePromises.push(\n new Promise<{ threadId: string; result: Awaited> }>(async (res) => {\n const result = await getMessages({ threadId })\n res({ threadId, result })\n })\n )\n }\n\n const messageResults = await Promise.all(messagePromises)\n if (messageResults.some((result) => result.result.statusCode === 500)) {\n return rejectWithValue(GetResponseFailureType.OPENAI)\n }\n\n for (const { result, threadId } of messageResults) {\n const messages = (result.body as any).messages\n const content = messages[0].content[0].text.value\n const score = scoreResponse(mostRecentInstruction!, content)\n if (config.name !== 'prod') console.log({ content, score })\n branchResults.push({ threadId, content, score })\n }\n\n const bestResponse = branchResults.sort((a, b) => b.score - a.score)[0]\n\n if (avatarId === undefined) {\n return rejectWithValue(GetResponseFailureType.EMPTY_AVATAR)\n }\n\n return {\n threadId: bestResponse.threadId,\n nextMessage: {\n content: bestResponse.content,\n role: Role.ASSISTANT,\n avatarAction: AvatarAction.TALKING,\n avatarId\n }\n }\n }\n)\n\n/**\n * Looks for any \"gaps\" in the conversation. That is, looks for any messages from the assistant\n * without any audio and will go ahead and fill the information in. It will fill the information in\n * chronological order.\n */\nconst hydrateAudioInformation = createAsyncThunk(\n '/conversation/hydrateAudioInformation',\n async (_args: void, { getState, rejectWithValue }) => {\n const { conversation } = (getState() as any).conversation as SliceState\n\n if (conversation === undefined || conversation.length === 0) {\n return []\n }\n\n const messagesToHydrate = conversation\n .map((message, ix) => {\n return { ...message, ix }\n })\n .filter((message) => message.role === Role.ASSISTANT)\n .filter((message) => !Object.keys(message).includes('auxillaryInformation')) as (AssistantMessage & {\n ix: number\n })[]\n\n const out: Array<{\n ix: number\n audio: string\n visemes: VisemeInformation[]\n wordBoundaries: WordBoundaries[]\n }> = []\n for (const { content, avatarId, ix } of messagesToHydrate) {\n const voice = (avatarMap.get(avatarId) as Avatar).voice\n const { statusCode, body } = await lipSync({ text: content, voice })\n\n if (statusCode === 500) {\n return rejectWithValue('Failed to hydrate audio')\n }\n\n const { audio, visemes, wordBoundaries } = body\n\n const serializedAudio = JSON.stringify((audio as any).data)\n const visemesInformation = visemes.map((viseme: { audioOffset: number; visemeId: number }) => {\n return { timestamp: viseme.audioOffset, visemeId: viseme.visemeId }\n }) as VisemeInformation[]\n\n out.push({ ix, audio: serializedAudio, visemes: visemesInformation, wordBoundaries })\n }\n\n return out\n }\n)\n\nexport const {\n setConversationId,\n setActionNodes,\n setCustomizations,\n setConversation,\n stopTalking,\n startTalking,\n setError,\n resetConversation,\n setMostRecentInstruction\n} = conversationSlice.actions\nexport { runThread, sendMessage, getResponse, hydrateAudioInformation, initializeConversation }\nexport default persistReducer(conversationPersistConfig, conversationSlice.reducer)\n","function _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction noop() {}\n\nvar noopStorage = {\n getItem: noop,\n setItem: noop,\n removeItem: noop\n};\n\nfunction hasStorage(storageType) {\n if ((typeof self === \"undefined\" ? \"undefined\" : _typeof(self)) !== 'object' || !(storageType in self)) {\n return false;\n }\n\n try {\n var storage = self[storageType];\n var testKey = \"redux-persist \".concat(storageType, \" test\");\n storage.setItem(testKey, 'test');\n storage.getItem(testKey);\n storage.removeItem(testKey);\n } catch (e) {\n if (process.env.NODE_ENV !== 'production') console.warn(\"redux-persist \".concat(storageType, \" test failed, persistence will be disabled.\"));\n return false;\n }\n\n return true;\n}\n\nexport default function getStorage(type) {\n var storageType = \"\".concat(type, \"Storage\");\n if (hasStorage(storageType)) return self[storageType];else {\n if (process.env.NODE_ENV !== 'production') {\n console.error(\"redux-persist failed to create sync storage. falling back to noop storage.\");\n }\n\n return noopStorage;\n }\n}","import createWebStorage from './createWebStorage';\nexport default createWebStorage('local');","import storage from 'redux-persist/es/storage'\n\nexport type SliceState = {\n showGUI: boolean\n selectedAvatarId: number | undefined\n}\n\nexport const initialState: SliceState = {\n showGUI: true, // Whether the user should see the GUI during a conversation\n selectedAvatarId: undefined // The ID of the selected avatar\n}\n\nexport const experimentalPersistConfig = {\n key: 'experimental',\n storage\n}\n","import getStorage from './getStorage';\nexport default function createWebStorage(type) {\n var storage = getStorage(type);\n return {\n getItem: function getItem(key) {\n return new Promise(function (resolve, reject) {\n resolve(storage.getItem(key));\n });\n },\n setItem: function setItem(key, item) {\n return new Promise(function (resolve, reject) {\n resolve(storage.setItem(key, item));\n });\n },\n removeItem: function removeItem(key) {\n return new Promise(function (resolve, reject) {\n resolve(storage.removeItem(key));\n });\n }\n };\n}","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { experimentalPersistConfig, initialState } from './data'\nimport { persistReducer } from 'redux-persist'\n\nconst experimentalSlice = createSlice({\n name: 'experimental',\n initialState,\n reducers: {\n setShowGUI(state, action: PayloadAction) {\n state.showGUI = action.payload\n },\n toggleShowGUI(state) {\n state.showGUI = !state.showGUI\n },\n selectAvatarId(state, action: PayloadAction) {\n state.selectedAvatarId = action.payload\n }\n }\n})\n\nexport const { setShowGUI, toggleShowGUI, selectAvatarId } = experimentalSlice.actions\nexport default persistReducer(experimentalPersistConfig, experimentalSlice.reducer)\n","export type SliceState = {\n sessionTime: number | undefined\n practiceGoal: number | undefined\n shouldEmailReminders: boolean | undefined\n}\n\nexport const initialState: SliceState = {\n sessionTime: undefined, // The amount of time the user has spent practicing this week\n practiceGoal: undefined, // The user's practice goal in minutes\n shouldEmailReminders: undefined // Whether the user should receive email reminders\n}\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { initialState, SliceState } from './data'\n\nconst goalsSlice = createSlice({\n name: 'goals',\n initialState,\n reducers: {\n setGoals(state, action: PayloadAction>) {\n const p = action.payload\n state.sessionTime = p.sessionTime ?? state.sessionTime\n state.practiceGoal = p.practiceGoal ?? state.practiceGoal\n state.shouldEmailReminders = p.shouldEmailReminders ?? state.shouldEmailReminders\n },\n setSessionTime(state, action: PayloadAction) {\n state.sessionTime = action.payload\n },\n setPracticeGoal(state, action: PayloadAction) {\n state.practiceGoal = action.payload\n },\n setShouldEmailReminders(state, action: PayloadAction) {\n state.shouldEmailReminders = action.payload\n }\n }\n})\n\nexport const { setGoals, setSessionTime, setPracticeGoal, setShouldEmailReminders } = goalsSlice.actions\nexport default goalsSlice.reducer\n","import { TypedUseSelectorHook, useDispatch, useSelector } from 'react-redux'\nimport type { RootState, AppDispatch } from '../../store'\n\n// Use throughout your app instead of plain `useDispatch` and `useSelector`\nexport const useAppDispatch = () => useDispatch()\nexport const useAppSelector: TypedUseSelectorHook = useSelector\n","import { combineReducers } from '@reduxjs/toolkit'\n\nimport userReducer from './user'\nimport siteReducer from './site'\nimport conversationReducer from './conversation'\nimport authenticationReducer from './authentication'\nimport userSettingsReducer from './userSettings'\nimport goalsReducer from './goals'\nimport experimentalReducer from './experimental'\n\nconst rootReducer = combineReducers({\n user: userReducer,\n site: siteReducer,\n conversation: conversationReducer,\n authentication: authenticationReducer,\n userSettings: userSettingsReducer,\n goals: goalsReducer,\n experimental: experimentalReducer\n})\n\nexport default rootReducer\n","import { configureStore } from '@reduxjs/toolkit'\nimport rootReducer from './rootReducer'\nimport { persistStore } from 'redux-persist'\n\nconst store = configureStore({\n reducer: rootReducer,\n middleware: (getDefaultMiddleware) => getDefaultMiddleware({ serializableCheck: false })\n})\n\nexport type RootState = ReturnType\nexport type AppStore = typeof store\nexport type AppDispatch = typeof store.dispatch\n\nexport const persistor = persistStore(store)\nexport default store\n","import { useAppSelector } from '../hooks'\nimport { SliceState as AuthenticationSliceState } from '../authentication/data'\n\nexport const useGetAuthentication = (): AuthenticationSliceState =>\n useAppSelector(({ authentication }) => {\n return authentication\n })\n","import { useAppSelector } from '../hooks'\nimport { SliceState as GoalsSliceState } from '../goals/data'\n\nexport const useGetGoals = (): GoalsSliceState =>\n useAppSelector(({ goals }) => {\n return goals\n })\n","import { useAppSelector } from '../hooks'\nimport { SliceState as SiteSliceState } from '../site/data'\n\nexport const useGetSite = (): SiteSliceState =>\n useAppSelector(({ site }) => {\n return site\n })\n","import { useAppSelector } from '../hooks'\nimport { SliceState as UserSliceState } from '../user'\n\nexport const useGetUser = (): UserSliceState =>\n useAppSelector(({ user }) => {\n return user\n })\n","import storage from 'redux-persist/lib/storage'\n\nexport enum ModalType {\n LOGIN = 'login',\n SIGNUP = 'signup',\n LANDING_PAGE_VIDEO = 'landing page video',\n FORGOT_PASSWORD = 'forgot password',\n PLAYBACK_BLOCKED = 'playback blocked',\n UNLOCK_BADGE = 'unlock badge',\n PRACTICE_GOAL = 'practice goal'\n}\n\nexport enum Referrer {\n GOOGLE_ADS = 'google ads',\n DEMO_VIDEO_GENERAL = 'demo video general',\n DEMO_VIDEO_CAREGIVER = 'demo video caregiver',\n EMAIL_NEWSLETTER = 'email newsletter',\n NEWS1_GENERAL = 'news1 general',\n NEWS1_CAREGIVER = 'news1 caregiver',\n NEWS2_GENERAL = 'news2 general',\n NEWS2_CAREGIVER = 'news2 caregiver'\n}\n\nexport type SliceState = {\n currentModal: ModalType | undefined // whats the current modal that's being displayed?\n currentModalMetadata: any | undefined // metadata for the current modal\n conversationStatus: 'operational' | 'down' // are conversations operational or are they down?\n referrer: Referrer | undefined // where did the user come from?\n}\n\nexport const initialState: SliceState = {\n currentModal: undefined,\n currentModalMetadata: undefined,\n conversationStatus: 'operational',\n referrer: undefined\n}\n\nexport const sitePersistConfig = {\n key: 'site',\n storage,\n whitelist: ['referrer']\n}\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { initialState, ModalType, Referrer, sitePersistConfig } from './data'\nimport { persistReducer } from 'redux-persist'\n\nconst siteSlice = createSlice({\n name: 'site',\n initialState,\n reducers: {\n setCurrentModal(state, action: PayloadAction) {\n state.currentModal = action.payload\n },\n setModalMetadata(state, action: PayloadAction) {\n state.currentModalMetadata = action.payload\n },\n setConversationStatus(state, action: PayloadAction<'operational' | 'down'>) {\n state.conversationStatus = action.payload\n },\n setReferrer(state, action: PayloadAction) {\n state.referrer = action.payload\n }\n }\n})\n\nexport const { setCurrentModal, setConversationStatus, setModalMetadata, setReferrer } = siteSlice.actions\nexport default persistReducer(sitePersistConfig, siteSlice.reducer)\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\nexport type SubscriptionStatus =\n | 'incomplete'\n | 'incomplete_expired'\n | 'trialing'\n | 'active'\n | 'past_due'\n | 'canceled'\n | 'unpaid'\n | 'nonexistent' // for when no subscription exists. All the other fields come from Stripe, themselves\n\nexport type SliceState = {\n userId: string | undefined // unique ID for the current user\n firstName: string | undefined // first name of the current user\n lastName: string | undefined // last name of the current user\n email: string | undefined // email address of the current user\n joinedAt: number | undefined // at what time did the user join? milliseconds since the epoch\n verifiedEmail: boolean | undefined // has the user verified their email yet?\n completedOnboarding: boolean | undefined // has the user completed the onboarding process?\n completedDiagnostic: boolean | undefined // has the user completed their diagnostic test?\n customerId: string | undefined // what is the Stripe customerId corresponding to this user?\n subscriptionStatus: SubscriptionStatus | undefined // what is the user's Stripe subscription status for Speakable?\n}\n\nexport const initialState: SliceState = {\n userId: undefined,\n firstName: undefined,\n lastName: undefined,\n email: undefined,\n joinedAt: undefined,\n verifiedEmail: undefined,\n completedOnboarding: undefined,\n completedDiagnostic: undefined,\n customerId: undefined,\n subscriptionStatus: undefined\n}\n\nconst userSlice = createSlice({\n name: 'user',\n initialState,\n reducers: {\n setUserID(state, action: PayloadAction) {\n state.userId = action.payload\n },\n setOnboardingState(state, action: PayloadAction) {\n state.completedOnboarding = action.payload\n },\n setEmailVerificationState(state, action: PayloadAction) {\n state.verifiedEmail = action.payload\n },\n setUserInfo(state, action: PayloadAction) {\n const p = action.payload\n state.firstName = p.firstName\n state.lastName = p.lastName\n state.email = p.email\n state.joinedAt = p.joinedAt\n state.verifiedEmail = p.verifiedEmail\n state.completedOnboarding = p.completedOnboarding\n state.completedDiagnostic = p.completedDiagnostic\n state.customerId = p.customerId\n },\n setSubscriptionStatus(state, action: PayloadAction) {\n state.subscriptionStatus = action.payload\n },\n resetUserData(state) {\n state.userId = initialState.userId\n state.firstName = initialState.firstName\n state.lastName = initialState.lastName\n state.email = initialState.firstName\n state.joinedAt = initialState.joinedAt\n state.verifiedEmail = initialState.verifiedEmail\n state.completedOnboarding = initialState.completedOnboarding\n state.completedDiagnostic = initialState.completedDiagnostic\n state.customerId = initialState.customerId\n state.subscriptionStatus = initialState.subscriptionStatus\n }\n }\n})\n\nexport const {\n setUserID,\n setOnboardingState,\n setSubscriptionStatus,\n setEmailVerificationState,\n setUserInfo,\n resetUserData\n} = userSlice.actions\nexport default userSlice.reducer\n","export type SliceState = {\n closedCaptions: boolean | undefined\n questionFrequency: number | undefined\n responseComplexity: number | undefined\n responseLength: number | undefined\n allowConversationAnalysis: boolean | undefined\n autoRecordEnabled: boolean | undefined\n}\n\nexport const initialState: SliceState = {\n closedCaptions: undefined,\n questionFrequency: undefined,\n responseComplexity: undefined,\n responseLength: undefined,\n allowConversationAnalysis: undefined,\n autoRecordEnabled: undefined\n}\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { initialState } from './data'\n\nconst userSettingsSlice = createSlice({\n name: 'userSettings',\n initialState,\n reducers: {\n setUserSettings(state, action: PayloadAction>) {\n const p = action.payload\n state.closedCaptions = p.closedCaptions ?? state.closedCaptions\n state.questionFrequency = p.questionFrequency ?? state.questionFrequency\n state.responseComplexity = p.responseComplexity ?? state.responseComplexity\n state.responseLength = p.responseLength ?? state.responseLength\n state.allowConversationAnalysis = p.allowConversationAnalysis ?? state.allowConversationAnalysis\n state.autoRecordEnabled = p.autoRecordEnabled ?? state.autoRecordEnabled\n },\n resetUserSettingsData(state) {\n state.closedCaptions = initialState.closedCaptions\n state.questionFrequency = initialState.questionFrequency\n state.responseComplexity = initialState.responseComplexity\n state.responseLength = initialState.responseLength\n state.allowConversationAnalysis = initialState.allowConversationAnalysis\n }\n }\n})\n\nexport const { resetUserSettingsData, setUserSettings } = userSettingsSlice.actions\nexport default userSettingsSlice.reducer\n","import { throwSentryException } from '../sentry'\n\nexport type PlayInput = {\n source: string // the source to be played. If no source, will try to continue playing the current source\n speed?: number // must be in the range (0, 1], defaults to 1\n pause?: {\n breakPoints: number[] // the breakpoints to pause at, in milliseconds\n pauseLength: number // the length of the pause, in milliseconds\n }\n}\n\nexport enum StartPlaybackResponse {\n SUCCESS = 'success',\n ALREADY_PLAYING = 'already playing',\n UNEXPECTED_ERROR = 'unexpected error',\n NOT_ALLOWED_ERROR = 'not allowed error'\n}\n\nexport default class AudioPlayer {\n private static existingInstance: AudioPlayer | undefined\n\n // the actual html element to play audio\n private readonly audio: HTMLAudioElement\n private _isPlaying: boolean\n\n /**\n *\n * @param source (optional) source to load into the audio player\n */\n private constructor() {\n this.audio = new Audio()\n this._isPlaying = false\n }\n\n /**\n *\n * @returns singleton instance of `AudioPlayer`\n */\n public static GetAudioPlayer(): AudioPlayer {\n this.existingInstance ??= new AudioPlayer()\n return this.existingInstance\n }\n\n /**\n * Plays the audio at the given speed, and with the given source. Returns a promise\n * when the audio is either finished playing, or something went wrong.\n */\n public async play({ speed, source, pause }: PlayInput): Promise {\n try {\n if (this.isPlaying) return StartPlaybackResponse.ALREADY_PLAYING\n\n this.audio.src = source\n this.audio.preservesPitch = true\n this.audio.playbackRate = speed ?? 1\n\n // will reject if something went wrong, otherwise we set isPlaying to true\n const audioPromise = this.audio.play()\n const promiseResult = await audioPromise.then(\n () => {\n this._isPlaying = true\n },\n (error) => {\n if (error.name === 'NotAllowedError') {\n return StartPlaybackResponse.NOT_ALLOWED_ERROR\n } else {\n throwSentryException({ error: `Could not initiate playback. Error: ${error}` })\n return StartPlaybackResponse.UNEXPECTED_ERROR\n }\n }\n )\n\n if (\n promiseResult === StartPlaybackResponse.NOT_ALLOWED_ERROR ||\n promiseResult === StartPlaybackResponse.UNEXPECTED_ERROR\n )\n return promiseResult\n\n let breakPointIx = 0\n if (pause !== undefined) {\n this.audio.addEventListener('timeupdate', () => {\n if (this.audio.currentTime * 1_000 >= pause.breakPoints[breakPointIx]) {\n breakPointIx++\n this.audio.pause()\n setTimeout(() => {\n this.audio.play()\n }, pause.pauseLength)\n }\n })\n }\n\n const endPromise = new Promise((res) => {\n const handleEnd = () => {\n this._isPlaying = false\n this.audio.removeEventListener('ended', handleEnd)\n res()\n }\n this.audio.addEventListener('ended', handleEnd)\n })\n\n // wait for the audio to finish\n await endPromise\n return StartPlaybackResponse.SUCCESS\n } catch (e) {\n return StartPlaybackResponse.UNEXPECTED_ERROR\n }\n }\n\n public stop(): void {\n if (!this.audio.paused) {\n this.audio.pause()\n this.audio.currentTime = 0\n this._isPlaying = false\n }\n }\n\n /**\n * Gets the current playback time.\n *\n * @returns the current playback time of the audio, in milliseconds.\n */\n public getCurrentTime(): number {\n return this.audio.currentTime * 1_000\n }\n\n public get isPlaying() {\n return this._isPlaying\n }\n}\n","import { NonRealTimeVAD, NonRealTimeVADOptions } from '@ricky0123/vad-web'\n\nexport enum StartRecordingResponse {\n SUCCESS,\n ALREADY_RECORDING,\n NO_PERMISSION,\n UNEXPECTED_ERROR\n}\n\nexport enum StopRecordingResponse {\n SUCCESS,\n MISSING_MEDIA_RECORDER,\n UNEXPECTED_ERROR\n}\n\nclass Recorder {\n private static currentRecorder: Recorder | undefined\n private _mediaRecorder: MediaRecorder | undefined\n private _chunks: number[]\n private _isRecording: boolean\n private _blob: Blob | undefined\n private _isSpeaking: boolean\n\n public static getRecorder(): Recorder {\n Recorder.currentRecorder ??= new Recorder()\n return Recorder.currentRecorder\n }\n\n /**\n * USE ONLY FOR TESTING PURPOSES\n *\n */\n public static reset() {\n Recorder.currentRecorder?.resetRecorder()\n Recorder.currentRecorder = undefined\n }\n\n private constructor() {\n this._mediaRecorder = undefined\n this._chunks = []\n this._isRecording = false\n this._blob = undefined\n this._isSpeaking = false\n }\n\n private resetRecorder(): void {\n this._mediaRecorder = undefined\n this._chunks = []\n this._isRecording = false\n this._blob = undefined\n this._isSpeaking = false\n }\n\n /**\n * Queries the user's browser for access to the microphone.\n *\n * @returns an instance of MediaStream iff the user successfully gave Speakable access to their microphone.\n */\n private async getMediaPermissions(): Promise {\n try {\n const stream = await navigator.mediaDevices.getUserMedia({ audio: true })\n return stream\n } catch (e) {\n this.resetRecorder()\n }\n }\n\n /**\n * Starts recording with the user's microphone. If permission for the microphone has not yet been determined,\n * the browser will ask the user for access to their microphone.\n *\n * @returns StartRecordingResponse.SUCCESS when the recorder starts recording. If there was a problem with starting\n * the recording, another enum value will be returned, instead.\n */\n public async startRecording(): Promise {\n if (this._isRecording) return StartRecordingResponse.ALREADY_RECORDING\n\n const frameSamples = 1536 * 4\n const options: Partial = { preSpeechPadFrames: 0 }\n const context = new window.AudioContext({ sampleRate: 16_000 })\n\n const startupTaskPromises = [NonRealTimeVAD.new(options), this.getMediaPermissions()]\n const startupTaskResults = await Promise.all(startupTaskPromises)\n const vad = startupTaskResults[0] as NonRealTimeVAD\n const stream = startupTaskResults[1] as MediaStream | undefined\n this.resetRecorder()\n if (stream === undefined) return StartRecordingResponse.NO_PERMISSION\n\n this._mediaRecorder = new MediaRecorder(stream)\n let readingIx = 0\n let lastSpeechIx = -1\n this._mediaRecorder.addEventListener('dataavailable', async (event: BlobEvent) => {\n const buffer = await event.data.arrayBuffer()\n this._chunks = [...this._chunks, ...new Uint8Array(buffer)]\n\n try {\n const buffer = await context.decodeAudioData(new Uint8Array(this._chunks).buffer)\n let data = buffer.getChannelData(0)\n data = data.slice(data.length - frameSamples, data.length)\n\n let isSpeaking = lastSpeechIx != -1 && readingIx - lastSpeechIx < 5\n for await (const _ of vad.run(data, 16_000)) {\n lastSpeechIx = readingIx\n isSpeaking = true\n break\n }\n\n this._isSpeaking = isSpeaking\n readingIx++\n } catch (e) {\n console.log(e)\n }\n })\n\n const startPromise = new Promise((res, rej) => {\n if (this._mediaRecorder === undefined) {\n rej()\n return\n }\n this._mediaRecorder.addEventListener('start', async (_event: Event) => {\n res()\n })\n })\n\n try {\n this._mediaRecorder.start(0.1 * 1_000) // timeslice: 0.1s of audio into a given blob\n this._isRecording = true\n } catch (e: any) {\n this.resetRecorder()\n return StartRecordingResponse.UNEXPECTED_ERROR\n }\n\n try {\n await startPromise\n return StartRecordingResponse.SUCCESS\n } catch (e) {\n return StartRecordingResponse.UNEXPECTED_ERROR\n }\n }\n\n /**\n * Stops the recording and saves a blob as an mp3 with the resulting data.\n *\n */\n public async stopRecording(): Promise {\n if (this._mediaRecorder === undefined) {\n this.resetRecorder()\n return StopRecordingResponse.MISSING_MEDIA_RECORDER\n }\n\n try {\n const promise = new Promise((res, rej) => {\n if (this._mediaRecorder === undefined) {\n rej()\n return\n }\n this._mediaRecorder.addEventListener('stop', async (_event: Event) => {\n await new Promise((res) => setTimeout(res, 50)) // wait for the last bytes to flush to dataavailable event subscription\n const array = new Uint8Array(this._chunks)\n this._blob = new Blob([array], { type: 'audio/mp3' })\n this._isRecording = false\n this._isSpeaking = false\n res()\n return\n })\n })\n\n if (this._mediaRecorder.state === 'inactive') throw new Error('Inactive media recorder')\n this._mediaRecorder.stop()\n await promise\n } catch (e: any) {\n this.resetRecorder()\n return StopRecordingResponse.UNEXPECTED_ERROR\n }\n return StopRecordingResponse.SUCCESS\n }\n\n public get isRecording() {\n return this._isRecording\n }\n\n public get blob() {\n return this._blob\n }\n\n public get isSpeaking() {\n return this._isSpeaking\n }\n}\n\nexport default Recorder\n","export const componentShadow = `0 6px 0px -3px black`\n\nexport const months = [\n 'January',\n 'February',\n 'March',\n 'April',\n 'May',\n 'June',\n 'July',\n 'August',\n 'September',\n 'October',\n 'November',\n 'December'\n]\n\nexport const abbreviatedMonths = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sept', 'Oct', 'Nov', 'Dec']\n\nexport const states = [\n 'Alabama',\n 'Alaska',\n 'Arizona',\n 'Arkansas',\n 'California',\n 'Colorado',\n 'Connecticut',\n 'Delaware',\n 'Florida',\n 'Georgia',\n 'Hawaii',\n 'Idaho',\n 'Illinois',\n 'Indiana',\n 'Iowa',\n 'Kansas',\n 'Kentucky',\n 'Louisiana',\n 'Maine',\n 'Maryland',\n 'Massachusetts',\n 'Michigan',\n 'Minnesota',\n 'Mississippi',\n 'Missouri',\n 'Montana',\n 'Nebraska',\n 'Nevada',\n 'New Hampshire',\n 'New Jersey',\n 'New Mexico',\n 'New York',\n 'North Carolina',\n 'North Dakota',\n 'Ohio',\n 'Oklahoma',\n 'Oregon',\n 'Pennsylvania',\n 'Rhode Island',\n 'South Carolina',\n 'South Dakota',\n 'Tennessee',\n 'Texas',\n 'Utah',\n 'Vermont',\n 'Virginia',\n 'Washington',\n 'West Virginia',\n 'Wisconsin',\n 'Wyoming'\n]\n\n// colors\nexport const LIGHT_GREEN = '#c3d984'\nexport const GREEN = '#B9DC57'\nexport const DARK_GREEN = '#abd929'\nexport const HOVER_GRAY = '#f0f0f0'\nexport const DISABLED_GRAY = 'lightgray'\nexport const RED = 'red'\n\nexport const BLUE_GRAY = '#2A3342'\nexport const LIGHT_BLUE_GRAY = '#8896AB'\nexport const EXTRA_LIGHT_BLUE_GRAY = '#BBC3CF'\nexport const BRIGHT_GREEN = '#22C55E'\nexport const LIGHT_BRIGHT_GREEN = '#DCFCE7'\n\nexport const JOURNEY_BACKGROUND_COLOR = '#e6f5ea'\nexport const JOURNEY_CURRENT_LEVEL_COLOR = '#57de7b'\n\n// fonts\nexport const BOLD_FONT_WEIGHT = 700\n\n// pages\nexport const PAGE_SIDE_PADDING = 50\nexport const DESKTOP_PAGE_SIDE_PADDING = 50\nexport const MOBILE_PAGE_SIDE_PADDING = 30\nexport const MOBILE_SIDE_PADDING = 20\nexport const NAV_BAR_HEIGHT = 100\nexport const DESKTOP_NAV_BAR_HEIGHT = 100\nexport const MOBILE_NAV_BAR_HEIGHT = 60\n\n// audio\nexport const RE_ENABLE_AUDIO_BUFFER = 250 // 250 ms\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { getClient, getCurrentScope, getGlobalScope } from '@sentry/core';\nimport type { Scope } from '@sentry/types';\nimport { addNonEnumerableProperty } from '@sentry/utils';\n\ninterface Action {\n type: T;\n}\n\ninterface AnyAction extends Action {\n [extraProps: string]: any;\n}\n\ntype Reducer = (state: S | undefined, action: A) => S;\n\ntype Dispatch = (action: T, ...extraArgs: any[]) => T;\n\ntype ExtendState = [Extension] extends [never] ? State : State & Extension;\n\ntype Unsubscribe = () => void;\n\ninterface Store> {\n dispatch: Dispatch;\n getState(): S;\n subscribe(listener: () => void): Unsubscribe;\n replaceReducer(\n nextReducer: Reducer,\n ): Store, NewActions, StateExt, Ext> & Ext;\n}\n\ndeclare const $CombinedState: unique symbol;\n\ntype CombinedState = { readonly [$CombinedState]?: undefined } & S;\n\ntype PreloadedState = Required extends {\n [$CombinedState]: undefined;\n}\n ? S extends CombinedState\n ? { [K in keyof S1]?: S1[K] extends Record ? PreloadedState : S1[K] }\n : never\n : { [K in keyof S]: S[K] extends string | number | boolean | symbol ? S[K] : PreloadedState };\n\ntype StoreEnhancerStoreCreator, StateExt = never> = <\n S = any,\n A extends Action = AnyAction,\n>(\n reducer: Reducer,\n preloadedState?: PreloadedState,\n) => Store, A, StateExt, Ext> & Ext;\n\nexport interface SentryEnhancerOptions {\n /**\n * Redux state in attachments or not.\n * @default true\n */\n attachReduxState?: boolean;\n\n /**\n * Transforms the state before attaching it to an event.\n * Use this to remove any private data before sending it to Sentry.\n * Return null to not attach the state.\n */\n stateTransformer(state: S | undefined): (S & any) | null;\n /**\n * Transforms the action before sending it as a breadcrumb.\n * Use this to remove any private data before sending it to Sentry.\n * Return null to not send the breadcrumb.\n */\n actionTransformer(action: AnyAction): AnyAction | null;\n /**\n * Called on every state update, configure the Sentry Scope with the redux state.\n */\n configureScopeWithState?(scope: Scope, state: S): void;\n}\n\nconst ACTION_BREADCRUMB_CATEGORY = 'redux.action';\nconst ACTION_BREADCRUMB_TYPE = 'info';\n\nconst defaultOptions: SentryEnhancerOptions = {\n attachReduxState: true,\n actionTransformer: action => action,\n stateTransformer: state => state || null,\n};\n\n/**\n * Creates an enhancer that would be passed to Redux's createStore to log actions and the latest state to Sentry.\n *\n * @param enhancerOptions Options to pass to the enhancer\n */\nfunction createReduxEnhancer(enhancerOptions?: Partial): any {\n // Note: We return an any type as to not have type conflicts.\n const options = {\n ...defaultOptions,\n ...enhancerOptions,\n };\n\n return (next: StoreEnhancerStoreCreator): StoreEnhancerStoreCreator =>\n (reducer: Reducer, initialState?: PreloadedState) => {\n options.attachReduxState &&\n getGlobalScope().addEventProcessor((event, hint) => {\n try {\n // @ts-expect-error try catch to reduce bundle size\n if (event.type === undefined && event.contexts.state.state.type === 'redux') {\n hint.attachments = [\n ...(hint.attachments || []),\n // @ts-expect-error try catch to reduce bundle size\n { filename: 'redux_state.json', data: JSON.stringify(event.contexts.state.state.value) },\n ];\n }\n } catch (_) {\n // empty\n }\n return event;\n });\n\n const sentryReducer: Reducer = (state, action): S => {\n const newState = reducer(state, action);\n\n const scope = getCurrentScope();\n\n /* Action breadcrumbs */\n const transformedAction = options.actionTransformer(action);\n if (typeof transformedAction !== 'undefined' && transformedAction !== null) {\n scope.addBreadcrumb({\n category: ACTION_BREADCRUMB_CATEGORY,\n data: transformedAction,\n type: ACTION_BREADCRUMB_TYPE,\n });\n }\n\n /* Set latest state to scope */\n const transformedState = options.stateTransformer(newState);\n if (typeof transformedState !== 'undefined' && transformedState !== null) {\n const client = getClient();\n const options = client && client.getOptions();\n const normalizationDepth = (options && options.normalizeDepth) || 3; // default state normalization depth to 3\n\n // Set the normalization depth of the redux state to the configured `normalizeDepth` option or a sane number as a fallback\n const newStateContext = { state: { type: 'redux', value: transformedState } };\n addNonEnumerableProperty(\n newStateContext,\n '__sentry_override_normalization_depth__',\n 3 + // 3 layers for `state.value.transformedState`\n normalizationDepth, // rest for the actual state\n );\n\n scope.setContext('state', newStateContext);\n } else {\n scope.setContext('state', null);\n }\n\n /* Allow user to configure scope with latest state */\n const { configureScopeWithState } = options;\n if (typeof configureScopeWithState === 'function') {\n configureScopeWithState(scope, newState);\n }\n\n return newState;\n };\n\n return next(sentryReducer, initialState);\n };\n}\n\nexport { createReduxEnhancer };\n","import { captureException, captureMessage, createReduxEnhancer } from '@sentry/react'\nimport { config } from '../config/config'\n\nexport interface IThrowSentryException {\n error: string\n hint?: any\n includeLocal?: boolean\n}\n\nexport const sentryReduxEnhancer = createReduxEnhancer()\n\nexport const throwSentryException = ({ error, hint, includeLocal }: IThrowSentryException) => {\n if (!includeLocal && config.name === 'local') return\n captureException(error, { data: hint })\n}\n\nexport interface ICaptureSentryMessage {\n message: string\n includeLocal?: boolean\n}\n\nexport const captureSentryMessage = ({ message, includeLocal }: ICaptureSentryMessage) => {\n if (!includeLocal && config.name === 'local') return\n captureMessage(message)\n}\n\n/**\n * Executes an asynchronous function with the expectation that if the function throws an error, we will\n * produce a sentry error.\n *\n * @param fn The asynchronous function to be executed\n * @param errorMessage The message to be displayed in the Sentry dashboard\n * @returns The result of `fn`\n */\nexport const asyncSentryWrapper = (\n fn: (...args: any) => Promise,\n errorMessage: string\n): ((...args: any) => Promise) => {\n return async (...args: any) => {\n try {\n return await fn(...args)\n } catch (e) {\n throwSentryException({ error: errorMessage, hint: { actualError: e } })\n throw new Error('An unexpected error occurred')\n }\n }\n}\n","/******************************************************************************\nCopyright (c) Microsoft Corporation.\n\nPermission to use, copy, modify, and/or distribute this software for any\npurpose with or without fee is hereby granted.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\nPERFORMANCE OF THIS SOFTWARE.\n***************************************************************************** */\n/* global Reflect, Promise, SuppressedError, Symbol */\n\nvar extendStatics = function(d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n};\n\nexport function __extends(d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n}\n\nexport var __assign = function() {\n __assign = Object.assign || function __assign(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n return t;\n }\n return __assign.apply(this, arguments);\n}\n\nexport function __rest(s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n t[p[i]] = s[p[i]];\n }\n return t;\n}\n\nexport function __decorate(decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n}\n\nexport function __param(paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n}\n\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\n var _, done = false;\n for (var i = decorators.length - 1; i >= 0; i--) {\n var context = {};\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\n if (kind === \"accessor\") {\n if (result === void 0) continue;\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\n if (_ = accept(result.get)) descriptor.get = _;\n if (_ = accept(result.set)) descriptor.set = _;\n if (_ = accept(result.init)) initializers.unshift(_);\n }\n else if (_ = accept(result)) {\n if (kind === \"field\") initializers.unshift(_);\n else descriptor[key] = _;\n }\n }\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\n done = true;\n};\n\nexport function __runInitializers(thisArg, initializers, value) {\n var useValue = arguments.length > 2;\n for (var i = 0; i < initializers.length; i++) {\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\n }\n return useValue ? value : void 0;\n};\n\nexport function __propKey(x) {\n return typeof x === \"symbol\" ? x : \"\".concat(x);\n};\n\nexport function __setFunctionName(f, name, prefix) {\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\n};\n\nexport function __metadata(metadataKey, metadataValue) {\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\n}\n\nexport function __awaiter(thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n}\n\nexport function __generator(thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n}\n\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n});\n\nexport function __exportStar(m, o) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\n}\n\nexport function __values(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n}\n\nexport function __read(o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n}\n\n/** @deprecated */\nexport function __spread() {\n for (var ar = [], i = 0; i < arguments.length; i++)\n ar = ar.concat(__read(arguments[i]));\n return ar;\n}\n\n/** @deprecated */\nexport function __spreadArrays() {\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\n r[k] = a[j];\n return r;\n}\n\nexport function __spreadArray(to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n}\n\nexport function __await(v) {\n return this instanceof __await ? (this.v = v, this) : new __await(v);\n}\n\nexport function __asyncGenerator(thisArg, _arguments, generator) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\n function fulfill(value) { resume(\"next\", value); }\n function reject(value) { resume(\"throw\", value); }\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\n}\n\nexport function __asyncDelegator(o) {\n var i, p;\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\n}\n\nexport function __asyncValues(o) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var m = o[Symbol.asyncIterator], i;\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\n}\n\nexport function __makeTemplateObject(cooked, raw) {\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\n return cooked;\n};\n\nvar __setModuleDefault = Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n};\n\nexport function __importStar(mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n}\n\nexport function __importDefault(mod) {\n return (mod && mod.__esModule) ? mod : { default: mod };\n}\n\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\n}\n\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\n}\n\nexport function __classPrivateFieldIn(state, receiver) {\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\n}\n\nexport function __addDisposableResource(env, value, async) {\n if (value !== null && value !== void 0) {\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\n var dispose, inner;\n if (async) {\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\n dispose = value[Symbol.asyncDispose];\n }\n if (dispose === void 0) {\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\n dispose = value[Symbol.dispose];\n if (async) inner = dispose;\n }\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\n env.stack.push({ value: value, dispose: dispose, async: async });\n }\n else if (async) {\n env.stack.push({ async: true });\n }\n return value;\n}\n\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\n var e = new Error(message);\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\n};\n\nexport function __disposeResources(env) {\n function fail(e) {\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\n env.hasError = true;\n }\n function next() {\n while (env.stack.length) {\n var rec = env.stack.pop();\n try {\n var result = rec.dispose && rec.dispose.call(rec.value);\n if (rec.async) return Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\n }\n catch (e) {\n fail(e);\n }\n }\n if (env.hasError) throw env.error;\n }\n return next();\n}\n\nexport default {\n __extends,\n __assign,\n __rest,\n __decorate,\n __param,\n __metadata,\n __awaiter,\n __generator,\n __createBinding,\n __exportStar,\n __values,\n __read,\n __spread,\n __spreadArrays,\n __spreadArray,\n __await,\n __asyncGenerator,\n __asyncDelegator,\n __asyncValues,\n __makeTemplateObject,\n __importStar,\n __importDefault,\n __classPrivateFieldGet,\n __classPrivateFieldSet,\n __classPrivateFieldIn,\n __addDisposableResource,\n __disposeResources,\n};\n","/**\n * @internal\n */\nexport const BLOCK_SIZE: number = 64;\n\n/**\n * @internal\n */\nexport const DIGEST_LENGTH: number = 32;\n\n/**\n * @internal\n */\nexport const KEY = new Uint32Array([\n 0x428a2f98,\n 0x71374491,\n 0xb5c0fbcf,\n 0xe9b5dba5,\n 0x3956c25b,\n 0x59f111f1,\n 0x923f82a4,\n 0xab1c5ed5,\n 0xd807aa98,\n 0x12835b01,\n 0x243185be,\n 0x550c7dc3,\n 0x72be5d74,\n 0x80deb1fe,\n 0x9bdc06a7,\n 0xc19bf174,\n 0xe49b69c1,\n 0xefbe4786,\n 0x0fc19dc6,\n 0x240ca1cc,\n 0x2de92c6f,\n 0x4a7484aa,\n 0x5cb0a9dc,\n 0x76f988da,\n 0x983e5152,\n 0xa831c66d,\n 0xb00327c8,\n 0xbf597fc7,\n 0xc6e00bf3,\n 0xd5a79147,\n 0x06ca6351,\n 0x14292967,\n 0x27b70a85,\n 0x2e1b2138,\n 0x4d2c6dfc,\n 0x53380d13,\n 0x650a7354,\n 0x766a0abb,\n 0x81c2c92e,\n 0x92722c85,\n 0xa2bfe8a1,\n 0xa81a664b,\n 0xc24b8b70,\n 0xc76c51a3,\n 0xd192e819,\n 0xd6990624,\n 0xf40e3585,\n 0x106aa070,\n 0x19a4c116,\n 0x1e376c08,\n 0x2748774c,\n 0x34b0bcb5,\n 0x391c0cb3,\n 0x4ed8aa4a,\n 0x5b9cca4f,\n 0x682e6ff3,\n 0x748f82ee,\n 0x78a5636f,\n 0x84c87814,\n 0x8cc70208,\n 0x90befffa,\n 0xa4506ceb,\n 0xbef9a3f7,\n 0xc67178f2\n]);\n\n/**\n * @internal\n */\nexport const INIT = [\n 0x6a09e667,\n 0xbb67ae85,\n 0x3c6ef372,\n 0xa54ff53a,\n 0x510e527f,\n 0x9b05688c,\n 0x1f83d9ab,\n 0x5be0cd19\n];\n\n/**\n * @internal\n */\nexport const MAX_HASHABLE_LENGTH = 2 ** 53 - 1;\n","import {\n BLOCK_SIZE,\n DIGEST_LENGTH,\n INIT,\n KEY,\n MAX_HASHABLE_LENGTH\n} from \"./constants\";\n\n/**\n * @internal\n */\nexport class RawSha256 {\n private state: Int32Array = Int32Array.from(INIT);\n private temp: Int32Array = new Int32Array(64);\n private buffer: Uint8Array = new Uint8Array(64);\n private bufferLength: number = 0;\n private bytesHashed: number = 0;\n\n /**\n * @internal\n */\n finished: boolean = false;\n\n update(data: Uint8Array): void {\n if (this.finished) {\n throw new Error(\"Attempted to update an already finished hash.\");\n }\n\n let position = 0;\n let { byteLength } = data;\n this.bytesHashed += byteLength;\n\n if (this.bytesHashed * 8 > MAX_HASHABLE_LENGTH) {\n throw new Error(\"Cannot hash more than 2^53 - 1 bits\");\n }\n\n while (byteLength > 0) {\n this.buffer[this.bufferLength++] = data[position++];\n byteLength--;\n\n if (this.bufferLength === BLOCK_SIZE) {\n this.hashBuffer();\n this.bufferLength = 0;\n }\n }\n }\n\n digest(): Uint8Array {\n if (!this.finished) {\n const bitsHashed = this.bytesHashed * 8;\n const bufferView = new DataView(\n this.buffer.buffer,\n this.buffer.byteOffset,\n this.buffer.byteLength\n );\n\n const undecoratedLength = this.bufferLength;\n bufferView.setUint8(this.bufferLength++, 0x80);\n\n // Ensure the final block has enough room for the hashed length\n if (undecoratedLength % BLOCK_SIZE >= BLOCK_SIZE - 8) {\n for (let i = this.bufferLength; i < BLOCK_SIZE; i++) {\n bufferView.setUint8(i, 0);\n }\n this.hashBuffer();\n this.bufferLength = 0;\n }\n\n for (let i = this.bufferLength; i < BLOCK_SIZE - 8; i++) {\n bufferView.setUint8(i, 0);\n }\n bufferView.setUint32(\n BLOCK_SIZE - 8,\n Math.floor(bitsHashed / 0x100000000),\n true\n );\n bufferView.setUint32(BLOCK_SIZE - 4, bitsHashed);\n\n this.hashBuffer();\n\n this.finished = true;\n }\n\n // The value in state is little-endian rather than big-endian, so flip\n // each word into a new Uint8Array\n const out = new Uint8Array(DIGEST_LENGTH);\n for (let i = 0; i < 8; i++) {\n out[i * 4] = (this.state[i] >>> 24) & 0xff;\n out[i * 4 + 1] = (this.state[i] >>> 16) & 0xff;\n out[i * 4 + 2] = (this.state[i] >>> 8) & 0xff;\n out[i * 4 + 3] = (this.state[i] >>> 0) & 0xff;\n }\n\n return out;\n }\n\n private hashBuffer(): void {\n const { buffer, state } = this;\n\n let state0 = state[0],\n state1 = state[1],\n state2 = state[2],\n state3 = state[3],\n state4 = state[4],\n state5 = state[5],\n state6 = state[6],\n state7 = state[7];\n\n for (let i = 0; i < BLOCK_SIZE; i++) {\n if (i < 16) {\n this.temp[i] =\n ((buffer[i * 4] & 0xff) << 24) |\n ((buffer[i * 4 + 1] & 0xff) << 16) |\n ((buffer[i * 4 + 2] & 0xff) << 8) |\n (buffer[i * 4 + 3] & 0xff);\n } else {\n let u = this.temp[i - 2];\n const t1 =\n ((u >>> 17) | (u << 15)) ^ ((u >>> 19) | (u << 13)) ^ (u >>> 10);\n\n u = this.temp[i - 15];\n const t2 =\n ((u >>> 7) | (u << 25)) ^ ((u >>> 18) | (u << 14)) ^ (u >>> 3);\n\n this.temp[i] =\n ((t1 + this.temp[i - 7]) | 0) + ((t2 + this.temp[i - 16]) | 0);\n }\n\n const t1 =\n ((((((state4 >>> 6) | (state4 << 26)) ^\n ((state4 >>> 11) | (state4 << 21)) ^\n ((state4 >>> 25) | (state4 << 7))) +\n ((state4 & state5) ^ (~state4 & state6))) |\n 0) +\n ((state7 + ((KEY[i] + this.temp[i]) | 0)) | 0)) |\n 0;\n\n const t2 =\n ((((state0 >>> 2) | (state0 << 30)) ^\n ((state0 >>> 13) | (state0 << 19)) ^\n ((state0 >>> 22) | (state0 << 10))) +\n ((state0 & state1) ^ (state0 & state2) ^ (state1 & state2))) |\n 0;\n\n state7 = state6;\n state6 = state5;\n state5 = state4;\n state4 = (state3 + t1) | 0;\n state3 = state2;\n state2 = state1;\n state1 = state0;\n state0 = (t1 + t2) | 0;\n }\n\n state[0] += state0;\n state[1] += state1;\n state[2] += state2;\n state[3] += state3;\n state[4] += state4;\n state[5] += state5;\n state[6] += state6;\n state[7] += state7;\n }\n}\n","// Copyright Amazon.com Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nimport { SourceData } from \"@aws-sdk/types\";\nimport { fromUtf8 as fromUtf8Browser } from \"@smithy/util-utf8\";\n\n// Quick polyfill\nconst fromUtf8 =\n typeof Buffer !== \"undefined\" && Buffer.from\n ? (input: string) => Buffer.from(input, \"utf8\")\n : fromUtf8Browser;\n\nexport function convertToBuffer(data: SourceData): Uint8Array {\n // Already a Uint8, do nothing\n if (data instanceof Uint8Array) return data;\n\n if (typeof data === \"string\") {\n return fromUtf8(data);\n }\n\n if (ArrayBuffer.isView(data)) {\n return new Uint8Array(\n data.buffer,\n data.byteOffset,\n data.byteLength / Uint8Array.BYTES_PER_ELEMENT\n );\n }\n\n return new Uint8Array(data);\n}\n","export const fromUtf8 = (input) => new TextEncoder().encode(input);\n","import { BLOCK_SIZE } from \"./constants\";\nimport { RawSha256 } from \"./RawSha256\";\nimport { Checksum, SourceData } from \"@aws-sdk/types\";\nimport { isEmptyData, convertToBuffer } from \"@aws-crypto/util\";\n\nexport class Sha256 implements Checksum {\n private readonly secret?: SourceData;\n private hash: RawSha256;\n private outer?: RawSha256;\n private error: any;\n\n constructor(secret?: SourceData) {\n this.secret = secret;\n this.hash = new RawSha256();\n this.reset();\n }\n\n update(toHash: SourceData): void {\n if (isEmptyData(toHash) || this.error) {\n return;\n }\n\n try {\n this.hash.update(convertToBuffer(toHash));\n } catch (e) {\n this.error = e;\n }\n }\n\n /* This synchronous method keeps compatibility\n * with the v2 aws-sdk.\n */\n digestSync(): Uint8Array {\n if (this.error) {\n throw this.error;\n }\n\n if (this.outer) {\n if (!this.outer.finished) {\n this.outer.update(this.hash.digest());\n }\n\n return this.outer.digest();\n }\n\n return this.hash.digest();\n }\n\n /* The underlying digest method here is synchronous.\n * To keep the same interface with the other hash functions\n * the default is to expose this as an async method.\n * However, it can sometimes be useful to have a sync method.\n */\n async digest(): Promise {\n return this.digestSync();\n }\n\n reset(): void {\n this.hash = new RawSha256();\n if (this.secret) {\n this.outer = new RawSha256();\n const inner = bufferFromSecret(this.secret);\n const outer = new Uint8Array(BLOCK_SIZE);\n outer.set(inner);\n\n for (let i = 0; i < BLOCK_SIZE; i++) {\n inner[i] ^= 0x36;\n outer[i] ^= 0x5c;\n }\n\n this.hash.update(inner);\n this.outer.update(outer);\n\n // overwrite the copied key in memory\n for (let i = 0; i < inner.byteLength; i++) {\n inner[i] = 0;\n }\n }\n }\n}\n\nfunction bufferFromSecret(secret: SourceData): Uint8Array {\n let input = convertToBuffer(secret);\n\n if (input.byteLength > BLOCK_SIZE) {\n const bufferHash = new RawSha256();\n bufferHash.update(input);\n input = bufferHash.digest();\n }\n\n const buffer = new Uint8Array(BLOCK_SIZE);\n buffer.set(input);\n return buffer;\n}\n","// Copyright Amazon.com Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nimport { SourceData } from \"@aws-sdk/types\";\n\nexport function isEmptyData(data: SourceData): boolean {\n if (typeof data === \"string\") {\n return data.length === 0;\n }\n\n return data.byteLength === 0;\n}\n","const SHORT_TO_HEX = {};\nconst HEX_TO_SHORT = {};\nfor (let i = 0; i < 256; i++) {\n let encodedByte = i.toString(16).toLowerCase();\n if (encodedByte.length === 1) {\n encodedByte = `0${encodedByte}`;\n }\n SHORT_TO_HEX[i] = encodedByte;\n HEX_TO_SHORT[encodedByte] = i;\n}\nexport function fromHex(encoded) {\n if (encoded.length % 2 !== 0) {\n throw new Error(\"Hex encoded strings must have an even number length\");\n }\n const out = new Uint8Array(encoded.length / 2);\n for (let i = 0; i < encoded.length; i += 2) {\n const encodedByte = encoded.slice(i, i + 2).toLowerCase();\n if (encodedByte in HEX_TO_SHORT) {\n out[i / 2] = HEX_TO_SHORT[encodedByte];\n }\n else {\n throw new Error(`Cannot decode unrecognized sequence ${encodedByte} as hexadecimal`);\n }\n }\n return out;\n}\nexport function toHex(bytes) {\n let out = \"\";\n for (let i = 0; i < bytes.byteLength; i++) {\n out += SHORT_TO_HEX[bytes[i]];\n }\n return out;\n}\n","import {\n BLOCK_SIZE,\n DIGEST_LENGTH,\n INIT,\n KEY,\n MAX_HASHABLE_LENGTH\n} from \"./constants\";\n\n/**\n * @internal\n */\nexport class RawSha256 {\n private state: Int32Array = Int32Array.from(INIT);\n private temp: Int32Array = new Int32Array(64);\n private buffer: Uint8Array = new Uint8Array(64);\n private bufferLength: number = 0;\n private bytesHashed: number = 0;\n\n /**\n * @internal\n */\n finished: boolean = false;\n\n update(data: Uint8Array): void {\n if (this.finished) {\n throw new Error(\"Attempted to update an already finished hash.\");\n }\n\n let position = 0;\n let { byteLength } = data;\n this.bytesHashed += byteLength;\n\n if (this.bytesHashed * 8 > MAX_HASHABLE_LENGTH) {\n throw new Error(\"Cannot hash more than 2^53 - 1 bits\");\n }\n\n while (byteLength > 0) {\n this.buffer[this.bufferLength++] = data[position++];\n byteLength--;\n\n if (this.bufferLength === BLOCK_SIZE) {\n this.hashBuffer();\n this.bufferLength = 0;\n }\n }\n }\n\n digest(): Uint8Array {\n if (!this.finished) {\n const bitsHashed = this.bytesHashed * 8;\n const bufferView = new DataView(\n this.buffer.buffer,\n this.buffer.byteOffset,\n this.buffer.byteLength\n );\n\n const undecoratedLength = this.bufferLength;\n bufferView.setUint8(this.bufferLength++, 0x80);\n\n // Ensure the final block has enough room for the hashed length\n if (undecoratedLength % BLOCK_SIZE >= BLOCK_SIZE - 8) {\n for (let i = this.bufferLength; i < BLOCK_SIZE; i++) {\n bufferView.setUint8(i, 0);\n }\n this.hashBuffer();\n this.bufferLength = 0;\n }\n\n for (let i = this.bufferLength; i < BLOCK_SIZE - 8; i++) {\n bufferView.setUint8(i, 0);\n }\n bufferView.setUint32(\n BLOCK_SIZE - 8,\n Math.floor(bitsHashed / 0x100000000),\n true\n );\n bufferView.setUint32(BLOCK_SIZE - 4, bitsHashed);\n\n this.hashBuffer();\n\n this.finished = true;\n }\n\n // The value in state is little-endian rather than big-endian, so flip\n // each word into a new Uint8Array\n const out = new Uint8Array(DIGEST_LENGTH);\n for (let i = 0; i < 8; i++) {\n out[i * 4] = (this.state[i] >>> 24) & 0xff;\n out[i * 4 + 1] = (this.state[i] >>> 16) & 0xff;\n out[i * 4 + 2] = (this.state[i] >>> 8) & 0xff;\n out[i * 4 + 3] = (this.state[i] >>> 0) & 0xff;\n }\n\n return out;\n }\n\n private hashBuffer(): void {\n const { buffer, state } = this;\n\n let state0 = state[0],\n state1 = state[1],\n state2 = state[2],\n state3 = state[3],\n state4 = state[4],\n state5 = state[5],\n state6 = state[6],\n state7 = state[7];\n\n for (let i = 0; i < BLOCK_SIZE; i++) {\n if (i < 16) {\n this.temp[i] =\n ((buffer[i * 4] & 0xff) << 24) |\n ((buffer[i * 4 + 1] & 0xff) << 16) |\n ((buffer[i * 4 + 2] & 0xff) << 8) |\n (buffer[i * 4 + 3] & 0xff);\n } else {\n let u = this.temp[i - 2];\n const t1 =\n ((u >>> 17) | (u << 15)) ^ ((u >>> 19) | (u << 13)) ^ (u >>> 10);\n\n u = this.temp[i - 15];\n const t2 =\n ((u >>> 7) | (u << 25)) ^ ((u >>> 18) | (u << 14)) ^ (u >>> 3);\n\n this.temp[i] =\n ((t1 + this.temp[i - 7]) | 0) + ((t2 + this.temp[i - 16]) | 0);\n }\n\n const t1 =\n ((((((state4 >>> 6) | (state4 << 26)) ^\n ((state4 >>> 11) | (state4 << 21)) ^\n ((state4 >>> 25) | (state4 << 7))) +\n ((state4 & state5) ^ (~state4 & state6))) |\n 0) +\n ((state7 + ((KEY[i] + this.temp[i]) | 0)) | 0)) |\n 0;\n\n const t2 =\n ((((state0 >>> 2) | (state0 << 30)) ^\n ((state0 >>> 13) | (state0 << 19)) ^\n ((state0 >>> 22) | (state0 << 10))) +\n ((state0 & state1) ^ (state0 & state2) ^ (state1 & state2))) |\n 0;\n\n state7 = state6;\n state6 = state5;\n state5 = state4;\n state4 = (state3 + t1) | 0;\n state3 = state2;\n state2 = state1;\n state1 = state0;\n state0 = (t1 + t2) | 0;\n }\n\n state[0] += state0;\n state[1] += state1;\n state[2] += state2;\n state[3] += state3;\n state[4] += state4;\n state[5] += state5;\n state[6] += state6;\n state[7] += state7;\n }\n}\n","/**\n * @internal\n */\nexport const BLOCK_SIZE: number = 64;\n\n/**\n * @internal\n */\nexport const DIGEST_LENGTH: number = 32;\n\n/**\n * @internal\n */\nexport const KEY = new Uint32Array([\n 0x428a2f98,\n 0x71374491,\n 0xb5c0fbcf,\n 0xe9b5dba5,\n 0x3956c25b,\n 0x59f111f1,\n 0x923f82a4,\n 0xab1c5ed5,\n 0xd807aa98,\n 0x12835b01,\n 0x243185be,\n 0x550c7dc3,\n 0x72be5d74,\n 0x80deb1fe,\n 0x9bdc06a7,\n 0xc19bf174,\n 0xe49b69c1,\n 0xefbe4786,\n 0x0fc19dc6,\n 0x240ca1cc,\n 0x2de92c6f,\n 0x4a7484aa,\n 0x5cb0a9dc,\n 0x76f988da,\n 0x983e5152,\n 0xa831c66d,\n 0xb00327c8,\n 0xbf597fc7,\n 0xc6e00bf3,\n 0xd5a79147,\n 0x06ca6351,\n 0x14292967,\n 0x27b70a85,\n 0x2e1b2138,\n 0x4d2c6dfc,\n 0x53380d13,\n 0x650a7354,\n 0x766a0abb,\n 0x81c2c92e,\n 0x92722c85,\n 0xa2bfe8a1,\n 0xa81a664b,\n 0xc24b8b70,\n 0xc76c51a3,\n 0xd192e819,\n 0xd6990624,\n 0xf40e3585,\n 0x106aa070,\n 0x19a4c116,\n 0x1e376c08,\n 0x2748774c,\n 0x34b0bcb5,\n 0x391c0cb3,\n 0x4ed8aa4a,\n 0x5b9cca4f,\n 0x682e6ff3,\n 0x748f82ee,\n 0x78a5636f,\n 0x84c87814,\n 0x8cc70208,\n 0x90befffa,\n 0xa4506ceb,\n 0xbef9a3f7,\n 0xc67178f2\n]);\n\n/**\n * @internal\n */\nexport const INIT = [\n 0x6a09e667,\n 0xbb67ae85,\n 0x3c6ef372,\n 0xa54ff53a,\n 0x510e527f,\n 0x9b05688c,\n 0x1f83d9ab,\n 0x5be0cd19\n];\n\n/**\n * @internal\n */\nexport const MAX_HASHABLE_LENGTH = 2 ** 53 - 1;\n","export * from \"./jsSha256\";\n","import { BLOCK_SIZE } from \"./constants\";\nimport { RawSha256 } from \"./RawSha256\";\nimport { Checksum, SourceData } from \"@aws-sdk/types\";\nimport { isEmptyData, convertToBuffer } from \"@aws-crypto/util\";\n\nexport class Sha256 implements Checksum {\n private readonly secret?: SourceData;\n private hash: RawSha256;\n private outer?: RawSha256;\n private error: any;\n\n constructor(secret?: SourceData) {\n this.secret = secret;\n this.hash = new RawSha256();\n this.reset();\n }\n\n update(toHash: SourceData): void {\n if (isEmptyData(toHash) || this.error) {\n return;\n }\n\n try {\n this.hash.update(convertToBuffer(toHash));\n } catch (e) {\n this.error = e;\n }\n }\n\n /* This synchronous method keeps compatibility\n * with the v2 aws-sdk.\n */\n digestSync(): Uint8Array {\n if (this.error) {\n throw this.error;\n }\n\n if (this.outer) {\n if (!this.outer.finished) {\n this.outer.update(this.hash.digest());\n }\n\n return this.outer.digest();\n }\n\n return this.hash.digest();\n }\n\n /* The underlying digest method here is synchronous.\n * To keep the same interface with the other hash functions\n * the default is to expose this as an async method.\n * However, it can sometimes be useful to have a sync method.\n */\n async digest(): Promise {\n return this.digestSync();\n }\n\n reset(): void {\n this.hash = new RawSha256();\n if (this.secret) {\n this.outer = new RawSha256();\n const inner = bufferFromSecret(this.secret);\n const outer = new Uint8Array(BLOCK_SIZE);\n outer.set(inner);\n\n for (let i = 0; i < BLOCK_SIZE; i++) {\n inner[i] ^= 0x36;\n outer[i] ^= 0x5c;\n }\n\n this.hash.update(inner);\n this.outer.update(outer);\n\n // overwrite the copied key in memory\n for (let i = 0; i < inner.byteLength; i++) {\n inner[i] = 0;\n }\n }\n }\n}\n\nfunction bufferFromSecret(secret: SourceData): Uint8Array {\n let input = convertToBuffer(secret);\n\n if (input.byteLength > BLOCK_SIZE) {\n const bufferHash = new RawSha256();\n bufferHash.update(input);\n input = bufferHash.digest();\n }\n\n const buffer = new Uint8Array(BLOCK_SIZE);\n buffer.set(input);\n return buffer;\n}\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport function __createBinding(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n}\r\n\r\nexport function __exportStar(m, exports) {\r\n for (var p in m) if (p !== \"default\" && !exports.hasOwnProperty(p)) exports[p] = m[p];\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n};\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\r\n result.default = mod;\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, privateMap) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to get private field on non-instance\");\r\n }\r\n return privateMap.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, privateMap, value) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to set private field on non-instance\");\r\n }\r\n privateMap.set(receiver, value);\r\n return value;\r\n}\r\n","// Copyright Amazon.com Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nimport { SourceData } from \"@aws-sdk/types\";\nimport { fromUtf8 as fromUtf8Browser } from \"@aws-sdk/util-utf8-browser\";\n\n// Quick polyfill\nconst fromUtf8 =\n typeof Buffer !== \"undefined\" && Buffer.from\n ? (input: string) => Buffer.from(input, \"utf8\")\n : fromUtf8Browser;\n\nexport function convertToBuffer(data: SourceData): Uint8Array {\n // Already a Uint8, do nothing\n if (data instanceof Uint8Array) return data;\n\n if (typeof data === \"string\") {\n return fromUtf8(data);\n }\n\n if (ArrayBuffer.isView(data)) {\n return new Uint8Array(\n data.buffer,\n data.byteOffset,\n data.byteLength / Uint8Array.BYTES_PER_ELEMENT\n );\n }\n\n return new Uint8Array(data);\n}\n","// Copyright Amazon.com Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nexport { convertToBuffer } from \"./convertToBuffer\";\nexport { isEmptyData } from \"./isEmptyData\";\nexport { numToUint8 } from \"./numToUint8\";\nexport {uint32ArrayFrom} from './uint32ArrayFrom';\n","// Copyright Amazon.com Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nimport { SourceData } from \"@aws-sdk/types\";\n\nexport function isEmptyData(data: SourceData): boolean {\n if (typeof data === \"string\") {\n return data.length === 0;\n }\n\n return data.byteLength === 0;\n}\n","// Copyright Amazon.com Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nexport function numToUint8(num: number) {\n return new Uint8Array([\n (num & 0xff000000) >> 24,\n (num & 0x00ff0000) >> 16,\n (num & 0x0000ff00) >> 8,\n num & 0x000000ff,\n ]);\n}\n","// Copyright Amazon.com Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n\n// IE 11 does not support Array.from, so we do it manually\nexport function uint32ArrayFrom(a_lookUpTable: Array): Uint32Array {\n if (!Uint32Array.from) {\n const return_array = new Uint32Array(a_lookUpTable.length)\n let a_index = 0\n while (a_index < a_lookUpTable.length) {\n return_array[a_index] = a_lookUpTable[a_index]\n a_index += 1\n }\n return return_array\n }\n return Uint32Array.from(a_lookUpTable)\n}\n","import { fromUtf8 as jsFromUtf8, toUtf8 as jsToUtf8 } from \"./pureJs\";\nimport { fromUtf8 as textEncoderFromUtf8, toUtf8 as textEncoderToUtf8 } from \"./whatwgEncodingApi\";\nexport const fromUtf8 = (input) => typeof TextEncoder === \"function\" ? textEncoderFromUtf8(input) : jsFromUtf8(input);\nexport const toUtf8 = (input) => typeof TextDecoder === \"function\" ? textEncoderToUtf8(input) : jsToUtf8(input);\n","export function fromUtf8(input) {\n return new TextEncoder().encode(input);\n}\nexport function toUtf8(input) {\n return new TextDecoder(\"utf-8\").decode(input);\n}\n","export const fromUtf8 = (input) => {\n const bytes = [];\n for (let i = 0, len = input.length; i < len; i++) {\n const value = input.charCodeAt(i);\n if (value < 0x80) {\n bytes.push(value);\n }\n else if (value < 0x800) {\n bytes.push((value >> 6) | 0b11000000, (value & 0b111111) | 0b10000000);\n }\n else if (i + 1 < input.length && (value & 0xfc00) === 0xd800 && (input.charCodeAt(i + 1) & 0xfc00) === 0xdc00) {\n const surrogatePair = 0x10000 + ((value & 0b1111111111) << 10) + (input.charCodeAt(++i) & 0b1111111111);\n bytes.push((surrogatePair >> 18) | 0b11110000, ((surrogatePair >> 12) & 0b111111) | 0b10000000, ((surrogatePair >> 6) & 0b111111) | 0b10000000, (surrogatePair & 0b111111) | 0b10000000);\n }\n else {\n bytes.push((value >> 12) | 0b11100000, ((value >> 6) & 0b111111) | 0b10000000, (value & 0b111111) | 0b10000000);\n }\n }\n return Uint8Array.from(bytes);\n};\nexport const toUtf8 = (input) => {\n let decoded = \"\";\n for (let i = 0, len = input.length; i < len; i++) {\n const byte = input[i];\n if (byte < 0x80) {\n decoded += String.fromCharCode(byte);\n }\n else if (0b11000000 <= byte && byte < 0b11100000) {\n const nextByte = input[++i];\n decoded += String.fromCharCode(((byte & 0b11111) << 6) | (nextByte & 0b111111));\n }\n else if (0b11110000 <= byte && byte < 0b101101101) {\n const surrogatePair = [byte, input[++i], input[++i], input[++i]];\n const encoded = \"%\" + surrogatePair.map((byteValue) => byteValue.toString(16)).join(\"%\");\n decoded += decodeURIComponent(encoded);\n }\n else {\n decoded += String.fromCharCode(((byte & 0b1111) << 12) | ((input[++i] & 0b111111) << 6) | (input[++i] & 0b111111));\n }\n }\n return decoded;\n};\n","/*\n\nBased off glamor's StyleSheet, thanks Sunil ❤️\n\nhigh performance StyleSheet for css-in-js systems\n\n- uses multiple style tags behind the scenes for millions of rules\n- uses `insertRule` for appending in production for *much* faster performance\n\n// usage\n\nimport { StyleSheet } from '@emotion/sheet'\n\nlet styleSheet = new StyleSheet({ key: '', container: document.head })\n\nstyleSheet.insert('#box { border: 1px solid red; }')\n- appends a css rule into the stylesheet\n\nstyleSheet.flush()\n- empties the stylesheet of all its contents\n\n*/\n// $FlowFixMe\nfunction sheetForTag(tag) {\n if (tag.sheet) {\n // $FlowFixMe\n return tag.sheet;\n } // this weirdness brought to you by firefox\n\n /* istanbul ignore next */\n\n\n for (var i = 0; i < document.styleSheets.length; i++) {\n if (document.styleSheets[i].ownerNode === tag) {\n // $FlowFixMe\n return document.styleSheets[i];\n }\n }\n}\n\nfunction createStyleElement(options) {\n var tag = document.createElement('style');\n tag.setAttribute('data-emotion', options.key);\n\n if (options.nonce !== undefined) {\n tag.setAttribute('nonce', options.nonce);\n }\n\n tag.appendChild(document.createTextNode(''));\n tag.setAttribute('data-s', '');\n return tag;\n}\n\nvar StyleSheet = /*#__PURE__*/function () {\n // Using Node instead of HTMLElement since container may be a ShadowRoot\n function StyleSheet(options) {\n var _this = this;\n\n this._insertTag = function (tag) {\n var before;\n\n if (_this.tags.length === 0) {\n if (_this.insertionPoint) {\n before = _this.insertionPoint.nextSibling;\n } else if (_this.prepend) {\n before = _this.container.firstChild;\n } else {\n before = _this.before;\n }\n } else {\n before = _this.tags[_this.tags.length - 1].nextSibling;\n }\n\n _this.container.insertBefore(tag, before);\n\n _this.tags.push(tag);\n };\n\n this.isSpeedy = options.speedy === undefined ? process.env.NODE_ENV === 'production' : options.speedy;\n this.tags = [];\n this.ctr = 0;\n this.nonce = options.nonce; // key is the value of the data-emotion attribute, it's used to identify different sheets\n\n this.key = options.key;\n this.container = options.container;\n this.prepend = options.prepend;\n this.insertionPoint = options.insertionPoint;\n this.before = null;\n }\n\n var _proto = StyleSheet.prototype;\n\n _proto.hydrate = function hydrate(nodes) {\n nodes.forEach(this._insertTag);\n };\n\n _proto.insert = function insert(rule) {\n // the max length is how many rules we have per style tag, it's 65000 in speedy mode\n // it's 1 in dev because we insert source maps that map a single rule to a location\n // and you can only have one source map per style tag\n if (this.ctr % (this.isSpeedy ? 65000 : 1) === 0) {\n this._insertTag(createStyleElement(this));\n }\n\n var tag = this.tags[this.tags.length - 1];\n\n if (process.env.NODE_ENV !== 'production') {\n var isImportRule = rule.charCodeAt(0) === 64 && rule.charCodeAt(1) === 105;\n\n if (isImportRule && this._alreadyInsertedOrderInsensitiveRule) {\n // this would only cause problem in speedy mode\n // but we don't want enabling speedy to affect the observable behavior\n // so we report this error at all times\n console.error(\"You're attempting to insert the following rule:\\n\" + rule + '\\n\\n`@import` rules must be before all other types of rules in a stylesheet but other rules have already been inserted. Please ensure that `@import` rules are before all other rules.');\n }\n this._alreadyInsertedOrderInsensitiveRule = this._alreadyInsertedOrderInsensitiveRule || !isImportRule;\n }\n\n if (this.isSpeedy) {\n var sheet = sheetForTag(tag);\n\n try {\n // this is the ultrafast version, works across browsers\n // the big drawback is that the css won't be editable in devtools\n sheet.insertRule(rule, sheet.cssRules.length);\n } catch (e) {\n if (process.env.NODE_ENV !== 'production' && !/:(-moz-placeholder|-moz-focus-inner|-moz-focusring|-ms-input-placeholder|-moz-read-write|-moz-read-only|-ms-clear|-ms-expand|-ms-reveal){/.test(rule)) {\n console.error(\"There was a problem inserting the following rule: \\\"\" + rule + \"\\\"\", e);\n }\n }\n } else {\n tag.appendChild(document.createTextNode(rule));\n }\n\n this.ctr++;\n };\n\n _proto.flush = function flush() {\n // $FlowFixMe\n this.tags.forEach(function (tag) {\n return tag.parentNode && tag.parentNode.removeChild(tag);\n });\n this.tags = [];\n this.ctr = 0;\n\n if (process.env.NODE_ENV !== 'production') {\n this._alreadyInsertedOrderInsensitiveRule = false;\n }\n };\n\n return StyleSheet;\n}();\n\nexport { StyleSheet };\n","/**\n * @param {number}\n * @return {number}\n */\nexport var abs = Math.abs\n\n/**\n * @param {number}\n * @return {string}\n */\nexport var from = String.fromCharCode\n\n/**\n * @param {object}\n * @return {object}\n */\nexport var assign = Object.assign\n\n/**\n * @param {string} value\n * @param {number} length\n * @return {number}\n */\nexport function hash (value, length) {\n\treturn charat(value, 0) ^ 45 ? (((((((length << 2) ^ charat(value, 0)) << 2) ^ charat(value, 1)) << 2) ^ charat(value, 2)) << 2) ^ charat(value, 3) : 0\n}\n\n/**\n * @param {string} value\n * @return {string}\n */\nexport function trim (value) {\n\treturn value.trim()\n}\n\n/**\n * @param {string} value\n * @param {RegExp} pattern\n * @return {string?}\n */\nexport function match (value, pattern) {\n\treturn (value = pattern.exec(value)) ? value[0] : value\n}\n\n/**\n * @param {string} value\n * @param {(string|RegExp)} pattern\n * @param {string} replacement\n * @return {string}\n */\nexport function replace (value, pattern, replacement) {\n\treturn value.replace(pattern, replacement)\n}\n\n/**\n * @param {string} value\n * @param {string} search\n * @return {number}\n */\nexport function indexof (value, search) {\n\treturn value.indexOf(search)\n}\n\n/**\n * @param {string} value\n * @param {number} index\n * @return {number}\n */\nexport function charat (value, index) {\n\treturn value.charCodeAt(index) | 0\n}\n\n/**\n * @param {string} value\n * @param {number} begin\n * @param {number} end\n * @return {string}\n */\nexport function substr (value, begin, end) {\n\treturn value.slice(begin, end)\n}\n\n/**\n * @param {string} value\n * @return {number}\n */\nexport function strlen (value) {\n\treturn value.length\n}\n\n/**\n * @param {any[]} value\n * @return {number}\n */\nexport function sizeof (value) {\n\treturn value.length\n}\n\n/**\n * @param {any} value\n * @param {any[]} array\n * @return {any}\n */\nexport function append (value, array) {\n\treturn array.push(value), value\n}\n\n/**\n * @param {string[]} array\n * @param {function} callback\n * @return {string}\n */\nexport function combine (array, callback) {\n\treturn array.map(callback).join('')\n}\n","import {from, trim, charat, strlen, substr, append, assign} from './Utility.js'\n\nexport var line = 1\nexport var column = 1\nexport var length = 0\nexport var position = 0\nexport var character = 0\nexport var characters = ''\n\n/**\n * @param {string} value\n * @param {object | null} root\n * @param {object | null} parent\n * @param {string} type\n * @param {string[] | string} props\n * @param {object[] | string} children\n * @param {number} length\n */\nexport function node (value, root, parent, type, props, children, length) {\n\treturn {value: value, root: root, parent: parent, type: type, props: props, children: children, line: line, column: column, length: length, return: ''}\n}\n\n/**\n * @param {object} root\n * @param {object} props\n * @return {object}\n */\nexport function copy (root, props) {\n\treturn assign(node('', null, null, '', null, null, 0), root, {length: -root.length}, props)\n}\n\n/**\n * @return {number}\n */\nexport function char () {\n\treturn character\n}\n\n/**\n * @return {number}\n */\nexport function prev () {\n\tcharacter = position > 0 ? charat(characters, --position) : 0\n\n\tif (column--, character === 10)\n\t\tcolumn = 1, line--\n\n\treturn character\n}\n\n/**\n * @return {number}\n */\nexport function next () {\n\tcharacter = position < length ? charat(characters, position++) : 0\n\n\tif (column++, character === 10)\n\t\tcolumn = 1, line++\n\n\treturn character\n}\n\n/**\n * @return {number}\n */\nexport function peek () {\n\treturn charat(characters, position)\n}\n\n/**\n * @return {number}\n */\nexport function caret () {\n\treturn position\n}\n\n/**\n * @param {number} begin\n * @param {number} end\n * @return {string}\n */\nexport function slice (begin, end) {\n\treturn substr(characters, begin, end)\n}\n\n/**\n * @param {number} type\n * @return {number}\n */\nexport function token (type) {\n\tswitch (type) {\n\t\t// \\0 \\t \\n \\r \\s whitespace token\n\t\tcase 0: case 9: case 10: case 13: case 32:\n\t\t\treturn 5\n\t\t// ! + , / > @ ~ isolate token\n\t\tcase 33: case 43: case 44: case 47: case 62: case 64: case 126:\n\t\t// ; { } breakpoint token\n\t\tcase 59: case 123: case 125:\n\t\t\treturn 4\n\t\t// : accompanied token\n\t\tcase 58:\n\t\t\treturn 3\n\t\t// \" ' ( [ opening delimit token\n\t\tcase 34: case 39: case 40: case 91:\n\t\t\treturn 2\n\t\t// ) ] closing delimit token\n\t\tcase 41: case 93:\n\t\t\treturn 1\n\t}\n\n\treturn 0\n}\n\n/**\n * @param {string} value\n * @return {any[]}\n */\nexport function alloc (value) {\n\treturn line = column = 1, length = strlen(characters = value), position = 0, []\n}\n\n/**\n * @param {any} value\n * @return {any}\n */\nexport function dealloc (value) {\n\treturn characters = '', value\n}\n\n/**\n * @param {number} type\n * @return {string}\n */\nexport function delimit (type) {\n\treturn trim(slice(position - 1, delimiter(type === 91 ? type + 2 : type === 40 ? type + 1 : type)))\n}\n\n/**\n * @param {string} value\n * @return {string[]}\n */\nexport function tokenize (value) {\n\treturn dealloc(tokenizer(alloc(value)))\n}\n\n/**\n * @param {number} type\n * @return {string}\n */\nexport function whitespace (type) {\n\twhile (character = peek())\n\t\tif (character < 33)\n\t\t\tnext()\n\t\telse\n\t\t\tbreak\n\n\treturn token(type) > 2 || token(character) > 3 ? '' : ' '\n}\n\n/**\n * @param {string[]} children\n * @return {string[]}\n */\nexport function tokenizer (children) {\n\twhile (next())\n\t\tswitch (token(character)) {\n\t\t\tcase 0: append(identifier(position - 1), children)\n\t\t\t\tbreak\n\t\t\tcase 2: append(delimit(character), children)\n\t\t\t\tbreak\n\t\t\tdefault: append(from(character), children)\n\t\t}\n\n\treturn children\n}\n\n/**\n * @param {number} index\n * @param {number} count\n * @return {string}\n */\nexport function escaping (index, count) {\n\twhile (--count && next())\n\t\t// not 0-9 A-F a-f\n\t\tif (character < 48 || character > 102 || (character > 57 && character < 65) || (character > 70 && character < 97))\n\t\t\tbreak\n\n\treturn slice(index, caret() + (count < 6 && peek() == 32 && next() == 32))\n}\n\n/**\n * @param {number} type\n * @return {number}\n */\nexport function delimiter (type) {\n\twhile (next())\n\t\tswitch (character) {\n\t\t\t// ] ) \" '\n\t\t\tcase type:\n\t\t\t\treturn position\n\t\t\t// \" '\n\t\t\tcase 34: case 39:\n\t\t\t\tif (type !== 34 && type !== 39)\n\t\t\t\t\tdelimiter(character)\n\t\t\t\tbreak\n\t\t\t// (\n\t\t\tcase 40:\n\t\t\t\tif (type === 41)\n\t\t\t\t\tdelimiter(type)\n\t\t\t\tbreak\n\t\t\t// \\\n\t\t\tcase 92:\n\t\t\t\tnext()\n\t\t\t\tbreak\n\t\t}\n\n\treturn position\n}\n\n/**\n * @param {number} type\n * @param {number} index\n * @return {number}\n */\nexport function commenter (type, index) {\n\twhile (next())\n\t\t// //\n\t\tif (type + character === 47 + 10)\n\t\t\tbreak\n\t\t// /*\n\t\telse if (type + character === 42 + 42 && peek() === 47)\n\t\t\tbreak\n\n\treturn '/*' + slice(index, position - 1) + '*' + from(type === 47 ? type : next())\n}\n\n/**\n * @param {number} index\n * @return {string}\n */\nexport function identifier (index) {\n\twhile (!token(peek()))\n\t\tnext()\n\n\treturn slice(index, position)\n}\n","export var MS = '-ms-'\nexport var MOZ = '-moz-'\nexport var WEBKIT = '-webkit-'\n\nexport var COMMENT = 'comm'\nexport var RULESET = 'rule'\nexport var DECLARATION = 'decl'\n\nexport var PAGE = '@page'\nexport var MEDIA = '@media'\nexport var IMPORT = '@import'\nexport var CHARSET = '@charset'\nexport var VIEWPORT = '@viewport'\nexport var SUPPORTS = '@supports'\nexport var DOCUMENT = '@document'\nexport var NAMESPACE = '@namespace'\nexport var KEYFRAMES = '@keyframes'\nexport var FONT_FACE = '@font-face'\nexport var COUNTER_STYLE = '@counter-style'\nexport var FONT_FEATURE_VALUES = '@font-feature-values'\nexport var LAYER = '@layer'\n","import {IMPORT, LAYER, COMMENT, RULESET, DECLARATION, KEYFRAMES} from './Enum.js'\nimport {strlen, sizeof} from './Utility.js'\n\n/**\n * @param {object[]} children\n * @param {function} callback\n * @return {string}\n */\nexport function serialize (children, callback) {\n\tvar output = ''\n\tvar length = sizeof(children)\n\n\tfor (var i = 0; i < length; i++)\n\t\toutput += callback(children[i], i, children, callback) || ''\n\n\treturn output\n}\n\n/**\n * @param {object} element\n * @param {number} index\n * @param {object[]} children\n * @param {function} callback\n * @return {string}\n */\nexport function stringify (element, index, children, callback) {\n\tswitch (element.type) {\n\t\tcase LAYER: if (element.children.length) break\n\t\tcase IMPORT: case DECLARATION: return element.return = element.return || element.value\n\t\tcase COMMENT: return ''\n\t\tcase KEYFRAMES: return element.return = element.value + '{' + serialize(element.children, callback) + '}'\n\t\tcase RULESET: element.value = element.props.join(',')\n\t}\n\n\treturn strlen(children = serialize(element.children, callback)) ? element.return = element.value + '{' + children + '}' : ''\n}\n","import {COMMENT, RULESET, DECLARATION} from './Enum.js'\nimport {abs, charat, trim, from, sizeof, strlen, substr, append, replace, indexof} from './Utility.js'\nimport {node, char, prev, next, peek, caret, alloc, dealloc, delimit, whitespace, escaping, identifier, commenter} from './Tokenizer.js'\n\n/**\n * @param {string} value\n * @return {object[]}\n */\nexport function compile (value) {\n\treturn dealloc(parse('', null, null, null, [''], value = alloc(value), 0, [0], value))\n}\n\n/**\n * @param {string} value\n * @param {object} root\n * @param {object?} parent\n * @param {string[]} rule\n * @param {string[]} rules\n * @param {string[]} rulesets\n * @param {number[]} pseudo\n * @param {number[]} points\n * @param {string[]} declarations\n * @return {object}\n */\nexport function parse (value, root, parent, rule, rules, rulesets, pseudo, points, declarations) {\n\tvar index = 0\n\tvar offset = 0\n\tvar length = pseudo\n\tvar atrule = 0\n\tvar property = 0\n\tvar previous = 0\n\tvar variable = 1\n\tvar scanning = 1\n\tvar ampersand = 1\n\tvar character = 0\n\tvar type = ''\n\tvar props = rules\n\tvar children = rulesets\n\tvar reference = rule\n\tvar characters = type\n\n\twhile (scanning)\n\t\tswitch (previous = character, character = next()) {\n\t\t\t// (\n\t\t\tcase 40:\n\t\t\t\tif (previous != 108 && charat(characters, length - 1) == 58) {\n\t\t\t\t\tif (indexof(characters += replace(delimit(character), '&', '&\\f'), '&\\f') != -1)\n\t\t\t\t\t\tampersand = -1\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t// \" ' [\n\t\t\tcase 34: case 39: case 91:\n\t\t\t\tcharacters += delimit(character)\n\t\t\t\tbreak\n\t\t\t// \\t \\n \\r \\s\n\t\t\tcase 9: case 10: case 13: case 32:\n\t\t\t\tcharacters += whitespace(previous)\n\t\t\t\tbreak\n\t\t\t// \\\n\t\t\tcase 92:\n\t\t\t\tcharacters += escaping(caret() - 1, 7)\n\t\t\t\tcontinue\n\t\t\t// /\n\t\t\tcase 47:\n\t\t\t\tswitch (peek()) {\n\t\t\t\t\tcase 42: case 47:\n\t\t\t\t\t\tappend(comment(commenter(next(), caret()), root, parent), declarations)\n\t\t\t\t\t\tbreak\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tcharacters += '/'\n\t\t\t\t}\n\t\t\t\tbreak\n\t\t\t// {\n\t\t\tcase 123 * variable:\n\t\t\t\tpoints[index++] = strlen(characters) * ampersand\n\t\t\t// } ; \\0\n\t\t\tcase 125 * variable: case 59: case 0:\n\t\t\t\tswitch (character) {\n\t\t\t\t\t// \\0 }\n\t\t\t\t\tcase 0: case 125: scanning = 0\n\t\t\t\t\t// ;\n\t\t\t\t\tcase 59 + offset: if (ampersand == -1) characters = replace(characters, /\\f/g, '')\n\t\t\t\t\t\tif (property > 0 && (strlen(characters) - length))\n\t\t\t\t\t\t\tappend(property > 32 ? declaration(characters + ';', rule, parent, length - 1) : declaration(replace(characters, ' ', '') + ';', rule, parent, length - 2), declarations)\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// @ ;\n\t\t\t\t\tcase 59: characters += ';'\n\t\t\t\t\t// { rule/at-rule\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tappend(reference = ruleset(characters, root, parent, index, offset, rules, points, type, props = [], children = [], length), rulesets)\n\n\t\t\t\t\t\tif (character === 123)\n\t\t\t\t\t\t\tif (offset === 0)\n\t\t\t\t\t\t\t\tparse(characters, root, reference, reference, props, rulesets, length, points, children)\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\tswitch (atrule === 99 && charat(characters, 3) === 110 ? 100 : atrule) {\n\t\t\t\t\t\t\t\t\t// d l m s\n\t\t\t\t\t\t\t\t\tcase 100: case 108: case 109: case 115:\n\t\t\t\t\t\t\t\t\t\tparse(value, reference, reference, rule && append(ruleset(value, reference, reference, 0, 0, rules, points, type, rules, props = [], length), children), rules, children, length, points, rule ? props : children)\n\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\t\t\tparse(characters, reference, reference, reference, [''], children, 0, points, children)\n\t\t\t\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tindex = offset = property = 0, variable = ampersand = 1, type = characters = '', length = pseudo\n\t\t\t\tbreak\n\t\t\t// :\n\t\t\tcase 58:\n\t\t\t\tlength = 1 + strlen(characters), property = previous\n\t\t\tdefault:\n\t\t\t\tif (variable < 1)\n\t\t\t\t\tif (character == 123)\n\t\t\t\t\t\t--variable\n\t\t\t\t\telse if (character == 125 && variable++ == 0 && prev() == 125)\n\t\t\t\t\t\tcontinue\n\n\t\t\t\tswitch (characters += from(character), character * variable) {\n\t\t\t\t\t// &\n\t\t\t\t\tcase 38:\n\t\t\t\t\t\tampersand = offset > 0 ? 1 : (characters += '\\f', -1)\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// ,\n\t\t\t\t\tcase 44:\n\t\t\t\t\t\tpoints[index++] = (strlen(characters) - 1) * ampersand, ampersand = 1\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// @\n\t\t\t\t\tcase 64:\n\t\t\t\t\t\t// -\n\t\t\t\t\t\tif (peek() === 45)\n\t\t\t\t\t\t\tcharacters += delimit(next())\n\n\t\t\t\t\t\tatrule = peek(), offset = length = strlen(type = characters += identifier(caret())), character++\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// -\n\t\t\t\t\tcase 45:\n\t\t\t\t\t\tif (previous === 45 && strlen(characters) == 2)\n\t\t\t\t\t\t\tvariable = 0\n\t\t\t\t}\n\t\t}\n\n\treturn rulesets\n}\n\n/**\n * @param {string} value\n * @param {object} root\n * @param {object?} parent\n * @param {number} index\n * @param {number} offset\n * @param {string[]} rules\n * @param {number[]} points\n * @param {string} type\n * @param {string[]} props\n * @param {string[]} children\n * @param {number} length\n * @return {object}\n */\nexport function ruleset (value, root, parent, index, offset, rules, points, type, props, children, length) {\n\tvar post = offset - 1\n\tvar rule = offset === 0 ? rules : ['']\n\tvar size = sizeof(rule)\n\n\tfor (var i = 0, j = 0, k = 0; i < index; ++i)\n\t\tfor (var x = 0, y = substr(value, post + 1, post = abs(j = points[i])), z = value; x < size; ++x)\n\t\t\tif (z = trim(j > 0 ? rule[x] + ' ' + y : replace(y, /&\\f/g, rule[x])))\n\t\t\t\tprops[k++] = z\n\n\treturn node(value, root, parent, offset === 0 ? RULESET : type, props, children, length)\n}\n\n/**\n * @param {number} value\n * @param {object} root\n * @param {object?} parent\n * @return {object}\n */\nexport function comment (value, root, parent) {\n\treturn node(value, root, parent, COMMENT, from(char()), substr(value, 2, -2), 0)\n}\n\n/**\n * @param {string} value\n * @param {object} root\n * @param {object?} parent\n * @param {number} length\n * @return {object}\n */\nexport function declaration (value, root, parent, length) {\n\treturn node(value, root, parent, DECLARATION, substr(value, 0, length), substr(value, length + 1, -1), length)\n}\n","import { StyleSheet } from '@emotion/sheet';\nimport { dealloc, alloc, next, token, from, peek, delimit, slice, position, RULESET, combine, match, serialize, copy, replace, WEBKIT, MOZ, MS, KEYFRAMES, DECLARATION, hash, charat, strlen, indexof, stringify, COMMENT, rulesheet, middleware, compile } from 'stylis';\nimport '@emotion/weak-memoize';\nimport '@emotion/memoize';\n\nvar identifierWithPointTracking = function identifierWithPointTracking(begin, points, index) {\n var previous = 0;\n var character = 0;\n\n while (true) {\n previous = character;\n character = peek(); // &\\f\n\n if (previous === 38 && character === 12) {\n points[index] = 1;\n }\n\n if (token(character)) {\n break;\n }\n\n next();\n }\n\n return slice(begin, position);\n};\n\nvar toRules = function toRules(parsed, points) {\n // pretend we've started with a comma\n var index = -1;\n var character = 44;\n\n do {\n switch (token(character)) {\n case 0:\n // &\\f\n if (character === 38 && peek() === 12) {\n // this is not 100% correct, we don't account for literal sequences here - like for example quoted strings\n // stylis inserts \\f after & to know when & where it should replace this sequence with the context selector\n // and when it should just concatenate the outer and inner selectors\n // it's very unlikely for this sequence to actually appear in a different context, so we just leverage this fact here\n points[index] = 1;\n }\n\n parsed[index] += identifierWithPointTracking(position - 1, points, index);\n break;\n\n case 2:\n parsed[index] += delimit(character);\n break;\n\n case 4:\n // comma\n if (character === 44) {\n // colon\n parsed[++index] = peek() === 58 ? '&\\f' : '';\n points[index] = parsed[index].length;\n break;\n }\n\n // fallthrough\n\n default:\n parsed[index] += from(character);\n }\n } while (character = next());\n\n return parsed;\n};\n\nvar getRules = function getRules(value, points) {\n return dealloc(toRules(alloc(value), points));\n}; // WeakSet would be more appropriate, but only WeakMap is supported in IE11\n\n\nvar fixedElements = /* #__PURE__ */new WeakMap();\nvar compat = function compat(element) {\n if (element.type !== 'rule' || !element.parent || // positive .length indicates that this rule contains pseudo\n // negative .length indicates that this rule has been already prefixed\n element.length < 1) {\n return;\n }\n\n var value = element.value,\n parent = element.parent;\n var isImplicitRule = element.column === parent.column && element.line === parent.line;\n\n while (parent.type !== 'rule') {\n parent = parent.parent;\n if (!parent) return;\n } // short-circuit for the simplest case\n\n\n if (element.props.length === 1 && value.charCodeAt(0) !== 58\n /* colon */\n && !fixedElements.get(parent)) {\n return;\n } // if this is an implicitly inserted rule (the one eagerly inserted at the each new nested level)\n // then the props has already been manipulated beforehand as they that array is shared between it and its \"rule parent\"\n\n\n if (isImplicitRule) {\n return;\n }\n\n fixedElements.set(element, true);\n var points = [];\n var rules = getRules(value, points);\n var parentRules = parent.props;\n\n for (var i = 0, k = 0; i < rules.length; i++) {\n for (var j = 0; j < parentRules.length; j++, k++) {\n element.props[k] = points[i] ? rules[i].replace(/&\\f/g, parentRules[j]) : parentRules[j] + \" \" + rules[i];\n }\n }\n};\nvar removeLabel = function removeLabel(element) {\n if (element.type === 'decl') {\n var value = element.value;\n\n if ( // charcode for l\n value.charCodeAt(0) === 108 && // charcode for b\n value.charCodeAt(2) === 98) {\n // this ignores label\n element[\"return\"] = '';\n element.value = '';\n }\n }\n};\nvar ignoreFlag = 'emotion-disable-server-rendering-unsafe-selector-warning-please-do-not-use-this-the-warning-exists-for-a-reason';\n\nvar isIgnoringComment = function isIgnoringComment(element) {\n return element.type === 'comm' && element.children.indexOf(ignoreFlag) > -1;\n};\n\nvar createUnsafeSelectorsAlarm = function createUnsafeSelectorsAlarm(cache) {\n return function (element, index, children) {\n if (element.type !== 'rule' || cache.compat) return;\n var unsafePseudoClasses = element.value.match(/(:first|:nth|:nth-last)-child/g);\n\n if (unsafePseudoClasses) {\n var isNested = !!element.parent; // in nested rules comments become children of the \"auto-inserted\" rule and that's always the `element.parent`\n //\n // considering this input:\n // .a {\n // .b /* comm */ {}\n // color: hotpink;\n // }\n // we get output corresponding to this:\n // .a {\n // & {\n // /* comm */\n // color: hotpink;\n // }\n // .b {}\n // }\n\n var commentContainer = isNested ? element.parent.children : // global rule at the root level\n children;\n\n for (var i = commentContainer.length - 1; i >= 0; i--) {\n var node = commentContainer[i];\n\n if (node.line < element.line) {\n break;\n } // it is quite weird but comments are *usually* put at `column: element.column - 1`\n // so we seek *from the end* for the node that is earlier than the rule's `element` and check that\n // this will also match inputs like this:\n // .a {\n // /* comm */\n // .b {}\n // }\n //\n // but that is fine\n //\n // it would be the easiest to change the placement of the comment to be the first child of the rule:\n // .a {\n // .b { /* comm */ }\n // }\n // with such inputs we wouldn't have to search for the comment at all\n // TODO: consider changing this comment placement in the next major version\n\n\n if (node.column < element.column) {\n if (isIgnoringComment(node)) {\n return;\n }\n\n break;\n }\n }\n\n unsafePseudoClasses.forEach(function (unsafePseudoClass) {\n console.error(\"The pseudo class \\\"\" + unsafePseudoClass + \"\\\" is potentially unsafe when doing server-side rendering. Try changing it to \\\"\" + unsafePseudoClass.split('-child')[0] + \"-of-type\\\".\");\n });\n }\n };\n};\n\nvar isImportRule = function isImportRule(element) {\n return element.type.charCodeAt(1) === 105 && element.type.charCodeAt(0) === 64;\n};\n\nvar isPrependedWithRegularRules = function isPrependedWithRegularRules(index, children) {\n for (var i = index - 1; i >= 0; i--) {\n if (!isImportRule(children[i])) {\n return true;\n }\n }\n\n return false;\n}; // use this to remove incorrect elements from further processing\n// so they don't get handed to the `sheet` (or anything else)\n// as that could potentially lead to additional logs which in turn could be overhelming to the user\n\n\nvar nullifyElement = function nullifyElement(element) {\n element.type = '';\n element.value = '';\n element[\"return\"] = '';\n element.children = '';\n element.props = '';\n};\n\nvar incorrectImportAlarm = function incorrectImportAlarm(element, index, children) {\n if (!isImportRule(element)) {\n return;\n }\n\n if (element.parent) {\n console.error(\"`@import` rules can't be nested inside other rules. Please move it to the top level and put it before regular rules. Keep in mind that they can only be used within global styles.\");\n nullifyElement(element);\n } else if (isPrependedWithRegularRules(index, children)) {\n console.error(\"`@import` rules can't be after other rules. Please put your `@import` rules before your other rules.\");\n nullifyElement(element);\n }\n};\n\n/* eslint-disable no-fallthrough */\n\nfunction prefix(value, length) {\n switch (hash(value, length)) {\n // color-adjust\n case 5103:\n return WEBKIT + 'print-' + value + value;\n // animation, animation-(delay|direction|duration|fill-mode|iteration-count|name|play-state|timing-function)\n\n case 5737:\n case 4201:\n case 3177:\n case 3433:\n case 1641:\n case 4457:\n case 2921: // text-decoration, filter, clip-path, backface-visibility, column, box-decoration-break\n\n case 5572:\n case 6356:\n case 5844:\n case 3191:\n case 6645:\n case 3005: // mask, mask-image, mask-(mode|clip|size), mask-(repeat|origin), mask-position, mask-composite,\n\n case 6391:\n case 5879:\n case 5623:\n case 6135:\n case 4599:\n case 4855: // background-clip, columns, column-(count|fill|gap|rule|rule-color|rule-style|rule-width|span|width)\n\n case 4215:\n case 6389:\n case 5109:\n case 5365:\n case 5621:\n case 3829:\n return WEBKIT + value + value;\n // appearance, user-select, transform, hyphens, text-size-adjust\n\n case 5349:\n case 4246:\n case 4810:\n case 6968:\n case 2756:\n return WEBKIT + value + MOZ + value + MS + value + value;\n // flex, flex-direction\n\n case 6828:\n case 4268:\n return WEBKIT + value + MS + value + value;\n // order\n\n case 6165:\n return WEBKIT + value + MS + 'flex-' + value + value;\n // align-items\n\n case 5187:\n return WEBKIT + value + replace(value, /(\\w+).+(:[^]+)/, WEBKIT + 'box-$1$2' + MS + 'flex-$1$2') + value;\n // align-self\n\n case 5443:\n return WEBKIT + value + MS + 'flex-item-' + replace(value, /flex-|-self/, '') + value;\n // align-content\n\n case 4675:\n return WEBKIT + value + MS + 'flex-line-pack' + replace(value, /align-content|flex-|-self/, '') + value;\n // flex-shrink\n\n case 5548:\n return WEBKIT + value + MS + replace(value, 'shrink', 'negative') + value;\n // flex-basis\n\n case 5292:\n return WEBKIT + value + MS + replace(value, 'basis', 'preferred-size') + value;\n // flex-grow\n\n case 6060:\n return WEBKIT + 'box-' + replace(value, '-grow', '') + WEBKIT + value + MS + replace(value, 'grow', 'positive') + value;\n // transition\n\n case 4554:\n return WEBKIT + replace(value, /([^-])(transform)/g, '$1' + WEBKIT + '$2') + value;\n // cursor\n\n case 6187:\n return replace(replace(replace(value, /(zoom-|grab)/, WEBKIT + '$1'), /(image-set)/, WEBKIT + '$1'), value, '') + value;\n // background, background-image\n\n case 5495:\n case 3959:\n return replace(value, /(image-set\\([^]*)/, WEBKIT + '$1' + '$`$1');\n // justify-content\n\n case 4968:\n return replace(replace(value, /(.+:)(flex-)?(.*)/, WEBKIT + 'box-pack:$3' + MS + 'flex-pack:$3'), /s.+-b[^;]+/, 'justify') + WEBKIT + value + value;\n // (margin|padding)-inline-(start|end)\n\n case 4095:\n case 3583:\n case 4068:\n case 2532:\n return replace(value, /(.+)-inline(.+)/, WEBKIT + '$1$2') + value;\n // (min|max)?(width|height|inline-size|block-size)\n\n case 8116:\n case 7059:\n case 5753:\n case 5535:\n case 5445:\n case 5701:\n case 4933:\n case 4677:\n case 5533:\n case 5789:\n case 5021:\n case 4765:\n // stretch, max-content, min-content, fill-available\n if (strlen(value) - 1 - length > 6) switch (charat(value, length + 1)) {\n // (m)ax-content, (m)in-content\n case 109:\n // -\n if (charat(value, length + 4) !== 45) break;\n // (f)ill-available, (f)it-content\n\n case 102:\n return replace(value, /(.+:)(.+)-([^]+)/, '$1' + WEBKIT + '$2-$3' + '$1' + MOZ + (charat(value, length + 3) == 108 ? '$3' : '$2-$3')) + value;\n // (s)tretch\n\n case 115:\n return ~indexof(value, 'stretch') ? prefix(replace(value, 'stretch', 'fill-available'), length) + value : value;\n }\n break;\n // position: sticky\n\n case 4949:\n // (s)ticky?\n if (charat(value, length + 1) !== 115) break;\n // display: (flex|inline-flex)\n\n case 6444:\n switch (charat(value, strlen(value) - 3 - (~indexof(value, '!important') && 10))) {\n // stic(k)y\n case 107:\n return replace(value, ':', ':' + WEBKIT) + value;\n // (inline-)?fl(e)x\n\n case 101:\n return replace(value, /(.+:)([^;!]+)(;|!.+)?/, '$1' + WEBKIT + (charat(value, 14) === 45 ? 'inline-' : '') + 'box$3' + '$1' + WEBKIT + '$2$3' + '$1' + MS + '$2box$3') + value;\n }\n\n break;\n // writing-mode\n\n case 5936:\n switch (charat(value, length + 11)) {\n // vertical-l(r)\n case 114:\n return WEBKIT + value + MS + replace(value, /[svh]\\w+-[tblr]{2}/, 'tb') + value;\n // vertical-r(l)\n\n case 108:\n return WEBKIT + value + MS + replace(value, /[svh]\\w+-[tblr]{2}/, 'tb-rl') + value;\n // horizontal(-)tb\n\n case 45:\n return WEBKIT + value + MS + replace(value, /[svh]\\w+-[tblr]{2}/, 'lr') + value;\n }\n\n return WEBKIT + value + MS + value + value;\n }\n\n return value;\n}\n\nvar prefixer = function prefixer(element, index, children, callback) {\n if (element.length > -1) if (!element[\"return\"]) switch (element.type) {\n case DECLARATION:\n element[\"return\"] = prefix(element.value, element.length);\n break;\n\n case KEYFRAMES:\n return serialize([copy(element, {\n value: replace(element.value, '@', '@' + WEBKIT)\n })], callback);\n\n case RULESET:\n if (element.length) return combine(element.props, function (value) {\n switch (match(value, /(::plac\\w+|:read-\\w+)/)) {\n // :read-(only|write)\n case ':read-only':\n case ':read-write':\n return serialize([copy(element, {\n props: [replace(value, /:(read-\\w+)/, ':' + MOZ + '$1')]\n })], callback);\n // :placeholder\n\n case '::placeholder':\n return serialize([copy(element, {\n props: [replace(value, /:(plac\\w+)/, ':' + WEBKIT + 'input-$1')]\n }), copy(element, {\n props: [replace(value, /:(plac\\w+)/, ':' + MOZ + '$1')]\n }), copy(element, {\n props: [replace(value, /:(plac\\w+)/, MS + 'input-$1')]\n })], callback);\n }\n\n return '';\n });\n }\n};\n\nvar defaultStylisPlugins = [prefixer];\n\nvar createCache = function createCache(options) {\n var key = options.key;\n\n if (process.env.NODE_ENV !== 'production' && !key) {\n throw new Error(\"You have to configure `key` for your cache. Please make sure it's unique (and not equal to 'css') as it's used for linking styles to your cache.\\n\" + \"If multiple caches share the same key they might \\\"fight\\\" for each other's style elements.\");\n }\n\n if (key === 'css') {\n var ssrStyles = document.querySelectorAll(\"style[data-emotion]:not([data-s])\"); // get SSRed styles out of the way of React's hydration\n // document.head is a safe place to move them to(though note document.head is not necessarily the last place they will be)\n // note this very very intentionally targets all style elements regardless of the key to ensure\n // that creating a cache works inside of render of a React component\n\n Array.prototype.forEach.call(ssrStyles, function (node) {\n // we want to only move elements which have a space in the data-emotion attribute value\n // because that indicates that it is an Emotion 11 server-side rendered style elements\n // while we will already ignore Emotion 11 client-side inserted styles because of the :not([data-s]) part in the selector\n // Emotion 10 client-side inserted styles did not have data-s (but importantly did not have a space in their data-emotion attributes)\n // so checking for the space ensures that loading Emotion 11 after Emotion 10 has inserted some styles\n // will not result in the Emotion 10 styles being destroyed\n var dataEmotionAttribute = node.getAttribute('data-emotion');\n\n if (dataEmotionAttribute.indexOf(' ') === -1) {\n return;\n }\n document.head.appendChild(node);\n node.setAttribute('data-s', '');\n });\n }\n\n var stylisPlugins = options.stylisPlugins || defaultStylisPlugins;\n\n if (process.env.NODE_ENV !== 'production') {\n // $FlowFixMe\n if (/[^a-z-]/.test(key)) {\n throw new Error(\"Emotion key must only contain lower case alphabetical characters and - but \\\"\" + key + \"\\\" was passed\");\n }\n }\n\n var inserted = {};\n var container;\n var nodesToHydrate = [];\n\n {\n container = options.container || document.head;\n Array.prototype.forEach.call( // this means we will ignore elements which don't have a space in them which\n // means that the style elements we're looking at are only Emotion 11 server-rendered style elements\n document.querySelectorAll(\"style[data-emotion^=\\\"\" + key + \" \\\"]\"), function (node) {\n var attrib = node.getAttribute(\"data-emotion\").split(' '); // $FlowFixMe\n\n for (var i = 1; i < attrib.length; i++) {\n inserted[attrib[i]] = true;\n }\n\n nodesToHydrate.push(node);\n });\n }\n\n var _insert;\n\n var omnipresentPlugins = [compat, removeLabel];\n\n if (process.env.NODE_ENV !== 'production') {\n omnipresentPlugins.push(createUnsafeSelectorsAlarm({\n get compat() {\n return cache.compat;\n }\n\n }), incorrectImportAlarm);\n }\n\n {\n var currentSheet;\n var finalizingPlugins = [stringify, process.env.NODE_ENV !== 'production' ? function (element) {\n if (!element.root) {\n if (element[\"return\"]) {\n currentSheet.insert(element[\"return\"]);\n } else if (element.value && element.type !== COMMENT) {\n // insert empty rule in non-production environments\n // so @emotion/jest can grab `key` from the (JS)DOM for caches without any rules inserted yet\n currentSheet.insert(element.value + \"{}\");\n }\n }\n } : rulesheet(function (rule) {\n currentSheet.insert(rule);\n })];\n var serializer = middleware(omnipresentPlugins.concat(stylisPlugins, finalizingPlugins));\n\n var stylis = function stylis(styles) {\n return serialize(compile(styles), serializer);\n };\n\n _insert = function insert(selector, serialized, sheet, shouldCache) {\n currentSheet = sheet;\n\n if (process.env.NODE_ENV !== 'production' && serialized.map !== undefined) {\n currentSheet = {\n insert: function insert(rule) {\n sheet.insert(rule + serialized.map);\n }\n };\n }\n\n stylis(selector ? selector + \"{\" + serialized.styles + \"}\" : serialized.styles);\n\n if (shouldCache) {\n cache.inserted[serialized.name] = true;\n }\n };\n }\n\n var cache = {\n key: key,\n sheet: new StyleSheet({\n key: key,\n container: container,\n nonce: options.nonce,\n speedy: options.speedy,\n prepend: options.prepend,\n insertionPoint: options.insertionPoint\n }),\n nonce: options.nonce,\n inserted: inserted,\n registered: {},\n insert: _insert\n };\n cache.sheet.hydrate(nodesToHydrate);\n return cache;\n};\n\nexport { createCache as default };\n","import {MS, MOZ, WEBKIT, RULESET, KEYFRAMES, DECLARATION} from './Enum.js'\nimport {match, charat, substr, strlen, sizeof, replace, combine} from './Utility.js'\nimport {copy, tokenize} from './Tokenizer.js'\nimport {serialize} from './Serializer.js'\nimport {prefix} from './Prefixer.js'\n\n/**\n * @param {function[]} collection\n * @return {function}\n */\nexport function middleware (collection) {\n\tvar length = sizeof(collection)\n\n\treturn function (element, index, children, callback) {\n\t\tvar output = ''\n\n\t\tfor (var i = 0; i < length; i++)\n\t\t\toutput += collection[i](element, index, children, callback) || ''\n\n\t\treturn output\n\t}\n}\n\n/**\n * @param {function} callback\n * @return {function}\n */\nexport function rulesheet (callback) {\n\treturn function (element) {\n\t\tif (!element.root)\n\t\t\tif (element = element.return)\n\t\t\t\tcallback(element)\n\t}\n}\n\n/**\n * @param {object} element\n * @param {number} index\n * @param {object[]} children\n * @param {function} callback\n */\nexport function prefixer (element, index, children, callback) {\n\tif (element.length > -1)\n\t\tif (!element.return)\n\t\t\tswitch (element.type) {\n\t\t\t\tcase DECLARATION: element.return = prefix(element.value, element.length, children)\n\t\t\t\t\treturn\n\t\t\t\tcase KEYFRAMES:\n\t\t\t\t\treturn serialize([copy(element, {value: replace(element.value, '@', '@' + WEBKIT)})], callback)\n\t\t\t\tcase RULESET:\n\t\t\t\t\tif (element.length)\n\t\t\t\t\t\treturn combine(element.props, function (value) {\n\t\t\t\t\t\t\tswitch (match(value, /(::plac\\w+|:read-\\w+)/)) {\n\t\t\t\t\t\t\t\t// :read-(only|write)\n\t\t\t\t\t\t\t\tcase ':read-only': case ':read-write':\n\t\t\t\t\t\t\t\t\treturn serialize([copy(element, {props: [replace(value, /:(read-\\w+)/, ':' + MOZ + '$1')]})], callback)\n\t\t\t\t\t\t\t\t// :placeholder\n\t\t\t\t\t\t\t\tcase '::placeholder':\n\t\t\t\t\t\t\t\t\treturn serialize([\n\t\t\t\t\t\t\t\t\t\tcopy(element, {props: [replace(value, /:(plac\\w+)/, ':' + WEBKIT + 'input-$1')]}),\n\t\t\t\t\t\t\t\t\t\tcopy(element, {props: [replace(value, /:(plac\\w+)/, ':' + MOZ + '$1')]}),\n\t\t\t\t\t\t\t\t\t\tcopy(element, {props: [replace(value, /:(plac\\w+)/, MS + 'input-$1')]})\n\t\t\t\t\t\t\t\t\t], callback)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\treturn ''\n\t\t\t\t\t\t})\n\t\t\t}\n}\n\n/**\n * @param {object} element\n * @param {number} index\n * @param {object[]} children\n */\nexport function namespace (element) {\n\tswitch (element.type) {\n\t\tcase RULESET:\n\t\t\telement.props = element.props.map(function (value) {\n\t\t\t\treturn combine(tokenize(value), function (value, index, children) {\n\t\t\t\t\tswitch (charat(value, 0)) {\n\t\t\t\t\t\t// \\f\n\t\t\t\t\t\tcase 12:\n\t\t\t\t\t\t\treturn substr(value, 1, strlen(value))\n\t\t\t\t\t\t// \\0 ( + > ~\n\t\t\t\t\t\tcase 0: case 40: case 43: case 62: case 126:\n\t\t\t\t\t\t\treturn value\n\t\t\t\t\t\t// :\n\t\t\t\t\t\tcase 58:\n\t\t\t\t\t\t\tif (children[++index] === 'global')\n\t\t\t\t\t\t\t\tchildren[index] = '', children[++index] = '\\f' + substr(children[index], index = 1, -1)\n\t\t\t\t\t\t// \\s\n\t\t\t\t\t\tcase 32:\n\t\t\t\t\t\t\treturn index === 1 ? '' : value\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\tswitch (index) {\n\t\t\t\t\t\t\t\tcase 0: element = value\n\t\t\t\t\t\t\t\t\treturn sizeof(children) > 1 ? '' : value\n\t\t\t\t\t\t\t\tcase index = sizeof(children) - 1: case 2:\n\t\t\t\t\t\t\t\t\treturn index === 2 ? value + element + element : value + element\n\t\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\t\treturn value\n\t\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t})\n\t\t\t})\n\t}\n}\n","function memoize(fn) {\n var cache = Object.create(null);\n return function (arg) {\n if (cache[arg] === undefined) cache[arg] = fn(arg);\n return cache[arg];\n };\n}\n\nexport { memoize as default };\n","import * as React from 'react';\nimport { useContext, forwardRef } from 'react';\nimport createCache from '@emotion/cache';\nimport _extends from '@babel/runtime/helpers/esm/extends';\nimport weakMemoize from '@emotion/weak-memoize';\nimport hoistNonReactStatics from '../_isolated-hnrs/dist/emotion-react-_isolated-hnrs.browser.esm.js';\nimport { getRegisteredStyles, registerStyles, insertStyles } from '@emotion/utils';\nimport { serializeStyles } from '@emotion/serialize';\nimport { useInsertionEffectAlwaysWithSyncFallback } from '@emotion/use-insertion-effect-with-fallbacks';\n\nvar isBrowser = \"object\" !== 'undefined';\nvar hasOwn = {}.hasOwnProperty;\n\nvar EmotionCacheContext = /* #__PURE__ */React.createContext( // we're doing this to avoid preconstruct's dead code elimination in this one case\n// because this module is primarily intended for the browser and node\n// but it's also required in react native and similar environments sometimes\n// and we could have a special build just for that\n// but this is much easier and the native packages\n// might use a different theme context in the future anyway\ntypeof HTMLElement !== 'undefined' ? /* #__PURE__ */createCache({\n key: 'css'\n}) : null);\n\nif (process.env.NODE_ENV !== 'production') {\n EmotionCacheContext.displayName = 'EmotionCacheContext';\n}\n\nvar CacheProvider = EmotionCacheContext.Provider;\nvar __unsafe_useEmotionCache = function useEmotionCache() {\n return useContext(EmotionCacheContext);\n};\n\nvar withEmotionCache = function withEmotionCache(func) {\n // $FlowFixMe\n return /*#__PURE__*/forwardRef(function (props, ref) {\n // the cache will never be null in the browser\n var cache = useContext(EmotionCacheContext);\n return func(props, cache, ref);\n });\n};\n\nif (!isBrowser) {\n withEmotionCache = function withEmotionCache(func) {\n return function (props) {\n var cache = useContext(EmotionCacheContext);\n\n if (cache === null) {\n // yes, we're potentially creating this on every render\n // it doesn't actually matter though since it's only on the server\n // so there will only every be a single render\n // that could change in the future because of suspense and etc. but for now,\n // this works and i don't want to optimise for a future thing that we aren't sure about\n cache = createCache({\n key: 'css'\n });\n return /*#__PURE__*/React.createElement(EmotionCacheContext.Provider, {\n value: cache\n }, func(props, cache));\n } else {\n return func(props, cache);\n }\n };\n };\n}\n\nvar ThemeContext = /* #__PURE__ */React.createContext({});\n\nif (process.env.NODE_ENV !== 'production') {\n ThemeContext.displayName = 'EmotionThemeContext';\n}\n\nvar useTheme = function useTheme() {\n return React.useContext(ThemeContext);\n};\n\nvar getTheme = function getTheme(outerTheme, theme) {\n if (typeof theme === 'function') {\n var mergedTheme = theme(outerTheme);\n\n if (process.env.NODE_ENV !== 'production' && (mergedTheme == null || typeof mergedTheme !== 'object' || Array.isArray(mergedTheme))) {\n throw new Error('[ThemeProvider] Please return an object from your theme function, i.e. theme={() => ({})}!');\n }\n\n return mergedTheme;\n }\n\n if (process.env.NODE_ENV !== 'production' && (theme == null || typeof theme !== 'object' || Array.isArray(theme))) {\n throw new Error('[ThemeProvider] Please make your theme prop a plain object');\n }\n\n return _extends({}, outerTheme, theme);\n};\n\nvar createCacheWithTheme = /* #__PURE__ */weakMemoize(function (outerTheme) {\n return weakMemoize(function (theme) {\n return getTheme(outerTheme, theme);\n });\n});\nvar ThemeProvider = function ThemeProvider(props) {\n var theme = React.useContext(ThemeContext);\n\n if (props.theme !== theme) {\n theme = createCacheWithTheme(theme)(props.theme);\n }\n\n return /*#__PURE__*/React.createElement(ThemeContext.Provider, {\n value: theme\n }, props.children);\n};\nfunction withTheme(Component) {\n var componentName = Component.displayName || Component.name || 'Component';\n\n var render = function render(props, ref) {\n var theme = React.useContext(ThemeContext);\n return /*#__PURE__*/React.createElement(Component, _extends({\n theme: theme,\n ref: ref\n }, props));\n }; // $FlowFixMe\n\n\n var WithTheme = /*#__PURE__*/React.forwardRef(render);\n WithTheme.displayName = \"WithTheme(\" + componentName + \")\";\n return hoistNonReactStatics(WithTheme, Component);\n}\n\nvar getLastPart = function getLastPart(functionName) {\n // The match may be something like 'Object.createEmotionProps' or\n // 'Loader.prototype.render'\n var parts = functionName.split('.');\n return parts[parts.length - 1];\n};\n\nvar getFunctionNameFromStackTraceLine = function getFunctionNameFromStackTraceLine(line) {\n // V8\n var match = /^\\s+at\\s+([A-Za-z0-9$.]+)\\s/.exec(line);\n if (match) return getLastPart(match[1]); // Safari / Firefox\n\n match = /^([A-Za-z0-9$.]+)@/.exec(line);\n if (match) return getLastPart(match[1]);\n return undefined;\n};\n\nvar internalReactFunctionNames = /* #__PURE__ */new Set(['renderWithHooks', 'processChild', 'finishClassComponent', 'renderToString']); // These identifiers come from error stacks, so they have to be valid JS\n// identifiers, thus we only need to replace what is a valid character for JS,\n// but not for CSS.\n\nvar sanitizeIdentifier = function sanitizeIdentifier(identifier) {\n return identifier.replace(/\\$/g, '-');\n};\n\nvar getLabelFromStackTrace = function getLabelFromStackTrace(stackTrace) {\n if (!stackTrace) return undefined;\n var lines = stackTrace.split('\\n');\n\n for (var i = 0; i < lines.length; i++) {\n var functionName = getFunctionNameFromStackTraceLine(lines[i]); // The first line of V8 stack traces is just \"Error\"\n\n if (!functionName) continue; // If we reach one of these, we have gone too far and should quit\n\n if (internalReactFunctionNames.has(functionName)) break; // The component name is the first function in the stack that starts with an\n // uppercase letter\n\n if (/^[A-Z]/.test(functionName)) return sanitizeIdentifier(functionName);\n }\n\n return undefined;\n};\n\nvar typePropName = '__EMOTION_TYPE_PLEASE_DO_NOT_USE__';\nvar labelPropName = '__EMOTION_LABEL_PLEASE_DO_NOT_USE__';\nvar createEmotionProps = function createEmotionProps(type, props) {\n if (process.env.NODE_ENV !== 'production' && typeof props.css === 'string' && // check if there is a css declaration\n props.css.indexOf(':') !== -1) {\n throw new Error(\"Strings are not allowed as css prop values, please wrap it in a css template literal from '@emotion/react' like this: css`\" + props.css + \"`\");\n }\n\n var newProps = {};\n\n for (var key in props) {\n if (hasOwn.call(props, key)) {\n newProps[key] = props[key];\n }\n }\n\n newProps[typePropName] = type; // For performance, only call getLabelFromStackTrace in development and when\n // the label hasn't already been computed\n\n if (process.env.NODE_ENV !== 'production' && !!props.css && (typeof props.css !== 'object' || typeof props.css.name !== 'string' || props.css.name.indexOf('-') === -1)) {\n var label = getLabelFromStackTrace(new Error().stack);\n if (label) newProps[labelPropName] = label;\n }\n\n return newProps;\n};\n\nvar Insertion = function Insertion(_ref) {\n var cache = _ref.cache,\n serialized = _ref.serialized,\n isStringTag = _ref.isStringTag;\n registerStyles(cache, serialized, isStringTag);\n useInsertionEffectAlwaysWithSyncFallback(function () {\n return insertStyles(cache, serialized, isStringTag);\n });\n\n return null;\n};\n\nvar Emotion = /* #__PURE__ */withEmotionCache(function (props, cache, ref) {\n var cssProp = props.css; // so that using `css` from `emotion` and passing the result to the css prop works\n // not passing the registered cache to serializeStyles because it would\n // make certain babel optimisations not possible\n\n if (typeof cssProp === 'string' && cache.registered[cssProp] !== undefined) {\n cssProp = cache.registered[cssProp];\n }\n\n var WrappedComponent = props[typePropName];\n var registeredStyles = [cssProp];\n var className = '';\n\n if (typeof props.className === 'string') {\n className = getRegisteredStyles(cache.registered, registeredStyles, props.className);\n } else if (props.className != null) {\n className = props.className + \" \";\n }\n\n var serialized = serializeStyles(registeredStyles, undefined, React.useContext(ThemeContext));\n\n if (process.env.NODE_ENV !== 'production' && serialized.name.indexOf('-') === -1) {\n var labelFromStack = props[labelPropName];\n\n if (labelFromStack) {\n serialized = serializeStyles([serialized, 'label:' + labelFromStack + ';']);\n }\n }\n\n className += cache.key + \"-\" + serialized.name;\n var newProps = {};\n\n for (var key in props) {\n if (hasOwn.call(props, key) && key !== 'css' && key !== typePropName && (process.env.NODE_ENV === 'production' || key !== labelPropName)) {\n newProps[key] = props[key];\n }\n }\n\n newProps.ref = ref;\n newProps.className = className;\n return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Insertion, {\n cache: cache,\n serialized: serialized,\n isStringTag: typeof WrappedComponent === 'string'\n }), /*#__PURE__*/React.createElement(WrappedComponent, newProps));\n});\n\nif (process.env.NODE_ENV !== 'production') {\n Emotion.displayName = 'EmotionCssPropInternal';\n}\n\nvar Emotion$1 = Emotion;\n\nexport { CacheProvider as C, Emotion$1 as E, ThemeContext as T, __unsafe_useEmotionCache as _, ThemeProvider as a, withTheme as b, createEmotionProps as c, hasOwn as h, isBrowser as i, useTheme as u, withEmotionCache as w };\n","import { h as hasOwn, E as Emotion, c as createEmotionProps, w as withEmotionCache, T as ThemeContext, i as isBrowser$1 } from './emotion-element-43c6fea0.browser.esm.js';\nexport { C as CacheProvider, T as ThemeContext, a as ThemeProvider, _ as __unsafe_useEmotionCache, u as useTheme, w as withEmotionCache, b as withTheme } from './emotion-element-43c6fea0.browser.esm.js';\nimport * as React from 'react';\nimport { insertStyles, registerStyles, getRegisteredStyles } from '@emotion/utils';\nimport { useInsertionEffectWithLayoutFallback, useInsertionEffectAlwaysWithSyncFallback } from '@emotion/use-insertion-effect-with-fallbacks';\nimport { serializeStyles } from '@emotion/serialize';\nimport '@emotion/cache';\nimport '@babel/runtime/helpers/extends';\nimport '@emotion/weak-memoize';\nimport '../_isolated-hnrs/dist/emotion-react-_isolated-hnrs.browser.esm.js';\nimport 'hoist-non-react-statics';\n\nvar pkg = {\n\tname: \"@emotion/react\",\n\tversion: \"11.11.4\",\n\tmain: \"dist/emotion-react.cjs.js\",\n\tmodule: \"dist/emotion-react.esm.js\",\n\tbrowser: {\n\t\t\"./dist/emotion-react.esm.js\": \"./dist/emotion-react.browser.esm.js\"\n\t},\n\texports: {\n\t\t\".\": {\n\t\t\tmodule: {\n\t\t\t\tworker: \"./dist/emotion-react.worker.esm.js\",\n\t\t\t\tbrowser: \"./dist/emotion-react.browser.esm.js\",\n\t\t\t\t\"default\": \"./dist/emotion-react.esm.js\"\n\t\t\t},\n\t\t\t\"import\": \"./dist/emotion-react.cjs.mjs\",\n\t\t\t\"default\": \"./dist/emotion-react.cjs.js\"\n\t\t},\n\t\t\"./jsx-runtime\": {\n\t\t\tmodule: {\n\t\t\t\tworker: \"./jsx-runtime/dist/emotion-react-jsx-runtime.worker.esm.js\",\n\t\t\t\tbrowser: \"./jsx-runtime/dist/emotion-react-jsx-runtime.browser.esm.js\",\n\t\t\t\t\"default\": \"./jsx-runtime/dist/emotion-react-jsx-runtime.esm.js\"\n\t\t\t},\n\t\t\t\"import\": \"./jsx-runtime/dist/emotion-react-jsx-runtime.cjs.mjs\",\n\t\t\t\"default\": \"./jsx-runtime/dist/emotion-react-jsx-runtime.cjs.js\"\n\t\t},\n\t\t\"./_isolated-hnrs\": {\n\t\t\tmodule: {\n\t\t\t\tworker: \"./_isolated-hnrs/dist/emotion-react-_isolated-hnrs.worker.esm.js\",\n\t\t\t\tbrowser: \"./_isolated-hnrs/dist/emotion-react-_isolated-hnrs.browser.esm.js\",\n\t\t\t\t\"default\": \"./_isolated-hnrs/dist/emotion-react-_isolated-hnrs.esm.js\"\n\t\t\t},\n\t\t\t\"import\": \"./_isolated-hnrs/dist/emotion-react-_isolated-hnrs.cjs.mjs\",\n\t\t\t\"default\": \"./_isolated-hnrs/dist/emotion-react-_isolated-hnrs.cjs.js\"\n\t\t},\n\t\t\"./jsx-dev-runtime\": {\n\t\t\tmodule: {\n\t\t\t\tworker: \"./jsx-dev-runtime/dist/emotion-react-jsx-dev-runtime.worker.esm.js\",\n\t\t\t\tbrowser: \"./jsx-dev-runtime/dist/emotion-react-jsx-dev-runtime.browser.esm.js\",\n\t\t\t\t\"default\": \"./jsx-dev-runtime/dist/emotion-react-jsx-dev-runtime.esm.js\"\n\t\t\t},\n\t\t\t\"import\": \"./jsx-dev-runtime/dist/emotion-react-jsx-dev-runtime.cjs.mjs\",\n\t\t\t\"default\": \"./jsx-dev-runtime/dist/emotion-react-jsx-dev-runtime.cjs.js\"\n\t\t},\n\t\t\"./package.json\": \"./package.json\",\n\t\t\"./types/css-prop\": \"./types/css-prop.d.ts\",\n\t\t\"./macro\": {\n\t\t\ttypes: {\n\t\t\t\t\"import\": \"./macro.d.mts\",\n\t\t\t\t\"default\": \"./macro.d.ts\"\n\t\t\t},\n\t\t\t\"default\": \"./macro.js\"\n\t\t}\n\t},\n\ttypes: \"types/index.d.ts\",\n\tfiles: [\n\t\t\"src\",\n\t\t\"dist\",\n\t\t\"jsx-runtime\",\n\t\t\"jsx-dev-runtime\",\n\t\t\"_isolated-hnrs\",\n\t\t\"types/*.d.ts\",\n\t\t\"macro.*\"\n\t],\n\tsideEffects: false,\n\tauthor: \"Emotion Contributors\",\n\tlicense: \"MIT\",\n\tscripts: {\n\t\t\"test:typescript\": \"dtslint types\"\n\t},\n\tdependencies: {\n\t\t\"@babel/runtime\": \"^7.18.3\",\n\t\t\"@emotion/babel-plugin\": \"^11.11.0\",\n\t\t\"@emotion/cache\": \"^11.11.0\",\n\t\t\"@emotion/serialize\": \"^1.1.3\",\n\t\t\"@emotion/use-insertion-effect-with-fallbacks\": \"^1.0.1\",\n\t\t\"@emotion/utils\": \"^1.2.1\",\n\t\t\"@emotion/weak-memoize\": \"^0.3.1\",\n\t\t\"hoist-non-react-statics\": \"^3.3.1\"\n\t},\n\tpeerDependencies: {\n\t\treact: \">=16.8.0\"\n\t},\n\tpeerDependenciesMeta: {\n\t\t\"@types/react\": {\n\t\t\toptional: true\n\t\t}\n\t},\n\tdevDependencies: {\n\t\t\"@definitelytyped/dtslint\": \"0.0.112\",\n\t\t\"@emotion/css\": \"11.11.2\",\n\t\t\"@emotion/css-prettifier\": \"1.1.3\",\n\t\t\"@emotion/server\": \"11.11.0\",\n\t\t\"@emotion/styled\": \"11.11.0\",\n\t\t\"html-tag-names\": \"^1.1.2\",\n\t\treact: \"16.14.0\",\n\t\t\"svg-tag-names\": \"^1.1.1\",\n\t\ttypescript: \"^4.5.5\"\n\t},\n\trepository: \"https://github.com/emotion-js/emotion/tree/main/packages/react\",\n\tpublishConfig: {\n\t\taccess: \"public\"\n\t},\n\t\"umd:main\": \"dist/emotion-react.umd.min.js\",\n\tpreconstruct: {\n\t\tentrypoints: [\n\t\t\t\"./index.js\",\n\t\t\t\"./jsx-runtime.js\",\n\t\t\t\"./jsx-dev-runtime.js\",\n\t\t\t\"./_isolated-hnrs.js\"\n\t\t],\n\t\tumdName: \"emotionReact\",\n\t\texports: {\n\t\t\tenvConditions: [\n\t\t\t\t\"browser\",\n\t\t\t\t\"worker\"\n\t\t\t],\n\t\t\textra: {\n\t\t\t\t\"./types/css-prop\": \"./types/css-prop.d.ts\",\n\t\t\t\t\"./macro\": {\n\t\t\t\t\ttypes: {\n\t\t\t\t\t\t\"import\": \"./macro.d.mts\",\n\t\t\t\t\t\t\"default\": \"./macro.d.ts\"\n\t\t\t\t\t},\n\t\t\t\t\t\"default\": \"./macro.js\"\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n};\n\nvar jsx = function jsx(type, props) {\n var args = arguments;\n\n if (props == null || !hasOwn.call(props, 'css')) {\n // $FlowFixMe\n return React.createElement.apply(undefined, args);\n }\n\n var argsLength = args.length;\n var createElementArgArray = new Array(argsLength);\n createElementArgArray[0] = Emotion;\n createElementArgArray[1] = createEmotionProps(type, props);\n\n for (var i = 2; i < argsLength; i++) {\n createElementArgArray[i] = args[i];\n } // $FlowFixMe\n\n\n return React.createElement.apply(null, createElementArgArray);\n};\n\nvar warnedAboutCssPropForGlobal = false; // maintain place over rerenders.\n// initial render from browser, insertBefore context.sheet.tags[0] or if a style hasn't been inserted there yet, appendChild\n// initial client-side render from SSR, use place of hydrating tag\n\nvar Global = /* #__PURE__ */withEmotionCache(function (props, cache) {\n if (process.env.NODE_ENV !== 'production' && !warnedAboutCssPropForGlobal && ( // check for className as well since the user is\n // probably using the custom createElement which\n // means it will be turned into a className prop\n // $FlowFixMe I don't really want to add it to the type since it shouldn't be used\n props.className || props.css)) {\n console.error(\"It looks like you're using the css prop on Global, did you mean to use the styles prop instead?\");\n warnedAboutCssPropForGlobal = true;\n }\n\n var styles = props.styles;\n var serialized = serializeStyles([styles], undefined, React.useContext(ThemeContext));\n\n if (!isBrowser$1) {\n var _ref;\n\n var serializedNames = serialized.name;\n var serializedStyles = serialized.styles;\n var next = serialized.next;\n\n while (next !== undefined) {\n serializedNames += ' ' + next.name;\n serializedStyles += next.styles;\n next = next.next;\n }\n\n var shouldCache = cache.compat === true;\n var rules = cache.insert(\"\", {\n name: serializedNames,\n styles: serializedStyles\n }, cache.sheet, shouldCache);\n\n if (shouldCache) {\n return null;\n }\n\n return /*#__PURE__*/React.createElement(\"style\", (_ref = {}, _ref[\"data-emotion\"] = cache.key + \"-global \" + serializedNames, _ref.dangerouslySetInnerHTML = {\n __html: rules\n }, _ref.nonce = cache.sheet.nonce, _ref));\n } // yes, i know these hooks are used conditionally\n // but it is based on a constant that will never change at runtime\n // it's effectively like having two implementations and switching them out\n // so it's not actually breaking anything\n\n\n var sheetRef = React.useRef();\n useInsertionEffectWithLayoutFallback(function () {\n var key = cache.key + \"-global\"; // use case of https://github.com/emotion-js/emotion/issues/2675\n\n var sheet = new cache.sheet.constructor({\n key: key,\n nonce: cache.sheet.nonce,\n container: cache.sheet.container,\n speedy: cache.sheet.isSpeedy\n });\n var rehydrating = false; // $FlowFixMe\n\n var node = document.querySelector(\"style[data-emotion=\\\"\" + key + \" \" + serialized.name + \"\\\"]\");\n\n if (cache.sheet.tags.length) {\n sheet.before = cache.sheet.tags[0];\n }\n\n if (node !== null) {\n rehydrating = true; // clear the hash so this node won't be recognizable as rehydratable by other s\n\n node.setAttribute('data-emotion', key);\n sheet.hydrate([node]);\n }\n\n sheetRef.current = [sheet, rehydrating];\n return function () {\n sheet.flush();\n };\n }, [cache]);\n useInsertionEffectWithLayoutFallback(function () {\n var sheetRefCurrent = sheetRef.current;\n var sheet = sheetRefCurrent[0],\n rehydrating = sheetRefCurrent[1];\n\n if (rehydrating) {\n sheetRefCurrent[1] = false;\n return;\n }\n\n if (serialized.next !== undefined) {\n // insert keyframes\n insertStyles(cache, serialized.next, true);\n }\n\n if (sheet.tags.length) {\n // if this doesn't exist then it will be null so the style element will be appended\n var element = sheet.tags[sheet.tags.length - 1].nextElementSibling;\n sheet.before = element;\n sheet.flush();\n }\n\n cache.insert(\"\", serialized, sheet, false);\n }, [cache, serialized.name]);\n return null;\n});\n\nif (process.env.NODE_ENV !== 'production') {\n Global.displayName = 'EmotionGlobal';\n}\n\nfunction css() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return serializeStyles(args);\n}\n\nvar keyframes = function keyframes() {\n var insertable = css.apply(void 0, arguments);\n var name = \"animation-\" + insertable.name; // $FlowFixMe\n\n return {\n name: name,\n styles: \"@keyframes \" + name + \"{\" + insertable.styles + \"}\",\n anim: 1,\n toString: function toString() {\n return \"_EMO_\" + this.name + \"_\" + this.styles + \"_EMO_\";\n }\n };\n};\n\nvar classnames = function classnames(args) {\n var len = args.length;\n var i = 0;\n var cls = '';\n\n for (; i < len; i++) {\n var arg = args[i];\n if (arg == null) continue;\n var toAdd = void 0;\n\n switch (typeof arg) {\n case 'boolean':\n break;\n\n case 'object':\n {\n if (Array.isArray(arg)) {\n toAdd = classnames(arg);\n } else {\n if (process.env.NODE_ENV !== 'production' && arg.styles !== undefined && arg.name !== undefined) {\n console.error('You have passed styles created with `css` from `@emotion/react` package to the `cx`.\\n' + '`cx` is meant to compose class names (strings) so you should convert those styles to a class name by passing them to the `css` received from component.');\n }\n\n toAdd = '';\n\n for (var k in arg) {\n if (arg[k] && k) {\n toAdd && (toAdd += ' ');\n toAdd += k;\n }\n }\n }\n\n break;\n }\n\n default:\n {\n toAdd = arg;\n }\n }\n\n if (toAdd) {\n cls && (cls += ' ');\n cls += toAdd;\n }\n }\n\n return cls;\n};\n\nfunction merge(registered, css, className) {\n var registeredStyles = [];\n var rawClassName = getRegisteredStyles(registered, registeredStyles, className);\n\n if (registeredStyles.length < 2) {\n return className;\n }\n\n return rawClassName + css(registeredStyles);\n}\n\nvar Insertion = function Insertion(_ref) {\n var cache = _ref.cache,\n serializedArr = _ref.serializedArr;\n useInsertionEffectAlwaysWithSyncFallback(function () {\n\n for (var i = 0; i < serializedArr.length; i++) {\n insertStyles(cache, serializedArr[i], false);\n }\n });\n\n return null;\n};\n\nvar ClassNames = /* #__PURE__ */withEmotionCache(function (props, cache) {\n var hasRendered = false;\n var serializedArr = [];\n\n var css = function css() {\n if (hasRendered && process.env.NODE_ENV !== 'production') {\n throw new Error('css can only be used during render');\n }\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n var serialized = serializeStyles(args, cache.registered);\n serializedArr.push(serialized); // registration has to happen here as the result of this might get consumed by `cx`\n\n registerStyles(cache, serialized, false);\n return cache.key + \"-\" + serialized.name;\n };\n\n var cx = function cx() {\n if (hasRendered && process.env.NODE_ENV !== 'production') {\n throw new Error('cx can only be used during render');\n }\n\n for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n\n return merge(cache.registered, css, classnames(args));\n };\n\n var content = {\n css: css,\n cx: cx,\n theme: React.useContext(ThemeContext)\n };\n var ele = props.children(content);\n hasRendered = true;\n return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Insertion, {\n cache: cache,\n serializedArr: serializedArr\n }), ele);\n});\n\nif (process.env.NODE_ENV !== 'production') {\n ClassNames.displayName = 'EmotionClassNames';\n}\n\nif (process.env.NODE_ENV !== 'production') {\n var isBrowser = \"object\" !== 'undefined'; // #1727, #2905 for some reason Jest and Vitest evaluate modules twice if some consuming module gets mocked\n\n var isTestEnv = typeof jest !== 'undefined' || typeof vi !== 'undefined';\n\n if (isBrowser && !isTestEnv) {\n // globalThis has wide browser support - https://caniuse.com/?search=globalThis, Node.js 12 and later\n var globalContext = // $FlowIgnore\n typeof globalThis !== 'undefined' ? globalThis // eslint-disable-line no-undef\n : isBrowser ? window : global;\n var globalKey = \"__EMOTION_REACT_\" + pkg.version.split('.')[0] + \"__\";\n\n if (globalContext[globalKey]) {\n console.warn('You are loading @emotion/react when it is already loaded. Running ' + 'multiple instances may cause problems. This can happen if multiple ' + 'versions are used, or if multiple builds of the same version are ' + 'used.');\n }\n\n globalContext[globalKey] = true;\n }\n}\n\nexport { ClassNames, Global, jsx as createElement, css, jsx, keyframes };\n","var unitlessKeys = {\n animationIterationCount: 1,\n aspectRatio: 1,\n borderImageOutset: 1,\n borderImageSlice: 1,\n borderImageWidth: 1,\n boxFlex: 1,\n boxFlexGroup: 1,\n boxOrdinalGroup: 1,\n columnCount: 1,\n columns: 1,\n flex: 1,\n flexGrow: 1,\n flexPositive: 1,\n flexShrink: 1,\n flexNegative: 1,\n flexOrder: 1,\n gridRow: 1,\n gridRowEnd: 1,\n gridRowSpan: 1,\n gridRowStart: 1,\n gridColumn: 1,\n gridColumnEnd: 1,\n gridColumnSpan: 1,\n gridColumnStart: 1,\n msGridRow: 1,\n msGridRowSpan: 1,\n msGridColumn: 1,\n msGridColumnSpan: 1,\n fontWeight: 1,\n lineHeight: 1,\n opacity: 1,\n order: 1,\n orphans: 1,\n tabSize: 1,\n widows: 1,\n zIndex: 1,\n zoom: 1,\n WebkitLineClamp: 1,\n // SVG-related properties\n fillOpacity: 1,\n floodOpacity: 1,\n stopOpacity: 1,\n strokeDasharray: 1,\n strokeDashoffset: 1,\n strokeMiterlimit: 1,\n strokeOpacity: 1,\n strokeWidth: 1\n};\n\nexport { unitlessKeys as default };\n","import hashString from '@emotion/hash';\nimport unitless from '@emotion/unitless';\nimport memoize from '@emotion/memoize';\n\nvar ILLEGAL_ESCAPE_SEQUENCE_ERROR = \"You have illegal escape sequence in your template literal, most likely inside content's property value.\\nBecause you write your CSS inside a JavaScript string you actually have to do double escaping, so for example \\\"content: '\\\\00d7';\\\" should become \\\"content: '\\\\\\\\00d7';\\\".\\nYou can read more about this here:\\nhttps://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Template_literals#ES2018_revision_of_illegal_escape_sequences\";\nvar UNDEFINED_AS_OBJECT_KEY_ERROR = \"You have passed in falsy value as style object's key (can happen when in example you pass unexported component as computed key).\";\nvar hyphenateRegex = /[A-Z]|^ms/g;\nvar animationRegex = /_EMO_([^_]+?)_([^]*?)_EMO_/g;\n\nvar isCustomProperty = function isCustomProperty(property) {\n return property.charCodeAt(1) === 45;\n};\n\nvar isProcessableValue = function isProcessableValue(value) {\n return value != null && typeof value !== 'boolean';\n};\n\nvar processStyleName = /* #__PURE__ */memoize(function (styleName) {\n return isCustomProperty(styleName) ? styleName : styleName.replace(hyphenateRegex, '-$&').toLowerCase();\n});\n\nvar processStyleValue = function processStyleValue(key, value) {\n switch (key) {\n case 'animation':\n case 'animationName':\n {\n if (typeof value === 'string') {\n return value.replace(animationRegex, function (match, p1, p2) {\n cursor = {\n name: p1,\n styles: p2,\n next: cursor\n };\n return p1;\n });\n }\n }\n }\n\n if (unitless[key] !== 1 && !isCustomProperty(key) && typeof value === 'number' && value !== 0) {\n return value + 'px';\n }\n\n return value;\n};\n\nif (process.env.NODE_ENV !== 'production') {\n var contentValuePattern = /(var|attr|counters?|url|element|(((repeating-)?(linear|radial))|conic)-gradient)\\(|(no-)?(open|close)-quote/;\n var contentValues = ['normal', 'none', 'initial', 'inherit', 'unset'];\n var oldProcessStyleValue = processStyleValue;\n var msPattern = /^-ms-/;\n var hyphenPattern = /-(.)/g;\n var hyphenatedCache = {};\n\n processStyleValue = function processStyleValue(key, value) {\n if (key === 'content') {\n if (typeof value !== 'string' || contentValues.indexOf(value) === -1 && !contentValuePattern.test(value) && (value.charAt(0) !== value.charAt(value.length - 1) || value.charAt(0) !== '\"' && value.charAt(0) !== \"'\")) {\n throw new Error(\"You seem to be using a value for 'content' without quotes, try replacing it with `content: '\\\"\" + value + \"\\\"'`\");\n }\n }\n\n var processed = oldProcessStyleValue(key, value);\n\n if (processed !== '' && !isCustomProperty(key) && key.indexOf('-') !== -1 && hyphenatedCache[key] === undefined) {\n hyphenatedCache[key] = true;\n console.error(\"Using kebab-case for css properties in objects is not supported. Did you mean \" + key.replace(msPattern, 'ms-').replace(hyphenPattern, function (str, _char) {\n return _char.toUpperCase();\n }) + \"?\");\n }\n\n return processed;\n };\n}\n\nvar noComponentSelectorMessage = 'Component selectors can only be used in conjunction with ' + '@emotion/babel-plugin, the swc Emotion plugin, or another Emotion-aware ' + 'compiler transform.';\n\nfunction handleInterpolation(mergedProps, registered, interpolation) {\n if (interpolation == null) {\n return '';\n }\n\n if (interpolation.__emotion_styles !== undefined) {\n if (process.env.NODE_ENV !== 'production' && interpolation.toString() === 'NO_COMPONENT_SELECTOR') {\n throw new Error(noComponentSelectorMessage);\n }\n\n return interpolation;\n }\n\n switch (typeof interpolation) {\n case 'boolean':\n {\n return '';\n }\n\n case 'object':\n {\n if (interpolation.anim === 1) {\n cursor = {\n name: interpolation.name,\n styles: interpolation.styles,\n next: cursor\n };\n return interpolation.name;\n }\n\n if (interpolation.styles !== undefined) {\n var next = interpolation.next;\n\n if (next !== undefined) {\n // not the most efficient thing ever but this is a pretty rare case\n // and there will be very few iterations of this generally\n while (next !== undefined) {\n cursor = {\n name: next.name,\n styles: next.styles,\n next: cursor\n };\n next = next.next;\n }\n }\n\n var styles = interpolation.styles + \";\";\n\n if (process.env.NODE_ENV !== 'production' && interpolation.map !== undefined) {\n styles += interpolation.map;\n }\n\n return styles;\n }\n\n return createStringFromObject(mergedProps, registered, interpolation);\n }\n\n case 'function':\n {\n if (mergedProps !== undefined) {\n var previousCursor = cursor;\n var result = interpolation(mergedProps);\n cursor = previousCursor;\n return handleInterpolation(mergedProps, registered, result);\n } else if (process.env.NODE_ENV !== 'production') {\n console.error('Functions that are interpolated in css calls will be stringified.\\n' + 'If you want to have a css call based on props, create a function that returns a css call like this\\n' + 'let dynamicStyle = (props) => css`color: ${props.color}`\\n' + 'It can be called directly with props or interpolated in a styled call like this\\n' + \"let SomeComponent = styled('div')`${dynamicStyle}`\");\n }\n\n break;\n }\n\n case 'string':\n if (process.env.NODE_ENV !== 'production') {\n var matched = [];\n var replaced = interpolation.replace(animationRegex, function (match, p1, p2) {\n var fakeVarName = \"animation\" + matched.length;\n matched.push(\"const \" + fakeVarName + \" = keyframes`\" + p2.replace(/^@keyframes animation-\\w+/, '') + \"`\");\n return \"${\" + fakeVarName + \"}\";\n });\n\n if (matched.length) {\n console.error('`keyframes` output got interpolated into plain string, please wrap it with `css`.\\n\\n' + 'Instead of doing this:\\n\\n' + [].concat(matched, [\"`\" + replaced + \"`\"]).join('\\n') + '\\n\\nYou should wrap it with `css` like this:\\n\\n' + (\"css`\" + replaced + \"`\"));\n }\n }\n\n break;\n } // finalize string values (regular strings and functions interpolated into css calls)\n\n\n if (registered == null) {\n return interpolation;\n }\n\n var cached = registered[interpolation];\n return cached !== undefined ? cached : interpolation;\n}\n\nfunction createStringFromObject(mergedProps, registered, obj) {\n var string = '';\n\n if (Array.isArray(obj)) {\n for (var i = 0; i < obj.length; i++) {\n string += handleInterpolation(mergedProps, registered, obj[i]) + \";\";\n }\n } else {\n for (var _key in obj) {\n var value = obj[_key];\n\n if (typeof value !== 'object') {\n if (registered != null && registered[value] !== undefined) {\n string += _key + \"{\" + registered[value] + \"}\";\n } else if (isProcessableValue(value)) {\n string += processStyleName(_key) + \":\" + processStyleValue(_key, value) + \";\";\n }\n } else {\n if (_key === 'NO_COMPONENT_SELECTOR' && process.env.NODE_ENV !== 'production') {\n throw new Error(noComponentSelectorMessage);\n }\n\n if (Array.isArray(value) && typeof value[0] === 'string' && (registered == null || registered[value[0]] === undefined)) {\n for (var _i = 0; _i < value.length; _i++) {\n if (isProcessableValue(value[_i])) {\n string += processStyleName(_key) + \":\" + processStyleValue(_key, value[_i]) + \";\";\n }\n }\n } else {\n var interpolated = handleInterpolation(mergedProps, registered, value);\n\n switch (_key) {\n case 'animation':\n case 'animationName':\n {\n string += processStyleName(_key) + \":\" + interpolated + \";\";\n break;\n }\n\n default:\n {\n if (process.env.NODE_ENV !== 'production' && _key === 'undefined') {\n console.error(UNDEFINED_AS_OBJECT_KEY_ERROR);\n }\n\n string += _key + \"{\" + interpolated + \"}\";\n }\n }\n }\n }\n }\n }\n\n return string;\n}\n\nvar labelPattern = /label:\\s*([^\\s;\\n{]+)\\s*(;|$)/g;\nvar sourceMapPattern;\n\nif (process.env.NODE_ENV !== 'production') {\n sourceMapPattern = /\\/\\*#\\ssourceMappingURL=data:application\\/json;\\S+\\s+\\*\\//g;\n} // this is the cursor for keyframes\n// keyframes are stored on the SerializedStyles object as a linked list\n\n\nvar cursor;\nvar serializeStyles = function serializeStyles(args, registered, mergedProps) {\n if (args.length === 1 && typeof args[0] === 'object' && args[0] !== null && args[0].styles !== undefined) {\n return args[0];\n }\n\n var stringMode = true;\n var styles = '';\n cursor = undefined;\n var strings = args[0];\n\n if (strings == null || strings.raw === undefined) {\n stringMode = false;\n styles += handleInterpolation(mergedProps, registered, strings);\n } else {\n if (process.env.NODE_ENV !== 'production' && strings[0] === undefined) {\n console.error(ILLEGAL_ESCAPE_SEQUENCE_ERROR);\n }\n\n styles += strings[0];\n } // we start at 1 since we've already handled the first arg\n\n\n for (var i = 1; i < args.length; i++) {\n styles += handleInterpolation(mergedProps, registered, args[i]);\n\n if (stringMode) {\n if (process.env.NODE_ENV !== 'production' && strings[i] === undefined) {\n console.error(ILLEGAL_ESCAPE_SEQUENCE_ERROR);\n }\n\n styles += strings[i];\n }\n }\n\n var sourceMap;\n\n if (process.env.NODE_ENV !== 'production') {\n styles = styles.replace(sourceMapPattern, function (match) {\n sourceMap = match;\n return '';\n });\n } // using a global regex with .exec is stateful so lastIndex has to be reset each time\n\n\n labelPattern.lastIndex = 0;\n var identifierName = '';\n var match; // https://esbench.com/bench/5b809c2cf2949800a0f61fb5\n\n while ((match = labelPattern.exec(styles)) !== null) {\n identifierName += '-' + // $FlowFixMe we know it's not null\n match[1];\n }\n\n var name = hashString(styles) + identifierName;\n\n if (process.env.NODE_ENV !== 'production') {\n // $FlowFixMe SerializedStyles type doesn't have toString property (and we don't want to add it)\n return {\n name: name,\n styles: styles,\n map: sourceMap,\n next: cursor,\n toString: function toString() {\n return \"You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).\";\n }\n };\n }\n\n return {\n name: name,\n styles: styles,\n next: cursor\n };\n};\n\nexport { serializeStyles };\n","/* eslint-disable */\n// Inspired by https://github.com/garycourt/murmurhash-js\n// Ported from https://github.com/aappleby/smhasher/blob/61a0530f28277f2e850bfc39600ce61d02b518de/src/MurmurHash2.cpp#L37-L86\nfunction murmur2(str) {\n // 'm' and 'r' are mixing constants generated offline.\n // They're not really 'magic', they just happen to work well.\n // const m = 0x5bd1e995;\n // const r = 24;\n // Initialize the hash\n var h = 0; // Mix 4 bytes at a time into the hash\n\n var k,\n i = 0,\n len = str.length;\n\n for (; len >= 4; ++i, len -= 4) {\n k = str.charCodeAt(i) & 0xff | (str.charCodeAt(++i) & 0xff) << 8 | (str.charCodeAt(++i) & 0xff) << 16 | (str.charCodeAt(++i) & 0xff) << 24;\n k =\n /* Math.imul(k, m): */\n (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16);\n k ^=\n /* k >>> r: */\n k >>> 24;\n h =\n /* Math.imul(k, m): */\n (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16) ^\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n } // Handle the last few bytes of the input array\n\n\n switch (len) {\n case 3:\n h ^= (str.charCodeAt(i + 2) & 0xff) << 16;\n\n case 2:\n h ^= (str.charCodeAt(i + 1) & 0xff) << 8;\n\n case 1:\n h ^= str.charCodeAt(i) & 0xff;\n h =\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n } // Do a few final mixes of the hash to ensure the last few\n // bytes are well-incorporated.\n\n\n h ^= h >>> 13;\n h =\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n return ((h ^ h >>> 15) >>> 0).toString(36);\n}\n\nexport { murmur2 as default };\n","import * as React from 'react';\n\nvar syncFallback = function syncFallback(create) {\n return create();\n};\n\nvar useInsertionEffect = React['useInsertion' + 'Effect'] ? React['useInsertion' + 'Effect'] : false;\nvar useInsertionEffectAlwaysWithSyncFallback = useInsertionEffect || syncFallback;\nvar useInsertionEffectWithLayoutFallback = useInsertionEffect || React.useLayoutEffect;\n\nexport { useInsertionEffectAlwaysWithSyncFallback, useInsertionEffectWithLayoutFallback };\n","var isBrowser = \"object\" !== 'undefined';\nfunction getRegisteredStyles(registered, registeredStyles, classNames) {\n var rawClassName = '';\n classNames.split(' ').forEach(function (className) {\n if (registered[className] !== undefined) {\n registeredStyles.push(registered[className] + \";\");\n } else {\n rawClassName += className + \" \";\n }\n });\n return rawClassName;\n}\nvar registerStyles = function registerStyles(cache, serialized, isStringTag) {\n var className = cache.key + \"-\" + serialized.name;\n\n if ( // we only need to add the styles to the registered cache if the\n // class name could be used further down\n // the tree but if it's a string tag, we know it won't\n // so we don't have to add it to registered cache.\n // this improves memory usage since we can avoid storing the whole style string\n (isStringTag === false || // we need to always store it if we're in compat mode and\n // in node since emotion-server relies on whether a style is in\n // the registered cache to know whether a style is global or not\n // also, note that this check will be dead code eliminated in the browser\n isBrowser === false ) && cache.registered[className] === undefined) {\n cache.registered[className] = serialized.styles;\n }\n};\nvar insertStyles = function insertStyles(cache, serialized, isStringTag) {\n registerStyles(cache, serialized, isStringTag);\n var className = cache.key + \"-\" + serialized.name;\n\n if (cache.inserted[serialized.name] === undefined) {\n var current = serialized;\n\n do {\n cache.insert(serialized === current ? \".\" + className : '', current, cache.sheet, true);\n\n current = current.next;\n } while (current !== undefined);\n }\n};\n\nexport { getRegisteredStyles, insertStyles, registerStyles };\n","'use client';\n\nimport * as React from 'react';\nimport * as ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport { exactProp, HTMLElementType, unstable_useEnhancedEffect as useEnhancedEffect, unstable_useForkRef as useForkRef, unstable_setRef as setRef } from '@mui/utils';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nfunction getContainer(container) {\n return typeof container === 'function' ? container() : container;\n}\n\n/**\n * Portals provide a first-class way to render children into a DOM node\n * that exists outside the DOM hierarchy of the parent component.\n *\n * Demos:\n *\n * - [Portal](https://mui.com/base-ui/react-portal/)\n *\n * API:\n *\n * - [Portal API](https://mui.com/base-ui/react-portal/components-api/#portal)\n */\nconst Portal = /*#__PURE__*/React.forwardRef(function Portal(props, forwardedRef) {\n const {\n children,\n container,\n disablePortal = false\n } = props;\n const [mountNode, setMountNode] = React.useState(null);\n // @ts-expect-error TODO upstream fix\n const handleRef = useForkRef( /*#__PURE__*/React.isValidElement(children) ? children.ref : null, forwardedRef);\n useEnhancedEffect(() => {\n if (!disablePortal) {\n setMountNode(getContainer(container) || document.body);\n }\n }, [container, disablePortal]);\n useEnhancedEffect(() => {\n if (mountNode && !disablePortal) {\n setRef(forwardedRef, mountNode);\n return () => {\n setRef(forwardedRef, null);\n };\n }\n return undefined;\n }, [forwardedRef, mountNode, disablePortal]);\n if (disablePortal) {\n if ( /*#__PURE__*/React.isValidElement(children)) {\n const newProps = {\n ref: handleRef\n };\n return /*#__PURE__*/React.cloneElement(children, newProps);\n }\n return /*#__PURE__*/_jsx(React.Fragment, {\n children: children\n });\n }\n return /*#__PURE__*/_jsx(React.Fragment, {\n children: mountNode ? /*#__PURE__*/ReactDOM.createPortal(children, mountNode) : mountNode\n });\n});\nprocess.env.NODE_ENV !== \"production\" ? Portal.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the TypeScript types and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * The children to render into the `container`.\n */\n children: PropTypes.node,\n /**\n * An HTML element or function that returns one.\n * The `container` will have the portal children appended to it.\n *\n * You can also provide a callback, which is called in a React layout effect.\n * This lets you set the container from a ref, and also makes server-side rendering possible.\n *\n * By default, it uses the body of the top-level document object,\n * so it's simply `document.body` most of the time.\n */\n container: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([HTMLElementType, PropTypes.func]),\n /**\n * The `children` will be under the DOM hierarchy of the parent component.\n * @default false\n */\n disablePortal: PropTypes.bool\n} : void 0;\nif (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line\n Portal['propTypes' + ''] = exactProp(Portal.propTypes);\n}\nexport { Portal };","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { isHostComponent } from './isHostComponent';\n\n/**\n * Type of the ownerState based on the type of an element it applies to.\n * This resolves to the provided OwnerState for React components and `undefined` for host components.\n * Falls back to `OwnerState | undefined` when the exact type can't be determined in development time.\n */\n\n/**\n * Appends the ownerState object to the props, merging with the existing one if necessary.\n *\n * @param elementType Type of the element that owns the `existingProps`. If the element is a DOM node or undefined, `ownerState` is not applied.\n * @param otherProps Props of the element.\n * @param ownerState\n */\nexport function appendOwnerState(elementType, otherProps, ownerState) {\n if (elementType === undefined || isHostComponent(elementType)) {\n return otherProps;\n }\n return _extends({}, otherProps, {\n ownerState: _extends({}, otherProps.ownerState, ownerState)\n });\n}","/**\n * Extracts event handlers from a given object.\n * A prop is considered an event handler if it is a function and its name starts with `on`.\n *\n * @param object An object to extract event handlers from.\n * @param excludeKeys An array of keys to exclude from the returned object.\n */\nexport function extractEventHandlers(object, excludeKeys = []) {\n if (object === undefined) {\n return {};\n }\n const result = {};\n Object.keys(object).filter(prop => prop.match(/^on[A-Z]/) && typeof object[prop] === 'function' && !excludeKeys.includes(prop)).forEach(prop => {\n result[prop] = object[prop];\n });\n return result;\n}","/**\n * Determines if a given element is a DOM element name (i.e. not a React component).\n */\nexport function isHostComponent(element) {\n return typeof element === 'string';\n}","/**\n * Removes event handlers from the given object.\n * A field is considered an event handler if it is a function with a name beginning with `on`.\n *\n * @param object Object to remove event handlers from.\n * @returns Object with event handlers removed.\n */\nexport function omitEventHandlers(object) {\n if (object === undefined) {\n return {};\n }\n const result = {};\n Object.keys(object).filter(prop => !(prop.match(/^on[A-Z]/) && typeof object[prop] === 'function')).forEach(prop => {\n result[prop] = object[prop];\n });\n return result;\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport clsx from 'clsx';\nimport { extractEventHandlers } from './extractEventHandlers';\nimport { omitEventHandlers } from './omitEventHandlers';\n/**\n * Merges the slot component internal props (usually coming from a hook)\n * with the externally provided ones.\n *\n * The merge order is (the latter overrides the former):\n * 1. The internal props (specified as a getter function to work with get*Props hook result)\n * 2. Additional props (specified internally on a Base UI component)\n * 3. External props specified on the owner component. These should only be used on a root slot.\n * 4. External props specified in the `slotProps.*` prop.\n * 5. The `className` prop - combined from all the above.\n * @param parameters\n * @returns\n */\nexport function mergeSlotProps(parameters) {\n const {\n getSlotProps,\n additionalProps,\n externalSlotProps,\n externalForwardedProps,\n className\n } = parameters;\n if (!getSlotProps) {\n // The simpler case - getSlotProps is not defined, so no internal event handlers are defined,\n // so we can simply merge all the props without having to worry about extracting event handlers.\n const joinedClasses = clsx(additionalProps == null ? void 0 : additionalProps.className, className, externalForwardedProps == null ? void 0 : externalForwardedProps.className, externalSlotProps == null ? void 0 : externalSlotProps.className);\n const mergedStyle = _extends({}, additionalProps == null ? void 0 : additionalProps.style, externalForwardedProps == null ? void 0 : externalForwardedProps.style, externalSlotProps == null ? void 0 : externalSlotProps.style);\n const props = _extends({}, additionalProps, externalForwardedProps, externalSlotProps);\n if (joinedClasses.length > 0) {\n props.className = joinedClasses;\n }\n if (Object.keys(mergedStyle).length > 0) {\n props.style = mergedStyle;\n }\n return {\n props,\n internalRef: undefined\n };\n }\n\n // In this case, getSlotProps is responsible for calling the external event handlers.\n // We don't need to include them in the merged props because of this.\n\n const eventHandlers = extractEventHandlers(_extends({}, externalForwardedProps, externalSlotProps));\n const componentsPropsWithoutEventHandlers = omitEventHandlers(externalSlotProps);\n const otherPropsWithoutEventHandlers = omitEventHandlers(externalForwardedProps);\n const internalSlotProps = getSlotProps(eventHandlers);\n\n // The order of classes is important here.\n // Emotion (that we use in libraries consuming Base UI) depends on this order\n // to properly override style. It requires the most important classes to be last\n // (see https://github.com/mui/material-ui/pull/33205) for the related discussion.\n const joinedClasses = clsx(internalSlotProps == null ? void 0 : internalSlotProps.className, additionalProps == null ? void 0 : additionalProps.className, className, externalForwardedProps == null ? void 0 : externalForwardedProps.className, externalSlotProps == null ? void 0 : externalSlotProps.className);\n const mergedStyle = _extends({}, internalSlotProps == null ? void 0 : internalSlotProps.style, additionalProps == null ? void 0 : additionalProps.style, externalForwardedProps == null ? void 0 : externalForwardedProps.style, externalSlotProps == null ? void 0 : externalSlotProps.style);\n const props = _extends({}, internalSlotProps, additionalProps, otherPropsWithoutEventHandlers, componentsPropsWithoutEventHandlers);\n if (joinedClasses.length > 0) {\n props.className = joinedClasses;\n }\n if (Object.keys(mergedStyle).length > 0) {\n props.style = mergedStyle;\n }\n return {\n props,\n internalRef: internalSlotProps.ref\n };\n}","/**\n * If `componentProps` is a function, calls it with the provided `ownerState`.\n * Otherwise, just returns `componentProps`.\n */\nexport function resolveComponentProps(componentProps, ownerState, slotState) {\n if (typeof componentProps === 'function') {\n return componentProps(ownerState, slotState);\n }\n return componentProps;\n}","'use client';\n\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nconst _excluded = [\"elementType\", \"externalSlotProps\", \"ownerState\", \"skipResolvingSlotProps\"];\nimport { unstable_useForkRef as useForkRef } from '@mui/utils';\nimport { appendOwnerState } from './appendOwnerState';\nimport { mergeSlotProps } from './mergeSlotProps';\nimport { resolveComponentProps } from './resolveComponentProps';\n/**\n * @ignore - do not document.\n * Builds the props to be passed into the slot of an unstyled component.\n * It merges the internal props of the component with the ones supplied by the user, allowing to customize the behavior.\n * If the slot component is not a host component, it also merges in the `ownerState`.\n *\n * @param parameters.getSlotProps - A function that returns the props to be passed to the slot component.\n */\nexport function useSlotProps(parameters) {\n var _parameters$additiona;\n const {\n elementType,\n externalSlotProps,\n ownerState,\n skipResolvingSlotProps = false\n } = parameters,\n rest = _objectWithoutPropertiesLoose(parameters, _excluded);\n const resolvedComponentsProps = skipResolvingSlotProps ? {} : resolveComponentProps(externalSlotProps, ownerState);\n const {\n props: mergedProps,\n internalRef\n } = mergeSlotProps(_extends({}, rest, {\n externalSlotProps: resolvedComponentsProps\n }));\n const ref = useForkRef(internalRef, resolvedComponentsProps == null ? void 0 : resolvedComponentsProps.ref, (_parameters$additiona = parameters.additionalProps) == null ? void 0 : _parameters$additiona.ref);\n const props = appendOwnerState(elementType, _extends({}, mergedProps, {\n ref\n }), ownerState);\n return props;\n}","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z\"\n}), 'Close');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M18.06 22.99h1.66c.84 0 1.53-.64 1.63-1.46L23 5.05h-5V1h-1.97v4.05h-4.97l.3 2.34c1.71.47 3.31 1.32 4.27 2.26 1.44 1.42 2.43 2.89 2.43 5.29zM1 21.99V21h15.03v.99c0 .55-.45 1-1.01 1H2.01c-.56 0-1.01-.45-1.01-1m15.03-7c0-8-15.03-8-15.03 0zM1.02 17h15v2h-15z\"\n}), 'Fastfood');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M19 3H5c-1.1 0-1.99.9-1.99 2L3 19c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2m-1 11h-4v4h-4v-4H6v-4h4V6h4v4h4z\"\n}), 'LocalHospital');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M3 18h18v-2H3zm0-5h18v-2H3zm0-7v2h18V6z\"\n}), 'Menu');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"m18 4 2 4h-3l-2-4h-2l2 4h-3l-2-4H8l2 4H7L5 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V4z\"\n}), 'Movie');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)([/*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n fillRule: \"evenodd\",\n d: \"M16.67 13.13C18.04 14.06 19 15.32 19 17v3h4v-3c0-2.18-3.57-3.47-6.33-3.87\"\n}, \"0\"), /*#__PURE__*/(0, _jsxRuntime.jsx)(\"circle\", {\n cx: \"9\",\n cy: \"8\",\n r: \"4\",\n fillRule: \"evenodd\"\n}, \"1\"), /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n fillRule: \"evenodd\",\n d: \"M15 12c2.21 0 4-1.79 4-4s-1.79-4-4-4c-.47 0-.91.1-1.33.24C14.5 5.27 15 6.58 15 8s-.5 2.73-1.33 3.76c.42.14.86.24 1.33.24m-6 1c-2.67 0-8 1.34-8 4v3h16v-3c0-2.66-5.33-4-8-4\"\n}, \"2\")], 'PeopleAlt');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M8 6.82v10.36c0 .79.87 1.27 1.54.84l8.14-5.18c.62-.39.62-1.29 0-1.69L9.54 5.98C8.87 5.55 8 6.03 8 6.82\"\n}), 'PlayArrowRounded');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M20 4H4v2h16zm1 10v-2l-1-5H4l-1 5v2h1v6h10v-6h4v6h2v-6zm-9 4H6v-4h6z\"\n}), 'Store');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M3 9v6h4l5 5V4L7 9zm13.5 3c0-1.77-1.02-3.29-2.5-4.03v8.05c1.48-.73 2.5-2.25 2.5-4.02M14 3.23v2.06c2.89.86 5 3.54 5 6.71s-2.11 5.85-5 6.71v2.06c4.01-.91 7-4.49 7-8.77s-2.99-7.86-7-8.77\"\n}), 'VolumeUp');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M20 6h-4V4c0-1.11-.89-2-2-2h-4c-1.11 0-2 .89-2 2v2H4c-1.11 0-1.99.89-1.99 2L2 19c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V8c0-1.11-.89-2-2-2m-6 0h-4V4h4z\"\n}), 'Work');","\"use strict\";\n'use client';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"default\", {\n enumerable: true,\n get: function () {\n return _utils.createSvgIcon;\n }\n});\nvar _utils = require(\"@mui/material/utils\");","'use client';\n\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nconst _excluded = [\"className\", \"component\"];\nimport * as React from 'react';\nimport clsx from 'clsx';\nimport styled from '@mui/styled-engine';\nimport styleFunctionSx, { extendSxProp } from './styleFunctionSx';\nimport useTheme from './useTheme';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default function createBox(options = {}) {\n const {\n themeId,\n defaultTheme,\n defaultClassName = 'MuiBox-root',\n generateClassName\n } = options;\n const BoxRoot = styled('div', {\n shouldForwardProp: prop => prop !== 'theme' && prop !== 'sx' && prop !== 'as'\n })(styleFunctionSx);\n const Box = /*#__PURE__*/React.forwardRef(function Box(inProps, ref) {\n const theme = useTheme(defaultTheme);\n const _extendSxProp = extendSxProp(inProps),\n {\n className,\n component = 'div'\n } = _extendSxProp,\n other = _objectWithoutPropertiesLoose(_extendSxProp, _excluded);\n return /*#__PURE__*/_jsx(BoxRoot, _extends({\n as: component,\n ref: ref,\n className: clsx(className, generateClassName ? generateClassName(defaultClassName) : defaultClassName),\n theme: themeId ? theme[themeId] || theme : theme\n }, other));\n });\n return Box;\n}","import generateUtilityClasses from '@mui/utils/generateUtilityClasses';\nconst boxClasses = generateUtilityClasses('MuiBox', ['root']);\nexport default boxClasses;","'use client';\n\nimport { createBox } from '@mui/system';\nimport PropTypes from 'prop-types';\nimport { unstable_ClassNameGenerator as ClassNameGenerator } from '../className';\nimport { createTheme } from '../styles';\nimport THEME_ID from '../styles/identifier';\nimport boxClasses from './boxClasses';\nconst defaultTheme = createTheme();\nconst Box = createBox({\n themeId: THEME_ID,\n defaultTheme,\n defaultClassName: boxClasses.root,\n generateClassName: ClassNameGenerator.generate\n});\nprocess.env.NODE_ENV !== \"production\" ? Box.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the d.ts file and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * @ignore\n */\n children: PropTypes.node,\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes.elementType,\n /**\n * The system prop that allows defining system overrides as well as additional CSS styles.\n */\n sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object])\n} : void 0;\nexport default Box;","'use client';\n\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\n\n/**\n * @ignore - internal component.\n */\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nfunction Ripple(props) {\n const {\n className,\n classes,\n pulsate = false,\n rippleX,\n rippleY,\n rippleSize,\n in: inProp,\n onExited,\n timeout\n } = props;\n const [leaving, setLeaving] = React.useState(false);\n const rippleClassName = clsx(className, classes.ripple, classes.rippleVisible, pulsate && classes.ripplePulsate);\n const rippleStyles = {\n width: rippleSize,\n height: rippleSize,\n top: -(rippleSize / 2) + rippleY,\n left: -(rippleSize / 2) + rippleX\n };\n const childClassName = clsx(classes.child, leaving && classes.childLeaving, pulsate && classes.childPulsate);\n if (!inProp && !leaving) {\n setLeaving(true);\n }\n React.useEffect(() => {\n if (!inProp && onExited != null) {\n // react-transition-group#onExited\n const timeoutId = setTimeout(onExited, timeout);\n return () => {\n clearTimeout(timeoutId);\n };\n }\n return undefined;\n }, [onExited, inProp, timeout]);\n return /*#__PURE__*/_jsx(\"span\", {\n className: rippleClassName,\n style: rippleStyles,\n children: /*#__PURE__*/_jsx(\"span\", {\n className: childClassName\n })\n });\n}\nprocess.env.NODE_ENV !== \"production\" ? Ripple.propTypes = {\n /**\n * Override or extend the styles applied to the component.\n */\n classes: PropTypes.object.isRequired,\n className: PropTypes.string,\n /**\n * @ignore - injected from TransitionGroup\n */\n in: PropTypes.bool,\n /**\n * @ignore - injected from TransitionGroup\n */\n onExited: PropTypes.func,\n /**\n * If `true`, the ripple pulsates, typically indicating the keyboard focus state of an element.\n */\n pulsate: PropTypes.bool,\n /**\n * Diameter of the ripple.\n */\n rippleSize: PropTypes.number,\n /**\n * Horizontal position of the ripple center.\n */\n rippleX: PropTypes.number,\n /**\n * Vertical position of the ripple center.\n */\n rippleY: PropTypes.number,\n /**\n * exit delay\n */\n timeout: PropTypes.number.isRequired\n} : void 0;\nexport default Ripple;","import generateUtilityClasses from '@mui/utils/generateUtilityClasses';\nimport generateUtilityClass from '@mui/utils/generateUtilityClass';\nexport function getTouchRippleUtilityClass(slot) {\n return generateUtilityClass('MuiTouchRipple', slot);\n}\nconst touchRippleClasses = generateUtilityClasses('MuiTouchRipple', ['root', 'ripple', 'rippleVisible', 'ripplePulsate', 'child', 'childLeaving', 'childPulsate']);\nexport default touchRippleClasses;","'use client';\n\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nconst _excluded = [\"center\", \"classes\", \"className\"];\nlet _ = t => t,\n _t,\n _t2,\n _t3,\n _t4;\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport { TransitionGroup } from 'react-transition-group';\nimport clsx from 'clsx';\nimport { keyframes } from '@mui/system';\nimport useTimeout from '@mui/utils/useTimeout';\nimport styled from '../styles/styled';\nimport useThemeProps from '../styles/useThemeProps';\nimport Ripple from './Ripple';\nimport touchRippleClasses from './touchRippleClasses';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst DURATION = 550;\nexport const DELAY_RIPPLE = 80;\nconst enterKeyframe = keyframes(_t || (_t = _`\n 0% {\n transform: scale(0);\n opacity: 0.1;\n }\n\n 100% {\n transform: scale(1);\n opacity: 0.3;\n }\n`));\nconst exitKeyframe = keyframes(_t2 || (_t2 = _`\n 0% {\n opacity: 1;\n }\n\n 100% {\n opacity: 0;\n }\n`));\nconst pulsateKeyframe = keyframes(_t3 || (_t3 = _`\n 0% {\n transform: scale(1);\n }\n\n 50% {\n transform: scale(0.92);\n }\n\n 100% {\n transform: scale(1);\n }\n`));\nexport const TouchRippleRoot = styled('span', {\n name: 'MuiTouchRipple',\n slot: 'Root'\n})({\n overflow: 'hidden',\n pointerEvents: 'none',\n position: 'absolute',\n zIndex: 0,\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n borderRadius: 'inherit'\n});\n\n// This `styled()` function invokes keyframes. `styled-components` only supports keyframes\n// in string templates. Do not convert these styles in JS object as it will break.\nexport const TouchRippleRipple = styled(Ripple, {\n name: 'MuiTouchRipple',\n slot: 'Ripple'\n})(_t4 || (_t4 = _`\n opacity: 0;\n position: absolute;\n\n &.${0} {\n opacity: 0.3;\n transform: scale(1);\n animation-name: ${0};\n animation-duration: ${0}ms;\n animation-timing-function: ${0};\n }\n\n &.${0} {\n animation-duration: ${0}ms;\n }\n\n & .${0} {\n opacity: 1;\n display: block;\n width: 100%;\n height: 100%;\n border-radius: 50%;\n background-color: currentColor;\n }\n\n & .${0} {\n opacity: 0;\n animation-name: ${0};\n animation-duration: ${0}ms;\n animation-timing-function: ${0};\n }\n\n & .${0} {\n position: absolute;\n /* @noflip */\n left: 0px;\n top: 0;\n animation-name: ${0};\n animation-duration: 2500ms;\n animation-timing-function: ${0};\n animation-iteration-count: infinite;\n animation-delay: 200ms;\n }\n`), touchRippleClasses.rippleVisible, enterKeyframe, DURATION, ({\n theme\n}) => theme.transitions.easing.easeInOut, touchRippleClasses.ripplePulsate, ({\n theme\n}) => theme.transitions.duration.shorter, touchRippleClasses.child, touchRippleClasses.childLeaving, exitKeyframe, DURATION, ({\n theme\n}) => theme.transitions.easing.easeInOut, touchRippleClasses.childPulsate, pulsateKeyframe, ({\n theme\n}) => theme.transitions.easing.easeInOut);\n\n/**\n * @ignore - internal component.\n *\n * TODO v5: Make private\n */\nconst TouchRipple = /*#__PURE__*/React.forwardRef(function TouchRipple(inProps, ref) {\n const props = useThemeProps({\n props: inProps,\n name: 'MuiTouchRipple'\n });\n const {\n center: centerProp = false,\n classes = {},\n className\n } = props,\n other = _objectWithoutPropertiesLoose(props, _excluded);\n const [ripples, setRipples] = React.useState([]);\n const nextKey = React.useRef(0);\n const rippleCallback = React.useRef(null);\n React.useEffect(() => {\n if (rippleCallback.current) {\n rippleCallback.current();\n rippleCallback.current = null;\n }\n }, [ripples]);\n\n // Used to filter out mouse emulated events on mobile.\n const ignoringMouseDown = React.useRef(false);\n // We use a timer in order to only show the ripples for touch \"click\" like events.\n // We don't want to display the ripple for touch scroll events.\n const startTimer = useTimeout();\n\n // This is the hook called once the previous timeout is ready.\n const startTimerCommit = React.useRef(null);\n const container = React.useRef(null);\n const startCommit = React.useCallback(params => {\n const {\n pulsate,\n rippleX,\n rippleY,\n rippleSize,\n cb\n } = params;\n setRipples(oldRipples => [...oldRipples, /*#__PURE__*/_jsx(TouchRippleRipple, {\n classes: {\n ripple: clsx(classes.ripple, touchRippleClasses.ripple),\n rippleVisible: clsx(classes.rippleVisible, touchRippleClasses.rippleVisible),\n ripplePulsate: clsx(classes.ripplePulsate, touchRippleClasses.ripplePulsate),\n child: clsx(classes.child, touchRippleClasses.child),\n childLeaving: clsx(classes.childLeaving, touchRippleClasses.childLeaving),\n childPulsate: clsx(classes.childPulsate, touchRippleClasses.childPulsate)\n },\n timeout: DURATION,\n pulsate: pulsate,\n rippleX: rippleX,\n rippleY: rippleY,\n rippleSize: rippleSize\n }, nextKey.current)]);\n nextKey.current += 1;\n rippleCallback.current = cb;\n }, [classes]);\n const start = React.useCallback((event = {}, options = {}, cb = () => {}) => {\n const {\n pulsate = false,\n center = centerProp || options.pulsate,\n fakeElement = false // For test purposes\n } = options;\n if ((event == null ? void 0 : event.type) === 'mousedown' && ignoringMouseDown.current) {\n ignoringMouseDown.current = false;\n return;\n }\n if ((event == null ? void 0 : event.type) === 'touchstart') {\n ignoringMouseDown.current = true;\n }\n const element = fakeElement ? null : container.current;\n const rect = element ? element.getBoundingClientRect() : {\n width: 0,\n height: 0,\n left: 0,\n top: 0\n };\n\n // Get the size of the ripple\n let rippleX;\n let rippleY;\n let rippleSize;\n if (center || event === undefined || event.clientX === 0 && event.clientY === 0 || !event.clientX && !event.touches) {\n rippleX = Math.round(rect.width / 2);\n rippleY = Math.round(rect.height / 2);\n } else {\n const {\n clientX,\n clientY\n } = event.touches && event.touches.length > 0 ? event.touches[0] : event;\n rippleX = Math.round(clientX - rect.left);\n rippleY = Math.round(clientY - rect.top);\n }\n if (center) {\n rippleSize = Math.sqrt((2 * rect.width ** 2 + rect.height ** 2) / 3);\n\n // For some reason the animation is broken on Mobile Chrome if the size is even.\n if (rippleSize % 2 === 0) {\n rippleSize += 1;\n }\n } else {\n const sizeX = Math.max(Math.abs((element ? element.clientWidth : 0) - rippleX), rippleX) * 2 + 2;\n const sizeY = Math.max(Math.abs((element ? element.clientHeight : 0) - rippleY), rippleY) * 2 + 2;\n rippleSize = Math.sqrt(sizeX ** 2 + sizeY ** 2);\n }\n\n // Touche devices\n if (event != null && event.touches) {\n // check that this isn't another touchstart due to multitouch\n // otherwise we will only clear a single timer when unmounting while two\n // are running\n if (startTimerCommit.current === null) {\n // Prepare the ripple effect.\n startTimerCommit.current = () => {\n startCommit({\n pulsate,\n rippleX,\n rippleY,\n rippleSize,\n cb\n });\n };\n // Delay the execution of the ripple effect.\n // We have to make a tradeoff with this delay value.\n startTimer.start(DELAY_RIPPLE, () => {\n if (startTimerCommit.current) {\n startTimerCommit.current();\n startTimerCommit.current = null;\n }\n });\n }\n } else {\n startCommit({\n pulsate,\n rippleX,\n rippleY,\n rippleSize,\n cb\n });\n }\n }, [centerProp, startCommit, startTimer]);\n const pulsate = React.useCallback(() => {\n start({}, {\n pulsate: true\n });\n }, [start]);\n const stop = React.useCallback((event, cb) => {\n startTimer.clear();\n\n // The touch interaction occurs too quickly.\n // We still want to show ripple effect.\n if ((event == null ? void 0 : event.type) === 'touchend' && startTimerCommit.current) {\n startTimerCommit.current();\n startTimerCommit.current = null;\n startTimer.start(0, () => {\n stop(event, cb);\n });\n return;\n }\n startTimerCommit.current = null;\n setRipples(oldRipples => {\n if (oldRipples.length > 0) {\n return oldRipples.slice(1);\n }\n return oldRipples;\n });\n rippleCallback.current = cb;\n }, [startTimer]);\n React.useImperativeHandle(ref, () => ({\n pulsate,\n start,\n stop\n }), [pulsate, start, stop]);\n return /*#__PURE__*/_jsx(TouchRippleRoot, _extends({\n className: clsx(touchRippleClasses.root, classes.root, className),\n ref: container\n }, other, {\n children: /*#__PURE__*/_jsx(TransitionGroup, {\n component: null,\n exit: true,\n children: ripples\n })\n }));\n});\nprocess.env.NODE_ENV !== \"production\" ? TouchRipple.propTypes = {\n /**\n * If `true`, the ripple starts at the center of the component\n * rather than at the point of interaction.\n */\n center: PropTypes.bool,\n /**\n * Override or extend the styles applied to the component.\n */\n classes: PropTypes.object,\n /**\n * @ignore\n */\n className: PropTypes.string\n} : void 0;\nexport default TouchRipple;","import generateUtilityClasses from '@mui/utils/generateUtilityClasses';\nimport generateUtilityClass from '@mui/utils/generateUtilityClass';\nexport function getButtonBaseUtilityClass(slot) {\n return generateUtilityClass('MuiButtonBase', slot);\n}\nconst buttonBaseClasses = generateUtilityClasses('MuiButtonBase', ['root', 'disabled', 'focusVisible']);\nexport default buttonBaseClasses;","'use client';\n\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nconst _excluded = [\"action\", \"centerRipple\", \"children\", \"className\", \"component\", \"disabled\", \"disableRipple\", \"disableTouchRipple\", \"focusRipple\", \"focusVisibleClassName\", \"LinkComponent\", \"onBlur\", \"onClick\", \"onContextMenu\", \"onDragLeave\", \"onFocus\", \"onFocusVisible\", \"onKeyDown\", \"onKeyUp\", \"onMouseDown\", \"onMouseLeave\", \"onMouseUp\", \"onTouchEnd\", \"onTouchMove\", \"onTouchStart\", \"tabIndex\", \"TouchRippleProps\", \"touchRippleRef\", \"type\"];\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport refType from '@mui/utils/refType';\nimport elementTypeAcceptingRef from '@mui/utils/elementTypeAcceptingRef';\nimport composeClasses from '@mui/utils/composeClasses';\nimport styled from '../styles/styled';\nimport useThemeProps from '../styles/useThemeProps';\nimport useForkRef from '../utils/useForkRef';\nimport useEventCallback from '../utils/useEventCallback';\nimport useIsFocusVisible from '../utils/useIsFocusVisible';\nimport TouchRipple from './TouchRipple';\nimport buttonBaseClasses, { getButtonBaseUtilityClass } from './buttonBaseClasses';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport { jsxs as _jsxs } from \"react/jsx-runtime\";\nconst useUtilityClasses = ownerState => {\n const {\n disabled,\n focusVisible,\n focusVisibleClassName,\n classes\n } = ownerState;\n const slots = {\n root: ['root', disabled && 'disabled', focusVisible && 'focusVisible']\n };\n const composedClasses = composeClasses(slots, getButtonBaseUtilityClass, classes);\n if (focusVisible && focusVisibleClassName) {\n composedClasses.root += ` ${focusVisibleClassName}`;\n }\n return composedClasses;\n};\nexport const ButtonBaseRoot = styled('button', {\n name: 'MuiButtonBase',\n slot: 'Root',\n overridesResolver: (props, styles) => styles.root\n})({\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n position: 'relative',\n boxSizing: 'border-box',\n WebkitTapHighlightColor: 'transparent',\n backgroundColor: 'transparent',\n // Reset default value\n // We disable the focus ring for mouse, touch and keyboard users.\n outline: 0,\n border: 0,\n margin: 0,\n // Remove the margin in Safari\n borderRadius: 0,\n padding: 0,\n // Remove the padding in Firefox\n cursor: 'pointer',\n userSelect: 'none',\n verticalAlign: 'middle',\n MozAppearance: 'none',\n // Reset\n WebkitAppearance: 'none',\n // Reset\n textDecoration: 'none',\n // So we take precedent over the style of a native element.\n color: 'inherit',\n '&::-moz-focus-inner': {\n borderStyle: 'none' // Remove Firefox dotted outline.\n },\n [`&.${buttonBaseClasses.disabled}`]: {\n pointerEvents: 'none',\n // Disable link interactions\n cursor: 'default'\n },\n '@media print': {\n colorAdjust: 'exact'\n }\n});\n\n/**\n * `ButtonBase` contains as few styles as possible.\n * It aims to be a simple building block for creating a button.\n * It contains a load of style reset and some focus/ripple logic.\n */\nconst ButtonBase = /*#__PURE__*/React.forwardRef(function ButtonBase(inProps, ref) {\n const props = useThemeProps({\n props: inProps,\n name: 'MuiButtonBase'\n });\n const {\n action,\n centerRipple = false,\n children,\n className,\n component = 'button',\n disabled = false,\n disableRipple = false,\n disableTouchRipple = false,\n focusRipple = false,\n LinkComponent = 'a',\n onBlur,\n onClick,\n onContextMenu,\n onDragLeave,\n onFocus,\n onFocusVisible,\n onKeyDown,\n onKeyUp,\n onMouseDown,\n onMouseLeave,\n onMouseUp,\n onTouchEnd,\n onTouchMove,\n onTouchStart,\n tabIndex = 0,\n TouchRippleProps,\n touchRippleRef,\n type\n } = props,\n other = _objectWithoutPropertiesLoose(props, _excluded);\n const buttonRef = React.useRef(null);\n const rippleRef = React.useRef(null);\n const handleRippleRef = useForkRef(rippleRef, touchRippleRef);\n const {\n isFocusVisibleRef,\n onFocus: handleFocusVisible,\n onBlur: handleBlurVisible,\n ref: focusVisibleRef\n } = useIsFocusVisible();\n const [focusVisible, setFocusVisible] = React.useState(false);\n if (disabled && focusVisible) {\n setFocusVisible(false);\n }\n React.useImperativeHandle(action, () => ({\n focusVisible: () => {\n setFocusVisible(true);\n buttonRef.current.focus();\n }\n }), []);\n const [mountedState, setMountedState] = React.useState(false);\n React.useEffect(() => {\n setMountedState(true);\n }, []);\n const enableTouchRipple = mountedState && !disableRipple && !disabled;\n React.useEffect(() => {\n if (focusVisible && focusRipple && !disableRipple && mountedState) {\n rippleRef.current.pulsate();\n }\n }, [disableRipple, focusRipple, focusVisible, mountedState]);\n function useRippleHandler(rippleAction, eventCallback, skipRippleAction = disableTouchRipple) {\n return useEventCallback(event => {\n if (eventCallback) {\n eventCallback(event);\n }\n const ignore = skipRippleAction;\n if (!ignore && rippleRef.current) {\n rippleRef.current[rippleAction](event);\n }\n return true;\n });\n }\n const handleMouseDown = useRippleHandler('start', onMouseDown);\n const handleContextMenu = useRippleHandler('stop', onContextMenu);\n const handleDragLeave = useRippleHandler('stop', onDragLeave);\n const handleMouseUp = useRippleHandler('stop', onMouseUp);\n const handleMouseLeave = useRippleHandler('stop', event => {\n if (focusVisible) {\n event.preventDefault();\n }\n if (onMouseLeave) {\n onMouseLeave(event);\n }\n });\n const handleTouchStart = useRippleHandler('start', onTouchStart);\n const handleTouchEnd = useRippleHandler('stop', onTouchEnd);\n const handleTouchMove = useRippleHandler('stop', onTouchMove);\n const handleBlur = useRippleHandler('stop', event => {\n handleBlurVisible(event);\n if (isFocusVisibleRef.current === false) {\n setFocusVisible(false);\n }\n if (onBlur) {\n onBlur(event);\n }\n }, false);\n const handleFocus = useEventCallback(event => {\n // Fix for https://github.com/facebook/react/issues/7769\n if (!buttonRef.current) {\n buttonRef.current = event.currentTarget;\n }\n handleFocusVisible(event);\n if (isFocusVisibleRef.current === true) {\n setFocusVisible(true);\n if (onFocusVisible) {\n onFocusVisible(event);\n }\n }\n if (onFocus) {\n onFocus(event);\n }\n });\n const isNonNativeButton = () => {\n const button = buttonRef.current;\n return component && component !== 'button' && !(button.tagName === 'A' && button.href);\n };\n\n /**\n * IE11 shim for https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent/repeat\n */\n const keydownRef = React.useRef(false);\n const handleKeyDown = useEventCallback(event => {\n // Check if key is already down to avoid repeats being counted as multiple activations\n if (focusRipple && !keydownRef.current && focusVisible && rippleRef.current && event.key === ' ') {\n keydownRef.current = true;\n rippleRef.current.stop(event, () => {\n rippleRef.current.start(event);\n });\n }\n if (event.target === event.currentTarget && isNonNativeButton() && event.key === ' ') {\n event.preventDefault();\n }\n if (onKeyDown) {\n onKeyDown(event);\n }\n\n // Keyboard accessibility for non interactive elements\n if (event.target === event.currentTarget && isNonNativeButton() && event.key === 'Enter' && !disabled) {\n event.preventDefault();\n if (onClick) {\n onClick(event);\n }\n }\n });\n const handleKeyUp = useEventCallback(event => {\n // calling preventDefault in keyUp on a